/* ===========================================================================
   Diseño base de la página (heredado del original)
   =========================================================================== */
.hurricanes-page{background:linear-gradient(180deg,#1a1a2e 0%,#0d3b66 50%,#14213d 100%);color:#fff}
.hurricanes-hero{background:linear-gradient(135deg,rgba(13,59,102,.9),rgba(20,33,61,.9)),url('https://images.unsplash.com/photo-1509803874385-db7c23652552?w=1920') center/cover;padding:80px 20px;text-align:center}
.hurricanes-hero-content{max-width:900px;margin:0 auto}
.hurricanes-hero-icon{font-size:5rem;margin-bottom:20px;display:block;animation:spin-left 10s linear infinite}
@keyframes spin-left{from{transform:rotate(0deg)}to{transform:rotate(-360deg)}}
.hurricanes-hero h1{font-size:clamp(2.2rem,5vw,3.2rem);font-weight:800;margin:0 0 20px;font-family:'Plus Jakarta Sans',sans-serif;color:#fff}
.hurricanes-hero p{color:rgba(255,255,255,.9);font-size:1.2rem;max-width:700px;margin:0 auto 30px;line-height:1.7}
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.btn-hero{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;border-radius:14px;font-weight:700;font-size:16px;text-decoration:none;transition:all .3s}
.btn-hero.radar{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}
.btn-hero.alertas{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff}
.btn-hero.aprende{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}
.btn-hero:hover{transform:translateY(-3px)}
.hurricanes-content{max-width:1200px;margin:0 auto;padding:60px 20px}
.section-title{display:flex;align-items:center;gap:14px;font-size:1.8rem;font-weight:800;margin:60px 0 30px;font-family:'Plus Jakarta Sans',sans-serif;color:#fff}
.section-title:first-child{margin-top:0}

/* Categorías Saffir-Simpson */
.category-scale{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:50px}
@media(max-width:768px){.category-scale{grid-template-columns:repeat(2,1fr)}}
.cat-item{border-radius:16px;padding:24px 16px;text-align:center;transition:all .3s}
.cat-item:hover{transform:translateY(-5px)}
.cat-item.cat1{background:linear-gradient(135deg,#fbbf24,#f59e0b)}
.cat-item.cat2{background:linear-gradient(135deg,#f97316,#ea580c)}
.cat-item.cat3{background:linear-gradient(135deg,#ef4444,#dc2626)}
.cat-item.cat4{background:linear-gradient(135deg,#dc2626,#b91c1c)}
.cat-item.cat5{background:linear-gradient(135deg,#a855f7,#7c3aed)}
.cat-item h4{font-size:1.6rem;font-weight:800;margin:0 0 8px}
.cat-item .cat-wind{font-size:.9rem;opacity:.95;margin-bottom:4px}
.cat-item .cat-surge{font-size:.85rem;opacity:.85}

/* Alertas */
.alerts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:50px}
.alert-card{border-radius:16px;overflow:hidden;transition:all .3s}
.alert-card:hover{transform:translateY(-5px)}
.alert-header{padding:20px;display:flex;align-items:center;gap:14px}
.alert-header .alert-icon{font-size:2.2rem}
.alert-header h4{margin:0;font-size:1.1rem;font-weight:700;flex:1}
.alert-header .severity{background:rgba(255,255,255,.2);padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase}
.alert-card.hw .alert-header{background:linear-gradient(135deg,#dc2626,#991b1b)}
.alert-card.hwatch .alert-header{background:linear-gradient(135deg,#f97316,#ea580c)}
.alert-card.tsw .alert-header{background:linear-gradient(135deg,#eab308,#ca8a04)}
.alert-card.tswatch .alert-header{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}
.alert-card.surge .alert-header{background:linear-gradient(135deg,#0891b2,#0e7490)}
.alert-body{padding:20px;background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.05))}
.alert-body p{color:rgba(255,255,255,.85);line-height:1.6;margin:0}
.alert-body p strong{color:#fff}

/* Alertas pareadas (Aviso vs Vigilancia) */
.alerts-pair{margin-bottom:40px}
.alerts-pair-title{display:flex;align-items:center;gap:14px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.12);flex-wrap:wrap}
.alerts-pair-title .pair-icon{font-size:1.8rem}
.alerts-pair-title h3{margin:0;font-size:1.25rem;font-weight:700;color:#fff;font-family:'Plus Jakarta Sans',sans-serif}
.alerts-pair-title .pair-sub{color:rgba(255,255,255,.6);font-size:.9rem;margin-left:auto;font-weight:500}
.alerts-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:768px){.alerts-grid-2{grid-template-columns:1fr}.alerts-pair-title .pair-sub{margin-left:0;width:100%}}

/* ===========================================================================
   MAREJADA CICLÓNICA (sección destacada con slider)
   =========================================================================== */
.surge-section{background:linear-gradient(180deg,rgba(8,145,178,.15),rgba(13,59,102,.25));border-radius:24px;padding:36px;margin-bottom:50px;border:1px solid rgba(8,145,178,.25)}
.surge-intro p{color:rgba(255,255,255,.9);line-height:1.75;font-size:1.05rem;margin:0 0 28px}
.surge-intro p strong{color:#7dd3fc}

/* Header sliderview */
.surge-viz{background:rgba(0,0,0,.3);border-radius:18px;padding:24px;border:1px solid rgba(255,255,255,.08);margin-bottom:30px}
.surge-viz-header{text-align:center;margin-bottom:22px}
.surge-viz-header h3{margin:0 0 6px;font-size:1.3rem;font-family:'Plus Jakarta Sans',sans-serif;color:#fff;font-weight:700}
.surge-viz-header p{margin:0;color:rgba(255,255,255,.65);font-size:.95rem}

/* Escena */
.surge-stage{position:relative;background:#1a3a5c;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}
.surge-scene{width:100%;display:block;height:auto}

/* Indicador grande del nivel */
.surge-level-display{position:absolute;top:16px;right:18px;background:linear-gradient(135deg,rgba(220,38,38,.95),rgba(153,27,27,.95));color:#fff;padding:14px 22px;border-radius:14px;box-shadow:0 8px 24px rgba(220,38,38,.4);text-align:center;backdrop-filter:blur(6px);transition:background .3s}
.surge-level-display.safe{background:linear-gradient(135deg,rgba(34,197,94,.95),rgba(22,163,74,.95));box-shadow:0 8px 24px rgba(34,197,94,.3)}
.surge-level-display.warn{background:linear-gradient(135deg,rgba(249,115,22,.95),rgba(234,88,12,.95));box-shadow:0 8px 24px rgba(249,115,22,.4)}
.surge-level-display.danger{background:linear-gradient(135deg,rgba(220,38,38,.95),rgba(153,27,27,.95));box-shadow:0 8px 24px rgba(220,38,38,.5)}
.surge-level-display.extreme{background:linear-gradient(135deg,#7c3aed,#5b21b6);box-shadow:0 8px 28px rgba(124,58,237,.5)}
.surge-level-number{font-size:2.4rem;font-weight:800;line-height:1;font-family:'Plus Jakarta Sans',sans-serif}
.surge-level-unit{font-size:1rem;font-weight:600;opacity:.85;margin-top:2px}
.surge-level-meters{font-size:.78rem;opacity:.75;margin-top:4px;letter-spacing:.04em}

/* Slider */
.surge-control{margin-top:24px;padding:0 8px}
.surge-slider-input{-webkit-appearance:none;appearance:none;width:100%;height:8px;background:linear-gradient(90deg,#22c55e 0%,#22c55e 20%,#eab308 20%,#eab308 40%,#f97316 40%,#f97316 60%,#dc2626 60%,#dc2626 80%,#7c3aed 80%);border-radius:6px;outline:none;cursor:pointer}
.surge-slider-input::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:26px;height:26px;border-radius:50%;background:#fff;cursor:pointer;border:3px solid #0d3b66;box-shadow:0 4px 12px rgba(0,0,0,.4);transition:transform .2s}
.surge-slider-input::-webkit-slider-thumb:hover{transform:scale(1.15)}
.surge-slider-input::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:#fff;cursor:pointer;border:3px solid #0d3b66;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.surge-ticks{display:flex;justify-content:space-between;margin-top:10px;color:rgba(255,255,255,.5);font-size:.85rem;font-weight:600;padding:0 4px}
.surge-ticks span.key{color:#fff;font-weight:800}
.surge-ticks span{position:relative}

/* Descripción dinámica */
.surge-description{margin-top:22px;padding:18px 22px;background:rgba(0,0,0,.25);border-radius:12px;border-left:4px solid #0891b2;color:rgba(255,255,255,.92);line-height:1.65;min-height:80px;transition:border-color .3s}
.surge-description.safe{border-left-color:#22c55e}
.surge-description.warn{border-left-color:#f97316}
.surge-description.danger{border-left-color:#dc2626}
.surge-description.extreme{border-left-color:#7c3aed}
.surge-description h4{margin:0 0 8px;font-size:1.05rem;color:#fff;font-weight:700}
.surge-description p{margin:0;font-size:.95rem}

/* Datos clave (facts) */
.surge-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:900px){.surge-facts{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.surge-facts{grid-template-columns:1fr}}
.surge-fact{background:rgba(0,0,0,.3);border-radius:14px;padding:18px;display:flex;align-items:center;gap:14px;border:1px solid rgba(255,255,255,.08)}
.surge-fact .fact-icon{font-size:2.2rem;flex-shrink:0}
.surge-fact .fact-number{font-size:1.5rem;font-weight:800;font-family:'Plus Jakarta Sans',sans-serif;color:#7dd3fc;line-height:1}
.surge-fact .fact-label{font-size:.82rem;color:rgba(255,255,255,.7);margin-top:4px;line-height:1.4}

/* Temporada */
.season-info{background:linear-gradient(135deg,rgba(139,92,246,.3),rgba(139,92,246,.1));border-radius:20px;padding:40px;margin-bottom:50px;border:1px solid rgba(139,92,246,.3)}
.season-info h3{font-size:1.4rem;color:#c4b5fd;margin-bottom:16px}
.season-info p{color:rgba(255,255,255,.85);line-height:1.7;margin-bottom:16px}
.season-info .season-dates{font-size:1.3rem;font-weight:800;color:#fff;background:rgba(0,0,0,.2);display:inline-block;padding:12px 24px;border-radius:12px;margin-top:10px}

/* Recomendaciones */
.recommendations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:40px}
@media(max-width:900px){.recommendations-grid{grid-template-columns:1fr}}
.rec-card{background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.05));border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}
.rec-header{padding:24px;text-align:center}
.rec-header .rec-icon{font-size:3rem;margin-bottom:12px;display:block}
.rec-header h3{margin:0;font-size:1.3rem;font-weight:700}
.rec-card.before .rec-header{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}
.rec-card.during .rec-header{background:linear-gradient(135deg,#dc2626,#b91c1c)}
.rec-card.after .rec-header{background:linear-gradient(135deg,#22c55e,#16a34a)}
.rec-body{padding:24px}
.rec-body ul{list-style:none;margin:0;padding:0}
.rec-body ul li{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.9);line-height:1.5}
.rec-body ul li:last-child{border-bottom:none}
.rec-body ul li::before{content:'✓';color:#34d399;font-weight:bold;flex-shrink:0}

/* CTA y fuentes */
.cta-box{background:linear-gradient(135deg,#f97316,#ea580c);border-radius:20px;padding:50px 40px;text-align:center;margin:50px 0}
.cta-box h3{font-size:1.6rem;margin:0 0 16px;font-family:'Plus Jakarta Sans',sans-serif}
.cta-box p{color:rgba(255,255,255,.9);font-size:1.1rem;margin:0 0 28px}
.cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn-cta{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;border-radius:12px;font-weight:700;font-size:16px;text-decoration:none;transition:all .3s}
.btn-cta.white{background:#fff;color:#ea580c}
.btn-cta.outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}
.btn-cta:hover{transform:translateY(-3px)}
.sources-box{background:rgba(255,255,255,.05);border-radius:12px;padding:24px;margin-top:40px;border:1px solid rgba(255,255,255,.1)}
.sources-box h4{color:rgba(255,255,255,.6);font-size:13px;text-transform:uppercase;margin:0 0 12px}
.sources-box p{color:rgba(255,255,255,.6);font-size:14px;margin:0}
.sources-box a{color:#c4b5fd}

/* ===========================================================================
   TRACKER EN VIVO (nuevo bloque)
   =========================================================================== */
.tracker-section{max-width:1280px;margin:-40px auto 0;padding:0 20px;position:relative;z-index:2}
.tracker-card{background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.03));border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 60px rgba(0,0,0,.4);backdrop-filter:blur(10px)}
.tracker-header{padding:24px 28px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:linear-gradient(135deg,rgba(220,38,38,.35),rgba(153,27,27,.25));border-bottom:1px solid rgba(255,255,255,.1)}
.tracker-header.calm{background:linear-gradient(135deg,rgba(59,130,246,.25),rgba(29,78,216,.15))}
.tracker-header .tracker-title{font-size:1.4rem;font-weight:800;font-family:'Plus Jakarta Sans',sans-serif;margin:0;display:flex;align-items:center;gap:12px}
.tracker-header .pulse-dot{width:12px;height:12px;background:#34d399;border-radius:50%;animation:pulse-live 1.5s infinite;box-shadow:0 0 12px #34d399}
@keyframes pulse-live{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}
.tracker-header .updated-badge{margin-left:auto;font-size:.85rem;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:8px;background:rgba(0,0,0,.25);padding:8px 14px;border-radius:20px}

/* Layout interno: cards de tormenta + mapa */
.tracker-body{display:grid;grid-template-columns:320px 1fr;gap:0}
@media(max-width:992px){.tracker-body{grid-template-columns:1fr}}

/* Panel lateral con cards de sistemas */
.storm-panel{padding:20px;background:rgba(0,0,0,.2);border-right:1px solid rgba(255,255,255,.08);max-height:640px;overflow-y:auto}
@media(max-width:992px){.storm-panel{border-right:none;border-bottom:1px solid rgba(255,255,255,.08);max-height:none}}
.storm-panel::-webkit-scrollbar{width:6px}
.storm-panel::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}

.storm-card{background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.04));border:2px solid rgba(255,255,255,.1);border-radius:14px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .25s}
.storm-card:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.3)}
.storm-card.active{border-color:#fbbf24;background:linear-gradient(135deg,rgba(251,191,36,.18),rgba(251,191,36,.06));box-shadow:0 4px 20px rgba(251,191,36,.15)}
.storm-card-name{font-weight:700;font-size:1.05rem;margin:0 0 4px;color:#fff;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.storm-card-desc{font-size:.82rem;color:rgba(255,255,255,.65);margin-bottom:10px}

/* Badge categoría */
.cat-badge{display:inline-block;padding:3px 10px;border-radius:10px;font-weight:800;font-size:.78rem;letter-spacing:.04em}
.cat-badge.cat-TD{background:#5BA4CF;color:#0d1e2e}
.cat-badge.cat-TS{background:#00FAF4;color:#003942}
.cat-badge.cat-CAT1{background:#FFFFCC;color:#5c4e00}
.cat-badge.cat-CAT2{background:#FFE775;color:#5c4400}
.cat-badge.cat-CAT3{background:#FFC140;color:#4d2e00}
.cat-badge.cat-CAT4{background:#FF8F20;color:#fff}
.cat-badge.cat-CAT5{background:linear-gradient(135deg,#FF6060,#a855f7);color:#fff}
.cat-badge.cat-UNK{background:#666;color:#fff}

/* Grid de stats dentro de cada card */
.storm-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:8px}
.storm-stat-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.55)}
.storm-stat-value{font-size:.95rem;font-weight:700;color:#fff}

/* Estado "sin sistemas" */
.no-storms-card{text-align:center;padding:60px 30px}
.no-storms-card .icon{font-size:4.5rem;margin-bottom:18px;opacity:.7}
.no-storms-card h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.5rem;margin-bottom:12px;color:#fff}
.no-storms-card p{color:rgba(255,255,255,.7);line-height:1.7;max-width:560px;margin:0 auto}

/* Wrapper del mapa */
.map-wrapper{position:relative;background:#e9f0f5}
#tropical-map{width:100%;height:640px}
@media(max-width:992px){#tropical-map{height:520px}}
@media(max-width:600px){#tropical-map{height:420px}}

/* ===========================================================================
   Dock inferior (botones de productos estilo capturas originales)
   =========================================================================== */
.map-dock{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);background:rgba(20,33,61,.95);border-radius:14px;padding:8px;display:flex;gap:6px;border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(10px);box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:2;align-items:center;flex-wrap:wrap;max-width:calc(100% - 28px)}
.dock-btn{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:#fff;padding:8px 14px;border-radius:10px;display:inline-flex;align-items:center;gap:8px;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap}
.dock-btn:hover:not(:disabled){background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.25)}
.dock-btn.active{background:linear-gradient(135deg,rgba(0,250,244,.18),rgba(91,164,207,.18));border-color:#00FAF4;color:#00FAF4}
.dock-btn:disabled{opacity:.45;cursor:not-allowed}
.dock-btn .dock-icon{font-size:1rem;line-height:1}
.dock-btn .dock-arrow{font-size:.7rem;opacity:.6;margin-left:2px}
.dock-btn#dock-animate.playing .dock-icon{color:#f59e0b}

/* Popups encima de los botones */
.dock-popup{position:absolute;bottom:calc(100% + 8px);left:0;background:rgba(20,33,61,.97);border:1px solid rgba(255,255,255,.18);border-radius:12px;padding:14px;min-width:240px;backdrop-filter:blur(10px);box-shadow:0 12px 32px rgba(0,0,0,.5);display:none;flex-direction:column;gap:6px}
.dock-popup.open{display:flex}
.dock-popup-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.65);margin-bottom:6px}
.dock-popup-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:8px;cursor:pointer;font-size:.88rem;color:#fff;transition:background .15s}
.dock-popup-item:hover:not(.disabled){background:rgba(255,255,255,.06)}
.dock-popup-item.disabled{opacity:.5;cursor:not-allowed}
.dock-popup-item input[type=checkbox]{accent-color:#00FAF4;cursor:pointer}
.dock-popup-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,.2)}
.dock-popup-tag{margin-left:auto;font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.dock-popup-tag.active{background:rgba(34,197,94,.25);color:#86efac}
.dock-popup-tag.soon{background:rgba(234,179,8,.25);color:#fde047}

/* Progress de animación */
.dock-anim-progress{display:none;align-items:center;gap:8px;padding:0 8px;min-width:160px}
.dock-anim-progress.visible{display:flex}
.anim-progress-label{font-size:.8rem;font-weight:700;color:#f59e0b;min-width:42px;text-align:center}
.anim-progress-track{flex:1;height:5px;background:rgba(255,255,255,.15);border-radius:3px;overflow:hidden}
.anim-progress-fill{height:100%;background:linear-gradient(90deg,#00FAF4,#f59e0b);border-radius:3px;width:0%;transition:width .25s linear}

/* Botón Experimental (badge BETA) */
.dock-btn-experimental{background:linear-gradient(135deg,rgba(124,58,237,.25),rgba(91,33,182,.18));border-color:rgba(168,85,247,.4)}
.dock-btn-experimental:hover:not(:disabled){background:linear-gradient(135deg,rgba(124,58,237,.4),rgba(91,33,182,.3));border-color:#a855f7}
.dock-badge-beta{background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;font-size:.55rem;font-weight:800;padding:2px 6px;border-radius:6px;letter-spacing:.06em;margin-left:4px;line-height:1}

/* ===========================================================================
   MODAL: Productos experimentales NHC
   =========================================================================== */
.exp-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;padding:24px}
.exp-modal.open{display:flex}
.exp-modal-backdrop{position:absolute;inset:0;background:rgba(10,15,28,.85);backdrop-filter:blur(8px);animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.exp-modal-dialog{position:relative;background:linear-gradient(180deg,#1a1a2e 0%,#0d3b66 100%);border-radius:24px;max-width:1180px;width:100%;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid rgba(168,85,247,.25);box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 80px rgba(124,58,237,.15);animation:slideUp .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes slideUp{from{opacity:0;transform:translateY(40px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}

.exp-modal-header{padding:28px 32px;display:flex;gap:16px;align-items:flex-start;border-bottom:1px solid rgba(255,255,255,.1);background:linear-gradient(135deg,rgba(124,58,237,.18),rgba(91,33,182,.08))}
.exp-modal-titles{flex:1;min-width:0}
.exp-modal-titles h2{margin:0 0 8px;font-family:'Plus Jakarta Sans',sans-serif;font-size:1.55rem;color:#fff;display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-weight:800}
.exp-modal-tag{background:linear-gradient(135deg,#a855f7,#7c3aed);padding:4px 12px;border-radius:14px;font-size:.7rem;font-weight:800;letter-spacing:.06em}
.exp-modal-titles p{margin:0;color:rgba(255,255,255,.75);font-size:.96rem;line-height:1.6;max-width:780px}
.exp-modal-close{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1;padding:0;flex-shrink:0}
.exp-modal-close:hover{background:rgba(255,255,255,.18);transform:rotate(90deg)}

.exp-modal-body{overflow-y:auto;padding:28px 32px;flex:1}
.exp-modal-body::-webkit-scrollbar{width:8px}
.exp-modal-body::-webkit-scrollbar-thumb{background:rgba(168,85,247,.3);border-radius:4px}

/* Grid de tarjetas */
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:1024px){.exp-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.exp-grid{grid-template-columns:1fr}}

.exp-card{background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden;transition:all .3s;display:flex;flex-direction:column}
.exp-card:hover{transform:translateY(-4px);border-color:rgba(168,85,247,.4);box-shadow:0 12px 32px rgba(0,0,0,.3),0 0 24px rgba(124,58,237,.1)}

.exp-card-header{padding:16px 18px;display:flex;align-items:center;gap:12px;color:#fff}
.exp-card-icon{font-size:1.8rem;line-height:1}
.exp-card-status{margin-left:auto;background:rgba(0,0,0,.3);padding:3px 10px;border-radius:12px;font-size:.65rem;font-weight:800;letter-spacing:.06em}

.exp-card-preview{background:#0a1424;padding:0;height:130px;overflow:hidden;display:flex;align-items:center;justify-content:center;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}
.exp-card-preview svg{width:100%;height:100%;display:block}

.exp-card-body{padding:18px 20px;flex:1;display:flex;flex-direction:column}
.exp-card-body h3{margin:0 0 8px;font-size:1.05rem;color:#fff;font-weight:700;font-family:'Plus Jakarta Sans',sans-serif}
.exp-card-body p{margin:0 0 16px;color:rgba(255,255,255,.72);line-height:1.55;font-size:.88rem;flex:1}
.exp-card-body p strong{color:#fff}
.exp-card-cta{background:linear-gradient(135deg,rgba(124,58,237,.25),rgba(91,33,182,.15));border:1px solid rgba(168,85,247,.35);color:#c4b5fd;padding:9px 14px;border-radius:10px;font-weight:700;cursor:pointer;font-size:.85rem;transition:all .2s;font-family:inherit;text-align:left}
.exp-card-cta:hover{background:linear-gradient(135deg,rgba(124,58,237,.4),rgba(91,33,182,.3));border-color:#a855f7;color:#fff;transform:translateX(4px)}

.exp-modal-footer{padding:20px 32px;border-top:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.2);margin-top:24px;border-radius:0 0 24px 24px}
.exp-modal-footer p{margin:0;color:rgba(255,255,255,.65);font-size:.85rem;line-height:1.6}
.exp-modal-footer a{color:#c4b5fd;text-decoration:none;font-weight:600}
.exp-modal-footer a:hover{text-decoration:underline}

/* Overlay de mockup en mapa (cuando se hace click en "Ver mockup") */
.exp-map-overlay{position:absolute;inset:0;background:rgba(13,30,52,.92);backdrop-filter:blur(4px);z-index:10;display:none;align-items:center;justify-content:center;padding:30px;flex-direction:column;color:#fff;text-align:center;border-radius:14px}
.exp-map-overlay.visible{display:flex;animation:fadeIn .25s}
.exp-map-overlay .exp-overlay-icon{font-size:4rem;margin-bottom:14px}
.exp-map-overlay h3{margin:0 0 8px;font-size:1.35rem;font-family:'Plus Jakarta Sans',sans-serif}
.exp-map-overlay p{margin:0 0 18px;max-width:580px;color:rgba(255,255,255,.75);line-height:1.6;font-size:.95rem}
.exp-map-overlay .exp-overlay-mock{max-width:520px;width:100%;margin-bottom:20px;border-radius:12px;border:1px solid rgba(168,85,247,.3);box-shadow:0 12px 32px rgba(0,0,0,.4)}
.exp-map-overlay .exp-overlay-close-btn{background:linear-gradient(135deg,#7c3aed,#5b21b6);border:none;color:#fff;padding:10px 22px;border-radius:10px;font-weight:700;cursor:pointer;font-family:inherit;font-size:.9rem;transition:transform .2s}
.exp-map-overlay .exp-overlay-close-btn:hover{transform:translateY(-2px)}
.exp-map-overlay .exp-overlay-tag{display:inline-block;background:rgba(168,85,247,.25);border:1px solid rgba(168,85,247,.4);padding:4px 12px;border-radius:14px;font-size:.7rem;font-weight:800;letter-spacing:.06em;margin-bottom:14px}

@media(max-width:768px){
  .exp-modal{padding:0}
  .exp-modal-dialog{max-height:100vh;border-radius:0}
  .exp-modal-header{padding:20px}
  .exp-modal-titles h2{font-size:1.25rem}
  .exp-modal-body{padding:20px}
  .exp-modal-footer{padding:16px 20px}
  .exp-map-overlay{padding:18px}
  .exp-map-overlay h3{font-size:1.1rem}
}

@media(max-width:992px){
  .map-overlay-controls{max-width:180px;padding:10px}
  .map-overlay-legend{font-size:.72rem;padding:10px}
  .map-dock{padding:6px;gap:4px}
  .dock-btn{padding:6px 10px;font-size:.8rem}
  .dock-btn .dock-label{display:none}
  .dock-anim-progress{min-width:120px}
}

/* Controles de capas flotantes sobre el mapa */
.map-overlay-controls{position:absolute;top:14px;left:14px;background:rgba(20,33,61,.92);border-radius:12px;padding:12px;border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(8px);max-width:220px;z-index:1}
.map-overlay-controls .ctrl-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.65);margin-bottom:10px}
.layer-toggle{display:flex;align-items:center;gap:8px;font-size:.85rem;padding:5px 0;cursor:pointer;color:#fff;user-select:none}
.layer-toggle input{accent-color:#fbbf24;cursor:pointer}
.layer-toggle .lyr-swatch{width:14px;height:14px;border-radius:3px;border:1px solid rgba(0,0,0,.25);flex-shrink:0}

/* Leyenda Saffir-Simpson compacta sobre el mapa */
.map-overlay-legend{position:absolute;bottom:14px;left:14px;background:rgba(20,33,61,.92);border-radius:12px;padding:12px 14px;border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(8px);z-index:1;font-size:.78rem}
.map-overlay-legend .ctrl-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.65);margin-bottom:8px}
.legend-row{display:flex;align-items:center;gap:8px;margin:3px 0;color:rgba(255,255,255,.9)}
.legend-row .legend-sw{width:22px;height:11px;border-radius:3px;border:1px solid rgba(0,0,0,.3);flex-shrink:0}
.legend-row .legend-lbl{font-weight:600;min-width:48px;font-size:.75rem}
.legend-row .legend-rng{color:rgba(255,255,255,.6);font-size:.7rem}

/* Popups Mapbox sobre fondo claro */
.mapboxgl-popup-content{border-radius:12px;padding:14px;font-family:inherit;background:#fff;color:#14213d;box-shadow:0 8px 24px rgba(0,0,0,.18)}
.mapboxgl-popup-tip{border-top-color:#fff;border-bottom-color:#fff}
.popup-title{font-weight:800;color:#0d3b66;margin-bottom:6px;font-size:1rem}
.popup-row{font-size:.85rem;margin:3px 0;color:#3a3a52}
.popup-row strong{color:#14213d}
.popup-cat{display:inline-block;margin-top:6px;padding:3px 8px;border-radius:8px;font-size:.72rem;font-weight:700;letter-spacing:.04em}
/* Marcador HTML de los puntos de pronóstico (centrado, anclado por Mapbox) */
.trop-point{cursor:pointer;display:flex;align-items:center;justify-content:center}
.trop-point svg{width:100%;height:100%;display:block}

/* Source/attribution más sutil */
.mapboxgl-ctrl-attrib{font-size:10px;background:rgba(255,255,255,.85)}

@media(max-width:992px){
  .map-overlay-controls{max-width:180px;padding:10px}
  .map-overlay-legend{font-size:.72rem;padding:10px}
}
@media(max-width:600px){
  .tracker-section{margin-top:-20px;padding:0 12px}
  .tracker-header{padding:16px 18px}
  .tracker-header .tracker-title{font-size:1.15rem}
  .tracker-header .updated-badge{margin-left:0;font-size:.75rem}
  .storm-panel{padding:14px;max-height:none}
  .map-overlay-controls{position:static;max-width:none;margin:10px;border-radius:10px}
  .map-overlay-legend{position:static;margin:0 10px 10px;border-radius:10px}
}
