@import "https://fonts.googleapis.com/css2?family=Lexend+Deca:wght@200;300;400;500;600;700&display=swap";
:root{--primary:#1e293b;--primary-hover:#0f172a;--primary-light:#e2e8f0;--primary-gradient:linear-gradient(135deg, #1e293b 0%, #0f172a 100%);--accent:#6366f1;--accent-hover:#4f46e5;--accent-light:#eef2ff;--accent-gradient:linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);--bg-page:#f1f5f9;--bg-sidebar:#fff;--bg-card:#fff;--text-heading:#0f172a;--text-main:#334155;--text-muted:#64748b;--text-light:#94a3b8;--border:#e2e8f0;--border-light:#f1f5f9;--shadow-sm:0 1px 2px #0000000d;--shadow-card:0 4px 24px -4px #0000000f;--shadow-btn:0 4px 12px #6366f140;--shadow-btn-hover:0 6px 16px #6366f159;--success-bg:#ecfdf5;--success-border:#a7f3d0;--success-text:#059669;--warning-bg:#fffbeb;--warning-border:#fde68a;--warning-text:#d97706;--error-bg:#fef2f2;--error-border:#fecaca;--error-text:#ef4444;--info-bg:#eef2ff;--info-border:#c7d2fe;--info-text:#4f46e5;--sidebar-w:260px;--header-h:0px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:var(--text-main);background:var(--bg-page);-webkit-font-smoothing:antialiased;font-family:Lexend Deca,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.admin-layout{min-height:100vh;display:flex}.admin-sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border);z-index:50;flex-direction:column;height:100vh;transition:transform .3s;display:flex;position:fixed;top:0;left:0}.sidebar-brand{border-bottom:1px solid var(--border-light);align-items:center;gap:.75rem;padding:1.5rem 1.25rem;display:flex}.sidebar-brand-logo{background:var(--accent-gradient);color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.15rem;font-weight:700;display:flex;box-shadow:0 4px 12px #6366f14d}.sidebar-brand-text h2{color:var(--text-heading);font-size:1rem;font-weight:700;line-height:1.2}.sidebar-brand-text span{color:var(--accent);letter-spacing:.02em;font-size:.7rem;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:.15rem;padding:1rem .75rem;display:flex;overflow-y:auto}.sidebar-link{color:var(--text-muted);border-radius:10px;align-items:center;gap:.65rem;padding:.65rem .85rem;font-size:.88rem;font-weight:500;transition:all .2s;display:flex}.sidebar-link ion-icon{font-size:1.25rem}.sidebar-link:hover{background:var(--border-light);color:var(--text-heading)}.sidebar-link.active{background:var(--accent-light);color:var(--accent);font-weight:600}.sidebar-footer{border-top:1px solid var(--border-light);padding:1rem 1.25rem}.sidebar-footer-profile{cursor:pointer;border-radius:10px;align-items:center;gap:.65rem;padding:.5rem;transition:background .2s;display:flex}.sidebar-footer-profile:hover{background:var(--border-light)}.sidebar-avatar{background:var(--accent-gradient);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.75rem;font-weight:600;display:flex}.sidebar-footer-name{color:var(--text-heading);text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:600;overflow:hidden}.sidebar-footer-email{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.68rem;overflow:hidden}.admin-main{margin-left:var(--sidebar-w);min-height:100vh;width:calc(100% - var(--sidebar-w));flex:1;padding:1.5rem 2rem}.mobile-header{z-index:40;border-bottom:1px solid var(--border);background:#fff;justify-content:space-between;align-items:center;height:56px;padding:0 1rem;display:none;position:sticky;top:0}.mobile-header-left{align-items:center;gap:.75rem;display:flex}.mobile-header-title{color:var(--text-heading);font-size:.95rem;font-weight:600}.mobile-header-btn{color:var(--text-muted);background:0 0;border:none;align-items:center;padding:.25rem;font-size:1.5rem;display:flex}.mobile-overlay{z-index:45;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;display:none;position:fixed;inset:0}@media (max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{z-index:50;transform:translate(-100%)}.admin-sidebar.open{transform:translate(0)}.mobile-overlay.visible{display:block}.mobile-header{display:flex}.admin-main{width:100%;min-height:calc(100vh - 56px);margin-left:0;padding:1rem}}.content-card{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:20px;min-height:calc(100vh - 3rem);padding:2rem 2.25rem}@media (max-width:768px){.content-card{border-radius:14px;min-height:auto;padding:1.25rem}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.75rem;display:flex}.page-header h1{color:var(--text-heading);margin-bottom:.2rem;font-size:1.5rem;font-weight:700}@media (max-width:768px){.page-header h1{font-size:1.25rem}}.page-subtitle{color:var(--text-muted);font-size:.85rem;font-weight:400}.btn{cursor:pointer;border:none;border-radius:9999px;justify-content:center;align-items:center;gap:.45rem;padding:.6rem 1.25rem;font-family:Lexend Deca,sans-serif;font-size:.85rem;font-weight:500;transition:all .2s;display:inline-flex}.btn ion-icon{font-size:1.1rem}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-btn)}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-btn-hover);transform:translateY(-1px)}.btn-outline{border:1px solid var(--border);color:var(--text-main);background:0 0}.btn-outline:hover{background:var(--bg-page);border-color:var(--accent-light)}.btn-ghost{color:var(--text-muted);background:0 0;border:none;padding:.4rem .75rem}.btn-ghost:hover{color:var(--accent);background:var(--accent-light)}.btn-danger{background:var(--error-text);color:#fff}.btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.btn-success{background:var(--success-text);color:#fff}.btn-success:hover{background:#047857;transform:translateY(-1px)}.btn-sm{padding:.4rem .9rem;font-size:.78rem}.btn-xs{padding:.3rem .7rem;font-size:.72rem}.btn-icon{width:36px;height:36px;color:var(--text-light);background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;padding:0;font-size:1.2rem;transition:all .2s;display:flex}.btn-icon:hover{color:var(--accent);background:var(--accent-light)}.btn:disabled{opacity:.5;pointer-events:none}.badge{white-space:nowrap;border:1px solid #0000;border-radius:9999px;align-items:center;gap:.3rem;padding:.25em .7em;font-size:.7rem;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}.badge-warning{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}.badge-error{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.badge-info{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}.badge-neutral{border-color:var(--border);color:var(--text-muted);background:#f9fafb}.form-group{margin-bottom:1.25rem}.form-label{color:var(--text-heading);margin-bottom:.4rem;font-size:.82rem;font-weight:500;display:block}.form-input{border:1px solid var(--border);width:100%;color:var(--text-heading);background:#fff;border-radius:10px;padding:.6rem 1rem;font-size:.88rem;transition:all .2s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.form-input::placeholder{color:var(--text-light)}.form-error{color:var(--error-text);margin-top:.3rem;font-size:.75rem}.form-input-error{border-color:var(--error-text)!important}.search-box{border:1px solid var(--border);background:#fff;border-radius:10px;align-items:center;gap:.5rem;width:100%;max-width:320px;padding:.5rem 1rem;transition:all .2s;display:flex}.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.search-box ion-icon{color:var(--text-light);flex-shrink:0;font-size:1.15rem}.search-box input{width:100%;color:var(--text-heading);background:0 0;border:none;outline:none;font-size:.85rem}.search-box input::placeholder{color:var(--text-light)}.filter-bar{scrollbar-width:none;align-items:center;gap:.5rem;margin-bottom:1.25rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.filter-chip{white-space:nowrap;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:#fff;border-radius:9999px;padding:.4rem .9rem;font-size:.78rem;font-weight:500;transition:all .2s}.filter-chip:hover{border-color:var(--accent-light);color:var(--accent)}.filter-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.toggle{cursor:pointer;flex-shrink:0;width:44px;height:24px;position:relative}.toggle-slider{background:var(--border);cursor:pointer;border-radius:99px;transition:all .25s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .25s;position:absolute;bottom:3px;left:3px;box-shadow:0 1px 3px #00000026}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.stats-grid{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}@media (max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:500px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);border-radius:16px;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;transition:box-shadow .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow-card)}.stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.stat-label{color:var(--text-muted);margin-bottom:.25rem;font-size:.78rem;font-weight:500}.stat-value{color:var(--text-heading);font-size:1.35rem;font-weight:700}.data-table{border-collapse:separate;border-spacing:0;width:100%}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.data-table td{color:var(--text-main);border-bottom:1px solid var(--border-light);vertical-align:middle;padding:.85rem 1rem;font-size:.85rem}.data-table tbody tr{transition:background .15s}.data-table tbody tr:hover{background:var(--border-light)}.data-table .vendor-info{align-items:center;gap:.75rem;display:flex}.data-table .vendor-logo{object-fit:cover;background:var(--border-light);width:36px;height:36px;color:var(--text-muted);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:600;display:flex;overflow:hidden}.data-table .vendor-logo img{object-fit:cover;width:100%;height:100%}.data-table .vendor-name{color:var(--text-heading);font-size:.88rem;font-weight:600}.data-table .vendor-slug{color:var(--text-light);font-size:.72rem}.data-table .actions-cell{align-items:center;gap:.35rem;display:flex}.table-wrap{margin:0 -.5rem;padding:0 .5rem;overflow-x:auto}.pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:.35rem;margin-top:1.5rem;display:flex}.pagination button{border:1px solid var(--border);min-width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;font-size:.8rem;font-weight:500;transition:all .2s;display:flex}.pagination button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.pagination button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.pagination button:disabled{opacity:.4;cursor:default}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:20px;width:90%;max-width:480px;padding:2rem;animation:.25s slideUp;box-shadow:0 20px 60px #00000026}@media (max-width:768px){.modal-content{padding:1.5rem}}.modal-title{color:var(--text-heading);margin-bottom:.5rem;font-size:1.15rem;font-weight:700}.modal-subtitle{color:var(--text-muted);margin-bottom:1.5rem;font-size:.85rem}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}@media (max-width:768px){.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{z-index:200;flex-direction:column;gap:.5rem;display:flex;position:fixed;top:1.25rem;right:1.25rem}@media (max-width:768px){.toast-container{align-items:center;inset:1rem 1rem auto}}.toast{color:var(--text-heading);border-left:4px solid var(--accent);background:#fff;border-radius:12px;align-items:center;gap:.75rem;min-width:280px;padding:.85rem 1.25rem;font-size:.85rem;font-weight:500;animation:.3s slideInRight;display:flex;box-shadow:0 8px 30px #0000001f}@media (max-width:768px){.toast{width:100%;min-width:auto}}.toast.success{border-left-color:var(--success-text);background:var(--success-bg);color:var(--success-text)}.toast.error{border-left-color:var(--error-text);background:var(--error-bg);color:var(--error-text)}.toast.warning{border-left-color:var(--warning-text);background:var(--warning-bg);color:var(--warning-text)}.toast ion-icon{flex-shrink:0;font-size:1.2rem}.toast-close{color:inherit;opacity:.7;cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:1.15rem;transition:opacity .2s;display:flex}.toast-close:hover{opacity:1}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.login-page{background:linear-gradient(135deg,#0f172a 0%,#1e293b 40%,#334155 100%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle,#6366f126,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;top:-100px;right:-100px}.login-page:after{content:"";background:radial-gradient(circle,#6366f11a,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-100px;left:-100px}.login-card{z-index:1;background:#fff;border-radius:24px;width:100%;max-width:420px;padding:2.5rem;position:relative;box-shadow:0 20px 60px #0000004d}@media (max-width:768px){.login-card{border-radius:20px;padding:1.5rem}}.login-brand{text-align:center;margin-bottom:2rem}.login-brand-logo{background:var(--accent-gradient);color:#fff;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:.75rem;font-size:1.4rem;font-weight:700;display:inline-flex;box-shadow:0 4px 14px #6366f14d}.login-brand h1{color:var(--text-heading);font-size:1.35rem;font-weight:700}.login-brand p{color:var(--text-muted);margin-top:.25rem;font-size:.82rem}.login-alert{background:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border);border-radius:10px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.82rem;display:flex}.login-alert ion-icon{flex-shrink:0;font-size:1.1rem}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1.5rem}.empty-state ion-icon{color:var(--text-light);margin-bottom:.75rem;font-size:3rem}.empty-state h3{color:var(--text-heading);margin-bottom:.35rem;font-size:1.1rem;font-weight:600}.empty-state p{font-size:.85rem}.loading-center{justify-content:center;align-items:center;min-height:200px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.profile-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media (max-width:768px){.profile-grid{grid-template-columns:1fr;gap:1rem}}.profile-section{background:var(--bg-card);border:1px solid var(--border-light);border-radius:16px;padding:1.75rem}@media (max-width:768px){.profile-section{border-radius:12px;padding:1.25rem}}.profile-section-title{color:var(--text-heading);align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:1rem;font-weight:600;display:flex}.profile-section-title ion-icon{color:var(--accent);font-size:1.2rem}.profile-info-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.profile-info-row:last-child{border-bottom:none}.profile-info-label{color:var(--text-muted);font-size:.82rem;font-weight:500}.profile-info-value{color:var(--text-heading);font-size:.88rem;font-weight:500}.detail-header{flex-wrap:wrap;align-items:center;gap:1.25rem;margin-bottom:2rem;display:flex}.detail-logo{background:var(--accent-light);width:64px;height:64px;color:var(--accent);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:flex;overflow:hidden}.detail-logo img{object-fit:cover;width:100%;height:100%}.detail-title{color:var(--text-heading);font-size:1.35rem;font-weight:700}.detail-meta{flex-wrap:wrap;gap:.75rem;margin-top:.35rem;display:flex}.detail-meta span{color:var(--text-muted);align-items:center;gap:.3rem;font-size:.78rem;display:flex}.detail-meta ion-icon{font-size:.9rem}.detail-actions{flex-wrap:wrap;gap:.5rem;margin-left:auto;display:flex}@media (max-width:768px){.detail-actions{width:100%;margin-left:0}.detail-actions button{flex:1}}.toggle{flex-shrink:0;width:44px;height:24px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:var(--border);border-radius:34px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s;position:absolute;bottom:3px;left:3px;box-shadow:0 1px 3px #00000026}input:checked+.toggle-slider{background-color:var(--accent)}input:checked+.toggle-slider:before{transform:translate(20px)}input:disabled+.toggle-slider{opacity:.6;cursor:not-allowed}
