/* ============================================================
   CINCO BAÑOS · Sistema de diseño base · v1
   Tokens + base + componentes
   ============================================================ */

:root{
  /* ---- Color · marca ---- */
  --sage:        #3A5A40;  /* primario: marca, headers, bloques de fondo */
  --sage-deep:   #2E4833;  /* hover / sage sobre sage */
  --sage-line:   #56705B;  /* líneas y bordes sobre sage */
  --sage-tint:   #E7ECE5;  /* bloque sage muy claro sobre crema */

  --cream:       #F5F1E8;  /* fondo principal */
  --paper:       #FCFAF4;  /* tarjetas / superficie elevada */
  --cream-deep:  #ECE5D6;  /* divisores / bloque crema profundo */

  --coral:       #E07A5F;  /* CTA, urgencia, acento */
  --coral-deep:  #C9684E;  /* hover CTA */
  --coral-tint:  #F4D9CF;  /* fondo suave de acento */

  --graphite:    #1B1B1B;  /* texto principal */
  --ink-2:       #5B564E;  /* texto secundario AA sobre crema */
  --stone:       #A8A29E;  /* líneas, separadores, labels apagados */
  --stone-line:  #D8D2C6;  /* hairlines sobre crema */

  /* ---- Tipografía ---- */
  --f-display:  'Space Grotesk', system-ui, sans-serif;  /* opción A (elegida) */
  --f-display-b:'Sora', system-ui, sans-serif;           /* opción B (comparativa) */
  --f-body:     'Hanken Grotesk', system-ui, sans-serif; /* cuerpo */
  --f-serif:    'Newsreader', Georgia, serif;            /* acento editorial */
  --f-mono:     'Space Grotesk', ui-monospace, monospace;/* etiquetas técnicas */

  /* ---- Escala tipográfica (px) ---- */
  --t-mega:   200px; /* el "5" icónico */
  --t-d1:     96px;
  --t-d2:     72px;
  --t-h1:     52px;
  --t-h2:     38px;
  --t-h3:     28px;
  --t-h4:     22px;
  --t-bodyl:  20px;
  --t-body:   17px;
  --t-bodys:  15px;
  --t-label:  13px;

  /* ---- Spacing (base 4) ---- */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px;
  --s6:32px; --s7:48px; --s8:64px; --s9:96px; --s10:128px;

  /* ---- Radios ---- */
  --r-xs:2px; --r-sm:6px; --r-md:12px; --r-lg:20px; --r-pill:999px;

  /* ---- Sombra (mínima, plano > profundidad) ---- */
  --shadow-soft: 0 1px 2px rgba(27,27,27,.04), 0 8px 24px rgba(46,72,51,.06);

  --maxw: 1180px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--cream);
  color:var(--graphite);
  font-family:var(--f-body);
  font-size:var(--t-body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit}

/* ---- Helpers de tipo ---- */
.display{font-family:var(--f-display);font-weight:700;line-height:1.02;letter-spacing:-.02em}
.serif{font-family:var(--f-serif)}
.eyebrow{
  font-family:var(--f-mono);
  font-size:var(--t-label);
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-2);
}
.muted{color:var(--ink-2)}

/* ============================================================
   COMPONENTES
   ============================================================ */

/* ---- Botones ---- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-display);
  font-weight:600;
  font-size:17px;
  line-height:1;
  padding:18px 28px;
  border-radius:var(--r-pill);
  border:1.5px solid transparent;
  cursor:pointer;
  text-decoration:none;
  transition:background .18s ease, color .18s ease, border-color .18s ease, transform .12s ease;
}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:3px solid var(--sage);outline-offset:3px}

.btn--primary{background:var(--coral);color:#231310}
.btn--primary:hover{background:var(--coral-deep);color:#fff}

.btn--secondary{background:transparent;color:var(--sage);border-color:var(--sage)}
.btn--secondary:hover{background:var(--sage);color:var(--cream)}

.btn--ghost{background:transparent;color:var(--graphite);border-color:var(--stone-line)}
.btn--ghost:hover{border-color:var(--graphite)}

.btn .arr{font-size:18px;transform:translateY(-1px)}

/* botón sobre fondo sage */
.on-sage .btn--secondary{color:var(--cream);border-color:var(--sage-line)}
.on-sage .btn--secondary:hover{background:var(--cream);color:var(--sage);border-color:var(--cream)}

/* ---- Tarjeta de testimonio ---- */
.tcard{
  background:var(--paper);
  border:1px solid var(--stone-line);
  border-radius:var(--r-lg);
  padding:var(--s6);
  display:flex;flex-direction:column;gap:var(--s5);
}
.tcard__quote{
  font-family:var(--f-serif);
  font-size:24px;
  line-height:1.4;
  font-style:italic;
  color:var(--graphite);
  margin:0;
}
.tcard__bath{
  border-radius:var(--r-md);
  height:200px;
}
.tcard__who{display:flex;align-items:center;gap:var(--s4)}
.tcard__avatar{
  width:54px;height:54px;border-radius:var(--r-pill);flex:none;
}
.tcard__name{font-weight:600;font-size:var(--t-bodys);letter-spacing:.01em}
.tcard__meta{font-size:var(--t-label);color:var(--ink-2);margin-top:2px}

