/* ════════════════════════════════════════════════════════════
   Andrea Karina Secchi — Sistema EDITORIAL (estilos compartidos)
   Tipografía + componentes + animaciones, editables en un solo lugar.
   ════════════════════════════════════════════════════════════ */

/* ── Variables de marca ─────────────────────────────────────── */
:root {
  /* Tipografía (self-hosted en assets/fonts/, ver assets/fonts.css) */
  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body:    "IBM Plex Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-mono:    "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;

  /* Paleta (única fuente de verdad) */
  --petrol:       #0C3B3C;   /* verde petróleo — bloques sólidos */
  --petrol-deep:  #0A3132;   /* verde hover / campo profundo */
  --cream:        #F4F0E8;   /* crema */
  --paper:        #FBF9F4;   /* papel */
  --ink:          #15201E;   /* tinta */
  --gold:         #A98143;   /* dorado — ÚNICO acento */
  --gold-soft:    #C9A86B;   /* tinte de dorado para fondos oscuros */
  --line:         rgba(21, 32, 30, .14);  /* hairline sobre claro */
  --line-dark:    rgba(244, 240, 232, .16); /* hairline sobre verde */

  /* REEMPLAZAR POR FOTO REAL DE ANDREA
     Cuando exista la foto, basta con setear esta variable a:
     --hero-photo: url("assets/andrea.jpg");
     y el panel verde del hero la usa de fondo automáticamente. */
  --hero-photo: none;
}

html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body); -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  /* Fondo liso color crema (sin patrón) para no interferir con la lectura. */
  background-color: var(--cream);
}

/* Display: óptico automático + tracking levemente negativo en títulos */
.font-display { font-family: var(--font-display); font-optical-sizing: auto; letter-spacing: -0.012em; }
h1.font-display, .h-tight { letter-spacing: -0.02em; line-height: 1.05; }

/* Números y datos: mono con cifras tabulares siempre */
.font-mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1; }

/* eyebrow / labels mono en mayúscula con tracking */
.eyebrow { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.18em; }

/* ── Componentes editoriales ────────────────────────────────── */

/* Botón sólido único: rectángulo verde, esquinas rectas */
.btn-solid {
  display: inline-flex; justify-content: center; align-items: center; gap: .5rem;
  background: var(--petrol); color: var(--cream);
  border: 1px solid var(--petrol); border-radius: 0;
  padding: 1rem 1.75rem; font-family: var(--font-body); font-weight: 500; font-size: 1rem; line-height: 1;
  transition: background .25s ease, border-color .25s ease;
}
.btn-solid:hover { background: var(--petrol-deep); border-color: var(--petrol-deep); }

/* Variante dorada sólida (sobre campos verdes) */
.btn-gold {
  display: inline-flex; justify-content: center; align-items: center; gap: .5rem;
  background: var(--gold); color: var(--petrol-deep);
  border: 1px solid var(--gold); border-radius: 0;
  padding: 1rem 1.75rem; font-weight: 600; font-size: 1rem; line-height: 1;
  transition: background .25s ease, border-color .25s ease;
}
.btn-gold:hover { background: var(--gold-soft); border-color: var(--gold-soft); }

/* Link de WhatsApp: subrayado dorado, sin caja */
.link-wa { text-decoration: underline; text-decoration-color: var(--gold);
  text-decoration-thickness: 1.5px; text-underline-offset: 5px; font-weight: 500;
  transition: color .2s ease, text-decoration-color .2s ease; }
.link-wa:hover { color: var(--gold); }
.link-wa-dark { text-decoration: underline; text-decoration-color: var(--gold-soft);
  text-decoration-thickness: 1.5px; text-underline-offset: 5px; font-weight: 500;
  transition: color .2s ease; }
.link-wa-dark:hover { color: var(--gold-soft); }

/* Hairlines utilitarias */
.hairline   { border: 0; border-top: 1px solid var(--line); }
.hairline-v { width: 1px; align-self: stretch; background: var(--line); }

