:root{
  --bg:#0b0f14;
  --panel:#0f1620;
  --panel-2:#121c28;
  --text:#e7eef7;
  --muted:#9fb0c3;
  --border:#1f2a3a;
  --accent:#5dd6ff;
  --accent-2:#7c5cff;
  --danger:#ff4d4d;
  --warn:#ff9f43;
  --ok:#2ecc71;
  --shadow: 0 18px 50px rgba(0,0,0,.45);
  --radius: 16px;
  --max: 1120px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  background: radial-gradient(1200px 600px at 15% 0%, rgba(124,92,255,.20), transparent 55%),
              radial-gradient(900px 500px at 85% 10%, rgba(93,214,255,.18), transparent 55%),
              var(--bg);
  color:var(--text);
  line-height:1.5;
}

a{color:var(--accent); text-decoration:none}
a:hover{opacity:.9; text-decoration:underline}

.container{max-width:var(--max); margin:0 auto; padding:24px}
.header{
  position:sticky; top:0; z-index:10;
  backdrop-filter: blur(14px);
  background: rgba(11,15,20,.72);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 24px; max-width:var(--max); margin:0 auto}
.brand{display:flex; align-items:center; gap:12px}
.logo{
  width:36px; height:36px; border-radius:12px;
  background: linear-gradient(135deg, rgba(93,214,255,.95), rgba(124,92,255,.9));
  box-shadow: 0 10px 30px rgba(93,214,255,.15);
  display:grid; place-items:center;
  font-weight:800; color:#081019;
}
.brand h1{font-size:14px; margin:0; letter-spacing:.3px}
.brand small{display:block; color:var(--muted); font-size:12px; margin-top:2px}

.nav{display:flex; gap:12px; flex-wrap:wrap; align-items:center}
.nav a{
  color:var(--text);
  padding:8px 10px;
  border-radius:12px;
  border:1px solid transparent;
}
.nav a:hover{border-color:var(--border); background:rgba(255,255,255,.03); text-decoration:none}
.nav a.active{border-color:rgba(93,214,255,.35); background:rgba(93,214,255,.08)}
.pill{
  font-size:12px; color:var(--muted);
  border:1px solid var(--border);
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.02);
}

.hero{padding:38px 0 20px}
.hero-grid{display:grid; grid-template-columns: 1.2fr .8fr; gap:18px; align-items:stretch}
@media (max-width: 920px){.hero-grid{grid-template-columns:1fr}}

.card{
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow);
}
.card h2{margin:0 0 8px; font-size:22px}
.card p{margin:0 0 12px; color:var(--muted)}
.kpis{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:12px}
@media (max-width: 720px){.kpis{grid-template-columns:1fr}}
.kpi{padding:12px; border-radius:14px; background:rgba(255,255,255,.02); border:1px solid var(--border)}
.kpi b{display:block; font-size:18px}
.kpi span{color:var(--muted); font-size:12px}

.btnrow{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px}
button,.btn{
  font-family:var(--font);
  cursor:pointer;
  border-radius:14px;
  padding:10px 12px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.03);
  color:var(--text);
}
button:hover,.btn:hover{background:rgba(255,255,255,.05)}
.btn-primary{
  border-color:rgba(93,214,255,.35);
  background:rgba(93,214,255,.08);
}
.btn-danger{
  border-color:rgba(255,77,77,.4);
  background:rgba(255,77,77,.10);
}
.btn-ghost{background:transparent}
.btn-small{padding:7px 10px; border-radius:12px; font-size:13px}

.grid-2{display:grid; grid-template-columns: 1fr 1fr; gap:16px}
@media (max-width: 920px){.grid-2{grid-template-columns:1fr}}

.section-title{display:flex; align-items:end; justify-content:space-between; gap:12px; margin:12px 0}
.section-title h2{margin:0; font-size:18px}
.section-title p{margin:0; color:var(--muted); font-size:13px}

hr.sep{border:none; border-top:1px solid var(--border); margin:16px 0}

.footer{
  color:var(--muted);
  border-top:1px solid var(--border);
  margin-top:28px;
  padding:18px 0 28px;
  font-size:12px;
}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--border);
  border-radius:999px;
  padding:6px 10px;
  background:rgba(255,255,255,.02);
  color:var(--muted);
  font-size:12px;
}
.badge-dot{width:8px; height:8px; border-radius:999px; background:var(--accent)}
.muted{color:var(--muted)}
.small{font-size:12px}
.note{padding:12px; border-radius:14px; border:1px dashed rgba(159,176,195,.35); color:var(--muted); background:rgba(255,255,255,.015)}

