:root{
  --bg:#0b1019;
  --panel:#121a28;
  --panel-2:#182335;
  --text:#eef4ff;
  --muted:#9aa8bd;
  --line:rgba(255,255,255,.10);
  --primary:#ff6b35;
  --primary-2:#ffb86b;
  --cyan:#35d5ff;
  --green:#53e6a3;
  --danger:#ff4f6d;
  --shadow: 0 22px 60px rgba(0,0,0,.38);
  --radius:24px;
  --sidebar:288px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  min-height:100vh;
  margin:0;
  color:var(--text);
  background:
    radial-gradient(circle at 10% 0%, rgba(255,107,53,.26), transparent 34%),
    radial-gradient(circle at 82% 10%, rgba(53,213,255,.18), transparent 28%),
    linear-gradient(135deg,#0b1019,#0f1724 46%,#17101a);
  overflow-x:hidden;
}
button,select{font:inherit}
.fx-bg{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:-1}
.smoke{position:absolute;width:42rem;height:42rem;border-radius:999px;filter:blur(35px);opacity:.18;background:radial-gradient(circle,rgba(255,255,255,.32),transparent 65%);animation:float 18s ease-in-out infinite}
.smoke-a{left:-12rem;top:6rem}.smoke-b{right:-15rem;top:18rem;animation-delay:-6s}.smoke-c{left:24%;bottom:-20rem;animation-delay:-12s}
.filament{position:absolute;width:1px;height:60vh;background:linear-gradient(transparent,rgba(255,150,84,.6),transparent);filter:drop-shadow(0 0 18px rgba(255,107,53,.5));transform:rotate(26deg);opacity:.45}
.filament-a{left:66%;top:-10%}.filament-b{left:26%;bottom:-10%;transform:rotate(-24deg)}
.vignette{position:absolute;inset:0;background:radial-gradient(circle at center, transparent 35%,rgba(0,0,0,.42) 100%)}
@keyframes float{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(3rem,-2rem,0) scale(1.1)}}
.app-shell{display:flex;min-height:100vh}
.sidebar{
  width:var(--sidebar);min-height:100vh;position:sticky;top:0;align-self:flex-start;
  display:flex;flex-direction:column;gap:18px;padding:24px 18px;
  background:rgba(8,13,23,.78);backdrop-filter:blur(20px);
  border-right:1px solid var(--line);box-shadow:var(--shadow);z-index:5;transition:width .22s ease, transform .22s ease;
}
.brand{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:18px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.03));border:1px solid var(--line)}
.brand img,.profile img{width:42px;height:42px;border-radius:14px;object-fit:contain;background:rgba(255,255,255,.94);padding:5px}
.brand strong,.profile strong{display:block;letter-spacing:.08em}.brand small,.profile small{display:block;color:var(--muted);font-size:.78rem;margin-top:1px}
.session{color:#c9d5e6;font-size:.78rem;padding:11px 13px;border:1px solid rgba(255,107,53,.28);border-radius:16px;background:rgba(255,107,53,.08)}
.nav{display:grid;gap:8px;margin-top:6px}
.nav a{display:flex;align-items:center;gap:12px;text-decoration:none;color:#dfe8f7;padding:13px 14px;border-radius:16px;border:1px solid transparent;transition:.18s ease;background:transparent}
.nav a:hover,.nav a.active{background:linear-gradient(135deg,rgba(255,107,53,.20),rgba(53,213,255,.08));border-color:rgba(255,255,255,.10);transform:translateX(3px)}
.nav i{display:grid;place-items:center;width:32px;height:32px;border-radius:12px;background:rgba(255,255,255,.08);font-style:normal;color:var(--primary-2)}
.nav b{font-size:.95rem}.side-footer{margin-top:auto;display:grid;gap:12px}.profile{display:flex;gap:10px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.05)}
.side-actions{display:flex;gap:8px}.logout,.collapse,.menu-btn,.filter-btn{border:0;color:#fff;cursor:pointer;border-radius:14px;transition:.18s ease}.logout{flex:1;padding:12px 14px;background:rgba(255,79,109,.18);border:1px solid rgba(255,79,109,.28)}.collapse{width:46px;background:rgba(255,255,255,.08);font-size:1.6rem}.logout:hover,.collapse:hover,.filter-btn:hover,.menu-btn:hover{transform:translateY(-1px);filter:brightness(1.1)}
.sidebar.collapsed{width:92px}.sidebar.collapsed .brand span,.sidebar.collapsed .session,.sidebar.collapsed .nav b,.sidebar.collapsed .profile span,.sidebar.collapsed .logout{display:none}.sidebar.collapsed .nav a{justify-content:center}.sidebar.collapsed .brand{justify-content:center}.sidebar.collapsed .side-actions{justify-content:center}.sidebar.collapsed .collapse{transform:rotate(180deg)}
.content{flex:1;min-width:0;padding:28px 30px 36px}.header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:22px}.menu-btn{display:none;background:rgba(255,255,255,.08);border:1px solid var(--line);width:48px;height:48px;font-size:1.25rem}.title-block{max-width:780px}.eyebrow{margin:0 0 7px;color:var(--primary-2);font-weight:800;text-transform:uppercase;font-size:.78rem;letter-spacing:.12em}.title-block h1{margin:0;font-size:clamp(2rem,4vw,4.2rem);line-height:.96;letter-spacing:-.05em}.title-block p:last-child{color:var(--muted);font-size:1rem;line-height:1.55;margin:14px 0 0}.status-card{min-width:250px;display:flex;align-items:center;gap:12px;padding:15px 16px;border:1px solid rgba(83,230,163,.22);border-radius:20px;background:rgba(83,230,163,.08);box-shadow:0 14px 40px rgba(0,0,0,.18)}.status-card strong{display:block}.status-card small{display:block;color:#b9c7d9;margin-top:2px}.pulse{width:13px;height:13px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(83,230,163,.55);animation:pulse 1.7s infinite}@keyframes pulse{to{box-shadow:0 0 0 12px rgba(83,230,163,0)}}
.filters{display:grid;grid-template-columns:repeat(5,minmax(140px,1fr)) auto;gap:12px;padding:14px;border:1px solid var(--line);border-radius:24px;background:rgba(255,255,255,.06);backdrop-filter:blur(14px);margin-bottom:18px}.filters label{display:grid;gap:7px}.filters span{font-size:.74rem;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.08em}.filters select{width:100%;border:1px solid rgba(255,255,255,.12);background:#101827;color:#f6f8ff;border-radius:14px;padding:12px 12px;outline:none}.filter-btn{align-self:end;padding:13px 18px;background:linear-gradient(135deg,var(--primary),#ff8f45);font-weight:900;box-shadow:0 12px 28px rgba(255,107,53,.24)}
.kpis{display:grid;grid-template-columns:1.25fr repeat(3,1fr);gap:14px;margin-bottom:18px}.kpi{position:relative;overflow:hidden;min-height:138px;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(135deg,rgba(255,255,255,.085),rgba(255,255,255,.035));box-shadow:0 16px 48px rgba(0,0,0,.18)}.kpi:after{content:"";position:absolute;right:-28px;top:-30px;width:130px;height:130px;border-radius:50%;background:rgba(255,255,255,.06)}.kpi i{display:grid;place-items:center;width:40px;height:40px;border-radius:15px;background:rgba(255,255,255,.10);font-style:normal;color:var(--primary-2);margin-bottom:13px}.kpi span{display:block;color:#c9d5e6;font-size:.92rem}.kpi strong{display:block;font-size:clamp(2rem,4vw,3.3rem);line-height:1;font-weight:950;letter-spacing:-.04em}.kpi small{color:var(--muted)}.kpi.main{background:linear-gradient(135deg,rgba(255,107,53,.20),rgba(255,255,255,.045))}.kpi.fire i{color:#ff8e72}.kpi.gas i{color:#7fe6ff}.kpi.comuna i{color:#90e7b8}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.panel{min-height:260px;padding:20px;border:1px solid var(--line);border-radius:var(--radius);background:rgba(18,26,40,.80);backdrop-filter:blur(18px);box-shadow:0 18px 52px rgba(0,0,0,.22)}.panel-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:18px}.panel h2{margin:0;font-size:1.05rem}.panel p{margin:5px 0 0;color:var(--muted);font-size:.9rem;line-height:1.4}.panel-head>span{display:grid;place-items:center;min-width:38px;height:38px;border-radius:14px;background:rgba(255,255,255,.08);color:var(--primary-2)}.type-panel{grid-column:span 5}.commune-panel{grid-column:span 7}.neighborhood-panel,.evolution-panel,.station-panel{grid-column:span 4}.critical-panel{grid-column:span 4}.audit-panel{grid-column:span 4}.recent-panel{grid-column:span 8}.source-panel{grid-column:span 4}
.donut-layout{display:grid;grid-template-columns:210px 1fr;gap:20px;align-items:center}.donut,.quality-ring{--chart:conic-gradient(var(--primary) 0deg, var(--cyan) 0deg);width:210px;aspect-ratio:1;border-radius:50%;display:grid;place-items:center;background:var(--chart);position:relative}.donut:before,.quality-ring:before{content:"";position:absolute;inset:18px;background:#121a28;border-radius:inherit;box-shadow:inset 0 0 24px rgba(0,0,0,.32)}.donut span,.quality-ring span{position:relative;display:grid;text-align:center}.donut strong,.quality-ring strong{font-size:2rem;letter-spacing:-.04em}.donut small,.quality-ring small{color:var(--muted);text-transform:uppercase;font-size:.72rem;font-weight:900}.legend{display:grid;gap:10px}.legend-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;color:#d9e5f6}.dot{width:11px;height:11px;border-radius:50%;background:var(--c)}.legend-row small{color:var(--muted)}
.commune-bars,.month-chart,.station-list,.neighborhood-list,.critical-list{display:grid;gap:11px}.bar-row{display:grid;grid-template-columns:110px 1fr 56px;gap:12px;align-items:center}.bar-track{height:12px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}.bar-fill{height:100%;width:var(--w);background:linear-gradient(90deg,var(--primary),var(--primary-2));border-radius:inherit}.bar-row b,.bar-row span{font-size:.9rem}.bar-row em{font-style:normal;color:var(--muted);text-align:right}.neighborhood-item,.station-item,.critical-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 13px;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:rgba(255,255,255,.045)}.neighborhood-item strong,.station-item strong{display:block}.neighborhood-item small,.station-item small,.critical-item small{color:var(--muted)}.rank{display:grid;place-items:center;min-width:34px;height:34px;border-radius:12px;background:rgba(255,107,53,.14);color:var(--primary-2);font-weight:950}.item-left{display:flex;align-items:center;gap:11px}.badge{padding:6px 9px;border-radius:99px;background:rgba(53,213,255,.10);border:1px solid rgba(53,213,255,.18);color:#a7eeff;font-size:.78rem;font-weight:800}.month-chart{grid-auto-flow:column;align-items:end;min-height:210px;gap:10px;padding-top:14px}.month{display:grid;grid-template-rows:1fr auto;gap:8px;align-items:end;text-align:center;color:var(--muted);font-size:.8rem}.stack{display:flex;flex-direction:column-reverse;height:180px;border-radius:14px;overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}.seg{height:var(--h);min-height:4px}.seg.fire{background:#ff6b35}.seg.gas{background:#35d5ff}.seg.other{background:#53e6a3}.critical-item{align-items:flex-start}.critical-item .severity{min-width:10px;height:46px;border-radius:99px;background:linear-gradient(var(--primary),var(--danger))}.critical-item strong{display:block;margin-bottom:2px}.quality{display:grid;grid-template-columns:170px 1fr;gap:18px;align-items:center}.quality-ring{width:170px;--chart:conic-gradient(var(--green) 0deg, rgba(255,255,255,.08) 0deg)}.quality dl{display:grid;grid-template-columns:1fr auto;gap:10px 12px;margin:0}.quality dt{color:var(--muted)}.quality dd{margin:0;font-weight:900}.recent-table{display:grid;gap:8px}.recent-row{display:grid;grid-template-columns:105px 1.1fr 1fr .9fr 72px;gap:10px;align-items:center;padding:12px;border-radius:15px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.07);font-size:.86rem}.recent-row.header{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:900;background:transparent;border-color:transparent;padding-bottom:2px}.recent-row b{color:#fff}.json-box{display:flex;gap:12px;align-items:center;padding:15px;border:1px solid rgba(255,107,53,.20);border-radius:18px;background:rgba(255,107,53,.08);margin-bottom:14px}.json-box i{font-style:normal;font-weight:950;color:#121a28;background:linear-gradient(135deg,var(--primary-2),var(--primary));padding:8px;border-radius:11px}.json-box strong{display:block;word-break:break-word}.json-box small{display:block;color:var(--muted);margin-top:3px}.source-grid{display:grid;grid-template-columns:1fr auto;gap:12px;padding:14px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:rgba(255,255,255,.04)}.source-grid span{color:var(--muted)}.source-grid b{text-align:right}.source-grid .ok{color:var(--green)}.footer-note{padding:18px 4px 6px;text-align:center;color:var(--muted);font-size:.9rem}.toast{position:fixed;right:24px;bottom:24px;max-width:330px;padding:14px 16px;border-radius:17px;background:rgba(18,26,40,.96);border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow);transform:translateY(20px);opacity:0;pointer-events:none;transition:.22s ease;z-index:20}.toast.show{opacity:1;transform:translateY(0)}
body.menu-open .sidebar{transform:translateX(0)}
@media (max-width:1180px){.filters{grid-template-columns:repeat(3,1fr)}.filter-btn{grid-column:span 3}.kpis{grid-template-columns:repeat(2,1fr)}.type-panel,.commune-panel,.neighborhood-panel,.evolution-panel,.station-panel,.critical-panel,.audit-panel,.recent-panel,.source-panel{grid-column:span 6}.donut-layout{grid-template-columns:1fr}.recent-row{grid-template-columns:90px 1fr 1fr}.recent-row span:nth-child(4),.recent-row b:nth-child(5){display:none}}
@media (max-width:820px){.app-shell{display:block}.sidebar{position:fixed;transform:translateX(-105%);width:292px}.sidebar.collapsed{width:292px}.sidebar.collapsed .brand span,.sidebar.collapsed .session,.sidebar.collapsed .nav b,.sidebar.collapsed .profile span,.sidebar.collapsed .logout{display:block}.sidebar.collapsed .nav a{justify-content:flex-start}.content{padding:18px 14px 30px}.menu-btn{display:block;flex-shrink:0}.header{display:grid;grid-template-columns:auto 1fr;align-items:start}.status-card{grid-column:1/-1;width:100%;min-width:0}.filters{grid-template-columns:1fr}.filter-btn{grid-column:auto}.kpis{grid-template-columns:1fr}.type-panel,.commune-panel,.neighborhood-panel,.evolution-panel,.station-panel,.critical-panel,.audit-panel,.recent-panel,.source-panel{grid-column:span 12}.quality{grid-template-columns:1fr}.month-chart{overflow-x:auto}.bar-row{grid-template-columns:80px 1fr 44px}.toast{left:14px;right:14px;bottom:14px}}
