/* ═══════════════════════════════════════════════════════════════
   PARKKEEN — styles.css
   CSS limpio desde cero.
═══════════════════════════════════════════════════════════════ */

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --green:  #4CAF27;
  --blue:   #1E6FD9;
  --orange: #F57C00;
  --pink:   #E91E8C;
  --dark:   #0c0c0c;
  --dark2:  #131313;
  --light:  #f7f7f5;
  --white:  #ffffff;
  --text:   #111111;
  --muted:  #777777;
  --border: #e4e4e4;
  --header-h: 64px;
  --f-display: 'Bebas Neue', sans-serif;
  --f-body:    'DM Sans', sans-serif;
}

/* ── Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body { font-family: var(--f-body); background: var(--light); color: var(--text); overflow-x: hidden; padding-top: var(--header-h); }
img  { max-width: 100%; display: block; }
button { font-family: var(--f-body); cursor: pointer; }

/* ── SPA pages ─────────────────────────────────────────────── */
.page { display: none; flex-direction: column; min-height: 100vh; }
.page.active { display: flex; }

/* ── Header ─────────────────────────────────────────────────── */
header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  height: var(--header-h);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 48px;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  transition: background .3s, border-color .3s;
}
header.scrolled { background: rgba(12,12,12,.94); border-bottom-color: rgba(255,255,255,.06); }

