/* ============================================================
   BASE — estructura con el lenguaje visual real de La Caravedo.
   Duotono espresso/crema, paneles planos rectos, ornamentos de
   grabado, hero editorial con botella line-art, ondas orgánicas.
   ============================================================ */

/* Orden de secciones por etapa */
main { display: flex; flex-direction: column; }
.hero { order: 0; }
.premios { order: 2; }
.registro { order: 3; }
.cerrado { order: 3; }
.ganadores { order: 4; }
.bases { order: 8; }
[data-when] { display: none; }
html[data-stage="premios"] [data-when~="premios"],
html[data-stage="registro-cerrado"] [data-when~="registro-cerrado"],
html[data-stage="ganadores"] [data-when~="ganadores"] { display: block; }
html[data-stage="ganadores"] .ganadores { order: 1; }
html[data-stage="ganadores"] .premios { order: 6; }
html[data-stage="registro-cerrado"] .cerrado { order: 1; }

/* Barra de cumplimiento (fina, fija) */
.compliance-bar { background: var(--legal-bg); color: var(--legal-fg); border-bottom: 1px solid var(--sand); position: sticky; top: 0; z-index: 40; }
.compliance-bar__in { display: flex; align-items: center; justify-content: center; gap: var(--space-4); padding: 9px 0; flex-wrap: wrap; text-align: center; }
.compliance-bar__legend { font-size: 0.72rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; }
.compliance-bar__age { font-size: 0.66rem; font-weight: 600; letter-spacing: 0.08em; border: 1px solid currentColor; padding: 1px 8px; }

/* Age-gate */
.age-gate { position: fixed; inset: 0; z-index: 60; display: grid; place-items: center; padding: var(--gutter); background: rgba(28, 25, 22, 0.7); backdrop-filter: blur(3px); }
.age-gate[hidden] { display: none; }
.age-gate__card { background: var(--cream); border: 1px solid var(--sand-2); padding: var(--space-8) var(--space-7); max-width: 440px; width: 100%; text-align: center; }
.age-gate__logo { height: 54px; width: auto; margin-bottom: var(--space-5); }
.age-gate__title { font-family: var(--serif); font-size: 2rem; }
.age-gate__text { color: var(--gray-600); margin-top: var(--space-3); }
.age-gate__actions { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; margin-top: var(--space-6); }
.age-gate__legal { margin-top: var(--space-6); letter-spacing: 0.1em; text-transform: uppercase; font-size: 0.66rem; }

/* Header */
.site-header { background: var(--cream); border-bottom: 1px solid var(--sand); }
.site-header__in { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding-block: var(--space-5); }
.site-header__logo { height: 40px; width: auto; }
.site-header__pill { font-size: 0.68rem; font-weight: 500; letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--gray-600); border-left: 1px solid var(--sand-2); padding-left: var(--space-4); }

/* Ornamentos en cabeceras de sección */
.section-head { text-align: center; max-width: 60ch; margin-inline: auto; margin-bottom: var(--space-8); }
.ornament-row { display: flex; align-items: center; justify-content: center; gap: var(--space-4); margin-top: var(--space-3); }
.section-title { font-family: var(--sans); font-size: var(--fs-h2); font-weight: 600; text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--espresso); }
.filigree { display: block; margin: var(--space-4) auto 0; }

/* HERO editorial */
.hero { background: var(--cream); padding-block: clamp(48px, 7vw, 96px) 0; position: relative; }
.hero__in { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: var(--space-8); align-items: center; min-height: 64vh; }
.hero__content { max-width: 26ch; }
.hero__content .overline { color: var(--accent-2); }
.hero__title { font-size: var(--fs-display); margin-top: var(--space-5); color: var(--espresso); line-height: 1.06; }
.hero__sub { font-size: 1.1rem; color: var(--gray-700); margin-top: var(--space-5); max-width: 42ch; font-weight: 300; }
.hero__cta { margin-top: var(--space-7); display: flex; gap: var(--space-4); flex-wrap: wrap; align-items: center; }
.hero__media { position: relative; display: grid; place-items: center; align-self: stretch; min-height: 420px; }
.hero__bottle { width: min(58%, 320px); height: auto; filter: var(--deco-filter); opacity: 0.92; }
.hero__media::after { content: ""; position: absolute; width: 1px; height: 60%; background: linear-gradient(var(--sand-2), transparent); right: 18%; top: 12%; }

