@import"https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&family=Fraunces:opsz,wght@9..144,600;9..144,700&display=swap";:root{--bg: #ecf2f9;--surface: #fdfefe;--surface-strong: #ffffff;--ink: #14263a;--ink-subtle: #3d5368;--line: #d1dde9;--brand: #0f548c;--brand-soft: #1e8f8e;--accent: #e39b32;--shadow: 0 20px 45px rgba(10, 28, 52, .14)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{font-family:Outfit,sans-serif;color:var(--ink);background:radial-gradient(circle at 12% 18%,rgba(15,84,140,.18),transparent 42%),radial-gradient(circle at 88% 90%,rgba(30,143,142,.16),transparent 44%),var(--bg)}h1,h2,h3,h4{margin:0;font-family:Fraunces,serif;letter-spacing:-.01em}p{margin:0}code{font-size:.92em;background:#0f548c14;border-radius:8px;padding:1px 6px}button,select,input{font-family:inherit}.passcode-screen{min-height:100vh;display:grid;place-items:center;padding:20px}.passcode-card{width:min(520px,92vw);background:#ffffffe0;border:1px solid var(--line);border-radius:24px;padding:24px;display:grid;gap:12px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.passcode-logo{width:170px;background:#fff;border-radius:10px;padding:7px 10px}.passcode-card .eyebrow{color:#2d5275}.passcode-card h1{font-size:clamp(1.35rem,3vw,1.9rem);line-height:1.2}.passcode-subtitle{color:var(--ink-subtle);line-height:1.45}.passcode-input{width:100%;height:56px;border-radius:12px;border:1px solid #c7d5e2;text-align:center;font-size:1.15rem;font-weight:600;letter-spacing:.15em;color:#10263c;background:#fff;padding:0 12px}.passcode-input:focus{outline:none;border-color:#0f548c;box-shadow:0 0 0 3px #0f548c26}.passcode-input.shake{animation:shake-x .35s ease}.helper-text,.error-text{font-size:13px;min-height:18px}.helper-text{color:var(--ink-subtle)}.error-text{color:#a43a2c;font-weight:600}.unlock-button{border:0;border-radius:12px;min-height:44px;background:linear-gradient(130deg,#1f4f7b,#0f548c);color:#eff7ff;font-weight:700;cursor:pointer}@keyframes shake-x{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.dashboard-shell{width:min(1260px,94vw);margin:26px auto 36px;display:grid;gap:18px;position:relative}.top-controls{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.view-switch{display:inline-flex;align-items:center;gap:6px;width:fit-content;background:#ffffffc2;border:1px solid var(--line);border-radius:14px;padding:5px;box-shadow:0 10px 24px #091b3014}.view-switch button{border:0;border-radius:10px;min-height:36px;padding:0 14px;background:transparent;color:#2b4054;font-weight:600;cursor:pointer}.view-switch button.active{background:linear-gradient(130deg,#1f4f7b,#0f548c);color:#eef6ff}.logout-button{border:1px solid #b8c9d8;border-radius:10px;min-height:36px;padding:0 14px;background:#fffc;color:#1f3d57;font-weight:600;cursor:pointer}.atmosphere{position:absolute;border-radius:999px;pointer-events:none;z-index:0}.atmosphere.one{width:320px;height:320px;top:-80px;right:-90px;background:radial-gradient(circle,#0f548c38,#0f548c00)}.atmosphere.two{width:380px;height:380px;bottom:-130px;left:-100px;background:radial-gradient(circle,#e39b3233,#e39b3200)}.hero,.filters,.kpi-grid,.chart-grid,.table-card,.empty-state{position:relative;z-index:1}.hero{background:linear-gradient(152deg,#143152,#0f548c 55%,#1e8f8e);color:#f3f7fb;border-radius:24px;padding:26px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;box-shadow:var(--shadow)}.hero-copy{display:grid;gap:10px;max-width:760px}.eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:700;color:#ccdeeb}.hero h1{font-size:clamp(1.4rem,3vw,2.15rem);line-height:1.2}.hero p{color:#f1f8ffed;line-height:1.5}.hero-summary{background:#ffffff29;border:1px solid rgba(255,255,255,.25);border-radius:16px;padding:12px 14px;min-width:240px;display:grid;gap:6px;align-self:start}.hero-summary img{width:154px;background:#fff;border-radius:10px;padding:7px 9px}.hero-summary small{opacity:.82;letter-spacing:.05em;text-transform:uppercase;font-size:10px}.hero-summary strong{font-size:16px;line-height:1.25}.hero-summary span{font-size:13px;color:#ecf7fff2}.filters{background:#fffc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid var(--line);border-radius:18px;padding:14px;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;box-shadow:0 14px 34px #091b3014}.filter-block{display:grid;gap:6px}.filter-block label{font-size:12px;color:var(--ink-subtle);font-weight:600}.filter-block select{border:1px solid #c6d4e1;border-radius:11px;background:#fff;color:var(--ink);padding:9px 12px;min-height:40px}.reset-button{align-self:end;border:0;border-radius:11px;min-height:40px;background:linear-gradient(130deg,#1f4f7b,#0f548c);color:#ecf5ff;font-weight:700;cursor:pointer}.kpi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:11px}.kpi-card{background:var(--surface-strong);border:1px solid var(--line);border-radius:16px;padding:13px 14px;display:grid;gap:8px;min-height:118px;box-shadow:0 12px 28px #07142714}.kpi-card p{font-size:12px;color:var(--ink-subtle);font-weight:600}.kpi-card h3{font-size:clamp(1.2rem,1.8vw,1.75rem);line-height:1.2}.kpi-card span{font-size:12px;color:#50647a;line-height:1.4}.kpi-card.focus{border-color:#0f548c59;background:linear-gradient(160deg,#fcfeff,#f2f9ff)}.kpi-card.accent{border-color:#e39b3275;background:linear-gradient(160deg,#fffefc,#fff6e9)}.chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.chart-card,.table-card,.empty-state{background:var(--surface-strong);border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:0 12px 28px #07142714}.card-head{display:grid;gap:4px;margin-bottom:10px}.card-head h2{font-size:1.15rem}.card-head p{color:var(--ink-subtle);font-size:13px;line-height:1.4}.chart-empty{height:290px;display:grid;place-items:center;color:var(--ink-subtle);font-size:14px;text-align:center}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;color:#4f6377;border-bottom:1px solid #d9e3ec;padding:10px 9px;white-space:nowrap}tbody td{border-bottom:1px solid #edf2f7;padding:10px 9px;white-space:nowrap}tbody tr:nth-child(odd){background:#fafcff}.empty-state{text-align:center;padding:40px 20px}.empty-state h2{font-size:1.25rem}.empty-state p{margin-top:8px;color:var(--ink-subtle)}@media (max-width: 1200px){.kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 980px){.dashboard-shell{width:min(1260px,95vw);margin-top:14px}.filters{grid-template-columns:repeat(2,minmax(0,1fr))}.chart-grid{grid-template-columns:1fr}}@media (max-width: 700px){.passcode-input{height:48px;font-size:1.05rem}.hero{padding:18px}.hero-summary,.view-switch{width:100%}.view-switch button{flex:1}.logout-button{width:100%}.filters{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.chart-card,.table-card{padding:12px}}@media (max-width: 440px){.kpi-grid{grid-template-columns:1fr}}
