main { overflow: hidden; }

/* ═══════════════════════════════════════
   HERO — 2 columns
═══════════════════════════════════════ */
.home-hero {
  padding: 64px 48px 40px;
  max-width: 1280px;
  margin: 0 auto;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 64px;
  align-items: center;
}

/* left column */
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--surface); border: 1px solid var(--border);
  padding: 5px 12px; border-radius: 100px;
  font-size: 12px; color: var(--muted); margin-bottom: 24px;
}
.hero-badge-dot { width:6px; height:6px; border-radius:50%; background:var(--accent2); flex-shrink:0; }

.hero-h1 {
  font-family: var(--font-serif);
  font-size: clamp(52px, 5.9vw, 76px);
  line-height: .98; font-weight: 500;
  letter-spacing: -.03em; margin: 0;
  color: var(--text);
}
.hero-h1 em { color: var(--accent); font-style: italic; }

.hero-sub {
  font-size: 18px; line-height: 1.5;
  color: var(--muted); margin-top: 24px;
  max-width: 480px; font-weight: 400;
}

/* search */
.home-search { position: relative; max-width: 520px; margin-top: 36px; }
.search-box {
  display: flex; align-items: center; gap: 12px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 12px; padding: 14px 18px;
  transition: box-shadow .15s, border-color .15s;
}
.search-box:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(230,57,70,.15);
}
#province-search {
  flex:1; background:transparent; border:none; outline:none;
  font-size:16px; color:var(--text); font-family:inherit;
}
#province-search::placeholder { color: var(--muted2); }
.search-kbd {
  font-size:10px; background:var(--surface2); color:var(--muted);
  padding:3px 7px; border-radius:4px; font-family:inherit; font-weight:600;
  border:1px solid var(--border); flex-shrink:0;
}

/* search dropdown */
.search-results {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0;
  background: var(--surface); border: 1.5px solid var(--accent);
  border-radius: 12px; box-shadow: 0 12px 32px rgba(0,0,0,.45);
  max-height: 300px; overflow-y: auto; display: none; z-index: 1000;
}
.search-results.visible { display:block; animation: sdr .14s ease; }
@keyframes sdr { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
.search-item {
  padding: 11px 16px; cursor: pointer; font-size: 14px;
  font-weight: 500; color: var(--text); display:flex;
  align-items:center; justify-content:space-between; transition: background .1s;
}
.search-item + .search-item { border-top: 1px solid var(--border); }
.search-item:hover, .search-item.active { background: var(--surface2); }
.search-item.no-result { cursor:default; color:var(--muted); font-weight:400; }

/* province pills */
.prov-pills {
  display: flex; gap: 8px; flex-wrap: wrap;
  align-items: center; margin-top: 14px;
}
.pills-lbl {
  font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:.1em; color:var(--muted2); margin-right:4px;
}
.prov-pill {
  background: var(--surface); color: var(--text);
  border: 1px solid var(--border);
  padding: 5px 11px; border-radius: 100px;
  font-size: 12px; font-weight: 500; cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  text-decoration: none;
}
.prov-pill:hover, .prov-pill.sel {
  background: var(--accent); border-color: var(--accent); color: #fff;
}

/* hero stats */
.hero-stats { display: flex; gap: 32px; margin-top: 36px; }
.hero-stat-n { font-family:var(--font-serif); font-size:32px; font-weight:600; color:var(--text); line-height:1; }
.hero-stat-l { font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; margin-top:4px; }

/* right column — countdown card */
.countdown-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 18px; padding: 32px;
  position: relative; overflow: hidden;
}
.countdown-card::before {
  content:""; position:absolute; top:-40px; right:-40px;
  width:200px; height:200px; border-radius:50%;
  background: rgba(230,57,70,.07); pointer-events:none;
}
.cd-eyebrow {
  font-size:12px; color:var(--muted); text-transform:uppercase;
  letter-spacing:.1em; font-weight:600;
}
.cd-name {
  font-family:var(--font-serif); font-size:28px; font-weight:500;
  margin-top:12px; line-height:1.15; color:var(--text);
}
.cd-date { font-size:14px; color:var(--muted); margin-top:4px; }
.cd-divider { height:1px; background:var(--border); margin:24px 0; }
.cd-timer {
  display:flex; gap:18px; align-items:baseline;
  font-variant-numeric:tabular-nums;
}
.cd-unit { display:flex; flex-direction:column; align-items:center; }
.cd-val {
  font-family:var(--font-serif); font-size:56px; font-weight:600;
  line-height:1; letter-spacing:-.03em; color:var(--text); display:block;
}
.cd-lbl {
  font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:.1em; color:var(--muted); margin-top:4px; display:block;
}
.cd-cta {
  margin-top:28px; width:100%; background:var(--accent); color:#fff;
  border:none; padding:12px 16px; border-radius:10px;
  font-size:14px; font-weight:600; cursor:pointer; transition:background .15s;
}
.cd-cta:hover { background:var(--accent-hover); }

