:root{--bg-primary: #F8FAFC;--bg-secondary: #FFFFFF;--bg-tertiary: #F1F5F9;--bg-elevated: #FFFFFF;--text-primary: #0F172A;--text-secondary: #475569;--text-tertiary: #94A3B8;--accent-primary: #2563EB;--accent-primary-hover: #1D4ED8;--accent-primary-muted: rgba(37, 99, 235, .08);--accent-primary-glow: rgba(37, 99, 235, .15);--accent-blue: #2563EB;--accent-yellow: #F59E0B;--accent-green: #10B981;--accent-red: #EF4444;--accent-purple: #8B5CF6;--accent-orange: #F97316;--accent-success: var(--accent-green);--accent-danger: var(--accent-red);--accent-pink: var(--accent-red);--border-color: #E2E8F0;--border-subtle: #F1F5F9;--border-hover: rgba(37, 99, 235, .3);--card-bg: #FFFFFF;--card-border: #E2E8F0;--card-hover-border: rgba(37, 99, 235, .2);--card-hover-bg: #FFFFFF;--glass-bg: var(--card-bg);--glass-border: var(--card-border);--gold-gradient: linear-gradient(135deg, #2563EB 0%, #3B82F6 100%);--sidebar-gradient: none;--sidebar-bg: #FFFFFF;--sidebar-active-bg: #EFF6FF;--sidebar-active-border: #2563EB;--sidebar-header-color: #94A3B8;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--font-display: "Inter", system-ui, -apple-system, sans-serif;--font-body: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--font-family: var(--font-body);--font-size-xs: 11px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 30px;--font-size-4xl: 36px;--elevation-1: 0 1px 2px rgba(0, 0, 0, .05);--elevation-2: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--elevation-3: 0 10px 25px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-sm: var(--elevation-1);--shadow-md: var(--elevation-2);--shadow-lg: var(--elevation-3);--shadow-neon-blue: none;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-3xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--bp-mobile-lg: 480px;--bp-tablet: 768px;--bp-desktop: 1024px;--bp-wide: 1280px;--page-max-width: 1600px;--page-max-width-narrow: 1100px;--touch-target: 44px;--safe-top: env(safe-area-inset-top, 0px);--safe-right: env(safe-area-inset-right, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px)}[data-theme=dark]{--bg-primary: #0F172A;--bg-secondary: #1E293B;--bg-tertiary: #334155;--bg-elevated: #1E293B;--text-primary: #F1F5F9;--text-secondary: #94A3B8;--text-tertiary: #64748B;--accent-primary: #3B82F6;--accent-primary-hover: #60A5FA;--accent-primary-muted: rgba(59, 130, 246, .15);--accent-primary-glow: rgba(59, 130, 246, .25);--border-color: rgba(255, 255, 255, .08);--border-subtle: rgba(255, 255, 255, .04);--border-hover: rgba(59, 130, 246, .3);--card-bg: #1E293B;--card-border: rgba(255, 255, 255, .06);--card-hover-border: rgba(59, 130, 246, .2);--card-hover-bg: #263548;--sidebar-bg: #0F172A;--sidebar-active-bg: rgba(59, 130, 246, .1);--sidebar-active-border: #3B82F6;--sidebar-header-color: #64748B;--sidebar-gradient: none;--elevation-1: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--elevation-2: 0 4px 16px rgba(0, 0, 0, .35);--elevation-3: 0 12px 40px rgba(0, 0, 0, .45);--accent-green: #34D399;--accent-red: #F87171;--accent-purple: #A78BFA;--accent-blue: #60A5FA;scrollbar-color:rgba(255,255,255,.08) transparent}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;line-height:1.6;font-size:var(--font-size-md)}#root{min-height:100vh;display:flex}h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.3;letter-spacing:-.02em;color:var(--text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4,h5,h6{font-family:var(--font-body);font-weight:600;color:var(--text-primary)}p{color:var(--text-secondary);line-height:1.7}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit;color:inherit}ul,ol{list-style:none}::selection{background:var(--accent-primary-muted);color:var(--accent-primary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0000001a;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#0000002e}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#ffffff14}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#ffffff26}*{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.1) transparent}[data-theme=dark] *{scrollbar-color:rgba(255,255,255,.08) transparent}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:var(--radius-sm)}.badge-btn{padding:5px 14px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;letter-spacing:.01em}.badge-btn.edit{background:var(--accent-primary-muted);color:var(--accent-primary);border-color:#2563eb26}.badge-btn.edit:hover{background:#2563eb26;transform:translateY(-1px)}.badge-btn.delete{background:#ef444414;color:var(--accent-red);border-color:#ef444426}.badge-btn.delete:hover{background:#ef444426;transform:translateY(-1px)}.card-hover{transition:all .2s var(--ease-out-expo)}.card-hover:hover{transform:translateY(-1px);box-shadow:var(--elevation-2);border-color:var(--card-hover-border)}img{transition:opacity .3s ease}.font-mono{font-family:var(--font-mono)}.font-display{font-family:var(--font-display)}.text-accent,.text-gold{color:var(--accent-primary)}.page-container{width:100%;max-width:var(--page-max-width);padding:var(--space-6)}.page-header{margin-bottom:var(--space-6)}.page-header h1{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-1)}.page-header p{color:var(--text-tertiary);font-size:var(--font-size-md)}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--elevation-1);transition:all var(--transition-fast)}.card:hover{box-shadow:var(--elevation-2);border-color:var(--card-hover-border)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:500;line-height:1.4}.status-badge.success{background:#10b9811a;color:#059669}.status-badge.warning{background:#f59e0b1a;color:#d97706}.status-badge.error{background:#ef444414;color:#dc2626}.status-badge.info{background:var(--accent-primary-muted);color:var(--accent-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);min-height:36px;border:1px solid transparent}.btn-primary{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.btn-primary:hover{background:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:var(--elevation-1)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--text-tertiary)}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover{opacity:.9;transform:translateY(-1px)}.table-container{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--elevation-1)}.table-container table{width:100%;border-collapse:collapse}.table-container th{text-align:left;padding:12px 16px;font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.table-container td{padding:12px 16px;font-size:var(--font-size-sm);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle)}.table-container tr:last-child td{border-bottom:none}.table-container tr:hover td{background:var(--bg-tertiary)}.input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-md);font-family:var(--font-body);color:var(--text-primary);background:var(--bg-secondary);transition:all var(--transition-fast);min-height:38px}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-muted)}.input::placeholder{color:var(--text-tertiary)}@media(max-width:768px){.page-container{padding:var(--space-4)}.page-header h1{font-size:var(--font-size-xl)}}@media(max-width:768px){*{-webkit-tap-highlight-color:rgba(0,0,0,0)}*:focus-visible{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}}body{padding-left:var(--safe-left);padding-right:var(--safe-right)}.scroll-touch{-webkit-overflow-scrolling:touch;overflow-y:scroll}.touch-target{min-height:var(--touch-target);min-width:var(--touch-target)}.desktop-only{display:initial}@media(max-width:768px){.mobile-only{display:initial}.desktop-only{display:none!important}}.mobile-only-flex,.mobile-only-block{display:none}.desktop-only-flex{display:flex}.desktop-only-block{display:block}@media(max-width:768px){.mobile-only-flex{display:flex}.mobile-only-block{display:block}.desktop-only-flex,.desktop-only-block{display:none!important}}body.scroll-locked{overflow:hidden;position:relative}@media(max-width:767px){input,textarea,select,.input{font-size:16px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.container{width:100%;max-width:100%;margin:0 auto;padding:var(--space-4)}@media(min-width:768px){.container{padding:var(--space-5)}}@media(min-width:1024px){.container{padding:var(--space-6);max-width:var(--page-max-width)}}.container--narrow{max-width:640px}.stack{display:flex;flex-direction:column;gap:var(--space-4)}.stack-sm{gap:var(--space-2)}.stack-md{gap:var(--space-4)}.stack-lg{gap:var(--space-6)}.cluster{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-3)}.grid-auto--sm{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.grid-auto--lg{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.scroll-x{display:flex;gap:var(--space-2);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scroll-snap-type:x proximity;padding-bottom:4px}@media(max-width:767px){.scroll-x::-webkit-scrollbar{display:none}.scroll-x{scrollbar-width:none}}.scroll-x>*{flex-shrink:0;scroll-snap-align:start}.sticky-bottom{position:sticky;bottom:0;background:var(--bg-primary);border-top:1px solid var(--border-color);padding:var(--space-3) var(--space-4);padding-bottom:calc(var(--space-3) + var(--safe-bottom));z-index:5}.page-head{margin-bottom:var(--space-4)}.page-head__title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:4px;color:var(--text-primary)}.page-head__subtitle{font-size:var(--font-size-sm);color:var(--text-tertiary)}@media(min-width:768px){.page-head{margin-bottom:var(--space-5)}.page-head__title{font-size:var(--font-size-2xl)}}.full-bleed-mobile{margin-left:calc(-1 * var(--space-4));margin-right:calc(-1 * var(--space-4))}@media(min-width:768px){.full-bleed-mobile{margin-left:0;margin-right:0}}.hide-on-mobile{display:initial}.hide-on-desktop{display:none}@media(max-width:767px){.hide-on-mobile{display:none!important}.hide-on-desktop{display:initial}}.focus-ring:focus-visible{outline:2px solid var(--accent-primary)!important;outline-offset:2px!important;border-radius:var(--radius-sm)}.detail-panel-overlay{position:fixed;inset:0;background:#0006;z-index:199;opacity:0;pointer-events:none;transition:opacity .25s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.detail-panel-overlay--open{opacity:1;pointer-events:auto}.detail-panel{position:fixed;background:var(--bg-secondary);z-index:200;display:flex;flex-direction:column;box-shadow:var(--elevation-3);transition:transform .3s var(--ease-out-expo);will-change:transform;left:0;right:0;bottom:0;max-height:92dvh;height:92dvh;border-top-left-radius:var(--radius-2xl);border-top-right-radius:var(--radius-2xl);padding-top:env(safe-area-inset-top,0);padding-bottom:var(--safe-bottom);transform:translateY(100%)}.detail-panel--open{transform:translateY(0)}.detail-panel__drag-handle{width:40px;height:4px;background:var(--border-color);border-radius:var(--radius-full);margin:var(--space-2) auto var(--space-3);flex-shrink:0}@media(min-width:768px)and (max-width:1023px){.detail-panel{inset:0 0 0 auto;width:60%;max-width:520px;height:100vh;max-height:100vh;border-radius:var(--radius-2xl) 0 0 var(--radius-2xl);transform:translate(100%);padding-top:0}.detail-panel--open{transform:translate(0)}.detail-panel__drag-handle{display:none}}@media(min-width:1024px){.detail-panel{inset:0 0 0 auto;width:var(--detail-panel-width, 480px);height:100vh;max-height:100vh;border-radius:0;border-left:1px solid var(--border-color);transform:translate(100%);padding-top:0}.detail-panel--open{transform:translate(0)}.detail-panel__drag-handle{display:none}}.detail-panel__body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding:var(--space-4) var(--space-5) var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.detail-panel__close-btn{background:transparent;border:none;color:var(--text-secondary);font-size:22px;width:var(--touch-target);height:var(--touch-target);display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--radius-md);flex-shrink:0}.detail-panel__close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--bg-secondary) 50%,var(--bg-tertiary) 100%);background-size:800px 100%;animation:skeleton-shimmer 1.4s linear infinite;border-radius:var(--radius-sm);display:block}.skeleton--text{height:14px;width:100%;margin-bottom:6px}.skeleton--text-lg{height:22px}.skeleton--text-sm{height:11px}.skeleton--w-25{width:25%}.skeleton--w-50{width:50%}.skeleton--w-75{width:75%}.skeleton--circle{border-radius:50%}.skeleton--card{height:96px;border-radius:var(--radius-lg);margin-bottom:var(--space-3)}.skeleton--row{height:56px;border-radius:var(--radius-md);margin-bottom:var(--space-2)}.skeleton-stack{display:flex;flex-direction:column;gap:var(--space-2)}@media(prefers-reduced-motion:reduce){.skeleton{animation:none}}.page-transition{animation:page-fade-in .25s cubic-bezier(.25,.1,.25,1) both}@keyframes page-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.app-container{display:flex;width:100%;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}.sidebar{width:250px;background:var(--sidebar-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:var(--space-4) var(--space-3);position:fixed;height:100vh;top:0;left:0;z-index:100;transition:width .25s var(--ease-out-expo),padding .25s var(--ease-out-expo),transform .3s ease;will-change:transform;overflow:hidden}.sidebar.collapsed{width:68px;padding:var(--space-4) var(--space-2)}.sidebar-header{margin-bottom:var(--space-4);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;padding:0 var(--space-2)}.sidebar-logo{width:32px;height:auto;display:block;transition:width .25s var(--ease-out-expo)}.sidebar.collapsed .sidebar-logo{width:28px}.sidebar-brand{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.sidebar-toggle{background:transparent;border:1px solid var(--border-color);color:var(--text-tertiary);width:28px;height:28px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.sidebar-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:0}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-thumb{background:#0000000f;border-radius:var(--radius-full)}[data-theme=dark] .sidebar-nav::-webkit-scrollbar-thumb{background:var(--border-color)}.nav-group{margin-bottom:var(--space-1)}.nav-group-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 10px;border:none;background:none;color:var(--text-tertiary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);margin-top:var(--space-2)}.nav-group-header:hover{color:var(--text-secondary);background:var(--bg-tertiary)}.nav-group-header-left{display:flex;align-items:center;gap:8px}.nav-group-icon{display:flex;align-items:center;opacity:.5}.nav-group-icon svg{width:14px;height:14px}.nav-group-chevron{display:flex;align-items:center;transition:transform .2s ease;transform:rotate(-90deg)}.nav-group-chevron.expanded{transform:rotate(0)}.nav-list{display:flex;flex-direction:column;gap:1px}.nav-list-nested{padding-left:4px}.nav-item{display:flex;align-items:center;padding:7px 10px;border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;position:relative;border-left:3px solid transparent;min-height:34px;text-decoration:none}.sidebar.collapsed .nav-item{justify-content:center;padding:8px;border-left:none}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--sidebar-active-bg);color:var(--accent-primary);border-left-color:var(--sidebar-active-border);font-weight:600}.sidebar.collapsed .nav-item.active{border-left:none;border-bottom:2px solid var(--accent-primary)}.nav-icon{display:flex;align-items:center;flex-shrink:0;transition:all var(--transition-fast);opacity:.55;margin-right:10px}.sidebar.collapsed .nav-icon{margin-right:0}.nav-icon.active{opacity:1}.nav-label{opacity:1;transition:opacity .15s ease;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .nav-label{opacity:0;width:0;overflow:hidden}.sidebar-footer{flex-shrink:0;padding-top:var(--space-3);border-top:1px solid var(--border-color);margin-top:var(--space-3)}.theme-toggle{display:flex;align-items:center;gap:var(--space-2);padding:8px 10px;border-radius:var(--radius-md);color:var(--text-tertiary);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast);width:100%;font-size:13px}.theme-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary)}.theme-icon{display:flex;align-items:center;flex-shrink:0}.theme-label{font-size:13px;font-weight:500}.sidebar.collapsed .theme-toggle{justify-content:center}.sidebar.collapsed .theme-label{display:none}.main-content{flex:1;margin-left:250px;padding:var(--space-6);transition:margin-left .25s var(--ease-out-expo);min-height:100vh;max-width:100%}.main-content.collapsed{margin-left:68px}.sidebar-brand-row{display:flex;align-items:center;gap:8px}.sidebar-brand-icon{font-size:20px}.sidebar-divider{margin:8px 10px;border-top:1px solid var(--border-subtle)}.sidebar-section-label{padding:4px 12px;font-size:10px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em}.sidebar-user-row{display:flex;align-items:center;gap:8px;padding:6px 10px;margin-top:4px}.sidebar-user-name{flex:1;font-size:12px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__logout-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);background:transparent;border:1px solid var(--border-color);color:var(--text-tertiary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}.sidebar__logout-btn:hover{background:var(--bg-tertiary);color:var(--accent-red)}.mobile-menu-btn{display:none;position:fixed;top:var(--space-4);left:var(--space-4);z-index:90;min-width:var(--touch-target);min-height:var(--touch-target);width:44px;height:44px;border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--elevation-2)}.mobile-menu-btn:hover{color:var(--accent-primary);border-color:var(--accent-primary)}.mobile-overlay{display:none;position:fixed;inset:0;background:#0006;z-index:99;opacity:0;transition:opacity .3s ease;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-overlay.active{opacity:1;pointer-events:auto}.mobile-only{display:none}.desktop-only{display:flex}@media(max-width:1024px){.main-content{padding:var(--space-5)}}@media(max-width:768px){.mobile-menu-btn{display:flex}.mobile-overlay{display:block}.mobile-only{display:flex}.desktop-only{display:none}.sidebar{transform:translate(-100%);transition:transform .3s var(--ease-out-expo);width:280px;max-width:85vw;box-shadow:var(--elevation-3);padding-top:calc(var(--space-4) + var(--safe-top));padding-bottom:var(--safe-bottom);padding-left:calc(var(--space-3) + var(--safe-left))}.sidebar.mobile-open{transform:translate(0);box-shadow:0 0 40px #00000040}.sidebar-footer{padding-bottom:calc(16px + var(--safe-bottom))}.sidebar.collapsed{width:280px}.sidebar.collapsed .nav-label{opacity:1;width:auto}.sidebar.collapsed .nav-icon{margin-right:10px}.sidebar.collapsed .nav-item{justify-content:flex-start;padding:8px 10px;border-left:3px solid transparent}.sidebar.collapsed .theme-label{display:inline}.sidebar.collapsed .theme-toggle{justify-content:flex-start}.main-content{margin-left:0;padding:var(--space-4);padding-top:calc(var(--space-4) + 56px)}.main-content.collapsed{margin-left:0}.nav-item{min-height:44px;font-size:15px}}@media(max-width:480px){.main-content{padding:var(--space-3);padding-top:calc(var(--space-3) + 56px)}}@media(min-width:768px)and (max-width:1023px){.sidebar{transform:translate(0);width:68px;padding:var(--space-4) var(--space-2)}.sidebar .nav-label,.sidebar .theme-label,.sidebar .sidebar-brand{opacity:0;width:0;overflow:hidden}.sidebar .nav-icon{margin-right:0}.sidebar .nav-item{justify-content:center;padding:8px;border-left:none}.sidebar .nav-item.active{border-left:none;border-bottom:2px solid var(--accent-primary)}.sidebar:not(.collapsed){width:250px;padding:var(--space-4) var(--space-3)}.sidebar:not(.collapsed) .nav-label,.sidebar:not(.collapsed) .theme-label,.sidebar:not(.collapsed) .sidebar-brand{opacity:1;width:auto}.sidebar:not(.collapsed) .nav-icon{margin-right:10px}.sidebar:not(.collapsed) .nav-item{justify-content:flex-start;padding:7px 10px;border-left:3px solid transparent}.sidebar:not(.collapsed) .nav-item.active{border-left-color:var(--sidebar-active-border);border-bottom:none}.mobile-menu-btn,.mobile-overlay{display:none}.main-content{margin-left:68px;padding:var(--space-5);padding-top:var(--space-5)}.main-content.collapsed{margin-left:250px}}.error-boundary{min-height:100dvh;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:var(--bg-primary)}.error-boundary__card{width:100%;max-width:540px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--elevation-2);text-align:center}.error-boundary__icon{font-size:36px;margin-bottom:var(--space-3)}.error-boundary__title{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-2)}.error-boundary__message{font-size:var(--font-size-md);color:var(--text-secondary);margin-bottom:var(--space-3)}.error-boundary__stack{background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:var(--space-3);margin-bottom:var(--space-4);text-align:left;font-size:11px;color:var(--text-tertiary);font-family:var(--font-mono);overflow-x:auto;white-space:pre}.error-boundary__actions{display:flex;gap:var(--space-2);justify-content:center;flex-wrap:wrap}.error-boundary__btn{background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);padding:0 var(--space-5);height:var(--touch-target);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.error-boundary__btn:hover{background:var(--accent-primary-hover)}.error-boundary__btn--ghost{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.error-boundary__btn--ghost:hover{background:var(--bg-secondary);color:var(--text-primary)}@media(min-width:768px){.error-boundary__title{font-size:var(--font-size-2xl)}}.toast-stack{position:fixed;bottom:calc(24px + var(--safe-bottom));left:24px;right:24px;display:flex;flex-direction:column-reverse;gap:var(--space-2);z-index:999;pointer-events:none}@media(min-width:480px){.toast-stack{left:auto;max-width:380px}}.toast{pointer-events:auto;padding:12px 18px;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;box-shadow:var(--elevation-3);cursor:pointer;animation:toast-in .25s var(--ease-out-expo)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast--ok{background:#22c55e26;color:var(--accent-green);border:1px solid rgba(34,197,94,.3)}.toast--err{background:#ef444426;color:var(--accent-red);border:1px solid rgba(239,68,68,.3)}.toast--info{background:var(--accent-primary-muted);color:var(--accent-primary);border:1px solid var(--accent-primary)}
