@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&display=swap";:root{--bg-main: #eef3ff;--bg-panel: #ffffff;--bg-soft: #f6f8ff;--text-strong: #14213d;--text-muted: #5f6f8b;--line: #d8e1f3;--brand: #2457e6;--brand-2: #0e8f90;--brand-3: #7b5cff;--warn: #d97706;--danger: #c9382f;--ok: #0f9d58;--shadow: 0 28px 60px rgba(25, 44, 95, .14);font-family:Plus Jakarta Sans,sans-serif;color:var(--text-strong);background:var(--bg-main);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 10% 8%,rgba(36,87,230,.16),transparent 34%),radial-gradient(circle at 86% 16%,rgba(14,143,144,.16),transparent 28%),radial-gradient(circle at 78% 70%,rgba(123,92,255,.08),transparent 24%),linear-gradient(180deg,#f8faff,#edf2ff);color:var(--text-strong)}button,input,select,textarea{font:inherit}#root{min-height:100vh}h1,h2,h3,h4{font-family:Space Grotesk,sans-serif;letter-spacing:-.02em;margin:0}p{margin:0}.auth-root{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-panel{width:min(460px,100%);background:var(--bg-panel);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:32px;display:grid;gap:16px}.auth-kicker{color:var(--brand-2);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:12px}.auth-subtitle{color:var(--text-muted)}.auth-form{display:grid;gap:12px}.auth-form label,.inline-form label{display:grid;gap:6px;color:var(--text-muted);font-size:14px}input,select,textarea{width:100%;border:1px solid #ced9f2;background:#fff;border-radius:14px;padding:11px 13px;color:var(--text-strong);transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}textarea{resize:vertical;min-height:96px}input:focus,select:focus,textarea:focus{outline:2px solid rgba(37,85,232,.16);border-color:var(--brand);box-shadow:0 0 0 4px #2555e81a;background:#fcfdff}.primary-btn,.secondary-btn,.text-btn,.mobile-menu-btn{border:none;border-radius:14px;cursor:pointer;transition:transform .2s ease,opacity .2s ease,box-shadow .2s ease}.primary-btn{background:linear-gradient(125deg,var(--brand),#3789f8);color:#fff;padding:10px 16px;font-weight:700;box-shadow:0 10px 22px #2555e847}.primary-btn:hover,.secondary-btn:hover,.mobile-menu-btn:hover{transform:translateY(-1px)}.primary-btn:disabled,.secondary-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.secondary-btn{background:#edf2ff;color:#2c4fb3;padding:10px 16px;font-weight:700;border:1px solid #cfdbfb}.text-btn{background:transparent;color:var(--text-muted);padding:8px 0;text-align:left}.form-error{color:var(--danger);font-size:13px}.form-success{color:var(--ok);font-size:13px}.splash{min-height:100vh;display:grid;place-items:center;color:var(--text-muted)}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{border-right:1px solid var(--line);background:radial-gradient(circle at top left,rgba(123,92,255,.14),transparent 34%),linear-gradient(180deg,#f8faff,#edf2ff);padding:18px 14px;display:grid;grid-template-rows:auto 1fr auto;gap:18px}.brand-block{display:flex;align-items:center;gap:12px;padding:12px 12px 16px;border-radius:20px;background:linear-gradient(135deg,#ffffffeb,#f1f5ffd1);border:1px solid rgba(216,225,243,.9);box-shadow:0 18px 34px #22356814}.brand-mark{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--brand-3) 58%,var(--brand-2));color:#fff;box-shadow:0 14px 30px #2457e642}.brand-mark svg{width:22px;height:22px}.brand-block h1{font-size:20px}.brand-block p{color:var(--text-muted);font-size:13px}.sidebar nav{display:grid;align-content:start;gap:6px}.nav-link{border:1px solid transparent;background:#ffffff8a;padding:11px 12px;border-radius:16px;color:var(--text-muted);display:flex;gap:10px;align-items:center;text-align:left;cursor:pointer;transition:transform .2s ease,border-color .2s ease,background-color .2s ease,box-shadow .2s ease}.nav-link:hover{transform:translateY(-1px);border-color:#d8e2ff;background:#ffffffe0;box-shadow:0 10px 24px #1c2d6014}.nav-link-icon{width:38px;height:38px;flex-shrink:0;border-radius:12px;display:grid;place-items:center;background:#edf2ff;color:#4d64c7}.nav-link-icon svg{width:18px;height:18px}.nav-link-copy{display:grid;gap:2px}.nav-link-copy strong,.nav-link-copy small{display:block}.nav-link-copy strong{font-size:14px}.nav-link-copy small{color:var(--text-muted);font-size:11px}.nav-link.active{background:linear-gradient(135deg,#eef3ff,#e8fbfb);border-color:#c6d8ff;color:#1e43a2;font-weight:700;box-shadow:0 16px 30px #2457e61a}.nav-link.active .nav-link-icon{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff}.sidebar-footer{padding:10px;border-top:1px dashed var(--line)}.sidebar-footer-card{display:grid;gap:8px;padding:12px;margin-bottom:8px;border-radius:16px;background:#ffffffb8;border:1px solid rgba(216,225,243,.84)}.sidebar-footer-card p:last-child{color:var(--text-muted);font-size:12px}.role-badge{display:inline-block;background:#dbecf7;color:#265f87;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700}.main-area{display:grid;grid-template-rows:auto 1fr;min-width:0}.topbar{position:sticky;top:0;z-index:5;border-bottom:1px solid var(--line);background:#f8fbffcc;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:14px 20px;display:flex;align-items:center;gap:16px}.mobile-menu-btn{background:#e8f0fb;color:#194f9f;font-weight:700;padding:8px 12px;display:none}.topbar-content{display:flex;align-items:center;gap:12px;margin-left:auto}.topbar-heading{display:flex;align-items:center;gap:12px;min-width:0}.topbar-heading-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#2457e61f,#0e8f9024);color:var(--brand)}.topbar-heading-icon svg{width:18px;height:18px}.topbar-heading strong{display:block;font-size:15px}.topbar-heading p{color:var(--text-muted);font-size:13px}.topbar-pill{display:inline-flex;align-items:center;gap:7px;padding:8px 10px;border-radius:999px;background:#ffffffe0;border:1px solid #dce5f5;color:#365486;font-size:12px;font-weight:700}.topbar-pill svg{width:14px;height:14px}.topbar-content p{color:var(--text-muted);font-size:14px}.topbar-role{padding:5px 10px;border-radius:999px;background:#dff6f6;color:#0a6a6c;font-size:12px;font-weight:700;text-transform:uppercase}.page-scroll{padding:20px;overflow:auto}.page{display:grid;gap:16px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 24px;border-radius:24px;border:1px solid rgba(216,225,243,.96);background:radial-gradient(circle at 92% 18%,rgba(14,143,144,.16),transparent 26%),radial-gradient(circle at 18% 18%,rgba(36,87,230,.12),transparent 28%),linear-gradient(135deg,#fffffff5,#f5f8fff5);box-shadow:0 18px 36px #22356814}.page-header-copy{display:grid;gap:6px}.page-header h2{font-size:clamp(30px,4vw,40px)}.page-header p{color:var(--text-muted)}.page-eyebrow{display:inline-flex;align-items:center;width:fit-content;padding:5px 10px;border-radius:999px;background:#2457e61a;color:var(--brand);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.page-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.page-meta-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:#ffffffd6;border:1px solid #dbe5f8;color:#425a85;font-size:12px;font-weight:600}.page-meta-chip svg{width:14px;height:14px}.panel{background:var(--bg-panel);border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:0 14px 30px #152a5f14;display:grid;gap:12px}.panel h3{font-size:18px}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.stat-card{background:var(--bg-panel);border:1px solid var(--line);border-radius:20px;padding:16px;box-shadow:0 18px 34px #1120280f;background:linear-gradient(180deg,#fffffffa,#f7f9fffa)}.stat-label-row{display:flex;align-items:center;justify-content:space-between}.stat-label{color:var(--text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.stat-icon{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,#2457e61f,#0e8f9024);color:#2b63d4}.stat-icon svg{width:18px;height:18px}.stat-card h3{margin-top:6px;font-size:28px}.stat-note{color:var(--text-muted);font-size:13px}.panel-grid.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dashboard-highlight-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.highlight-panel{display:flex;align-items:center;gap:14px;padding:18px;border-radius:20px;background:linear-gradient(135deg,#14213dfa,#234a8df5);color:#fff;box-shadow:0 20px 38px #172b5129}.highlight-panel__icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:#ffffff24}.highlight-panel__icon svg{width:18px;height:18px}.highlight-panel__label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#ffffffb3}.highlight-panel strong{display:block;margin-top:4px;font-size:26px}.highlight-panel span{color:#ffffffbd;font-size:13px}.chart-wrap{width:100%;height:260px}.panel-toolbar{display:flex;gap:10px}.search-input{max-width:460px}.table-wrap{overflow:auto;border:1px solid #e2e8f8;border-radius:14px;background:#fff}table{width:100%;border-collapse:collapse;min-width:700px}th,td{text-align:left;padding:11px 10px;border-bottom:1px solid #e7ecf9;font-size:13px}th{color:#4d5f69;font-weight:700;text-transform:uppercase;font-size:11px;letter-spacing:.06em}small{color:var(--text-muted)}.status-pill{display:inline-flex;align-items:center;border-radius:999px;font-size:11px;padding:4px 8px;text-transform:uppercase;letter-spacing:.04em;font-weight:700}.status-pill.ok{background:#ddf6eb;color:#117a3f}.status-pill.warn{background:#fef3d9;color:#9b5e0c}.status-pill.muted{background:#e9eff3;color:#5f6f78}.inline-form{display:grid;gap:12px}.grid-two{grid-template-columns:repeat(2,minmax(0,1fr))}.full-row{grid-column:1 / -1}.split-input{display:grid;grid-template-columns:1fr 92px;gap:8px}.highlight-row{display:flex;gap:16px;align-items:center;background:#eef7f9;border-radius:12px;padding:10px 12px}.image-selection{background:#f4f7ff;border:1px solid #d7e1fb;border-radius:14px;padding:12px;color:#2f4f9b;display:grid;gap:8px}.image-selection ul{margin:0;padding-left:18px}.muted{color:var(--text-muted)}.edit-image-panel{border:1px solid #d7e1fb;border-radius:14px;background:#f9fbff;padding:12px;display:grid;gap:10px}.edit-image-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.edit-image-head p{color:var(--text-muted);font-size:13px}.edit-image-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.edit-image-card{border:1px solid var(--line);border-radius:12px;background:#fff;overflow:hidden}.edit-image-card img{width:100%;height:160px;object-fit:cover;display:block}.edit-image-meta{padding:10px;display:grid;gap:8px}.edit-image-actions{display:flex;gap:8px;flex-wrap:wrap}.inline-check{display:inline-flex;align-items:center;gap:8px;color:var(--text-strong)}.inline-check input{width:auto}.banner-preview{border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px}.banner-preview img{width:100%;max-height:220px;object-fit:cover;border-radius:10px;display:block}.banner-thumb{width:120px;height:46px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}.product-thumb{width:40px;height:40px;object-fit:cover;border-radius:10px;border:1px solid #d7e5ec}.thumb-placeholder{font-size:11px;color:#7c8f99}.info-banner{background:#edf2ff;border:1px solid #cfdbfb;color:#2c4ea2;border-radius:14px;padding:10px 12px}.nutrition-editor{border:1px solid #d7e1fb;border-radius:14px;background:#f8faff;padding:12px;display:grid;gap:10px}.nutrition-editor h4{margin:0;font-size:15px}.nutrition-grid-admin{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.media-chip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.media-chip{display:flex!important;align-items:center;gap:8px;border:1px solid #d5def8;border-radius:10px;background:#fff;padding:8px 10px;cursor:pointer;color:#32466d!important}.media-chip input{width:auto;margin:0}.media-chip-preview{width:42px;height:42px;border-radius:8px;border:1px solid #d7e5ec;background:#f7f9fb;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;flex:0 0 auto}.media-chip-preview img{width:100%;height:100%;object-fit:cover;display:block}.media-chip-name{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.info-banner code{background:#dfeaff;border-radius:8px;padding:2px 6px;margin:0 4px}.mono-cell{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.loading-panel,.error-panel{margin:20px}.fade-in{animation:fadeInUp .45s ease both}.stagger-grid>*:nth-child(1){animation-delay:.05s}.stagger-grid>*:nth-child(2){animation-delay:.1s}.stagger-grid>*:nth-child(3){animation-delay:.15s}.stagger-grid>*:nth-child(4){animation-delay:.2s}.stagger-grid>*:nth-child(5){animation-delay:.25s}.stagger-grid>*:nth-child(6){animation-delay:.3s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-highlight-grid,.panel-grid.two-col{grid-template-columns:1fr}.nutrition-grid-admin{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:255px;transform:translate(-102%);transition:transform .25s ease;z-index:20;box-shadow:var(--shadow)}.sidebar.open{transform:translate(0)}.mobile-menu-btn{display:inline-block}.page-header{flex-direction:column;align-items:flex-start}.topbar{flex-wrap:wrap}.topbar-content{width:100%;justify-content:flex-end}.grid-two,.edit-image-grid,.media-chip-grid{grid-template-columns:1fr}}@media(max-width:640px){.stats-grid,.nutrition-grid-admin{grid-template-columns:1fr}.page-scroll{padding:14px}.topbar{padding:12px 14px}.topbar-heading,.topbar-content{width:100%}.topbar-content{flex-wrap:wrap;justify-content:flex-start;margin-left:0}}.panel-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:12px}.toolbar-filters{display:flex;gap:8px;flex-wrap:wrap}.toolbar-filters select,.toolbar-filters input{min-width:0}.row-action-btn{background:none;border:1px solid var(--brand, #1e6b94);color:var(--brand, #1e6b94);border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.row-action-btn:hover{background:var(--brand, #1e6b94);color:#fff}.empty-row{text-align:center;color:#8a9bab;padding:28px!important}.status-pill.err{background:#fde8e8;color:#9b1b1b}.modal-backdrop{position:fixed;inset:0;background:#00000073;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:#fff;border-radius:14px;box-shadow:0 24px 64px #00000038;width:100%;max-width:560px;overflow:hidden;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid #e3edf2}.modal-head h3{margin:0;font-size:1.05rem}.modal-close{background:none;border:none;font-size:1rem;cursor:pointer;color:#8a9bab;padding:4px 8px;border-radius:6px;transition:background .15s}.modal-close:hover{background:#f0f4f8;color:#333}.modal-body{padding:18px 20px}.modal-sub{font-size:12px;color:#8a9bab;margin:0 0 14px}.modal-foot{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 20px 18px;border-top:1px solid #e3edf2}.checkbox-field{display:flex!important;flex-direction:row!important;align-items:center;gap:8px;cursor:pointer}.checkbox-field input[type=checkbox]{width:16px;height:16px;cursor:pointer;flex-shrink:0}.required{color:#c0392b;font-size:.85em}.muted-text{color:#aaa}
