:root{--black: #000000;--white: #ffffff;--lime: #c7f33c;--lime-pale: #e1f2ae;--lime-deep: #a8d324;--bg: #e8e8e8;--surface: #f4f4f2;--surface-2: #ececea;--surface-3: #dededb;--line: #d6d6d2;--ink: #0b0b0b;--ink-2: #2a2a28;--ink-3: #6b6b68;--ink-4: #9a9a95;--border-subtle: rgba(11, 11, 11, .06);--page-bg: radial-gradient(circle at 4% 94%, rgba(199, 243, 60, .72), transparent 18rem), radial-gradient(circle at 96% 8%, rgba(225, 242, 174, .72), transparent 20rem), var(--bg);--success: #2ba84a;--warning: #e8a21a;--danger: #d6452b;--info: #2d7dd2;--r-sm: 10px;--r-md: 14px;--r-lg: 20px;--r-xl: 28px;--r-2xl: 36px;--r-pill: 999px;--sh-1: 0 1px 2px rgba(0, 0, 0, .04), 0 1px 0 rgba(255, 255, 255, .5) inset;--sh-2: 0 6px 18px rgba(0, 0, 0, .06), 0 1px 0 rgba(255, 255, 255, .6) inset;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color-scheme:light}:root[data-theme=dark]{--black: #000000;--white: #181916;--lime: #c7f33c;--lime-pale: #33411a;--lime-deep: #d9ff5d;--bg: #10110f;--surface: #181916;--surface-2: #22231f;--surface-3: #2d2f29;--line: #383a33;--ink: #f6f7ef;--ink-2: #d8dad0;--ink-3: #a7aa9e;--ink-4: #73776a;--border-subtle: rgba(255, 255, 255, .08);--page-bg: radial-gradient(circle at 6% 92%, rgba(199, 243, 60, .22), transparent 20rem), radial-gradient(circle at 94% 8%, rgba(199, 243, 60, .1), transparent 22rem), var(--bg);--sh-1: 0 1px 2px rgba(0, 0, 0, .28), 0 1px 0 rgba(255, 255, 255, .04) inset;--sh-2: 0 12px 32px rgba(0, 0, 0, .34), 0 1px 0 rgba(255, 255, 255, .05) inset;color-scheme:dark}*{box-sizing:border-box}body{margin:0;min-width:320px;background:var(--page-bg);color:var(--ink);-webkit-font-smoothing:antialiased}button,input{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:76px minmax(0,1fr);gap:24px;min-height:100vh;padding:20px}.rail{align-items:center;align-self:stretch;background:var(--surface);border-radius:var(--r-2xl);box-shadow:var(--sh-1);display:flex;flex-direction:column;gap:12px;padding:12px;position:sticky;top:20px;height:calc(100vh - 40px)}.logo{align-items:center;background:var(--ink);border-radius:16px;color:var(--lime);display:flex;height:48px;justify-content:center;width:48px}.rail__items{display:flex;flex-direction:column;gap:6px;width:100%}.iconbtn{align-items:center;background:transparent;border:0;border-radius:50%;color:var(--ink-3);display:inline-flex;height:48px;justify-content:center;transition:background .18s ease,color .18s ease,transform .12s ease;width:48px}.iconbtn:hover,.iconbtn.is-active{background:var(--ink);color:var(--lime)}.iconbtn:active,.btn:active{transform:translateY(1px)}.iconbtn--soft{background:var(--surface);color:var(--ink)}.iconbtn--soft:hover{background:var(--surface-2);color:var(--ink)}.avatar{align-items:center;background:var(--lime);border:0;border-radius:50%;color:var(--ink);display:flex;font-size:13px;font-weight:700;height:42px;justify-content:center;margin-top:auto;width:42px}.theme-toggle{background:var(--surface-2);color:var(--ink);margin-top:auto}.theme-toggle:hover{background:var(--lime);color:#0b0b0b}.theme-toggle+.avatar{margin-top:0}.workspace{display:flex;flex-direction:column;gap:24px;min-width:0}.topbar{align-items:center;display:flex;gap:18px;justify-content:space-between;padding:4px 4px 0}.topbar__title{align-items:center;display:flex;gap:12px;min-width:0}.eyebrow{color:var(--ink-3);display:block;font-size:12px;font-weight:650;letter-spacing:.08em;text-transform:uppercase}h1,h2,p{margin:0}h1{font-size:clamp(30px,4vw,44px);font-weight:650;letter-spacing:0;line-height:1.05}h2{font-size:22px;font-weight:650;line-height:1.2}.topbar__actions{align-items:center;display:flex;gap:8px}.searchbox{align-items:center;background:var(--surface);border-radius:var(--r-pill);color:var(--ink-3);display:flex;gap:10px;height:44px;padding:0 16px;width:min(310px,28vw)}.searchbox input{background:transparent;border:0;color:var(--ink);min-width:0;outline:0;width:100%}.chip{align-items:center;background:var(--surface-2);border-radius:var(--r-pill);color:var(--ink-2);display:inline-flex;font-size:12px;font-weight:700;gap:6px;min-height:28px;padding:4px 12px;white-space:nowrap}.chip--dark{background:var(--ink);color:var(--surface)}.chip--lime{background:var(--lime);color:var(--ink)}.chip--success{background:#2ba84a26;color:#1f7d38}.chip--warning{background:#e8a21a2e;color:#8b5c00}.chip--danger{background:#d6452b26;color:#9d2d1c}.dot{border-radius:50%;display:inline-block;height:8px;width:8px}.dot--online{background:var(--lime)}.view-grid{display:grid;gap:18px;grid-template-columns:360px minmax(0,1fr)}.score-panel{background:radial-gradient(ellipse 75% 55% at -8% 110%,var(--score-accent, transparent) 0%,transparent 70%),var(--ink);border-radius:var(--r-2xl);box-shadow:var(--sh-2);color:var(--white);display:flex;flex-direction:column;justify-content:center;min-height:310px;overflow:hidden;padding:28px;position:relative}.score-panel--success{--score-accent: rgba(199, 243, 60, .3)}.score-panel--warning{--score-accent: rgba(251, 191, 36, .3)}.score-panel--danger{--score-accent: rgba(248, 113, 113, .3)}.score-panel strong{font-size:clamp(58px,8vw,92px);font-weight:760;line-height:.98;margin-top:36px;position:relative}.score-status{font-size:15px;font-weight:800;letter-spacing:.12em;margin-top:10px;position:relative;text-transform:uppercase}.score-status--success{color:#c7f33c}.score-status--warning{color:#fbbf24}.score-status--danger{color:#f87171}.score-value--success{color:var(--white)}.score-value--warning{color:#fbbf24}.score-value--danger{color:#f87171}.score-panel p{color:#ffffffb3;font-size:14px;margin-top:12px;max-width:240px;position:relative}.kpi-grid,.summary-row{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}.kpi-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--r-xl);box-shadow:var(--sh-1);display:flex;flex-direction:column;gap:10px;min-height:148px;padding:20px;position:relative}.kpi-card:before{background:var(--accent, var(--ink));border-radius:var(--r-pill);content:"";height:6px;left:20px;position:absolute;right:20px;top:16px}.kpi-card span{color:var(--ink-3);font-size:12px;font-weight:750;letter-spacing:.05em;margin-top:16px;text-transform:uppercase}.kpi-card strong{color:var(--ink);font-size:clamp(30px,4vw,42px);font-weight:760;line-height:1}.kpi-card small{color:var(--ink-3);font-size:13px}.kpi-card--success{--accent: var(--success)}.kpi-card--warning{--accent: var(--warning)}.kpi-card--danger{--accent: var(--danger)}.kpi-card--info{--accent: var(--info)}.kpi-card--lime{--accent: var(--lime)}.kpi-card--neutral{--accent: var(--line)}.panel{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--r-2xl);box-shadow:var(--sh-1);grid-column:span 1;padding:20px;min-width:0}.panel--wide{grid-column:span 1}.panel-header{align-items:center;display:flex;justify-content:space-between;gap:16px;margin-bottom:14px}.btn{align-items:center;border:0;border-radius:var(--r-pill);display:inline-flex;gap:8px;font-weight:700;height:40px;justify-content:center;padding:0 16px}.btn:disabled{cursor:not-allowed;opacity:.48}.btn--ghost{background:var(--surface-2);color:var(--ink)}.btn--lime{background:var(--lime);color:var(--ink)}.list{display:flex;flex-direction:column;gap:8px}.list-item{align-items:flex-start;background:var(--white);border-radius:var(--r-lg);display:flex;gap:12px;padding:14px}.severity{border-radius:var(--r-pill);flex:0 0 auto;height:36px;width:6px}.severity--high{background:var(--danger)}.severity--medium{background:var(--warning)}.severity--low{background:var(--ink-4)}.list-item__body{display:flex;flex:1;flex-direction:column;gap:6px;min-width:0}.list-item__top{align-items:center;display:flex;gap:10px;justify-content:space-between}.list-item strong{font-size:15px}.list-item p,.list-item small{color:var(--ink-3);font-size:13px;line-height:1.45}.table-shell{background:var(--white);border-radius:var(--r-xl);overflow:auto}table{border-collapse:collapse;min-width:760px;width:100%}th,td{border-bottom:1px solid var(--line);padding:14px 16px;text-align:left;vertical-align:middle}th{color:var(--ink-3);font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase}td{color:var(--ink-2);font-size:14px}tr:last-child td{border-bottom:0}.num{font-variant-numeric:tabular-nums;text-align:right}.stack{display:flex;flex-direction:column;gap:18px}.upload-grid{display:grid;gap:16px;grid-template-columns:repeat(4,minmax(0,1fr))}.upload-card,.state-card{background:var(--surface);border-radius:var(--r-2xl);box-shadow:var(--sh-1);display:flex;flex-direction:column;gap:14px;min-height:260px;padding:24px}.upload-card svg,.state-card svg{color:var(--ink)}.upload-card p,.state-card p{color:var(--ink-3);line-height:1.5}.upload-card--dark{background:var(--ink);color:var(--surface)}.upload-card--dark p,.upload-card--dark svg{color:#ffffffb8}.upload-card .btn{margin-top:auto}.period-fields{display:grid;gap:10px;grid-template-columns:1fr 1fr}.period-fields label{display:flex;flex-direction:column;gap:6px}.period-fields span{color:#ffffffa3;font-size:12px;font-weight:750;letter-spacing:.05em;text-transform:uppercase}.period-fields input{background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:var(--r-pill);color:currentColor;height:40px;outline:0;padding:0 12px}.process-status{display:flex;flex-wrap:wrap;gap:8px}.inline-alert{border-radius:var(--r-lg);font-size:13px;font-weight:700;line-height:1.4;padding:12px}.inline-alert--danger{background:#d6452b2e;color:#ffd3cb}.inline-alert--success{background:#c7f33c2e;color:var(--lime)}.process-result{display:flex;flex-direction:column;gap:10px}.process-result__actions{display:flex;flex-wrap:wrap;gap:8px}.upload-card__saved{align-items:center;background:var(--surface-2);border-radius:var(--r-pill);color:var(--ink-2);display:flex;font-size:13px;font-weight:700;gap:8px;min-height:34px;overflow:hidden;padding:0 12px}.upload-card__saved span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.state-card{align-items:center;justify-content:center;text-align:center}.empty{align-items:center;background:var(--white);border-radius:var(--r-lg);color:var(--ink-3);display:flex;gap:10px;padding:18px}.empty--compact{font-size:14px;padding:14px}.modal-backdrop{align-items:center;background:#00000057;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;padding:24px;position:fixed;z-index:40}.modal{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--r-2xl);box-shadow:0 24px 60px #00000038;display:flex;flex-direction:column;gap:18px;max-height:min(760px,calc(100vh - 48px));max-width:620px;overflow:auto;padding:22px;width:min(620px,100%)}.modal__header,.modal__title,.modal__actions{align-items:center;display:flex;gap:12px}.modal__header{justify-content:space-between}.modal__title{min-width:0}.modal__icon{align-items:center;background:var(--ink);border-radius:16px;color:var(--lime);display:flex;flex:0 0 auto;height:46px;justify-content:center;width:46px}.modal__copy{color:var(--ink-3);line-height:1.5}.dropzone{align-items:center;background:var(--white);border:1px dashed var(--line);border-radius:var(--r-xl);color:var(--ink);display:flex;flex-direction:column;gap:8px;min-height:180px;justify-content:center;padding:24px;position:relative;text-align:center;transition:background .18s ease,border-color .18s ease,transform .12s ease}.dropzone:hover{background:var(--surface-2);border-color:var(--ink-4)}.dropzone:active{transform:translateY(1px)}.dropzone svg{color:var(--ink)}.dropzone strong{font-size:17px}.dropzone span{color:var(--ink-3);font-size:14px}.dropzone input{cursor:pointer;top:0;right:0;bottom:0;left:0;opacity:0;position:absolute}.modal__files{display:flex;flex-direction:column;gap:10px}.file-list{background:var(--white);border-radius:var(--r-xl);overflow:hidden}.file-row{align-items:center;border-bottom:1px solid var(--line);display:grid;gap:10px;grid-template-columns:auto minmax(0,1fr) auto;padding:13px 14px}.file-row:last-child{border-bottom:0}.file-row span{color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-row small{color:var(--ink-3);font-variant-numeric:tabular-nums}.modal__actions{justify-content:flex-end}:root[data-theme=dark] .logo,:root[data-theme=dark] .iconbtn:hover,:root[data-theme=dark] .iconbtn.is-active,:root[data-theme=dark] .upload-card--dark{background:#050604}:root[data-theme=dark] .score-panel p,:root[data-theme=dark] .upload-card--dark p,:root[data-theme=dark] .upload-card--dark svg{color:#f6f7efad}:root[data-theme=dark] .chip--dark{background:#050604;color:var(--lime)}:root[data-theme=dark] .chip--success{background:#2ba84a38;color:#8ee2a1}:root[data-theme=dark] .chip--warning{background:#e8a21a3b;color:#f1c86d}:root[data-theme=dark] .chip--danger{background:#d6452b38;color:#ee9a8b}:root[data-theme=dark] .modal-backdrop{background:#00000094}:root[data-theme=dark] .modal__icon{background:#050604}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1100px){.view-grid,.upload-grid{grid-template-columns:1fr}.kpi-grid,.summary-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.app-shell{grid-template-columns:1fr;padding:12px}.rail{border-radius:var(--r-xl);flex-direction:row;height:auto;overflow-x:auto;position:static}.rail__items{flex-direction:row}.avatar{margin-left:auto;margin-top:0}.topbar,.topbar__actions{align-items:flex-start;flex-direction:column}.searchbox{width:100%}.kpi-grid,.summary-row{grid-template-columns:1fr}.modal-backdrop{align-items:flex-end;padding:10px}.modal{border-radius:var(--r-xl);max-height:calc(100vh - 20px);padding:18px}.modal__actions{align-items:stretch;flex-direction:column-reverse}}.login-backdrop{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--page-bg)}.login-card{width:100%;max-width:360px;padding:2rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);display:flex;flex-direction:column;gap:1.5rem}.login-card__header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.login-card__header h1{font-size:1.25rem;font-weight:700;color:var(--ink);margin:0}.login-card__header p{font-size:.8125rem;color:var(--ink-3);margin:0}.login-card__form{display:flex;flex-direction:column;gap:1rem}.login-card__form label{display:flex;flex-direction:column;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--ink-2)}.login-card__form input{padding:.5rem .75rem;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface-2);color:var(--ink);font-size:.875rem;outline:none;transition:border-color .15s}.login-card__form input:focus{border-color:var(--lime-deep)}.login-card__form .btn{margin-top:.5rem;width:100%;justify-content:center}