/* Onda orgánica entre secciones (duotono) */
.wave { display: block; width: 100%; height: clamp(40px, 6vw, 90px); margin-bottom: -1px; }
.wave path { fill: var(--beige); }

/* Countdown editorial (numerales serif + hairlines) */
.countdown { margin-top: var(--space-7); display: flex; gap: var(--space-5); }
.countdown__box { text-align: center; }
.countdown__num { font-family: var(--serif); font-size: 2.6rem; line-height: 1; color: var(--espresso); font-variant-numeric: tabular-nums; }
.countdown__lbl { display: block; font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.22em; color: var(--gray-600); margin-top: 8px; }
.countdown__sep { align-self: start; font-family: var(--serif); font-size: 2.2rem; color: var(--sand-2); }

/* Secciones */
.premios, .registro, .ganadores, .bases, .cerrado { padding-block: var(--section-y); }
.premios { background: var(--beige); }
.registro { background: var(--cream); }
.ganadores { background: var(--beige); }
.bases { background: var(--cream); }
.cerrado { background: var(--cream); text-align: center; }

/* Premios: paneles planos como "NUESTRAS MARCAS" */
.premios__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.prize { background: var(--panel); border: 1px solid var(--sand); padding: var(--space-6) var(--space-5) var(--space-7); text-align: center; position: relative; transition: border-color var(--dur-base) var(--ease-out); }
.prize:hover { border-color: var(--accent-2); }
.prize__media { aspect-ratio: 4 / 5; display: grid; place-items: center; overflow: hidden; margin-bottom: var(--space-5); }
.prize__media img { max-width: 70%; max-height: 92%; object-fit: contain; mix-blend-mode: multiply; }
.prize__media-fallback { font-family: var(--serif); font-size: 3rem; color: var(--sand-2); }
.prize__badge { display: inline-block; font-size: 0.6rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent-2); border: 1px solid var(--accent-2); padding: 4px 12px; margin-bottom: var(--space-4); }
.prize__title { font-family: var(--sans); font-size: 1rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: var(--espresso); }
.prize__detail { color: var(--gray-600); margin-top: var(--space-3); font-size: var(--fs-small); font-weight: 300; line-height: 1.5; }
.prize__filigree { height: 12px; width: auto; margin-top: var(--space-4); filter: var(--deco-filter); opacity: 0.7; }

/* Registro */
.registro__in { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: var(--space-8); align-items: start; }
.registro__intro { max-width: 40ch; }
.pasos { list-style: none; counter-reset: paso; padding: 0; margin-top: var(--space-7); display: grid; gap: var(--space-5); }
.pasos li { counter-increment: paso; position: relative; padding-left: 60px; }
.pasos li::before { content: "0" counter(paso); position: absolute; left: 0; top: -4px; font-family: var(--serif); font-size: 1.6rem; color: var(--accent-2); }
.pasos b { display: block; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.9rem; }
.pasos span { color: var(--gray-600); font-size: var(--fs-small); font-weight: 300; }

