:root{
    --bg0:#e9e9e9;
    --bg1:#ffe0ca;
    --surface: rgba(255,255,255,.06);
    --stroke: rgba(255,255,255,.12);
    --text:#1c1c1c;
    --muted:#B8C7D0;

    /* Acento (bullets mobile + detalles) */
    --accent:#ff8d6b;
    --accentSoft: rgba(255,141,107,.22);

    --regionFill: rgba(255,141,107,.16);
    --regionFillHover: rgba(255,141,107,.30);
  }



  .wrap{max-width:1200px;margin:auto;padding:24px 16px 40px}
  @media (min-width:768px){ .wrap{padding:34px 20px 60px} }

  .hero{display:grid;gap:10px;margin-bottom:18px;}
  .kicker{
    display:inline-flex;align-items:center;gap:.55rem;width:fit-content;
    padding:.28rem .7rem;border-radius:999px;
    background: rgba(255,255,255,.06);
    border:1px solid var(--stroke);
    color: var(--muted);
    font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;
  }
  .kicker::before{
    content:"";width:.55rem;height:.55rem;border-radius:50%;
    background: var(--accent);
    box-shadow: 0 0 0 4px rgba(255,141,107,.12);
  }

  h1{
    margin:0;
    font-weight:800;
    letter-spacing:.2px;
    line-height:1.05;
    font-size: clamp(1.65rem, 2.8vw, 2.4rem);
  }
  .sub{margin:0;color:var(--muted);max-width:72ch;font-size:.98rem;}

  .panel{
    border-radius: 26px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.207), rgba(255, 255, 255, 0.03));
    border:1px solid var(--stroke);
    box-shadow: 0 24px 70px rgba(255, 221, 221, 0.45), inset 0 1px 0 rgba(255, 222, 222, 0.08);
    overflow:hidden;
  }

  /* ============== DESKTOP MAP ============== */
  .mapbox{
    position:relative;
    width:100%;
    min-height: 420px;
    aspect-ratio: 16/9;
    border-radius: 26px;
    overflow:hidden;
    background:
      radial-gradient(900px 480px at 40% 30%, rgba(255,255,255,.06), rgba(0,0,0,.38));
  }
/* Capas del mapa desktop */
.bg, .dim-layer, .hits{ position:absolute; inset:0; }

.bg{
  z-index:1;
  pointer-events:none;
  background:center/cover no-repeat;
}

.dim-layer{
  z-index:2;
  /* tu mismo fondo */
}

