:root{font-family:Inter,system-ui,-apple-system,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary-50: #eef2ff;--primary-100: #e0e7ff;--primary-200: #c7d2fe;--primary-400: #818cf8;--primary-500: #6366f1;--primary-600: #4f46e5;--primary-700: #4338ca;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--bg-page: #0f1117;--bg-card: #161b27;--bg-input: #1c2333;--border-color: rgba(255, 255, 255, .08);--border-focus: var(--primary-500);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--error: #ef4444}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;background-color:var(--bg-page);color:var(--text-primary);display:flex;align-items:stretch}#root{width:100%;display:flex;align-items:stretch}h1{font-size:1.875rem;font-weight:700;line-height:1.2;color:var(--text-primary)}a{color:var(--primary-400);text-decoration:none;font-weight:500;transition:color .2s}a:hover{color:var(--primary-500)}button{font-family:inherit}.auth-layout{display:flex;width:100%;min-height:100vh}.auth-brand-panel{position:relative;flex:0 0 45%;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#1e1b4b,#312e81 40%,#1e1b4b);padding:3rem 3.5rem}.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.35;pointer-events:none}.orb-1{width:420px;height:420px;background:radial-gradient(circle,#6366f1 0%,transparent 70%);top:-120px;left:-100px;animation:orb-drift 8s ease-in-out infinite alternate}.orb-2{width:320px;height:320px;background:radial-gradient(circle,#a78bfa 0%,transparent 70%);bottom:-80px;right:-60px;animation:orb-drift 10s ease-in-out infinite alternate-reverse}@keyframes orb-drift{0%{transform:translate(0) scale(1)}to{transform:translate(20px,20px) scale(1.08)}}.brand-content{position:relative;z-index:1;max-width:380px}.brand-logo{font-size:2rem;font-weight:800;letter-spacing:-.5px;color:#fff;margin-bottom:2.5rem}.brand-logo span{color:var(--primary-400)}.brand-headline{font-size:1.75rem;font-weight:700;line-height:1.3;color:#fff;margin-bottom:1rem}.brand-subtitle{font-size:.9375rem;color:#ffffffa6;line-height:1.6;margin-bottom:2rem}.brand-features{list-style:none;display:flex;flex-direction:column;gap:.85rem}.brand-features li{display:flex;align-items:center;gap:.75rem;font-size:.9375rem;color:#fffc;font-weight:500}.feature-icon{font-size:1.15rem;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:#ffffff1a;border-radius:8px;flex-shrink:0}.auth-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:2.5rem 2rem;background-color:var(--bg-page);overflow-y:auto}.auth-form-container{width:100%;max-width:420px;display:flex;flex-direction:column;gap:1.75rem}.mobile-brand{display:none}.mobile-brand-logo{font-size:1.5rem;font-weight:800;color:var(--text-primary)}.mobile-brand-logo span{color:var(--primary-400)}.auth-form-header{display:flex;flex-direction:column;gap:.4rem}.auth-form-header h1{font-size:1.875rem;font-weight:700;color:var(--text-primary)}.auth-form-header p{font-size:.9375rem;color:var(--text-secondary)}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-label{font-size:.875rem;font-weight:600;color:var(--text-primary);letter-spacing:.01em}.input-wrapper{position:relative;display:flex;align-items:center}.form-input{width:100%;height:2.875rem;padding:0 2.75rem 0 1rem;background:var(--bg-input);border:1.5px solid var(--border-color);border-radius:10px;font-size:.9375rem;color:var(--text-primary);outline:none;transition:border-color .2s,box-shadow .2s,background .2s;font-family:inherit}.form-input::placeholder{color:var(--text-muted)}.form-input:hover{border-color:#ffffff29}.form-input:focus{border-color:var(--border-focus);background:#1e2540;box-shadow:0 0 0 3px #6366f12e}.form-input.input-error{border-color:var(--error);box-shadow:0 0 0 3px #ef444426}.input-icon{position:absolute;right:.85rem;font-size:1rem;pointer-events:none;color:var(--text-muted);line-height:1}.input-wrapper:has(.password-toggle) .input-icon{right:2.75rem}.password-toggle{position:absolute;right:.6rem;background:transparent;border:none;padding:.25rem;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--text-muted);transition:background .15s,color .15s;line-height:1}.password-toggle:hover{background:#ffffff12;color:var(--text-primary);border-color:transparent}.password-toggle:focus-visible{outline:2px solid var(--primary-500);outline-offset:1px}.field-error{font-size:.8125rem;color:var(--error);display:flex;align-items:center;gap:.25rem}.form-extras{display:flex;align-items:center;justify-content:space-between;margin-top:-.25rem}.forgot-link{font-size:.875rem;color:var(--primary-400);font-weight:500;text-decoration:none;transition:color .2s}.forgot-link:hover{color:var(--primary-500)}.checkbox-group{display:flex;align-items:center;gap:.55rem}.checkbox-group input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--primary-500);cursor:pointer;flex-shrink:0;border-radius:4px}.checkbox-group label{font-size:.875rem;color:var(--text-secondary);cursor:pointer;line-height:1.4}.btn-submit{width:100%;height:2.875rem;margin-top:.25rem;background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-500) 100%);color:#fff;font-size:.9375rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;letter-spacing:.02em;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 14px #6366f159}.btn-submit:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #6366f173}.btn-submit:active:not(:disabled){transform:translateY(0);opacity:1}.btn-submit:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.btn-submit:focus-visible{outline:3px solid var(--primary-400);outline-offset:2px}.server-error{background:#ef44441f;color:var(--error);border:1px solid rgba(239,68,68,.3);border-radius:10px;padding:.75rem 1rem;font-size:.875rem;font-weight:500;text-align:center;animation:shake .35s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@media(max-width:768px){.auth-brand-panel{display:none}.mobile-brand{display:flex;justify-content:center}.auth-form-panel{padding:3rem 1.25rem 2rem;align-items:flex-start}.auth-form-container{max-width:100%}}.dashboard-layout{display:flex;width:100%;min-height:100vh;background:var(--bg-page)}.dashboard-sidebar{width:240px;flex-shrink:0;background:var(--bg-card);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:1.5rem 1rem;gap:1.5rem;position:sticky;top:0;height:100vh;overflow-y:auto;margin-right:1.5rem}.sidebar-logo{font-size:1.5rem;font-weight:800;color:var(--text-primary);padding:0 .5rem;letter-spacing:-.5px}.sidebar-logo span{color:var(--primary-400)}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem;flex:1}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border-radius:10px;font-size:.9rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:background .15s,color .15s}.sidebar-nav-item:hover{background:#ffffff0d;color:var(--text-primary)}.sidebar-nav-item.active{background:#6366f126;color:var(--primary-400)}.sidebar-nav-icon{font-size:1rem;line-height:1}.sidebar-menu-group{display:flex;flex-direction:column}.sidebar-menu-toggle{width:100%;background:none;border:none;cursor:pointer;justify-content:flex-start}.sidebar-menu-toggle.open{background:#6366f11a;color:var(--primary-400)}.sidebar-menu-label{flex:1;text-align:left}.sidebar-chevron{font-size:.75rem;transition:transform .25s ease;color:var(--text-muted);margin-left:auto}.sidebar-chevron.rotated{transform:rotate(90deg);color:var(--primary-400)}.sidebar-submenu{max-height:0;overflow:hidden;transition:max-height .3s ease,opacity .25s ease;opacity:0;padding-left:.5rem}.sidebar-submenu.expanded{max-height:200px;opacity:1}.sidebar-submenu-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem .5rem 2.25rem;font-size:.84rem;font-weight:500;color:var(--text-secondary);text-decoration:none;border-radius:8px;transition:background .15s,color .15s}.sidebar-submenu-item:hover{background:#ffffff0d;color:var(--text-primary)}.sidebar-submenu-icon{font-size:.85rem;line-height:1}.sidebar-footer{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#ffffff08;border-radius:12px;border:1px solid var(--border-color)}.sidebar-user{display:flex;align-items:center;gap:.6rem;flex:1;min-width:0}.sidebar-user-info{display:flex;flex-direction:column;min-width:0}.sidebar-username{font-size:.825rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-email{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout{background:transparent;border:none;padding:.4rem;border-radius:8px;color:var(--text-muted);font-size:1rem;cursor:pointer;transition:background .15s,color .15s;flex-shrink:0}.sidebar-logout:hover{background:#ef44441f;color:var(--error)}.avatar{width:2.25rem;height:2.25rem;border-radius:50%;background:linear-gradient(135deg,var(--primary-600),var(--primary-400));display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:.05em}.avatar-sm{width:1.875rem;height:1.875rem;font-size:.7rem}.dashboard-main{flex:1;display:flex;flex-direction:column;gap:1.75rem;padding:2rem 2.25rem;overflow-y:auto}.dashboard-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.topbar-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.3}.topbar-subtitle{font-size:.9rem;color:var(--text-secondary);margin-top:.3rem}.topbar-actions{display:flex;align-items:center;gap:.75rem}.topbar-btn{position:relative;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;width:2.5rem;height:2.5rem;cursor:pointer;font-size:1rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.topbar-btn:hover{background:#ffffff0f;color:var(--text-primary)}.notif-dot{position:absolute;top:.4rem;right:.4rem;width:7px;height:7px;background:var(--primary-500);border-radius:50%;border:2px solid var(--bg-page)}.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.35rem 1.5rem;display:flex;flex-direction:column;gap:.6rem;transition:border-color .2s,transform .2s}.stat-card:hover{border-color:#6366f14d;transform:translateY(-2px)}.stat-card-header{display:flex;align-items:center;justify-content:space-between}.stat-card-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.stat-card-icon{font-size:1.25rem;background:#6366f11a;width:2.25rem;height:2.25rem;border-radius:10px;display:flex;align-items:center;justify-content:center}.stat-card-value{font-size:2rem;font-weight:800;color:var(--text-primary);line-height:1;letter-spacing:-1px}.stat-card-delta{font-size:.8rem;color:var(--primary-400);font-weight:500}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:1rem}.dashboard-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.card-header{display:flex;align-items:center;justify-content:space-between}.card-title{font-size:1rem;font-weight:700;color:var(--text-primary)}.card-link{font-size:.8rem;color:var(--primary-400);font-weight:500}.activity-list{list-style:none;display:flex;flex-direction:column;gap:0}.activity-item{display:flex;align-items:flex-start;gap:.85rem;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.activity-item:last-child{border-bottom:none}.activity-icon{font-size:1rem;background:#6366f11a;width:2rem;height:2rem;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.activity-body{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}.activity-text{font-size:.875rem;color:var(--text-primary);line-height:1.4}.activity-time{font-size:.775rem;color:var(--text-muted)}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.quick-action-btn{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;background:#ffffff08;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s;font-family:inherit;text-align:left}.quick-action-btn:hover{background:#ffffff12;color:var(--text-primary);border-color:#ffffff1f}.quick-action-btn.primary{background:#5f3f441f;border-color:#6366f14d;color:var(--primary-400);grid-column:span 2}.quick-action-btn.primary:hover{background:#6366f133}.skeleton{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%;animation:skeleton-sweep 1.5s infinite;border-radius:6px}.skeleton-text{height:.875rem;width:7rem}.skeleton-value{height:2rem;width:4rem}@keyframes skeleton-sweep{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:1024px){.stat-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.dashboard-sidebar{display:none}.dashboard-main{padding:1.25rem 1rem}.stat-cards{grid-template-columns:repeat(2,1fr);gap:.75rem}.dashboard-grid{grid-template-columns:1fr}}@media(max-width:480px){.stat-cards{grid-template-columns:1fr}}.light-mode{--bg-page: #f1f5f9;--bg-card: #ffffff;--bg-input: #f8fafc;--border-color: rgba(0, 0, 0, .08);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8}.light-mode,.light-mode *{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}.light-mode .dashboard-sidebar{border-right-color:#00000014}.light-mode .topbar-btn{background:#fff;border-color:#0000001a}.light-mode .topbar-btn:hover{background:#f1f5f9;color:var(--text-primary)}.light-mode .sidebar-footer{background:#00000008;border-color:#00000014}.light-mode .stat-card:hover{border-color:#6366f166}.theme-toggle:hover{transform:scale(1.12) rotate(15deg);transition:transform .2s ease}.layout-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow-y:auto}.layout-topbar-strip{display:flex;align-items:center;gap:.75rem;padding:1rem 2.25rem;border-bottom:1px solid var(--border-color);justify-content:flex-end;background:var(--bg-card);position:sticky;top:0;z-index:10}.page-action-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-500) 100%);color:#fff;font-size:.875rem;font-weight:600;border-radius:10px;text-decoration:none;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 14px #6366f14d;white-space:nowrap}.page-action-btn:hover{color:#fff;opacity:.9;transform:translateY(-1px);box-shadow:0 6px 18px #6366f166}.breadcrumb{display:flex;align-items:center;gap:.4rem;font-size:.8125rem;color:var(--text-muted);margin-bottom:.4rem}.breadcrumb-link{color:var(--primary-400);text-decoration:none;font-weight:500}.breadcrumb-link:hover{color:var(--primary-500)}.breadcrumb-sep{color:var(--text-muted)}.page-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;animation:fadeSlideIn .3s ease}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-card-toolbar{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);gap:1rem}.page-search{flex:1;max-width:360px;height:2.5rem;padding:0 1rem;background:var(--bg-input);border:1.5px solid var(--border-color);border-radius:10px;font-size:.875rem;color:var(--text-primary);outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s}.page-search::placeholder{color:var(--text-muted)}.page-search:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f126}.page-count{font-size:.8125rem;color:var(--text-muted);white-space:nowrap}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table thead tr{background:#ffffff08;border-bottom:1px solid var(--border-color)}.data-table th{padding:.85rem 1.2rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);white-space:nowrap}.data-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .15s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:#ffffff06}.data-table td{padding:.9rem 1.2rem;color:var(--text-secondary);vertical-align:middle}.table-id{color:var(--text-muted)!important;font-size:.8rem!important}.table-name{color:var(--text-primary)!important;font-weight:600!important}.table-muted{color:var(--text-muted)!important}.table-price{color:var(--primary-400)!important;font-weight:600!important}.table-badge{display:inline-flex;align-items:center;padding:.2rem .65rem;background:#6366f11f;color:var(--primary-400);border-radius:20px;font-size:.78rem;font-weight:600;border:1px solid rgba(99,102,241,.2)}.table-badge.parent{background:#a78bfa1f;color:#a78bfa;border-color:#a78bfa33}.table-slug{background:#ffffff0f;color:var(--text-muted);padding:.15rem .5rem;border-radius:6px;font-size:.8rem;font-family:Courier New,monospace}.stock-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:20px;font-size:.78rem;font-weight:600}.stock-badge.ok{background:#22c55e1f;color:#4ade80;border:1px solid rgba(34,197,94,.2)}.stock-badge.low{background:#ef44441f;color:#f87171;border:1px solid rgba(239,68,68,.2)}.table-actions{display:flex;gap:.4rem}.tbl-btn{background:#ffffff0a;border:1px solid var(--border-color);border-radius:8px;padding:.3rem .55rem;cursor:pointer;font-size:.85rem;transition:background .15s,border-color .15s,transform .1s}.tbl-btn:hover{transform:scale(1.1)}.tbl-btn.edit:hover{background:#6366f126;border-color:#6366f14d}.tbl-btn.delete:hover{background:#ef44441f;border-color:#ef44444d}.table-empty{text-align:center!important;color:var(--text-muted)!important;padding:3rem 1rem!important;font-style:italic}.form-card{max-width:780px}.page-form{display:flex;flex-direction:column;gap:1.25rem;padding:1.75rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem}.form-textarea{height:auto!important;resize:vertical;padding-top:.75rem!important;padding-bottom:.75rem!important}.form-actions{display:flex;align-items:center;gap:1rem;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--border-color)}.form-cancel-btn{padding:.65rem 1.4rem;border-radius:10px;font-size:.9rem;font-weight:500;color:var(--text-secondary);background:#ffffff0a;border:1px solid var(--border-color);text-decoration:none;transition:background .15s,color .15s}.form-cancel-btn:hover{background:#ffffff14;color:var(--text-primary)}.form-submit-btn{width:auto!important;padding:0 1.75rem!important;margin-top:0!important}.form-success{margin:1.5rem 1.75rem 0;padding:.75rem 1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.25);border-radius:10px;color:#4ade80;font-size:.875rem;font-weight:500;animation:fadeSlideIn .3s ease}select.form-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem!important}select.form-input option{background:var(--bg-card);color:var(--text-primary)}.light-mode .page-card{background:#fff;border-color:#00000014}.light-mode .data-table thead tr,.light-mode .data-table tbody tr:hover{background:#00000005}.light-mode .data-table th,.light-mode .table-empty{color:var(--gray-400)}.light-mode .page-card-toolbar{border-bottom-color:#00000012}.light-mode .data-table tbody tr{border-bottom-color:#0000000f}.light-mode .tbl-btn{background:#00000008;border-color:#00000014}.light-mode .layout-topbar-strip{background:#fff;border-bottom-color:#00000014}.light-mode .form-actions{border-top-color:#00000012}.light-mode .form-cancel-btn{background:#00000008;border-color:#00000014}
