/* ───────────────────────────────────────────────────────────────────────────
   Eclipse total de Sol · 12 agosto 2026 · elDiario.es
   ─────────────────────────────────────────────────────────────────────────── */

#div-container-mapa-eclipse {
    font-family: "Encode Sans", Helvetica, Arial, sans-serif;
    /* El CMS mete un text-align:center automático en los div: forzamos left para que
       todo lo que no lo indique explícitamente quede alineado a la izquierda. */
    text-align: left;
    margin: 30px 0;
}

/* Títulos y subtítulos al estilo de los gráficos de elecciones de elDiario
   (.chart_title_election / .chart_subtitle_election). */
.eclipse-title {
    font-family: "Encode Sans", sans-serif;
    text-align: left;
    color: #000;
    font-size: 22px;
    font-weight: 700;
    line-height: 25px;
    max-width: 643px;
    margin: 0 0 10px;
}

.eclipse-subtitle {
    font-family: "Encode Sans", sans-serif;
    text-align: left;
    color: #181818;
    font-size: 14px;
    line-height: 20px;
    max-width: 643px;
    margin: 0 0 15px;
}

/* ── Toggle de modo ─────────────────────────────────────────────────────── */
.eclipse-mode-toggle {
    display: flex;
    gap: 0;
    margin: 0 0 10px;
    border: 1px solid #d8d8d8;
    border-radius: 6px;
    overflow: hidden;
    width: fit-content;
}
.eclipse-mode-toggle .em-btn {
    border: none;
    background: #fff;
    color: #555;
    font-family: "Encode Sans", sans-serif;
    font-size: 13px;
    font-weight: 600;
    padding: 7px 14px;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}