.logo {
  font-family: var(--f-display); font-size: 1.75rem; letter-spacing: 4px;
  background: linear-gradient(90deg, var(--blue) 0%, var(--green) 33%, var(--orange) 66%, var(--pink) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; cursor: pointer;
}
.header-right { display: flex; align-items: center; gap: 24px; }
.header-cta {
  font-size: .72rem; font-weight: 500; letter-spacing: 2px; text-transform: uppercase;
  color: var(--text); background: none; border: none; border-bottom: 2px solid var(--orange);
  padding-bottom: 2px; transition: color .2s;
}
header.scrolled .header-cta { color: rgba(255,255,255,.85); }

.hamburger { display: flex; flex-direction: column; gap: 5px; cursor: pointer; padding: 6px; }
.hamburger span { display: block; height: 2px; border-radius: 2px; transition: width .3s; }
.hb1 { width: 26px; background: var(--blue); }
.hb2 { width: 19px; background: var(--green); }
.hb3 { width: 13px; background: var(--orange); }
.hamburger:hover .hb2, .hamburger:hover .hb3 { width: 26px; }

/* ── Menu overlay ───────────────────────────────────────────── */
.menu-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: var(--dark);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .4s;
}
.menu-overlay.open { opacity: 1; pointer-events: all; }
.menu-overlay nav { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.menu-overlay nav a {
  font-family: var(--f-display);
  font-size: clamp(3rem, 8vw, 6.5rem);
  letter-spacing: 4px; color: rgba(255,255,255,.12);
  text-decoration: none; line-height: 1;
  cursor: pointer;
  transition: color .3s, letter-spacing .3s;
}
.menu-overlay nav a:hover { color: #fff; letter-spacing: 6px; }
.menu-overlay nav a.n1:hover { color: var(--blue); }
.menu-overlay nav a.n2:hover { color: var(--green); }
.menu-overlay nav a.n3:hover { color: var(--orange); }
.menu-close {
  position: absolute; top: 28px; right: 40px;
  background: none; border: none; color: rgba(255,255,255,.3);
  font-size: 2rem; cursor: pointer; transition: color .2s;
}
.menu-close:hover { color: #fff; }
.menu-foot {
  position: absolute; bottom: 36px; left: 0; right: 0; text-align: center;
  font-size: .65rem; letter-spacing: 4px; text-transform: uppercase;
  color: rgba(255,255,255,.15);
}

/* ── Rainbow bar ────────────────────────────────────────────── */
.rbar { height: 4px; background: linear-gradient(90deg, var(--blue), var(--green), var(--orange), var(--pink)); }

/* ── Buttons ────────────────────────────────────────────────── */
.btn-orange {
  display: inline-block; padding: 14px 34px; background: var(--orange); color: #fff;
  border: none; border-radius: 3px; font-size: .76rem; font-weight: 500;
  letter-spacing: 2px; text-transform: uppercase; cursor: pointer;
  transition: opacity .2s, transform .15s;
}
.btn-orange:hover { opacity: .88; transform: translateY(-1px); }

.btn-green {
  display: inline-block; padding: 14px 34px; background: var(--green); color: #fff;
  border: none; border-radius: 3px; font-size: .76rem; font-weight: 500;
  letter-spacing: 2px; text-transform: uppercase; cursor: pointer;
  transition: opacity .2s, transform .15s;
}
.btn-green:hover { opacity: .88; transform: translateY(-1px); }

.btn-blue {
  display: inline-block; padding: 14px 34px; background: var(--blue); color: #fff;
  border: none; border-radius: 3px; font-size: .76rem; font-weight: 500;
  letter-spacing: 2px; text-transform: uppercase; cursor: pointer;
  transition: opacity .2s, transform .15s;
}
.btn-blue:hover { opacity: .88; transform: translateY(-1px); }

.btn-wa {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 32px; background: #25D366; color: #fff;
  border: none; border-radius: 3px; font-size: .76rem; font-weight: 500;
  letter-spacing: 2px; text-transform: uppercase; cursor: pointer;
  text-decoration: none; transition: background .2s;
}
.btn-wa:hover { background: #1ea855; }

.btn-wa-big {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 34px; background: #25D366; color: #fff;
  border: none; border-radius: 6px; font-size: .85rem; font-weight: 500;
  text-decoration: none; flex-shrink: 0;
  transition: background .2s, transform .15s;
  box-shadow: 0 6px 24px rgba(37,211,102,.22);
}
.btn-wa-big:hover { background: #1ea855; transform: translateY(-2px); }

/* ── Shared section styles ──────────────────────────────────── */
.sec-white { padding: 88px 7vw; background: var(--white); }
.sec-light  { padding: 88px 7vw; background: var(--light); }

.eyebrow {
  font-size: .63rem; font-weight: 500; letter-spacing: 4px; text-transform: uppercase;
  margin-bottom: 14px; display: flex; align-items: center; gap: 12px;
}
.eyebrow::before { content: ''; display: block; width: 28px; height: 1px; background: currentColor; }
.eyebrow.green  { color: var(--green); }
.eyebrow.orange { color: var(--orange); }
.eyebrow.blue   { color: var(--blue); }

.sec-h2 {
  font-family: var(--f-display);
  font-size: clamp(2.4rem, 4.5vw, 4rem);
  line-height: .95; letter-spacing: 2px; margin-bottom: 20px;
}
.sec-lead { font-size: .92rem; color: var(--muted); line-height: 1.85; font-weight: 300; }

/* Scroll reveal */
.sr { opacity: 0; transition: opacity .7s ease, transform .7s ease; }
.sr-left  { transform: translateX(-44px); }
.sr-right { transform: translateX(44px); }
.sr-up    { transform: translateY(32px); }
.sr.visible { opacity: 1; transform: none; }
.d1 { transition-delay: .1s; }
.d2 { transition-delay: .22s; }
.d3 { transition-delay: .34s; }

/* ── HERO ───────────────────────────────────────────────────── */
.hero {
  min-height: calc(100vh - var(--header-h));
  background: var(--dark);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 60px 0;
  /* min-height + align-items:center + padding ensures content never clips
     regardless of zoom level or viewport size. The hero grows if content
     needs more space, but never gets smaller than visible viewport. */
}
.hero-scene { position: absolute; inset: 0; }
.hero-scene svg { width: 100%; height: 100%; }
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.9) 0%, rgba(0,0,0,.5) 35%, rgba(0,0,0,.1) 75%);
}
.hero-content {
  position: relative; z-index: 2;
  padding: 0 7vw;
  max-width: min(720px, 60vw);
}
.hero-eyebrow {
  display: flex; align-items: center; gap: 12px;
  font-size: .68rem; font-weight: 500; letter-spacing: 4px; text-transform: uppercase;
  color: var(--green); margin-bottom: 20px;
}
.hero-eyebrow::before { content: ''; display: block; width: 28px; height: 1px; background: var(--green); }
.hero-h1 {
  font-family: var(--f-display);
  font-size: clamp(3.8rem, 8.5vw, 8rem);
  line-height: .88; letter-spacing: 2px; color: #fff; margin-bottom: 24px;
}
.hero-sub {
  font-size: .94rem; color: rgba(255,255,255,.5); line-height: 1.85;
  font-weight: 300; margin-bottom: 36px; max-width: 420px;
}
.hero-scroll {
  position: absolute; bottom: 36px; right: 7vw;
  display: flex; align-items: center; gap: 10px;
  font-size: .6rem; letter-spacing: 3px; text-transform: uppercase;
  color: rgba(255,255,255,.2);
}
.hero-scroll-line { width: 1px; height: 44px; background: linear-gradient(to bottom, transparent, rgba(255,255,255,.25)); }

/* ── WHO SECTION ───────────────────────────────────────────── */
.who-grid {
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: 64px; align-items: center; margin-top: 52px;
}

/* Tarjeta verde con emoji */
.who-img {
  position: relative;
  border-radius: 12px;
  height: 400px;
  background: linear-gradient(160deg, #a8d5a2 0%, #6ab86a 50%, #3a8f3a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.who-img-icon {
  font-size: 6rem;
  line-height: 1;
}
.who-img-tag {
  position: absolute;
  bottom: 24px;
  left: 24px;
  background: rgba(255,255,255,.95);
  border-radius: 4px;
  padding: 10px 18px;
  font-size: .68rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--text);
}

/* Stats en cards */
.who-stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 32px;
}
.ws-stat {
  padding: 22px 14px;
  background: var(--light);
  border-radius: 8px;
  text-align: center;
}
.ws-num {
  font-family: var(--f-display);
  font-size: 2.6rem;
  letter-spacing: 2px;
  line-height: 1;
  margin-bottom: 4px;
}
.ws-label {
  font-size: .7rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 500;
}

/* ── NAV CARDS ─────────────────────────────────────────────── */
.cards-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 20px; margin-top: 48px;
}
.nav-card {
  position: relative; height: 280px;
  border-radius: 12px; overflow: hidden; cursor: pointer;
}
.card-bg {
  position: absolute; inset: 0;
  transition: transform .5s ease;
}
.nav-card:hover .card-bg { transform: scale(1.04); }
.card-bg-mod { background: linear-gradient(145deg, #0d2b0d 0%, #1c4d1c 60%, #0f3510 100%); }
.card-bg-cot { background: linear-gradient(145deg, #1a100a 0%, #2d1d0c 60%, #1a1208 100%); }
/* Subtle texture */
.card-bg::after {
  content: '';
  position: absolute; inset: 0;
  background: repeating-linear-gradient(-45deg, transparent, transparent 28px, rgba(255,255,255,.015) 28px, rgba(255,255,255,.015) 56px);
}
.card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.8), rgba(0,0,0,.1));
  transition: background .3s;
}
.nav-card:hover .card-overlay { background: linear-gradient(to top, rgba(0,0,0,.88), rgba(0,0,0,.18)); }
.card-content {
  position: absolute; bottom: 0; left: 0; right: 0; padding: 26px;
}
.card-tag {
  display: inline-block; font-size: .6rem; font-weight: 600;
  letter-spacing: 2.5px; text-transform: uppercase; padding: 4px 12px;
  border-radius: 2px; margin-bottom: 10px;
}
.card-mod .card-tag { background: rgba(76,175,39,.2); color: #8aea5a; }
.card-cot .card-tag { background: rgba(245,124,0,.2); color: #ffb86a; }
.card-title { font-family: var(--f-display); font-size: 2.2rem; letter-spacing: 2px; color: #fff; margin-bottom: 8px; }
.card-desc { font-size: .8rem; color: rgba(255,255,255,.55); line-height: 1.6; }
.card-arrow {
  display: inline-block; margin-top: 14px; font-size: .7rem; font-weight: 500;
  letter-spacing: 2px; text-transform: uppercase; border-bottom: 1px solid;
  padding-bottom: 2px; transition: padding-left .2s;
}
.card-mod .card-arrow { color: var(--green); border-color: var(--green); }
.card-cot .card-arrow { color: var(--orange); border-color: var(--orange); }
.nav-card:hover .card-arrow { padding-left: 6px; }

/* ── WA BAND ────────────────────────────────────────────────── */
.wa-band {
  padding: 56px 7vw; background: var(--light);
  display: flex; align-items: center; justify-content: space-between; gap: 40px;
}
.wa-title { font-family: var(--f-display); font-size: 2rem; letter-spacing: 2px; margin-bottom: 6px; }
.wa-sub   { font-size: .87rem; color: var(--muted); font-weight: 300; }

/* ── FOOTER ─────────────────────────────────────────────────── */
footer { background: var(--dark); padding: 64px 7vw 36px; }
.footer-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 52px; padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.footer-logo {
  font-family: var(--f-display); font-size: 1.9rem; letter-spacing: 4px;
  background: linear-gradient(90deg, var(--blue), var(--green), var(--orange), var(--pink));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; display: block; margin-bottom: 14px;
}
.footer-desc { font-size: .78rem; color: rgba(255,255,255,.28); line-height: 1.85; font-weight: 300; }
.footer-col-h { font-size: .58rem; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.22); margin-bottom: 18px; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 11px; }
.footer-links li { font-size: .8rem; color: rgba(255,255,255,.38); cursor: pointer; transition: color .2s; }
.footer-links li:hover { color: #fff; }
.footer-bottom {
  padding-top: 28px; display: flex; align-items: center; justify-content: space-between;
  font-size: .7rem; color: rgba(255,255,255,.18);
}
.footer-dots { display: flex; gap: 6px; }
.footer-dots div { width: 7px; height: 7px; border-radius: 50%; }

/* ── WA FLOAT ───────────────────────────────────────────────── */
.wa-float {
  position: fixed; bottom: 28px; right: 28px; z-index: 400;
  width: 56px; height: 56px; border-radius: 50%; background: #25D366;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 24px rgba(37,211,102,.38); text-decoration: none;
  animation: wapulse 2.5s infinite;
}
@keyframes wapulse {
  0%,100% { box-shadow: 0 6px 24px rgba(37,211,102,.38); }
  50%      { box-shadow: 0 6px 32px rgba(37,211,102,.6), 0 0 0 10px rgba(37,211,102,.1); }
}

/* ── PAGE HERO (interior pages) ─────────────────────────────── */
.page-hero {
  padding-top: var(--header-h);
  background: var(--dark2); min-height: 46vh;
  display: flex; align-items: flex-end;
  position: relative; overflow: hidden;
}
.page-hero-bg    { position: absolute; inset: 0; background: linear-gradient(135deg,#0a1208,#0e1f0a,#081218); }
.page-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.88), rgba(0,0,0,.15)); }
.page-hero-content { position: relative; z-index: 2; padding: 64px 7vw; }
.breadcrumb { font-size: .63rem; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.28); margin-bottom: 18px; cursor: pointer; }
.breadcrumb span:hover { color: #fff; }
.page-h1 { font-family: var(--f-display); font-size: clamp(3rem, 7vw, 5.5rem); letter-spacing: 3px; color: #fff; line-height: .92; margin-bottom: 18px; }
.page-sub { font-size: .93rem; color: rgba(255,255,255,.42); line-height: 1.8; font-weight: 300; max-width: 500px; }

/* ── PILLS ──────────────────────────────────────────────────── */
.pills-grid { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 32px; }
.pill {
  background: var(--white); border: 1.5px solid var(--border);
  border-radius: 50px; padding: 10px 20px;
  font-size: .85rem; font-weight: 500; color: var(--text);
}

/* ── FULL DAY GRID ──────────────────────────────────────────── */
.fd-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 48px; }

.fd-card {
  border: 1px solid var(--border); border-radius: 12px;
  overflow: hidden; display: flex; flex-direction: column;
  background: var(--white);
}
.fd-card-dark { background: var(--dark2); border-color: rgba(255,255,255,.07); }

.fd-header { padding: 32px 32px 24px; }
.fd-header-light { background: var(--light); border-bottom: 1px solid var(--border); }
.fd-header-dark  { background: rgba(255,255,255,.04); border-bottom: 1px solid rgba(255,255,255,.07); }

.fd-badge {
  display: inline-block; font-size: .6rem; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase;
  padding: 4px 12px; border-radius: 2px; margin-bottom: 12px;
}
.fd-badge-green  { background: rgba(76,175,39,.12);  color: #2a7a10; }
.fd-badge-orange { background: rgba(245,124,0,.15);  color: #a05500; }

.fd-title { font-family: var(--f-display); font-size: 2.4rem; letter-spacing: 2px; margin-bottom: 10px; color: var(--text); }
.fd-title-dark { color: #fff; }
.fd-desc { font-size: .86rem; color: var(--muted); line-height: 1.7; }
.fd-desc-dark { color: rgba(255,255,255,.45); }

.fd-body { padding: 20px 32px; flex: 1; }

.fd-includes { padding: 4px 32px 20px; border-top: 1px solid var(--border); }
.fd-includes-dark { border-top-color: rgba(255,255,255,.07); }

.fd-footer { padding: 20px 32px 28px; background: var(--light); border-top: 1px solid var(--border); }
.fd-footer-light { background: var(--light); border-top-color: var(--border); }
.fd-footer-dark  { background: rgba(255,255,255,.03); border-top: 1px solid rgba(255,255,255,.07); }

/* Timeline */
.tv-item { display: flex; padding-bottom: 14px; }
.tv-dot-wrap { display: flex; flex-direction: column; align-items: center; margin-right: 14px; flex-shrink: 0; }
.tv-dot  { width: 9px; height: 9px; border-radius: 50%; margin-top: 3px; }
.tv-line { width: 1px; flex: 1; min-height: 16px; margin: 4px 0; }
.tv-time { font-size: .62rem; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 2px; }
.tv-text { font-size: .85rem; color: var(--text); }
.tv-time-dark { color: rgba(255,255,255,.35); }
.tv-text-dark { color: rgba(255,255,255,.8); }

.col-h { font-size: .62rem; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: var(--muted); margin-bottom: 18px; }
.col-h-dark { color: rgba(255,255,255,.35); }

.inc-yes { font-size: .84rem; color: var(--text); margin-bottom: 9px; }
.inc-yes-dark { color: rgba(255,255,255,.8); }
.inc-no  { font-size: .84rem; color: var(--muted); margin-bottom: 9px; }
.inc-no-dark { color: rgba(255,255,255,.3); }

/* ── ALOJAMIENTO TABS ───────────────────────────────────────── */
.aloj-tabs { display: flex; gap: 12px; margin-top: 48px; margin-bottom: 10px; }
.aloj-tab {
  padding: 11px 26px; border-radius: 3px; border: 2px solid var(--border);
  background: var(--white); font-size: .8rem; font-weight: 500;
  letter-spacing: 1px; text-transform: uppercase; cursor: pointer;
  color: var(--muted); transition: all .2s;
}
.aloj-tab.active { border-color: var(--blue); background: rgba(30,111,217,.06); color: var(--blue); }
.aloj-note { font-size: .78rem; color: var(--muted); margin-bottom: 32px; font-style: italic; }

.aloj-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.aloj-card {
  border: 1.5px solid var(--border); border-radius: 12px;
  padding: 28px; background: var(--white);
  display: flex; flex-direction: column; gap: 0;
  transition: box-shadow .3s;
}
.aloj-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,.08); }
.aloj-featured { border-color: var(--blue); box-shadow: 0 4px 24px rgba(30,111,217,.12); position: relative; }
.aloj-feat-badge {
  position: absolute; top: -1px; left: 50%; transform: translateX(-50%);
  background: var(--blue); color: #fff;
  font-size: .58rem; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  padding: 4px 16px; border-radius: 0 0 8px 8px;
}
.aloj-nights { font-family: var(--f-display); font-size: 2.8rem; letter-spacing: 2px; color: var(--blue); line-height: 1; padding-top: 10px; }
.aloj-sub    { font-size: .72rem; color: var(--muted); letter-spacing: 1px; text-transform: uppercase; margin-top: 4px; margin-bottom: 20px; }
.aloj-includes { flex: 1; margin-bottom: 20px; }
.aloj-dynamic  { font-weight: 600; }

/* ── TABLA COMPARATIVA ──────────────────────────────────────── */
.table-wrap { overflow-x: auto; margin-top: 40px; }
.cmp-table { width: 100%; border-collapse: collapse; font-size: .87rem; }
.cmp-table th {
  font-size: .63rem; letter-spacing: 3px; text-transform: uppercase;
  font-weight: 500; padding: 14px 20px; text-align: left;
  border-bottom: 2px solid var(--border); color: var(--muted);
}
.cmp-table th:not(:first-child) { text-align: center; }
.cmp-table td { padding: 12px 20px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.cmp-table td:not(:first-child) { text-align: center; color: var(--green); font-weight: 600; }
.cmp-table td.no { color: #ccc; font-weight: 400; }
.cmp-table tr:hover td { background: rgba(0,0,0,.02); }

/* ── CTA BAND ───────────────────────────────────────────────── */
.cta-band { background: var(--dark); padding: 72px 7vw; text-align: center; }
.cta-btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ── COTIZADOR ──────────────────────────────────────────────── */
.cot-hero { background: var(--dark); padding: 48px 7vw; text-align: center; }
.cot-hero h1 { font-family: var(--f-display); font-size: clamp(2.4rem,5vw,4rem); letter-spacing: 3px; color: #fff; margin-bottom: 10px; }
.cot-hero h1 span { color: var(--orange); }
.cot-hero p { font-size: .9rem; color: rgba(255,255,255,.45); font-weight: 300; max-width: 480px; margin: 0 auto; line-height: 1.8; }

.cot-wrap {
  max-width: 1100px; margin: 0 auto;
  padding: 44px 24px 72px;
  display: grid; grid-template-columns: 1fr 360px; gap: 28px;
  align-items: start; background: var(--light);
  flex: 1;
}
.cot-left { display: flex; flex-direction: column; gap: 20px; }
.cot-panel {
  background: var(--white); border: 1px solid var(--border);
  border-radius: 10px; padding: 28px 30px;
}
.step-label { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.step-num {
  width: 26px; height: 26px; border-radius: 50%; background: var(--dark); color: #fff;
  font-size: .72rem; font-weight: 500; display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.step-title { font-size: .72rem; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; }

.alumnos-wrap { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: 6px; overflow: hidden; width: fit-content; }
.alumnos-btn  { width: 44px; height: 50px; background: var(--light); border: none; font-size: 1.3rem; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .15s; }
.alumnos-btn:hover { background: var(--border); }
.alumnos-input { width: 80px; height: 50px; border: none; border-left: 1px solid var(--border); border-right: 1px solid var(--border); text-align: center; font-family: var(--f-display); font-size: 1.8rem; letter-spacing: 2px; color: var(--text); outline: none; background: var(--white); }
.alumnos-hint  { margin-top: 10px; font-size: .78rem; color: var(--muted); }

/* pkg-grid: plan cards in cotizador */
.pkg-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px,1fr)); gap: 12px; }
.pkg-card {
  border: 2px solid var(--border); border-radius: 8px; padding: 16px 14px;
  cursor: pointer; transition: border-color .2s; user-select: none;
}
.pkg-card:hover { border-color: #aaa; }
.pkg-card.selected { border-color: var(--orange); background: rgba(245,124,0,.04); }
.pkg-card .pkg-name { font-family: var(--f-display); font-size: 1rem; letter-spacing: 1px; margin: 6px 0 4px; color: var(--text); }
.pkg-card.selected .pkg-name { color: var(--orange); }
.pkg-card .pkg-icon { font-size: 1.4rem; }
.pkg-card .pkg-desc { font-size: .72rem; color: var(--muted); line-height: 1.5; margin-bottom: 8px; }
.pkg-inc { font-size: .7rem; color: var(--muted); display: flex; gap: 5px; margin-bottom: 3px; }
.pkg-inc::before { content: '✓'; color: var(--green); font-weight: 700; flex-shrink: 0; }

/* aloj toggle in cotizador */
.aloj-toggle { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.aloj-toggle-btn {
  padding: 14px 16px; border: 2px solid var(--border); border-radius: 8px;
  background: var(--white); font-size: .85rem; font-weight: 500; cursor: pointer;
  text-align: left; transition: all .2s;
}
.aloj-toggle-btn small { display: block; font-size: .72rem; color: var(--muted); margin-top: 3px; font-weight: 400; }
.aloj-toggle-btn.selected { border-color: var(--blue); background: rgba(30,111,217,.06); color: var(--blue); }
.aloj-toggle-btn.selected small { color: rgba(30,111,217,.7); }

/* pagos */
.pago-btn {
  display: flex; align-items: center; justify-content: space-between;
  padding: 15px 18px; border: 1.5px solid var(--border); border-radius: 8px;
  background: var(--white); cursor: pointer; transition: all .2s; gap: 12px;
  margin-bottom: 10px;
}
.pago-btn:hover { border-color: #bbb; }
.pago-btn.selected { border-color: var(--green); background: rgba(76,175,39,.04); }
.pago-btn-left { display: flex; align-items: center; gap: 12px; }
.pago-radio {
  width: 18px; height: 18px; border-radius: 50%; border: 2px solid var(--border);
  flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: all .15s;
}
.pago-btn.selected .pago-radio { border-color: var(--green); background: var(--green); }
.pago-btn.selected .pago-radio::after { content: ''; width: 7px; height: 7px; border-radius: 50%; background: #fff; display: block; }
.pago-name   { font-size: .9rem; font-weight: 500; }
.pago-detail { font-size: .74rem; color: var(--muted); }
.pago-btn.selected .pago-detail { color: rgba(76,175,39,.8); }
.pago-amount { font-family: var(--f-display); font-size: 1.4rem; letter-spacing: 1px; text-align: right; flex-shrink: 0; }
.pago-btn.selected .pago-amount { color: var(--green); }
.pago-per    { font-size: .66rem; color: var(--muted); text-align: right; }

/* form */
.contact-form { display: flex; flex-direction: column; gap: 14px; }
.form-row2    { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-group   { display: flex; flex-direction: column; gap: 6px; }
.form-lbl     { font-size: .62rem; font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase; color: var(--muted); }
.form-input   { width: 100%; padding: 12px 16px; border: 1.5px solid var(--border); border-radius: 6px; font-family: var(--f-body); font-size: .87rem; color: var(--text); outline: none; transition: border-color .2s; background: var(--white); }
.form-input:focus { border-color: var(--blue); }
.form-input.error { border-color: #e24b4a; }

/* summary */
.cot-right { position: sticky; top: calc(var(--header-h) + 20px); }
.sum-card  { background: var(--white); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.sum-header { background: var(--dark); padding: 20px 24px 16px; }
.sum-header h2 { font-family: var(--f-display); font-size: 1.4rem; letter-spacing: 3px; color: #fff; margin-bottom: 4px; }
.sum-header p  { font-size: .72rem; color: rgba(255,255,255,.35); letter-spacing: 1px; }
.sum-body { padding: 18px 24px; }
.sum-row  { display: flex; justify-content: space-between; align-items: flex-start; padding: 9px 0; border-bottom: 1px solid var(--border); font-size: .84rem; }
.sum-row:last-child { border-bottom: none; }
.sum-key  { color: var(--muted); font-weight: 300; max-width: 55%; }
.sum-val  { font-weight: 500; text-align: right; }
.sum-totals { background: var(--dark); padding: 18px 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.tot-block  { text-align: center; }
.tot-label  { font-size: .58rem; letter-spacing: 2.5px; text-transform: uppercase; color: rgba(255,255,255,.35); margin-bottom: 6px; }
.tot-val    { font-family: var(--f-display); font-size: 1.8rem; letter-spacing: 2px; line-height: 1; }
.tot-sub    { font-size: .66rem; color: rgba(255,255,255,.35); margin-top: 3px; }
.cuota-box  {
  background: rgba(30,111,217,.08); border: 1px solid rgba(30,111,217,.15);
  border-radius: 6px; padding: 12px 20px; margin: 14px 24px;
  display: flex; align-items: center; justify-content: space-between;
}
.cuota-box-lbl { font-size: .72rem; color: var(--blue); font-weight: 300; }
.cuota-box-val { font-family: var(--f-display); font-size: 1.4rem; letter-spacing: 1px; color: var(--blue); }
.sum-actions { padding: 16px 24px 20px; display: flex; flex-direction: column; gap: 10px; }
.btn-wa-cot {
  width: 100%; padding: 13px; background: #25D366; color: #fff; border: none; border-radius: 6px;
  font-family: var(--f-body); font-size: .78rem; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase;
  cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 10px;
  transition: background .2s, transform .15s;
}
.btn-wa-cot:hover { background: #1ea855; transform: translateY(-1px); }
.btn-email-cot {
  width: 100%; padding: 13px; background: var(--orange); color: #fff; border: none; border-radius: 6px;
  font-family: var(--f-body); font-size: .78rem; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase;
  cursor: pointer; transition: opacity .2s, transform .15s;
}
.btn-email-cot:hover { opacity: .88; transform: translateY(-1px); }
.sum-note { padding: 0 24px 16px; font-size: .72rem; color: var(--muted); text-align: center; line-height: 1.6; }

/* Toast */
.toast {
  position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%) translateY(80px);
  background: var(--dark); color: #fff; padding: 12px 28px; border-radius: 50px;
  font-size: .82rem; font-weight: 500; z-index: 9999;
  transition: transform .35s, opacity .35s; opacity: 0; white-space: nowrap;
}
.toast.show { transform: translateX(-50%) translateY(0); opacity: 1; }
.toast.ok   { background: var(--green); }
.toast.err  { background: #e24b4a; }

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 900px) {
  header { padding: 0 20px; }
  .hero-content { padding: calc(var(--header-h) + 16px) 24px 60px; max-width: 100%; }
  .hero-h1 { font-size: clamp(3rem,10vw,5rem); }
  .who-grid { grid-template-columns: 1fr; gap: 40px; }
  .cards-grid { grid-template-columns: 1fr; }
  .fd-grid { grid-template-columns: 1fr; }
  .aloj-grid { grid-template-columns: 1fr; }
  .cot-wrap { grid-template-columns: 1fr; padding: 24px 16px 60px; }
  .cot-right { position: static; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .wa-band { flex-direction: column; align-items: flex-start; padding: 48px 7vw; }
  .form-row2 { grid-template-columns: 1fr; }
  .aloj-toggle { grid-template-columns: 1fr; }
  .who-stats-row { grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
  .who-img { height: 280px; }
}
@media (max-width: 600px) {
  .footer-grid { grid-template-columns: 1fr; }
  .header-cta  { display: none; }
  .pkg-grid    { grid-template-columns: 1fr 1fr; }
}