/* ═══════════════════════════════════════
   AD SLOT
═══════════════════════════════════════ */
.ad-slot {
  max-width: 1280px; margin: 0 auto; padding: 0 48px;
}
.ad-slot-inner {
  height: 90px; background: var(--surface);
  border: 1px dashed var(--border); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: var(--muted2);
  text-transform: uppercase; letter-spacing: .1em;
}

/* ═══════════════════════════════════════
   MAP SECTION
═══════════════════════════════════════ */
.map-section {
  padding: 72px 0;
  background: linear-gradient(180deg, #f8fbff 0%, #eef5fb 100%);
}
.map-section-header {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 32px;
}
.map-eyebrow {
  font-size:12px; color:var(--accent2); text-transform:uppercase;
  letter-spacing:.12em; font-weight:700; margin-bottom:8px;
}
.map-h2 {
  font-family:var(--font-serif); font-size:44px; font-weight:500;
  margin:0; letter-spacing:-.02em; color:var(--text);
}
.map-hint-text { font-size:14px; color:var(--muted); max-width:300px; text-align:right; }

.map-section-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 48px;
  align-items: start;
}
.map-card {
  background: linear-gradient(180deg, #f9fcff 0%, #edf5fb 100%);
  border: 1px solid var(--border);
  border-radius: 16px; padding: 24px;
  position: relative; overflow: hidden;
}
/* SVG map inside card */
#spain-map-wrapper {
  position: relative;
  padding-bottom: 57%;
  overflow: hidden;
}
#spain-map-wrapper svg {
  position: absolute; top: 0; left: 50%;
  transform: translateX(-50%);
  width: 100%; max-width: 100%; height: auto; display: block;
}
/* provinces */
#spain-map-wrapper .province {
  fill: #90d5dc;
  stroke: #ffffff;
  stroke-width: 1.25;
  cursor: pointer;
  transition: fill .16s ease, filter .16s ease;
}
#spain-map-wrapper .province:hover {
  fill: #4baeb7;
  filter: drop-shadow(0 4px 10px rgba(75,174,183,.28));
}
#spain-map-wrapper .province.disabled {
  fill: #dfe9ef;
  stroke: #d6e0e8;
  opacity: .9;
  cursor: default;
  pointer-events: none;
}
#spain-map-wrapper .province:focus-visible { outline:3px solid var(--accent); outline-offset:3px; }
/* Ceuta y Melilla se muestran como chips debajo del mapa, no en el SVG */
#Las\ Palmas, #Santa\ Cruz\ De\ Tenerife { transform: translate(180px,-290px); }

#map-tooltip {
  position: fixed;
  background: var(--bg); color: var(--text); border: 1px solid var(--border);
  padding: 7px 13px; border-radius: 10px; font-size: 13px; font-weight: 600;
  pointer-events: none; opacity: 0; transition: opacity .14s;
  white-space: nowrap; z-index: 9999; box-shadow: 0 8px 24px rgba(0,0,0,.4);
}

/* "Más buscadas" list */
.mas-buscadas-lbl {
  font-size:11px; color:var(--muted); text-transform:uppercase;
  letter-spacing:.12em; font-weight:700; margin-bottom:14px;
}
.mas-buscadas-list {
  display: flex; flex-direction: column; gap: 1px;
  border: 1px solid var(--border); border-radius: 12px; overflow: hidden;
}
.mb-item {
  background: var(--surface); padding: 16px 20px;
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer; transition: background .12s;
  border-bottom: 1px solid var(--border);
}
.mb-item:last-child { border-bottom: none; }
.mb-item:hover, .mb-item.sel { background: var(--surface2); }
.mb-item-left { display: flex; align-items: center; gap: 14px; }
.mb-num {
  font-family:var(--font-serif); font-size:22px; color:var(--muted2);
  font-weight:500; width:24px; text-align:right;
}
.mb-name { font-size:15px; font-weight:600; color:var(--text); }
.mb-ccaa { font-size:11px; color:var(--muted); }
.mb-right { display:flex; align-items:center; gap:10px; }
.mb-fests { font-size:11px; color:var(--muted); }
.mb-arrow { font-size:16px; color:var(--muted2); transition:color .12s; }
.mb-item.sel .mb-arrow, .mb-item:hover .mb-arrow { color:var(--accent); }

/* Ceuta/Melilla chips */
.map-territories {
  display:flex; align-items:center; gap:8px; margin-top:12px;
}
.map-territories__label {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.07em; color:var(--muted2); margin-right:4px;
}
.territory-chip {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 12px 6px 9px; border-radius:100px;
  background:var(--surface2); border:1px solid var(--border);
  color:var(--text); font-size:12px; font-weight:600;
  text-decoration:none; transition:background .15s, border-color .15s;
}
.territory-chip:hover { background:var(--accent); border-color:var(--accent); color:#fff; }
.territory-chip__dot { width:5px; height:5px; border-radius:50%; background:var(--muted); flex-shrink:0; }

:root[data-theme="dark"] .map-section {
  background: transparent;
}

:root[data-theme="dark"] .map-card {
  background: var(--surface);
}

:root[data-theme="dark"] #spain-map-wrapper .province {
  fill: #5d8bb2;
  stroke: #dce9f6;
}

