@import"https://fonts.googleapis.com/css2?family=Barlow:wght@400;500;600;700&family=Rajdhani:wght@600;700&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{--background: #eaf1fb;--surface: #ffffff;--surface-soft: #f6f9ff;--foreground: #172333;--muted: #edf3fb;--muted-foreground: #5b6b84;--accent: #0091db;--accent-foreground: #ffffff;--border: #c8d4e8;--border-light: #dde6f4;--ring: #004ea2;--primary: #004ea2;--primary-hover: #003f84;--primary-foreground: #ffffff;--brand-cyan: #0091db;--brand-grey-dark: #4c4948;--brand-grey-light: #c1c6c8;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--font-display: "Rajdhani", "Barlow", "Segoe UI", "Microsoft YaHei", sans-serif;--font-body: "Barlow", "Segoe UI", "Microsoft YaHei", sans-serif;--font-mono: "IBM Plex Mono", "Cascadia Code", "Consolas", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-8: 3rem;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 10px rgba(7, 31, 71, .08);--shadow-md: 0 10px 24px rgba(7, 31, 71, .12);--shadow-lg: 0 18px 38px rgba(7, 31, 71, .16);--shadow-xl: 0 26px 60px rgba(7, 31, 71, .2);--sidebar-width: 268px;--topbar-height: 64px;--color-brand-primary: var(--primary);--color-brand-primary-hover: var(--primary-hover);--color-brand-accent: var(--brand-cyan);--color-text: var(--foreground);--color-text-strong: #0f2238;--color-text-muted: var(--muted-foreground);--color-border: var(--border);--color-border-subtle: var(--border-light);--surface-elevated: rgba(255, 255, 255, .92);--surface-glass: rgba(255, 255, 255, .78);--surface-card: linear-gradient(180deg, rgba(255, 255, 255, .96) 0%, rgba(247, 251, 255, .96) 100%);--surface-toolbar: linear-gradient(180deg, rgba(255, 255, 255, .96) 0%, rgba(244, 249, 255, .96) 100%);--surface-table-header: linear-gradient(180deg, #f7fbff 0%, #e9f2ff 100%);--surface-row-hover: #f3f8ff;--success-bg: #ecfdf3;--success-border: #86efac;--success-text: #166534;--warning-bg: #fff7ed;--warning-border: #fdba74;--warning-text: #9a3412;--error-bg: #fff1f2;--error-border: #fda4af;--error-text: #be123c;--info-bg: #eff6ff;--info-border: #bfdbfe;--info-text: #1d4ed8;--control-height-sm: 32px;--control-height-md: 40px;--control-height-lg: 48px;--control-padding-x: .9rem;--focus-ring: 0 0 0 3px rgba(0, 101, 189, .2);--transition-fast: .14s ease;--transition-base: .2s ease;--z-sticky: 20;--z-modal: 1000}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:radial-gradient(55rem 26rem at -5% -10%,rgba(0,78,162,.18) 0%,transparent 56%),radial-gradient(48rem 22rem at 100% 0%,rgba(0,145,219,.14) 0%,transparent 58%),repeating-linear-gradient(135deg,rgba(0,78,162,.03) 0px,rgba(0,78,162,.03) 1px,transparent 1px,transparent 14px),var(--background);color:var(--foreground);line-height:1.45;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100vh;overflow:hidden}#app{height:100vh;overflow:hidden}a{color:var(--accent);text-decoration:none;transition:color .2s ease,opacity .2s ease}a:hover{opacity:.7}button{font-family:var(--font-body);cursor:pointer}input,textarea,select{font-family:var(--font-body)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--foreground);letter-spacing:.01em}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl);font-weight:600}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-6)}*::selection{background:#0091db38;color:#0f172a}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#e7eef8;border-radius:999px}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#95afd2,#7b9ec8);border-radius:999px;border:2px solid #e7eef8}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#7f9fc9,#678bb8)}.loading{display:flex;align-items:center;justify-content:center;padding:var(--space-8);font-family:var(--font-body);font-size:var(--text-base);color:var(--muted-foreground)}.empty-state{text-align:center;padding:var(--space-8) var(--space-6);border:1px solid var(--border-light);border-radius:var(--radius-md)}.empty-state-title{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-2);font-weight:600}.empty-state-text{font-family:var(--font-body);font-size:var(--text-base);color:var(--muted-foreground)}.version-badge{display:inline-block;font-family:var(--font-mono);font-size:var(--text-xs);padding:var(--space-1) var(--space-3);background:linear-gradient(180deg,#f5f9ff,#e8f1ff);color:#154072;border-radius:var(--radius-sm);border:1px solid #c2d5ee}.section-divider{height:1px;background:var(--border-light);margin:var(--space-6) 0}@media (max-width: 1024px){html{font-size:15px}}@media (max-width: 768px){html{font-size:14px}}.btn{font-family:var(--font-body);font-size:var(--text-sm);font-weight:700;padding:.5rem .88rem;border:1px solid var(--border);background:linear-gradient(180deg,#fff,#eef4ff);color:var(--foreground);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);box-shadow:0 1px #ffffffbf inset,0 3px 10px #0d295414;text-transform:uppercase;letter-spacing:.03em}.btn:hover{border-color:#92add2;transform:translateY(-1px);box-shadow:0 8px 18px #0d295424}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,#004ea2,#006fc1 42%,#0091db);color:var(--primary-foreground);border-color:#0a5eb5}.btn-primary:hover{background:linear-gradient(135deg,#003f84,#005ea7 42%,#007fc2)}.btn-secondary{background:linear-gradient(135deg,#29466d,#3b618f);border-color:#3b618f;color:#fff}.btn-secondary:hover{filter:brightness(1.04)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;color:var(--foreground);margin-bottom:var(--space-2)}.form-input{width:100%;padding:.58rem .72rem;font-family:var(--font-body);font-size:var(--text-sm);border:1px solid #b9cbe4;background:linear-gradient(180deg,#fff,#f5f9ff);color:var(--foreground);border-radius:var(--radius-sm);transition:all .2s ease}.form-input:focus{outline:none;border-color:#0b67c2;box-shadow:0 0 0 3px #0065bd33}.form-input::placeholder{color:var(--muted-foreground)}.card{background:var(--surface);border:1px solid #d4e0f2;padding:var(--space-5);border-radius:var(--radius-md);box-shadow:0 8px 20px #09274e14;transition:all .2s ease;position:relative;overflow:hidden}.card:hover{box-shadow:0 16px 30px #09274e21;border-color:#afc4e2}.card:before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:2px;background:linear-gradient(90deg,#004ea2,#0091db)}.card-label{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;color:var(--muted-foreground);margin-bottom:var(--space-2)}.card-value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:700;line-height:1;color:var(--foreground)}.card-unit{font-family:var(--font-body);font-size:var(--text-sm);color:var(--muted-foreground);margin-top:var(--space-2)}.grid{display:grid;gap:var(--space-5)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.table-wrapper{border:1px solid #cdd9eb;border-radius:var(--radius-md);overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 280px);background:var(--surface);box-shadow:0 8px 18px #08224814}.table-wrapper thead th{position:sticky;top:0;z-index:3;background:linear-gradient(180deg,#f4f8ff,#e9f1fe)}table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}th{font-family:var(--font-body);font-size:var(--text-xs);letter-spacing:.04em;text-transform:uppercase;font-weight:700;text-align:left;padding:.72rem .84rem;background:linear-gradient(180deg,#f4f8ff,#e9f1fe);color:#254164;border-bottom:1px solid #cfddef;white-space:nowrap}td{padding:.68rem .84rem;border-bottom:1px solid #edf2f8;font-family:var(--font-body);font-size:var(--text-sm);color:var(--foreground)}tr:last-child td{border-bottom:none}tr:hover td{background:#f2f7ff}.tabs{display:flex;border-bottom:1px solid var(--border-light);margin-bottom:var(--space-5);gap:var(--space-1)}.tab{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;padding:.6rem .95rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted-foreground);cursor:pointer;transition:all .15s ease;margin-bottom:-1px;border-top-left-radius:var(--radius-sm);border-top-right-radius:var(--radius-sm)}.tab:hover{color:var(--foreground);background:#f2f6fd}.tab.active{color:var(--primary);border-bottom-color:var(--primary);background:#ecf4ff}.page{padding:var(--space-6);height:calc(100vh - var(--topbar-height));overflow:hidden;display:flex;flex-direction:column;background:radial-gradient(80rem 34rem at 15% -15%,rgba(0,78,162,.14) 0%,transparent 60%),radial-gradient(72rem 30rem at 100% 0%,rgba(0,145,219,.12) 0%,transparent 56%),repeating-linear-gradient(135deg,rgba(0,78,162,.02) 0px,rgba(0,78,162,.02) 1px,transparent 1px,transparent 12px),var(--background);animation:pageFadeIn .35s ease}.page-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.table-container{flex:1;overflow:auto;position:relative;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md)}.table-container table{min-width:100%}.table-container th.sticky-left,.table-container td.sticky-left{position:sticky;left:0;z-index:2;background:var(--surface)}.table-container th.sticky-left-80,.table-container td.sticky-left-80{position:sticky;left:80px;z-index:2;background:var(--surface)}.table-container thead th{position:sticky;top:0;z-index:3;background:#eef3fb}.table-container thead th.sticky-left{z-index:4}.page-header{display:none!important}.page-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;line-height:1.2;margin-bottom:var(--space-1);letter-spacing:-.01em}.page-subtitle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--muted-foreground)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-5)}.stat-card{padding:var(--space-5);background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border-light);transition:all .2s ease;box-shadow:var(--shadow-sm)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-label{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;color:var(--muted-foreground);margin-bottom:var(--space-2)}.stat-value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:800;line-height:1;margin-bottom:var(--space-2)}.stat-unit{font-family:var(--font-body);font-size:var(--text-sm);color:var(--muted-foreground)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.dashboard-actions{display:flex;gap:var(--space-3);align-items:center}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:radial-gradient(44rem 28rem at 0% 0%,rgba(0,78,162,.15) 0%,transparent 62%),radial-gradient(44rem 28rem at 100% 100%,rgba(0,145,219,.14) 0%,transparent 62%),var(--background)}.login-container{width:100%;max-width:440px}.login-header{text-align:center;margin-bottom:var(--space-6)}.login-title{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:800;line-height:1.05;margin-bottom:var(--space-2)}.login-subtitle{font-family:var(--font-body);font-size:var(--text-base);color:var(--muted-foreground)}.login-form{background:var(--surface);padding:var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border-light)}.login-footer{margin-top:var(--space-5);text-align:center;font-family:var(--font-body);font-size:var(--text-sm);color:var(--muted-foreground)}.notification,.toast{position:fixed;top:var(--space-5);right:var(--space-5);padding:.75rem 1rem;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-family:var(--font-body);font-size:var(--text-sm);z-index:2000;min-width:260px;animation:slideIn .2s ease-out}.notification,.toast{background:#0f172a;color:#fff}.toast.success,.notification.success{background:var(--success)}.toast.error,.notification.error{background:var(--error)}.toast.warning,.notification.warning{background:var(--warning)}@keyframes slideIn{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{width:min(520px,92vw);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border:1px solid var(--border-light);padding:var(--space-6)}.modal-header{margin-bottom:var(--space-5)}.modal-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-xl)}.modal-body{margin-bottom:var(--space-5)}.modal-footer{display:flex;gap:var(--space-3);justify-content:flex-end}.sidebar{width:var(--sidebar-width);background:linear-gradient(190deg,#0f2b4f,#123763 45%,#114a7d);border-right:1px solid rgba(124,160,206,.35);padding:var(--space-5) 0;position:fixed;height:100vh;overflow-y:auto;box-shadow:8px 0 24px #05183338}.sidebar-header{padding:0 var(--space-5) var(--space-5);border-bottom:1px solid rgba(156,187,225,.25);margin-bottom:var(--space-4)}.sidebar-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;color:#f2f7ff;letter-spacing:-.01em}.sidebar-subtitle{font-family:var(--font-body);font-size:var(--text-sm);color:#c4d9f4;margin-top:var(--space-1)}.nav-menu{list-style:none;padding:0}.nav-item{padding:0}.nav-link{display:block;margin:.1rem .55rem;padding:.56rem .78rem;font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;color:#d7e7fc;text-decoration:none;transition:all .15s ease;border-radius:10px}.nav-link:hover{background:#76abea33;color:#fff}.nav-link.active{background:linear-gradient(135deg,#0a69c0,#0b8ad5 55%,#27acef);color:#fff;box-shadow:0 8px 20px #0f9eff52}.nav-section{padding:var(--space-3) var(--space-5);font-family:var(--font-body);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#9ebce2;margin-top:var(--space-3)}.main-content{flex:1;margin-left:var(--sidebar-width);height:100vh;background:var(--background);display:flex;flex-direction:column;overflow:hidden}.topbar{height:var(--topbar-height);background:#fffc;border-bottom:1px solid #cfdced;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);position:sticky;top:0;z-index:100}.topbar-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;letter-spacing:.02em;color:#183154}.topbar-user{font-family:var(--font-body);font-size:var(--text-sm);display:flex;align-items:center;gap:var(--space-4);color:var(--muted-foreground)}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1024px){.stats-grid,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid var(--border-light)}.main-content{margin-left:0}.stats-grid,.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.dashboard-header{flex-direction:column;gap:var(--space-4);align-items:flex-start}}.page{gap:var(--space-4)}.page-content,.tab-content,.tab-content-scrollable{min-height:0}.toolbar,.filters-row,.line-filter-row,.dashboard-actions,.form-actions,.action-row,.filter-row{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3)}.toolbar,.filters-row,.line-filter-row,.sticky-toolbar{padding:var(--space-3);background:var(--surface-toolbar);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.sticky-toolbar{position:sticky;top:0;z-index:var(--z-sticky);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.section-card,.config-card,.editor-panel,.note-list,.summary-panel,.data-panel,.panel,.tab-panel,.capacity-wrapper{background:var(--surface-card);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.section-card,.config-card,.editor-panel,.note-list,.panel,.tab-panel{padding:var(--space-5)}.section-title,.panel-title,.card-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;color:var(--color-text-strong);letter-spacing:-.01em}.section-subtitle,.panel-subtitle,.hint,.help-text{font-size:var(--text-sm);color:var(--muted-foreground)}.form-input,.form-textarea,.input,.search-input,select,textarea{min-height:var(--control-height-md);padding:.55rem var(--control-padding-x);border:1px solid #b9cbe4;border-radius:var(--radius-sm);background:linear-gradient(180deg,#fff,#f7fbff);color:var(--foreground);font-family:var(--font-body);font-size:var(--text-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.form-input:focus,.form-textarea:focus,.input:focus,.search-input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--focus-ring)}.form-textarea,textarea.form-input,.markdown-editor{min-height:120px;resize:vertical}.btn{min-height:var(--control-height-md)}.btn-small,.btn-sm{min-height:var(--control-height-sm);padding:.38rem .72rem;font-size:var(--text-xs)}.btn-danger{background:linear-gradient(135deg,#dc2626,#ef4444);border-color:#dc2626;color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#b91c1c,#dc2626)}.btn-ghost,.btn-link{background:transparent;border-color:transparent;box-shadow:none;color:var(--primary)}.btn-ghost:hover,.btn-link:hover{background:var(--info-bg);border-color:var(--info-border);transform:none}.compact-tabs,.tabs{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2);margin-bottom:var(--space-4);background:#ffffff8f;border:1px solid var(--border-light);border-radius:var(--radius-md)}.tab,.tab-chip{border:1px solid transparent;border-radius:var(--radius-sm);min-height:var(--control-height-sm)}.tab.active,.tab-chip.active{color:#fff;background:linear-gradient(135deg,var(--primary) 0%,var(--brand-cyan) 100%);border-color:var(--primary);box-shadow:0 8px 18px #0a69c02e}.table-wrapper,.table-container,.table-scroll{border-color:var(--border-light);border-radius:var(--radius-md);background:var(--surface);box-shadow:var(--shadow-sm)}.table-wrapper thead th,.table-container thead th,.table-scroll thead th{background:var(--surface-table-header);color:#254164}tr:hover td,.table-row:hover td{background:var(--surface-row-hover)}.warning-panel,.warnings-container,.warning-box{background:var(--warning-bg);border:1px solid var(--warning-border);color:var(--warning-text);border-radius:var(--radius-md);padding:var(--space-3)}.error-state,.error-message,.missing-description{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.loading-state,.empty-state{display:grid;place-items:center;min-height:160px;color:var(--muted-foreground);background:#ffffffb8;border:1px dashed var(--border);border-radius:var(--radius-md)}.modal,.confirm-modal,.modal-content{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl)}.modal-close,.close-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:#fff;color:var(--muted-foreground);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover,.close-btn:hover{color:var(--foreground);border-color:var(--border);background:var(--surface-soft)}@media (max-width: 768px){.toolbar,.filters-row,.line-filter-row,.dashboard-actions,.form-actions{align-items:stretch}.toolbar>*,.filters-row>*,.line-filter-row>*{max-width:100%}}
