/* ============================================================
   Weather Center Live P.R. — tema claro / broadcast
   ============================================================ */
:root{
  --bg:#eef3fb;
  --surface:#ffffff;
  --surface-2:#f5f8ff;
  --tint:#e7eefb;
  --line:#d9e2f2;
  --ink:#0d1b3e;
  --muted:#5e6e8f;
  --blue:#0b5bd3;
  --blue-2:#1380ff;
  --sky:#19b6e8;
  --navy:#0a1b3d;
  --warn:#f5a623;
  --orange:#ff7a2f;
  --red:#e63148;
  --green:#1aa86a;
  --radius:16px;
  --shadow:0 8px 26px rgba(16,38,84,.10);
  --shadow-lg:0 18px 44px rgba(16,38,84,.16);
  --maxw:1280px;
}
html{color-scheme:light only}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);line-height:1.55;overflow-x:hidden;
  background:
    radial-gradient(1100px 520px at 12% -6%, rgba(150,170,200,.55), transparent 60%),
    radial-gradient(1000px 520px at 88% 2%, rgba(140,162,196,.50), transparent 58%),
    radial-gradient(1200px 700px at 50% 118%, rgba(150,170,202,.45), transparent 60%),
    linear-gradient(180deg,#c7d3e6 0%, #d7e0f0 38%, #e6edf8 100%);
  background-attachment:fixed;
}
/* textura suave de nubes */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background:
    radial-gradient(380px 200px at 20% 18%, rgba(255,255,255,.7), transparent 70%),
    radial-gradient(420px 220px at 70% 30%, rgba(255,255,255,.55), transparent 70%),
    radial-gradient(340px 180px at 45% 60%, rgba(255,255,255,.5), transparent 70%),
    radial-gradient(460px 240px at 85% 75%, rgba(255,255,255,.5), transparent 72%),
    radial-gradient(320px 170px at 10% 85%, rgba(255,255,255,.5), transparent 70%);
}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
h1,h2,h3{font-family:'Barlow Condensed','Inter',sans-serif;line-height:1.06;letter-spacing:.3px}

.live-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--red);margin-right:8px;vertical-align:middle;animation:pulse 1.8s infinite}
.dot-blue{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--blue-2);margin-right:7px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(230,49,72,.5)}70%{box-shadow:0 0 0 8px rgba(230,49,72,0)}100%{box-shadow:0 0 0 0 rgba(230,49,72,0)}}

/* ---------- TOP BAR ---------- */
.topbar{background:linear-gradient(90deg,var(--navy),var(--blue));color:#dce8ff;font-size:.8rem}
.topbar-inner{max-width:var(--maxw);margin:0 auto;padding:7px 22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.tb-clock strong{color:#fff;font-variant-numeric:tabular-nums}

/* ---------- HEADER ---------- */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);box-shadow:0 2px 12px rgba(16,38,84,.05)}
.header-inner{max-width:var(--maxw);margin:0 auto;padding:11px 22px;display:flex;align-items:center;gap:22px}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--blue),var(--sky));color:#fff;box-shadow:0 6px 16px rgba(11,91,211,.35)}
.brand-text{font-family:'Barlow Condensed';font-size:1.4rem;font-weight:700;letter-spacing:.4px;white-space:nowrap;color:var(--navy)}
.brand-text strong{color:var(--blue)}
.brand-text em{font-style:normal;color:var(--sky)}
.main-nav{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap}
.main-nav a{padding:9px 14px;border-radius:9px;font-size:.94rem;font-weight:600;color:var(--muted);transition:.18s}
.main-nav a:hover{color:var(--blue);background:var(--tint)}
.header-actions{display:flex;align-items:center;gap:12px}
.live-badge{display:inline-flex;align-items:center;gap:2px;background:#fff0f1;border:1px solid #f6c5cc;color:var(--red);padding:7px 13px;border-radius:999px;font-weight:800;font-size:.74rem;letter-spacing:.8px}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:24px;height:2px;background:var(--navy);border-radius:2px}

/* ---------- HERO ---------- */
.hero{padding:46px 0 10px;background:radial-gradient(900px 380px at 80% -40%, #d6e6ff, transparent 70%)}
.hero-head{max-width:760px;margin-bottom:26px}
.hero-head h1{font-size:clamp(2.1rem,4.6vw,3.4rem);font-weight:800;color:var(--navy)}
.hero-head h1 span{display:block;color:var(--blue)}
.hero-head p{color:var(--muted);font-size:1.08rem;margin-top:12px}
.outlook-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}

/* ---------- SECTIONS ---------- */
.section{padding:54px 0}
.section-tint{background:rgba(255,255,255,.5)}
.section-head{margin-bottom:26px}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.4rem);font-weight:800;color:var(--navy);display:flex;align-items:center}
.section-head p{color:var(--muted);margin-top:4px}