/* ── Hero: composición tipográfica verde (sin foto) ─────────── */
/* El panel verde sangra hacia el borde derecho del viewport en ≥lg. */
.hero-green {
  position: relative; overflow: hidden;
  background-color: var(--petrol);
  background-image: var(--hero-photo);  /* none por defecto; foto futura */
  background-size: cover; background-position: center;
}
@media (min-width: 1024px) {
  /* El panel verde sangra hasta el borde derecho del viewport SIN pasarse.
     Antes usaba calc(50% - 50vw): en un grid item el 50% se resuelve contra
     la COLUMNA (no el contenedor), así que el panel se desbordaba ~265px y se
     llevaba el monograma fuera de pantalla (y empeoraba al hacer zoom-out).
     Acá la extensión se calcula en viewport+rem: mitad del contenido del
     contenedor = 34rem (max-w-6xl 72rem con padding lateral 2rem). Por debajo
     de 72rem de ancho el contenedor llena la pantalla ⇒ sólo el padding (2rem). */
  .hero-green {
    margin-right: min(-2rem, 34rem - 50vw);
    padding-right: calc(2.5rem + max(2rem, 50vw - 34rem));
  }
}
/* Monograma de marca en marca de agua */
.hero-monogram {
  position: absolute; right: -0.04em; bottom: -0.16em; z-index: 0;
  font-family: var(--font-display); font-weight: 500; line-height: .8;
  font-size: clamp(140px, 24vw, 320px); letter-spacing: -0.05em;
  color: rgba(244, 240, 232, .06); pointer-events: none; user-select: none;
}
/* Bloque crema plano que pisa la costura entre columnas */
.hero-break {
  background: var(--cream); color: var(--ink); border: 0; border-radius: 0;
}

/* ── Ajustes de los efectos heredados ───────────────────────── */

/* underline animado en links de nav + estado de página activa */
.nav-link { position: relative; }
.nav-link::after { content: ''; position: absolute; left: 0; bottom: -6px; height: 1.5px; width: 0; background: var(--gold); transition: width .3s ease; }
.nav-link:hover::after, .nav-link:focus-visible::after { width: 100%; }
.nav-link[aria-current="page"] { color: var(--ink); }
.nav-link[aria-current="page"]::after { width: 100%; }

/* reveal al scrollear */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }

/* hover editorial de bloques: SIN sombra ni salto — sólo la hairline vira a dorado */
.lift { transition: border-color .3s ease; }
.lift:hover { border-color: var(--gold); }

/* hover con movimiento (tarjetas de planes): se elevan suave + sombra + borde dorado */
.lift-move { transition: transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease, border-color .3s ease; }
.lift-move:hover { transform: translateY(-6px); box-shadow: 0 18px 38px -18px rgba(21,32,30,.35); border-color: var(--gold); }
@media (prefers-reduced-motion: reduce) { .lift-move, .lift-move:hover { transform: none; box-shadow: none; transition: none; } }

/* textura sutil para placeholders de imagen */
.ph-texture { background-image: repeating-linear-gradient(135deg, rgba(21,32,30,.05) 0 2px, transparent 2px 9px); }
.ph-texture-dark { background-image: repeating-linear-gradient(135deg, rgba(244,240,232,.06) 0 2px, transparent 2px 9px); }

/* pulso del FAB whatsapp */
@keyframes pulse-ring { 0% { box-shadow: 0 0 0 0 rgba(37,211,102,.5); } 70% { box-shadow: 0 0 0 14px rgba(37,211,102,0); } 100% { box-shadow: 0 0 0 0 rgba(37,211,102,0); } }
.fab-pulse { animation: pulse-ring 2.6s infinite; }