.eclipse-mode-toggle .em-btn + .em-btn { border-left: 1px solid #d8d8d8; }
.eclipse-mode-toggle .em-btn:hover { background: #f3f3f3; }
.eclipse-mode-toggle .em-btn-active { background: #15151f; color: #fff; }

/* Comparador de fuentes de la franja */
.eclipse-cmp-toggle {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin: 0 0 10px;
    font-family: "Encode Sans", sans-serif;
}
.eclipse-cmp-toggle .cmp-title {
    font-size: 12px;
    font-weight: 600;
    color: #444;
    margin-right: 4px;
}
.eclipse-cmp-toggle .cmp-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border: 1px solid #d8d8d8;
    background: #fff;
    color: #888;
    font-family: inherit;
    font-size: 12.5px;
    font-weight: 600;
    padding: 5px 11px;
    border-radius: 20px;
    cursor: pointer;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.eclipse-cmp-toggle .cmp-chip .cmp-dot {
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: var(--c);
    opacity: 0.3;
    transition: opacity 0.15s;
}
.eclipse-cmp-toggle .cmp-chip.on {
    color: #15151f;
    border-color: var(--c);
    background: color-mix(in srgb, var(--c) 9%, #fff);
}
.eclipse-cmp-toggle .cmp-chip.on .cmp-dot { opacity: 1; }
.eclipse-cmp-toggle .cmp-chip:hover { border-color: #bbb; }

.eclipse-map-container {
    position: relative;
    width: 100%;
}

.eclipse-map {
    width: 100%;
    background: #eef1f4;
    border-radius: 4px;
    overflow: hidden;
}

/* ── Buscador de direcciones (mapbox-gl-geocoder sobre MapLibre) ──────────── */
/* Va dentro de un wrapper .geocoder, flotando centrado en la parte superior. */
.eclipse-map-container .geocoder {
    position: absolute;          /* (faltaba en el snippet; necesario para top/overlay) */
    left: 0;
    right: 0;
    top: 10px;
    z-index: 2;
    display: flex;
    justify-content: center;
    pointer-events: none;        /* deja pasar el clic al mapa por los lados vacíos */
}
/* MapLibre desactiva pointer-events en controles que no son suyos: se reactiva. */
.eclipse-map-container .mapboxgl-ctrl-geocoder {
    pointer-events: auto;
    margin: 0 auto;
    width: 100%;
    max-width: 250px;
    min-width: 0;
    font-family: "Encode Sans", sans-serif;
    box-shadow: 0 0 0 2px #0000001a;
}
.eclipse-map-container .mapboxgl-ctrl-geocoder--input {
    font-size: 14px;
    font-family: "Encode Sans", sans-serif;
    height: 36px;
}
.eclipse-map-container .mapboxgl-ctrl-geocoder--icon { top: 8px; }
.eclipse-map-container .mapboxgl-ctrl-geocoder--error { display: none; }
@media (max-width: 900px) {
    .eclipse-map-container .mapboxgl-ctrl-geocoder--input { font-size: 16px; }
}

/* ── Slider + play ──────────────────────────────────────────────────────── */
.eclipse-slider-container {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 40px;          /* por encima de la atribución del mapa */
    display: flex;
    justify-content: center;
    pointer-events: none;
}

.eclipse-slider-inner {
    background: rgba(255, 255, 255, 0.92);
    border-radius: 6px;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.18);
    padding: 6px 12px;       /* simétrico: el play no queda pegado abajo */
    pointer-events: auto;
}

.eclipse-time-readout {
    text-align: center;
    font-size: 13px;
    color: #333;
    padding: 0 0 2px;
    white-space: nowrap;
}
.eclipse-time-readout strong { font-size: 15px; color: #111; }

/* play a la izquierda + columna (hora arriba, slider abajo) a la derecha;
   align-items:center → el play queda centrado verticalmente respecto al bloque */
.eclipse-player-row {
    display: flex;
    align-items: center;
    gap: 10px;
}
.eclipse-slider-col {
    display: flex;
    flex-direction: column;
}

.eclipse-play-btn {
    width: 34px;
    height: 34px;
    min-width: 34px;
    border: none;
    border-radius: 50%;
    background: #ECDC19;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: background 0.15s;
}

.eclipse-play-btn:hover { background: #cbbd16; }

.eclipse-slider-box .tick text {
    font-size: 11px;
    fill: #555;
    font-family: "Encode Sans", sans-serif;
}

.eclipse-slider-box .parameter-value text {
    font-size: 12px;
    font-weight: 700;
    fill: #111;
}

/* ── Leyenda ────────────────────────────────────────────────────────────── */
.eclipse-legend {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;   /* centrada (va encima del mapa) */
    gap: 14px;
    font-size: 12px;
    color: #444;
    margin: 0 0 8px;
}
.eclipse-legend span { display: inline-flex; align-items: center; gap: 5px; }
.eclipse-legend i {
    width: 16px; height: 12px; display: inline-block; border-radius: 2px;
}
.eclipse-legend .li-banda { background: rgba(20, 20, 40, 0.35); }
.eclipse-legend .li-central { background: #ECDC19; height: 0; border-top: 2px dashed #ECDC19; }
.eclipse-legend .li-umbra { background: #1a1a2e; }
.eclipse-legend .li-obsc-line {
    width: 18px; height: 0; border-top: 2px dashed #5b6172;
}
.eclipse-legend .em-ramp {
    width: 120px; height: 12px; border-radius: 2px; display: inline-block;
    background: linear-gradient(to right, #ffe9a8, #f6b15a 40%, #9f6f97 70%, #42376f 90%, #15151f);
}

.eclipse-hint {
    font-size: 12px;
    color: #777;
    margin: 6px 2px 0;
    font-style: italic;
}

/* ── Panel de circunstancias locales (clic) ─────────────────────────────── */
.eclipse-info-panel {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 300px;
    background: rgba(255, 255, 255, 0.96);
    border-radius: 6px;
    box-shadow: 0 1px 8px rgba(0, 0, 0, 0.2);
    padding: 12px 14px;
    font-size: 13px;
    color: #222;
    display: none;
    z-index: 5;
}

.eclipse-info-panel.visible { display: block; }

.eclipse-info-panel .ip-close {
    position: absolute;
    top: 6px;
    right: 9px;
    cursor: pointer;
    color: #999;
    font-size: 16px;
    line-height: 1;
}
.eclipse-info-panel .ip-close:hover { color: #333; }

.eclipse-info-panel .ip-place {
    font-weight: 700;
    font-size: 14px;
    margin-bottom: 8px;
    padding-right: 14px;
}
.eclipse-info-panel .ip-coords {
    display: block;
    font-weight: 400;
    font-size: 11px;
    color: #888;
    margin-top: 2px;
}

.eclipse-info-panel .ip-disc {
    display: block;
    margin: 0 auto 8px;
}

/* Tira de 3 fases del eclipse (entra · máximo · sale) */
.eclipse-info-panel .ip-phases {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 4px;
    margin: 2px 0 10px;
}
.eclipse-info-panel .ip-phase {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
}
.eclipse-info-panel .ip-phase .ip-disc { margin: 0 0 3px; overflow: visible; }
.eclipse-info-panel .ip-ph-time { font-size: 12px; font-weight: 700; color: #222; }
.eclipse-info-panel .ip-ph-lbl { font-size: 10px; color: #999; text-transform: uppercase; letter-spacing: .03em; }

.eclipse-info-panel .ip-kind {
    text-align: center;
    font-weight: 700;
    margin-bottom: 8px;
    padding: 3px 0;
    border-radius: 3px;
}
.eclipse-info-panel .ip-kind.total { background: #1a1a2e; color: #fff; }
.eclipse-info-panel .ip-kind.partial { background: #ECDC19; color: #15151f; }

.eclipse-info-panel table { width: 100%; border-collapse: collapse; }
.eclipse-info-panel td { padding: 2px 0; vertical-align: top; }
.eclipse-info-panel td.lbl { color: #666; }
.eclipse-info-panel td.val { text-align: right; font-weight: 600; }
/* fila de puesta de Sol (destacada) y contactos bajo el horizonte (atenuados) */
.eclipse-info-panel tr.ip-sunset td { color: #B8AC14; }
.eclipse-info-panel tr.ip-sunset td.lbl { color: #B8AC14; }
.eclipse-info-panel tr.ip-muted td { color: #b3b3b3; font-weight: 400; }
/* fila del rango de totalidad (destacada) */
.eclipse-info-panel tr.ip-total-row td { color: #15151f; }
.eclipse-info-panel tr.ip-total-row td.val { font-size: 12px; white-space: nowrap; }

.eclipse-info-panel .ip-tz {
    margin-top: 7px;
    font-size: 10.5px;
    color: #999;
    text-align: right;
}

.eclipse-source {
    font-size: 12px;
    color: #888;
    margin: 12px 2px 0;
}

@media (max-width: 600px) {
    /* panel a lo ancho y abajo */
    .eclipse-info-panel {
        top: auto;
        bottom: 10px;
        left: 5px;
        right: 5px;
        width: calc(100% - 10px);
        font-size: 12px;
    }
    /* en móvil ocultamos los botones de zoom +/- (se usa el pellizco) */
    .eclipse-map-container .maplibregl-ctrl-group { display: none; }
}

/* ── Minimaps estáticos (small multiples) ───────────────────────────────────── */
.eclipse-mm-cell {
    background: #fff;
    border: 1px solid #e2e2e2;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}
.eclipse-mm-hora {
    font-family: "Encode Sans", sans-serif;
    font-size: 13px;
    font-weight: 700;
    color: #15151f;
    padding: 6px 8px 4px;
    letter-spacing: 0.01em;
}
.eclipse-mm-map { display: block; }
.eclipse-mm-ciudad {
    font-family: "Encode Sans", sans-serif;
    font-size: 10px;
    font-weight: 400;
    fill: #1a1a1a;
    stroke: #fff;
    stroke-width: 2.2px;
    paint-order: stroke fill;   /* halo blanco detrás del texto */
    dominant-baseline: middle;
}
/* Separador entre gráficos (como .separator_container_election de elecciones). */
.eclipse-separator {
    width: 100%;
    border-top: 2px solid #dddddd;
    margin: 40px 0 18px;
}

/* Títulos de sección (minimaps, buscador): mismo estilo de elecciones. El espacio
   arriba lo da el separador, así que sin margen superior. */
.eclipse-minimaps-title {
    font-family: "Encode Sans", sans-serif;
    text-align: left;
    color: #000;
    font-size: 22px;
    font-weight: 700;
    line-height: 25px;
    max-width: 643px;
    margin: 0 0 10px;
}
.eclipse-minimaps-sub {
    font-family: "Encode Sans", sans-serif;
    text-align: left;
    color: #181818;
    font-size: 14px;
    line-height: 20px;
    max-width: 643px;
    margin: 0 0 15px;
}

/* ── Buscador de municipios ──────────────────────────────────────────────── */
#container-buscador-eclipse { font-family: "Encode Sans", sans-serif; }
.eclipse-bus-box { max-width: 360px; }
/* caja de búsqueda (estilos de la plantilla de elecciones) */
.search-ciudades-contenedor { position: relative; }
.input-icon-wrapper { position: relative; width: 100%; }
.input-icon-wrapper svg {
    position: absolute; top: 50%; left: 12px; transform: translateY(-50%);
    color: rgba(0, 0, 0, 0.5); pointer-events: none;
}
.search-ciudades-contenedor input {
    width: 100%; height: 38px; padding: 10px 10px 10px 38px;
    border: 1px solid #d9d9d9; border-radius: 5px;
    font-family: "Encode Sans", sans-serif; font-size: 14px;
    background: #fff; color: rgba(0, 0, 0, 0.78);
    text-overflow: ellipsis; white-space: nowrap; overflow: hidden;
}
.search-ciudades-contenedor input:focus { outline: none; border-color: #B8AC14; }
.eclipse-bus-suggest {
    display: none; position: absolute; left: 0; right: 0; top: 42px; z-index: 1000;
    list-style: none; margin: 0; padding: 4px 0;
    background: #fff; border-radius: 4px; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    max-height: 260px; overflow-y: auto; font-size: 14px;
}
.eclipse-bus-suggest li {
    padding: 6px 12px; cursor: pointer; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    border-bottom: 1px solid #eee;
}
.eclipse-bus-suggest li:last-child { border-bottom: none; }
.eclipse-bus-suggest li.active, .eclipse-bus-suggest li:hover { background: #fbf8d9; }
.eclipse-sg-mun { font-weight: 600; color: #15151f; }
.eclipse-sg-prov { color: #999; font-size: 12.5px; }
.eclipse-bus-msg { color: #888; font-size: 13px; }

/* panel detallado (super-tooltip) — la caja existe siempre (placeholder al inicio) */
.eclipse-bus-detalle {
    position: relative;
    margin-top: 16px; border: 1px solid #e2e2e2; border-radius: 10px;
    padding: 16px; background: #fff; box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
}
.eclipse-bus-placeholder {
    color: #888; font-size: 14px; text-align: center; padding: 22px 8px;
}
.eclipse-bus-head { margin-bottom: 12px; padding-right: 150px; }   /* hueco para el botón de descarga */

/* Botón "Descargar imagen" (arriba a la derecha; se excluye de la captura). */
.eclipse-bus-download {
    position: absolute; top: 14px; right: 14px;
    display: inline-flex; align-items: center; gap: 5px;
    background: #ECDC19; color: #15151f; border: none; border-radius: 6px;
    font-family: "Encode Sans", sans-serif; font-size: 12.5px; font-weight: 700;
    padding: 7px 11px; cursor: pointer; transition: background 0.15s;
}
.eclipse-bus-download:hover { background: #cbbd16; }
.eclipse-bus-download svg { display: block; }

/* Pie de marca (sí entra en la imagen exportada): texto a la izquierda, logo a la derecha. */
.eclipse-bus-foot {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    margin-top: 16px; padding-top: 10px; border-top: 1px solid #f0f0f0;
    font-size: 11px; color: #999;
}
/* Logo del pie: caja con overflow:hidden → el logo (a 160px de ancho) se recorta por
   abajo, quitando el tagline y dejando el wordmark más grande (igual que en el export). */
.eclipse-bus-logo { width: 160px; height: 22px; overflow: hidden; flex: none; }
/* altura EXPLÍCITA (no auto): iOS Safari no mantiene bien la proporción de un SVG con
   height:auto y lo agranda → con la caja recortada saldría cortado. 160 × 67/348 = 30,8. */
.eclipse-bus-logo img { width: 160px; height: 30.8px; display: block; }
.eclipse-bus-title { font-size: 19px; font-weight: 700; color: #15151f; }
.eclipse-bus-prov { font-size: 14px; font-weight: 400; color: #888; }
.eclipse-bus-sub { font-size: 12.5px; color: #888; margin: 2px 0 8px; }
.eclipse-bus-badge {
    display: inline-block; font-weight: 700; font-size: 13px; padding: 3px 10px; border-radius: 4px;
}
.eclipse-bus-badge.total { background: #1a1a2e; color: #fff; }
.eclipse-bus-badge.partial { background: #ECDC19; color: #15151f; }

.eclipse-bus-cols { display: flex; gap: 18px; flex-wrap: wrap; }
.eclipse-bus-left { flex: 1 1 360px; min-width: 0; }
.eclipse-bus-right { flex: 0 0 230px; }

.eclipse-bus-discs-lbl { font-size: 13px; font-weight: 600; color: #555; margin: 6px 0 10px; }
/* grid auto-fill: ~6 discos a 1024px, ~4 a 640px, baja a 3 y 2 sin breakpoints fijos */
.eclipse-bus-discs {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 12px 8px; margin-bottom: 18px;
}
.eclipse-disc { display: flex; flex-direction: column; align-items: center; }
.eclipse-disc-svg { line-height: 0; width: 76%; max-width: 130px; }
.eclipse-disc-svg svg { display: block; width: 100%; height: auto; }
.eclipse-disc-t { font-size: 13px; font-weight: 700; color: #222; margin-top: 5px; }
.eclipse-disc-o { font-size: 12px; color: #999; }

.eclipse-bus-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.eclipse-bus-table td { padding: 4px 0; vertical-align: top; border-bottom: 1px solid #f0f0f0; }
.eclipse-bus-table td.l { color: #666; }
.eclipse-bus-table td.v { text-align: right; font-weight: 600; color: #15151f; white-space: nowrap; }
.eclipse-bus-table tr.tot td { color: #15151f; }
.eclipse-bus-table tr.tot td.v { color: #15151f; }
.eclipse-bus-table tr.sunset td { color: #B8AC14; }
.eclipse-bus-nota { font-size: 11.5px; color: #999; margin: 8px 0 0; font-style: italic; }

.eclipse-bus-mini { width: 100%; }
.eclipse-bus-mini canvas { border: 1px solid #e6e6e6; border-radius: 6px; display: block; }

@media (max-width: 560px) {
    .eclipse-bus-right { flex-basis: 100%; }
    .eclipse-bus-mini { max-width: 280px; }
    /* móvil: auto-fill con mínimo bajo (70px) → 4 por fila en la mayoría de móviles,
       3 en los muy estrechos (≤320) y 5 en los muy anchos. Se adapta al ancho. */
    .eclipse-bus-discs { grid-template-columns: repeat(auto-fill, minmax(70px, 1fr)); gap: 10px 5px; }
    .eclipse-disc-svg { width: 88%; }
    /* iOS hace zoom al enfocar un input con texto <16px → lo subimos a 16px */
    .search-ciudades-contenedor input { font-size: 16px; }
    .eclipse-disc-t { font-size: 11px; margin-top: 3px; }
    .eclipse-disc-o { font-size: 10px; }
    /* el botón pasa a estar en flujo (arriba) para no chocar con el título */
    .eclipse-bus-head { padding-right: 0; }
    .eclipse-bus-download { position: static; margin-bottom: 12px; }
}

/* ── Modo EXPORT ──────────────────────────────────────────────────────────────
   El panel se clona aquí (fuera de pantalla) para exportarlo a ANCHO FIJO con la
   maqueta de ESCRITORIO, sea cual sea el dispositivo. Estos selectores de 2 clases
   ganan en especificidad a las @media de arriba, así que neutralizan la maqueta
   móvil aunque el usuario esté en un móvil. El logo va arriba a la derecha. */
.eclipse-export {
    position: fixed; left: -10000px; top: 0; width: 600px; background: #fff;
    /* el clon cuelga de <body> (fuera de #div-container-mapa-eclipse), así que NO hereda
       la tipografía: la fijamos aquí o html2canvas exportaría con la fuente por defecto. */
    font-family: "Encode Sans", Helvetica, Arial, sans-serif;
}
.eclipse-export .eclipse-bus-detalle { margin: 0; box-shadow: none; }
.eclipse-export .eclipse-bus-head { padding-right: 185px; }   /* hueco para el logo (170px) */
.eclipse-export .eclipse-bus-discs { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 10px 6px; }
.eclipse-export .eclipse-disc-svg { width: 78%; }
.eclipse-export .eclipse-disc-t { font-size: 13px; margin-top: 5px; }
.eclipse-export .eclipse-disc-o { font-size: 12px; }
/* base flex más baja para que tabla + mini-mapa quepan en una línea a 600px
   (con el basis de 360px el flex parte de línea antes de encoger). */
.eclipse-export .eclipse-bus-left { flex: 1 1 300px; }
.eclipse-export .eclipse-bus-right { flex: 0 0 200px; }
.eclipse-export .eclipse-bus-mini { max-width: 200px; }
/* logo arriba-dcha: caja 170×23 con overflow:hidden → el logo (a 170px de ancho) se
   recorta por la parte de abajo, quitando el tagline. */
.eclipse-export .eclipse-bus-logo-top { position: absolute; top: 16px; right: 16px; width: 170px; height: 23px; overflow: hidden; }
.eclipse-export .eclipse-bus-logo-top img { width: 170px; height: 32.7px; display: block; }   /* alto explícito por iOS (170 × 67/348) */