.hits{
  z-index:3;
  pointer-events:auto;
}
  .dim-layer{
    z-index:2;
    background: radial-gradient(900px 480px at 40% 30%, rgba(0,0,0,.18), rgba(255, 255, 255, 0.62));
    opacity:0; pointer-events:none;
    transition:opacity .25s ease;
  }
  .map-hover-active .dim-layer{opacity:1;}
  .hits{z-index:3; pointer-events:auto;}
  .mapbox svg{display:block;width:100%;height:100%
  
  }

  .hits svg, .hits svg * { pointer-events:auto !important; }
  .region{
    cursor:pointer;
    fill: var(--regionFill);
    stroke: rgba(255,255,255,.10);
    stroke-width: 1px;
    transition: fill .18s ease, filter .18s ease, transform .38s cubic-bezier(.175,.885,.32,1.275);
    transform-origin:center center;
  }
  .region:hover, .region:focus-visible{
    fill: var(--regionFillHover);
    filter: brightness(1.12) saturate(1.05);
    transform: scale(1.008);
    outline:none;
  }

  /* Tooltip */
  .map-tip{
    position:fixed; z-index:9999; pointer-events:none;
    opacity:0; transform: translateY(6px);
    transition: opacity .12s ease, transform .12s ease;
    padding: .5rem .65rem;
    border-radius: 12px;
    background: rgba(10,15,20,.78);
    border: 1px solid rgba(255,255,255,.18);
    color:#F3FAFB;
    box-shadow: 0 18px 45px rgba(0,0,0,.35);
    backdrop-filter: blur(10px);
    font-size: .92rem;
    max-width: 280px;
  }
  .map-tip strong{font-weight:800;}
  .map-tip .mini{display:block;color:rgba(255,255,255,.72);font-size:.76rem;margin-top:.1rem;}
  .map-tip.show{opacity:1;transform: translateY(0);}

  /* ============== MOBILE ============== */
  .mobile-map{
    border-radius: 18px;
    overflow:hidden;
    border:1px solid var(--stroke);
    background: rgba(255,255,255,.04);
    box-shadow: 0 20px 55px rgba(0,0,0,.35);
  }

  .accordion{ --bs-accordion-bg: transparent; --bs-accordion-border-color: transparent; }
  .accordion-item{ background: transparent; border:0; margin-bottom:10px; }
  .accordion-button{
    border-radius: 16px !important;
    background: rgba(255,255,255,.06);
    border:1px solid var(--stroke);
    color: var(--text);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
    font-weight: 800;
    padding: 14px 14px;
  }
  .accordion-button:focus{
    border-color: rgba(255,141,107,.60);
    box-shadow: 0 0 0 .22rem rgba(255,141,107,.16);
  }
  .accordion-button:not(.collapsed){
    background: rgba(255,255,255,.09);
    border-color: rgba(255,255,255,.18);
  }
  .accordion-button::after{ filter: invert(1); opacity:.8; }
  .accordion-body{ padding: 12px 0 0 0; }

  /* Mobile: TODOS los dots/bullets en #ff8d6b */
  .country-btn .dot{
    width:.55rem;height:.55rem;border-radius:50%;
    background: var(--accent);
    box-shadow: 0 0 0 4px rgba(255,255,255,.06);
    flex:none;
  }
  .country-btn .label{ display:flex; align-items:center; gap:.65rem; }

  /* Card sin imagen */
  .poster{
    border-radius: 18px;
    overflow:hidden;
    border:1px solid rgba(255,255,255,.12);
    box-shadow: 0 18px 45px rgba(0,0,0,.35);
    background:
      radial-gradient(900px 320px at 20% 10%, rgba(255,141,107,.14), transparent 60%),
      linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  }
  .poster__content{ padding: 16px 14px 14px; }
  .poster__eyebrow{
    display:inline-flex; align-items:center; gap:.45rem;
    font-size:.72rem; letter-spacing:.10em; text-transform:uppercase;
    background: rgba(255,255,255,.07);
    border:1px solid rgba(255,255,255,.14);
    color:#EAF2F4;
    padding:.25rem .55rem; border-radius: 999px; margin-bottom:.5rem;
  }
  .poster__eyebrow::before{
    content:""; width:.5rem;height:.5rem;border-radius:50%;
    background: var(--accent);
    box-shadow: 0 0 0 4px rgba(255,141,107,.12);
  }
  .poster__title{ font-weight:800; line-height:1.05; margin:0 0 .45rem 0; font-size: 1.25rem; }
  .poster__subtitle{ color: rgba(255,255,255,.78); margin:0 0 .7rem 0; font-size:.95rem; }

  .poster__list{ margin:0; padding:0; list-style:none; }
  .poster__list li{
    display:flex; gap:.6rem; align-items:flex-start;
    padding:.42rem 0;
    color: #1c1c1c;
    font-size:.92rem;
    border-top: 1px dashed rgba(255,255,255,.14);
  }
  .poster__list li:first-child{ border-top:none }
  .poster__bullet{
    width:.6rem; height:.6rem; border-radius:50%;
    margin-top:.33rem;
    background: var(--accent);
    box-shadow: 0 0 0 4px rgba(255,141,107,.12);
    flex:none;
  }

  /* ============== MODAL (sin imagen) ============== */
  .modal-content.country-card{
    background: rgba(255, 234, 234, 0.92);
    color: var(--text);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 20px;
    box-shadow: 0 26px 80px rgba(0,0,0,.55);
    overflow:hidden;
  }
  .modal-header{
    border:0;
    padding: 14px 16px;
    background: linear-gradient(90deg, rgba(255,141,107,.18), transparent 60%);
  }
  .modal-title{ font-weight:800; letter-spacing:.2px; }
  .modal-header .btn-close{ filter: invert(1) grayscale(1); opacity:.85; }
  .country-body{ padding: 14px 16px 18px; }
  .country-sub{ color: rgba(255,255,255,.76); margin: 0 0 10px 0; font-size: .95rem; }
  .country-list{ margin:0; padding-left: 1.1rem; color: rgba(27, 27, 27, 0.92); }
  .country-list li{ margin: .25rem 0; }

  @media (prefers-reduced-motion: reduce){
    *{ transition:none !important; animation:none !important; scroll-behavior:auto !important; }
  }

/* Evita conflictos con estilos globales (li{float:left;} en style.css) */
.poster__list li, .country-list li{ float:none !important; }
