/* ============================================================
   MARELI SELECTION — Editorial stylesheet
   V1 · 2026-07-04
   Tipografías: Cormorant Garamond (display) · Jost (texto)
   ============================================================ */

:root{
  --bg:        #FAF7F1;
  --paper:     #FFFFFF;
  --ink:       #23201B;
  --ink-soft:  #4A443C;
  --muted:     #7D746A;
  --line:      #E6DFD3;
  --accent:    #A0784A;
  --accent-d:  #7C5B36;
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Jost", "Segoe UI", sans-serif;
  --max: 1180px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

.container{ max-width:var(--max); margin:0 auto; padding:0 28px; }

/* ---------- Utilidades editoriales ---------- */
.kicker{
  font-size:11px; letter-spacing:.38em; text-transform:uppercase;
  color:var(--accent); font-weight:400; margin-bottom:18px;
}
.serif{ font-family:var(--serif); }
.section{ padding:92px 0; }
.section--tight{ padding:64px 0; }
.section-head{ max-width:640px; margin-bottom:56px; }
.section-head h2{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(1.9rem, 3.4vw, 2.7rem); line-height:1.15;
}
.section-head p{ color:var(--muted); margin-top:14px; max-width:52ch; }
.rule{ border:none; border-top:1px solid var(--line); }

.textlink{
  display:inline-block; font-size:12.5px; letter-spacing:.22em;
  text-transform:uppercase; font-weight:400; color:var(--ink);
  border-bottom:1px solid var(--accent); padding-bottom:6px;
  transition:color .25s, border-color .25s;
}
.textlink:hover{ color:var(--accent-d); border-color:var(--accent-d); }

/* ---------- Barra superior ---------- */
.topline{
  text-align:center; font-size:10.5px; letter-spacing:.32em;
  text-transform:uppercase; color:var(--muted);
  padding:12px 16px; border-bottom:1px solid var(--line);
  background:var(--bg);
}

/* ---------- Cabecera ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(250,247,241,.94); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.header-in{
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 28px; max-width:var(--max); margin:0 auto;
}
.brand{ display:flex; flex-direction:column; line-height:1; }
.brand-name{
  font-family:var(--serif); font-size:1.55rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
}
.brand-tag{
  font-size:9px; letter-spacing:.5em; text-transform:uppercase;
  color:var(--accent); margin-top:7px;
}
.nav{ display:flex; gap:36px; align-items:center; }
.nav a{
  font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-soft); transition:color .2s; padding:4px 0;
}
.nav a:hover, .nav a[aria-current="page"]{ color:var(--accent-d); }
.nav a[aria-current="page"]{ border-bottom:1px solid var(--accent); }

.nav-toggle{
  display:none; background:none; border:none; cursor:pointer;
  font-size:11px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ink); padding:8px 0;
}

@media (max-width:900px){
  .nav-toggle{ display:block; }
  .nav{
    display:none; position:absolute; top:100%; left:0; right:0;
    background:var(--bg); border-bottom:1px solid var(--line);
    flex-direction:column; gap:0; padding:12px 0 20px;
  }
  .nav.open{ display:flex; }
  .nav a{ padding:13px 28px; width:100%; }
}

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:76vh; display:flex; align-items:flex-end; overflow:hidden; }
.hero img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(24,20,15,.62) 0%, rgba(24,20,15,.12) 55%, rgba(24,20,15,.05) 100%);
}
.hero-in{ position:relative; z-index:2; color:#FDFBF7; padding:0 28px 84px; max-width:var(--max); margin:0 auto; width:100%; }
.hero .kicker{ color:#E4CFA8; }
.hero h1{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.5rem, 6vw, 4.4rem); line-height:1.06; max-width:13ch;
}
.hero p{ margin-top:20px; max-width:46ch; font-size:1.05rem; color:rgba(253,251,247,.88); }
.hero .textlink{ margin-top:34px; color:#FDFBF7; border-color:#E4CFA8; }
.hero .textlink:hover{ color:#E4CFA8; }

/* Hero interior (páginas de categoría) */
.hero--page{ min-height:52vh; }

/* ---------- Manifiesto ---------- */
.manifesto{ text-align:center; max-width:720px; margin:0 auto; }
.manifesto p{
  font-family:var(--serif); font-size:clamp(1.35rem, 2.6vw, 1.85rem);
  line-height:1.5; font-weight:500; color:var(--ink-soft);
}
.manifesto p em{ color:var(--accent-d); }

/* ---------- Categorías ---------- */
.cats{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
@media (max-width:820px){ .cats{ grid-template-columns:1fr; } }
.cat{ position:relative; overflow:hidden; display:block; }
.cat img{ width:100%; aspect-ratio:3/4; object-fit:cover; transition:transform .8s ease; }
.cat:hover img{ transform:scale(1.03); } /* SPEC-002 §14: zoom máx. 1.03 */
.cat::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(24,20,15,.55), rgba(24,20,15,0) 55%);
}
.cat-label{
  position:absolute; left:26px; bottom:24px; z-index:2; color:#FDFBF7;
}
.cat-label .kicker{ color:#E4CFA8; margin-bottom:8px; }
.cat-label h3{ font-family:var(--serif); font-weight:500; font-size:1.6rem; }

/* ---------- Productos ---------- */
.products{
  display:grid; gap:34px 26px;
  grid-template-columns:repeat(auto-fill, minmax(235px, 1fr));
}
.product-link{ display:block; }
.product-media{
  overflow:hidden; background:#EFE9DF; margin-bottom:18px;
}
.product-media img{
  width:100%; aspect-ratio:4/5; object-fit:cover;
  transition:transform .7s ease;
}
.product-link:hover .product-media img{ transform:scale(1.03); }
.product-brand{
  font-size:10.5px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--muted); margin-bottom:7px;
}
.product-name{
  font-family:var(--serif); font-weight:500; font-size:1.18rem;
  line-height:1.3; color:var(--ink);
}
/* Criterio editorial: voz de editora en serif */
.product-note{
  font-family:var(--serif); font-size:1.05rem; color:var(--ink-soft);
  font-style:italic; margin-top:7px; line-height:1.45;
}
.product-price{ color:var(--muted); font-size:.92rem; margin-top:6px; }
.product-cta{
  display:inline-block; margin-top:12px; font-size:11px;
  letter-spacing:.24em; text-transform:uppercase; color:var(--accent-d);
  border-bottom:1px solid var(--line); padding-bottom:4px;
  transition:border-color .25s;
}
.product-link:hover .product-cta{ border-color:var(--accent); }

