@keyframes landing-fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes landing-glow-pulse{0%,to{opacity:.6;transform:translate(-50%) scale(1)}50%{opacity:1;transform:translate(-50%) scale(1.05)}}@keyframes landing-dots-float{0%,to{transform:translate(0);opacity:.15}50%{transform:translate(4px,-6px);opacity:.25}}@keyframes landing-scroll-hint-bounce{0%,to{transform:translateY(0);opacity:.7}50%{transform:translateY(6px);opacity:1}}.landing-page{min-height:100vh;background:var(--landing-bg, #f8fafc)}body.landing-visible{overflow:auto}.landing-scroll-progress{position:fixed;top:0;left:0;width:100%;height:3px;background:var(--accent-teal-lt, #14b8a6);z-index:9999;transform-origin:left;transition:transform .08s ease-out}.landing-hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px 60px;background:var(--hero-bg, #0f172a);color:var(--hero-text, #f1f5f9);overflow:hidden}.landing-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.landing-hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(148,163,184,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.05) 1px,transparent 1px);background-size:48px 48px}.landing-hero-glow{position:absolute;bottom:-20%;left:50%;width:80%;max-width:600px;height:320px;background:radial-gradient(ellipse,rgba(14,165,233,.15) 0%,transparent 65%);pointer-events:none;animation:landing-glow-pulse 8s ease-in-out infinite}.landing-hero-dots{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 30%,rgba(148,163,184,.12) 0%,transparent 1px),radial-gradient(circle at 80% 70%,rgba(148,163,184,.1) 0%,transparent 1px),radial-gradient(circle at 40% 80%,rgba(148,163,184,.08) 0%,transparent 1px);background-size:120px 120px,160px 160px,100px 100px;animation:landing-dots-float 12s ease-in-out infinite;pointer-events:none}.landing-hero-band{position:absolute;top:-50%;right:-50%;bottom:-50%;left:-50%;width:200%;background:linear-gradient(105deg,transparent 0%,transparent 38%,rgba(14,165,233,.06) 50%,transparent 62%,transparent 100%);background-size:60% 100%;animation:landing-hero-band-move 18s linear infinite;pointer-events:none}@keyframes landing-hero-band-move{0%{transform:translate(-30%)}to{transform:translate(10%)}}.landing-hero-brand{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:10px 14px;padding:18px 24px;font-size:.9rem;font-weight:600;color:#ffffffe6;letter-spacing:.04em;z-index:2}.landing-hero-brand-icon{color:var(--accent-teal-lt, #14b8a6)}.landing-hero-brand-divider{color:#ffffff59;font-weight:400;-webkit-user-select:none;user-select:none}.landing-hero-brand-tag{font-size:.8rem;font-weight:500;color:#ffffffd9;padding:4px 10px;background:#ffffff1a;border-radius:6px;border:1px solid rgba(255,255,255,.15)}.landing-hero-brand-30{font-size:.8rem;color:var(--accent-teal-lt, #14b8a6);padding:4px 10px;background:#14b8a626;border-radius:6px;font-family:var(--font-mono)}.landing-hero-inner{position:relative;max-width:720px;text-align:center;z-index:1}.landing-hero-anim{opacity:0;animation:landing-fade-in-up .7s ease-out forwards}.landing-hero-anim-2{animation-delay:.15s}.landing-hero-anim-3{animation-delay:.3s}.landing-hero-anim-4{animation-delay:.45s}.landing-hero-title{font-family:var(--landing-font-display, "Noto Serif SC", serif);font-size:clamp(2rem,5vw,3rem);font-weight:600;letter-spacing:.02em;line-height:1.25;margin-bottom:16px;color:#fff}.landing-hero-title-highlight{color:var(--accent-teal-lt, #14b8a6);text-shadow:0 0 20px rgba(20,184,166,.4)}.landing-hero-subtitle{font-size:.95rem;color:#e2e8f0d9;margin-bottom:20px;font-weight:500}.landing-hero-desc{font-size:1rem;line-height:1.65;color:#cbd5e1e6;margin-bottom:36px;max-width:520px;margin-left:auto;margin-right:auto}.landing-hero-cta{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;font-size:1rem;font-weight:600;color:#0f172a;background:#f1f5f9;border:none;border-radius:10px;cursor:pointer;transition:background .2s ease,transform .15s ease,box-shadow .25s ease;font-family:inherit}.landing-hero-cta:hover{background:#e2e8f0;transform:translateY(-2px);box-shadow:0 12px 28px #0ea5e940}.landing-hero-cta:active{transform:translateY(0)}.landing-hero-scroll-hint{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;color:#ffffffbf;font-size:.8rem;font-weight:500;z-index:2;animation:landing-scroll-hint-bounce 2s ease-in-out infinite}.landing-hero-scroll-hint span{letter-spacing:.04em}.landing-section-divider{display:flex;align-items:center;justify-content:center;gap:16px;padding:48px 24px;background:var(--landing-bg, #f8fafc)}.landing-section-divider-line{flex:1;max-width:120px;height:1px;background:linear-gradient(90deg,transparent,var(--border, #dde1e8));transform:scaleX(0);transform-origin:center;transition:transform .5s ease}.landing-section-divider-line-right{background:linear-gradient(90deg,var(--border, #dde1e8),transparent)}.landing-section-divider-visible .landing-section-divider-line-left,.landing-section-divider-visible .landing-section-divider-line-right{transform:scaleX(1)}.landing-section-divider-icon{display:flex;align-items:center;justify-content:center;color:var(--accent-teal-lt, #14b8a6);opacity:0;transition:opacity .4s ease .2s}.landing-section-divider-visible .landing-section-divider-icon{opacity:1}.landing-trust{padding:72px 24px 80px;background:linear-gradient(180deg,#0f172a,#1e293b,#0f172a);color:#f1f5f9}.landing-trust .landing-trust-header,.landing-trust .landing-trust-grid .landing-trust-card,.landing-trust .landing-trust-footer{opacity:0;transform:translateY(20px) scale(.96);transition:opacity .5s ease,transform .5s ease}.landing-trust-visible .landing-trust-header{opacity:1;transform:translateY(0) scale(1);transition-delay:.05s}.landing-trust-visible .landing-trust-card{opacity:1;transform:translateY(0) scale(1);transition-delay:calc(.15s + var(--stagger, 0) * .1s)}.landing-trust-visible .landing-trust-footer{opacity:1;transform:translateY(0);transition-delay:.45s}.landing-trust-inner{max-width:1000px;margin:0 auto;text-align:center}.landing-trust-badge{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.12em;color:var(--accent-teal-lt, #14b8a6);margin-bottom:12px;text-transform:uppercase}.landing-trust-title{font-family:var(--landing-font-display, "Noto Serif SC", serif);font-size:1.6rem;font-weight:600;color:#fff;margin-bottom:14px;letter-spacing:.02em}.landing-trust-lead{font-size:.95rem;line-height:1.7;color:#cbd5e1e6;max-width:640px;margin:0 auto 44px}.landing-trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:40px}.landing-trust-card{position:relative;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:28px 24px;text-align:left;transition:background .2s ease,border-color .2s ease,transform .2s ease;overflow:hidden}.landing-trust-card:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--accent-teal-lt, #14b8a6);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.landing-trust-card:hover,.landing-trust-visible .landing-trust-card:hover{background:#ffffff0f;border-color:#14b8a640;transform:translateY(-2px)}.landing-trust-card:hover:after{transform:scaleX(1)}.landing-trust-card-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:#14b8a626;color:var(--accent-teal-lt, #14b8a6);border-radius:12px;margin-bottom:16px;transition:transform .2s ease}.landing-trust-card:hover .landing-trust-card-icon{transform:scale(1.05)}.landing-trust-card-title{font-size:1.05rem;font-weight:600;color:#fff;margin-bottom:8px}.landing-trust-card-desc{font-size:.9rem;line-height:1.6;color:#cbd5e1d9;margin:0}.landing-trust-footer{padding-top:28px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:baseline;justify-content:center;gap:8px;flex-wrap:wrap}.landing-trust-30{font-family:var(--font-mono);font-size:2.5rem;font-weight:700;color:var(--accent-teal-lt, #14b8a6);line-height:1;letter-spacing:.02em;text-shadow:0 0 24px rgba(20,184,166,.35)}.landing-trust-30-label{font-size:1rem;font-weight:600;color:#ffffffd9}.landing-features .landing-features-title,.landing-features .landing-features-lead,.landing-features .landing-feature-card{opacity:0;transform:translateY(24px) scale(.98);transition:opacity .5s ease,transform .5s ease,box-shadow .2s ease,border-color .2s ease}.landing-features-visible .landing-features-title{opacity:1;transform:translateY(0) scale(1);transition-delay:.05s}.landing-features-visible .landing-features-lead{opacity:1;transform:translateY(0) scale(1);transition-delay:.15s}.landing-features-visible .landing-feature-card{opacity:1;transform:translateY(0) scale(1);transition-delay:calc(.2s + var(--stagger, 0) * .06s)}.landing-features{padding:100px 24px 80px;background:var(--landing-bg, #f8fafc)}.landing-features-inner{max-width:1100px;margin:0 auto}.landing-features-title{font-family:var(--landing-font-display, "Noto Serif SC", serif);font-size:1.75rem;font-weight:600;color:var(--text-primary, #111827);text-align:center;margin-bottom:12px}.landing-features-lead{font-size:1rem;color:var(--text-secondary, #4b5563);text-align:center;max-width:560px;margin:0 auto 48px;line-height:1.6}.landing-features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.landing-feature-card{position:relative;background:#fff;border:1px solid var(--border-light, #eaecef);border-radius:12px;padding:28px 24px;overflow:hidden}.landing-feature-card:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--accent-teal-lt, #14b8a6);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.landing-feature-card:hover,.landing-features-visible .landing-feature-card:hover{box-shadow:0 12px 32px #00000014;border-color:var(--accent-blue-bg, #eff6ff);transform:translateY(-2px)}.landing-feature-card:hover:after,.landing-features-visible .landing-feature-card:hover:after{transform:scaleX(1)}.landing-feature-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--accent-blue-bg, #eff6ff);color:var(--accent-blue, #1d4ed8);border-radius:10px;margin-bottom:16px;transition:transform .2s ease}.landing-feature-card:hover .landing-feature-icon,.landing-features-visible .landing-feature-card:hover .landing-feature-icon{transform:translateY(-2px) scale(1.05)}.landing-feature-title{font-size:1.05rem;font-weight:600;color:var(--text-primary, #111827);margin-bottom:8px}.landing-feature-desc{font-size:.9rem;color:var(--text-secondary, #4b5563);line-height:1.55;margin:0}.landing-proof .landing-proof-inner{opacity:0;transform:translateY(20px);transition:opacity .5s ease .1s,transform .5s ease .1s}.landing-proof-visible .landing-proof-inner{opacity:1;transform:translateY(0)}.landing-proof{padding:56px 24px;background:linear-gradient(180deg,#fff,#f8fafc);border-top:1px solid var(--border-light, #eaecef)}.landing-proof-inner{max-width:900px;margin:0 auto;text-align:center}.landing-proof-headline{font-size:.85rem;font-weight:600;color:var(--text-muted, #9ca3af);text-transform:uppercase;letter-spacing:.08em;margin-bottom:20px}.landing-proof-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:32px 48px}.landing-proof-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease,background .2s ease;transition-delay:calc(.1s + var(--stagger, 0) * .08s)}.landing-proof-visible .landing-proof-item{opacity:1;transform:translateY(0)}.landing-proof-item:hover{background:var(--accent-teal-bg, #f0fdfa)}.landing-proof-item:hover .landing-proof-icon{transform:scale(1.1);color:var(--accent-teal-lt, #14b8a6)}.landing-proof-icon{color:var(--accent-teal, #0f766e);flex-shrink:0;transition:transform .2s ease,color .2s ease}.landing-proof-label{font-size:.9rem;color:var(--text-secondary, #4b5563)}.landing-proof-value{font-size:.9rem;font-weight:600;color:var(--text-primary, #111827);font-family:var(--font-mono)}.landing-footer{padding:32px 24px 40px;background:var(--text-primary, #111827);color:#ffffffbf}.landing-footer-inner{max-width:900px;margin:0 auto;text-align:center}.landing-footer-brand{display:inline-flex;align-items:center;gap:10px;margin-bottom:16px}.landing-footer-logo{display:flex;align-items:center;justify-content:center;color:var(--accent-teal-lt, #14b8a6)}.landing-footer-brand span{font-size:.9rem;font-weight:600;color:#ffffffe6}.landing-footer-nav{display:flex;justify-content:center;gap:24px;margin-bottom:16px}.landing-footer-nav a{font-size:.9rem;color:#fffc;text-decoration:none;transition:color .15s ease}.landing-footer-nav a:hover{color:#fff}.landing-footer-copy{font-size:.8rem;color:#ffffff80;margin:0}@keyframes login-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes login-bg-float{0%,to{transform:translate(0);opacity:.55}50%{transform:translate(6px,-10px);opacity:.9}}.login-page img{max-width:100%;height:auto}.login-page *{box-sizing:border-box}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:0;background:radial-gradient(1200px 600px at 50% 15%,rgba(20,184,166,.22),transparent 60%),linear-gradient(145deg,#070c16,#0f172a 55%,#070c16)}.login-shell{width:100%;height:100vh;display:grid;grid-template-columns:1.2fr .8fr;gap:0}@media (max-width: 860px){.login-shell{grid-template-columns:1fr}.login-poster{display:none}}.login-poster{position:relative;border-radius:0;overflow:hidden;border-right:1px solid rgba(255,255,255,.08);background:#ffffff05;min-height:100vh}.login-poster-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.login-poster-unit{position:absolute;right:26px;bottom:22px;width:min(360px,46%);opacity:.22;filter:drop-shadow(0 20px 40px rgba(14,165,233,.12));transform:translateY(0);animation:login-unit-float 9s ease-in-out infinite;pointer-events:none}.login-poster-unit:before{content:"";position:absolute;left:50%;top:58%;transform:translate(-50%,-50%);width:120%;height:78%;border-radius:999px;background:radial-gradient(ellipse at center,rgba(20,184,166,.38) 0%,rgba(14,165,233,.18) 40%,transparent 70%);filter:blur(14px);opacity:.9;z-index:0}@keyframes login-unit-float{0%,to{transform:translateY(0);opacity:.2}50%{transform:translateY(-10px);opacity:.26}}.login-poster-unit img{width:100%;height:auto;display:block;position:relative;z-index:1}.login-poster-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(148,163,184,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.06) 1px,transparent 1px);background-size:56px 56px;opacity:.55}.login-poster-glow{position:absolute;top:-30%;right:-30%;bottom:-30%;left:-30%;background:radial-gradient(ellipse at 30% 30%,rgba(14,165,233,.22),transparent 55%),radial-gradient(ellipse at 70% 70%,rgba(20,184,166,.18),transparent 55%);animation:login-bg-float 10s ease-in-out infinite}.login-poster-band{position:absolute;top:-60%;right:-60%;bottom:-60%;left:-60%;width:220%;background:linear-gradient(110deg,transparent 0%,transparent 40%,rgba(14,165,233,.07) 50%,transparent 60%,transparent 100%);background-size:60% 100%;animation:login-poster-band-move 18s linear infinite}@keyframes login-poster-band-move{0%{transform:translate(-30%)}to{transform:translate(12%)}}.login-poster-inner{position:relative;padding:42px 42px 32px;color:#ffffffeb;animation:login-fade-in .55s ease-out both;display:flex;flex-direction:column;height:100%}.login-poster-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px}.login-poster-logo{width:360px;max-width:100%;height:auto;display:block;opacity:1}.login-poster-badges{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.login-badge{font-size:12px;font-weight:600;color:#e2e8f0db;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);padding:8px 10px;border-radius:999px;white-space:nowrap}.login-badge-strong{color:#ffffffeb;border-color:#14b8a63d;background:#14b8a61a}.login-poster-title{font-family:var(--landing-font-display, "Noto Serif SC", serif);font-size:40px;font-weight:600;margin:8px 0 10px;color:#fff;letter-spacing:.02em;line-height:1.12}.login-poster-title-highlight{color:var(--accent-teal-lt, #14b8a6);text-shadow:0 0 20px rgba(20,184,166,.42)}.login-poster-subtitle{margin:0 0 18px;font-size:14px;line-height:1.7;color:#cbd5e1db;max-width:460px}.login-poster-metrics{margin-top:10px;display:grid;gap:12px}.login-metric{display:grid;gap:4px;padding:12px 14px;border-radius:14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.login-metric .k{font-size:12px;font-weight:700;letter-spacing:.08em;color:#e2e8f0c7;text-transform:uppercase}.login-metric .v{font-size:13px;font-weight:600;color:#ffffffe6}.login-poster-footer{margin-top:auto;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}.login-poster-note{font-size:12px;color:#cbd5e1b8;letter-spacing:.04em}.login-card{width:100%;border-radius:0;border:none;background:#ffffff0a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:0;color:#ffffffe6;animation:login-fade-in .55s ease-out both;display:flex;align-items:center;justify-content:center;min-height:100vh}.login-card-inner{width:min(420px,92%);padding:26px 22px;border-radius:18px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a}} .login-card-header{margin-bottom:16px}.login-card-title{font-size:16px;font-weight:800;color:#fff;letter-spacing:.02em}.login-card-desc{margin-top:6px;font-size:12px;color:#e2e8f0b8;line-height:1.6}.login-brand{display:none}.login-mark{width:12px;height:12px;border-radius:4px;background:#14b8a6;box-shadow:0 0 18px #14b8a699}.login-brand-text strong{display:block;font-size:18px;letter-spacing:.02em;color:#fff}.login-brand-text span{display:block;font-size:12px;color:#e2e8f0b8;margin-top:4px;line-height:1.5}.login-form{display:grid;gap:12px}.login-field{display:grid;gap:6px}.login-field span{font-size:12px;font-weight:600;color:#e2e8f0cc;letter-spacing:.02em}.login-field input{width:100%;padding:11px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#0f172a8c;color:#ffffffeb;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.login-field input:focus{border-color:#14b8a699;box-shadow:0 0 0 3px #14b8a62e}.login-error{padding:10px 12px;border-radius:10px;background:#b91c1c24;border:1px solid rgba(239,68,68,.28);color:#fee2e2f2;font-size:12px}.login-submit{margin-top:4px;width:100%;padding:11px 12px;border:none;border-radius:10px;background:#f1f5f9;color:#0f172a;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:transform .15s ease,box-shadow .2s ease,background .2s ease}.login-submit:hover{transform:translateY(-1px);box-shadow:0 10px 24px #0ea5e92e;background:#e2e8f0}.login-password{position:relative;display:flex;align-items:center}.login-password input{padding-right:42px}.login-pwd-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#e2e8f0d9;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,transform .15s ease}.login-pwd-toggle:hover{background:#ffffff1a;transform:translateY(-50%) scale(1.03)}.login-hint{margin-top:14px;font-size:12px;color:#e2e8f0b3}.login-hint code{font-family:var(--font-mono);color:#ffffffeb;background:#ffffff14;padding:2px 6px;border-radius:6px}.login-options{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:2px}.login-remember{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:#e2e8f0c7;-webkit-user-select:none;user-select:none}.login-remember input{width:14px;height:14px;accent-color:#14b8a6}.login-default{font-size:12px;color:#e2e8f0b3}.login-default code{font-family:var(--font-mono);color:#ffffffeb;background:#ffffff14;padding:2px 6px;border-radius:6px;margin:0 2px}:root{--bg-base: #F0F2F6;--bg-card: #FFFFFF;--bg-card-hover: #FAFBFC;--bg-sidebar: #F8F9FB;--bg-sidebar-item-active: #1D4ED8;--bg-sidebar-item-hover: rgba(29, 78, 216, .06);--bg-header: rgba(255, 255, 255, .95);--border: #DDE1E8;--border-light: #EAECF0;--border-sidebar: #E5E7EB;--text-primary: #111827;--text-secondary: #4B5563;--text-muted: #9CA3AF;--text-sidebar: #374151;--text-mono: #374151;--accent-blue: #1D4ED8;--accent-blue-lt: #3B82F6;--accent-blue-bg: #EFF6FF;--accent-teal: #0F766E;--accent-teal-lt: #14B8A6;--accent-teal-bg: #F0FDFA;--accent-orange: #C2410C;--accent-orange-lt: #F97316;--accent-orange-bg: #FFF7ED;--accent-green: #15803D;--accent-green-lt: #22C55E;--accent-green-bg: #F0FDF4;--accent-amber: #B45309;--accent-amber-lt: #F59E0B;--running-dot: #22C55E;--standby-dot: #F59E0B;--stop-dot: #6B7280;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08), 0 2px 4px rgba(0, 0, 0, .04);--shadow-card: 0 1px 4px rgba(0, 0, 0, .06);--transition: all .18s cubic-bezier(.4, 0, .2, 1);--landing-font-display: "Noto Serif SC", serif;--hero-bg: #0f172a;--hero-text: #f1f5f9;--landing-bg: #f8fafc}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-sans);background:linear-gradient(145deg,#eaf0fb,#eff1f5 40%,#edf0f5);color:var(--text-primary);line-height:1.5;overflow:hidden}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:220px;background:var(--bg-sidebar);display:flex;flex-direction:column;flex-shrink:0;border-right:1px solid var(--border-sidebar);transition:width .25s ease;z-index:100;position:relative}.sidebar.collapsed{width:64px}.sidebar-collapse-btn{position:absolute;top:50%;right:-13px;transform:translateY(-50%);width:26px;height:26px;border-radius:50%;background:#fff;border:1.5px solid var(--border);box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:200;transition:var(--transition);color:var(--text-muted)}.sidebar-collapse-btn:hover{background:var(--accent-blue-bg);border-color:var(--accent-blue-lt);color:var(--accent-blue-lt);box-shadow:0 2px 12px #1d4ed82e}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 14px;height:54px;border-bottom:1px solid var(--border-sidebar);overflow:hidden}.sidebar-logo-mark{width:32px;height:32px;background:linear-gradient(135deg,#1d4ed8,#1e40af);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 6px #1d4ed840}.sidebar-logo-text{overflow:hidden;white-space:nowrap}.sidebar-logo-text strong{display:block;font-size:13px;font-weight:700;color:var(--text-primary);letter-spacing:.02em}.sidebar-logo-text span{font-size:10px;font-weight:500;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase}.sidebar-section-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:16px 14px 6px;white-space:nowrap;overflow:hidden}.sidebar-nav{flex:1;padding:6px 8px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{display:none}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);font-size:12.5px;font-weight:500;white-space:nowrap;overflow:hidden;transition:var(--transition);margin-bottom:2px;text-align:left;border:none;background:none;width:100%}.nav-item:hover{background:var(--bg-sidebar-item-hover);color:var(--accent-blue)}.nav-item.active{background:var(--bg-sidebar-item-active);color:#fff;font-weight:600;box-shadow:0 2px 8px #1d4ed838}.nav-item.coming-soon{opacity:.55}.nav-item.coming-soon:hover{background:var(--bg-sidebar-item-hover);color:var(--text-secondary)}.nav-icon{flex-shrink:0;display:flex;align-items:center;color:var(--text-muted)}.nav-item.active .nav-icon{color:#fff}.nav-item:hover .nav-icon{color:var(--accent-blue)}.nav-badge{margin-left:auto;font-size:9px;font-weight:700;padding:1px 5px;border-radius:4px;background:#eff6ff;color:#93c5fd;text-transform:uppercase;letter-spacing:.05em}.sidebar-footer{padding:8px;border-top:1px solid var(--border-sidebar)}.sidebar-user{display:flex;align-items:center;gap:8px;padding:8px 6px;border-radius:var(--radius-sm);overflow:hidden}.sidebar-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#1d4ed8,#0f766e);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-info{overflow:hidden}.sidebar-user-info p{font-size:11.5px;font-weight:600;color:var(--text-primary);white-space:nowrap}.sidebar-user-info span{font-size:10px;color:var(--text-muted)}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.main-area:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(29,78,216,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(29,78,216,.035) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;z-index:0}.header{height:54px;background:var(--bg-header);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0;position:relative;z-index:10}.header-station{display:flex;align-items:center;gap:8px;flex:1}.header-station h1{font-size:13.5px;font-weight:700;color:var(--text-primary)}.status-badge{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700}.status-badge.running{background:var(--accent-green-bg);color:var(--accent-green);border:1px solid #BBF7D0}.status-badge.running:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent-green-lt);animation:pulse-dot 2s infinite}.header-divider{width:1px;height:20px;background:var(--border)}.header-meta{display:flex;align-items:center;gap:20px}.header-home-link{font-size:12px;font-weight:600;color:var(--text-secondary);text-decoration:none;transition:color .15s ease}.header-home-link:hover{color:var(--accent-blue)}.header-logout-btn{border:1px solid var(--border-light);background:var(--bg-card);color:var(--text-secondary);padding:6px 10px;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease}.header-logout-btn:hover{transform:translateY(-1px);border-color:#14b8a673;background:#14b8a60f}.header-meta-item{text-align:right}.header-meta-item .label{display:block;font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.header-meta-item .value{display:block;font-size:11.5px;font-weight:700;color:var(--text-primary);font-family:var(--font-mono)}.header-meta-item .value.blue{color:var(--accent-blue-lt)}.header-meta-item .value.green{color:var(--accent-green)}.content-area{flex:1;overflow-y:auto;padding:14px 16px;position:relative;z-index:1;display:flex;flex-direction:column;gap:12px}.content-area>*{flex-shrink:0}.content-area::-webkit-scrollbar{width:4px}.content-area::-webkit-scrollbar-track{background:transparent}.content-area::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.section-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.section-title .dot{width:3px;height:14px;background:var(--accent-blue-lt);border-radius:2px}.section-tag{font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;background:var(--accent-blue-bg);color:var(--accent-blue);text-transform:uppercase;letter-spacing:.06em}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-sm);border-color:#c7cdd8}.card-body{padding:14px 16px}.kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.kpi-card{padding:13px 15px}.kpi-card.highlight{border-color:#bfdbfe;background:linear-gradient(135deg,#eff6ff,#fff 60%)}.kpi-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}.kpi-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);line-height:1.3}.kpi-icon{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-icon.blue{background:var(--accent-blue-bg);color:var(--accent-blue-lt)}.kpi-icon.teal{background:var(--accent-teal-bg);color:var(--accent-teal-lt)}.kpi-icon.orange{background:var(--accent-orange-bg);color:var(--accent-orange-lt)}.kpi-icon.green{background:var(--accent-green-bg);color:var(--accent-green-lt)}.kpi-icon.red{background:#fef2f2;color:#b91c1c}.kpi-value{font-size:26px;font-weight:300;font-family:var(--font-mono);color:var(--text-primary);line-height:1;letter-spacing:-.02em}.kpi-value.blue{color:var(--accent-blue-lt);font-weight:400}.kpi-value.red{color:#b91c1c;font-weight:400}.kpi-value.amber{color:#b45309;font-weight:400}.kpi-unit{font-size:10px;font-weight:600;color:var(--text-muted);margin-left:2px;font-family:var(--font-sans)}.kpi-sub{margin-top:8px;padding-top:8px;border-top:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.kpi-sub-label{font-size:9px;color:var(--text-muted)}.pf-status-tag{display:inline-block;padding:1px 6px;border-radius:3px;font-size:9px;font-weight:600;line-height:1.6;flex-shrink:0}.pf-status-tag.ok{background:#ecfdf5;color:#047857}.pf-status-tag.warn{background:#fffbeb;color:#b45309}.pf-status-tag.alert{background:#fef2f2;color:#b91c1c}.kpi-card.pf-alert{border-color:#fca5a5;box-shadow:0 0 0 1px #b91c1c1f,0 2px 8px #b91c1c14}.kpi-card.pf-warn{border-color:#fcd34d;box-shadow:0 0 0 1px #b453091f,0 2px 8px #b4530914}.kpi-sub-value{font-size:10.5px;font-weight:700;font-family:var(--font-mono);color:var(--text-secondary)}.env-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.env-card{padding:10px 12px}.env-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.env-label{font-size:10px;font-weight:700;color:var(--text-secondary)}.env-limit{font-size:9px;color:var(--text-muted)}.env-main{display:flex;align-items:baseline;gap:4px;margin-bottom:4px}.env-value{font-family:var(--font-mono);font-size:18px;font-weight:600}.env-unit{font-size:10px;color:var(--text-muted)}.env-status-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:999px;font-size:9px;font-weight:600}.env-status-ok{background:var(--accent-green-bg);color:var(--accent-green);border:1px solid #bbf7d0}.env-status-warn{background:#fffbeb;color:var(--accent-amber);border:1px solid #fde68a}.env-status-alert{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.unit-grid{display:grid;grid-template-columns:1fr;gap:10px}.unit-card{padding:13px 15px}.unit-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border-light)}.unit-id{font-size:13px;font-weight:700;font-family:var(--font-mono);color:var(--text-primary)}.unit-model{font-size:9px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:1px}.unit-status-badge{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px}.unit-status-badge.running{background:var(--accent-green-bg);color:var(--accent-green);border:1px solid #BBF7D0}.unit-status-badge.standby{background:#fffbeb;color:var(--accent-amber);border:1px solid #FDE68A}.unit-status-badge.stop{background:#f9fafb;color:#6b7280;border:1px solid var(--border)}.unit-status-dot{width:5px;height:5px;border-radius:50%}.running .unit-status-dot{background:var(--accent-green-lt);animation:pulse-dot 2s infinite}.standby .unit-status-dot{background:var(--accent-amber-lt)}.stop .unit-status-dot{background:#9ca3af}.unit-power-row{display:flex;align-items:baseline;gap:4px;margin-bottom:10px}.unit-power-val{font-size:30px;font-weight:300;font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.03em}.unit-power-unit{font-size:11px;color:var(--text-muted);font-weight:600}.unit-load-bar-wrap{margin-bottom:10px}.unit-load-label{display:flex;justify-content:space-between;font-size:9.5px;font-weight:600;color:var(--text-muted);margin-bottom:4px}.unit-load-bar{height:4px;background:var(--bg-base);border-radius:3px;overflow:hidden}.unit-load-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent-blue-lt),#60A5FA);transition:width 1s ease}.unit-params{display:grid;grid-template-columns:1fr 1fr;gap:6px}.unit-param{background:var(--bg-base);border-radius:var(--radius-sm);padding:6px 8px}.unit-param-label{font-size:9px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.unit-param-value{font-size:13px;font-weight:700;font-family:var(--font-mono);color:var(--text-primary);margin-top:1px}.unit-param-value.warn{color:var(--accent-orange-lt)}.unit-param-value.ok{color:var(--accent-teal-lt)}.cyl-panel{grid-column:1 / -1;margin-top:4px;display:flex;flex-direction:column;gap:6px}.cyl-bank{display:flex;align-items:center;gap:6px}.cyl-bank-label{width:28px;font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;text-align:right;flex-shrink:0}.cyl-bank-row{display:grid;grid-template-columns:repeat(8,1fr);gap:3px;flex:1}.cyl-cell{display:flex;flex-direction:column;align-items:center;padding:4px 2px;border-radius:var(--radius-sm);background:var(--bg-base);border:1px solid var(--border-light);transition:background .3s,border-color .3s,box-shadow .3s}.cyl-id{font-size:8px;font-weight:600;color:var(--text-muted);letter-spacing:.04em}.cyl-temp{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text-primary);line-height:1}.cyl-dev{font-family:var(--font-mono);font-size:8px;color:var(--text-muted)}.cyl-warn{background:#fbbf241a;border-color:#fbbf2459}.cyl-warn .cyl-temp{color:var(--accent-amber)}.cyl-alert{background:#ef444414;border-color:#ef44444d}.cyl-alert .cyl-temp{color:#dc2626}.cyl-hi{position:relative}.cyl-hi:after{content:"";position:absolute;top:2px;right:2px;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:5px solid #EF4444}.cyl-lo{position:relative}.cyl-lo:after{content:"";position:absolute;top:2px;right:2px;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--accent-blue-lt)}.cyl-legend{display:flex;align-items:center;gap:6px;font-size:9px;color:var(--text-muted);padding-left:34px}.cyl-legend-sep{color:var(--border)}.cyl-legend-warn{color:var(--accent-orange-lt);font-weight:600}.cyl-legend-hi{color:#ef4444;font-weight:600}.cyl-legend-lo{color:var(--accent-blue-lt);font-weight:600}.cyl-diag-warn{padding:5px 10px;margin-left:34px;border-radius:var(--radius-sm);background:#fbbf2414;border:1px solid rgba(251,191,36,.25);font-size:10px;color:var(--accent-amber);font-weight:600}.chart-row{display:grid;grid-template-columns:1fr 340px;gap:10px}.chart-card{padding:14px 16px}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.chart-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em}.chart-legend{display:flex;align-items:center;gap:12px}.legend-item{display:flex;align-items:center;gap:4px;font-size:9.5px;font-weight:600;color:var(--text-muted)}.legend-dot{width:8px;height:3px;border-radius:2px}.efficiency-card{padding:14px 16px}.efficiency-donut{display:flex;justify-content:center;position:relative;margin:10px 0 12px}.efficiency-donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.efficiency-donut-val{font-size:28px;font-weight:300;font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.02em;line-height:1}.efficiency-donut-label{font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.efficiency-list{display:flex;flex-direction:column;gap:8px}.efficiency-item-row{display:flex;align-items:center;justify-content:space-between;font-size:10.5px}.efficiency-item-row .name{color:var(--text-secondary);font-weight:500}.efficiency-item-row .val{font-family:var(--font-mono);font-weight:700;color:var(--text-primary)}.efficiency-bar{height:3px;background:var(--bg-base);border-radius:2px;overflow:hidden;margin-top:3px}.efficiency-bar-fill{height:100%;border-radius:2px}.process-card{padding:14px 20px}.process-flow{display:flex;align-items:center;padding:4px 0;position:relative}.process-flow:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:repeating-linear-gradient(90deg,var(--border) 0,var(--border) 6px,transparent 6px,transparent 12px);transform:translateY(-50%);z-index:0}.process-node{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}.process-node-icon{width:44px;height:44px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-card);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:var(--transition)}.process-node-icon.active{background:linear-gradient(135deg,#1d4ed8,#2563eb);border-color:#1d4ed8;box-shadow:0 4px 16px #1d4ed847}.process-node-info{text-align:center;margin-top:6px}.process-node-label{font-size:9.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.process-node-name{font-size:11px;font-weight:700;color:var(--text-secondary);margin-top:1px}.process-node-val{font-family:var(--font-mono);font-size:11.5px;font-weight:700;color:var(--text-primary);margin-top:2px}.process-arrow{color:var(--border);flex-shrink:0;z-index:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.modal-box{background:var(--bg-card);border-radius:var(--radius-xl);padding:28px 32px;width:420px;box-shadow:0 24px 64px #00000029;border:1px solid var(--border);animation:slideUp .2s ease}.modal-icon{width:44px;height:44px;border-radius:var(--radius-md);background:#fff7ed;border:1px solid #FDE68A;display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--accent-amber-lt)}.modal-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.modal-subtitle{font-size:12px;color:var(--text-secondary);line-height:1.6;margin-bottom:20px}.modal-feature-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.modal-feature-list li{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary);padding:6px 10px;background:var(--bg-base);border-radius:var(--radius-sm)}.modal-feature-list li:before{content:"→";color:var(--accent-blue-lt);font-weight:700;flex-shrink:0}.modal-btn{width:100%;padding:10px;border-radius:var(--radius-md);border:none;cursor:pointer;font-size:13px;font-weight:600;background:var(--accent-blue-lt);color:#fff;transition:var(--transition)}.modal-btn:hover{background:var(--accent-blue)}.kpi-card.clickable{cursor:pointer;transition:var(--transition)}.kpi-card.clickable:hover{border-color:var(--accent-blue-lt);box-shadow:0 2px 12px #3b82f61a}.kpi-card.clickable:active{transform:scale(.985)}.kpi-modal-box{background:var(--bg-card);border-radius:var(--radius-xl);padding:20px 24px 16px;width:620px;max-width:92vw;box-shadow:0 24px 64px #0000002e;border:1px solid var(--border);animation:slideUp .2s ease}.kpi-modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}.kpi-modal-title{font-size:15px;font-weight:700;color:var(--text-primary)}.kpi-modal-date{font-size:10px;color:var(--text-muted);margin-top:2px;font-family:var(--font-mono)}.kpi-modal-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-base);color:var(--text-muted);cursor:pointer;transition:var(--transition);flex-shrink:0}.kpi-modal-close:hover{background:var(--bg-card);color:var(--text-primary);border-color:var(--border)}.kpi-modal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:4px;padding-top:12px;border-top:1px solid var(--border-light)}.kpi-modal-stat-item{display:flex;flex-direction:column;align-items:center;gap:2px}.kpi-modal-stat-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.kpi-modal-stat-value{font-size:16px;font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.kpi-modal-stat-unit{font-size:10px;font-weight:500;color:var(--text-muted);font-family:var(--font-sans)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes ticker{0%{transform:translate(100%)}to{transform:translate(-100%)}}.data-table{width:100%;border-collapse:collapse;font-size:11px}.data-table th{text-align:left;padding:9px 12px;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--bg-base);border-bottom:1px solid var(--border-light);white-space:nowrap;position:sticky;top:0;z-index:1}.data-table td{padding:8px 12px;border-bottom:1px solid var(--border-light);color:var(--text-secondary);white-space:nowrap}.data-table tbody tr:hover{background:var(--bg-card-hover)}.data-table td.mono{font-family:var(--font-mono);color:var(--text-primary);font-weight:600}.table-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:10px;color:var(--text-muted);font-weight:600;border-top:1px solid var(--border-light)}.filter-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:6px}.filter-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;border:1px solid var(--border);background:var(--bg-card);font-size:10.5px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.filter-chip:hover{border-color:var(--accent-blue-lt);color:var(--accent-blue-lt)}.filter-chip.active{background:var(--accent-blue-lt);color:#fff;border-color:var(--accent-blue-lt)}.filter-chip:disabled{opacity:.4;cursor:not-allowed}.page-action-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);font-size:11px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.page-action-btn:hover{background:var(--accent-blue-bg);border-color:var(--accent-blue-lt);color:var(--accent-blue-lt)}.asset-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.report-page-nav{display:flex;align-items:center;gap:4px;margin-bottom:10px}.report-tab{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font-size:10.5px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.report-tab:hover{border-color:var(--accent-blue-lt);color:var(--accent-blue-lt)}.report-tab.active{background:var(--accent-blue-lt);color:#fff;border-color:var(--accent-blue-lt)}.report-paper{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 2px 16px #0000000f;padding:32px 36px;min-height:580px;display:flex;flex-direction:column}.rpt-header{display:flex;justify-content:space-between;align-items:flex-start}.rpt-company{font-size:14px;font-weight:700;color:var(--text-primary)}.rpt-subtitle{font-size:11px;font-weight:600;color:var(--accent-blue-lt);margin-top:2px;text-transform:uppercase;letter-spacing:.08em}.rpt-header-right{text-align:right}.rpt-date{font-size:11px;font-family:var(--font-mono);font-weight:600;color:var(--text-primary)}.rpt-page{font-size:9px;color:var(--text-muted);margin-top:2px}.rpt-divider{height:1px;background:linear-gradient(90deg,var(--accent-blue-lt),var(--border-light));margin:12px 0}.rpt-content{flex:1}.rpt-section-title{font-size:12px;font-weight:700;color:var(--text-primary);margin-bottom:8px;padding-left:8px;border-left:3px solid var(--accent-blue-lt)}.rpt-kv-table{width:100%;border-collapse:collapse}.rpt-kv-table td{padding:7px 0;border-bottom:1px solid var(--border-light);font-size:11.5px}.rpt-kv-label{color:var(--text-muted);font-weight:600;width:180px}.rpt-kv-value{font-family:var(--font-mono);font-weight:700;color:var(--text-primary)}.rpt-data-table{width:100%;border-collapse:collapse;font-size:11px}.rpt-data-table th{text-align:left;padding:7px 10px;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--bg-base);border-bottom:1px solid var(--border)}.rpt-data-table td{padding:7px 10px;border-bottom:1px solid var(--border-light);color:var(--text-secondary)}.rpt-data-table td.mono{font-family:var(--font-mono);font-weight:600;color:var(--text-primary)}.rpt-note{font-size:10.5px;color:var(--text-secondary);line-height:1.7;background:var(--bg-base);border-radius:var(--radius-sm);padding:10px 14px}.rpt-footer{display:flex;justify-content:space-between;font-size:9px;color:var(--text-muted)}.date-range-inputs{display:inline-flex;align-items:center;gap:6px;margin-left:4px}.date-input{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:10.5px;font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-card);outline:none;transition:var(--transition)}.date-input:focus{border-color:var(--accent-blue-lt);box-shadow:0 0 0 2px #3b82f61f}.pagination{display:flex;align-items:center;gap:2px}.page-btn{min-width:26px;height:26px;padding:0 5px;border:1px solid var(--border);border-radius:4px;background:var(--bg-card);font-size:10px;font-weight:600;font-family:var(--font-mono);color:var(--text-secondary);cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center}.page-btn:hover:not(:disabled){border-color:var(--accent-blue-lt);color:var(--accent-blue-lt)}.page-btn.current{background:var(--accent-blue-lt);color:#fff;border-color:var(--accent-blue-lt)}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-ellipsis{font-size:10px;color:var(--text-muted);padding:0 2px}.asset-tabs{display:flex;gap:4px;margin-bottom:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px}.asset-tab{display:flex;align-items:center;gap:5px;padding:7px 16px;border:none;border-radius:var(--radius-sm);background:transparent;font-size:11px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.asset-tab:hover{color:var(--text-secondary);background:var(--bg-base)}.asset-tab.active{background:var(--accent-blue-lt);color:#fff;box-shadow:0 2px 6px #1d4ed833}.table-actions{display:flex;gap:4px}.table-action-btn{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:4px;border:1px solid var(--border);background:var(--bg-card);font-size:10px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:var(--transition);font-family:var(--font-sans);white-space:nowrap}.table-action-btn:hover{border-color:var(--accent-blue-lt);color:var(--accent-blue-lt)}.table-action-btn.accent{border-color:var(--accent-blue-lt);color:var(--accent-blue-lt);background:var(--accent-blue-bg)}.table-action-btn.accent:hover{background:var(--accent-blue-lt);color:#fff}.table-action-btn.success{border-color:var(--accent-green-lt);color:var(--accent-green);background:var(--accent-green-bg)}.table-action-btn.success:hover{background:var(--accent-green-lt);color:#fff}.stock-actions{display:flex;gap:4px;padding-top:6px;border-top:1px solid var(--border-light)}.maint-status-progress{background:var(--accent-blue-bg);color:var(--accent-blue);border:1px solid #BFDBFE}.row-done{opacity:.5}.icon-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:var(--transition)}.icon-btn:hover{color:var(--text-primary);border-color:var(--text-muted)}.form-row{margin-bottom:12px}.form-label{display:block;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.form-input{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-card);outline:none;transition:var(--transition);resize:vertical}.form-input:focus{border-color:var(--accent-blue-lt);box-shadow:0 0 0 2px #3b82f61f}.form-input:disabled{background:var(--bg-base);color:var(--text-muted)}select.form-input{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.gec-dimension-tabs{display:flex;gap:4px;align-items:center}.gec-dimension-btn{padding:5px 12px;font-size:11px;font-weight:600;border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--card-bg);color:var(--text-secondary);cursor:pointer;transition:background .2s,border-color .2s,color .2s}.gec-dimension-btn:hover{background:var(--bg-base);color:var(--text-primary)}.gec-dimension-btn.active{background:var(--accent-blue-lt);border-color:var(--accent-blue-lt);color:#fff}.gec-carbon-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}.gec-carbon-card{padding:14px 16px;text-align:center}.gec-carbon-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.gec-carbon-value{font-family:var(--font-mono);font-size:28px;font-weight:700;color:var(--accent-teal-lt)}.gec-carbon-unit{font-size:11px;color:var(--text-muted);margin-top:2px}.gec-carbon-sub{font-size:9px;color:var(--text-muted);margin-top:4px}@media print{.sidebar,.header,.section-header,.filter-chip,.page-action-btn,.sidebar-collapse-btn,.report-page-nav,.date-range-inputs,.asset-tabs,.gec-dimension-tabs{display:none!important}.app-shell{display:block}.main-area{overflow:visible}.content-area{overflow:visible;padding:0}.card{box-shadow:none;border:1px solid #ddd;break-inside:avoid}body{background:#fff}.main-area:before{display:none}.report-paper{box-shadow:none;border:none;padding:20px 24px;min-height:auto;break-inside:avoid}.help-tip-wrap{display:none}}.help-tip-wrap{position:relative;display:inline-flex;align-items:center}.help-tip-btn{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;color:var(--text-muted);cursor:help;padding:0;transition:color .2s;flex-shrink:0}.help-tip-wrap:hover .help-tip-btn{color:var(--accent-blue-lt)}.help-tip-popover-fixed{position:fixed;width:270px;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:0 8px 24px #00000024,0 2px 6px #00000014;z-index:9999;animation:ht-fade-in .15s ease}@keyframes ht-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.help-tip-head{padding:8px 10px 6px;border-bottom:1px solid var(--border-light)}.help-tip-title{font-size:11px;font-weight:700;color:var(--text-primary)}.help-tip-body{padding:8px 10px 10px;font-size:10.5px;line-height:1.65;color:var(--text-secondary)}.help-tip-body strong{color:var(--text-primary);font-weight:600}.help-tip-body .ht-row{display:flex;gap:4px;margin-top:4px}.help-tip-body .ht-tag{display:inline-block;padding:1px 5px;border-radius:3px;font-size:9px;font-weight:600;line-height:1.5}.ht-tag.green{background:#ecfdf5;color:#047857}.ht-tag.amber{background:#fffbeb;color:#b45309}.ht-tag.red{background:#fef2f2;color:#b91c1c}