:root[data-theme="dark"] #spain-map-wrapper .province:hover {
  fill: #7fc5d1;
}

:root[data-theme="dark"] #spain-map-wrapper .province.disabled {
  fill: #243244;
  stroke: #2a3a4e;
}

/* ═══════════════════════════════════════
   DÍAS SEÑALADOS (home)
═══════════════════════════════════════ */
.dias-section-home {
  background: var(--surface);
  padding: 72px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.dias-home-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
  margin-top: 32px;
}
.dia-home-card {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 14px; padding: 24px; position:relative; overflow:hidden;
}
.dia-home-icon { font-size:32px; color:var(--accent2); margin-bottom:14px; line-height:1; }
.dia-home-wd { font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.1em; font-weight:600; }
.dia-home-name { font-family:var(--font-serif); font-size:22px; font-weight:500; color:var(--text); margin-top:6px; line-height:1.15; }
.dia-home-date { font-size:13px; color:var(--muted); margin-top:8px; }

/* ═══════════════════════════════════════
   CALCULADORA PUENTES (home)
═══════════════════════════════════════ */
.calc-section { padding: 72px 0; }
.calc-grid {
  display: grid; grid-template-columns: 1fr 1.5fr; gap: 64px;
}
.calc-eyebrow { font-size:12px; color:var(--accent2); text-transform:uppercase; letter-spacing:.12em; font-weight:700; margin-bottom:8px; }
.calc-h2 {
  font-family:var(--font-serif); font-size:44px; font-weight:500;
  margin:0; letter-spacing:-.02em; line-height:1.05; color:var(--text);
}
.calc-p { color:var(--muted); font-size:16px; line-height:1.55; margin-top:20px; }
.calc-btn {
  margin-top:24px; background:var(--accent2); color:var(--accent2-text);
  border:none; padding:14px 22px; border-radius:10px;
  font-size:14px; font-weight:700; cursor:pointer; transition:opacity .15s;
}
.calc-btn:hover { opacity:.88; }
.calc-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:16px; padding:28px;
}
.calc-card-lbl { font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.1em; font-weight:600; margin-bottom:18px; }
.puente-row {
  display: grid; grid-template-columns: 72px 1fr auto; gap: 18px;
  align-items: center; padding: 14px 0;
  border-bottom: 1px solid var(--border);
}
.puente-row:last-child { border-bottom:none; }
.puente-date-day { font-family:var(--font-serif); font-size:28px; font-weight:500; color:var(--text); line-height:1; text-align:center; }
.puente-date-mon { font-size:10px; color:var(--muted); text-transform:uppercase; letter-spacing:.1em; margin-top:2px; text-align:center; }
.puente-name { font-size:14px; font-weight:600; color:var(--text); }
.puente-info { font-size:12px; color:var(--muted); margin-top:2px; }
.puente-badge { padding:6px 10px; border-radius:6px; font-size:11px; font-weight:700; letter-spacing:.05em; }

/* ═══════════════════════════════════════
   SEO CONTENT (home)
═══════════════════════════════════════ */
.home-seo-content { padding: 72px 0; border-top: 1px solid var(--border); }
.home-seo-content .seo-box {
  max-width: 900px; margin: 0 auto;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 24px; padding: 40px;
}
.home-seo-content h2 { font-family:var(--font-serif); font-size:clamp(28px,3.5vw,36px); font-weight:500; color:var(--text); margin-bottom:16px; letter-spacing:-.025em; }
.home-seo-content h3 { font-size:18px; font-weight:600; color:var(--text); margin:24px 0 8px; }
.home-seo-content p { font-size:15px; line-height:1.75; color:var(--muted); margin:0 0 14px; }

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media (max-width: 900px) {
  .home-hero { padding: 40px 20px; }
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-h1 { font-size: clamp(44px, 8vw, 64px); }
  .hero-sub { font-size: 16px; }
  .map-section-grid { grid-template-columns: 1fr; }
  .map-hint-text { text-align:left; max-width:100%; }
  .dias-home-grid { grid-template-columns: 1fr 1fr; }
  .calc-grid { grid-template-columns: 1fr; gap: 32px; }
  .ad-slot { padding: 0 20px; }
  .map-section { padding: 40px 0; }
  .dias-section-home { padding: 48px 0; }
  .calc-section { padding: 48px 0; }
}
@media (max-width: 560px) {
  .dias-home-grid { grid-template-columns: 1fr; }
  .hero-stats { gap: 20px; }
  .hero-stat-n { font-size: 26px; }
  .cd-val { font-size: 40px; }
  .cd-timer { gap: 12px; }
}