/* ---- Bloque de precio grande ---- */
.pcard{
  background:var(--paper);
  border:1px solid var(--stone-line);
  border-radius:var(--r-lg);
  padding:var(--s6);
  display:flex;flex-direction:column;gap:var(--s4);
}
.pcard--feature{
  background:var(--sage);
  color:var(--cream);
  border-color:var(--sage);
}
.pcard__tag{
  font-family:var(--f-mono);font-size:var(--t-label);font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);
}
.pcard--feature .pcard__tag{color:#C9D4C6}
.pcard__name{font-family:var(--f-display);font-size:var(--t-h3);font-weight:600;letter-spacing:-.01em}
.pcard__price{
  font-family:var(--f-display);
  font-weight:700;
  font-size:64px;
  line-height:.95;
  letter-spacing:-.03em;
  display:flex;align-items:baseline;gap:4px;
}
.pcard__price small{font-size:24px;font-weight:600}
.pcard__since{font-size:var(--t-bodys);color:var(--ink-2)}
.pcard--feature .pcard__since{color:#C9D4C6}
.pcard__list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.pcard__list li{display:flex;gap:10px;font-size:var(--t-bodys);align-items:flex-start}
.pcard__list .tick{color:var(--coral);font-weight:700;flex:none}
.pcard--feature .pcard__list .tick{color:#F0B6A4}

/* ---- Acordeón FAQ ---- */
.faq{border-top:1px solid var(--stone-line)}
.faq details{border-bottom:1px solid var(--stone-line)}
.faq summary{
  list-style:none;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:var(--s4);
  padding:var(--s5) 0;
  font-family:var(--f-display);font-weight:600;font-size:var(--t-h4);
  letter-spacing:-.01em;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary:focus-visible{outline:3px solid var(--sage);outline-offset:4px;border-radius:var(--r-xs)}
.faq .sign{
  flex:none;width:34px;height:34px;border-radius:var(--r-pill);
  border:1.5px solid var(--stone-line);
  display:grid;place-items:center;font-size:20px;color:var(--sage);
  transition:transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.faq details[open] .sign{background:var(--sage);color:var(--cream);border-color:var(--sage);transform:rotate(45deg)}
.faq__body{padding:0 0 var(--s5);max-width:60ch;color:var(--ink-2);font-size:var(--t-body)}

/* ---- Item de timeline día-por-día ---- */
.day{
  position:relative;
  background:var(--paper);
  border:1px solid var(--stone-line);
  border-radius:var(--r-md);
  padding:var(--s5);
  display:flex;flex-direction:column;gap:var(--s3);
  overflow:hidden;
}
.day__n{
  font-family:var(--f-display);
  font-weight:700;
  font-size:88px;
  line-height:.8;
  letter-spacing:-.04em;
  color:var(--sage);
}
.day__k{font-family:var(--f-mono);font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--coral)}
.day__t{font-family:var(--f-display);font-weight:600;font-size:var(--t-h4);letter-spacing:-.01em}
.day__d{font-size:var(--t-bodys);color:var(--ink-2);margin:0}
.day--last{background:var(--sage);border-color:var(--sage);color:var(--cream)}
.day--last .day__n{color:var(--cream)}
.day--last .day__d{color:#C9D4C6}
.day--last .day__k{color:var(--coral-tint)}

/* ---- Card antes/después (slider) ---- */
.ba{
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--stone-line);
  background:var(--paper);
}
.ba__stage{
  position:relative;height:300px;overflow:hidden;user-select:none;
  touch-action:none;cursor:ew-resize;
}
.ba__img{position:absolute;inset:0;height:100%;width:100%}
.ba__after{z-index:1}
.ba__before{z-index:2;width:50%;border-right:2px solid var(--cream)}
.ba__tag{
  position:absolute;top:14px;z-index:3;
  font-family:var(--f-mono);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  background:rgba(27,27,27,.72);color:#fff;padding:5px 10px;border-radius:var(--r-pill);
}
.ba__tag--b{left:14px}
.ba__tag--a{right:14px;background:var(--coral);color:#231310}
.ba__handle{
  position:absolute;top:0;bottom:0;left:50%;z-index:4;width:2px;background:var(--cream);
  transform:translateX(-1px);
}
.ba__knob{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:46px;height:46px;border-radius:var(--r-pill);background:var(--cream);
  display:grid;place-items:center;color:var(--sage);font-size:18px;font-weight:700;
  box-shadow:var(--shadow-soft);
}
.ba__foot{padding:var(--s5);display:flex;justify-content:space-between;align-items:flex-end;gap:var(--s4)}
.ba__place{font-family:var(--f-display);font-weight:600;font-size:var(--t-h4)}
.ba__sub{font-size:var(--t-bodys);color:var(--ink-2)}

/* ---- Placeholder de imagen (briefing fotográfico) ---- */
.ph{
  position:relative;
  background-color:var(--cream-deep);
  background-image:repeating-linear-gradient(135deg,
     rgba(58,90,64,.10) 0 2px, transparent 2px 11px);
  display:grid;place-items:center;
  color:var(--sage);
}
.ph--sage{
  background-color:#33503A;
  background-image:repeating-linear-gradient(135deg,
     rgba(245,241,232,.10) 0 2px, transparent 2px 11px);
  color:var(--cream);
}
.ph__lab{
  font-family:var(--f-mono);font-size:11px;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;text-align:center;line-height:1.5;padding:10px 14px;max-width:80%;
  opacity:.85;
}