.form-card { background: var(--cream-2); border: 1px solid var(--sand-2); padding: var(--space-7); }
.form-card h3 { font-family: var(--serif); font-weight: 400; font-size: 1.7rem; margin-bottom: var(--space-5); }
.field { margin-bottom: var(--space-5); }
.field label { display: block; font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.16em; margin-bottom: 8px; color: var(--gray-700); }
.field input { width: 100%; font-family: var(--sans); font-size: 1rem; padding: 10px 2px; border: none; border-bottom: 1px solid var(--sand-2); background: transparent; color: var(--espresso); }
.field input:focus { outline: none; border-bottom-color: var(--accent-2); }
.field .req { color: var(--accent-2); }
.field-error { color: #a23a2b; font-size: 0.78rem; margin-top: 6px; min-height: 1em; }
.consent { display: grid; gap: 12px; margin: var(--space-6) 0; }
.consent label { display: grid; grid-template-columns: 20px 1fr; gap: 12px; align-items: start; font-size: 0.8rem; color: var(--gray-600); cursor: pointer; font-weight: 300; }
.consent input { width: 17px; height: 17px; margin-top: 2px; accent-color: var(--accent-2); }
.form-card .btn { width: 100%; }
.honeypot { position: absolute; left: -9999px; }
.form-success { background: var(--cream-2); border: 1px solid var(--accent-2); padding: var(--space-7); text-align: center; }
.form-success h3 { font-family: var(--serif); font-weight: 400; font-size: 1.8rem; }

/* Ganadores */
.buscador { max-width: 440px; margin-inline: auto; margin-bottom: var(--space-5); display: flex; gap: var(--space-4); align-items: end; }
.buscador input { flex: 1; font-family: var(--sans); padding: 10px 2px; border: none; border-bottom: 1px solid var(--sand-2); background: transparent; font-size: 1rem; }
.buscador input:focus { outline: none; border-bottom-color: var(--accent-2); }
.buscador__result { text-align: center; margin-bottom: var(--space-7); font-size: 0.9rem; min-height: 1.4em; color: var(--gray-700); }
.ganadores__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 0; border-top: 1px solid var(--sand); }
.winner { display: flex; align-items: center; gap: var(--space-4); padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--sand); border-right: 1px solid var(--sand); background: transparent; transition: background var(--dur-fast); }
.winner.is-match { background: var(--accent-2-soft); }
.winner__avatar { width: 42px; height: 42px; border: 1px solid var(--accent-2); color: var(--accent-2); display: grid; place-items: center; font-family: var(--serif); font-size: 1.2rem; flex-shrink: 0; }
.winner__name { font-weight: 500; letter-spacing: 0.02em; }
.winner__prize { display: block; font-size: 0.78rem; color: var(--gray-600); font-weight: 300; }
.re-cta { margin-top: var(--space-8); text-align: center; border: 1px solid var(--sand-2); padding: var(--space-7); }
.re-cta p { margin: 0 0 var(--space-5); font-weight: 300; color: var(--gray-700); }

/* Bases */
.bases__in { max-width: 820px; margin-inline: auto; }
.acordeon { margin-top: var(--space-6); }
.acc-item { border-bottom: 1px solid var(--sand); }
.acc-q { width: 100%; text-align: left; background: none; border: none; font-family: var(--sans); font-size: 0.95rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.06em; color: var(--espresso); padding: var(--space-5) 0; cursor: pointer; display: flex; justify-content: space-between; gap: var(--space-4); }
.acc-q::after { content: "+"; color: var(--accent-2); font-family: var(--serif); font-size: 1.4rem; line-height: 1; }
.acc-q[aria-expanded="true"]::after { content: "\2013"; }
.acc-a { color: var(--gray-600); padding: 0 0 var(--space-5); max-width: 64ch; font-weight: 300; }
.acc-a[hidden] { display: none; }

/* Footer */
.site-footer { background: var(--espresso); color: var(--cream); padding-block: var(--space-8); }
.site-footer__legend { font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: #d8cdbf; }
.site-footer__links { display: flex; gap: var(--space-6); flex-wrap: wrap; margin: var(--space-5) 0; }
.site-footer__links a { color: var(--cream); text-decoration: none; font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.12em; border-bottom: 1px solid transparent; padding-bottom: 2px; }
.site-footer__links a:hover { border-bottom-color: var(--accent); }
.site-footer .legal-text { color: #a89e90; }

/* Responsive */
@media (max-width: 880px) {
  .hero__in { grid-template-columns: 1fr; min-height: 0; gap: var(--space-6); }
  .hero__content { max-width: none; }
  .hero__media { min-height: 240px; order: -1; }
  .registro__in { grid-template-columns: 1fr; }
  .premios__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .premios__grid { grid-template-columns: 1fr; }
  .countdown { gap: var(--space-4); }
  .countdown__num { font-size: 2rem; }
}
