/* ============================================
   IncidentesCR - Styles v2
   ============================================ */

:root{
    --bg:#0f0f23;--surface:#1a1a2e;--surface-2:#16213e;--border:#2a2a4a;
    --text:#e0e0e0;--text-2:#a0a0b0;--accent:#e94560;--accent-2:#c23152;
    --green:#22c55e;--orange:#f97316;--yellow:#eab308;--red:#ef4444;--gray:#64748b;
    --radius:12px;--radius-sm:8px;--header-h:64px;--tab-h:56px;--qr-h:76px;
    --sidebar-w:180px;
    --ads-top-offset:0px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-tap-highlight-color:transparent}
a{color:var(--accent);text-decoration:none}
button{cursor:pointer;font-family:inherit}

/* Layout */
.main-app{max-width:900px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}
body.no-ads .main-app{max-width:100%}

/* Header */
.app-header{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.header-content{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:var(--header-h)}
.header-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{font-size:28px}
.logo-text h1{font-size:18px;font-weight:700;line-height:1.2}
.subtitle{font-size:11px;color:var(--text-2);text-transform:uppercase;letter-spacing:1px}
.btn-icon{background:none;border:none;color:var(--text);font-size:22px;padding:8px;border-radius:50%;transition:background .2s}
.btn-icon:hover{background:var(--surface-2)}

/* Map */
#map-section{position:relative;height:40vh;min-height:250px;max-height:450px}
#map{height:100%;width:100%;z-index:1;background:#f2f2f2}

/* Province Bar */
.province-bar{display:flex;gap:6px;padding:8px 12px;overflow-x:auto;background:var(--surface);border-bottom:1px solid var(--border);-webkit-overflow-scrolling:touch}
.province-bar::-webkit-scrollbar{display:none}
.prov-chip{flex-shrink:0;padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;background:var(--surface-2);color:var(--text-2);border:1px solid var(--border);transition:all .2s;white-space:nowrap;touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer}
.prov-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Map incident popup (Google InfoWindow + Leaflet): force readable text on light background */
.incident-popup{min-width:160px;max-width:260px;color-scheme:light;color:#16162a!important;background:#fff;font-family:system-ui,-apple-system,sans-serif;font-size:13px;line-height:1.35}
.incident-popup .ip-title{display:block;font-size:14px;margin:0 0 6px;color:#0d0d12!important}
.incident-popup .ip-meta,.incident-popup .ip-km{font-size:12px;color:#2a2a38!important;margin:0 0 4px}
.incident-popup .ip-desc{font-size:12px;color:#1a1a24!important;margin:6px 0}
.incident-popup .ip-time{font-size:11px;color:#4a4a5c!important;margin-top:8px}
.incident-popup .ip-img{display:block;width:140px;max-width:100%;height:auto;border-radius:6px;margin-top:6px;object-fit:cover}
.incident-popup .ip-vid{display:block;width:148px;max-width:100%;border-radius:6px;margin-top:6px}
.gm-style .gm-style-iw-c .incident-popup,.gm-style .gm-style-iw-d .incident-popup{color:#16162a!important}
.gm-style .gm-style-iw-c .incident-popup .ip-title,.gm-style .gm-style-iw-d .incident-popup .ip-title{color:#0d0d12!important}
.gm-style .gm-style-iw-c .incident-popup .ip-meta,.gm-style .gm-style-iw-c .incident-popup .ip-km,.gm-style .gm-style-iw-d .incident-popup .ip-meta,.gm-style .gm-style-iw-d .incident-popup .ip-km{color:#2a2a38!important}
.gm-style .gm-style-iw-c .incident-popup .ip-time,.gm-style .gm-style-iw-d .incident-popup .ip-time{color:#4a4a5c!important}
.leaflet-popup-content .incident-popup{color:#16162a!important}

/* Tabs */
.tabs{display:flex;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:var(--header-h);z-index:90}
.tab-btn{flex:1;padding:10px 0;background:none;border:none;border-bottom:3px solid transparent;color:var(--text-2);font-size:13px;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}
.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-icon{font-size:16px}

/* Tab Panels */
.tab-panel{display:none;padding:16px;padding-bottom:calc(var(--qr-h) + env(safe-area-inset-bottom, 0px) + 36px)}
.tab-panel.active{display:block}

/* Feed */
.feed-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.feed-header h2{font-size:16px}
.badge{background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:2px 10px;border-radius:12px}
.feed-list{display:flex;flex-direction:column;gap:10px}
.feed-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;border-left:4px solid var(--gray)}
.feed-card.type-accidente{border-left-color:var(--red)}
.feed-card.type-trafico{border-left-color:var(--orange)}
.feed-card.type-policia{border-left-color:#2563eb}
.feed-card.type-derrumbe{border-left-color:var(--yellow)}
.feed-card.type-cierre{border-left-color:var(--gray)}
.feed-card-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.feed-card-icon{font-size:22px}
.feed-card-type{font-weight:700;font-size:14px}
.feed-card-time{margin-left:auto;font-size:11px;color:var(--text-2)}
.feed-card-meta{font-size:12px;color:var(--text-2);margin-bottom:4px}
.feed-card-desc{font-size:13px;color:var(--text);line-height:1.4}
.feed-card-moderate{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.feed-card-moderate-label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;width:100%}
.incident-moderate-btn{padding:6px 10px;font-size:12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;transition:background .15s,border-color .15s}
.incident-moderate-btn:hover{background:var(--surface)}
.incident-moderate-btn--danger{border-color:rgba(239,68,68,.45);color:#f87171}
.incident-moderate-btn--danger:hover{background:rgba(239,68,68,.12)}
.popup-moderate{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.popup-moderate-label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;width:100%}
.my-reports-intro{font-size:12px!important;margin-bottom:10px!important}
.my-reports-list{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-direction:column;gap:10px}
.my-reports-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px}
.my-reports-item-head{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;color:var(--text)}
.my-reports-status{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--surface);border:1px solid var(--border);color:var(--text-2)}
.my-reports-status--active{border-color:rgba(34,197,94,.4);color:#4ade80}
.my-reports-status--inactive{opacity:.85}
.my-reports-actions{display:flex;flex-wrap:wrap;gap:6px}
.my-reports-empty{font-size:13px;color:var(--text-2);padding:8px 0}
.empty-state,.loading-state{text-align:center;padding:40px 20px;color:var(--text-2)}
.empty-state-icon{font-size:48px;display:block;margin-bottom:12px;opacity:.4}

select{width:100%;padding:10px 12px;background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;appearance:none}

/* Info */
.info-container{max-width:600px}
.info-container h2{font-size:18px;margin-bottom:12px}
.info-container h3{font-size:14px;margin:16px 0 8px;color:var(--accent)}
.info-container p,.info-container ol,.info-container ul{font-size:13px;color:var(--text-2);line-height:1.6;margin-bottom:8px}
.legend-list{display:flex;flex-direction:column;gap:8px}
.legend-item{display:flex;align-items:center;gap:10px;font-size:13px}
.legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}

/* Buttons */
.btn-primary{padding:12px 24px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;transition:background .2s}
.btn-primary:hover{background:var(--accent-2)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-secondary{padding:12px 24px;background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px}
.btn-full{width:100%}
.btn-lg{padding:14px;font-size:16px}

/* Quick Report Bar: contenedor fijo + pista con scroll (móvil); sin transform en el scroll (iOS) */
.quick-report-bar{
    position:fixed;bottom:0;left:0;right:0;width:100%;max-width:900px;margin:0 auto;
    background:var(--surface);border-top:1px solid var(--border);z-index:200;
    overflow:hidden;overscroll-behavior-x:contain;
    padding-bottom:env(safe-area-inset-bottom, 0px)
}
.quick-report-bar__track{
    display:flex;justify-content:flex-start;align-items:stretch;gap:6px;
    padding:6px 8px;padding-bottom:6px;
    overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;
    scrollbar-width:thin;scrollbar-color:var(--border) transparent;touch-action:pan-x;
    overscroll-behavior-x:contain
}
.quick-report-bar__track::-webkit-scrollbar{height:5px}
.quick-report-bar__track::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.quick-report-bar__track::-webkit-scrollbar-track{background:transparent}
.quick-report-bar--overflow .quick-report-bar__track{padding-right:min(56px, 14vw)}
.quick-report-bar__fade{
    position:absolute;right:0;top:0;bottom:0;width:40px;pointer-events:none;
    background:linear-gradient(90deg, transparent, var(--surface) 72%);
    opacity:0;transition:opacity .2s ease
}
.quick-report-bar--overflow:not(.quick-report-bar--end) .quick-report-bar__fade{opacity:1}
.quick-report-bar__hint{
    position:absolute;right:8px;top:50%;transform:translateY(-50%);
    display:flex;align-items:center;gap:2px;pointer-events:none;
    font-size:9px;font-weight:800;color:var(--text-2);text-transform:uppercase;letter-spacing:.4px;
    opacity:0;transition:opacity .2s ease;line-height:1
}
.quick-report-bar__hint-ar{font-size:11px;color:var(--accent);letter-spacing:-2px}
.quick-report-bar--overflow:not(.quick-report-bar--end) .quick-report-bar__hint{opacity:.92}
.qr-btn{
    flex:0 0 auto;min-width:56px;max-width:76px;scroll-snap-align:start;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 4px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-2);font-size:10px;font-weight:600;transition:all .15s;
    touch-action:pan-x;-webkit-tap-highlight-color:transparent
}
.qr-btn:active{transform:scale(.95)}
.qr-icon{font-size:26px;line-height:1}
.qr-label{font-size:9px;text-transform:uppercase;letter-spacing:.2px;line-height:1.15;text-align:center;word-break:break-word;hyphens:auto}
@media (min-width:720px){
    .quick-report-bar{padding-bottom:env(safe-area-inset-bottom, 0px)}
    .quick-report-bar__track{justify-content:space-around;overflow-x:visible;padding:8px 12px;padding-bottom:8px}
    .quick-report-bar__track .qr-btn{flex:1;min-width:0;max-width:none;scroll-snap-align:unset}
    .quick-report-bar__fade,.quick-report-bar__hint{display:none!important}
    .qr-icon{font-size:28px}
    .qr-label{font-size:10px;letter-spacing:.5px}
}
.qr-accidente:hover,.qr-accidente:active{background:rgba(239,68,68,.15);color:var(--red)}
.qr-trafico:hover,.qr-trafico:active{background:rgba(249,115,22,.15);color:var(--orange)}
.qr-policia:hover,.qr-policia:active{background:rgba(37,99,235,.15);color:#2563eb}
.qr-derrumbe:hover,.qr-derrumbe:active{background:rgba(234,179,8,.15);color:var(--yellow)}
.qr-cierre:hover,.qr-cierre:active{background:rgba(100,116,139,.15);color:var(--gray)}
.qr-lluvia:hover,.qr-lluvia:active{background:rgba(59,130,246,.15);color:#3b82f6}
.qr-neblina:hover,.qr-neblina:active{background:rgba(148,163,184,.15);color:#94a3b8}
.qr-aceite:hover,.qr-aceite:active{background:rgba(168,85,247,.15);color:#a855f7}

/* Modal */
.modal{display:none;position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.7);align-items:flex-end;justify-content:center;padding:0}
.modal.show{display:flex}
.modal-content{background:var(--surface);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;border-radius:var(--radius) var(--radius) 0 0;animation:slideUp .25s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border)}
.modal-header h2{font-size:16px}
.btn-close{background:none;border:none;color:var(--text-2);font-size:26px;padding:4px 8px}

/* Report Modal */
.report-type-display{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface-2);border-bottom:1px solid var(--border)}
.report-type-icon{font-size:32px}
.report-type-name{font-size:18px;font-weight:700}
.report-minimap{height:150px;border-bottom:1px solid var(--border)}
.report-body{padding:16px;display:flex;flex-direction:column;gap:12px}
.form-group.compact label{font-size:12px;color:var(--text-2);margin-bottom:4px;display:block}
.form-group.compact select,.form-group.compact textarea,.form-group.compact input{width:100%;padding:8px 10px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit}
.report-actions{display:flex;flex-direction:column;gap:8px;margin-top:8px}

/* Voice Input */
.voice-input-group{display:flex;gap:8px;align-items:flex-start}
.voice-input-group textarea{flex:1}
.btn-voice{width:44px;height:44px;border-radius:50%;border:2px solid var(--border);background:var(--surface-2);color:var(--text);font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.btn-voice.recording{background:var(--red);border-color:var(--red);color:#fff;animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.voice-status{font-size:11px;color:var(--accent);padding:2px 0}

/* Toast */
.toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%);background:var(--surface);color:var(--text);padding:12px 24px;border-radius:var(--radius);border:1px solid var(--border);font-size:13px;z-index:600;box-shadow:0 8px 32px rgba(0,0,0,.4);white-space:nowrap;transition:opacity .3s}
.toast.hidden{opacity:0;pointer-events:none}
.toast.success{border-color:var(--green);color:var(--green)}
.toast.error{border-color:var(--red);color:var(--red)}
.toast.warn{border-color:#f97316;color:#f97316}

/* GPS Loading */
.gps-loading{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--surface);padding:24px 32px;border-radius:var(--radius);border:1px solid var(--border);display:flex;align-items:center;gap:12px;z-index:550;font-size:14px;box-shadow:0 8px 32px rgba(0,0,0,.4)}

/* Utilities */
.hidden{display:none!important}
.text-muted{color:var(--text-2);font-size:12px}
.spinner{display:inline-block;width:22px;height:22px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Debug Panel */
/* ============================================
   AD SYSTEM
   ============================================ */

/* Sidebars */
.ad-sidebar{display:none!important}
.ad-sidebar-label{text-align:center;font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--text-2);opacity:.4;padding:6px 0}
.ad-mosaic{display:flex;flex-direction:column;gap:8px;padding:0 6px}
.ad-tile{display:block;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);transition:transform .2s,box-shadow .2s;background:var(--surface);position:relative}
.ad-tile:hover{transform:scale(1.03);box-shadow:0 4px 16px rgba(233,69,96,.12);border-color:var(--accent)}
.ad-tile--modal{cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:left;font:inherit;color:inherit;width:100%}
.ad-tile--modal:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.ad-tile-img{width:100%;height:auto;display:block;aspect-ratio:4/3;object-fit:cover}
a.ad-tile{text-decoration:none}

.ad-tile-caption{font-size:11px;line-height:1.35;color:var(--text-2);padding:6px 8px;border-top:1px solid var(--border);background:rgba(0,0,0,.15);display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
@media(min-width:1100px){.ad-sidebar .ad-tile-caption{font-size:10px;padding:5px 6px;-webkit-line-clamp:5}}

/* Ad contact bar (phone + WhatsApp links) */
.ad-contact-bar{display:flex;gap:0;border-top:1px solid var(--border)}
.ad-contact-link{flex:1;text-align:center;padding:6px 4px;font-size:11px;color:var(--text-2);text-decoration:none;transition:all .15s;background:var(--surface-2)}
.ad-contact-link:hover{color:var(--accent);background:var(--surface)}
.ad-wa-link{color:var(--green)}
.ad-wa-link:hover{color:#25d366;background:rgba(37,211,102,.1)}

/* Franja plan empresarial (arriba del todo) */
.ads-enterprise-wrap{background:linear-gradient(180deg, rgba(233,69,96,.1) 0%, rgba(26,26,46,.6) 100%);border-bottom:1px solid var(--border)}
.ads-enterprise-wrap.hidden{display:none!important}
.ads-enterprise-inner{max-width:min(900px,calc(100vw - 24px));margin:0 auto;padding:10px 12px 6px}
.ads-enterprise-label{display:block;font-size:9px;text-transform:uppercase;letter-spacing:1.2px;color:var(--accent);margin-bottom:8px;font-weight:600;opacity:.95}
.ads-enterprise-scroll{display:flex;flex-direction:row;flex-wrap:nowrap;gap:10px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.ads-enterprise-scroll::-webkit-scrollbar{height:5px}
.ads-enterprise-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.ads-enterprise-scroll .ad-tile{flex:0 0 auto;width:min(46vw,200px);max-width:200px;scroll-snap-align:start}
.ads-enterprise-scroll .ad-tile-img{aspect-ratio:16/10}
.ads-enterprise-wrap--expanded .ads-enterprise-scroll{flex-wrap:wrap;overflow-x:visible;scroll-snap-type:none;justify-content:flex-start}
.ads-enterprise-wrap--expanded .ads-enterprise-scroll .ad-tile{width:calc(50% - 5px);max-width:200px}
@media(min-width:520px){
    .ads-enterprise-wrap--expanded .ads-enterprise-scroll .ad-tile{width:calc(33.333% - 7px)}
}
.ads-enterprise-toggle{display:block;width:100%;margin-top:6px;padding:9px 12px;font-size:13px;color:var(--text-2);background:rgba(0,0,0,.2);border:1px solid var(--border);border-radius:var(--radius-sm);transition:color .15s,border-color .15s,background .15s}
.ads-enterprise-toggle:hover{color:var(--accent);border-color:rgba(233,69,96,.45);background:rgba(233,69,96,.06)}
.ads-enterprise-toggle.hidden{display:none!important}
.ads-load-more{display:block;width:100%;margin-top:10px;padding:10px 14px;font-size:13px;font-weight:500;color:var(--text);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color .15s,color .15s}
.ads-load-more:hover{border-color:var(--accent);color:var(--accent)}
.ads-load-more.hidden{display:none!important}

/* Mobile ad banner */
.ad-mobile-banner{background:var(--surface);border-bottom:1px solid var(--border);padding:8px}
.ad-mobile-banner.hidden{display:none!important}
.ad-mobile-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.ad-mobile-grid .ad-tile{border-radius:var(--radius-sm)}
.ad-mobile-grid .ad-tile-img{aspect-ratio:16/9}

/* Desktop sidebars */
@media(min-width:1100px){
    .ad-mobile-banner{display:none!important}
    .ads-enterprise-inner{max-width:min(900px,calc(100vw - 2 * var(--sidebar-w) - 48px))}
    .ads-enterprise-scroll .ad-tile{width:168px}
    .ad-sidebar.has-ads{display:block!important;position:fixed;top:var(--ads-top-offset);bottom:0;width:var(--sidebar-w);overflow-y:auto;padding:12px 0;z-index:50}
    .ad-sidebar-left.has-ads{left:calc(50% - 450px - var(--sidebar-w) - 20px)}
    .ad-sidebar-right.has-ads{right:calc(50% - 450px - var(--sidebar-w) - 20px)}
    .ad-sidebar::-webkit-scrollbar{width:0}
}
@media(min-width:1400px){
    .ad-sidebar{width:220px}
}

/* Modal anuncio (imagen + texto completo, responsivo) */
.modal-public-ad{position:fixed;inset:0;z-index:600;display:flex;align-items:flex-end;justify-content:center;padding:0;font-size:15px}
.modal-public-ad.hidden{display:none!important}
.modal-public-ad__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(2px)}
.modal-public-ad__dialog{position:relative;width:100%;max-width:520px;max-height:min(92dvh,920px);overflow-y:auto;overflow-x:hidden;background:var(--surface);border:1px solid var(--border);border-radius:16px 16px 0 0;box-shadow:0 -12px 48px rgba(0,0,0,.5);animation:adModalSlideUp .28s ease}
@keyframes adModalSlideUp{from{transform:translateY(110%);opacity:.85}to{transform:translateY(0);opacity:1}}
@media(min-width:520px){
    .modal-public-ad{align-items:center;padding:max(12px,env(safe-area-inset-bottom));padding-bottom:max(16px,env(safe-area-inset-bottom))}
    .modal-public-ad__dialog{border-radius:var(--radius);max-height:min(88dvh,860px);animation:adModalPop .22s ease}
    @keyframes adModalPop{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
}
.modal-public-ad__close{position:absolute;top:10px;right:10px;z-index:2;width:42px;height:42px;border:none;border-radius:50%;background:rgba(15,15,35,.75);color:#fff;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(0,0,0,.35)}
.modal-public-ad__close:hover,.modal-public-ad__close:focus-visible{background:var(--accent);outline:none}
.modal-public-ad__img-wrap{background:var(--bg-2);display:flex;align-items:center;justify-content:center;min-height:120px;max-height:min(44dvh,380px);padding:12px 14px}
.modal-public-ad__img-wrap img{max-width:100%;max-height:min(44dvh,380px);width:auto;height:auto;object-fit:contain;border-radius:var(--radius-xs)}
.modal-public-ad__body{padding:16px 18px calc(20px + env(safe-area-inset-bottom))}
.modal-public-ad__title{font-size:18px;font-weight:700;margin:0 0 10px;color:#fff;line-height:1.3}
.modal-public-ad__text{font-size:14px;line-height:1.55;color:var(--text);margin:0 0 14px;white-space:pre-wrap;word-break:break-word}
.modal-public-ad__text.hidden{display:none!important}
.modal-public-ad__actions{display:flex;flex-direction:column;gap:10px}
.modal-public-ad__actions .ad-contact-bar{border-radius:var(--radius-sm);overflow:hidden}
.modal-public-ad__extlink{margin-top:2px}

/* ============================================
   AD FORM (Self-service)
   ============================================ */

/* Sub-tabs */
.ad-subtabs{display:flex;gap:0;margin-bottom:16px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}
.ad-subtab{flex:1;padding:10px 12px;border:none;background:var(--surface-2);color:var(--text-2);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.ad-subtab.active{background:var(--accent);color:#fff}
.ad-subtab-panel{display:none}
.ad-subtab-panel.active{display:block}

.advertise-container{max-width:600px}
.plans-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:16px 0}
.plan-option{padding:12px 8px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-2);text-align:center;font-size:12px;transition:all .2s;cursor:pointer}
.plan-option.active{border-color:var(--accent);color:var(--text);background:var(--surface-2)}
.plan-option strong{font-size:14px;color:var(--text)}
.plan-price-mini{color:var(--accent);font-weight:700;font-size:13px}

.ad-submit-form{display:flex;flex-direction:column;gap:12px;margin-top:16px}
.ad-submit-form input[type="text"],.ad-submit-form input[type="url"],.ad-submit-form input[type="email"],
.ad-submit-form input[type="tel"],.ad-submit-form input[type="date"],.ad-submit-form select{
    width:100%;padding:10px 12px;background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit
}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* File upload */
.file-upload-area{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:16px;text-align:center;cursor:pointer;transition:border-color .2s;position:relative;overflow:hidden}
.file-upload-area:hover{border-color:var(--accent)}
.file-upload-small{padding:10px}
.file-input-hidden{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.file-upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-2);font-size:13px}
.file-upload-icon{font-size:32px;opacity:.5}
.file-preview-img{width:100%;max-height:200px;object-fit:contain;border-radius:var(--radius-sm)}
.file-preview-img.hidden{display:none}

/* Payment info dynamic */
.payment-info-dynamic{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;margin-top:4px}
.payment-detail{font-size:13px;color:var(--text-2)}
.payment-detail strong{display:block;font-size:14px;color:var(--text);margin-bottom:6px}
.payment-detail p{margin:2px 0}

/* Total amount display */
.ad-total-display{text-align:center;padding:12px;background:var(--surface-2);border-radius:var(--radius-sm);font-size:16px;color:var(--text-2);margin-top:4px}
.ad-total-display strong{color:var(--accent);font-size:22px}

/* ============================================
   MY ADS DASHBOARD
   ============================================ */
.my-ads-login{margin-bottom:16px}
.my-ads-form{display:flex;gap:8px;margin-top:8px}
.my-ads-form input{flex:1;padding:10px 12px;background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px}

.my-ad-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}
.my-ad-header{display:flex;gap:12px;align-items:center;margin-bottom:12px}
.my-ad-thumb{width:60px;height:45px;border-radius:var(--radius-sm);object-fit:cover;background:var(--surface-2)}
.my-ad-info{flex:1}
.my-ad-info strong{display:block;font-size:14px;margin-bottom:4px}
.my-ad-body-preview{font-size:12px;color:var(--text-2);margin:4px 0 0;line-height:1.35}
.my-ad-meta{display:flex;gap:6px;flex-wrap:wrap}
.my-ad-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:8px}
.my-ad-stat{text-align:center;padding:10px;background:var(--surface-2);border-radius:var(--radius-sm)}
.my-ad-stat-value{display:block;font-size:20px;font-weight:700;color:#fff}
.my-ad-stat-label{font-size:11px;color:var(--text-2);text-transform:uppercase}
.my-ad-dates{font-size:12px;color:var(--text-2)}

/* Status badges (reused) */
.status-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600}
.status-active{background:rgba(34,197,94,.15);color:var(--green)}
.status-expired{background:rgba(100,116,139,.15);color:var(--gray)}
.status-pending{background:rgba(249,115,22,.15);color:var(--orange)}
.type-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;background:rgba(233,69,96,.1);color:var(--accent)}

/* ============================================
   MEDIA UPLOAD (modal de reporte)
   ============================================ */
.media-controls{display:flex;gap:6px;margin:6px 0 8px}
.btn-media{flex:1;padding:8px 4px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}
.btn-media:hover{background:var(--surface);color:var(--text);border-color:var(--accent)}
.media-preview-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;min-height:0}
.media-thumb-item{position:relative;flex-shrink:0}
.media-thumb{width:72px;height:56px;object-fit:cover;border-radius:var(--radius-sm);background:var(--surface-2);display:block;border:1px solid var(--border)}
.media-thumb--audio{display:flex;align-items:center;justify-content:center;color:var(--accent)}
.media-thumb--audio svg{width:28px;height:28px}
.media-thumb-type{position:absolute;top:2px;left:4px;font-size:14px;text-shadow:0 1px 3px rgba(0,0,0,.8);pointer-events:none}
.media-thumb-type--svg{top:4px;left:4px}
.media-thumb-type--svg svg{width:16px;height:16px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.85))}
.media-thumb-remove{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:var(--red);border:none;color:#fff;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;z-index:1}
/* Feed card thumbnail */
.feed-card-thumb{margin-top:8px;border-radius:var(--radius-sm);overflow:hidden;max-height:130px}
.feed-card-thumb img{width:100%;max-height:130px;object-fit:cover;display:block;cursor:pointer}
.feed-card-vid-thumb{width:100%;max-height:130px;object-fit:cover;display:block;cursor:pointer;background:#000}
.feed-card-thumb--audio{display:flex;align-items:center;gap:12px;padding:12px 14px;background:linear-gradient(135deg,rgba(99,102,241,.12),rgba(129,140,248,.08));border:2px solid rgba(99,102,241,.45);cursor:pointer;color:var(--text)}
.feed-card-thumb--audio:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.feed-audio-icon{line-height:0;flex-shrink:0;display:flex;align-items:center;color:var(--accent)}
.feed-audio-icon svg{width:24px;height:24px}
.feed-audio-text{display:flex;flex-direction:column;gap:2px;text-align:left}
.feed-audio-text strong{font-size:14px;font-weight:700}
.feed-audio-text small{font-size:11px;color:var(--text-2);font-weight:600}
.feed-card-audio-mark{margin-left:6px;display:inline-flex;align-items:center;vertical-align:middle;opacity:.95;color:var(--accent)}
.feed-card-audio-mark svg{width:16px;height:16px}
.feed-card-media-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;align-items:stretch}
.feed-media-cell{flex:1 1 30%;min-width:76px;max-width:118px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);background:var(--surface-2)}
.feed-media-cell img,.feed-media-vid{width:100%;height:76px;object-fit:cover;display:block;cursor:pointer;background:#000}
.feed-media-cell--audio{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 6px;background:linear-gradient(135deg,rgba(99,102,241,.14),rgba(129,140,248,.09));cursor:pointer;font-size:10px;font-weight:700;color:var(--text);line-height:1.2}
.feed-media-cell--audio svg{width:22px;height:22px;flex-shrink:0;color:var(--accent)}
.feed-media-more{flex:0 0 auto;align-self:center;padding:10px 12px;font-size:12px;font-weight:700;color:var(--text-2);background:var(--surface-2);border-radius:var(--radius-sm);border:1px solid var(--border)}
.ip-media-strip{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;align-items:flex-start;max-width:min(100%,320px)}
.incident-popup .ip-media-strip .ip-img,.incident-popup .ip-media-strip .ip-vid{width:108px;height:81px;object-fit:cover;border-radius:8px}
.incident-popup .ip-media-strip .ip-audio-tile{margin-top:0}

.modal-incident-media{position:fixed;inset:0;z-index:800;display:flex;align-items:center;justify-content:center;padding:16px}
.modal-incident-media.hidden{display:none!important}
.mim-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(2px)}
.mim-dialog{position:relative;z-index:1;max-width:100%;max-height:min(92vh,900px);display:flex;align-items:center;justify-content:center}
.mim-close{position:absolute;top:-40px;right:0;width:40px;height:40px;border:none;border-radius:50%;background:var(--surface);color:var(--text);font-size:26px;line-height:1;cursor:pointer;z-index:2;border:1px solid var(--border)}
.mim-close:hover{color:var(--accent)}
.mim-el{max-width:100%;max-height:min(88vh,860px);width:auto;height:auto;border-radius:var(--radius-sm)}
.mim-el.hidden{display:none!important}
#mim-img{object-fit:contain}
/* <audio> no tiene altura intrínseca: sin esto el control queda aplastado (línea roja) */
.mim-audio-box{display:flex;flex-direction:column;align-items:center;gap:14px;padding:20px 16px;width:min(92vw,440px);box-sizing:border-box}
.mim-audio-box.hidden{display:none!important}
.mim-audio-el{
    display:block!important;width:100%!important;min-width:260px;min-height:54px;height:auto!important;
    max-width:100%;border-radius:var(--radius-sm);background:var(--surface-2)
}
.mim-audio-hint{margin:0;font-size:13px;line-height:1.45;color:var(--text-2);text-align:center;max-width:36em}
.incident-popup .ip-audio-tile{display:flex;align-items:center;gap:12px;margin-top:10px;padding:12px 14px;width:100%;max-width:100%;box-sizing:border-box;background:linear-gradient(135deg,#e8ecff,#f4f6ff)!important;border:2px solid #4f46e5!important;border-radius:10px;cursor:pointer;color:#1e1b4b!important;font-size:13px!important;line-height:1.25}
.incident-popup .ip-audio-tile:focus-visible{outline:2px solid #4f46e5;outline-offset:2px}
.incident-popup .ip-audio-glyph{line-height:0;flex-shrink:0;display:flex;align-items:center}
.incident-popup .ip-audio-glyph svg{width:28px;height:28px;display:block}
.incident-popup .ip-audio-text-stack{display:flex;flex-direction:column;gap:2px;min-width:0;text-align:left}
.incident-popup .ip-audio-label{font-weight:700;font-size:14px!important;color:#1e1b4b!important}
.incident-popup .ip-audio-action{font-size:11px!important;font-weight:600;color:#4338ca!important}
.incident-popup .ip-img{cursor:pointer}
.incident-popup .ip-vid{cursor:pointer}

.btn-media.recording{background:var(--red);color:#fff;border-color:var(--red);animation:pulse-rec .9s ease-in-out infinite}
@keyframes pulse-rec{0%,100%{opacity:1}50%{opacity:.72}}

/* Onboarding / instrucciones (primera visita + ayuda; responsive, safe-area) */
.onboarding-modal{position:fixed;inset:0;z-index:920;display:flex;align-items:flex-end;justify-content:center;padding:0;box-sizing:border-box}
.onboarding-modal.hidden{display:none!important}
.onboarding-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.onboarding-dialog{
    position:relative;z-index:1;width:100%;max-width:520px;max-height:min(90dvh,720px);
    background:var(--surface);border:1px solid var(--border);border-bottom:none;
    border-radius:var(--radius) var(--radius) 0 0;
    box-shadow:0 -8px 40px rgba(0,0,0,.45);
    display:flex;flex-direction:column;min-height:0;animation:onboardingSlide .28s ease
}
@keyframes onboardingSlide{from{transform:translateY(100%);opacity:.9}to{transform:translateY(0);opacity:1}}
.onboarding-x{
    position:absolute;top:10px;right:10px;width:40px;height:40px;border:none;border-radius:50%;
    background:var(--surface-2);color:var(--text);font-size:24px;line-height:1;cursor:pointer;z-index:2;
    border:1px solid var(--border);display:flex;align-items:center;justify-content:center;padding:0
}
.onboarding-x:hover{color:var(--accent)}
.onboarding-title{
    margin:0;padding:20px 52px 10px 18px;font-size:clamp(1.05rem,4vw,1.35rem);font-weight:700;line-height:1.25;color:var(--text)
}
.onboarding-body{
    flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 18px 8px;
    overscroll-behavior:contain
}
.onboarding-lead{margin:0 0 14px;font-size:clamp(0.8rem,3.4vw,0.95rem);line-height:1.5;color:var(--text-2)}
.onboarding-steps{
    margin:0;padding-left:1.2rem;display:flex;flex-direction:column;gap:clamp(10px,3vw,14px);
    font-size:clamp(0.78rem,3.2vw,0.9rem);line-height:1.5;color:var(--text-2);list-style-position:outside
}
.onboarding-steps li::marker{color:var(--accent);font-weight:700}
.onboarding-steps strong{color:var(--text);font-weight:600}
.onboarding-note{margin:16px 0 8px;font-size:clamp(0.72rem,3vw,0.82rem);line-height:1.45;color:var(--text-2);font-style:italic}
.onboarding-ico-hint{color:var(--accent);font-style:normal;font-weight:700}
.onboarding-footer{
    flex-shrink:0;padding:12px 18px;padding-bottom:max(14px, env(safe-area-inset-bottom, 14px));
    border-top:1px solid var(--border);background:var(--surface)
}
.onboarding-btn-main{padding:14px;font-size:clamp(0.9rem,3.5vw,1rem);font-weight:700}
@media (min-width:560px){
    .onboarding-modal{align-items:center;padding:max(16px, env(safe-area-inset-top)) 16px max(16px, env(safe-area-inset-bottom))}
    .onboarding-dialog{border-radius:var(--radius);border:1px solid var(--border);max-height:min(86dvh,680px)}
    @keyframes onboardingSlide{from{transform:scale(.96);opacity:.85}to{transform:scale(1);opacity:1}}
}
@media (prefers-reduced-motion:reduce){
    .onboarding-dialog{animation:none}
}

/* ============================================
   NOTICIAS (tab + feed + publicar + modal articulo)
   ============================================ */
.news-container{max-width:680px;margin:0 auto}
.news-subtabs{display:flex;gap:0;margin-bottom:14px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}
.news-subtab{flex:1;padding:10px 12px;border:none;background:var(--surface-2);color:var(--text-2);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.news-subtab.active{background:var(--accent);color:#fff}
.news-subtab-panel{display:none}
.news-subtab-panel.active{display:block}

.news-feed-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.news-feed-header h2{font-size:16px}
.news-feed-list{display:flex;flex-direction:column;gap:12px}

/* Tarjeta estilo articulo de noticia */
.news-card{
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
    overflow:hidden;cursor:pointer;transition:transform .15s ease, border-color .15s ease, box-shadow .15s ease;
    display:flex;flex-direction:column
}
.news-card:hover,.news-card:focus-visible{border-color:var(--accent);box-shadow:0 6px 24px rgba(0,0,0,.25);outline:none;transform:translateY(-1px)}
.news-card__hero{position:relative;width:100%;background:var(--surface-2);overflow:hidden}
.news-card__hero img{width:100%;display:block;aspect-ratio:16/9;object-fit:cover}
.news-card__hero video{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;background:#000}
.news-card__hero-audio{display:flex;align-items:center;gap:12px;padding:18px;background:linear-gradient(135deg, rgba(99,102,241,.18), rgba(129,140,248,.1));color:var(--text)}
.news-card__hero-audio svg{width:32px;height:32px;color:var(--accent);flex-shrink:0}
.news-card__hero-badge{position:absolute;top:8px;left:8px;background:rgba(15,15,35,.78);color:#fff;font-size:10px;font-weight:700;letter-spacing:.5px;padding:4px 8px;border-radius:999px;text-transform:uppercase}
.news-card__hero-mediacount{position:absolute;top:8px;right:8px;background:rgba(15,15,35,.78);color:#fff;font-size:10px;font-weight:700;padding:4px 8px;border-radius:999px}
.news-card__body{padding:14px}
.news-card__kicker{display:inline-block;font-size:10px;letter-spacing:1.2px;text-transform:uppercase;font-weight:700;color:var(--accent);margin-bottom:6px}
.news-card__title{font-size:16px;font-weight:700;line-height:1.3;color:var(--text);margin:0 0 6px}
.news-card__excerpt{font-size:13px;color:var(--text-2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.news-card__meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:10px;font-size:11px;color:var(--text-2)}
.news-card__meta-dot{opacity:.5}
.news-card__location{color:var(--text-2);font-weight:600}
.news-card__location::before{content:"\01F4CD";margin-right:4px}
.news-card__expires{color:#b45309;font-weight:600}
.news-card__expires::before{content:"\23F3";margin-right:4px}
.news-article-expires{color:#b45309;font-weight:600}
.news-duration-select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:14px}
.news-card__audio-mark{margin-left:auto;color:var(--accent)}
.news-card__audio-mark svg{width:14px;height:14px;vertical-align:middle}
.news-empty{padding:32px 16px;text-align:center;color:var(--text-2);font-size:13px;border:1px dashed var(--border);border-radius:var(--radius)}

/* Formulario publicar */
.news-publish-form{display:flex;flex-direction:column;gap:12px;margin-top:14px}
.news-publish-form input[type="text"],.news-publish-form textarea{
    width:100%;padding:10px 12px;background:var(--surface-2);color:var(--text);border:1px solid var(--border);
    border-radius:var(--radius-sm);font-size:14px;font-family:inherit;resize:vertical
}
.news-publish-form textarea{min-height:160px}
.checkbox-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none}
.checkbox-label input[type="checkbox"]{width:18px;height:18px;accent-color:var(--accent)}
.news-location-row{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.news-location-row.hidden{display:none!important}
.news-location-actions{display:flex;flex-wrap:wrap;gap:8px}
.news-location-hint{font-size:11px;color:var(--text-2)}
.news-minimap{height:180px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);background:var(--surface-2);cursor:crosshair}
.news-minimap .leaflet-container{background:#f2f2f2}
.news-location-info{display:flex;flex-direction:column;gap:2px;padding:8px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}
.news-location-info.hidden{display:none!important}
.news-location-address{font-size:13px;color:var(--text);font-weight:600}
.news-location-address::before{content:"\01F4CD";margin-right:6px;font-weight:400}
.news-location-coords{font-size:11px;color:var(--text-2);font-family:ui-monospace,Consolas,monospace}
.news-location-status{font-size:12px;color:var(--text-2)}
.btn-sm{padding:8px 14px;font-size:12px}

/* Modal articulo (lectura completa) */
.modal-news-article{position:fixed;inset:0;z-index:780;display:flex;align-items:flex-end;justify-content:center;padding:0}
.modal-news-article.hidden{display:none!important}
.modal-news-article__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.modal-news-article__dialog{
    position:relative;z-index:1;width:100%;max-width:720px;max-height:min(94dvh,940px);
    overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-bottom:none;
    border-radius:18px 18px 0 0;box-shadow:0 -12px 48px rgba(0,0,0,.55);animation:newsArticleSlideUp .28s ease;
    -webkit-overflow-scrolling:touch
}
@keyframes newsArticleSlideUp{from{transform:translateY(110%);opacity:.85}to{transform:translateY(0);opacity:1}}
@media(min-width:560px){
    .modal-news-article{align-items:center;padding:max(12px,env(safe-area-inset-bottom))}
    .modal-news-article__dialog{border-radius:var(--radius);border:1px solid var(--border);max-height:min(90dvh,900px);animation:newsArticlePop .25s ease}
    @keyframes newsArticlePop{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}
}
.modal-news-article__close{
    position:absolute;top:10px;right:10px;z-index:2;width:42px;height:42px;border:none;border-radius:50%;
    background:rgba(15,15,35,.78);color:#fff;font-size:24px;line-height:1;cursor:pointer;
    display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(0,0,0,.4)
}
.modal-news-article__close:hover,.modal-news-article__close:focus-visible{background:var(--accent);outline:none}

.news-article{padding:22px 22px calc(28px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:14px;color:var(--text)}
.news-article__head{display:flex;flex-direction:column;gap:8px;border-bottom:1px solid var(--border);padding-bottom:14px}
.news-article__kicker{font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--accent)}
.news-article__title{font-size:clamp(1.4rem, 4.5vw, 1.85rem);font-weight:800;line-height:1.18;color:#fff;margin:0;font-family:Georgia,'Times New Roman',serif;letter-spacing:-.01em}
.news-article__byline{font-size:12px;color:var(--text-2)}
.news-article__byline strong{color:var(--text);font-weight:600}
.news-article__location{font-size:12px;color:var(--text-2)}
.news-article__location::before{content:"\01F4CD";margin-right:6px}
.news-article__location:empty{display:none}

.news-article__media{display:flex;flex-direction:column;gap:10px}
.news-article__media:empty{display:none}
.news-article__media-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));gap:8px}
.news-article__media-grid--single{grid-template-columns:1fr}
.news-article__media .news-media-item{position:relative;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);background:var(--surface-2);cursor:pointer}
.news-article__media .news-media-item img,.news-article__media .news-media-item video{display:block;width:100%;height:auto;max-height:360px;object-fit:cover;background:#000}
.news-article__media .news-media-item--audio{
    display:flex;align-items:center;gap:12px;padding:14px 16px;color:var(--text);
    background:linear-gradient(135deg, rgba(99,102,241,.16), rgba(129,140,248,.08))
}
.news-article__media .news-media-item--audio svg{width:28px;height:28px;color:var(--accent);flex-shrink:0}
.news-article__media .news-media-item--audio .news-media-audio-stack{display:flex;flex-direction:column;gap:2px}
.news-article__media .news-media-item--audio .news-media-audio-stack strong{font-size:14px}
.news-article__media .news-media-item--audio .news-media-audio-stack small{font-size:11px;color:var(--text-2)}

.news-article__body{
    font-size:clamp(0.95rem, 2.6vw, 1.05rem);line-height:1.65;color:var(--text);
    font-family:Georgia,'Times New Roman',serif;white-space:pre-wrap;word-break:break-word
}
.news-article__body p{margin:0 0 12px}
.news-article__footer{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;border-top:1px solid var(--border);padding-top:14px}
.news-article__footer button[hidden]{display:none}

/* Map: marcador de noticia (letra "N" sobre fondo accent) */
.news-map-marker-wrap{background:transparent!important;border:none!important}
.news-map-marker{
    background:var(--accent);border:2px solid #fff;color:#fff;
    border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;
    font-family:Georgia,'Times New Roman',serif;font-weight:800;font-size:18px;line-height:1;letter-spacing:.5px;
    box-shadow:0 4px 14px rgba(233,69,96,.5),0 2px 6px rgba(0,0,0,.35);
    -webkit-user-select:none;user-select:none
}
.news-map-marker:hover{transform:scale(1.08);transition:transform .15s ease}
.news-map-popup{min-width:200px;max-width:280px;color:#16162a!important;font-family:system-ui,-apple-system,sans-serif}
.news-map-popup__kicker{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#e94560}
.news-map-popup__chip{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#e94560;color:#fff;font-family:Georgia,'Times New Roman',serif;font-size:12px;font-weight:800;line-height:1}
.news-map-popup__title{font-size:14px;font-weight:700;color:#0d0d12!important;margin:4px 0 6px;line-height:1.3}
.news-map-popup__excerpt{font-size:12px;color:#3a3a4c!important;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:8px}
.news-map-popup__btn{display:inline-block;padding:6px 12px;background:var(--accent);color:#fff!important;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;text-decoration:none}
.news-map-popup__btn:hover{background:var(--accent-2)}

/* ============================================================
   FOOTER SEMÁNTICO (SEO/AIO)
   Aparece al final de la página; no rompe el layout de la PWA.
   ============================================================ */
.site-footer{
    background:#0b0b1c;color:#cbd5e1;border-top:1px solid rgba(255,255,255,.06);
    padding:32px 16px 24px;margin-top:48px;font-size:13px;line-height:1.55
}
.site-footer__inner{
    max-width:1200px;margin:0 auto;display:grid;gap:24px;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr))
}
.site-footer__col{min-width:0}
.site-footer__title{
    color:#fff;font-size:14px;font-weight:700;letter-spacing:.3px;
    margin:0 0 10px;text-transform:uppercase
}
.site-footer__col p{margin:0 0 10px;color:#cbd5e1}
.site-footer__col strong{color:#fff}
.site-footer__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.site-footer__list li{position:relative;padding-left:14px;color:#cbd5e1}
.site-footer__list li::before{content:"\2022";position:absolute;left:0;top:0;color:#e94560}
.site-footer__legal{
    max-width:1200px;margin:24px auto 0;padding-top:18px;
    border-top:1px solid rgba(255,255,255,.06);
    display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
    color:#94a3b8;font-size:12px
}
.site-footer__legal strong{color:#fff}
.site-footer__nav{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.site-footer__nav a{color:#cbd5e1;text-decoration:none;font-weight:600}
.site-footer__nav a:hover{color:#fff;text-decoration:underline}

/* noscript fallback */
.noscript-fallback{
    max-width:760px;margin:24px auto;padding:18px 22px;background:#fff7ed;color:#7c2d12;
    border:1px solid #fdba74;border-radius:10px;font-size:14px;line-height:1.55
}
.noscript-fallback h2{margin:0 0 8px;font-size:18px;color:#9a3412}
.noscript-fallback p{margin:0 0 10px}
.noscript-fallback a{color:#9a3412;font-weight:700}

@media (max-width:640px){
    .site-footer{padding:24px 14px 18px;margin-top:32px}
    .site-footer__legal{flex-direction:column;align-items:flex-start;gap:10px}
}