/* slider de las calculadoras (acento dorado, esquinas rectas) */
input[type=range].rng { -webkit-appearance: none; appearance: none; height: 4px; border-radius: 0; background: #18564F; outline: none; }
input[type=range].rng::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 24px; height: 24px; border-radius: 0; background: var(--gold); cursor: pointer; border: 2px solid var(--petrol); }
input[type=range].rng::-moz-range-thumb { width: 24px; height: 24px; border-radius: 0; background: var(--gold); cursor: pointer; border: 2px solid var(--petrol); }

*:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; border-radius: 0; }
[x-cloak] { display: none !important; }

/* Legibilidad de los <select>: el desplegable nativo usa fondo del SO
   (normalmente blanco), donde el texto crema heredado queda invisible.
   Forzamos texto tinta sobre papel en las opciones. */
select option { color: var(--ink); background-color: var(--paper); }

/* Scroll-lock al abrir el menú mobile: congela el fondo (la página no se
   mueve detrás del overlay). body.nav-open se fija en su lugar; el JS del
   header (x-effect) guarda/restaura la posición de scroll. */
body.nav-open { position: fixed; left: 0; right: 0; width: 100%; overflow: hidden; }

/* ── Usabilidad de formularios / a11y ───────────────────────── */

/* iOS Safari hace auto-zoom al focar inputs con font-size < 16px.
   En mobile forzamos 16px en los controles para evitar el zoom no
   deseado (crítico en el campo de CUIT). En ≥sm vuelve al tamaño
   de diseño, donde el zoom no aplica. */
@media (max-width: 639px) {
  input, select, textarea,
  input[class], select[class], textarea[class] { font-size: 16px; }
}

/* Foco siempre visible en los controles: algunos usan utilidades que
   anulan el outline. Restauramos el outline dorado del sistema. */
input:focus-visible, select:focus-visible, textarea:focus-visible,
a:focus-visible, button:focus-visible {
  outline: 2px solid var(--gold); outline-offset: 2px;
}

/* Targets táctiles cómodos en mobile: los links de listas del footer
   y de navegación quedan con altura suficiente (>=44px de área). */
@media (max-width: 1023px) {
  footer nav a, footer ul a { display: inline-block; padding-block: .35rem; }
}


/* ════════════════════════════════════════════════════════════
   Movimiento: transición entre páginas (View Transitions) +
   aparición escalonada del texto al cargar.
   ════════════════════════════════════════════════════════════ */
@view-transition { navigation: auto; }
::view-transition-old(root) { animation: vt-out .25s ease both; }
::view-transition-new(root) { animation: vt-in .45s cubic-bezier(.2,.7,.2,1) both; }
@keyframes vt-out { to { opacity: 0; } }
@keyframes vt-in { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

@keyframes rise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: no-preference) {
  .hero-intro > *,
  .hero-aside,
  .page-intro .max-w-6xl > * { animation: rise .7s cubic-bezier(.2,.7,.2,1) both; }
  .hero-intro > :nth-child(1) { animation-delay: .05s; }
  .hero-intro > :nth-child(2) { animation-delay: .13s; }
  .hero-intro > :nth-child(3) { animation-delay: .21s; }
  .hero-intro > :nth-child(4) { animation-delay: .29s; }
  .hero-intro > :nth-child(5) { animation-delay: .37s; }
  .hero-aside { animation-delay: .30s; }
  .page-intro .max-w-6xl > :nth-child(2) { animation-delay: .10s; }
  .page-intro .max-w-6xl > :nth-child(3) { animation-delay: .18s; }
  .page-intro .max-w-6xl > :nth-child(4) { animation-delay: .26s; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .fab-pulse { animation: none; }
  ::view-transition-old(root), ::view-transition-new(root) { animation: none !important; }
}

/* contraste AA: eyebrows dorados sobre fondo claro usan un dorado mas oscuro legible (sobre verde se mantiene el gold-500/gold-300 actual) */
.eyebrow.text-gold-500 { color: #7E5E2A; }
