:root{--bg-marketing: #16171f;--bg-panel: #1b1c25;--bg-surface: #21222e;--bg-surface-2: #2b2d3a;--bg-white-02: rgba(255, 255, 255, .02);--bg-white-04: rgba(255, 255, 255, .04);--bg-white-05: rgba(255, 255, 255, .05);--text-primary: #f7f8f8;--text-secondary: #cbd5e1;--text-tertiary: #9aa6b6;--text-quaternary: #7d8492;--accent-primary: #7170ff;--accent-primary-hover: #828fff;--accent-primary-soft: rgba(113, 112, 255, .12);--accent-primary-glow: rgba(113, 112, 255, .28);--accent-indigo: var(--accent-primary);--accent-violet: var(--accent-primary);--accent-violet-hover: var(--accent-primary-hover);--accent-violet-soft: var(--accent-primary-soft);--accent-violet-glow: var(--accent-primary-glow);--border-subtle: rgba(255, 255, 255, .05);--border-standard: rgba(255, 255, 255, .08);--border-solid: #2c2e3a;--success: #10b981;--success-dark: #27a644;--warn: #f59e0b;--danger: #ef4444;--vttb-warn-bg: rgba(245, 158, 11, .13);--vttb-warn-fg: #fcd34d;--vttb-warn-border: rgba(245, 158, 11, .5);--vttb-success-bg: rgba(16, 185, 129, .13);--vttb-success-fg: #6ee7b7;--vttb-success-border: rgba(16, 185, 129, .5);--vttb-danger-bg: rgba(239, 68, 68, .13);--vttb-danger-fg: #fca5a5;--vttb-danger-border: rgba(239, 68, 68, .5);--vttb-rating-on: #fbbf24;--vttb-rating-off: #4b5563;--vttb-on-accent: rgba(255, 255, 255, .25);--accent-orange: #f97316;--hl-green: #4ade80;--hl-red: #f87171;--hl-purple: #c084fc;--hl-orange: #fb923c;--hl-cyan: #67e8f9;--hl-violet: #c4b5fd;--hl-amber: #fcd34d;--hl-slate: #94a3b8;--orange: var(--accent-primary);--orange-lt: var(--accent-primary-soft);--orange-glow: var(--accent-primary-glow);--navy: var(--bg-marketing);--navy-2: var(--bg-panel);--navy-3: var(--bg-surface);--cyan: #00c8ee;--emerald: var(--success);--amber: var(--warn);--red: var(--danger);--indigo: var(--accent-primary);--border: var(--border-standard);--navy-card: var(--bg-white-02);--navy-border: var(--border-standard);--navy-bg: var(--bg-surface-2);--bg-elev: var(--bg-surface-2);--bg-card: var(--bg-panel);--text-muted: var(--text-tertiary);--t1: var(--text-primary);--t2: var(--text-secondary);--t3: var(--text-tertiary);--font-base: "Inter", "Inter Variable", -apple-system, "SF Pro Display", system-ui, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-size-base: 16px;--sidebar-w: 236px;--topbar-h: 64px;--r-micro: 2px;--r-small: 4px;--r-btn: 6px;--r-input: 6px;--r-card: 8px;--r-panel: 12px;--r-large: 22px;--r-pill: 9999px;--shadow-ring: 0 0 0 1px rgba(0, 0, 0, .2);--shadow-elevated: 0 2px 4px rgba(0, 0, 0, .4);--shadow-dialog: 0 8px 2px rgba(0, 0, 0, 0), 0 5px 2px rgba(0, 0, 0, .01), 0 3px 2px rgba(0, 0, 0, .04), 0 1px 1px rgba(0, 0, 0, .07), 0 0 1px rgba(0, 0, 0, .08);--primary: var(--accent-primary);--primary-press: var(--accent-primary-hover);--primary-tint: var(--accent-primary-soft);--moment: #ff9033;--moment-soft: rgba(255, 144, 51, .16);--alarm: #ff4d6d;--alarm-soft: rgba(255, 77, 109, .14);--glass-bg: rgba(10, 10, 18, .72);--glass-stroke: rgba(107, 108, 255, .1);--glass-edge: rgba(255, 255, 255, .04);--glass-blur: blur(20px) saturate(180%);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .4);--duration-fast: .12s;--duration-normal: .2s;--duration-slow: .36s;--duration-exit: .24s;--duration-stagger: 80ms;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--z-base: 0;--z-sticky: 50;--z-dropdown: 100;--z-modal: 400;--z-toast: 500;--z-tooltip: 600;--z-overlay: 700;--z-debug: 9999;--focus-ring-width: 2px;--focus-ring-offset: 2px;--focus-ring-color: var(--primary);--focus-ring-solid: 0 0 0 var(--focus-ring-offset) #ffffff, 0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color);--focus-ring-solid-dark: 0 0 0 var(--focus-ring-offset) #0a0a12, 0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color);--focus-ring-glass: inset 0 0 0 1px rgba(255, 255, 255, .6), 0 0 0 var(--focus-ring-offset) rgba(255, 255, 255, .2), 0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color);--bp-mobile: 0px;--bp-tablet: 640px;--bp-laptop: 1024px;--bp-desktop: 1440px;--bp-wide: 1920px;--container-narrow: 720px;--container-default: 1200px;--container-wide: 1440px;--container-data: 1680px;--touch-min: 44px;--touch-comfort: 48px;--touch-dense: 36px;--font-display-xl: clamp(2rem, 3.5vw + .5rem, 2.75rem);--font-display-lg: clamp(1.5rem, 2.5vw + .5rem, 2rem);--font-display-md: clamp(1.25rem, 1.5vw + .5rem, 1.5rem);--font-kpi-display: clamp(2.5rem, 5vw + .5rem, 3.5rem);--spacing-section-y: clamp(2rem, 5vw, 4rem);--spacing-card-pad: clamp(1rem, 1.5vw + .25rem, 1.5rem);--spacing-page-pad-x: clamp(1rem, 3vw + .5rem, 3rem)}html.light{--bg-marketing: #f7f8f8;--bg-panel: #ffffff;--bg-surface: #f3f4f5;--bg-surface-2: #e8e9eb;--bg-white-02: rgba(0, 0, 0, .02);--bg-white-04: rgba(0, 0, 0, .04);--bg-white-05: rgba(0, 0, 0, .06);--text-primary: #0f172a;--text-secondary: #334155;--text-tertiary: #64748b;--text-quaternary: #94a3b8;--accent-primary: #5e6ad2;--accent-primary-hover: #4f5abf;--accent-primary-soft: rgba(94, 106, 210, .1);--accent-primary-glow: rgba(94, 106, 210, .18);--border-subtle: rgba(0, 0, 0, .06);--border-standard: rgba(0, 0, 0, .1);--border-solid: #d0d6e0;--success: #15803d;--success-dark: #166534;--warn: #b45309;--danger: #b91c1c;--cyan: #0e7490;--vttb-warn-bg: rgba(245, 158, 11, .1);--vttb-warn-fg: #b45309;--vttb-warn-border: rgba(245, 158, 11, .45);--vttb-success-bg: rgba(16, 185, 129, .08);--vttb-success-fg: #047857;--vttb-success-border: rgba(16, 185, 129, .45);--vttb-danger-bg: rgba(239, 68, 68, .08);--vttb-danger-fg: #b91c1c;--vttb-danger-border: rgba(239, 68, 68, .45);--vttb-rating-on: #f59e0b;--vttb-rating-off: #cbd5e1;--vttb-on-accent: rgba(255, 255, 255, .3);--accent-orange: #ea580c;--hl-green: #15803d;--hl-red: #b91c1c;--hl-purple: #7e22ce;--hl-orange: #c2410c;--hl-cyan: #0e7490;--hl-violet: #6d28d9;--hl-amber: #b45309;--hl-slate: #475569;--shadow-ring: 0 0 0 1px rgba(0, 0, 0, .06);--shadow-elevated: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--shadow-dialog: 0 4px 6px rgba(0, 0, 0, .05), 0 10px 15px rgba(0, 0, 0, .08), 0 0 0 1px rgba(0, 0, 0, .05);--moment: #f58220;--moment-soft: rgba(245, 130, 32, .12);--alarm: #e91429;--alarm-soft: rgba(233, 20, 41, .1);--glass-bg: rgba(255, 255, 252, .82);--glass-stroke: rgba(30, 31, 142, .06);--glass-edge: rgba(255, 255, 255, .6);--glass-blur: blur(20px) saturate(180%);--glass-shadow: 0 8px 32px rgba(30, 31, 142, .08)}html.theme-blue{--accent-primary: #3b82f6;--accent-primary-hover: #60a5fa;--accent-primary-soft: rgba(59, 130, 246, .12);--accent-primary-glow: rgba(59, 130, 246, .28)}html.theme-violet{--accent-primary: #7170ff;--accent-primary-hover: #828fff;--accent-primary-soft: rgba(113, 112, 255, .12);--accent-primary-glow: rgba(113, 112, 255, .28)}html.theme-green{--accent-primary: #22c55e;--accent-primary-hover: #4ade80;--accent-primary-soft: rgba(34, 197, 94, .12);--accent-primary-glow: rgba(34, 197, 94, .28)}html.theme-pink{--accent-primary: #ec4899;--accent-primary-hover: #f472b6;--accent-primary-soft: rgba(236, 72, 153, .12);--accent-primary-glow: rgba(236, 72, 153, .28)}html.theme-amber{--accent-primary: #f59e0b;--accent-primary-hover: #fbbf24;--accent-primary-soft: rgba(245, 158, 11, .14);--accent-primary-glow: rgba(245, 158, 11, .3)}html.theme-orange{--accent-primary: #f97316;--accent-primary-hover: #fb923c;--accent-primary-soft: rgba(249, 115, 22, .14);--accent-primary-glow: rgba(249, 115, 22, .3)}html.theme-teal{--accent-primary: #06b6d4;--accent-primary-hover: #22d3ee;--accent-primary-soft: rgba(6, 182, 212, .14);--accent-primary-glow: rgba(6, 182, 212, .28)}html.theme-slate{--accent-primary: #94a3b8;--accent-primary-hover: #cbd5e1;--accent-primary-soft: rgba(148, 163, 184, .14);--accent-primary-glow: rgba(148, 163, 184, .28)}html.theme-pese{--accent-primary: #8081ff;--accent-primary-hover: #9596ff;--accent-primary-soft: rgba(128, 129, 255, .14);--accent-primary-glow: rgba(128, 129, 255, .32);--text-primary: #f2f2f7;--text-secondary: #c8c8d2;--text-tertiary: #8e8e9c;--text-quaternary: #5c5c68}html.light.theme-blue{--accent-primary: #2563eb;--accent-primary-hover: #1d4ed8;--accent-primary-soft: rgba(37, 99, 235, .1);--accent-primary-glow: rgba(37, 99, 235, .18)}html.light.theme-violet{--accent-primary: #5e6ad2;--accent-primary-hover: #4f5abf;--accent-primary-soft: rgba(94, 106, 210, .1);--accent-primary-glow: rgba(94, 106, 210, .18)}html.light.theme-green{--accent-primary: #16a34a;--accent-primary-hover: #15803d;--accent-primary-soft: rgba(22, 163, 74, .1);--accent-primary-glow: rgba(22, 163, 74, .18)}html.light.theme-pink{--accent-primary: #db2777;--accent-primary-hover: #be185d;--accent-primary-soft: rgba(219, 39, 119, .1);--accent-primary-glow: rgba(219, 39, 119, .18)}html.light.theme-amber{--accent-primary: #d97706;--accent-primary-hover: #b45309;--accent-primary-soft: rgba(217, 119, 6, .1);--accent-primary-glow: rgba(217, 119, 6, .18)}html.light.theme-orange{--accent-primary: #ea580c;--accent-primary-hover: #c2410c;--accent-primary-soft: rgba(234, 88, 12, .1);--accent-primary-glow: rgba(234, 88, 12, .18)}html.light.theme-teal{--accent-primary: #0891b2;--accent-primary-hover: #0e7490;--accent-primary-soft: rgba(8, 145, 178, .1);--accent-primary-glow: rgba(8, 145, 178, .18)}html.light.theme-slate{--accent-primary: #475569;--accent-primary-hover: #334155;--accent-primary-soft: rgba(71, 85, 105, .1);--accent-primary-glow: rgba(71, 85, 105, .18)}html.light.theme-pese{--accent-primary: #1e1f8e;--accent-primary-hover: #16177a;--accent-primary-soft: rgba(30, 31, 142, .08);--accent-primary-glow: rgba(30, 31, 142, .18);--text-primary: #111122;--text-secondary: #2f2f3d;--text-tertiary: #555566;--text-quaternary: #767685}html.font-inter{--font-base: "Inter", "Inter Variable", -apple-system, "SF Pro Display", system-ui, "Segoe UI", Roboto, "Helvetica Neue", sans-serif}html.font-be-vietnam{--font-base: "Be Vietnam Pro", "Inter", -apple-system, system-ui, "Segoe UI", Roboto, sans-serif}html.font-lexend{--font-base: "Lexend", "Inter", -apple-system, system-ui, "Segoe UI", Roboto, sans-serif}html.font-nunito{--font-base: "Nunito", "Inter", -apple-system, system-ui, "Segoe UI", Roboto, sans-serif}html.text-sm{--font-size-base: 14px}html.text-md{--font-size-base: 16px}html.text-lg{--font-size-base: 18px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}html{font-size:var(--font-size-base, 16px)}body{font-family:var(--font-base, "Inter", system-ui, sans-serif);font-feature-settings:"cv01","ss03";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-marketing);color:var(--text-primary);overflow:hidden}#root{height:100%}button{font-family:inherit}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:radial-gradient(ellipse at 50% 30%,#1f2030,#14151b 70%)}html.light .login-screen{background:radial-gradient(ellipse at 50% 30%,#fff,#f0f1f3 70%)}.login-center{display:flex;flex-direction:column;align-items:center;gap:28px;width:100%;max-width:440px;padding:0 16px}.login-brand{display:flex;flex-direction:column;align-items:center;gap:12px}.logo-mark{width:56px;height:56px;background:var(--accent-indigo);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.9rem;font-weight:590;color:#fff;box-shadow:var(--shadow-ring),0 8px 24px #5e6ad240}html.light .logo-mark{color:#fff;box-shadow:var(--shadow-ring),0 4px 12px #5e6ad233}.login-brand h1{font-size:1.75rem;font-weight:510;letter-spacing:-.56px;color:var(--text-primary)}.login-brand p{font-size:.9375rem;font-weight:400;letter-spacing:-.165px;color:var(--text-tertiary);text-align:center}.login-card{background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-panel);padding:32px 28px;width:100%;box-shadow:var(--shadow-dialog),0 24px 48px #0006}html.light .login-card{background:#fff;box-shadow:var(--shadow-dialog),0 16px 40px #00000014}.login-card h2{font-size:1.125rem;font-weight:590;letter-spacing:-.18px;margin-bottom:22px;color:var(--text-primary)}.field-group{display:flex;flex-direction:column;gap:14px;margin-bottom:20px}.field-label{font-size:.8125rem;font-weight:510;color:var(--text-secondary);margin-bottom:6px;display:block}.input-wrap{position:relative}.input-wrap input{width:100%;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-input);padding:10px 12px;color:var(--text-primary);font-family:inherit;font-feature-settings:"cv01","ss03";font-size:.9375rem;outline:none;transition:border-color .15s,background .15s}.input-wrap input:focus{border-color:var(--accent-violet);background:var(--bg-white-04)}.input-wrap input::placeholder{color:var(--text-quaternary)}.pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:1rem}.pw-toggle:hover{color:var(--text-secondary)}.btn-primary{width:100%;background:var(--accent-indigo);color:#fff;border:none;border-radius:var(--r-btn);padding:10px 16px;font-family:inherit;font-feature-settings:"cv01","ss03";font-size:.9375rem;font-weight:510;cursor:pointer;transition:background .15s}.btn-primary:hover{background:var(--accent-violet-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}html.light .btn-primary{color:#fff}.login-error{display:none;background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:10px 14px;font-size:.85rem;color:var(--red);margin-top:14px}.login-error.visible{display:block}.login-footer{font-size:.78rem;color:var(--t3);text-align:center}.app-shell{position:relative;height:100vh;--sidebar-collapsed: 60px;--sidebar-expanded: 240px}.sidebar{width:var(--sidebar-w);background:var(--navy-2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;overflow-x:hidden;z-index:200}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:16px;border-bottom:1px solid var(--border-subtle)}.sidebar-logo .logo-mark-sm{width:28px;height:28px;background:var(--accent-indigo);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:590;color:#fff;flex-shrink:0}html.light .sidebar-logo .logo-mark-sm{color:#fff}.sidebar-logo span{font-size:.95rem;font-weight:510;letter-spacing:-.18px;color:var(--text-primary)}.plant-selector{margin:12px 12px 4px;position:relative}.plant-selector select{width:100%;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-btn);padding:7px 28px 7px 12px;color:var(--text-secondary);font-family:inherit;font-feature-settings:"cv01","ss03";font-size:.8125rem;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8f98' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color .15s,background .15s}.plant-selector select:hover{background-color:var(--bg-white-04)}.plant-selector select:focus{border-color:var(--accent-violet)}.sidebar-nav{flex:1;overflow-y:auto;padding:6px 8px}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border-standard);border-radius:2px}.nav-section-label{font-size:.6875rem;font-weight:590;color:var(--text-quaternary);text-transform:uppercase;letter-spacing:.08em;padding:14px 10px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:6px 10px;color:var(--text-secondary);text-decoration:none;font-size:.8125rem;font-weight:510;cursor:pointer;transition:background .1s,color .1s;border-radius:var(--r-btn);-webkit-user-select:none;user-select:none}.nav-item:hover{background:var(--bg-white-04);color:var(--text-primary)}.nav-item.active{background:var(--bg-white-05);color:var(--text-primary);box-shadow:inset 2px 0 0 var(--accent-violet)}html.light .nav-item.active{box-shadow:inset 2px 0 0 var(--accent-indigo)}.nav-item .nav-icon{width:18px;text-align:center;font-size:.95rem;color:var(--text-tertiary)}.nav-item.active .nav-icon,.nav-item:hover .nav-icon{color:var(--text-primary)}.sidebar-footer{border-top:1px solid var(--border-subtle);padding:12px;position:relative}.user-row{display:flex;align-items:center;gap:10px}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-indigo);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:590;color:#fff;flex-shrink:0}html.light .user-avatar{color:#fff}.user-info{flex:1;min-width:0}.user-name{font-size:.8125rem;font-weight:510;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.6875rem;color:var(--text-quaternary)}.user-menu-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:1.05rem;padding:4px;border-radius:var(--r-btn);transition:color .15s,background .15s}.user-menu-btn:hover{color:var(--text-primary);background:var(--bg-white-05)}.user-dropdown{display:none;position:absolute;bottom:60px;left:12px;right:12px;background:var(--bg-surface);border:1px solid var(--border-standard);border-radius:var(--r-panel);overflow:hidden;z-index:100;box-shadow:var(--shadow-dialog),0 12px 32px #00000080}.user-dropdown.open{display:block}.user-dropdown button{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;padding:10px 14px;color:var(--text-secondary);font-family:inherit;font-feature-settings:"cv01","ss03";font-size:.8125rem;font-weight:510;cursor:pointer;transition:background .1s,color .1s;text-align:left}.user-dropdown button:hover{background:var(--bg-white-05);color:var(--text-primary)}.user-dropdown button.danger{color:var(--danger)}.user-dropdown button.danger:hover{background:#ef44441a}.main-area{margin-left:var(--sidebar-collapsed);height:100vh;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-marketing);transition:margin-left .2s ease}.app-shell:has(.app-sidebar.pinned) .main-area{margin-left:var(--sidebar-expanded)}.topbar{height:var(--topbar-h);background:var(--bg-panel);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;padding:0 20px;gap:14px;flex-shrink:0}.topbar-title{font-size:.9375rem;font-weight:510;letter-spacing:-.15px;color:var(--text-primary);flex:1}.topbar-search{display:flex;align-items:center;gap:8px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-btn);padding:6px 10px;width:260px;transition:border-color .15s,background .15s}.topbar-search:focus-within{border-color:var(--accent-violet);background:var(--bg-white-04)}.topbar-search span{color:var(--text-tertiary);font-size:.85rem}.topbar-search input{background:none;border:none;outline:none;color:var(--text-primary);font-family:inherit;font-feature-settings:"cv01","ss03";font-size:.8125rem;width:100%}.topbar-search input::placeholder{color:var(--text-quaternary)}.topbar-date{font-size:.8125rem;color:var(--text-tertiary);white-space:nowrap}.topbar-icon-btn{width:32px;height:32px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-btn);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.95rem;color:var(--text-tertiary);transition:background .15s,color .15s,border-color .15s;position:relative}.topbar-icon-btn:hover{background:var(--bg-white-05);color:var(--text-primary)}.content-area{flex:1;overflow-y:auto;padding:28px}.content-area::-webkit-scrollbar{width:6px}.content-area::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.card{background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-card);padding:20px}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.kpi-card{background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-card);padding:18px 20px;transition:background .15s}.kpi-card:hover{background:var(--bg-white-04)}.kpi-label{font-size:.75rem;color:var(--text-quaternary);font-weight:510;text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.kpi-value{font-size:1.75rem;font-weight:510;letter-spacing:-.616px;color:var(--text-primary);line-height:1}.kpi-sub{font-size:.75rem;font-weight:400;color:var(--text-tertiary);margin-top:6px}.kpi-accent-orange{color:var(--accent-violet)}.kpi-accent-cyan{color:var(--cyan)}.kpi-accent-emerald{color:var(--success)}.kpi-accent-indigo{color:var(--accent-indigo)}.section-title{font-size:.9375rem;font-weight:590;letter-spacing:-.15px;color:var(--text-primary);margin-bottom:14px}.section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.pill{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--r-pill);font-size:.75rem;font-weight:510;border:1px solid transparent}.pill-green{background:#10b9811f;color:var(--success);border-color:#10b98133}.pill-cyan{background:#00c8ee1a;color:var(--cyan);border-color:#00c8ee33}.pill-amber{background:#f59e0b1f;color:var(--warn);border-color:#f59e0b33}.pill-red{background:#ef44441f;color:var(--danger);border-color:#ef444433}.pill-gray{background:transparent;color:var(--text-secondary);border-color:var(--border-solid)}.pill-orange{background:var(--accent-violet-soft);color:var(--accent-violet);border-color:#7170ff33}.pill-indigo{background:#5e6ad21f;color:var(--accent-indigo);border-color:#5e6ad233}.btn-sm{padding:5px 12px;border-radius:var(--r-btn);font-family:inherit;font-feature-settings:"cv01","ss03";font-size:.8125rem;font-weight:510;cursor:pointer;border:1px solid transparent;transition:background .15s,color .15s,border-color .15s}.btn-orange{background:var(--accent-indigo);color:#fff;border-color:var(--accent-indigo)}.btn-orange:hover{background:var(--accent-violet-hover);border-color:var(--accent-violet-hover)}html.light .btn-orange{color:#fff}.btn-outline{background:var(--bg-white-02);color:var(--text-secondary);border-color:var(--border-standard)}.btn-outline:hover{background:var(--bg-white-05);border-color:var(--border-solid);color:var(--text-primary)}.empty-state{text-align:center;padding:48px 24px;color:var(--text-quaternary)}.empty-state .empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:.6}.empty-state p{font-size:.9rem;font-weight:400}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.alert-banner{background:var(--accent-violet-soft);border:1px solid rgba(113,112,255,.25);border-radius:var(--r-card);padding:12px 16px;margin-bottom:20px;display:flex;align-items:center;gap:12px;font-size:.875rem;font-weight:510;color:var(--accent-violet)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--t3);font-size:.875rem}.chart-card{background:var(--navy-2);border:1px solid var(--border);border-radius:var(--r-card);padding:20px;margin-bottom:20px}.chart-svg{width:100%;height:180px}.plant-network{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.plant-row-card{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--r-panel);padding:16px 18px;display:flex;align-items:center;justify-content:space-between}.activity-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.activity-row:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.contract-expiry-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border)}.contract-expiry-row:last-child{border-bottom:none}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{padding:12px 16px;border-radius:var(--r-card);font-size:.8125rem;font-weight:510;color:#fff;min-width:260px;max-width:360px;box-shadow:var(--shadow-dialog),0 12px 32px #00000080;animation:slideIn .3s ease;pointer-events:auto}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-warning{background:var(--warn);color:#0a0a0a}html.light .toast{box-shadow:var(--shadow-dialog)}html.light .toast-warning{color:#fff}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.toast.hiding{animation:slideOut .3s ease forwards}.filter-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.filter-pill{padding:4px 12px;border-radius:var(--r-pill);font-size:.75rem;font-weight:510;cursor:pointer;border:1px solid var(--border-solid);background:transparent;color:var(--text-secondary);font-family:inherit;font-feature-settings:"cv01","ss03";transition:background .15s,color .15s,border-color .15s}.filter-pill:hover{background:var(--bg-white-04);color:var(--text-primary)}.filter-pill.active{background:var(--accent-violet-soft);border-color:var(--accent-violet);color:var(--accent-violet)}.table-wrap{overflow-x:auto;border-radius:var(--r-card);border:1px solid var(--border-standard);background:var(--bg-white-02)}table{width:100%;border-collapse:collapse;font-size:.8125rem}table th{background:transparent;color:var(--text-quaternary);font-size:.6875rem;font-weight:590;text-transform:uppercase;letter-spacing:.06em;padding:10px 16px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--border-subtle)}table td{padding:11px 16px;color:var(--text-secondary);border-top:1px solid var(--border-subtle);vertical-align:middle}table tbody tr:first-child td{border-top:none}table tr:hover td{background:var(--bg-white-02)}.plant-big-card{background:var(--navy-2);border:1px solid var(--border);border-radius:var(--r-card);padding:24px;display:flex;flex-direction:column}.plant-big-card h3{font-size:1.15rem;font-weight:590;margin-bottom:4px}.plant-metric{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border);font-size:.875rem}.plant-metric:last-child{border-bottom:none}.plant-metric-label{color:var(--t2)}.plant-metric-val{font-weight:590;color:var(--t1)}.plants-grid-compact{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}@media(max-width:1180px){.plants-grid-compact{grid-template-columns:repeat(3,1fr)}}@media(max-width:860px){.plants-grid-compact{grid-template-columns:repeat(2,1fr)}}@media(max-width:540px){.plants-grid-compact{grid-template-columns:1fr}}.plant-compact-card{background:var(--navy-2);border:1px solid var(--border);border-radius:var(--r-card);padding:10px 12px;display:flex;flex-direction:column;gap:4px;transition:border-color .12s ease}.plant-compact-card:hover{border-color:var(--accent-primary)}.plant-compact-head{display:flex;justify-content:space-between;align-items:center;gap:6px;min-height:22px}.plant-compact-name{font-size:.95rem;font-weight:600;color:var(--t1);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.25}.plant-compact-code{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:.72rem;color:var(--t3);letter-spacing:.4px}.plant-compact-meta{display:flex;gap:10px;flex-wrap:wrap;font-size:.78rem;color:var(--t2)}.plant-compact-meta-empty{font-size:.72rem;color:var(--t3);font-style:italic}.plant-compact-addr{font-size:.72rem;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plant-compact-counts{display:flex;gap:6px;font-size:.7rem;color:var(--t3);margin-top:4px;padding-top:6px;border-top:1px dashed var(--border)}.plant-compact-actions{display:flex;gap:4px;flex-shrink:0}.plant-icon-btn{background:transparent;border:1px solid var(--border);border-radius:6px;padding:2px 6px;font-size:.72rem;cursor:pointer;color:var(--t2);font-family:inherit;line-height:1}.plant-icon-btn:hover{color:var(--t1);border-color:var(--accent-primary)}.plant-icon-btn.danger:hover{color:var(--danger);border-color:var(--danger)}.table-container{background:var(--navy-2);border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;box-shadow:0 12px 32px #0006;margin-top:16px}.grid-6{display:grid;grid-template-columns:46px minmax(200px,2.5fr) minmax(130px,1.2fr) minmax(200px,1.6fr) 100px minmax(160px,200px);gap:16px;align-items:center}.grid-7{display:grid;grid-template-columns:46px minmax(180px,2.5fr) minmax(110px,1.2fr) minmax(130px,1.2fr) minmax(140px,1.4fr) 80px auto;gap:16px;align-items:center}.grid-header{background:#0003;padding:14px 20px;font-size:.72rem;font-weight:590;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border)}.grid-row{padding:14px 20px;border-bottom:1px solid var(--border);transition:background .15s ease}.grid-row:last-child{border-bottom:none}.grid-row:hover{background:#ffffff08}.grid-row .stt{font-size:.85rem;color:var(--t3);font-weight:590}.grid-row .title-col{display:flex;flex-direction:column;gap:6px;overflow:hidden}.grid-row .title{font-size:.95rem;font-weight:590;color:var(--t1);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.grid-row .title-tags{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.grid-row .code{font-family:monospace;font-size:.82rem;color:var(--cyan);background:#00c8ee1a;padding:3px 8px;border-radius:6px;border:1px solid rgba(0,200,238,.2);font-weight:510}.grid-row .badge-group{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.grid-row .badge{font-size:.72rem;border-radius:6px;padding:3px 10px;border:1px solid transparent;font-weight:510;white-space:nowrap}.grid-row .date{font-size:.78rem;color:var(--t2);white-space:nowrap}.grid-row .actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}.status-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:6px;font-size:.72rem;font-weight:510}.badge-green{background:#10b98126;color:var(--success)}.badge-blue{background:#00c8ee26;color:var(--cyan)}.badge-orange{background:#7170ff26;color:var(--accent-violet)}.badge-red{background:#ef444426;color:var(--danger)}.badge-gray{background:#ffffff12;color:var(--t2)}.severity-badge{display:inline-flex;padding:2px 8px;border-radius:4px;font-size:.72rem;font-weight:600}.severity-critical{background:#dc262626;color:#dc2626}.severity-high{background:#ea580c26;color:#ea580c}.severity-medium{background:#eab30826;color:#eab308}.severity-low{background:#22c55e26;color:#22c55e}.status-overview-row{display:flex;align-items:center;gap:8px;font-size:.8rem}.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.two-col{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}@media(max-width:1024px){.two-col{grid-template-columns:1fr}}.bank-tab-group{display:flex;gap:2px;background:var(--navy-3);border-radius:10px;padding:3px}.bank-tab{padding:5px 14px;border-radius:8px;font-size:.82rem;font-weight:590;border:none;cursor:pointer;transition:background .15s,color .15s;background:transparent;color:var(--t2);font-family:inherit}.bank-tab.active{background:var(--orange);color:#fff}.exam-config-card{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--r-panel);padding:16px;margin-bottom:10px}.exam-config-card:last-child{margin-bottom:0}.exam-config-card h4{font-size:.9rem;font-weight:590;margin-bottom:8px;color:var(--t1)}.pill-emerald{background:#10b9811f;color:var(--success);border-color:#10b98133}.topic-bar{margin-bottom:10px}.topic-bar-label{display:flex;justify-content:space-between;font-size:.8rem;color:var(--t2);margin-bottom:4px}.topic-bar-track{height:6px;background:var(--navy-3);border-radius:3px;overflow:hidden}.topic-bar-fill{height:100%;border-radius:3px;background:var(--orange)}.forecast-chart-wrap{background:var(--navy-2);border:1px solid var(--border);border-radius:var(--r-card);padding:20px 20px 12px;margin-bottom:20px}.forecast-chart-svg{width:100%;height:auto}.tab-bar{display:flex;border-bottom:1px solid var(--border);gap:0}.tab-item{padding:10px 22px;font-size:.875rem;font-weight:510;color:var(--t2);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;-webkit-user-select:none;user-select:none}.tab-item:hover{color:var(--t1)}.tab-item.active{color:var(--orange);border-bottom-color:var(--orange)}.forecast-stat-row{display:flex;gap:20px;flex-wrap:wrap;padding:12px 0 4px;border-top:1px solid var(--border);margin-top:8px}.forecast-stat{display:flex;flex-direction:column;gap:2px}.forecast-stat-label{font-size:.72rem;color:var(--t3)}.forecast-stat-val{font-size:1rem;font-weight:590;color:var(--t1)}.forecast-date-strip{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;margin-bottom:16px}.forecast-date-btn{flex-shrink:0;padding:6px 14px;border-radius:8px;border:1px solid var(--border);background:var(--navy-3);color:var(--t2);font-size:.78rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.forecast-date-btn:hover{border-color:var(--orange);color:var(--t1)}.forecast-date-btn.active{background:var(--orange);border-color:var(--orange);color:#fff}.forecast-table{width:100%;border-collapse:collapse;margin-top:16px;font-size:.85rem}.forecast-table th{padding:8px 12px;text-align:left;color:var(--t3);font-weight:510;border-bottom:1px solid var(--border)}.forecast-table td{padding:9px 12px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--t2)}.forecast-table tr:last-child td{border-bottom:none}.forecast-table td:last-child{color:var(--t1);font-weight:510;text-align:right}.forecast-table th:last-child{text-align:right}.forecast-band-legend,.forecast-legend{display:flex;gap:18px;flex-wrap:wrap;padding:8px 0 4px;font-size:.74rem;color:var(--t3);justify-content:center}.forecast-legend-item{display:inline-flex;align-items:center;gap:6px}.forecast-legend-line{display:inline-block;width:18px;height:2.5px;border-radius:2px}.forecast-legend-band{display:inline-block;width:18px;height:10px;border-radius:2px;opacity:.35}.forecast-legend-swatch{display:inline-block;width:12px;height:12px;border-radius:3px}.forecast-nday-slider{display:inline-flex;gap:4px;padding:3px;background:var(--navy-3);border:1px solid var(--border);border-radius:8px}.forecast-nday-btn{background:transparent;border:none;color:var(--t2);font-size:.76rem;font-weight:510;padding:4px 10px;border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.forecast-nday-btn:hover{color:var(--t1)}.forecast-nday-btn.active{background:var(--orange);color:#fff}.forecast-year-picker{display:inline-flex;align-items:center;gap:8px}.forecast-year-label{font-size:1rem;font-weight:700;color:var(--t1);min-width:56px;text-align:center}.forecast-band-wrap{position:relative}.forecast-tooltip{position:absolute;top:8px;background:var(--navy-1);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:.78rem;pointer-events:none;min-width:160px;box-shadow:0 4px 12px #0006;z-index:10}.forecast-tooltip-title{font-weight:600;color:var(--t1);font-size:.84rem;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--border)}.forecast-tooltip-row{display:flex;justify-content:space-between;align-items:center;gap:12px;color:var(--t2);margin:2px 0}.forecast-tooltip-row span:last-child{font-variant-numeric:tabular-nums;color:var(--t1)}.three-col-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media(max-width:768px){.three-col-grid{grid-template-columns:1fr 1fr;gap:10px}}@media(max-width:480px){.three-col-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}html.light .modal-overlay{background:#00000073}.modal-box{background:var(--bg-surface);border:1px solid var(--border-standard);border-radius:var(--r-panel);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-dialog),0 24px 48px #00000080}html.light .modal-box{background:#fff}.modal-box.wide{max-width:760px}.modal-box.xwide{max-width:960px}.modal-box::-webkit-scrollbar{width:4px}.modal-box::-webkit-scrollbar-thumb{background:var(--border-standard);border-radius:2px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border-subtle)}.modal-header h3{font-size:1rem;font-weight:590;letter-spacing:-.16px;color:var(--text-primary);margin:0}.modal-close{background:none;border:none;color:var(--text-quaternary);font-size:1.2rem;cursor:pointer;padding:4px 8px;line-height:1;border-radius:var(--r-btn);transition:color .15s,background .15s}.modal-close:hover{color:var(--text-primary);background:var(--bg-white-05)}.modal-body{padding:22px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 22px;border-top:1px solid var(--border-subtle)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.8125rem;font-weight:510;color:var(--text-secondary);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-input);padding:9px 12px;color:var(--text-primary);font-family:inherit;font-feature-settings:"cv01","ss03";font-size:.875rem;outline:none;transition:border-color .15s,background .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent-violet);background:var(--bg-white-04)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-quaternary)}.form-group select option{background:var(--bg-surface);color:var(--text-primary)}html.light .form-group select option{background:#fff}select option{background:var(--bg-surface);color:var(--text-primary)}html.light select option{background:#fff;color:var(--text-primary)}.form-group .field-error{display:block;margin-top:4px;font-size:.75rem;color:var(--danger)}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-error{background:#ef44441f;border:1px solid rgba(239,68,68,.28);border-radius:var(--r-btn);padding:9px 12px;font-size:.8125rem;color:var(--danger);margin-top:12px}.btn-red{background:#ef444424;color:var(--danger);border-color:#ef44444d}.btn-red:hover{background:#ef444433}.btn-solid-red{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-solid-red:hover{background:#c02626;border-color:#c02626}.btn-green{background:#22c55e24;color:#22c55e;border-color:#22c55e4d}.btn-green:hover{background:#22c55e38}.transfer-list{display:flex;flex-direction:column;gap:10px;margin-top:14px}.transfer-card{background:var(--navy-2);border:1px solid var(--border);border-radius:12px;padding:14px 16px}.transfer-card-head{display:flex;flex-direction:column;gap:4px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}.transfer-card-title{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.transfer-card-name{font-weight:600;color:var(--t1);font-size:.95rem}.transfer-card-meta{display:flex;gap:6px;font-size:.78rem;color:var(--t3);flex-wrap:wrap}.transfer-card-body{display:flex;flex-direction:column;gap:6px}.transfer-card-field{display:flex;gap:10px;align-items:baseline;font-size:.85rem}.transfer-card-field-label{flex-shrink:0;width:110px;color:var(--t3);font-size:.78rem}.transfer-card-field-value{flex:1;color:var(--t1);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.transfer-card-field-value .t-from{color:var(--t3)}.transfer-card-field-value .t-arrow{color:var(--orange);font-weight:600}.transfer-card-field-value .t-to{color:var(--t1);font-weight:510}.transfer-card-actions{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:flex;gap:8px;flex-wrap:wrap}.transfer-current{background:#f265220f;border:1px solid rgba(242,101,34,.18);border-radius:8px;padding:8px 10px;margin-top:6px;font-size:.82rem;color:var(--t1)}.transfer-current-label{color:var(--orange);font-weight:600;margin-right:4px}.authority-grant{background:var(--navy-2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.authority-list{display:flex;flex-direction:column;gap:6px}.authority-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--navy-2);border:1px solid var(--border);border-radius:8px}.authority-row-info{flex:1;min-width:0}.authority-row-name{font-size:.88rem;font-weight:510;color:var(--t1)}.authority-row-meta{font-size:.74rem;color:var(--t3);margin-top:2px}.authority-row-scope{flex-shrink:0;padding:4px 10px;background:#f265221a;border:1px solid rgba(242,101,34,.3);color:var(--orange);border-radius:999px;font-size:.78rem;font-weight:510;white-space:nowrap}.personnel-history{display:flex;flex-direction:column;gap:10px;position:relative}.personnel-history-empty{font-size:.82rem;color:var(--t3);font-style:italic;padding:10px 0}.personnel-history-item{display:flex;gap:12px;align-items:flex-start;position:relative}.personnel-history-item:not(:last-child):before{content:"";position:absolute;left:5px;top:18px;bottom:-10px;width:1px;background:var(--border)}.personnel-history-dot{flex-shrink:0;width:11px;height:11px;border-radius:50%;margin-top:6px;background:var(--navy-3);border:2px solid var(--orange);z-index:1}.personnel-history-dot-transfer{border-color:var(--orange)}.personnel-history-dot-position{border-color:#14b8a6}.personnel-history-content{flex:1;background:var(--navy-2);border:1px solid var(--border);border-radius:8px;padding:8px 12px}.personnel-history-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.personnel-history-kind{font-weight:600;font-size:.82rem;color:var(--t1)}.personnel-history-date{margin-left:auto;font-size:.74rem;color:var(--t3)}.personnel-history-body{display:flex;flex-direction:column;gap:3px}.personnel-history-row{font-size:.82rem}.personnel-history-row-label{color:var(--t3);font-size:.78rem}.personnel-history-row-from{color:var(--t3)}.personnel-history-row-arrow{color:var(--orange);margin:0 6px}.personnel-history-row-to{color:var(--t1);font-weight:510}.personnel-history-reason{font-size:.82rem;color:var(--t2);margin-top:2px}.personnel-history-meta{font-size:.74rem;color:var(--t3);margin-top:2px}.hr-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.hr-kpi{background:var(--navy-2);border:1px solid var(--border);border-radius:var(--r-panel);padding:16px 20px}.hr-kpi-value{font-size:1.85rem;font-weight:590;line-height:1;margin-bottom:5px}.hr-kpi-label{font-size:.72rem;font-weight:590;color:var(--t3);text-transform:uppercase;letter-spacing:.06em}.hr-unit-row{display:grid;grid-template-columns:repeat(9,1fr);gap:10px;margin:-8px 0 16px}.hr-unit-card{background:var(--navy-2);border:1px solid var(--border);border-radius:10px;padding:10px 12px;cursor:pointer;transition:all .15s;text-align:center;font-family:inherit}.hr-unit-card:hover:not(:disabled){border-color:#f2652266;transform:translateY(-1px)}.hr-unit-card:disabled{opacity:.4;cursor:not-allowed}.hr-unit-card.active{background:#f265221f;border-color:var(--orange)}.hr-unit-card .u-code{font-size:.78rem;font-weight:700;color:var(--t2);letter-spacing:.05em}.hr-unit-card.active .u-code{color:var(--orange)}.hr-unit-card .u-count{font-size:1.4rem;font-weight:700;color:var(--t1);line-height:1.1;margin-top:2px}@media(max-width:1200px){.hr-unit-row{grid-template-columns:repeat(5,1fr)}}@media(max-width:768px){.hr-unit-row{grid-template-columns:repeat(3,1fr)}}.hr-plant-row{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:10px 12px;margin:-8px 0 16px;background:#f265220d;border:1px dashed rgba(242,101,34,.3);border-radius:10px;max-height:140px;overflow-y:auto}.hr-plant-label{font-size:.78rem;font-weight:600;color:var(--orange);margin-right:4px;white-space:nowrap}.hr-plant-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:.78rem;background:var(--navy-2);border:1px solid var(--border);border-radius:999px;color:var(--t2);cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}.hr-plant-chip:hover{border-color:#f2652280;color:var(--t1)}.hr-plant-chip.active{background:#f2652226;border-color:var(--orange);color:var(--orange);font-weight:600}.hr-plant-chip .hr-plant-count{background:#ffffff0f;padding:0 6px;border-radius:999px;font-size:.72rem;font-weight:600}.hr-plant-chip.active .hr-plant-count{background:var(--orange);color:#fff}.hr-plant-clear{margin-left:auto;padding:4px 10px;font-size:.74rem;background:transparent;border:1px solid var(--border);border-radius:999px;color:var(--t3);cursor:pointer;font-family:inherit;white-space:nowrap}.hr-plant-clear:hover{color:var(--t1);border-color:var(--t3)}.hr-pagination-bar{display:flex;justify-content:space-between;align-items:center;margin-top:14px;flex-wrap:wrap;gap:10px}.pg-btn{min-width:32px;padding:5px 10px;font-size:.78rem;border-radius:7px;background:var(--navy-2);border:1px solid var(--border);color:var(--t2);cursor:pointer;transition:all .15s;font-family:inherit}.pg-btn:hover:not(:disabled){color:var(--t1);border-color:#f2652266}.pg-btn.active{background:var(--orange);color:#fff;border-color:var(--orange);font-weight:600}.pg-btn:disabled{opacity:.4;cursor:not-allowed}.pg-ellipsis{padding:5px 6px;color:var(--t3);font-size:.8rem}.hr-filter-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.hr-search{display:flex;align-items:center;gap:8px;background:var(--navy-2);border:1px solid var(--border);border-radius:var(--r-btn);padding:8px 13px;flex:1;min-width:200px;transition:border-color .2s}.hr-search:focus-within{border-color:#7170ff80}.hr-search span{color:var(--t3);font-size:.88rem;flex-shrink:0}.hr-search input{background:none;border:none;outline:none;color:var(--t1);font-family:inherit;font-size:.875rem;width:100%}.hr-search input::placeholder{color:var(--t3)}.hr-count{font-size:.8rem;color:var(--t3);white-space:nowrap}.pill-admin{background:#7170ff26;color:var(--orange)}.pill-manager{background:#00c8ee1f;color:var(--cyan)}.pill-user{background:#ffffff12;color:var(--t2)}.user-avatar-sm{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:590;flex-shrink:0}.avatar-admin{background:var(--orange);color:var(--navy)}.avatar-manager{background:var(--cyan);color:var(--navy)}.avatar-user{background:#ffffff1f;color:var(--t2)}html.light .avatar-admin,html.light .avatar-manager{color:#fff}.user-cell{display:flex;align-items:center;gap:10px}.user-cell-info{min-width:0}.user-cell-name{font-size:.875rem;font-weight:590;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.user-cell-email{font-size:.75rem;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.dept-path{font-size:.82rem;color:var(--t2);line-height:1.35}.dept-path .dept-sep{color:var(--t3);margin:0 4px;opacity:.6}.dept-path .dept-leaf{color:var(--t1);font-weight:510}.dept-tree-node{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid var(--border);border-radius:8px;margin-bottom:6px;background:var(--navy-2);gap:10px}.dept-tree-node:hover{border-color:#7170ff59}.dept-tree-node .dept-tree-name{color:var(--t1);font-size:.88rem;font-weight:510;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dept-tree-node .dept-tree-actions{display:flex;gap:4px;flex-shrink:0}.dept-tree-actions button{padding:3px 8px;font-size:.72rem;border-radius:6px;background:var(--navy-3);border:1px solid var(--border);color:var(--t2);cursor:pointer;transition:all .15s}.dept-tree-actions button:hover{color:var(--t1);border-color:#7170ff66}.dept-tree-actions button.danger:hover{color:var(--red);border-color:#ef444480}@media(max-width:768px){.hr-kpi-row{grid-template-columns:1fr 1fr}}@media(max-width:480px){.hr-kpi-row{grid-template-columns:1fr 1fr;gap:10px}}@media(max-width:768px){body{overflow:auto}.kpi-row{grid-template-columns:1fr 1fr;gap:10px}.grid-3{grid-template-columns:1fr 1fr;gap:12px}}@media(max-width:480px){.kpi-row{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr;gap:10px}}.settings-page{display:flex;flex-direction:column;gap:16px;max-width:1100px;margin:0 auto}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:4px 0 12px}.settings-title{display:flex;align-items:center;gap:10px;font-size:1.05rem;font-weight:600;color:var(--text-primary)}.settings-title-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--r-card);background:var(--accent-primary-soft, var(--accent-violet-soft));color:var(--accent-primary, var(--accent-violet));font-size:1rem}.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:.85rem;border:1px solid var(--border-standard);border-radius:var(--r-btn);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .12s}.btn-ghost:hover{background:var(--bg-white-04);color:var(--text-primary)}.settings-card{background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-panel);padding:20px 22px;box-shadow:var(--shadow-elevated)}.settings-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:900px){.settings-grid-2{grid-template-columns:1fr}}.settings-section-title{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:14px}.settings-beta-pill{margin-left:auto;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:var(--r-pill);background:var(--accent-primary-soft, var(--accent-violet-soft));color:var(--accent-primary, var(--accent-violet))}.seg-group{display:inline-flex;gap:6px;flex-wrap:wrap}.seg-btn{padding:8px 16px;font-size:.85rem;font-weight:500;border:1px solid var(--border-standard);border-radius:var(--r-btn);background:var(--bg-white-02);color:var(--text-secondary);cursor:pointer;transition:all .12s}.seg-btn:hover{background:var(--bg-white-04);color:var(--text-primary)}.seg-btn.active{background:var(--accent-primary-soft, var(--accent-violet-soft));border-color:var(--accent-primary, var(--accent-violet));color:var(--accent-primary, var(--accent-violet))}.color-chip-group{display:flex;flex-wrap:wrap;gap:8px}.color-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 14px 6px 10px;font-size:.85rem;font-weight:500;border:1px solid var(--border-standard);border-radius:var(--r-pill);background:var(--bg-white-02);color:var(--text-secondary);cursor:pointer;transition:all .12s}.color-chip:hover{background:var(--bg-white-04);color:var(--text-primary)}.color-chip.active{background:var(--accent-primary-soft, var(--accent-violet-soft));border-color:var(--accent-primary, var(--accent-violet));color:var(--text-primary)}.color-dot{display:inline-block;width:12px;height:12px;border-radius:var(--r-pill);box-shadow:0 0 0 2px #ffffff14}.settings-select{width:100%;padding:9px 12px;font-size:.9rem;border:1px solid var(--border-standard);border-radius:var(--r-input);background:var(--bg-white-02);color:var(--text-primary);cursor:pointer;font-family:inherit}.settings-select:focus{outline:none;border-color:var(--accent-primary, var(--accent-violet));box-shadow:0 0 0 3px var(--accent-primary-glow, var(--accent-violet-glow))}.settings-input{width:100%;margin-top:8px;padding:9px 12px;font-size:.85rem;border:1px solid var(--border-subtle);border-radius:var(--r-input);background:var(--bg-white-02);color:var(--text-tertiary);font-family:inherit}.settings-note{margin-top:8px;font-size:.78rem;color:var(--text-tertiary)}.settings-note-muted{text-align:center;font-style:italic;margin-top:14px}.settings-field{margin-top:14px}.settings-label{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--border-subtle)}.settings-toggle-row:last-child{border-bottom:none}.settings-toggle-label{font-size:.9rem;font-weight:500;color:var(--text-primary)}.settings-toggle-desc{font-size:.78rem;color:var(--text-tertiary);margin-top:2px}.toggle-switch{width:38px;height:22px;border-radius:var(--r-pill);background:var(--bg-surface-2);border:1px solid var(--border-standard);position:relative;cursor:pointer;transition:background .16s;flex-shrink:0}.toggle-switch.on{background:var(--accent-primary, var(--accent-violet));border-color:var(--accent-primary, var(--accent-violet))}.toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .16s;box-shadow:0 1px 3px #0003}.toggle-switch.on .toggle-knob{transform:translate(16px)}.app-header{height:var(--topbar-h);background:var(--bg-panel);border-bottom:1px solid var(--border-standard);display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;position:relative;z-index:50}.app-header-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.app-header-right{display:flex;align-items:center;gap:10px}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-tertiary);min-width:0}.breadcrumb-home{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--r-btn);color:var(--text-secondary);text-decoration:none;background:var(--bg-white-02);border:1px solid var(--border-subtle);transition:background .12s}.breadcrumb-home:hover{background:var(--bg-white-04);color:var(--text-primary)}.breadcrumb-home-icon{font-size:.95rem;color:var(--text-tertiary)}.breadcrumb-sep{color:var(--text-quaternary);font-size:.95rem}.breadcrumb-current{display:inline-flex;align-items:center;padding:6px 12px;border-radius:var(--r-btn);background:var(--accent-primary);color:#fff;font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px}.breadcrumb-link{display:inline-flex;align-items:center;padding:6px 12px;border-radius:var(--r-btn);color:var(--text-secondary);text-decoration:none;background:var(--bg-white-02);border:1px solid var(--border-subtle);font-size:.85rem;transition:background .12s,color .12s}.breadcrumb-link:hover{background:var(--bg-white-04);color:var(--text-primary)}.header-clock-group{display:flex;align-items:center;gap:8px}.header-clock,.header-date-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:.82rem;background:var(--bg-white-02);border:1px solid var(--border-subtle);border-radius:var(--r-btn);color:var(--text-secondary)}.header-clock-time{font-variant-numeric:tabular-nums;font-weight:600;color:var(--text-primary)}.header-clock-icon,.header-date-icon{color:var(--text-tertiary);font-size:.85rem}@media(max-width:900px){.header-date-pill{display:none}}.header-bell-wrap,.header-user-wrap{position:relative}.header-bell-btn{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-white-02);border:1px solid var(--border-subtle);border-radius:var(--r-btn);cursor:pointer;color:var(--text-secondary);transition:background .12s}.header-bell-btn:hover{background:var(--bg-white-04);color:var(--text-primary)}.header-bell-icon{font-size:1rem}.header-bell-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;background:var(--accent-primary);color:#fff;border-radius:var(--r-pill);font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-panel)}.header-user-btn{display:inline-flex;align-items:center;gap:10px;padding:4px 10px 4px 4px;background:var(--bg-white-02);border:1px solid var(--border-subtle);border-radius:var(--r-btn);cursor:pointer;color:var(--text-primary);transition:background .12s}.header-user-btn:hover{background:var(--bg-white-04)}.header-user-avatar{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-pill);background:var(--accent-primary);color:#fff;font-size:.72rem;font-weight:700;flex-shrink:0}.header-user-avatar.lg{width:40px;height:40px;font-size:.9rem}.header-user-info{display:flex;flex-direction:column;align-items:flex-start;gap:1px;line-height:1.1;min-width:0}.header-user-name{font-size:.82rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.header-user-role{font-size:.7rem;color:var(--text-tertiary);display:flex;align-items:center;gap:4px}.header-user-role:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--success);display:inline-block}.header-user-email{font-size:.75rem;color:var(--text-tertiary)}.header-user-caret{color:var(--text-tertiary);font-size:.7rem}@media(max-width:700px){.header-user-info,.header-user-caret{display:none}}.header-popup{position:absolute;top:calc(100% + 8px);right:0;min-width:260px;background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-panel);box-shadow:var(--shadow-dialog),0 12px 32px #00000052;padding:8px;z-index:200;animation:header-popup-in .14s ease-out}@keyframes header-popup-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.header-popup-title{padding:8px 12px;font-size:.78rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.header-popup-empty{padding:24px 12px;text-align:center;color:var(--text-secondary);font-size:.85rem}.header-popup-empty-icon{font-size:1.5rem;margin-bottom:8px;opacity:.6}.header-popup-empty-sub{margin-top:4px;font-size:.75rem;color:var(--text-tertiary)}.header-popup-user-row{display:flex;align-items:center;gap:12px;padding:10px 12px}.header-popup-sep{height:1px;background:var(--border-subtle);margin:4px 0}.header-popup-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;background:none;border:none;border-radius:var(--r-btn);font-family:inherit;font-size:.85rem;color:var(--text-secondary);cursor:pointer;text-align:left;transition:background .1s}.header-popup-item:hover{background:var(--bg-white-04);color:var(--text-primary)}.header-popup-item-danger{color:var(--danger)}.header-popup-item-danger:hover{background:#ef44441a;color:var(--danger)}.header-bell-popup{min-width:320px}.header-user-popup{min-width:280px}.app-sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-collapsed);background:var(--bg-panel);border-right:1px solid var(--border-standard);display:flex;flex-direction:column;z-index:100;transition:width .2s ease;overflow:hidden}.app-sidebar:hover,.app-sidebar.pinned{width:var(--sidebar-expanded);box-shadow:0 0 32px #0003}.app-sidebar.pinned{box-shadow:none}.app-sidebar-logo{display:flex;align-items:center;gap:10px;padding:14px;border-bottom:1px solid var(--border-subtle);height:var(--topbar-h);flex-shrink:0}.app-sidebar-logo .logo-mark-sm{width:32px;height:32px;background:var(--accent-primary);border-radius:var(--r-card);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#fff;flex-shrink:0}.app-sidebar-brand{font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;opacity:0;transition:opacity .16s 80ms;flex:1}.app-sidebar:hover .app-sidebar-brand,.app-sidebar.pinned .app-sidebar-brand{opacity:1}.app-sidebar-pin{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:var(--r-btn);display:none;transition:background .12s}.app-sidebar-pin:hover{background:var(--bg-white-04);color:var(--text-primary)}.app-sidebar:hover .app-sidebar-pin,.app-sidebar.pinned .app-sidebar-pin{display:inline-flex;align-items:center;justify-content:center}.app-sidebar-plant{padding:10px 12px;border-bottom:1px solid var(--border-subtle);flex-shrink:0;opacity:0;pointer-events:none;transition:opacity .16s 80ms}.app-sidebar:hover .app-sidebar-plant,.app-sidebar.pinned .app-sidebar-plant{opacity:1;pointer-events:auto}.app-sidebar-plant select{width:100%;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-btn);padding:6px 26px 6px 10px;color:var(--text-secondary);font-family:inherit;font-size:.8125rem;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8f98' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.app-sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 0}.app-sidebar-nav::-webkit-scrollbar{width:4px}.app-sidebar-nav::-webkit-scrollbar-thumb{background:var(--border-standard);border-radius:2px}.app-sidebar-section{margin-bottom:4px}.app-sidebar-section-head{display:flex;align-items:center;gap:10px;width:100%;padding:8px 14px 8px 18px;margin:0;background:none;border:none;border-radius:var(--r-btn);font-family:inherit;text-align:left;white-space:nowrap;cursor:pointer;transition:background .1s}.app-sidebar-section-head:hover{background:var(--bg-white-04)}.app-sidebar-section.active .app-sidebar-section-head .app-sidebar-section-label{color:var(--text-primary)}.app-sidebar-section-icon{flex-shrink:0}.app-sidebar-section-chevron{margin-left:auto;flex-shrink:0;color:var(--text-tertiary);opacity:0;transition:opacity .16s 80ms,transform .16s}.app-sidebar:hover .app-sidebar-section-chevron,.app-sidebar.pinned .app-sidebar-section-chevron{opacity:1}.app-sidebar-section.expanded .app-sidebar-section-chevron{transform:rotate(180deg)}.app-sidebar-section-label{font-size:.7rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;opacity:0;transition:opacity .16s 80ms}.app-sidebar:hover .app-sidebar-section-label,.app-sidebar.pinned .app-sidebar-section-label{opacity:1}.app-sidebar-section-items{padding:0 8px}.app-sidebar-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-btn);color:var(--text-secondary);font-size:.82rem;font-weight:500;text-decoration:none;cursor:pointer;white-space:nowrap;transition:background .1s,color .1s}.app-sidebar-item:hover{background:var(--bg-white-04);color:var(--text-primary)}.app-sidebar-item.active{background:var(--accent-primary-soft);color:var(--accent-primary);font-weight:600}.app-sidebar-item-disabled{color:var(--text-quaternary);cursor:default;font-style:italic}.app-sidebar-item-icon{flex-shrink:0;color:var(--text-tertiary)}.app-sidebar-item.active .app-sidebar-item-icon{color:var(--accent-primary)}.app-sidebar-item-label{flex:1;overflow:hidden;text-overflow:ellipsis;opacity:0;transition:opacity .16s 80ms}.app-sidebar:hover .app-sidebar-item-label,.app-sidebar.pinned .app-sidebar-item-label{opacity:1}.app-sidebar-item-badge{margin-left:auto;background:var(--accent-primary);color:#fff;font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:var(--r-pill);min-width:18px;text-align:center;opacity:0;transition:opacity .16s 80ms}.app-sidebar:hover .app-sidebar-item-badge,.app-sidebar.pinned .app-sidebar-item-badge{opacity:1}.home-page{display:flex;flex-direction:column;gap:16px;max-width:1280px;margin:0 auto}.home-greeting{padding:4px 0}.home-greeting-text{font-size:1.4rem;font-weight:600;color:var(--text-primary)}.home-greeting-name{color:var(--accent-primary)}.home-greeting-emoji{font-size:1.4rem}.home-tabs{display:flex;gap:8px;border-bottom:1px solid var(--border-subtle);padding-bottom:0}.home-tab{padding:10px 18px;background:none;border:none;border-bottom:2px solid transparent;font-size:.9rem;font-weight:500;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:color .12s,border-color .12s}.home-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);font-weight:600}.home-tab:hover:not(.active){color:var(--text-primary)}.module-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;padding:8px 0}@media(max-width:1200px){.module-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:900px){.module-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:600px){.module-grid{grid-template-columns:repeat(2,1fr)}}.module-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:22px 16px;background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-panel);cursor:pointer;text-align:center;font-family:inherit;color:inherit;transition:transform .16s,border-color .12s,box-shadow .16s}.module-card:hover{transform:translateY(-3px);border-color:var(--accent-primary);box-shadow:0 8px 20px #0000002e}html.light .module-card:hover{box-shadow:0 8px 20px #00000014}.module-card-disabled{opacity:.55;cursor:not-allowed}.module-card-disabled:hover{transform:none;border-color:var(--border-standard);box-shadow:none}.module-card-icon{width:56px;height:56px;border-radius:var(--r-panel);display:flex;align-items:center;justify-content:center;flex-shrink:0}.module-card-body{display:flex;flex-direction:column;gap:4px}.module-card-title{font-size:.95rem;font-weight:600;color:var(--text-primary);line-height:1.3}.module-card-desc{font-size:.8rem;font-weight:400;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em}.module-sub-panel{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.module-sub-panel-head{display:flex;flex-direction:column;gap:14px}.module-sub-back{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-btn);color:var(--text-secondary);font-family:inherit;font-size:.85rem;cursor:pointer;transition:background .12s}.module-sub-back:hover{background:var(--bg-white-04);color:var(--text-primary)}.module-sub-title{display:flex;align-items:center;gap:14px}.module-sub-icon{width:48px;height:48px;border-radius:var(--r-panel);display:flex;align-items:center;justify-content:center;flex-shrink:0}.module-sub-name{font-size:1.3rem;font-weight:600;color:var(--text-primary);line-height:1.3}.module-sub-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin-top:4px}.module-sub-groups{display:flex;flex-direction:column;gap:26px}.module-group{display:flex;flex-direction:column;gap:12px}.module-group-head{display:flex;align-items:center;gap:10px}.module-group-bar{width:4px;height:16px;border-radius:var(--r-pill);flex-shrink:0}.module-group-title{font-size:.9rem;font-weight:700;color:var(--accent-primary);margin:0;text-transform:uppercase;letter-spacing:.04em}.module-group-rule{flex:1;height:1px;min-width:16px;background:var(--border-standard)}.module-group-count{font-size:.7rem;font-weight:600;color:var(--text-tertiary);background:var(--bg-white-05);border-radius:var(--r-pill);padding:1px 8px}.module-group-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media(max-width:1200px){.module-group-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.module-group-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.module-group-grid{grid-template-columns:1fr}}.fn-card{position:relative;display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-card);cursor:pointer;text-align:left;font-family:inherit;color:inherit;transition:transform .14s,border-color .12s,box-shadow .14s}.fn-card:hover{transform:translateY(-2px);border-color:var(--accent-primary);box-shadow:0 6px 16px #00000029}html.light .fn-card:hover{box-shadow:0 6px 16px #00000012}.fn-card-icon{width:40px;height:40px;border-radius:var(--r-card);display:flex;align-items:center;justify-content:center;flex-shrink:0}.fn-card-body{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}.fn-card-title{font-size:.9rem;font-weight:600;color:var(--text-primary);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fn-card-desc{font-size:.78rem;font-weight:400;color:var(--text-tertiary);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.fn-card-external{flex-shrink:0;align-self:flex-start;color:var(--text-tertiary);font-size:.85rem}.nav-admin{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.nav-admin-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.nav-admin-actions{display:flex;gap:8px;flex-shrink:0}.nav-admin-actions .btn-primary{width:auto;display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-size:.85rem}.nav-admin-grid{display:grid;grid-template-columns:280px 1fr;gap:16px;align-items:start}@media(max-width:860px){.nav-admin-grid{grid-template-columns:1fr}}.nav-admin-col{background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-panel);padding:14px}.nav-admin-col-title{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.85rem;font-weight:700;color:var(--text-primary);margin-bottom:12px}.nav-admin-list{display:flex;flex-direction:column;gap:6px}.nav-admin-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-btn);font-size:.85rem;color:var(--text-primary);cursor:pointer}.nav-admin-row.selected{border-color:var(--accent-primary);background:var(--accent-primary-soft)}.nav-admin-row.sub{margin-left:18px;cursor:default;align-items:flex-start}.nav-admin-row.sub .nav-admin-grip{margin-top:4px}.nav-admin-sub-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.nav-admin-sub-line{display:flex;align-items:center;gap:8px}.nav-admin-sub-line .nav-admin-row-label{flex:1}.nav-admin-desc-input{width:100%;padding:5px 8px;background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-btn);color:var(--text-secondary);font-family:inherit;font-size:.78rem;outline:none}.nav-admin-desc-input:focus{border-color:var(--accent-primary)}.nav-admin-desc-input::placeholder{color:var(--text-quaternary)}.nav-admin-row.group{background:var(--bg-surface-2);border-style:dashed;cursor:default}.nav-admin-row.is-hidden{opacity:.5}.nav-admin-row-label{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;text-overflow:ellipsis}.nav-admin-row-path{font-size:.68rem;color:var(--text-tertiary)}.nav-admin-grip{display:flex;align-items:center;color:var(--text-tertiary);cursor:grab;touch-action:none}.nav-admin-grip:active{cursor:grabbing}.nav-admin-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:var(--r-btn);color:var(--text-tertiary);cursor:pointer;flex-shrink:0}.nav-admin-icon-btn:hover{background:var(--bg-white-04);color:var(--text-primary)}.nav-admin-icon-btn.danger:hover{color:var(--danger)}.nav-admin-group-input{flex:1;min-width:0;background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-btn);padding:5px 10px;font-family:inherit;font-size:.85rem;font-weight:600;color:var(--text-primary);outline:none}.nav-admin-group-input:focus{border-color:var(--accent-primary)}.nav-admin-hint{margin-top:12px;font-size:.76rem;color:var(--text-tertiary);line-height:1.5}.profile-page{max-width:1200px;margin:0 auto}.profile-layout{display:grid;grid-template-columns:320px 1fr;gap:16px}@media(max-width:900px){.profile-layout{grid-template-columns:1fr}}.profile-card{background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-panel);padding:20px 22px}.profile-avatar-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 22px}.profile-avatar{width:96px;height:96px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;margin-bottom:14px}.profile-name{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.profile-role-badge{display:inline-flex;align-items:center;padding:3px 12px;background:var(--accent-primary-soft);color:var(--accent-primary);border-radius:var(--r-pill);font-size:.78rem;font-weight:600;margin-top:6px;margin-bottom:18px}.profile-meta{width:100%;display:flex;flex-direction:column;gap:10px;padding-top:18px;border-top:1px solid var(--border-subtle);text-align:left}.profile-meta-row{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--text-secondary)}.profile-meta-row svg{color:var(--text-tertiary);flex-shrink:0}.profile-info-col{display:flex;flex-direction:column;gap:16px}.profile-card-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border-subtle)}.profile-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px 24px}@media(max-width:600px){.profile-grid-2{grid-template-columns:1fr}}.profile-field-row{display:flex;flex-direction:column;gap:4px}.profile-field-label{font-size:.75rem;color:var(--text-tertiary)}.profile-field-value{font-size:.9rem;color:var(--text-primary);font-weight:500}.legal-page{display:flex;flex-direction:column;min-height:100vh;height:auto;background:var(--bg-marketing);color:var(--text-primary);overflow-y:auto}.legal-header{position:sticky;top:0;z-index:10;background:var(--bg-panel);border-bottom:1px solid var(--border-standard)}.legal-header-inner{max-width:880px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 24px}.legal-back{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);text-decoration:none;font-size:.875rem;padding:6px 10px;border-radius:var(--r-btn);transition:background .12s}.legal-back:hover{background:var(--bg-white-04);color:var(--text-primary)}.legal-brand{display:inline-flex;align-items:center;gap:8px;font-size:.95rem;color:var(--text-primary)}.legal-logo{width:28px;height:28px;border-radius:6px;font-size:1rem}.legal-lang-switch{display:inline-flex;background:var(--bg-surface);border:1px solid var(--border-standard);border-radius:var(--r-pill);padding:3px;gap:2px}.legal-lang-switch button{background:transparent;border:0;color:var(--text-tertiary);padding:5px 12px;border-radius:var(--r-pill);font-size:.8rem;cursor:pointer;transition:all .12s}.legal-lang-switch button:hover{color:var(--text-secondary)}.legal-lang-switch button.active{background:var(--accent-primary);color:#fff}.legal-main{flex:1;padding:32px 24px 80px}.legal-article{max-width:720px;margin:0 auto;background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-panel);padding:40px 48px;line-height:1.65}.legal-article h1{font-size:2rem;font-weight:590;margin-bottom:8px;color:var(--text-primary)}.legal-article h2{font-size:1.25rem;font-weight:590;margin-top:32px;margin-bottom:12px;color:var(--text-primary)}.legal-article h3{font-size:1rem;font-weight:590;margin-top:20px;margin-bottom:8px;color:var(--text-secondary)}.legal-article p{margin-bottom:12px;color:var(--text-secondary);font-size:.95rem}.legal-article ul{margin:12px 0 16px 24px;padding-left:4px}.legal-article li{margin-bottom:6px;color:var(--text-secondary);font-size:.92rem}.legal-article a{color:var(--accent-primary);text-decoration:none}.legal-article a:hover{text-decoration:underline}.legal-article code{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.85em;background:var(--bg-surface);padding:1px 6px;border-radius:var(--r-small);color:var(--text-primary)}.legal-article strong{color:var(--text-primary);font-weight:590}.legal-meta{font-size:.85rem!important;color:var(--text-tertiary)!important;border-bottom:1px solid var(--border-subtle);padding-bottom:16px;margin-bottom:24px!important}.legal-footer{background:var(--bg-panel);border-top:1px solid var(--border-standard);padding:20px 24px}.legal-footer-inner{max-width:880px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:.85rem;color:var(--text-tertiary)}.legal-footer-inner a{color:var(--text-secondary);text-decoration:none}.legal-footer-inner a:hover{color:var(--accent-primary);text-decoration:underline}@media(max-width:640px){.legal-article{padding:24px 20px}.legal-article h1{font-size:1.5rem}.legal-header-inner{padding:10px 16px;flex-wrap:wrap}.legal-footer-inner{flex-direction:column;text-align:center}}.vttb-catalog-grid{grid-template-columns:repeat(6,minmax(0,1fr))}@media(max-width:1280px){.vttb-catalog-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}@media(max-width:1024px){.vttb-catalog-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:768px){.vttb-catalog-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:540px){.vttb-catalog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.vttb-help-body a:not([style*=color]){color:var(--accent-orange);text-decoration:none;font-weight:500}.vttb-help-body a:not([style*=color]):hover{text-decoration:underline}.glass-panel{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-stroke);box-shadow:0 1px 0 var(--glass-edge) inset,var(--glass-shadow);border-radius:var(--r-panel)}.glass-topbar{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-stroke);box-shadow:0 1px 0 var(--glass-edge) inset}.text-moment{color:var(--moment)}.bg-moment-soft{background:var(--moment-soft)}.text-alarm{color:var(--alarm)}.bg-alarm-soft{background:var(--alarm-soft)}.kpi-display{font-size:var(--font-kpi-display);font-weight:700;line-height:1.05;letter-spacing:-.02em;color:var(--moment);font-variant-numeric:tabular-nums}html.light .kpi-display{color:var(--text-primary)}.kpi-tile{position:relative;padding-left:16px}.kpi-tile:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:4px;border-radius:var(--r-pill);background:var(--moment)}.kpi-tile.alarm:before{background:var(--alarm)}.display-xl{font-size:var(--font-display-xl);font-weight:700;line-height:1.15;letter-spacing:-.02em}.display-lg{font-size:var(--font-display-lg);font-weight:600;line-height:1.2;letter-spacing:-.01em}.display-md{font-size:var(--font-display-md);font-weight:600;line-height:1.25}.btn-pill{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:var(--touch-comfort);padding:0 24px;border-radius:var(--r-pill);border:1px solid transparent;background:var(--primary);color:#fff;font-size:15px;font-weight:500;cursor:pointer;transition:background var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.btn-pill:hover{background:var(--accent-primary-hover)}.btn-pill:active{transform:scale(.97)}.btn-pill-secondary{background:transparent;color:var(--text-primary);border-color:var(--border-standard)}.btn-pill-secondary:hover{background:var(--bg-white-04)}*:focus{outline:none}*:focus-visible{box-shadow:var(--focus-ring-solid-dark);border-radius:inherit;transition:box-shadow var(--duration-fast) var(--ease-out)}html.light *:focus-visible{box-shadow:var(--focus-ring-solid)}.glass-panel *:focus-visible,.glass-topbar *:focus-visible{box-shadow:var(--focus-ring-glass)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-delay:0s!important;animation-duration:.05s!important;animation-iteration-count:1!important;transition-duration:.05s!important;scroll-behavior:auto!important}.modal-slide-in,.drawer-open,.list-stagger-item{transform:none!important}}@media(prefers-reduced-transparency:reduce){.glass-panel,.glass-topbar{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background-color:var(--bg-panel)!important;border:1px solid var(--border-standard)!important;box-shadow:var(--shadow-elevated)!important}}.emp-detail-header{display:flex;gap:18px;align-items:flex-start;padding:18px 20px;background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--r-card);margin-bottom:16px}.emp-detail-avatar{width:64px;height:64px;border-radius:50%;background:var(--accent-violet);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:600;flex-shrink:0}.emp-detail-info{flex:1}.emp-detail-name{margin:0 0 6px;font-size:1.4rem;font-weight:600}.emp-detail-meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.emp-detail-actions{display:flex;gap:8px;flex-shrink:0}.emp-detail-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-subtle);margin-bottom:16px}.emp-detail-tab{padding:8px 14px;background:transparent;border:none;color:var(--t2);cursor:pointer;font-size:.9rem;border-bottom:2px solid transparent}.emp-detail-tab:hover{color:var(--t1)}.emp-detail-tab.active{color:var(--accent-orange);border-bottom-color:var(--accent-orange);font-weight:600}.emp-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:12px}.emp-section{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--r-card);padding:14px 16px}.emp-section-title{font-size:.95rem;font-weight:600;margin:0 0 12px;color:var(--accent-orange);border-bottom:1px solid var(--border-subtle);padding-bottom:8px}.emp-section-body{display:flex;flex-direction:column;gap:6px}.emp-row{display:grid;grid-template-columns:140px 1fr;gap:8px;font-size:.85rem}.emp-row-label{color:var(--t3)}.emp-row-value{color:var(--t1)}.emp-subsection{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--r-card);padding:16px}.emp-subsection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.emp-subsection-header h3{margin:0;font-size:1rem;font-weight:600}.emp-edit-form{display:flex;flex-direction:column;gap:12px}.tk-quickfill{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--bg-surface-2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;margin:12px 0;font-size:13px;color:var(--text-secondary)}.tk-quickfill-label{font-weight:600;color:var(--text-primary)}.tk-quickfill select,.tk-quickfill input[type=number]{font-size:13px;padding:4px 6px}.tk-quickfill-wk{display:inline-flex;align-items:center;gap:4px;cursor:pointer}.tk-grid-scroll{overflow-x:auto;overflow-y:visible;margin-top:12px;border:1px solid var(--border);border-radius:8px;scrollbar-width:thin}.tk-grid-scroll::-webkit-scrollbar{height:12px}.tk-grid-scroll::-webkit-scrollbar-thumb{background:var(--border-solid, var(--border));border-radius:6px}.tk-grid{border-collapse:separate;border-spacing:0;font-size:12px;white-space:nowrap;color:var(--text-primary)}.tk-grid th,.tk-grid td{border-bottom:1px solid var(--border)}.tk-sticky{position:sticky;left:0;z-index:2;width:210px;min-width:210px;max-width:210px;background:var(--bg-surface);color:var(--text-primary);padding:6px 10px;text-align:left;box-shadow:1px 0 0 var(--border);overflow:hidden;text-overflow:ellipsis}.tk-head{z-index:3;background:var(--bg-surface-2);font-weight:600;border-bottom:2px solid var(--border)}.tk-name{font-weight:500}.tk-code{font-weight:700;color:var(--accent-primary);margin-right:4px}.tk-day-head{padding:6px 4px;min-width:30px;text-align:center;color:var(--text-tertiary);font-weight:600;border-left:1px solid var(--border);border-bottom:2px solid var(--border);background:var(--bg-surface-2)}.tk-cell{padding:2px 4px;min-width:30px;text-align:center;cursor:pointer;border-left:1px solid var(--border)}.tk-cell:hover{background:var(--accent-primary-soft, rgba(94,106,210,.12))}.tk-weekend{background:var(--bg-white-02, rgba(127,127,127,.06))}.tk-cell-select{font-size:12px;min-width:56px;padding:0}.tk-cell-val{font-weight:600;color:var(--text-primary)}.tk-cell-empty{color:var(--text-tertiary)}.tk-tot-head{padding:6px;text-align:center;background:var(--bg-surface-2);border-left:1px solid var(--border);border-bottom:2px solid var(--border);font-weight:600}.tk-tot{padding:4px 6px;text-align:center;border-left:1px solid var(--border);color:var(--text-primary)}.tk-std{cursor:pointer}.tk-std:hover{background:var(--accent-primary-soft, rgba(94,106,210,.12))}.tk-std-input{width:56px;font-size:12px;padding:1px 3px}.tk-std-pencil{color:var(--text-tertiary);font-size:10px}.picker-col-title{font-weight:600;font-size:.9rem;margin-bottom:6px}.picker-pane{flex:1;min-height:320px;max-height:52vh;overflow-y:auto;border:1px solid var(--border, #e5e7eb);border-radius:var(--r-card, 8px);padding:6px;background:var(--bg, transparent)}.picker-unit-head{display:flex;align-items:center;gap:8px;padding:5px 6px;margin-bottom:2px;background:var(--bg2, rgba(127,127,127,.08));border-radius:6px;font-size:.82rem;color:var(--t2, #6b7280);position:sticky;top:-6px;z-index:1}.picker-row{display:flex;align-items:center;gap:8px;width:100%;padding:5px 8px;border:none;background:transparent;cursor:pointer;text-align:left;font-size:.88rem;color:inherit;border-radius:6px}.picker-row:hover{background:var(--accent-primary-soft, rgba(94,106,210,.12))}.picker-row-add{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;font-weight:700;background:var(--accent-violet, #5e6ad2);color:#fff;font-size:.8rem;flex:0 0 auto}.picker-code{font-family:monospace;font-size:.74rem;color:var(--t2, #6b7280)}.picker-pos{font-size:.74rem;color:var(--t2, #6b7280)}.picker-row-selected{cursor:default;background:var(--bg2, rgba(127,127,127,.05));margin-bottom:3px}.picker-row-selected:hover{background:var(--bg2, rgba(127,127,127,.05))}.picker-unit-tag{font-size:.74rem;color:var(--t2, #6b7280)}.picker-row-remove{border:none;background:transparent;cursor:pointer;color:var(--accent-red, #ef4444);font-size:.9rem;padding:2px 6px;flex:0 0 auto}.btn-xs{font-size:.72rem;padding:2px 8px;border-radius:5px;cursor:pointer;line-height:1.4;white-space:nowrap}.picker-caret{border:none;background:transparent;cursor:pointer;color:var(--t2, #6b7280);font-size:.7rem;padding:0 2px;flex:0 0 auto;line-height:1}.picker-count{font-size:.72rem;color:var(--t2, #6b7280);background:var(--bg, rgba(127,127,127,.12));border-radius:10px;padding:0 7px;flex:0 0 auto}.picker-subunit-head{display:flex;align-items:center;gap:8px;padding:3px 6px;margin:2px 0;font-size:.78rem;color:var(--t2, #6b7280);border-left:2px solid var(--accent-violet, #5e6ad2)}.hse-select,.hse-input,.hse-textarea{font-family:inherit;font-size:.85rem;color:var(--text-primary);background:var(--bg-white-02, rgba(255,255,255,.03));border:1px solid var(--border-standard);border-radius:10px;padding:8px 12px;outline:none;transition:border-color .15s,box-shadow .15s,background .15s}.hse-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;padding-right:32px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2399a0ad' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 10px center}.hse-select:hover,.hse-input:hover,.hse-textarea:hover{border-color:var(--border-solid)}.hse-select:focus,.hse-input:focus,.hse-textarea:focus{border-color:var(--accent-violet, #5e6ad2);box-shadow:0 0 0 3px var(--accent-violet-glow, rgba(94,106,210,.18));background:var(--bg-white-04, rgba(255,255,255,.05))}.hse-select option{background:var(--bg-surface);color:var(--text-primary)}html.light .hse-select option{background:#fff}.elearning-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-standard);margin-bottom:16px}.elearning-tabs--inline{margin-bottom:12px;margin-top:-4px}.elearning-tab{padding:10px 16px;background:transparent;border:0;border-bottom:2px solid transparent;cursor:pointer;font-size:.875rem;color:var(--text-tertiary);font-family:inherit}.elearning-tab:hover{color:var(--text-secondary)}.elearning-tab.is-active{color:var(--accent-violet);border-bottom-color:var(--accent-violet);font-weight:590}.elearning-tab:disabled{color:var(--text-quaternary);cursor:not-allowed}.elearning-tab__badge{display:inline-block;margin-left:6px;background:var(--accent-violet);color:#fff;border-radius:var(--r-pill);padding:1px 7px;font-size:11px}.elearning-catalog{padding:16px}.elearning-filters{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.elearning-filters input,.elearning-filters select{height:36px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-input);padding:0 10px;color:var(--text-primary);font-family:inherit;font-size:.875rem}.elearning-filters input::placeholder{color:var(--text-quaternary)}.elearning-filter__search{flex:1;min-width:240px}.elearning-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.elearning-empty{text-align:center;padding:60px 20px;color:var(--text-tertiary)}.elearning-card{display:block;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-card);overflow:hidden;transition:transform .15s,box-shadow .15s,border-color .15s;text-decoration:none;color:inherit}.elearning-card:hover{transform:translateY(-2px);border-color:var(--accent-violet-soft);box-shadow:0 6px 20px #0000004d}.elearning-card__thumb{height:140px;background-size:cover;background-position:center;background-color:var(--bg-surface-2);display:flex;align-items:center;justify-content:center;position:relative}.elearning-card__body{padding:12px 16px}.elearning-card__title{font-size:.9375rem;font-weight:590;color:var(--text-primary);margin:0 0 6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.elearning-card__meta{font-size:.75rem;color:var(--text-tertiary);display:flex;flex-wrap:wrap;gap:6px;margin:0 0 4px}.elearning-card__instructor{font-size:.75rem;color:var(--text-secondary);margin:0 0 8px}.elearning-card__count{font-size:.75rem;color:var(--text-tertiary);margin:0}.elearning-progress{position:relative;background:var(--bg-white-04);border-radius:var(--r-pill);height:6px;overflow:hidden;margin-top:8px}.elearning-progress__bar{position:absolute;inset:0 auto 0 0;background:var(--accent-violet);transition:width .3s}.elearning-progress__label{display:block;font-size:.6875rem;color:var(--text-tertiary);margin-top:4px}.elearning-badge{display:inline-block;padding:2px 8px;border-radius:var(--r-pill);font-size:11px;font-weight:590;background:var(--bg-white-04);color:var(--text-secondary)}.elearning-badge--mandatory{position:absolute;top:8px;right:8px;background:var(--danger);color:#fff}.elearning-badge--completed{position:absolute;top:8px;left:8px;background:var(--success);color:#fff}.elearning-badge--cert{background:var(--warn);color:#fff}.elearning-badge--preview{background:var(--accent-violet-soft);color:var(--accent-violet);border:1px solid var(--accent-violet-soft)}.elearning-detail{padding:16px;max-width:1200px;margin:0 auto}.elearning-detail__hero{display:grid;grid-template-columns:320px 1fr;gap:24px;margin-bottom:24px}.elearning-detail__cover{height:200px;background-size:cover;background-position:center;background-color:var(--bg-surface-2);border-radius:var(--r-card);display:flex;align-items:center;justify-content:center}.elearning-detail__intro h1{font-size:1.75rem;color:var(--text-primary);margin-bottom:8px}.elearning-detail__meta{color:var(--text-tertiary);font-size:.8125rem;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.elearning-detail__creator{color:var(--text-secondary);margin-bottom:12px;font-size:.875rem}.elearning-detail__desc{color:var(--text-secondary);line-height:1.6;margin-bottom:16px}.elearning-detail__actions{display:flex;gap:12px;align-items:center}.elearning-detail__curriculum h2,.elearning-detail__resources h2{font-size:1.125rem;color:var(--text-primary);margin-bottom:12px}.elearning-chapters{border:1px solid var(--border-standard);border-radius:var(--r-card);background:var(--bg-white-02)}.elearning-chapter{border-bottom:1px solid var(--border-subtle)}.elearning-chapter:last-child{border-bottom:0}.elearning-chapter__header{width:100%;text-align:left;background:transparent;border:0;padding:12px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;font-size:.875rem;color:var(--text-primary);font-family:inherit}.elearning-chapter__header:hover{background:var(--bg-white-04)}.elearning-chapter__lessons{list-style:none;padding:0 16px 12px 40px;margin:0}.elearning-lesson-row{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.8125rem;color:var(--text-secondary)}.elearning-lesson__icon{width:20px}.elearning-lesson__title{flex:1}.elearning-lesson__duration{color:var(--text-tertiary);font-size:.75rem}.elearning-lesson__lock{opacity:.5}.elearning-learn{display:grid;grid-template-columns:1fr 320px;height:calc(100vh - var(--topbar-h, 64px));overflow:hidden}.elearning-learn__main{overflow-y:auto;display:flex;flex-direction:column}.elearning-learn__player{background:#000;position:relative}.elearning-learn__nav{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-panel);border-bottom:1px solid var(--border-standard);gap:12px}.elearning-learn__title{font-weight:590;flex:1;text-align:center;color:var(--text-primary)}.elearning-learn__tabs{padding:16px;flex:1}.elearning-tab-pane{padding-top:16px}.elearning-video-status{background:var(--bg-surface);color:var(--text-secondary);padding:60px 20px;text-align:center;font-size:1rem}.elearning-reading{padding:24px;background:var(--bg-panel);max-width:800px;margin:0 auto;color:var(--text-primary)}.elearning-reading__content p{margin-bottom:12px;line-height:1.6;color:var(--text-secondary)}.elearning-quiz-intro{padding:40px;text-align:center;background:var(--bg-panel);color:var(--text-primary)}.elearning-sidebar{background:var(--bg-panel);border-left:1px solid var(--border-standard);overflow-y:auto;padding:16px}.elearning-sidebar__title{font-size:.875rem;color:var(--text-primary);margin-bottom:12px;font-weight:590}.elearning-sidebar__chapter{margin-bottom:12px}.elearning-sidebar__chapter-head{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-tertiary);padding:6px 0}.elearning-sidebar__lessons{list-style:none;padding:0;margin:0}.elearning-sidebar__lesson{display:flex;align-items:center;gap:8px;padding:8px;cursor:pointer;border-radius:var(--r-btn);font-size:.8125rem;color:var(--text-secondary)}.elearning-sidebar__lesson:hover{background:var(--bg-white-04);color:var(--text-primary)}.elearning-sidebar__lesson.is-active{background:var(--accent-violet-soft);color:var(--accent-violet);font-weight:590}.elearning-sidebar__lesson.is-completed{color:var(--success)}.elearning-sidebar__lesson-icon{width:20px}.elearning-sidebar__lesson-title{flex:1;line-height:1.3}.elearning-sidebar__lesson-duration{font-size:.6875rem;color:var(--text-tertiary)}.elearning-notes__form textarea{width:100%;padding:9px 12px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-input);color:var(--text-primary);font-family:inherit;font-size:.875rem}.elearning-notes__form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.elearning-notes__form-actions label{color:var(--text-secondary);font-size:.8125rem}.elearning-notes__section{margin-top:16px}.elearning-notes__section h4{color:var(--text-primary);font-size:.875rem;margin-bottom:8px}.elearning-notes__list{list-style:none;padding:0;margin:0}.elearning-note{display:flex;align-items:flex-start;gap:8px;padding:10px;border-bottom:1px solid var(--border-subtle)}.elearning-note__time{color:var(--accent-violet);flex-shrink:0;cursor:pointer}.elearning-note__content{flex:1;line-height:1.5;margin:0;color:var(--text-secondary)}.elearning-note__actions{display:flex;gap:4px;align-items:center}.elearning-note__actions small{color:var(--text-tertiary);font-size:.75rem}.elearning-note--public{background:var(--bg-white-02);border-radius:var(--r-btn)}.elearning-discussion__form{margin-bottom:16px}.elearning-discussion__form textarea{width:100%;padding:9px 12px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-input);color:var(--text-primary);font-family:inherit;font-size:.875rem;margin-bottom:8px}.elearning-discussion__list{list-style:none;padding:0;margin:0}.elearning-thread{padding:12px;border-bottom:1px solid var(--border-subtle)}.elearning-thread.is-pinned{background:var(--accent-violet-soft);border-radius:var(--r-card)}.elearning-thread__pin{color:var(--warn);font-size:.75rem;font-weight:590}.elearning-thread__head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}.elearning-thread__head strong{color:var(--text-primary);font-weight:590}.elearning-thread__head small{color:var(--text-tertiary);font-size:.75rem}.elearning-thread__content{color:var(--text-secondary);line-height:1.6;margin-bottom:8px}.elearning-thread__actions{display:flex;gap:8px}.elearning-thread__replies{list-style:none;padding-left:24px;margin-top:12px;border-left:2px solid var(--border-standard)}.elearning-reply{padding:8px 12px}.elearning-thread__reply-form{margin-top:8px;padding-left:24px}.elearning-thread__reply-form textarea{width:100%;padding:9px 12px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-input);color:var(--text-primary);font-family:inherit;font-size:.875rem;margin-bottom:4px}.elearning-resources{list-style:none;padding:0;margin:0}.elearning-resource{display:flex;align-items:center;gap:12px;padding:10px;border-bottom:1px solid var(--border-subtle)}.elearning-resource__icon{font-size:1.5rem}.elearning-resource__info{flex:1}.elearning-resource__info strong{color:var(--text-primary);font-weight:590}.elearning-resource__info small{display:block;color:var(--text-tertiary);font-size:.75rem}.elearning-quiz-take{max-width:720px;margin:0 auto;padding:24px;background:var(--bg-panel);border-radius:var(--r-card)}.elearning-quiz-take__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:24px}.elearning-quiz-take__header h2{color:var(--text-primary)}.elearning-quiz-take__header small{color:var(--text-tertiary);font-size:.8125rem}.elearning-quiz-take__text{font-size:1rem;line-height:1.6;margin-bottom:16px;color:var(--text-primary)}.elearning-quiz-take__options{list-style:none;padding:0;margin:0 0 24px}.elearning-quiz-take__opt{border:1px solid var(--border-standard);background:var(--bg-white-02);border-radius:var(--r-btn);margin-bottom:8px;cursor:pointer;transition:all .15s;color:var(--text-secondary)}.elearning-quiz-take__opt label{display:flex;gap:8px;padding:12px;cursor:pointer;align-items:center}.elearning-quiz-take__opt:hover{background:var(--bg-white-04)}.elearning-quiz-take__opt.is-selected{border-color:var(--accent-violet);background:var(--accent-violet-soft);color:var(--text-primary)}.elearning-quiz-take__nav{display:flex;justify-content:space-between;align-items:center;gap:12px}.elearning-quiz-take__pages{display:flex;gap:4px;flex-wrap:wrap}.elearning-quiz-page{width:32px;height:32px;border-radius:var(--r-pill);border:1px solid var(--border-standard);background:var(--bg-white-02);color:var(--text-secondary);cursor:pointer;font-size:.75rem;font-family:inherit}.elearning-quiz-page.is-active{background:var(--accent-violet);color:#fff;border-color:var(--accent-violet)}.elearning-quiz-page.is-answered{border-color:var(--accent-violet)}.elearning-quiz-result{max-width:720px;margin:0 auto;padding:24px}.elearning-quiz-result h2{color:var(--text-primary)}.elearning-quiz-result__score{font-size:3rem;margin:16px 0;text-align:center;color:var(--accent-violet);font-weight:700}.elearning-quiz-review{margin:24px 0;padding-left:20px}.elearning-quiz-review__q{padding:12px;border-radius:var(--r-btn);margin-bottom:8px}.elearning-quiz-review__q.is-right{background:#10b9811a;border:1px solid rgba(16,185,129,.3)}.elearning-quiz-review__q.is-wrong{background:#ef44441a;border:1px solid rgba(239,68,68,.3)}.elearning-quiz-review__q ul{list-style:none;padding-left:0;margin:8px 0}.elearning-quiz-review__q ul li{color:var(--text-secondary);padding:2px 0}.elearning-quiz-review__q ul li.is-correct{color:var(--success);font-weight:590}.elearning-quiz-review__q ul li.is-wrong-pick{color:var(--danger);text-decoration:line-through}.elearning-quiz-review__explain{margin-top:8px;font-style:italic;color:var(--text-tertiary);font-size:.875rem}.elearning-certs{padding:16px}.elearning-certs__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.elearning-cert{background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-card);overflow:hidden}.elearning-cert__thumb{height:140px;background-size:cover;background-position:center;background-color:var(--bg-surface-2);display:flex;align-items:center;justify-content:center}.elearning-cert__body{padding:12px 16px;color:var(--text-secondary)}.elearning-cert__body h3{color:var(--text-primary);margin-bottom:6px}.elearning-cert__body p{font-size:.8125rem;margin-bottom:4px}.elearning-cert__body code{background:var(--bg-white-04);padding:2px 6px;border-radius:var(--r-small);color:var(--accent-violet);font-size:.8125rem}.elearning-cert__actions{display:flex;gap:8px;margin-top:8px}.elearning-verify{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#08090a,#1f2026)}.elearning-verify__card{background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-panel);padding:32px;max-width:600px;width:100%;box-shadow:0 20px 50px #00000080;color:var(--text-primary)}.elearning-verify__card h1{color:var(--accent-violet);margin-bottom:4px}.elearning-verify__card p{color:var(--text-tertiary)}.elearning-verify__result{margin-top:24px;padding:20px;border-radius:var(--r-card)}.elearning-verify__result.is-valid{background:#10b9811a;border:1px solid rgba(16,185,129,.4)}.elearning-verify__result.is-invalid{background:#ef44441a;border:1px solid rgba(239,68,68,.4)}.elearning-verify__table{width:100%;margin-top:12px}.elearning-verify__table th{text-align:left;padding:6px 0;width:30%;color:var(--text-tertiary);font-weight:510}.elearning-verify__table td{padding:6px 0;color:var(--text-primary)}.elearning-verify__table code{background:var(--bg-white-04);padding:2px 6px;border-radius:var(--r-small);color:var(--accent-violet)}.elearning-admin-list{padding:16px}.elearning-admin-list__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.elearning-admin-list__head h2{color:var(--text-primary)}.elearning-admin-list__filters{display:flex;gap:12px;margin-bottom:16px}.elearning-admin-list__filters input,.elearning-admin-list__filters select{height:36px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-input);padding:0 10px;color:var(--text-primary);font-family:inherit;font-size:.875rem}.elearning-admin-edit{padding:16px}.elearning-admin-edit__header{margin-bottom:16px}.elearning-admin-edit__header h2{color:var(--text-primary);margin:4px 0}.elearning-admin-edit__header small{color:var(--text-tertiary)}.elearning-admin-edit__pane{padding:16px 0}.elearning-admin-form{max-width:800px}.elearning-admin-form .form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.elearning-admin-form .form-actions{display:flex;gap:8px;margin-top:16px}.form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.elearning-modal-pane{max-height:60vh;overflow-y:auto}.elearning-modal-hint{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:12px;line-height:1.5}.elearning-modal-actions{display:flex;gap:8px;margin-top:12px}.elearning-checkbox-label{display:flex!important;align-items:center;gap:8px;font-weight:510!important;color:var(--text-secondary)!important;margin-bottom:0!important;cursor:pointer}.elearning-checkbox-label input[type=checkbox]{width:auto!important;margin:0!important;accent-color:var(--accent-violet)}.elearning-checkbox-label span{font-size:.8125rem}.elearning-chapters-edit__add{display:flex;gap:8px;margin-bottom:16px}.elearning-chapters-edit__add input{flex:1;padding:9px 12px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-input);color:var(--text-primary);font-family:inherit;font-size:.875rem}.elearning-chapter-edit{background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-card);margin-bottom:12px;padding:12px}.elearning-chapter-edit__head{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--text-primary)}.elearning-chapter-edit__head strong{color:var(--text-primary);font-weight:590}.elearning-chapter-edit__head small{color:var(--text-tertiary);font-size:.75rem}.elearning-chapter-edit__head input{flex:1;padding:6px 10px;background:var(--bg-white-04);border:1px solid var(--border-standard);border-radius:var(--r-input);color:var(--text-primary);font-family:inherit}.elearning-chapter-edit__actions{margin-left:auto;display:flex;gap:4px}.elearning-chapter-edit__lessons{list-style:none;padding:0;margin:0 0 8px}.elearning-lesson-edit{display:flex;align-items:center;gap:8px;padding:8px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);font-size:.875rem}.elearning-lesson-edit:last-child{border-bottom:0}.elearning-lesson-edit__actions{display:flex;gap:4px;margin-left:auto}.status-pill{display:inline-block;padding:2px 8px;border-radius:var(--r-pill);font-size:.6875rem;font-weight:590}.status-pill--draft{background:var(--bg-white-04);color:var(--text-tertiary)}.status-pill--published{background:#10b98126;color:var(--success)}.status-pill--archived{background:#f59e0b26;color:var(--warn)}.status-pill--pending,.status-pill--transcoding{background:#5e6ad22e;color:var(--accent-indigo)}.status-pill--ready{background:#10b98126;color:var(--success)}.status-pill--failed{background:#ef444426;color:var(--danger)}.elearning-question-row{background:var(--bg-white-02);border:1px solid var(--border-standard);padding:12px;border-radius:var(--r-btn);margin-bottom:8px}.elearning-question-row__head{color:var(--text-primary);margin-bottom:6px}.elearning-question-row__head small{color:var(--text-tertiary)}.elearning-question-row ul{list-style:none;padding-left:16px;margin:6px 0}.elearning-question-row ul li{color:var(--text-secondary);padding:2px 0;font-size:.8125rem}.elearning-question-row ul li.is-correct{color:var(--success);font-weight:590}.elearning-question-editor{background:var(--bg-white-04);border:1px solid var(--accent-violet-soft);padding:14px;border-radius:var(--r-btn);margin-top:12px}.elearning-question-editor h4{color:var(--text-primary);margin-bottom:8px;font-size:.875rem}.elearning-option-edit{display:flex;align-items:center;gap:8px;margin-bottom:6px}.elearning-option-edit input[type=text]{flex:1;padding:6px 10px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-input);color:var(--text-primary);font-family:inherit;font-size:.875rem}.elearning-students-tab__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;flex-wrap:wrap}.elearning-students-tab__filters{display:flex;gap:8px;flex:1;max-width:600px}.elearning-students-tab__filters input,.elearning-students-tab__filters select{padding:6px 10px;background:var(--bg-white-02);border:1px solid var(--border-standard);border-radius:var(--r-input);height:32px;color:var(--text-primary);font-family:inherit;font-size:.8125rem}.elearning-settings-tab{max-width:800px}.elearning-settings-section{background:var(--bg-white-02);border:1px solid var(--border-standard);padding:16px;border-radius:var(--r-card);margin-bottom:16px}.elearning-settings-section h3{color:var(--text-primary);margin-bottom:8px;font-size:1rem}.elearning-settings-section p{color:var(--text-tertiary);font-size:.8125rem}.elearning-settings__form{display:flex;gap:8px;margin-bottom:12px}.elearning-settings__form input{flex:1;padding:6px 10px;background:var(--bg-white-04);border:1px solid var(--border-standard);border-radius:var(--r-input);color:var(--text-primary);font-family:inherit;font-size:.875rem}.elearning-settings-section textarea{width:100%;padding:9px 12px;background:var(--bg-white-04);border:1px solid var(--border-standard);border-radius:var(--r-input);color:var(--text-primary);font-family:inherit;font-size:.875rem;margin-bottom:8px}.elearning-settings__list{list-style:none;padding:0;margin:0}.elearning-settings__list li{padding:8px 0;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);font-size:.8125rem}.elearning-settings__list li:last-child{border-bottom:0}.elearning-settings__list li strong{color:var(--text-primary);font-weight:590}.data-table{width:100%;border-collapse:collapse;background:var(--bg-white-02);border-radius:var(--r-card);overflow:hidden;border:1px solid var(--border-standard)}.data-table th{text-align:left;padding:10px 12px;background:var(--bg-white-04);font-size:.75rem;color:var(--text-tertiary);font-weight:590;text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border-standard)}.data-table td{padding:10px 12px;border-bottom:1px solid var(--border-subtle);font-size:.875rem;color:var(--text-secondary)}.data-table tr:last-child td{border-bottom:0}.data-table .actions{display:flex;gap:4px}.elearning-admin-discussions p{color:var(--text-tertiary);font-size:.8125rem;margin-bottom:12px}.elearning-admin-discussions a{color:var(--accent-violet)}.elearning-quiz-results{padding:4px 0}.elearning-player-wrap{position:relative;width:100%;background:#000;overflow:hidden}.elearning-player-wrap video{width:100%;max-height:70vh;display:block;background:#000}.elearning-watermark{position:absolute;pointer-events:none;user-select:none;-webkit-user-select:none;color:#ffffff4d;font-size:11px;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:500;letter-spacing:.4px;padding:3px 8px;background:#0000002e;border-radius:3px;text-shadow:0 1px 3px rgba(0,0,0,.85),0 0 6px rgba(0,0,0,.45);transition:top 2.5s ease-in-out,left 2.5s ease-in-out;z-index:10;white-space:nowrap;mix-blend-mode:difference;max-width:80%;overflow:hidden;text-overflow:ellipsis}.muted{color:var(--text-tertiary)}.error{color:var(--danger)}.ith-page{max-width:1200px;margin:0 auto;padding:16px 24px}.ith-page--wide{max-width:none}.ith-page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}.ith-page-head h1{margin:0;font-size:1.25rem;font-weight:590;color:var(--text-primary)}.ith-page-head .subtitle{margin:4px 0 0;font-size:.8125rem;color:var(--text-tertiary)}.ith-page-actions{display:flex;gap:8px;align-items:center}.ith-card{background:var(--bg-card);border:1px solid var(--border-standard);border-radius:var(--r-panel);padding:20px;box-shadow:var(--shadow-elevated)}.ith-card+.ith-card{margin-top:16px}.ith-card-section{border-top:1px solid var(--border-subtle);margin-top:16px;padding-top:16px}.ith-card-section:first-child{border-top:0;margin-top:0;padding-top:0}.ith-card-section__title{margin:0 0 12px;font-size:.8125rem;font-weight:590;color:var(--text-secondary)}.ith-empty{background:var(--bg-card);border:1px solid var(--border-standard);border-radius:var(--r-panel);padding:48px 24px;text-align:center;color:var(--text-tertiary);font-size:.875rem}.ith-form-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.ith-input,.ith-select,.ith-textarea{width:100%;background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-input);padding:8px 10px;font-size:.875rem;color:var(--text-primary);font-family:inherit;outline:none;transition:border-color .12s}.ith-input:focus,.ith-select:focus,.ith-textarea:focus{border-color:var(--accent-orange)}.ith-textarea{min-height:110px;resize:vertical}.ith-help{color:var(--text-tertiary);font-size:.75rem;margin-top:4px}.ith-error{background:#ef444414;border:1px solid rgba(239,68,68,.3);color:var(--danger);border-radius:var(--r-input);padding:8px 12px;font-size:.8125rem}.ith-info{background:#f9731614;border:1px solid rgba(249,115,22,.3);color:var(--accent-orange);border-radius:var(--r-input);padding:8px 12px;font-size:.8125rem}.ith-pill-group{display:flex;flex-wrap:wrap;gap:6px}.ith-pill{background:var(--bg-panel);border:1px solid var(--border-standard);border-radius:var(--r-pill);padding:4px 14px;font-size:.8125rem;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:all .12s}.ith-pill:hover{border-color:var(--border-solid)}.ith-pill.is-active{background:var(--accent-orange);border-color:var(--accent-orange);color:#fff}.ith-tickets-table{width:100%;border-collapse:collapse;font-size:.8125rem;text-align:left}.ith-tickets-table thead{background:var(--bg-surface);color:var(--text-tertiary);font-size:.6875rem;text-transform:uppercase;letter-spacing:.04em}.ith-tickets-table th{padding:10px 14px;font-weight:590}.ith-tickets-table td{padding:10px 14px;border-top:1px solid var(--border-subtle)}.ith-tickets-table tbody tr:hover{background:var(--bg-white-02)}.ith-tickets-table a{color:var(--text-primary);text-decoration:none;font-weight:590}.ith-tickets-table a:hover{color:var(--accent-orange)}.ith-tickets-table .meta{color:var(--text-tertiary);font-size:.6875rem;margin-top:2px}.ith-status{display:inline-block;padding:1px 8px;border-radius:var(--r-small);font-size:.6875rem;font-weight:590}.ith-status--new{background:#3b82f626;color:#60a5fa}.ith-status--assigned{background:#f59e0b26;color:#fbbf24}.ith-status--in_progress{background:#f9731626;color:#fb923c}.ith-status--resolved{background:#10b98126;color:#34d399}.ith-status--closed{background:#94a3b826;color:#94a3b8}.ith-sla{display:inline-block;padding:1px 8px;border-radius:var(--r-small);font-size:.6875rem;font-weight:590;white-space:nowrap}.ith-sla--green{background:#10b98126;color:#34d399}.ith-sla--amber{background:#f59e0b26;color:#fbbf24}.ith-sla--red{background:#ef444426;color:#f87171}.ith-sla--neutral{background:var(--bg-surface-2);color:var(--text-tertiary)}.ith-att-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media(max-width:600px){.ith-att-grid{grid-template-columns:repeat(2,1fr)}}.ith-att{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--r-card);overflow:hidden;display:block;text-decoration:none;color:inherit}.ith-att--clickable:hover{border-color:var(--accent-orange)}.ith-att__img{display:block;width:100%;height:140px;object-fit:cover;background:var(--bg-surface-2)}.ith-att__meta{padding:6px 10px}.ith-att__name{color:var(--text-secondary);font-size:.75rem;font-weight:500;truncate:ellipsis;word-break:break-all}.ith-att__sub{color:var(--text-tertiary);font-size:.6875rem;margin-top:2px}.ith-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:10px}.ith-photo{position:relative;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--r-card);overflow:hidden}.ith-photo img{display:block;width:100%;height:110px;object-fit:cover}.ith-photo__remove{position:absolute;top:4px;right:4px;background:#000000b3;color:#fff;border:0;border-radius:var(--r-pill);width:22px;height:22px;cursor:pointer;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center}.ith-photo__size{padding:4px 8px;font-size:.625rem;color:var(--text-tertiary)}.ith-comments{display:flex;flex-direction:column;gap:12px}.ith-comment{border-left:2px solid var(--accent-orange);padding:4px 0 4px 12px}.ith-comment__head{display:flex;justify-content:space-between;font-size:.6875rem;margin-bottom:4px}.ith-comment__author{color:var(--text-secondary);font-weight:590}.ith-comment__time{color:var(--text-tertiary)}.ith-comment__body{color:var(--text-primary);font-size:.875rem;white-space:pre-wrap}.ith-comment-form{display:flex;gap:8px;margin-top:12px}.ith-comment-form input{flex:1}.ith-detail-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle)}@media(max-width:700px){.ith-detail-meta{grid-template-columns:repeat(2,1fr)}}.ith-detail-meta__label{display:block;font-size:.625rem;text-transform:uppercase;color:var(--text-tertiary);letter-spacing:.04em;margin-bottom:2px}.ith-detail-meta__value{color:var(--text-secondary);font-size:.8125rem}.ith-resolved-banner{background:#10b98114;border:1px solid rgba(16,185,129,.3);border-radius:var(--r-card);padding:14px 16px;margin-top:16px}.ith-resolved-banner p{margin:0 0 10px;color:var(--success);font-size:.875rem;font-weight:500}.ith-kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px}.ith-kanban-col{flex:0 0 280px;min-height:600px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-top-width:3px;border-radius:var(--r-card);display:flex;flex-direction:column;transition:background .12s}.ith-kanban-col--new{border-top-color:#60a5fa}.ith-kanban-col--assigned{border-top-color:#fbbf24}.ith-kanban-col--in_progress{border-top-color:#fb923c}.ith-kanban-col--resolved{border-top-color:#34d399}.ith-kanban-col.is-over{background:#f9731614;border-color:var(--accent-orange)}.ith-kanban-col__head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border-subtle);background:var(--bg-card);border-top-left-radius:var(--r-card);border-top-right-radius:var(--r-card)}.ith-kanban-col__title{font-size:.8125rem;font-weight:590;color:var(--text-primary)}.ith-kanban-col__count{background:var(--bg-surface-2);border-radius:var(--r-pill);padding:1px 8px;font-size:.6875rem;color:var(--text-secondary);font-weight:590}.ith-kanban-col__body{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px}.ith-kanban-col__empty{text-align:center;color:var(--text-tertiary);font-size:.75rem;padding:20px 0}.ith-card-mini{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-card);padding:10px 12px;cursor:pointer;transition:box-shadow .12s,transform .12s}.ith-card-mini:hover{box-shadow:var(--shadow-elevated)}.ith-card-mini.is-dragging{opacity:.7;transform:rotate(1deg);box-shadow:var(--shadow-dialog)}.ith-card-mini__title-row{display:flex;gap:8px;margin-bottom:6px}.ith-card-mini__dot{flex:0 0 8px;height:8px;border-radius:50%;margin-top:6px}.ith-card-mini__title{flex:1;font-size:.8125rem;font-weight:500;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ith-card-mini__sub{display:flex;gap:6px;font-size:.6875rem;color:var(--text-tertiary);margin-bottom:6px}.ith-card-mini__sub .mono{font-family:var(--font-mono, ui-monospace, monospace)}.ith-card-mini__people{display:flex;align-items:center;justify-content:space-between;font-size:.6875rem;color:var(--text-tertiary);margin-bottom:6px}.ith-card-mini__assignee{background:var(--bg-surface-2);color:var(--text-secondary);border-radius:var(--r-small);padding:1px 8px}.ith-cat--wifi{background:#38bdf8}.ith-cat--vpn{background:#06b6d4}.ith-cat--printer{background:#818cf8}.ith-cat--laptop{background:#c084fc}.ith-cat--email{background:#f472b6}.ith-cat--software{background:#fbbf24}.ith-cat--voip{background:#2dd4bf}.ith-cat--account{background:#f87171}.ith-cat--other{background:#94a3b8}.ith-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:40;display:flex;justify-content:flex-end}.ith-drawer{width:480px;max-width:90vw;background:var(--bg-panel);border-left:1px solid var(--border-standard);height:100%;display:flex;flex-direction:column;box-shadow:var(--shadow-dialog)}.ith-drawer__head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-subtle)}.ith-drawer__head h2{margin:0;font-size:.875rem;font-weight:590;color:var(--text-secondary)}.ith-drawer__body{flex:1;overflow-y:auto;padding:16px 18px}.ith-drawer__footer{border-top:1px solid var(--border-subtle);padding:10px 14px;background:var(--bg-surface)}.ith-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:16px}@media(max-width:800px){.ith-stats{grid-template-columns:repeat(2,1fr)}}.ith-stat{background:var(--bg-card);border:1px solid var(--border-standard);border-radius:var(--r-card);padding:12px 14px}.ith-stat__label{font-size:.625rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);font-weight:590}.ith-stat__value{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-top:4px}.ith-stat__value--amber{color:#fbbf24}.ith-stat__value--emerald{color:#34d399}.ith-stat__value--red{color:#f87171}.ith-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}@media(max-width:700px){.ith-metrics{grid-template-columns:1fr}}.ith-metric{background:var(--bg-card);border:1px solid var(--border-standard);border-radius:var(--r-card);padding:16px}.ith-metric__title{font-size:.875rem;color:var(--text-tertiary)}.ith-metric__value{font-size:1.875rem;font-weight:600;margin:6px 0 4px;color:var(--text-primary)}.ith-metric__hint{font-size:.75rem;color:var(--text-tertiary)}.ith-chart-wrap{height:240px;margin-top:8px}.ith-admin-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-top:1px solid var(--border-subtle)}.ith-admin-row:first-child{border-top:0}.ith-admin-row__label{width:160px;font-size:.875rem;font-weight:500;color:var(--text-primary)}.ith-admin-row__hint{font-size:.6875rem;color:var(--text-tertiary)}.ith-asset-table{width:100%;border-collapse:collapse;font-size:.8125rem;text-align:left}.ith-asset-table thead{background:var(--bg-surface);color:var(--text-tertiary);font-size:.6875rem;text-transform:uppercase;letter-spacing:.04em}.ith-asset-table th{padding:10px 14px;font-weight:590}.ith-asset-table td{padding:8px 14px;border-top:1px solid var(--border-subtle)}.ith-asset-table .mono{font-family:ui-monospace,monospace;font-size:.75rem;color:var(--text-secondary)}.ith-asset-table tr.is-selected{background:#f9731614}.ith-back-link{display:inline-block;font-size:.75rem;color:var(--text-tertiary);text-decoration:none;margin-bottom:6px}.ith-back-link:hover{color:var(--text-secondary)}