/* Nota de afiliación discreta */
.affiliate-note{
  font-size:12px; color:var(--muted); font-style:italic;
  margin-top:44px; max-width:64ch;
}

/* ---------- Bloque editorial (imagen + texto) ---------- */
.split{
  display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;
}
@media (max-width:860px){ .split{ grid-template-columns:1fr; gap:36px; } }
.split img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.split h2{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(1.8rem, 3vw, 2.4rem); line-height:1.15; margin-bottom:18px;
}
.split p{ color:var(--ink-soft); margin-bottom:14px; }
.split .textlink{ margin-top:16px; }

/* ---------- Newsletter ---------- */
.newsletter{ background:var(--ink); color:#F4EFE6; }
.newsletter-in{
  max-width:680px; margin:0 auto; text-align:center; padding:96px 28px;
}
.newsletter .kicker{ color:#CBA96F; }
.newsletter h2{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(1.9rem, 3.4vw, 2.6rem); line-height:1.2;
}
.newsletter p{ color:rgba(244,239,230,.72); margin-top:16px; }
.nl-form{
  display:flex; gap:0; margin-top:38px; border-bottom:1px solid rgba(244,239,230,.45);
}
.nl-form input{
  flex:1; background:none; border:none; outline:none;
  color:#F4EFE6; font-family:var(--sans); font-weight:300;
  font-size:1rem; padding:14px 4px; letter-spacing:.02em;
}
.nl-form input::placeholder{ color:rgba(244,239,230,.45); }
.nl-form button{
  background:none; border:none; cursor:pointer; color:#CBA96F;
  font-family:var(--sans); font-size:11.5px; letter-spacing:.26em;
  text-transform:uppercase; padding:14px 4px; transition:color .2s;
}
.nl-form button:hover{ color:#F4EFE6; }
.nl-msg{ margin-top:22px; font-family:var(--serif); font-size:1.15rem; color:#CBA96F; min-height:1.5em; }
.nl-privacy{ font-size:11.5px; color:rgba(244,239,230,.45); margin-top:14px; }
@media (max-width:560px){ .nl-form{ flex-direction:column; border:none; }
  .nl-form input{ border-bottom:1px solid rgba(244,239,230,.45); }
  .nl-form button{ margin-top:18px; } }

/* ---------- Pie ---------- */
.site-footer{ border-top:1px solid var(--line); background:var(--bg); }
.footer-in{
  max-width:var(--max); margin:0 auto; padding:72px 28px 0;
  display:grid; grid-template-columns:2fr 1fr 1fr; gap:48px;
}
@media (max-width:760px){ .footer-in{ grid-template-columns:1fr; gap:36px; } }
.footer-brand .brand-name{ font-size:1.3rem; }
.footer-brand p{ color:var(--muted); font-size:.92rem; margin-top:16px; max-width:38ch; }
.footer-col h4{
  font-size:11px; letter-spacing:.3em; text-transform:uppercase;
  font-weight:400; color:var(--ink); margin-bottom:18px;
}
.footer-col a{
  display:block; color:var(--muted); font-size:.94rem;
  padding:5px 0; transition:color .2s;
}
.footer-col a:hover{ color:var(--accent-d); }
.footer-legal{
  max-width:var(--max); margin:56px auto 0; padding:22px 28px;
  border-top:1px solid var(--line);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-size:12px; color:var(--muted);
}
.footer-legal a{ color:var(--muted); }
.footer-legal a:hover{ color:var(--accent-d); }

/* ---------- Artículo ---------- */
.article-head{ max-width:760px; margin:0 auto; text-align:center; padding:80px 28px 48px; }
.article-head h1{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.1rem, 4.5vw, 3.3rem); line-height:1.12;
}
.article-head .meta{ margin-top:20px; font-size:12px; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); }
.article-hero{ max-width:980px; margin:0 auto; padding:0 28px; }
.article-hero img{ width:100%; aspect-ratio:16/9; object-fit:cover; }
.article-hero figcaption{ font-size:12px; color:var(--muted); margin-top:10px; font-style:italic; }
.article-body{ max-width:680px; margin:0 auto; padding:56px 28px 40px; }
.article-body p{ margin-bottom:24px; color:var(--ink-soft); font-size:1.06rem; }
.article-body h2{
  font-family:var(--serif); font-weight:500; font-size:1.75rem;
  margin:48px 0 18px; line-height:1.2;
}
.article-body blockquote{
  font-family:var(--serif); font-size:1.45rem; line-height:1.45;
  color:var(--accent-d); border-left:2px solid var(--accent);
  padding-left:26px; margin:40px 0;
}
.article-body .lead{ font-size:1.22rem; font-family:var(--serif); color:var(--ink); }
.article-products{ max-width:980px; margin:0 auto; padding:24px 28px 72px; }

/* ---------- Página legal ---------- */
.legal-body{ max-width:720px; margin:0 auto; padding:72px 28px 96px; }
.legal-body h1{ font-family:var(--serif); font-weight:500; font-size:2.4rem; margin-bottom:12px; }
.legal-body h2{ font-family:var(--serif); font-weight:500; font-size:1.5rem; margin:44px 0 14px; }
.legal-body p, .legal-body li{ color:var(--ink-soft); font-size:.98rem; margin-bottom:12px; }
.legal-body ul{ padding-left:22px; }

/* ============================================================
   MARELI EDITORIAL MOSAIC SYSTEM
   Clusters irregulares: nada de cuadrículas uniformes.
   Patrón de productos (ciclo de 5): 2 piezas anchas + 3 verticales.
   ============================================================ */

/* --- Cluster de categorías (Home) --- */
.cats{
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:215px;
  gap:14px; /* ventanas casi compartiendo borde (MEMS §4) */
}
.cat img{ aspect-ratio:auto; height:100%; }
.cat:nth-child(1){ grid-column:span 4; grid-row:span 2; }
.cat:nth-child(2){ grid-column:span 2; grid-row:span 2; }
.cat:nth-child(3){ grid-column:span 2; }
.cat:nth-child(4){ grid-column:span 2; }
.cat:nth-child(5){ grid-column:span 2; }
.cat:nth-child(6){ grid-column:span 6; grid-row:span 1; }
.cat:nth-child(6) img{ object-position:center 35%; }
/* Responsive del cluster: tablet mosaico 2 col (701–820) y móvil vertical (≤700) — ver bloque RC2 */

/* --- Cluster de productos --- */
.products{
  grid-template-columns:repeat(6,1fr);
  gap:44px 26px;
}
.product{ grid-column:span 2; }
.product:nth-child(5n+1),
.product:nth-child(5n+2){ grid-column:span 3; }
.product:nth-child(5n+1) .product-media img,
.product:nth-child(5n+2) .product-media img{ aspect-ratio:5/4; }
.product:nth-child(5n+4) .product-media img{ aspect-ratio:1/1; }
.product:nth-child(5n+1) .product-name,
.product:nth-child(5n+2) .product-name{ font-size:1.4rem; }
@media (max-width:820px){
  .products{ grid-template-columns:repeat(2,1fr); gap:36px 18px; }
  .product, .product:nth-child(5n+1), .product:nth-child(5n+2){ grid-column:auto; }
  .product:nth-child(5n+1) .product-media img,
  .product:nth-child(5n+2) .product-media img{ aspect-ratio:4/5; }
  .product:nth-child(5n+1) .product-name,
  .product:nth-child(5n+2) .product-name{ font-size:1.18rem; }
}
@media (max-width:520px){
  .products{ grid-template-columns:1fr; }
  .product .product-media img{ aspect-ratio:4/3; }
}

/* --- Breadcrumbs --- */
.breadcrumbs{
  font-size:10.5px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--muted); padding:16px 0; border-bottom:1px solid var(--line);
}
.breadcrumbs a{ color:var(--muted); transition:color .2s; }
.breadcrumbs a:hover{ color:var(--accent-d); }
.breadcrumbs .sep{ margin:0 12px; color:var(--line); }

/* --- FAQs editoriales --- */
.faq-section{ border-top:1px solid var(--line); padding-top:72px; padding-bottom:80px; }
.faqs{ max-width:760px; }
.faq{ border-bottom:1px solid var(--line); }
.faq summary{
  cursor:pointer; list-style:none; display:flex; justify-content:space-between;
  align-items:baseline; gap:24px; padding:22px 0;
  font-family:var(--serif); font-size:1.25rem; font-weight:500; color:var(--ink);
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--sans); font-weight:300; color:var(--accent); font-size:1.3rem; }
.faq[open] summary::after{ content:"–"; }
.faq p{ color:var(--ink-soft); padding:0 0 24px; max-width:62ch; }

