:root{--sage-green: #5e6e52;--dark-sage: #4e5c44;--sage-light: #8a9c7c;--sage-xlight: #eff2ec;--khaki-brown: #8b7355;--cream: #f5f2ed;--white: #ffffff;--gray-50: #fafbfc;--gray-100: #f5f6f8;--gray-150: #eef0f3;--gray-200: #e4e7ec;--gray-300: #d0d5dd;--gray-400: #b0bac8;--gray-500: #8895a7;--gray-600: #667085;--gray-700: #475467;--gray-800: #344054;--gray-900: #101828;--success: #5e8c52;--success-bg: #e2edda;--danger: #a05248;--danger-bg: #ecddd8;--warning: #9c7c38;--warning-bg: #ede8d0;--info: #4a7a8c;--info-bg: #d8e8ed;--quarantine: #7a5e8a;--quarantine-bg: #e8e0ed;--sidebar-bg: #1a2318;--sidebar-header: #141d12;--sidebar-text: rgba(255, 255, 255, .72);--sidebar-muted: rgba(255, 255, 255, .42);--sidebar-hover: rgba(255, 255, 255, .07);--sidebar-active: rgba(122, 132, 113, .28);--sidebar-accent: #7a9168;--sidebar-width: 260px;--sidebar-collapsed: 64px;--surface: #ffffff;--surface-rgb: 255, 255, 255;--surface-2: #f7f5f1;--surface-3: #edeae3;--border: #e6e1d8;--border-strong: #d1cbbf;--text-primary: #1a1814;--text-secondary: #47433b;--text-muted: #78736a;--text-disabled: #b5afa6;--text-inverse: #ffffff;--bg-app: #f7f5f1;--shadow-xs: 0 1px 2px rgba(16, 24, 40, .04);--shadow-sm: 0 1px 3px rgba(16, 24, 40, .08), 0 1px 2px rgba(16, 24, 40, .06);--shadow-md: 0 4px 8px -2px rgba(16, 24, 40, .08), 0 2px 4px -2px rgba(16, 24, 40, .06);--shadow-lg: 0 12px 16px -4px rgba(16, 24, 40, .08), 0 4px 6px -2px rgba(16, 24, 40, .05);--shadow-xl: 0 20px 24px -4px rgba(16, 24, 40, .1), 0 8px 8px -4px rgba(16, 24, 40, .06);--radius-xs: 3px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-pill: 100px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--fs-xs: 11px;--fs-sm: 13px;--fs-base: 14px;--fs-md: 15px;--fs-lg: 16px;--fs-xl: 18px;--fs-2xl: 22px;--fs-3xl: 28px;--fs-4xl: 36px;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--fw-extrabold: 800;--lh-tight: 1.2;--lh-base: 1.5;--lh-loose: 1.75;--t-fast: .12s ease;--t-base: .2s ease;--t-slow: .32s ease;--t-sidebar: .28s cubic-bezier(.4, 0, .2, 1);--z-sidebar: 100;--z-top-bar: 90;--z-dropdown: 200;--z-modal: 1000;--z-toast: 2000}[data-theme=dark]{--surface: #181d16;--surface-rgb: 24, 29, 22;--surface-2: #1e2419;--surface-3: #252d20;--border: #2e3829;--border-strong: #3d4c37;--bg-app: #111510;--text-primary: #f0ece4;--text-secondary: #c8c2b8;--text-muted: #8a8478;--text-disabled: #52504a;--gray-50: #181d16;--gray-100: #1e2419;--gray-200: #2e3829;--gray-300: #3d4c37;--gray-400: #526047;--gray-500: #6e7f62;--gray-600: #94a386;--gray-700: #b8c8aa;--gray-800: #d4e0c8;--gray-900: #edf2e8;--success-bg: #111e0e;--danger-bg: #1e1210;--warning-bg: #1e1a0a;--info-bg: #0a1618;--quarantine-bg: #17111e;--sage-xlight: rgba(94, 110, 82, .15);--cream: #1e2419}[data-theme=dark] body,[data-theme=dark] .app-shell{background-image:radial-gradient(ellipse at 15% 20%,rgba(94,110,82,.12) 0%,transparent 55%),radial-gradient(ellipse at 85% 75%,rgba(139,115,85,.08) 0%,transparent 55%)}[data-theme=dark] .card{background:#181d169e;border-color:#ffffff12;box-shadow:0 4px 24px #00000040,0 1px 3px #00000026}[data-theme=dark] .card:hover{border-color:#ffffff1f;box-shadow:0 8px 32px #0000004d,0 2px 6px #0000002e}[data-theme=dark] .card-header{border-bottom-color:#ffffff0f}[data-theme=dark] .stat-card{background:#181d168c;border-color:#ffffff12;box-shadow:0 2px 12px #0003}[data-theme=dark] .stat-card:hover{border-color:#ffffff1f;box-shadow:0 6px 20px #00000047}[data-theme=dark] .stat-card.success{background:#5e8c521f;border-color:#5e8c5238}[data-theme=dark] .stat-card.warning{background:#9c7c381f;border-color:#9c7c3838}[data-theme=dark] .stat-card.danger{background:#a052481f;border-color:#a0524838}[data-theme=dark] .stat-card.info{background:#4a7a8c1f;border-color:#4a7a8c38}[data-theme=dark] .stat-card.quarantine{background:#7a5e8a1f;border-color:#7a5e8a38}[data-theme=dark] .top-bar{background:#111510b3;border-bottom-color:#ffffff0f}[data-theme=dark] .modal{background:#181d16c7;border-color:#ffffff14;box-shadow:0 20px 60px #0006,0 4px 16px #00000040}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:var(--font);font-size:var(--fs-base);font-weight:var(--fw-regular);line-height:var(--lh-base);color:var(--text-primary);background:var(--bg-app);background-image:radial-gradient(ellipse at 15% 20%,rgba(94,110,82,.18) 0%,transparent 55%),radial-gradient(ellipse at 85% 75%,rgba(139,115,85,.14) 0%,transparent 55%),radial-gradient(ellipse at 50% 50%,rgba(94,110,82,.06) 0%,transparent 80%);background-attachment:fixed;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}img{max-width:100%;display:block}input,select,textarea{font-family:inherit}.app-shell{display:flex;min-height:100dvh}.sidebar-rail{width:var(--sidebar-collapsed);background:var(--sidebar-bg);position:fixed;top:0;left:0;height:100vh;display:flex;flex-direction:column;align-items:center;z-index:var(--z-sidebar);box-shadow:2px 0 8px #0000002e}.rail-brand{width:40px;height:40px;margin:14px 0 10px;background:#ffffffe6;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.rail-brand img{width:90%;height:90%;object-fit:contain}.rail-brand-letter{font-size:20px;font-weight:800;color:var(--sidebar-bg);line-height:1}.rail-nav{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--sp-3) 0;overflow-y:auto;overflow-x:hidden;width:100%}.rail-nav::-webkit-scrollbar{width:0}.rail-btn{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--sidebar-text);background:transparent;border:none;cursor:pointer;transition:background var(--t-fast),color var(--t-fast);position:relative;flex-shrink:0}.rail-btn:hover,.rail-btn.open{background:var(--sidebar-hover);color:#fff}.rail-btn.active{background:var(--sidebar-active);color:#fff}.rail-btn.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--sidebar-accent);border-radius:0 2px 2px 0}.rail-user{width:34px;height:34px;margin:0 0 14px;border-radius:50%;background:linear-gradient(135deg,var(--sage-green),var(--sage-light));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:var(--fw-bold);color:#fff;cursor:pointer;flex-shrink:0;letter-spacing:-.5px;transition:opacity var(--t-fast)}.rail-user:hover{opacity:.85}.sidebar-popout{position:fixed;top:0;left:var(--sidebar-collapsed);height:100vh;width:230px;background:#1a2318e0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.08);z-index:calc(var(--z-sidebar) - 1);display:flex;flex-direction:column;padding:20px 0 16px;box-shadow:4px 0 24px #00000038;animation:popoutIn .16s ease}@keyframes popoutIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.popout-label{font-size:10px;font-weight:var(--fw-bold);color:var(--sidebar-muted);text-transform:uppercase;letter-spacing:.8px;padding:0 16px 10px;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:6px}.popout-item{display:flex;align-items:center;gap:10px;padding:9px 16px;color:var(--sidebar-text);font-size:var(--fs-md);font-weight:var(--fw-medium);text-decoration:none;transition:background var(--t-fast),color var(--t-fast);position:relative;white-space:nowrap}.popout-item svg{flex-shrink:0;width:15px;height:15px}.popout-item:hover{background:var(--sidebar-hover);color:#fff}.popout-item.active{background:var(--sidebar-active);color:#fff}.popout-item.active:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--sidebar-accent);border-radius:0 2px 2px 0}.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--sage-green),var(--sage-light));display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:var(--fw-bold);color:#fff;flex-shrink:0;letter-spacing:-.5px}.user-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:calc(var(--z-modal) - 1)}.user-menu{position:fixed;bottom:70px;left:calc(var(--sidebar-collapsed) + 8px);width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);z-index:var(--z-modal);overflow:hidden;animation:slideUp .18s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{padding:var(--sp-4);background:var(--surface-2);border-bottom:1px solid var(--border)}.user-menu-name{font-size:var(--fs-md);font-weight:var(--fw-semibold);color:var(--text-primary)}.user-menu-email{font-size:var(--fs-xs);color:var(--text-muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-item{display:flex;align-items:center;gap:var(--sp-3);padding:10px var(--sp-4);font-size:var(--fs-md);color:var(--text-secondary);cursor:pointer;transition:background var(--t-fast),color var(--t-fast);width:100%}.user-menu-item:hover{background:var(--surface-2);color:var(--text-primary)}.user-menu-item.danger{color:var(--danger)}.user-menu-item.danger:hover{background:var(--danger-bg)}.user-menu-divider{height:1px;background:var(--border);margin:var(--sp-1) 0}.theme-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px var(--sp-4);font-size:var(--fs-md);color:var(--text-secondary);cursor:pointer}.toggle-switch{width:36px;height:20px;background:var(--gray-300);border-radius:10px;position:relative;transition:background var(--t-base)}.toggle-switch.on{background:var(--sage-green)}.toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform var(--t-base);box-shadow:0 1px 3px #0003}.toggle-switch.on .toggle-knob{transform:translate(16px)}.main-content{margin-left:0;flex:1;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}.main-content.rail{margin-left:var(--sidebar-collapsed)}.top-bar{background:#ffffffa6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.5);padding:0 var(--sp-8);height:64px;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);position:sticky;top:0;z-index:var(--z-top-bar);flex-shrink:0}.top-bar-left{display:flex;flex-direction:column;gap:2px}.page-title{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--text-primary);line-height:1.2;letter-spacing:-.3px}.page-breadcrumb{font-size:var(--fs-xs);color:var(--text-muted)}.top-bar-actions{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}.content{padding:32px;flex:1}.content-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-6);gap:var(--sp-4);flex-wrap:wrap}.content-header-left h1{font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-primary);letter-spacing:-.4px}.content-header-left p{font-size:var(--fs-sm);color:var(--text-muted);margin-top:3px}.card{background:#ffffff94;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.55);border-radius:var(--radius-md);box-shadow:0 4px 24px #0000000f,0 1px 3px #0000000a;margin-bottom:var(--sp-5);transition:box-shadow var(--t-base),border-color var(--t-base)}.card:hover{box-shadow:0 8px 32px #00000017,0 2px 6px #0000000d;border-color:#ffffffbf}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid rgba(255,255,255,.4);background:transparent}.card-header h2{font-size:var(--fs-md);font-weight:var(--fw-semibold);color:var(--text-primary);display:flex;align-items:center;gap:var(--sp-2);margin:0}.card-header-actions{display:flex;align-items:center;gap:var(--sp-2)}.card-body{padding:24px}.card-body-sm{padding:var(--sp-4)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--sp-3);margin-bottom:var(--sp-6)}.stat-card{background:#ffffff7a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-lg);padding:var(--sp-5) var(--sp-5) var(--sp-4);box-shadow:0 2px 12px #0000000d;transition:box-shadow var(--t-base),border-color var(--t-base);position:relative;overflow:hidden;display:flex;flex-direction:column;gap:var(--sp-1)}.stat-card:before{display:none}.stat-card:hover{box-shadow:0 6px 20px #00000014;border-color:#ffffffb8}.stat-card.success{background:#5e8c521a;border-color:#5e8c523d}.stat-card.success:hover{background:#5e8c5226}.stat-card.warning{background:#9c7c381a;border-color:#9c7c383d}.stat-card.warning:hover{background:#9c7c3826}.stat-card.danger{background:#a052481a;border-color:#a052483d}.stat-card.danger:hover{background:#a0524826}.stat-card.info{background:#4a7a8c1a;border-color:#4a7a8c3d}.stat-card.info:hover{background:#4a7a8c26}.stat-card.quarantine{background:#7a5e8a1a;border-color:#7a5e8a3d}.stat-card.quarantine:hover{background:#7a5e8a26}.stat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:0}.stat-label{font-size:10px;font-weight:var(--fw-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px}.stat-card.success .stat-label{color:var(--success)}.stat-card.warning .stat-label{color:var(--warning)}.stat-card.danger .stat-label{color:var(--danger)}.stat-card.info .stat-label{color:var(--info)}.stat-card.quarantine .stat-label{color:var(--quarantine)}.stat-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:#0000000a;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all var(--t-base)}.stat-card.success .stat-icon{color:var(--success);background:#5e8c5224}.stat-card.warning .stat-icon{color:var(--warning);background:#9c7c3824}.stat-card.danger .stat-icon{color:var(--danger);background:#a0524824}.stat-card.info .stat-icon{color:var(--info);background:#4a7a8c24}.stat-card.quarantine .stat-icon{color:var(--quarantine);background:#7a5e8a24}.stat-value{font-size:var(--fs-3xl);font-weight:var(--fw-extrabold);color:var(--text-primary);line-height:1;letter-spacing:-1px;margin-top:var(--sp-1)}.stat-card.success .stat-value{color:var(--success)}.stat-card.warning .stat-value{color:var(--warning)}.stat-card.danger .stat-value{color:var(--danger)}.stat-card.info .stat-value{color:var(--info)}.stat-card.quarantine .stat-value{color:var(--quarantine)}.stat-meta{font-size:var(--fs-xs);color:var(--text-muted);display:flex;align-items:center;gap:4px}.stat-card.compact{padding:12px 16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:8px 14px;border-radius:var(--radius-md);font-size:var(--fs-md);font-weight:var(--fw-semibold);font-family:var(--font);line-height:1.4;cursor:pointer;border:1px solid transparent;transition:all var(--t-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;box-shadow:none}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-sm{padding:6px 10px;font-size:var(--fs-sm)}.btn-lg{padding:10px 18px;font-size:var(--fs-lg)}.btn-icon{padding:8px}.btn-icon.btn-sm{padding:6px}.btn-primary{background:var(--sage-green);color:#fff;border-color:var(--sage-green)}.btn-primary:hover{background:var(--sage-green);border-color:var(--sage-green);filter:brightness(.92)}.btn-secondary{background:var(--surface);color:var(--text-secondary);border-color:var(--border-strong)}.btn-secondary:hover{background:var(--surface-2);color:var(--text-primary)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover{background:var(--surface-2);color:var(--text-primary)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover{filter:brightness(.92)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{filter:brightness(.92)}.btn-warning{background:var(--warning);color:#fff;border-color:var(--warning)}.btn-warning:hover{filter:brightness(.92)}.btn-outline-primary{background:transparent;color:var(--sage-green);border-color:var(--sage-green)}.btn-outline-primary:hover{background:var(--sage-xlight)}.btn-outline-danger{background:transparent;color:var(--danger);border-color:var(--danger)}.btn-outline-danger:hover{background:var(--danger-bg)}.btn.loading{pointer-events:none;position:relative;color:transparent}.btn.loading:after{content:"";position:absolute;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.form-group{margin-bottom:var(--sp-4)}.form-label{display:block;font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-muted);margin-bottom:var(--sp-1)}.form-required{color:var(--danger);margin-left:2px}.form-input,.form-select,.form-textarea{width:100%;height:40px;padding:0 var(--sp-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-md);color:var(--text-primary);font-family:var(--font);transition:border-color var(--t-fast),box-shadow var(--t-fast);outline:none}.form-textarea{height:auto;min-height:100px;padding:var(--sp-3);resize:vertical}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--sage-green);box-shadow:0 0 0 3px #5e6e521a}.form-input.error,.form-select.error{border-color:var(--danger);box-shadow:0 0 0 3px #f044381a}.form-hint{font-size:var(--fs-xs);color:var(--text-muted);margin-top:var(--sp-1)}.form-error{font-size:var(--fs-xs);color:var(--danger);margin-top:var(--sp-1)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--sp-4)}.form-section-title{font-size:var(--fs-sm);font-weight:var(--fw-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--sp-4);padding-bottom:var(--sp-2);border-bottom:none}.table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:var(--fs-md)}thead{background:var(--surface-2);position:sticky;top:0;z-index:1}th{padding:10px var(--sp-4);text-align:left;font-size:var(--fs-xs);font-weight:var(--fw-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--surface-2)}td{padding:13px var(--sp-4);color:var(--text-secondary);border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr{transition:background var(--t-fast)}tbody tr:hover{background:var(--surface-2)}.table-actions{display:flex;gap:var(--sp-1);align-items:center}.filter-bar{display:flex;flex-direction:row;align-items:center;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-5);padding:var(--sp-3) var(--sp-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:none}.filter-bar .form-input,.filter-bar .form-select{height:30px;font-size:var(--fs-sm);padding:3px 8px;width:auto;min-width:120px;max-width:200px}.filter-group{display:flex;align-items:center;gap:var(--sp-2)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-pill);font-size:var(--fs-xs);font-weight:var(--fw-semibold);letter-spacing:.2px;white-space:nowrap}.badge-success{background:var(--success-bg);color:var(--success)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-quarantine{background:var(--quarantine-bg);color:var(--quarantine)}.badge-gray{background:var(--surface-3);color:var(--text-muted)}.badge-primary{background:var(--sage-xlight);color:var(--dark-sage)}[data-theme=dark] .badge-primary{background:#7a847133;color:#fff}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#10182880;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--sp-4);animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#ffffffb8;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.6);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000001f,0 4px 16px #0000000f;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;animation:modalIn .2s ease}.modal-lg{max-width:780px}.modal-xl{max-width:1000px}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--border)}.modal-title{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary)}.modal-close{width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--t-fast)}.modal-close:hover{background:var(--surface-2);color:var(--text-primary)}.modal-body{padding:var(--sp-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border);background:var(--surface-2);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.alert{display:flex;gap:var(--sp-3);padding:var(--sp-4);border-radius:var(--radius-md);border:1px solid transparent;font-size:var(--fs-md)}.alert-success{background:var(--success-bg);border-color:#12b76a66;color:var(--success)}.alert-danger{background:var(--danger-bg);border-color:#f0443866;color:var(--danger)}.alert-warning{background:var(--warning-bg);border-color:#f7900966;color:var(--warning)}.alert-info{background:var(--info-bg);border-color:#0ba5ec66;color:var(--info)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--sp-10) var(--sp-6);color:var(--text-muted);gap:var(--sp-3)}.empty-state-icon{width:48px;height:48px;color:var(--gray-400)}.empty-state h3{font-size:var(--fs-lg);font-weight:var(--fw-semibold);color:var(--text-secondary)}.empty-state p{font-size:var(--fs-md);max-width:320px}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.chart-wrapper{width:100%;overflow:hidden;position:relative}.recharts-text.recharts-cartesian-axis-tick-value{fill:var(--text-muted)!important;font-size:11px!important;font-family:var(--font)!important}.recharts-cartesian-axis-line,.recharts-cartesian-axis-tick-line{stroke:var(--border)!important}.recharts-cartesian-grid-vertical line{display:none}.recharts-cartesian-grid-horizontal line{stroke:var(--border)!important;stroke-opacity:.7}.recharts-line-dots .recharts-dot{opacity:0}.recharts-line .recharts-active-dot circle{opacity:1;r:5}.recharts-tooltip-wrapper{outline:none!important}.recharts-default-tooltip{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-md)!important;font-family:var(--font)!important;font-size:12px!important;padding:10px 14px!important}.recharts-tooltip-label{color:var(--text-secondary)!important;font-weight:var(--fw-semibold)!important;margin-bottom:4px!important;font-size:11px!important;text-transform:uppercase;letter-spacing:.5px}.recharts-tooltip-item{color:var(--text-primary)!important;font-size:13px!important}.recharts-legend-item-text{color:var(--text-muted)!important;font-size:11px!important;font-family:var(--font)!important}.chart-toggle{display:flex;gap:var(--sp-1);background:var(--surface-2);border-radius:var(--radius-sm);padding:3px}.chart-toggle-btn{padding:5px 10px;font-size:var(--fs-xs);font-weight:var(--fw-semibold);border-radius:4px;color:var(--text-muted);cursor:pointer;transition:all var(--t-fast);border:none;background:none;font-family:var(--font)}.chart-toggle-btn.active{background:var(--surface);color:var(--text-primary);box-shadow:var(--shadow-xs)}@keyframes tickerScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.price-ticker-wrap{display:flex;align-items:center;overflow:hidden;height:44px;width:100%;background:var(--surface-2);border-radius:var(--radius-md);border:1px solid var(--border);margin-top:var(--sp-1);margin-bottom:var(--sp-4)}.ticker-loading-placeholder{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;height:100%;color:var(--text-muted);font-size:var(--fs-xs);font-weight:600}.ticker-dot{width:8px;height:8px;background:var(--sage-green);border-radius:50%;animation:pulse 1.5s infinite}.price-ticker-scroll{flex:1;overflow:hidden;height:100%;position:relative;-webkit-mask-image:linear-gradient(to right,transparent,black 40px,black calc(100% - 40px),transparent);mask-image:linear-gradient(to right,transparent,black 40px,black calc(100% - 40px),transparent)}.price-ticker-track{display:inline-flex;align-items:center;height:100%;white-space:nowrap;animation:tickerScroll calc(var(--item-count, 10) * 3s) linear infinite}.price-ticker-track:hover{animation-play-state:paused}.ticker-item{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;margin-right:var(--sp-4);font-size:var(--fs-xs);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;cursor:pointer;text-decoration:none}.ticker-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.ticker-badge{padding:2px 6px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.3px}.ticker-price{font-weight:600;color:var(--text-primary);font-size:var(--fs-xs)}.ticker-unit{color:var(--text-muted);font-size:10px;margin-left:1px}.ticker-change{display:inline-flex;align-items:center;gap:2px;font-size:10px;font-weight:600;padding:1px 4px;border-radius:3px}.ticker-change.up{color:#16a34a;background:#22c55e1a}.ticker-change.down{color:#dc2626;background:#ef44441a}.ticker-change.flat{color:var(--text-muted);background:var(--surface-3)}.dropzone{border:2px dashed var(--border-strong);border-radius:var(--radius-md);padding:var(--sp-8) var(--sp-6);text-align:center;cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast);display:flex;flex-direction:column;align-items:center;gap:var(--sp-3)}.dropzone:hover,.dropzone.drag-over{border-color:var(--sage-green);background:var(--sage-xlight)}.dropzone-icon{color:var(--gray-400)}.dropzone h3{font-size:var(--fs-md);font-weight:var(--fw-semibold);color:var(--text-secondary)}.dropzone p{font-size:var(--fs-sm);color:var(--text-muted)}.page-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:var(--sp-5)}.page-tab{padding:10px var(--sp-4);font-size:var(--fs-base);font-weight:var(--fw-medium);color:var(--text-muted);cursor:pointer;border:none;background:none;font-family:var(--font);position:relative;transition:color var(--t-fast);white-space:nowrap}.page-tab:hover{color:var(--text-primary)}.page-tab.active{color:var(--sage-green);font-weight:var(--fw-medium)}.page-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--sage-green);border-radius:2px 2px 0 0}[data-tooltip]{position:relative}[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);padding:5px 8px;background:var(--gray-900);color:#fff;font-size:var(--fs-xs);border-radius:var(--radius-xs);white-space:nowrap;z-index:var(--z-dropdown);pointer-events:none}.sync-status{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;background:#93a2750d;border:1px solid transparent;transition:all .3s ease}.sync-status.offline{background:#ef44440d;border-color:#ef444433}.sync-status.pending{background:#f59e0b0d;border-color:#f59e0b33}.sync-status.synced{background:#10b9810d;border-color:#10b98133}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--white);position:relative;overflow:hidden;padding:var(--sp-6)}.auth-bg-logo{position:absolute;top:50%;right:-10%;transform:translateY(-50%);width:140vw;height:140vh;opacity:.1;z-index:0;pointer-events:none}.auth-bg-logo img{width:100%;height:100%;object-fit:contain;object-position:right center}.auth-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0000000a;border:1px solid var(--border);width:100%;max-width:400px;position:relative;z-index:1;padding:var(--sp-10) var(--sp-8);display:flex;flex-direction:column}.auth-card-header{text-align:center;margin-bottom:var(--sp-8)}.auth-logo-wrap{width:160px;height:160px;margin:0 auto var(--sp-4)}.auth-logo-img{width:100%;height:100%;object-fit:contain}.auth-app-name{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--text-primary);letter-spacing:1px;margin-bottom:4px}.auth-tagline{font-size:var(--fs-sm);color:var(--text-muted)}.auth-card-body{flex:1}.auth-card-footer{margin-top:var(--sp-8);text-align:center;font-size:var(--fs-sm);color:var(--text-muted)}.auth-card-footer a{color:var(--sage-green);font-weight:var(--fw-semibold)}.auth-version{position:absolute;bottom:var(--sp-6);left:50%;transform:translate(-50%);font-size:var(--fs-xs);color:var(--text-disabled);white-space:nowrap}.btn-login{width:100%;height:44px;background:var(--sage-green);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--fs-md);font-weight:var(--fw-bold);font-family:var(--font);cursor:pointer;transition:background var(--t-fast);margin-top:var(--sp-4);letter-spacing:.3px}.btn-login:hover{background:var(--dark-sage)}.btn-login:disabled{opacity:.6;cursor:not-allowed}@keyframes shake{0%,to{transform:translate(0)}15%,45%,75%{transform:translate(-6px)}30%,60%,90%{transform:translate(6px)}}.shake{animation:shake .4s ease}.text-sage{color:var(--sage-green)}.text-khaki{color:var(--khaki-brown)}[data-theme=dark] .text-sage,[data-theme=dark] .text-khaki{color:var(--text-primary)}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.mt-auto{margin-top:auto}.ml-auto{margin-left:auto}.text-muted{color:var(--text-muted);font-size:var(--fs-sm)}.text-sm{font-size:var(--fs-sm)}.text-xs{font-size:var(--fs-xs)}.text-bold{font-weight:var(--fw-bold)}.text-semibold{font-weight:var(--fw-semibold)}.text-right{text-align:right}.text-center{text-align:center}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.divider{height:1px;background:var(--border);margin:var(--sp-4) 0}.w-full{width:100%}.card-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5)}@media (max-width: 992px){.card-grid{grid-template-columns:1fr}}.detail-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.detail-tile{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:4px;box-shadow:none}.detail-tile-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.detail-tile-value{font-size:14px;font-weight:600;color:var(--text-primary)}.health-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:12px;box-shadow:none;transition:transform .2s}.health-card:active{transform:scale(.98)}.health-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.health-card-type{font-weight:700;color:var(--sage-green);font-size:14px}.health-card-date{font-size:12px;color:var(--text-muted)}@media (max-width: 480px){.detail-tiles{grid-template-columns:repeat(2,1fr)}}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:60px;background:rgba(var(--surface-rgb, 255, 255, 255),.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:var(--z-top-bar);padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -2px 10px #0000000d}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--text-muted);text-decoration:none;font-size:9px;font-weight:600;transition:all var(--t-fast);padding:4px 2px;min-width:16%;border-radius:var(--radius-sm)}.bottom-nav-item.active{color:var(--sage-green)}.bottom-nav-item:active{background:var(--surface-2)}.bottom-nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;text-align:center}@media (max-width: 768px){.main-content{margin-left:0!important;padding-bottom:60px}.content{padding:var(--sp-2) var(--sp-3)}.top-bar{padding-top:calc(24px + env(safe-area-inset-top,0px));padding-left:var(--sp-4);padding-right:var(--sp-4);padding-bottom:8px;height:auto;min-height:60px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;background:rgba(var(--surface-rgb, 255, 255, 255),.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;flex-direction:row;align-items:flex-end;justify-content:space-between;text-align:left}.top-bar-left{display:flex;flex-direction:column;align-items:flex-start}.page-title{font-size:16px;font-weight:700;margin-top:0;text-align:left}.stats-grid{grid-template-columns:repeat(2,1fr)!important;gap:8px!important;margin-bottom:12px}.stat-card.compact{padding:8px 12px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;text-align:left;aspect-ratio:auto;min-height:64px;border-radius:12px;min-width:0!important}.stat-card.compact .stat-label{font-size:10px;margin-bottom:2px;opacity:.8}.stat-card.compact .stat-value{font-size:20px!important;font-weight:800;line-height:1;letter-spacing:-.5px}.card{border-radius:12px;margin-bottom:12px;box-shadow:none;border:1px solid var(--border)}.card-header{padding:12px 16px;border-bottom:1px solid var(--border)}.card-header h2{font-size:13px}.form-row,.form-row-3{grid-template-columns:1fr;gap:12px}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0;width:100%;border-radius:0}table:not(.mobile-card-table){min-width:600px}.mobile-card-table{min-width:0!important;width:100%!important;margin:0!important}.mobile-hide{display:none!important}.mobile-card-table thead{display:none}.mobile-card-table,.mobile-card-table tbody,.mobile-card-table tr,.mobile-card-table td{display:block;width:100%}.mobile-card-table tr{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:12px;padding:10px 14px;box-shadow:none}.mobile-card-table td{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--surface-2);text-align:right;font-size:14px}.mobile-card-table td:last-child{border-bottom:none!important;padding-top:12px;justify-content:center}.mobile-card-table td:before{content:attr(data-label);font-weight:600;color:var(--text-muted);font-size:11px;text-transform:uppercase;flex:1;text-align:left}.mobile-card-table .table-actions{width:100%;justify-content:space-around}.card-body,.card-body-sm{padding:16px!important}.content-header-left h1{font-size:20px;letter-spacing:-.5px}.filter-bar{gap:8px;padding:10px;flex-direction:column;align-items:stretch}.filter-bar .form-input,.filter-bar .form-select{width:100%!important;max-width:none!important}.page-tabs{margin-top:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:8px;display:flex;gap:8px;scrollbar-width:none}.page-tabs::-webkit-scrollbar{display:none}.page-tab{white-space:nowrap;flex-shrink:0;padding:8px 16px;font-size:13px}}@media (max-width: 480px){.stats-grid{grid-template-columns:repeat(2,1fr)!important}.content-header{flex-direction:column;align-items:flex-start;gap:var(--sp-2)}.content-header-left h1{font-size:var(--fs-xl)}}