/* ---------- LIVE CARD (imagen en vivo) ---------- */
.live-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.2s;display:flex;flex-direction:column}
.live-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.live-card figcaption{display:flex;align-items:center;padding:12px 16px;font-weight:700;color:var(--navy);font-size:.96rem;border-bottom:1px solid var(--line);background:var(--surface-2)}
.live-card figcaption em{font-style:normal;color:var(--muted);font-weight:500;margin-left:6px;font-size:.84rem}
.live-card img{width:100%;display:block;background:#0a1b3d;min-height:160px;object-fit:contain;cursor:zoom-in}
.live-card .img-err{padding:26px 16px;color:var(--muted);font-size:.88rem;text-align:center}
.img-err a{color:var(--blue);font-weight:600}

.sat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}

/* ---------- PRONÓSTICO LOCAL ---------- */
.local-head{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;flex-wrap:wrap}
.local-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.unit-toggle{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:4px;box-shadow:var(--shadow)}
.unit-toggle button{border:0;background:none;font-family:inherit;font-weight:800;font-size:.95rem;color:var(--muted);padding:8px 16px;border-radius:8px;cursor:pointer;transition:.15s}
.unit-toggle button.active{background:linear-gradient(135deg,var(--blue),var(--sky));color:#fff}

/* alerta NWS para el pueblo */
.alert-banner{display:flex;align-items:flex-start;gap:14px;border-radius:var(--radius);padding:16px 18px;margin-bottom:20px;border-left:6px solid var(--warn);background:#fff8e8;box-shadow:var(--shadow)}
.alert-banner.sev-extreme,.alert-banner.sev-severe{border-left-color:var(--red);background:#fdecee}
.alert-banner.sev-moderate{border-left-color:var(--orange);background:#fff1e6}
.alert-banner .ab-ico{font-size:1.6rem;line-height:1.2}
.alert-banner .ab-body{flex:1}
.alert-banner .ab-title{font-weight:800;color:var(--navy);font-size:1.05rem}
.alert-banner .ab-sub{color:var(--muted);font-size:.88rem;margin-top:2px}
.alert-banner .ab-more{margin-top:6px}
.alert-banner .ab-more summary{cursor:pointer;color:var(--blue);font-weight:600;font-size:.85rem}
.alert-banner .ab-more p{color:#374a6b;font-size:.86rem;margin-top:8px;white-space:pre-line;max-height:200px;overflow:auto}

/* ---------- SISTEMAS ACTIVOS ---------- */
.town-picker{display:flex;align-items:center;gap:10px;font-weight:600;color:var(--muted)}
.town-picker select{font-family:inherit;font-size:1rem;font-weight:700;color:var(--navy);background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:11px 16px;cursor:pointer;box-shadow:var(--shadow);min-width:180px}
.town-picker select:focus{outline:none;border-color:var(--blue-2)}
.sub-h{font-size:1.25rem;color:var(--navy);margin:28px 0 14px}

.local-now{display:grid;grid-template-columns:1.1fr 2fr;gap:18px}
.now-main{background:linear-gradient(150deg,var(--blue),var(--sky));color:#fff;border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.now-main .nm-town{font-weight:700;opacity:.92}
.now-main .nm-row{display:flex;align-items:center;gap:14px;margin:6px 0 4px}
.now-main .nm-ico{font-size:3.6rem;line-height:1}
.now-main .nm-temp{font-size:4rem;font-weight:800;font-family:'Barlow Condensed';line-height:1}
.now-main .nm-cond{font-weight:600;opacity:.95}
.now-main .nm-feels{opacity:.85;font-size:.9rem;margin-top:2px}
.now-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.now-stat{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:center}
.now-stat .ns-k{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.5px}
.now-stat .ns-v{font-size:1.7rem;font-weight:800;font-family:'Barlow Condensed';color:var(--navy)}
.now-stat .ns-ico{font-size:1.2rem}

.hourly-scroll{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 16px}
.hourly-scroll::-webkit-scrollbar{height:8px}
.hourly-scroll::-webkit-scrollbar-thumb{background:#c2d2ec;border-radius:8px}
.hour-card{flex:0 0 auto;width:104px;text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 8px;box-shadow:var(--shadow)}
.hour-card .ht{color:var(--muted);font-size:.82rem;font-weight:600}
.hour-card .hi{font-size:1.7rem;margin:6px 0}
.hour-card .htemp{font-size:1.2rem;font-weight:800;font-family:'Barlow Condensed';color:var(--navy)}
.hour-card .hrain{color:var(--blue);font-size:.78rem;margin-top:3px}

.daily-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}
.day-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 10px;text-align:center;box-shadow:var(--shadow);transition:.18s}
.day-card:hover{transform:translateY(-3px);border-color:var(--blue-2)}
.day-card .dn{font-weight:700;text-transform:uppercase;letter-spacing:.4px;font-size:.82rem;color:var(--navy)}
.day-card .dd{color:var(--muted);font-size:.74rem;margin-bottom:6px}
.day-card .di{font-size:2rem;margin:4px 0}
.day-card .dhi{font-weight:800;font-size:1.15rem;font-family:'Barlow Condensed';color:var(--navy)}
.day-card .dlo{color:var(--muted);font-weight:600}
.day-card .drain{color:var(--blue);font-size:.76rem;margin-top:4px}

/* ---------- SISTEMAS ACTIVOS ---------- */
.storms-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.storm-loading,.storm-none{grid-column:1/-1;background:var(--surface);border:1px dashed var(--line);border-radius:var(--radius);padding:26px;text-align:center;color:var(--muted)}
.storm-card{background:var(--surface);border:1px solid var(--line);border-left:5px solid var(--blue-2);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.storm-card.cat-h{border-left-color:var(--red)}
.storm-card.cat-ts{border-left-color:var(--orange)}
.storm-card.cat-td{border-left-color:var(--warn)}
.storm-card h3{font-size:1.5rem;color:var(--navy)}
.storm-cat{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.6px;text-transform:uppercase;padding:4px 10px;border-radius:6px;background:var(--tint);color:var(--blue);margin-bottom:8px}
.storm-meta{list-style:none;margin-top:10px;font-size:.9rem}
.storm-meta li{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px dashed var(--line)}
.storm-meta span{color:var(--muted)}
.storm-meta strong{color:var(--navy)}

/* ---------- MODELOS ---------- */
.models-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.model-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);transition:.2s;position:relative;overflow:hidden}
.model-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--blue-2)}
.model-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--g)}
.model-tag{font-size:1.55rem;font-weight:800;font-family:'Barlow Condensed';color:var(--navy)}
.model-desc{color:var(--muted);font-size:.9rem;margin:6px 0 14px}
.model-go{color:var(--blue);font-weight:700;font-size:.9rem}

