:root[data-theme=light]{--bg: #f5f7fb;--surface: #ffffff;--surface-alt: #f3f4f6;--text: #0f172a;--text-muted: #6b7280;--border: #e5e7eb;--primary: #2563eb;--primary-soft: #e0ecff;--danger: #ef4444;--radius: 14px;--shadow: 0 2px 8px rgba(15, 23, 42, .05);--shadow-lg: 0 16px 40px rgba(15, 23, 42, .12)}:root[data-theme=dark]{--bg: #020617;--surface: #0f172a;--surface-alt: #020617;--text: #e5e7eb;--text-muted: #9ca3af;--border: #1f2937;--primary: #60a5fa;--primary-soft: #0b1736;--danger: #f87171;--radius: 14px;--shadow: none;--shadow-lg: none}html,body,.app-shell,.topbar,.card,.page,.page-container{transition:background .25s ease,color .25s ease,border-color .25s ease}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text)}.app-shell{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(circle at top left,rgba(37,99,235,.12),transparent 50%),radial-gradient(circle at bottom right,rgba(34,197,94,.12),transparent 55%),var(--bg)}.page-container{flex:1;max-width:1200px;margin:20px auto 32px;padding:0 16px 32px}.page{max-width:1200px;margin:0 auto}.err{color:var(--danger);font-size:.9rem}.ok{color:#22c55e;font-size:.9rem}.muted{color:var(--text-muted)}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:18px 18px 16px;box-shadow:var(--shadow)}.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 24px;background:#0f172af5;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid rgba(148,163,184,.4);box-shadow:0 18px 40px #0f172a99;color:#e5e7eb}.topbar-left{display:flex;align-items:center;gap:10px}.topbar-logo{width:46px;height:46px;border-radius:16px;overflow:hidden;background:radial-gradient(circle at 20% 20%,#3b82f6,#22c55e);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px #2563eb80}.topbar-logo img{width:80%;height:80%;object-fit:contain}.topbar-title{display:flex;flex-direction:column;gap:2px}.topbar-title-main{font-weight:700;font-size:1.05rem;letter-spacing:.04em}.topbar-title-sub{font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:#9ca3af}.topbar-nav{display:flex;gap:8px;flex:1;justify-content:center;flex-wrap:wrap}.topbar-link{padding:6px 14px;border-radius:999px;border:1px solid transparent;font-size:.87rem;color:#e5e7eb;text-decoration:none;opacity:.8}.topbar-link:hover{background:#94a3b82e;border-color:#94a3b880;opacity:1}.topbar-link-active{background:#22c55e;border-color:#4ade80;color:#0f172a;opacity:1}.small-link{font-size:.8rem}.topbar-right{display:flex;align-items:center;gap:10px}.topbar-user-pill{padding:5px 11px;border-radius:999px;background:#0f172a66;border:1px solid rgba(148,163,184,.6);font-size:.8rem;display:flex;gap:6px;align-items:center}.topbar-user-name{font-weight:600}.topbar-user-role{color:#cbd5f5}.store-select{border-radius:999px;border:1px solid rgba(148,163,184,.8);padding:4px 10px;background:#0f172aeb;color:#e5e7eb;font-size:.78rem}.icon-button{border-radius:999px;border:1px solid rgba(148,163,184,.9);background:#0f172ae6;color:#e5e7eb;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.logout-btn{width:32px;height:32px;font-size:.95rem;background:#f97316;border-color:#fed7aa;color:#0f172a}.logout-btn:hover{background:#fed7aa}.theme-toggle{width:34px;height:34px;border-radius:999px;border:1px solid rgba(148,163,184,.8);background:#0f172acc;color:#e5e7eb;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}@media(max-width:780px){.topbar{flex-direction:column;align-items:stretch;padding:10px 16px 12px}.topbar-left{justify-content:space-between}.topbar-nav{order:3;justify-content:flex-start;overflow-x:auto;padding-top:6px}.topbar-right{justify-content:flex-end;flex-wrap:wrap}}.btn{padding:8px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface-alt);color:var(--text);cursor:pointer;font-size:.9rem;font-weight:500}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-outline{background:transparent}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-sm{padding:6px 10px;font-size:.8rem}.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:.78rem;border:1px solid var(--border);background:var(--surface);color:var(--text-muted)}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.field label{font-size:.85rem;font-weight:600;color:var(--text)}input[type=text],input[type=number],input[type=password],select,textarea{padding:9px 11px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.9rem}textarea{resize:vertical}.category-layout{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:20px}@media(max-width:900px){.category-layout{grid-template-columns:minmax(0,1fr)}}.category-create-card,.category-list-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:16px 18px;box-shadow:var(--shadow)}.category-list-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.categories-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}@media(max-width:1100px){.categories-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.categories-grid{grid-template-columns:minmax(0,1fr)}}.category-card{padding:10px 12px 9px;border-radius:12px;border:1px solid var(--border);background:var(--surface-alt);display:flex;flex-direction:column;gap:6px}.category-card-title{font-weight:600;font-size:.95rem}.category-card-sub{font-size:.88rem;color:var(--text-muted)}.category-card-meta{font-size:.8rem;color:var(--text-muted)}.category-card-actions{margin-top:6px;display:flex;gap:8px}.icon-btn{width:30px;height:30px;border-radius:999px;border:1px solid var(--border);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px}.product-layout{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:24px;align-items:flex-start}@media(max-width:960px){.product-layout{grid-template-columns:minmax(0,1fr)}}.product-list-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.product-list-controls{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.products-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.product-create-card,.product-list-card{padding:16px 18px;background:#fff;border-radius:14px;box-shadow:0 8px 20px #0f172a0f}.product-create-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px 16px}@media(max-width:900px){.product-create-grid{grid-template-columns:minmax(0,1fr)}}.product-card{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border-radius:16px;border:1px solid #e5e7eb;background:#f9fafb;box-shadow:0 4px 10px #0f172a0a;height:auto}.product-card:hover{box-shadow:0 8px 18px #0f172a14}.product-card img.thumb{width:90px;height:90px;border-radius:12px;object-fit:cover;flex-shrink:0}.product-card-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.product-card-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.product-card-title{font-weight:700;font-size:1rem}.product-card-sub{font-size:.9rem;color:#6b7280}.product-card-desc{font-size:.9rem;color:#4b5563}.product-card-price{margin-top:2px;font-weight:600}.product-card-meta{font-size:.8rem;color:#6b7280}.product-card-actions{margin-top:8px;display:flex;gap:8px}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;background:radial-gradient(circle at top left,#1d4ed8 0,#22c55e 38%,#020617);padding:16px;overflow:hidden}.login-overlay{position:absolute;inset:0;background:radial-gradient(circle at 10% 20%,rgba(248,250,252,.18) 0,transparent 45%),radial-gradient(circle at 90% 80%,rgba(59,130,246,.18) 0,transparent 45%);pointer-events:none}.login-shell{position:relative;z-index:1;width:100%;max-width:920px;display:flex;border-radius:22px;background:#0f172af2;border:1px solid rgba(148,163,184,.7);box-shadow:0 30px 80px #0f172ae6;overflow:hidden}.login-side{flex:1.1;padding:22px 22px 20px;background:radial-gradient(circle at 0% 0%,rgba(56,189,248,.5),transparent 45%),radial-gradient(circle at 100% 100%,rgba(34,197,94,.5),transparent 45%),#020617;color:#e5e7eb;display:flex;flex-direction:column;gap:16px}.login-side-header{display:flex;align-items:center;gap:10px}.login-side-logo{width:42px;height:42px;border-radius:14px;background:#0f172acc;display:flex;align-items:center;justify-content:center;overflow:hidden}.login-side-logo img{width:80%;height:80%;object-fit:contain}.login-side-title{display:flex;flex-direction:column;gap:2px}.side-title-main{font-size:.95rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.side-title-sub{font-size:.75rem;color:#cbd5f5}.login-side-body h1{margin:10px 0 6px;font-size:1.4rem;font-weight:700}.login-side-body p{margin:0 0 10px;font-size:.92rem;color:#cbd5f5}.login-feature-list{list-style:none;padding:0;margin:0;display:grid;gap:6px;font-size:.9rem}.login-feature-list li{display:flex;align-items:center;gap:6px}.login-main{flex:1;padding:22px 22px 18px;background:#0b1220;display:flex;flex-direction:column;gap:14px}.login-brand-small{display:flex;align-items:center;gap:8px;margin-bottom:4px}.login-brand-logo{width:40px;height:40px;border-radius:12px;background:radial-gradient(circle at 20% 20%,#3b82f6,#22c55e);overflow:hidden;display:flex;align-items:center;justify-content:center}.login-brand-logo img{width:80%;height:80%;object-fit:contain}.login-brand-name{font-weight:600;font-size:.95rem;color:#e5e7eb}.login-brand-sub{font-size:.78rem;color:#9ca3af}.login-title{margin:4px 0 0;font-size:1.2rem;font-weight:600;color:#e5e7eb}.login-subtitle{margin:2px 0 8px;font-size:.9rem;color:#9ca3af}.login-form-advanced{display:flex;flex-direction:column;gap:10px}.login-error{margin:0 0 4px;color:#fecaca;font-size:.8rem}.login-form-advanced .field label{color:#e5e7eb}.password-wrapper{position:relative;display:flex;align-items:center}.password-wrapper input{width:100%;padding-right:70px}.password-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);border-radius:999px;border:1px solid rgba(148,163,184,.8);background:#0f172ae6;color:#e5e7eb;font-size:.75rem;padding:4px 8px;cursor:pointer}.login-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:2px}.remember-row{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#cbd5f5}.remember-row input{width:14px;height:14px}.login-forgot{font-size:.8rem;color:#93c5fd;cursor:default}.btn.full{width:100%}.login-footer-note{margin:8px 0 0;font-size:.8rem;color:#9ca3af}@media(max-width:768px){.login-shell{flex-direction:column;max-width:420px;padding:4px}.login-side{display:none}.login-main{padding:18px 16px 16px;border-radius:18px}}.app-footer{text-align:center;padding:16px 0 22px;font-size:.9rem;color:var(--text-muted)}.app-footer strong{color:#38bdf8}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.store-search{min-width:220px}.store-search-input{width:100%;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.9rem}.store-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.store-card{display:flex;flex-direction:column;gap:8px}.store-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.store-title{font-weight:600;font-size:.98rem}.store-subtitle{font-size:.86rem;color:var(--text-muted)}.store-card-body{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;font-size:.88rem}.store-meta{flex:1}.store-subscription{margin-top:2px}.store-logo-wrap{flex-shrink:0}.store-logo{width:110px;height:72px;border-radius:10px;object-fit:cover;border:1px solid var(--border)}.store-card-actions{margin-top:6px;display:flex;gap:8px;justify-content:flex-end}.icon-btn{width:30px;height:30px;border-radius:999px;border:1px solid var(--border);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px}.icon-btn:hover{background:var(--primary-soft)}.icon-btn-danger{border-color:#fecaca;background:#fee2e2;color:#b91c1c}@media(max-width:720px){.page-header{flex-direction:column;align-items:flex-start}.store-search{width:100%}}