.table{width:100%; border-collapse:separate; border-spacing:0}
.table th,.table td{
  padding:10px 10px;
  border-bottom:1px solid var(--border);
  font-size:14px;
}
.table th{color:var(--muted); font-weight:600; text-align:left; background:rgba(255,255,255,.02)}
.table tr:hover td{background:rgba(255,255,255,.02)}
.table td:last-child{text-align:right}
.table .right{text-align:right}

.switches{display:flex; gap:10px; flex-wrap:wrap}
.switches button.active{
  border-color:rgba(124,92,255,.45);
  background:rgba(124,92,255,.10);
}

.trend-badge{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:44px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  font-weight:700;
  letter-spacing:.2px;
}

.trend-upstrong{border-color:rgba(255,68,85,.60); background:rgba(255,68,85,.14); color:#ffd0d0} /* ▲▲ strong increase */
.trend-up{border-color:rgba(255,166,64,.60); background:rgba(255,166,64,.14); color:#ffe2c4}       /* ▲ increase */
.trend-flat{border-color:rgba(43,203,137,.60); background:rgba(43,203,137,.12); color:#c9f6da}     /* ➝ stable */
.legend{display:grid; gap:8px; margin-top:14px}
.legend-row{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:10px 12px; border:1px solid var(--border); border-radius:14px; background:rgba(255,255,255,.02)}
.legend-row code{color:var(--text)}

.map-wrap{position:relative}
.map-canvas{
  width:100%;
  aspect-ratio: 16/9;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background: radial-gradient(800px 400px at 20% 20%, rgba(93,214,255,.08), transparent 60%),
              radial-gradient(800px 400px at 80% 30%, rgba(124,92,255,.08), transparent 60%),
              rgba(255,255,255,.02);
  display:block;
}
.map-overlay{
  position:absolute; inset:14px auto auto 14px;
  display:flex; gap:10px; flex-wrap:wrap; align-items:center;
}
.map-overlay .badge{background:rgba(11,15,20,.55); backdrop-filter: blur(10px)}
.side-list{max-height:420px; overflow:auto}
.input{
  width:100%;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.02);
  color:var(--text);
}
label{font-size:12px; color:var(--muted); display:block; margin:10px 0 6px}
.row{display:grid; grid-template-columns:1fr 1fr; gap:10px}
@media (max-width: 720px){.row{grid-template-columns:1fr}}

.modal-backdrop{
  position:fixed; inset:0;
  background:rgba(0,0,0,.78);
  backdrop-filter: blur(4px);
  display:none; align-items:center; justify-content:center;
  padding:20px;
  z-index:5000;
}
.modal{
  width:min(720px, 100%);
  background:rgba(10,14,20,.92);
  border:1px solid rgba(31,42,58,.95);
  border-radius:18px;
  box-shadow: 0 20px 60px rgba(0,0,0,.55);
  padding:18px;
  color: var(--text);
}
.modal h3{margin:0 0 8px}
.modal .muted{margin:0 0 10px}
.modal-actions{display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap; margin-top:12px}

/* Leaflet map container */
.leaflet-map{width:100%;height:520px;min-height:420px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:rgba(255,255,255,.02);}
@media (max-width: 720px){.leaflet-map{height:440px;min-height:360px;}}
.leaflet-control-zoom a{background:rgba(11,15,20,.90) !important;color:var(--text) !important;border:1px solid var(--border) !important;}
.leaflet-control-attribution{background:rgba(11,15,20,.65) !important;color:var(--muted) !important;border:1px solid rgba(31,42,58,.65) !important;border-radius:12px;padding:4px 8px !important;}

/* Modal readability */
.modal input, .modal select, .modal textarea{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(31,42,58,.85);
}
.modal .muted{color:rgba(220,230,255,.78)}


/* Print/PDF export */
@media print{
  header, nav, .topbar, .btnrow, .nav, .langswitch, .no-print { display:none !important; }
  body{ background:#fff !important; color:#000 !important; }
  .card{ box-shadow:none !important; border:1px solid #ddd !important; }
  a{ color:#000 !important; text-decoration:none !important; }
  .badge{ border:1px solid #ccc !important; }
}


#s4w-turnstile{ padding:10px; border:1px solid rgba(255,255,255,.08); border-radius:12px; background:rgba(0,0,0,.25); }