/* ---------- RADAR ---------- */
.radar-controls{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.radar-layers{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:4px;box-shadow:var(--shadow);flex-wrap:wrap}
.rchip{border:0;background:none;font-family:inherit;font-weight:700;font-size:.9rem;color:var(--muted);padding:9px 16px;border-radius:8px;cursor:pointer;transition:.15s}
.rchip.active{background:linear-gradient(135deg,var(--blue),var(--sky));color:#fff}
.radar-scheme{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--muted);font-size:.92rem}
.radar-scheme select{font-family:inherit;font-size:.92rem;font-weight:700;color:var(--navy);background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:9px 14px;cursor:pointer;box-shadow:var(--shadow)}
.radar-scheme select:focus{outline:none;border-color:var(--blue-2)}

.map{width:100%;height:520px;border-radius:var(--radius);border:1px solid var(--line);overflow:hidden;box-shadow:var(--shadow);background:#dfe8f5}
.map-basin{height:460px;margin-bottom:20px}
.storm-tip{background:var(--navy);color:#fff;border:0;font-weight:700;font-size:.78rem;padding:2px 7px;box-shadow:var(--shadow)}
.storm-tip::before{display:none}
.radar-timeline{display:flex;align-items:center;gap:14px;margin-top:14px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px 16px;box-shadow:var(--shadow)}
.play-btn{background:linear-gradient(135deg,var(--blue),var(--sky));color:#fff;border:0;width:42px;height:42px;border-radius:50%;font-size:1rem;cursor:pointer;flex-shrink:0}
.radar-timeline input[type=range]{flex:1;accent-color:var(--blue)}
.radar-clock{font-family:'Barlow Condensed';font-weight:700;font-size:1.1rem;min-width:60px;text-align:right;color:var(--navy)}

/* ---------- LINKS ---------- */
.links-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.link-col{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.link-col h3{color:var(--blue);font-size:1.2rem;margin-bottom:10px}
.link-col a{display:block;color:var(--ink);padding:6px 0;font-size:.92rem;border-bottom:1px solid var(--line);transition:.15s}
.link-col a:last-child{border-bottom:0}
.link-col a:hover{color:var(--blue);padding-left:5px}

/* ---------- EE.UU. (severo/tornados) ---------- */
.sat-grid.usa-grid{grid-template-columns:repeat(3,1fr)}
.usa-grid .live-card img{min-height:200px;background:#0a1b3d}

/* ---------- VIDEOS 9:16 ---------- */
.video-drop{border:2px dashed var(--blue-2);border-radius:var(--radius);background:rgba(255,255,255,.6);padding:30px;text-align:center;cursor:pointer;transition:.2s;margin-bottom:22px}
.video-drop:hover,.video-drop.drag{background:#e8f1ff;border-color:var(--blue)}
.video-drop .vd-ico{font-size:2.4rem}
.video-drop .vd-t{font-weight:800;color:var(--navy);font-size:1.15rem;margin-top:6px;font-family:'Barlow Condensed'}
.video-drop .vd-s{color:var(--muted);font-size:.9rem;margin-top:4px}
.video-drop input{display:none}
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.video-card{position:relative;background:#000;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:9/16}
.video-card video{width:100%;height:100%;object-fit:cover;display:block;background:#000}
.video-card .vc-name{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(0,0,0,.75));color:#fff;font-size:.78rem;font-weight:600;padding:18px 10px 8px;pointer-events:none}
.video-card .vc-del{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.55);color:#fff;border:0;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:.9rem;z-index:2}
.video-card .vc-del:hover{background:var(--red)}
.video-empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:20px}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--navy);color:#c5d4f0;padding-top:40px}
.footer-inner{display:grid;grid-template-columns:1.7fr 1fr;gap:30px;padding-bottom:28px}
.footer-brand .brand-text{color:#fff}.footer-brand .brand-text strong{color:var(--sky)}.footer-brand .brand-text em{color:#9fc3ff}
.footer-brand p{font-size:.88rem;margin-top:12px;max-width:560px;color:#aebfe0}
.footer-brand strong{color:#fff}
.footer-nav{display:flex;flex-direction:column;gap:9px;align-items:flex-start}
.footer-nav a{color:#aebfe0;transition:.15s}.footer-nav a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:16px 22px;text-align:center;font-size:.82rem;color:#9fb1d6}

/* ---------- LIGHTBOX ---------- */
.lightbox{position:fixed;inset:0;z-index:5000;background:rgba(8,18,40,.92);display:none;align-items:center;justify-content:center;padding:30px;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:95%;max-height:92vh;border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.lb-close{position:absolute;top:18px;right:26px;color:#fff;font-size:1.8rem;cursor:pointer;opacity:.8}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1024px){
  .models-grid{grid-template-columns:repeat(2,1fr)}
  .links-grid{grid-template-columns:repeat(2,1fr)}
  .daily-grid{grid-template-columns:repeat(4,1fr)}
  .local-now{grid-template-columns:1fr}
  .sat-grid.usa-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .daily-grid{grid-template-columns:repeat(2,1fr)}
  .now-stats{grid-template-columns:repeat(3,1fr)}
  .main-nav{position:fixed;top:96px;right:0;left:0;flex-direction:column;gap:0;background:#fff;border-bottom:1px solid var(--line);padding:8px 18px;transform:translateY(-150%);transition:.3s;box-shadow:var(--shadow-lg)}
  .main-nav.open{transform:translateY(0)}
  .main-nav a{padding:13px 6px;border-bottom:1px solid var(--line)}
  .nav-toggle{display:flex}
  .outlook-grid,.sat-grid,.sat-grid.usa-grid,.models-grid,.links-grid,.footer-inner{grid-template-columns:1fr}
  .section{padding:38px 0}
  .map{height:380px}
  .topbar-inner{justify-content:center}
}
