@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;0,14..32,800;0,14..32,900&display=swap");:root{--brand-50:#eef2ff;--brand-100:#e0e7ff;--brand-400:#818cf8;--brand-500:#6366f1;--brand-600:#4f46e5;--brand-700:#4338ca;--brand-900:#1e1b4b;--amber-400:#fbbf24;--amber-500:#f59e0b;--primary:var(--brand-500);--primary-hover:var(--brand-600);--primary-glow:rgba(99,102,241,0.35);--accent-grad:linear-gradient(135deg,#6366f1,#a855f7 50%,#ec4899);--accent-grad-h:linear-gradient(135deg,#4f46e5,#9333ea 50%,#db2777);--amber-grad:linear-gradient(135deg,#f59e0b,#ef4444);--bg:#f4f5ff;--bg-subtle:#eef0ff;--bg-card:rgba(255,255,255,0.9);--bg-card-hover:rgba(255,255,255,1);--bg-input:rgba(0,0,0,0.045);--bg-modal:#ffffff;--bg-sidebar:#ffffff;--border:rgba(99,102,241,0.12);--border-hover:rgba(99,102,241,0.22);--border-focus:rgba(99,102,241,0.5);--border-brand:rgba(99,102,241,0.25);--text-1:#0f172a;--text-2:#334155;--text-3:#64748b;--text-4:#1e293b;--success:#10b981;--success-bg:rgba(16,185,129,0.08);--success-border:rgba(16,185,129,0.2);--danger:#f43f5e;--danger-bg:rgba(244,63,94,0.08);--danger-border:rgba(244,63,94,0.2);--warning:#f59e0b;--warning-bg:rgba(245,158,11,0.08);--warning-border:rgba(245,158,11,0.2);--info:#38bdf8;--info-bg:rgba(56,189,248,0.08);--info-border:rgba(56,189,248,0.2);--header-bg:rgba(244,245,255,0.85);--chart-grid:rgba(99,102,241,0.08);--radius-xs:6px;--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--shadow-sm:0 1px 4px rgba(99,102,241,0.08);--shadow-card:0 4px 24px rgba(99,102,241,0.1);--shadow-modal:0 24px 80px rgba(99,102,241,0.15),0 0 0 1px rgba(99,102,241,0.08);--shadow-glow:0 0 40px rgba(99,102,241,0.12);--shadow-btn:0 4px 14px rgba(99,102,241,0.3);--sidebar-w:256px;--header-h:64px;--ease:cubic-bezier(0.4,0,0.2,1);--transition:0.2s var(--ease);--transition-fast:0.12s var(--ease)}[data-theme=dark]{--bg:#080b12;--bg-subtle:#0d1117;--bg-card:rgba(255,255,255,0.035);--bg-card-hover:rgba(255,255,255,0.065);--bg-input:rgba(255,255,255,0.05);--bg-modal:#0f1623;--bg-sidebar:rgba(8,11,18,0.98);--border:rgba(255,255,255,0.07);--border-hover:rgba(255,255,255,0.12);--border-focus:rgba(99,102,241,0.5);--border-brand:rgba(99,102,241,0.25);--text-1:#f1f5f9;--text-2:#94a3b8;--text-3:#475569;--text-4:#1e293b;--success-bg:rgba(16,185,129,0.1);--success-border:rgba(16,185,129,0.25);--danger-bg:rgba(244,63,94,0.1);--danger-border:rgba(244,63,94,0.25);--warning-bg:rgba(245,158,11,0.1);--warning-border:rgba(245,158,11,0.25);--info-bg:rgba(56,189,248,0.1);--info-border:rgba(56,189,248,0.25);--header-bg:rgba(8,11,18,0.85);--chart-grid:rgba(255,255,255,0.05);--shadow-sm:0 2px 8px rgba(0,0,0,0.3);--shadow-card:0 4px 24px rgba(0,0,0,0.45);--shadow-modal:0 24px 80px rgba(0,0,0,0.7),0 0 0 1px rgba(255,255,255,0.05);--shadow-glow:0 0 40px rgba(99,102,241,0.2);--shadow-btn:0 4px 15px rgba(99,102,241,0.4)}.admin-layout,body{background:radial-gradient(ellipse 80% 60% at 20% 0,rgba(99,102,241,.06) 0,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(168,85,247,.04) 0,transparent 60%),var(--bg)}.sidebar{box-shadow:1px 0 0 var(--border),2px 0 16px rgba(99,102,241,.06)}.sidebar:before{background:radial-gradient(ellipse at 50% -20%,rgba(99,102,241,.08) 0,transparent 70%)}.header{box-shadow:0 1px 0 var(--border),0 4px 16px rgba(99,102,241,.06)}.nav-link:hover{background:rgba(99,102,241,.06)}.nav-link.active{background:linear-gradient(135deg,rgba(99,102,241,.12),rgba(168,85,247,.08));color:var(--brand-600)}[data-theme=dark] .admin-layout,[data-theme=dark] body{background:radial-gradient(ellipse 80% 60% at 20% 0,rgba(99,102,241,.08) 0,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(168,85,247,.06) 0,transparent 60%),var(--bg)}[data-theme=dark] .sidebar{box-shadow:1px 0 0 var(--border),2px 0 16px rgba(0,0,0,.3)}[data-theme=dark] .sidebar:before{background:radial-gradient(ellipse at 50% -20%,rgba(99,102,241,.15) 0,transparent 70%)}[data-theme=dark] .header{background:var(--header-bg);box-shadow:0 1px 0 var(--border)}[data-theme=dark] .nav-link:hover{color:var(--text-1);background:var(--bg-card-hover);border-color:var(--border)}[data-theme=dark] .nav-link.active{color:#fff;background:linear-gradient(135deg,rgba(99,102,241,.2),rgba(168,85,247,.12));border-color:var(--border-brand)}.skeleton{background:linear-gradient(90deg,rgba(99,102,241,.06) 25%,rgba(99,102,241,.12) 50%,rgba(99,102,241,.06) 75%)}.toast-success{background:rgba(16,185,129,.1);color:#059669}.toast-error{background:rgba(244,63,94,.1);color:#e11d48}.toast-info{background:rgba(56,189,248,.1);color:#0284c7}.btn-ghost{background:rgba(255,255,255,.8);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:white}.dropzone{background:rgba(99,102,241,.03);border-color:rgba(99,102,241,.2)}.dropzone.active,.dropzone:hover{background:rgba(99,102,241,.06)}.modal{border-color:rgba(99,102,241,.12)}.notification-preview{background:linear-gradient(135deg,rgba(99,102,241,.06),rgba(168,85,247,.04))}.notif-bubble{background:rgba(99,102,241,.06)}.image-card,.notif-bubble{border-color:rgba(99,102,241,.12)}.category-card,.chart-section,.image-card{box-shadow:var(--shadow-sm)}::-webkit-scrollbar-thumb{background:rgba(99,102,241,.2)}::-webkit-scrollbar-thumb:hover{background:rgba(99,102,241,.35)}.theme-toggle{width:36px;height:20px;border-radius:10px;background:rgba(99,102,241,.15);border:1px solid var(--border-brand);position:relative;cursor:pointer;transition:background var(--transition);flex-shrink:0}.theme-toggle.dark{background:rgba(99,102,241,.2)}.theme-toggle.light{background:rgba(245,158,11,.2);border-color:rgba(245,158,11,.3)}.theme-toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--accent-grad);transition:transform var(--transition),background var(--transition);box-shadow:0 1px 4px rgba(0,0,0,.3)}.theme-toggle.light .theme-toggle-thumb{transform:translateX(16px);background:var(--amber-grad)}.theme-switcher-row{display:flex;align-items:center;gap:8px;padding:8px 0 0;border-top:1px solid var(--border);margin-top:10px}.theme-switcher-label{font-size:11px;color:var(--text-3);font-weight:600;letter-spacing:.05em;text-transform:uppercase;flex:1 1}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text-1);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}img{display:block;max-width:100%}button{cursor:pointer;font-family:inherit}a{text-decoration:none;color:inherit}code{font-family:Fira Code,Fira Mono,monospace}.admin-layout{background:radial-gradient(ellipse 80% 60% at 20% 0,rgba(99,102,241,.08) 0,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(168,85,247,.06) 0,transparent 60%),var(--bg)}.admin-layout,.main-content{display:flex;min-height:100vh}.main-content{flex:1 1;margin-left:var(--sidebar-w);flex-direction:column;transition:margin-left var(--transition)}.page-body{flex:1 1;padding:32px;padding-top:calc(var(--header-h) + 32px);max-width:1400px}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;overflow:hidden}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:200px;background:radial-gradient(ellipse at 50% -20%,rgba(99,102,241,.15) 0,transparent 70%);pointer-events:none}.sidebar-logo{height:var(--header-h);gap:12px;padding:0 20px;border-bottom:1px solid var(--border);position:relative}.sidebar-logo,.sidebar-logo-img-wrap{display:flex;align-items:center;flex-shrink:0}.sidebar-logo-img-wrap{width:42px;height:42px;border-radius:12px;overflow:hidden;justify-content:center;border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:transform var(--transition)}.sidebar-logo-img-wrap:hover{transform:scale(1.05)}.sidebar-logo-img{width:100%;height:100%;object-fit:cover}.sidebar-logo-text{font-size:14px;font-weight:800;color:var(--text-1);line-height:1.2;letter-spacing:-.01em}.sidebar-logo-sub{font-size:10px;color:var(--text-3);font-weight:500;text-transform:uppercase;letter-spacing:.1em;margin-top:2px}.sidebar-nav{flex:1 1;padding:16px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.sidebar-nav::-webkit-scrollbar{width:0}.nav-section-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);padding:8px 10px 6px;margin-top:8px}.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;color:var(--text-2);transition:all var(--transition);position:relative;overflow:hidden;border:1px solid transparent}.nav-link:hover{color:var(--text-1);background:var(--bg-card-hover);border-color:var(--border)}.nav-link.active{color:#fff;background:linear-gradient(135deg,rgba(99,102,241,.2),rgba(168,85,247,.12));border-color:var(--border-brand);box-shadow:inset 0 0 0 1px rgba(99,102,241,.1)}.nav-link.active .nav-icon{color:var(--brand-400)}.nav-link.active:before{content:"";position:absolute;left:0;top:25%;bottom:25%;width:3px;background:var(--accent-grad);border-radius:0 3px 3px 0}.nav-icon{width:17px;height:17px;flex-shrink:0;transition:color var(--transition);stroke-width:2}.nav-label{flex:1 1}.nav-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--radius-full);background:rgba(99,102,241,.2);color:var(--brand-400);border:1px solid var(--border-brand)}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0}.sidebar-user{gap:10px}.sidebar-avatar,.sidebar-user{display:flex;align-items:center}.sidebar-avatar{width:34px;height:34px;border-radius:var(--radius-sm);background:var(--accent-grad);justify-content:center;font-size:13px;font-weight:800;color:#fff;flex-shrink:0}.sidebar-user-name{font-size:12.5px;font-weight:600;color:var(--text-1);line-height:1.3}.sidebar-version{font-size:10px;color:var(--text-3);margin-top:2px}.header{position:fixed;top:0;left:var(--sidebar-w);right:0;height:var(--header-h);background:var(--header-bg);border-bottom:1px solid var(--border);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);display:flex;align-items:center;justify-content:space-between;padding:0 32px;z-index:90}.header-left{display:flex;flex-direction:column}.header-title{font-size:18px;font-weight:700;color:var(--text-1);letter-spacing:-.02em;line-height:1.2}.header-subtitle{font-size:12px;color:var(--text-3);margin-top:2px}.header-actions{display:flex;align-items:center;gap:10px}.header-badge{display:inline-flex;align-items:center;gap:7px;background:var(--success-bg);border:1px solid var(--success-border);border-radius:var(--radius-full);padding:5px 14px;font-size:12px;font-weight:600;color:var(--success);letter-spacing:.01em}.header-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:pulse-dot 2s infinite}.header-icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);color:var(--text-2);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.header-icon-btn:hover{background:var(--bg-card-hover);color:var(--text-1);border-color:var(--border-hover)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all var(--transition)}.card:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.glass-card{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-lg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:20px;gap:20px;margin-bottom:32px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;position:relative;overflow:hidden;transition:all var(--transition)}.stat-card:before{top:-1px;left:-1px;right:-1px;height:2px;opacity:0;transition:opacity var(--transition)}.stat-card:after,.stat-card:before{content:"";position:absolute;background:var(--accent-grad)}.stat-card:after{top:0;right:0;width:100px;height:100px;border-radius:50%;opacity:.04;transform:translate(30px,-30px);transition:all var(--transition)}.stat-card:hover{border-color:var(--border-brand);transform:translateY(-2px);box-shadow:var(--shadow-card),var(--shadow-glow)}.stat-card:hover:before{opacity:1}.stat-card:hover:after{opacity:.08;transform:translate(20px,-20px)}.stat-icon-wrap{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;position:relative;z-index:1}.stat-icon-wrap.brand{background:rgba(99,102,241,.12);border:1px solid rgba(99,102,241,.2);color:var(--brand-400)}.stat-icon-wrap.amber{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.2);color:var(--amber-400)}.stat-icon-wrap.success{background:var(--success-bg);border:1px solid var(--success-border);color:var(--success)}.stat-icon-wrap.danger{background:var(--danger-bg);border:1px solid var(--danger-border);color:var(--danger)}.stat-value{font-size:36px;font-weight:900;color:var(--text-1);line-height:1;margin-bottom:6px;letter-spacing:-.03em;background:var(--accent-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label,.stat-value{position:relative;z-index:1}.stat-label{font-size:13px;font-weight:500;color:var(--text-2)}.stat-trend{display:inline-flex;align-items:center;gap:4px;margin-top:8px;font-size:11.5px;font-weight:600}.stat-trend.up{color:var(--success)}.stat-trend.down{color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 18px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;border:none;transition:all var(--transition);white-space:nowrap;letter-spacing:.01em;cursor:pointer}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-primary{background:var(--accent-grad);color:#fff;box-shadow:var(--shadow-btn)}.btn-primary:hover:not(:disabled){background:var(--accent-grad-h);transform:translateY(-1px);box-shadow:0 6px 24px rgba(99,102,241,.55)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-ghost{background:var(--bg-card);color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-1);border-color:var(--border-hover)}.btn-amber{background:var(--amber-grad);color:#fff;box-shadow:0 4px 15px rgba(245,158,11,.35)}.btn-amber:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px rgba(245,158,11,.5)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.btn-danger:hover:not(:disabled){background:rgba(244,63,94,.18);border-color:rgba(244,63,94,.4)}.btn-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.btn-success:hover:not(:disabled){background:rgba(16,185,129,.18)}.btn-sm{padding:6px 12px;font-size:12px;border-radius:var(--radius-xs);gap:5px}.btn-lg{padding:14px 28px;font-size:15px}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-sm)}.btn-icon.btn-sm{width:30px;height:30px;border-radius:var(--radius-xs)}.form-group{margin-bottom:20px}.form-label{display:block;font-size:11.5px;font-weight:700;color:var(--text-3);margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em}.form-input-wrap{position:relative;display:flex;align-items:center}.form-input-icon{position:absolute;left:14px;color:var(--text-3);pointer-events:none;width:16px;height:16px;stroke-width:2}.form-input,.form-textarea{width:100%;padding:11px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text-1);font-family:inherit;transition:all var(--transition);outline:none}.form-input.has-icon{padding-left:42px}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-3)}.form-input:hover,.form-textarea:hover{border-color:var(--border-hover);background:rgba(255,255,255,.06)}.form-input:focus,.form-textarea:focus{border-color:var(--brand-500);background:rgba(99,102,241,.05);box-shadow:0 0 0 3px rgba(99,102,241,.12)}.form-textarea{resize:vertical;min-height:100px}.form-hint{font-size:11.5px;color:var(--text-3);margin-top:5px}.form-char-count{font-size:11px;color:var(--text-3);text-align:right;margin-top:4px}.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:fadeIn .18s ease}.modal{background:var(--bg-modal);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-modal);animation:slideUp .22s var(--ease);position:relative}.modal:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.4),transparent)}.modal-lg{max-width:700px}.modal-sm{max-width:400px}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px}.modal-title-wrap{gap:12px}.modal-icon,.modal-title-wrap{display:flex;align-items:center}.modal-icon{width:40px;height:40px;border-radius:12px;justify-content:center;flex-shrink:0}.modal-icon.brand{background:rgba(99,102,241,.12);border:1px solid rgba(99,102,241,.2);color:var(--brand-400)}.modal-icon.danger{background:var(--danger-bg);border:1px solid var(--danger-border);color:var(--danger)}.modal-title{font-size:18px;font-weight:700;color:var(--text-1);letter-spacing:-.01em}.modal-subtitle{font-size:13px}.modal-close,.modal-subtitle{color:var(--text-3);margin-top:2px}.modal-close{width:32px;height:32px;border-radius:var(--radius-xs);background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition)}.modal-close:hover{background:var(--bg-card-hover);color:var(--text-1);border-color:var(--border-hover)}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:28px;padding-top:20px;border-top:1px solid var(--border)}.image-grid{grid-template-columns:repeat(auto-fill,minmax(175px,1fr));grid-gap:12px;gap:12px}.image-card{position:relative;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:3/4;background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:all var(--transition)}.image-card:hover{transform:scale(1.02);box-shadow:0 8px 30px rgba(0,0,0,.6);border-color:var(--border-brand)}.image-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--transition)}.image-card:hover img{transform:scale(1.06)}.image-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.8));opacity:0;transition:opacity var(--transition);display:flex;align-items:flex-end;padding:12px;gap:8px}.image-card:hover .image-overlay{opacity:1}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));grid-gap:20px;gap:20px}.category-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition);cursor:pointer;display:flex;flex-direction:column}.category-card:hover{border-color:var(--border-brand);transform:translateY(-4px);box-shadow:var(--shadow-card),0 0 0 1px rgba(99,102,241,.1)}.category-card-img{width:100%;height:165px;object-fit:cover;display:block;transition:transform var(--transition)}.category-card:hover .category-card-img{transform:scale(1.04)}.category-card-img-wrap{overflow:hidden;position:relative;height:165px}.category-card-img-wrap:after{content:"";position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(180deg,transparent,rgba(8,11,18,.6))}.category-card-img-placeholder{width:100%;height:165px;background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(168,85,247,.06));display:flex;align-items:center;justify-content:center;color:var(--text-3)}.category-card-body{padding:16px 16px 8px;flex:1 1}.category-card-title{font-size:15px;font-weight:700;color:var(--text-1);margin-bottom:6px;letter-spacing:-.01em}.category-card-meta{font-size:12.5px;color:var(--text-3);display:flex;align-items:center;gap:8px}.category-card-id{font-size:10px;color:var(--text-3);padding:2px 7px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius-xs);font-family:Fira Code,monospace}.category-card-actions{display:flex;gap:8px;padding:8px 16px 16px}.dropzone{border:2px dashed var(--border);border-radius:var(--radius-md);padding:44px 24px;text-align:center;cursor:pointer;transition:all var(--transition);background:var(--bg-input)}.dropzone.active,.dropzone:hover{border-color:var(--brand-500);background:rgba(99,102,241,.05);box-shadow:0 0 0 4px rgba(99,102,241,.06)}.dropzone-icon{width:48px;height:48px;margin:0 auto 14px;border-radius:14px;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.2);display:flex;align-items:center;justify-content:center;color:var(--brand-400)}.dropzone-title{font-size:15px;font-weight:600;color:var(--text-1);margin-bottom:4px}.dropzone-sub{font-size:13px;color:var(--text-3)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.page-title-wrap{display:flex;flex-direction:column}.page-eyebrow{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand-400);margin-bottom:6px}.page-title{font-size:28px;font-weight:900;color:var(--text-1);line-height:1.15;letter-spacing:-.03em}.page-title span{background:var(--accent-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{font-size:14px;color:var(--text-3);margin-top:6px;font-weight:400}.toast-container{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:var(--radius-md);font-size:13.5px;font-weight:500;pointer-events:all;animation:slideInRight .28s var(--ease);box-shadow:0 8px 30px rgba(0,0,0,.5);max-width:380px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.toast-success{background:rgba(16,185,129,.14);border:1px solid var(--success-border);color:#34d399}.toast-error{background:rgba(244,63,94,.14);border:1px solid var(--danger-border);color:#fb7185}.toast-info{background:var(--info-bg);border:1px solid var(--info-border);color:var(--info)}.toast-icon{width:18px;height:18px;flex-shrink:0}.skeleton{background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 75%);background-size:200% 100%;animation:shimmer 1.8s infinite;border-radius:var(--radius-sm)}.chart-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;margin-bottom:24px}.chart-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:12px}.chart-title{font-size:16px;font-weight:700;color:var(--text-1);letter-spacing:-.01em}.chart-subtitle{font-size:13px;color:var(--text-3);margin-top:3px}.lightbox-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:300;display:flex;align-items:center;justify-content:center;animation:fadeIn .18s ease}.lightbox-img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 24px 80px rgba(0,0,0,.8),0 0 0 1px rgba(255,255,255,.06);animation:scaleIn .22s var(--ease)}.lightbox-actions{position:absolute;top:20px;right:20px;display:flex;gap:10px}.progress-bar-wrap{background:rgba(255,255,255,.07);border-radius:var(--radius-full);height:5px;overflow:hidden;margin-top:12px}.progress-bar-fill{height:100%;border-radius:var(--radius-full);background:var(--accent-grad);transition:width .3s ease;box-shadow:0 0 8px rgba(99,102,241,.5)}.section-divider{border:none;border-top:1px solid var(--border);margin:28px 0}.empty-state{text-align:center;padding:80px 24px;color:var(--text-2)}.empty-state-icon{width:64px;height:64px;margin:0 auto 20px;border-radius:20px;background:rgba(99,102,241,.08);border:1px solid var(--border-brand);display:flex;align-items:center;justify-content:center;color:var(--text-3)}.empty-state-title{font-size:18px;font-weight:700;color:var(--text-1);margin-bottom:8px;letter-spacing:-.01em}.empty-state-sub{font-size:14px;color:var(--text-3);max-width:320px;margin:0 auto;line-height:1.6}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--radius-full);font-size:11.5px;font-weight:600}.badge-primary{background:rgba(99,102,241,.15);color:var(--brand-400);border:1px solid var(--border-brand)}.badge-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.badge-amber{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.badge-danger{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-3);margin-bottom:24px}.breadcrumb a:hover{color:var(--text-1);transition:color var(--transition)}.breadcrumb-sep{color:var(--text-3);opacity:.5}.breadcrumb-current{color:var(--text-2);font-weight:500}.notification-preview{background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(168,85,247,.05));border:1px solid var(--border-brand);border-radius:var(--radius-lg);padding:24px;margin-top:24px}.notif-preview-header{font-size:10.5px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;display:flex;align-items:center;gap:6px}.notif-bubble{background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:16px;padding:14px 16px;display:flex;gap:12px;align-items:flex-start}.notif-bubble-icon{width:38px;height:38px;border-radius:11px;background:var(--accent-grad);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;box-shadow:0 0 14px rgba(99,102,241,.3)}.notif-bubble-title{font-size:14px;font-weight:700;color:var(--text-1);margin-bottom:4px}.notif-bubble-body{font-size:13px;color:var(--text-2)}.template-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:600;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text-2);cursor:pointer;transition:all var(--transition)}.template-chip:hover{background:rgba(99,102,241,.1);border-color:var(--border-brand);color:var(--brand-400)}.info-box{padding:14px 16px;border-radius:var(--radius-sm);font-size:13px;line-height:1.6;display:flex;gap:10px;align-items:flex-start}.info-box.brand{background:rgba(99,102,241,.07);border:1px solid rgba(99,102,241,.18);color:var(--text-2)}.info-box.warning{background:var(--warning-bg);border:1px solid var(--warning-border);color:var(--text-2)}.info-box-icon{flex-shrink:0;margin-top:1px}.table-row{display:flex;align-items:center;gap:16px;padding:13px 0;border-bottom:1px solid var(--border);transition:background var(--transition)}.table-row:last-child{border-bottom:none}.table-rank{font-size:12px;font-weight:700;color:var(--text-3);width:28px;text-align:right;flex-shrink:0}.table-name{flex:1 1;font-size:14px;font-weight:500;color:var(--text-1)}.table-count{font-size:12px;font-weight:700;color:var(--text-2);width:36px;text-align:right;flex-shrink:0}.checklist-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}.checklist-item:last-child{border-bottom:none}.check-icon{width:20px;height:20px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.check-icon.done{background:var(--success-bg);border:1px solid var(--success-border);color:var(--success)}.check-icon.pending{background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text-3)}.quick-action-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:16px;gap:16px;margin-bottom:32px}.quick-action-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:all var(--transition);text-decoration:none;color:inherit}.quick-action-card:hover{background:var(--bg-card-hover);border-color:var(--border-brand);transform:translateY(-2px);box-shadow:var(--shadow-card)}.quick-action-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center}.quick-action-icon.brand{background:rgba(99,102,241,.12);border:1px solid rgba(99,102,241,.2);color:var(--brand-400)}.quick-action-icon.amber{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.2);color:var(--amber-400)}.quick-action-icon.success{background:var(--success-bg);border:1px solid var(--success-border);color:var(--success)}.quick-action-icon.purple{background:rgba(168,85,247,.12);border:1px solid rgba(168,85,247,.2);color:#c084fc}.quick-action-label{font-size:13.5px;font-weight:700;color:var(--text-1)}.quick-action-sub{font-size:12px;color:var(--text-3)}@keyframes slideUp{0%{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideInRight{0%{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.18)}@media (max-width:768px){:root{--sidebar-w:0px}.sidebar{transform:translateX(-256px);transition:transform var(--transition)}.sidebar.open{transform:translateX(0);--sidebar-w:256px}.page-body{padding:20px 16px;padding-top:calc(var(--header-h) + 20px)}.header{left:0;padding:0 16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.image-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.category-grid{grid-template-columns:1fr}.quick-action-grid{grid-template-columns:repeat(2,1fr)}}.mobile-only{display:none!important}.desktop-only{display:flex!important}@media (max-width:1024px){:root{--sidebar-w:280px}.desktop-only{display:none!important}.mobile-only{display:flex!important}.main-content{margin-left:0}.header{left:0;padding:0 16px}.page-body{padding:20px 16px;padding-top:calc(var(--header-h) + 20px)}.sidebar{transform:translateX(-100%);transition:transform .3s var(--ease);z-index:1000;width:var(--sidebar-w);box-shadow:20px 0 50px rgba(0,0,0,.2)}.sidebar.open{transform:translateX(0)}.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:999;animation:fadeIn .2s ease-out}.sidebar-close-btn{background:none;border:none;color:var(--text-3);padding:8px;margin-left:auto;cursor:pointer}.category-grid,.quick-action-grid,.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px}.stat-value{font-size:28px}.header-actions{gap:6px}.header-icon-btn{width:32px;height:32px}}@media (max-width:640px){.category-grid,.quick-action-grid,.stats-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.header-user-btn span{display:none}.header-actions{gap:4px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));grid-gap:16px;gap:16px}.responsive-two-col{display:grid;grid-template-columns:1fr 1fr;grid-gap:28px;gap:28px}@media (max-width:1024px){.responsive-two-col{grid-template-columns:1fr;gap:20px}}@media (max-width:768px){.recharts-cartesian-axis-tick-value,.recharts-legend-item-text{font-size:10px!important}}.app-switcher-wrap{position:relative;display:flex;align-items:center}.app-switcher-btn{display:flex;align-items:center;padding:6px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;gap:10px;text-align:left;min-width:160px}.app-switcher-btn.active,.app-switcher-btn:hover{background:var(--bg-3);border-color:var(--brand-400)}.app-switcher-icon{width:32px;height:32px;background:var(--brand-50);color:var(--brand-500);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}[data-theme=dark] .app-switcher-icon{background:rgba(var(--brand-rgb),.1)}.app-switcher-info{flex:1 1;min-width:0}.app-switcher-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);margin-bottom:2px}.app-switcher-name{font-size:13px;font-weight:700;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-switcher-chevron{color:var(--text-3);transition:transform .2s ease}.app-switcher-chevron.rotated{transform:rotate(180deg)}.app-switcher-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:260px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;animation:slideInDown .2s ease}@keyframes slideInDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.app-switcher-header{padding:10px 14px;font-size:11px;font-weight:600;color:var(--text-3);background:var(--bg-2);border-bottom:1px solid var(--border)}.app-switcher-list{max-height:240px;overflow-y:auto}.app-switcher-item{width:100%;display:flex;align-items:center;padding:10px 14px;gap:12px;background:none;border:none;cursor:pointer;transition:background .15s ease;text-align:left}.app-switcher-item:hover{background:var(--bg-2)}.app-switcher-item.active{background:var(--brand-50)}[data-theme=dark] .app-switcher-item.active{background:rgba(var(--brand-rgb),.1)}.app-switcher-item-icon{width:28px;height:28px;border-radius:6px;overflow:hidden;background:var(--bg-3);flex-shrink:0}.app-switcher-item-icon img{width:100%;height:100%;object-fit:cover}.app-switcher-item-info{flex:1 1;min-width:0}.app-switcher-item-name{font-size:13px;font-weight:600;color:var(--text-1)}.app-switcher-item-id{font-size:11px;color:var(--text-3)}.app-switcher-item-check{color:var(--brand-500)}.autopost-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:32px;box-shadow:var(--shadow-sm)}.autopost-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.autopost-title-wrap{display:flex;gap:16px;align-items:center}.autopost-icon{width:40px;height:40px;border-radius:10px;background:var(--bg-2);color:var(--text-3);display:flex;align-items:center;justify-content:center;transition:all .3s ease}.autopost-icon.active{background:var(--brand-50);color:var(--brand-500);box-shadow:0 0 15px rgba(var(--brand-rgb),.2)}[data-theme=dark] .autopost-icon.active{background:rgba(var(--brand-rgb),.15)}.autopost-title{font-size:16px;font-weight:700;color:var(--text-1)}.autopost-subtitle{font-size:13px;color:var(--text-3)}.autopost-body{background:var(--bg-1);border-radius:var(--radius-md);padding:20px}.autopost-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:20px;gap:20px;margin-bottom:20px}.autopost-stat-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);margin-bottom:8px}.autopost-stat-value{font-size:20px;font-weight:700;color:var(--text-1)}.autopost-stat-input-wrap{display:flex;align-items:center;gap:8px}.autopost-stat-input-wrap input{width:60px;padding:4px 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg-2);color:var(--text-1);font-weight:700;text-align:center}.autopost-stat-input-wrap span{font-size:13px;color:var(--text-3)}.autopost-footer{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--border)}.autopost-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-3);font-weight:500}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--bg-3)}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:white;box-shadow:0 2px 4px rgba(0,0,0,.1)}input:checked+.slider{background-color:var(--brand-500)}input:focus+.slider{box-shadow:0 0 1px var(--brand-500)}input:checked+.slider:before{transform:translateX(20px)}.slider.round{border-radius:24px}.slider.round:before{border-radius:50%}.autoposter-grid{display:flex;flex-direction:column;gap:16px}.autoposter-card-horizontal{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;transition:all .2s ease}.autoposter-card-horizontal:hover{border-color:var(--brand-300);box-shadow:var(--shadow-md);transform:translateY(-2px)}.autoposter-info{display:flex;align-items:center;gap:16px;flex:1 1}.autoposter-icon{width:44px;height:44px;border-radius:12px;background:var(--bg-2);color:var(--text-3);display:flex;align-items:center;justify-content:center}.autoposter-icon.active{background:var(--brand-50);color:var(--brand-500)}[data-theme=dark] .autoposter-icon.active{background:rgba(var(--brand-rgb),.15)}.autoposter-name{font-size:16px;font-weight:700;color:var(--text-1);text-transform:capitalize}.autoposter-id{font-size:12px;color:var(--text-3);font-family:monospace}.autoposter-stats-row{display:flex;gap:40px;margin:0 40px}.autoposter-stat-item{text-align:center}.autoposter-stat-label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-3);margin-bottom:4px}.autoposter-stat-value{font-size:18px;font-weight:700;color:var(--text-1)}.autoposter-actions,.category-card-drag-handle{display:flex;align-items:center}.category-card-drag-handle{position:absolute;top:10px;left:10px;width:32px;height:32px;border-radius:8px;background:rgba(255,255,255,.9);justify-content:center;color:var(--text-3);cursor:-webkit-grab;cursor:grab;opacity:0;transition:all var(--transition);z-index:5;box-shadow:var(--shadow-sm);border:1px solid var(--border)}[data-theme=dark] .category-card-drag-handle{background:rgba(15,22,35,.8)}.category-card:hover .category-card-drag-handle{opacity:1}.category-card-drag-handle:active{cursor:-webkit-grabbing;cursor:grabbing}.category-card.dragging{box-shadow:0 20px 40px rgba(0,0,0,.2);border-color:var(--brand-500)}.category-list{display:flex;flex-direction:column;gap:12px}.category-list-item{display:flex;align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 16px;gap:16px;transition:all var(--transition)}.category-list-item:hover{background:var(--bg-card-hover);border-color:var(--border-brand);transform:translateX(4px)}.category-list-item.dragging{opacity:.5;border-color:var(--brand-500)}.category-list-img{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.category-list-info{flex:1 1;display:flex;flex-direction:column}.category-list-title{font-size:15px;font-weight:700;color:var(--text-1)}.category-list-meta{font-size:12px;color:var(--text-3)}.category-list-actions,.category-list-meta{display:flex;align-items:center;gap:8px}.category-list-drag-handle{color:var(--text-3);cursor:-webkit-grab;cursor:grab;padding:8px;margin:-8px;transition:color var(--transition)}.category-list-drag-handle:hover{color:var(--brand-500)}.view-toggle-group{display:flex;background:var(--bg-input);padding:4px;border-radius:var(--radius-sm);border:1px solid var(--border)}.view-toggle-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:calc(var(--radius-sm) - 2px);border:none;background:transparent;color:var(--text-3);transition:all var(--transition);cursor:pointer}.view-toggle-btn.active{background:var(--bg-card);color:var(--brand-500);box-shadow:var(--shadow-sm)}