    :root {
      --accent:      #e63c2f;
      --accent-glow: rgba(230,60,47,0.25);
      --bg-dark:     #0e0e10;
      --bg-card:     #16161a;
      --bg-panel:    #1c1c22;
      --border:      rgba(255,255,255,0.07);
      --border-hov:  rgba(255,255,255,0.16);
      --text-hi:     #f0f0f0;
      --text-mid:    #999aaa;
      --text-lo:     #44445a;
      --r-sm:        6px;
      --r-md:        12px;
      --r-lg:        18px;
      --r-xl:        24px;
      --font-h:      'Syne', sans-serif;
      --font-b:      'DM Sans', sans-serif;
    }

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }

    body {
      background: var(--bg-dark);
      color: var(--text-hi);
      font-family: var(--font-b);
      font-size: 15px;
      line-height: 1.6;
    }

    .ocultar {display: none;}

    /* ── HEADER ─────────────────────────────────────────── */
    .site-header {
      padding: 52px 0 36px;
      position: relative;
      overflow: hidden;
    }
    .site-header::before {
      content: '';
      position: absolute; inset: 0;
      background:
        radial-gradient(ellipse 60% 50% at 8% 20%, rgba(230,60,47,0.12) 0%, transparent 70%),
        radial-gradient(ellipse 40% 40% at 88% 75%, rgba(90,70,220,0.06) 0%, transparent 70%);
      pointer-events: none;
    }

    .container-fluid-imn {
      display: flex;
      justify-content: space-between;
    }

    .eyebrow {
      display: inline-flex; align-items: center; gap: 7px;
      font-size: 16.5px; font-weight: 700; letter-spacing: 0.13em;
      text-transform: uppercase; color: var(--accent);
      background: rgba(230,60,47,0.10); border: 1px solid rgba(230,60,47,0.22);
      border-radius: 100px; padding: 4px 13px; margin-bottom: 18px;
    }

    .site-title {
      font-family: var(--font-h);
      font-size: clamp(20px, 4.5vw, 40px);
      font-weight: 800; line-height: 1.08;
      letter-spacing: -0.03em; color: #fff; margin-bottom: 12px;
    }
    .site-title span {
      background: linear-gradient(135deg, var(--accent) 0%, #ff9080 100%);
      -webkit-background-clip: text; -webkit-text-fill-color: transparent;
      background-clip: text;
    }

    .site-desc {
      font-size: 14.5px; color: var(--text-mid);
      max-width: 500px; font-weight: 300; line-height: 1.75;
    }

    /* ── LOGO HEADER ─── */
    .header-logo {
      position: absolute;
      top: 28px;
      right: 24px;
      width: 140px;
      opacity: 0.92;
      filter: brightness(1.1);
    }


    /* Stats row */
    .stats-row {
      display: flex; gap: 28px; margin-top: 28px; flex-wrap: wrap;
      align-items: center;
      padding-top: 20px;
    }
    .stat-item { display: flex; flex-direction: column; gap: 2px; }
    .stat-num {
      font-family: var(--font-h); font-size: 24px;
      font-weight: 700; color: #fff; line-height: 1;
    }
    .stat-lbl { font-size: 11px; color: var(--text-mid); letter-spacing: 0.04em; }
    .stat-div { width: 1px; background: var(--border); height: 34px; }

    /* ── STICKY NAV WRAP ──────────────────────────────────── */
    .nav-wrap {
      position: sticky; top: 0; z-index: 100;
      background: rgba(14,14,16,0.92);
      backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
      border-bottom: 1px solid var(--border);
    }

    /* ── VARIABLES NAV (nivel 1) ──────────────────────────── */
    .nav-vars {
      display: flex; overflow-x: auto; scrollbar-width: none;
      border-bottom: 1px solid var(--border);
    }
    .nav-vars::-webkit-scrollbar { display: none; }

    .btn-var {
      display: flex; align-items: center; gap: 7px;
      padding: 13px 20px;
      font-family: var(--font-b); font-size: 13px; font-weight: 500;
      color: var(--text-mid); background: transparent; border: none;
      border-bottom: 2px solid transparent; cursor: pointer;
      white-space: nowrap; transition: color .18s, border-color .18s;
      letter-spacing: 0.01em;
    }
    .btn-var i { font-size: 15px; opacity: .65; }
    .btn-var:hover { color: var(--text-hi); }
    .btn-var.active { color: #fff; border-bottom-color: var(--accent); }
    .btn-var.active i { opacity: 1; }

    /* ── MESES NAV (nivel 2) ──────────────────────────────── */
    .nav-meses {
      display: flex; overflow-x: auto; scrollbar-width: none;
      padding: 0 6px;
    }
    .nav-meses::-webkit-scrollbar { display: none; }

    .btn-mes {
      padding: 10px 16px;
      font-family: var(--font-b); font-size: 12.5px; font-weight: 500;
      color: var(--text-mid); background: transparent; border: none;
      border-bottom: 2px solid transparent; cursor: pointer;
      white-space: nowrap; transition: color .15s, border-color .15s;
    }
    .btn-mes:hover { color: var(--text-hi); }
    .btn-mes.active { color: var(--accent); border-bottom-color: var(--accent); }

    /* ── SUB-VARS NAV (nivel 3 — solo Distritales) ──────── */
    .nav-subvars-wrap {
      display: none;
      border-top: 1px solid var(--border);
      background: rgba(255,255,255,0.02);
    }
    .nav-subvars-wrap.visible { display: block; }

    .nav-subvars {
      display: flex; overflow-x: auto; scrollbar-width: none;
      padding: 0 6px;
    }
    .nav-subvars::-webkit-scrollbar { display: none; }

    .btn-sub {
      padding: 8px 14px;
      font-family: var(--font-b); font-size: 12px; font-weight: 500;
      color: var(--text-mid); background: transparent; border: none;
      border-bottom: 2px solid transparent; cursor: pointer;
      white-space: nowrap; transition: color .15s, border-color .15s;
    }
    .btn-sub:hover { color: var(--text-hi); }
    .btn-sub.active { color: #f0b429; border-bottom-color: #f0b429; }

    /* ── CONTENT ─────────────────────────────────────────── */
    .content-area { padding: 28px 0 64px; }

    /* ── VAR SECTIONS ─────────────────────────────────────── */
    .var-section { display: none; }
    .var-section.active { display: block; animation: fadeUp .22s ease; }

    /* ── MES PANELS ───────────────────────────────────────── */
    .mes-panel { display: none; }
    .mes-panel.active { display: block; animation: fadeUp .2s ease; }

    /* ── SUB PANELS (3er nivel) ────────────────────────────── */
    .sub-panel { display: none; }
    .sub-panel.active { display: block; animation: fadeUp .18s ease; }

    @keyframes fadeUp {
      from { opacity: 0; transform: translateY(5px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    /* ── MAPA CARD ────────────────────────────────────────── */
    .mapa-card {
      background: var(--bg-panel);
      border: 1px solid var(--border);
      border-radius: var(--r-xl);
      overflow: hidden;
      position: relative;
      transition: border-color .2s;
    }
    .mapa-card:hover { border-color: var(--border-hov); }
    .mapa-card::after {
      content: '';
      position: absolute; top: 0; left: 0;
      width: 140px; height: 3px;
      background: linear-gradient(90deg, var(--accent), transparent);
    }

    .mapa-card-header {
      display: flex; align-items: center;
      justify-content: space-between;
      padding: 16px 22px 14px;
      border-bottom: 1px solid var(--border);
    }
    .mapa-meta { display: flex; align-items: center; gap: 10px; }
    .mapa-icon {
      width: 34px; height: 34px; border-radius: 9px;
      background: rgba(230,60,47,0.13);
      display: flex; align-items: center; justify-content: center;
      font-size: 17px; color: var(--accent); flex-shrink: 0;
    }
    .mapa-titulo {
      font-family: var(--font-h); font-size: 14.5px;
      font-weight: 700; color: #fff; line-height: 1.2;
    }
    .mapa-subtitulo { font-size: 11px; color: var(--text-mid); margin-top: 1px; }

    .mapa-actions { display: flex; gap: 7px; }
    .btn-icon {
      width: 32px; height: 32px; border-radius: var(--r-sm);
      background: rgba(255,255,255,0.04); border: 1px solid var(--border);
      color: var(--text-mid);
      display: flex; align-items: center; justify-content: center;
      cursor: pointer; font-size: 14px;
      transition: all .15s; text-decoration: none;
    }
    .btn-icon:hover { background: rgba(255,255,255,0.09); color: var(--text-hi); border-color: var(--border-hov); }

    /* Map body — full width */
    .mapa-body {
      position: relative;
      min-height: 460px;
      display: flex; align-items: center; justify-content: center;
      overflow: hidden;
    }
    .mapa-body img {
      width: 100%; height: auto; display: block; object-fit: contain;
    }

    /* Placeholder */
    .mapa-placeholder {
      display: flex; flex-direction: column;
      align-items: center; justify-content: center;
      gap: 12px; padding: 60px 40px; text-align: center; width: 100%;
    }
    .ph-grid {
      display: grid; grid-template-columns: repeat(6, 1fr);
      gap: 3px; width: 100%; max-width: 360px; margin-bottom: 6px;
    }
    .ph-cell { height: 30px; border-radius: 3px; opacity: .32; }
    .c1{background:#3b82f6} .c2{background:#22c55e} .c3{background:#eab308}
    .c4{background:#f97316} .c5{background:#ef4444} .c6{background:#a855f7}

    .ph-title {
      font-family: var(--font-h); font-size: 16px;
      font-weight: 700; color: var(--text-hi);
    }
    .ph-code {
      font-family: monospace; font-size: 11px;
      background: rgba(255,255,255,0.05); border: 1px solid var(--border);
      border-radius: 5px; padding: 4px 10px; color: var(--accent);
    }

    /* Badge por variable */
    .var-badge {
      font-size: 10px; font-weight: 700; letter-spacing: .08em;
      text-transform: uppercase; padding: 3px 10px;
      border-radius: 100px; border: 1px solid;
    }
    .vb-lluvia      { color:#60a5fa; border-color:rgba(96,165,250,.28);  background:rgba(96,165,250,.09); }
    .vb-rafagas     { color:#a78bfa; border-color:rgba(167,139,250,.28); background:rgba(167,139,250,.09); }
    .vb-tempmax     { color:#fb923c; border-color:rgba(251,146,60,.28);  background:rgba(251,146,60,.09); }
    .vb-tempmin     { color:#34d399; border-color:rgba(52,211,153,.28);  background:rgba(52,211,153,.09); }
    .vb-composite   { color:#f9a8d4; border-color:rgba(249,168,212,.28); background:rgba(249,168,212,.09); }
    .vb-distritales { color:#fcd34d; border-color:rgba(252,211,77,.28);  background:rgba(252,211,77,.09); }

    .mapa-footer {
      padding: 12px 22px;
      border-top: 1px solid var(--border);
      display: flex; align-items: center;
      justify-content: space-between; flex-wrap: wrap; gap: 8px;
    }
    .legend-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
    .legend-lbl { font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing:.09em; color: var(--text-lo); }
    .legend-chip { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text-mid); }
    .legend-dot  { width: 10px; height: 10px; border-radius: 2px; }

    /* ── FOOTER ────────────────────────────────────────── */
    .site-footer {
      border-top: 1px solid var(--border);
      padding: 22px 0;
      display: flex; align-items: center;
      justify-content: space-between; flex-wrap: wrap; gap: 12px;
    }
    .footer-brand {
      font-family: var(--font-h); font-size: 13px;
      font-weight: 700; color: var(--text-lo); letter-spacing:.04em;
    }
    .footer-vars {
      display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
    }
    .fv-chip {
      font-size: 10.5px; font-weight: 500;
      padding: 3px 10px; border-radius: 100px;
      border: 1px solid var(--border); color: var(--text-mid);
      cursor: pointer; transition: all .15s;
      background: transparent;
    }
    .fv-chip:hover { border-color: var(--border-hov); color: var(--text-hi); }
    .fv-chip.active { border-color: var(--accent); color: var(--accent); background: rgba(230,60,47,.08); }

    /* ── RESPONSIVE ─────────────────────────────────────── */
    @media (max-width: 768px) {
      .site-header { padding: 36px 0 26px; }
      .btn-var { padding: 11px 14px; font-size: 12px; }
      .btn-mes { padding: 9px 10px; font-size: 12px; }
      .mapa-body { min-height: 280px; }
      .header-logo { width: 100px; top: 18px; right: 16px;}
    }