/* ============================================================
   RC2 — REFINAMIENTO EDITORIAL
   Hover según SPEC-002 (máx. 1.03) · ritmo escalonado ·
   capitular · reveal on scroll · tablet mosaico
   ============================================================ */

::selection{ background:var(--accent); color:#FDFBF7; }

/* Ritmo escalonado del mosaico de productos (romper alineación mecánica) */
@media (min-width:821px){
  .product:nth-child(5n+4){ margin-top:38px; }
  .product:nth-child(5n+3){ margin-top:12px; }
}

/* Capitular editorial en el artículo */
.article-body .lead::first-letter{
  font-family:var(--serif); font-size:3.6em; font-weight:500;
  float:left; line-height:.82; padding:6px 12px 0 0; color:var(--accent-d);
}

/* FAQ: hover discreto */
.faq summary:hover{ color:var(--accent-d); }

/* Reveal on scroll — sutil, silencioso (SPEC-002 §14) */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .cat img, .product-media img{ transition:none; }
}

/* Tablet 701–820: mosaico simplificado, no lista (SPEC-002 §9) */
@media (min-width:701px) and (max-width:820px){
  .cats{ grid-template-columns:repeat(2,1fr); grid-auto-rows:230px; }
  .cat{ grid-column:auto; grid-row:auto; }
  .cat:nth-child(1){ grid-column:span 2; grid-row:span 2; }
  .cat:nth-child(6){ grid-column:span 2; }
  .cat img{ aspect-ratio:auto; height:100%; }
}
/* Móvil ≤700: narrativa vertical */
@media (max-width:700px){
  .cats{ grid-template-columns:1fr; grid-auto-rows:auto; }
  .cat{ grid-column:auto; grid-row:auto; }
  .cat img{ aspect-ratio:4/3; height:auto; }
}

/* --- Banda Mareli Eventos --- */
.eventos-band{
  background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.eventos-in{ max-width:640px; text-align:center; padding:84px 28px; margin:0 auto; }
.eventos-in h2{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(1.8rem,3.2vw,2.4rem); line-height:1.2;
}
.eventos-in p{ color:var(--muted); margin-top:14px; }
.eventos-in .textlink{ margin-top:28px; }
