/* ============================================================
   CALMA VIVA — Design Tokens + Styles
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght,SOFT@0,9..144,300..600,30;1,9..144,300..600,30&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --indigo-noche:   #1A2744;
  --indigo-mar:     #2D3F6B;
  --indigo-cielo:   #4A5F8A;
  --oro-calido:     #C9A96E;
  --oro-suave:      #E8D5A8;
  --rosa-arena:     #E8DDD4;
  --verde-salvia:   #A8B5A0;
  --blanco-lienzo:  #FAF8F4;
  --blanco-calido:  #F5F2EC;
  --tinta:          #3A3A3A;
  --tinta-suave:    #5A5A5A;

  --accent:         var(--oro-calido);
  --accent-soft:    var(--oro-suave);

  --fg-1:           var(--indigo-noche);
  --fg-2:           var(--indigo-cielo);
  --fg-3:           var(--tinta-suave);
  --fg-mute:        rgba(26,39,68,0.45);
  --fg-accent:      var(--oro-calido);
  --fg-on-dark-1:   var(--blanco-lienzo);
  --fg-on-dark-2:   rgba(250,248,244,0.65);

  --border-faint:   rgba(26,39,68,0.07);
  --border-soft:    rgba(26,39,68,0.15);
  --border-on-dark: rgba(232,213,168,0.18);

  --font-display:   'Fraunces', 'Cormorant Garamond', Georgia, serif;
  --font-body:      'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  --shadow-sm:  0 2px 8px rgba(26,39,68,0.04);
  --shadow-md:  0 8px 24px rgba(26,39,68,0.06);
  --shadow-lg:  0 24px 64px rgba(26,39,68,0.08);
  --shadow-xl:  0 40px 90px rgba(26,39,68,0.12);

  --ease-calm:    cubic-bezier(0.4,0,0.2,1);
  --ease-breathe: cubic-bezier(0.45,0,0.55,1);
}

/* ── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--blanco-lienzo);
  color: var(--fg-1);
  font-family: var(--font-body);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
button, input { font-family: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; cursor: pointer; }
img { max-width: 100%; display: block; }

/* ── Fade-up on scroll ───────────────────────────────────── */
.cv-rise {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 900ms var(--ease-calm), transform 900ms var(--ease-calm);
}
.cv-rise.in { opacity:1; transform:translateY(0); }

/* ── HEADER ──────────────────────────────────────────────── */
.cv-header {
  position: fixed; top:0; left:0; right:0; z-index:50;
  background: rgba(250,248,244,0);
  border-bottom: 1px solid transparent;
  transition: background 0.4s var(--ease-calm), border-color 0.4s, backdrop-filter 0.4s;
  isolation: isolate;
}
.cv-header:not(.solid) .cv-header-logo {
  padding: 10px 22px;
  border-radius: 999px;
  background: rgba(250,248,244,0.78);
  backdrop-filter: blur(8px) saturate(160%);
  -webkit-backdrop-filter: blur(8px) saturate(160%);
  box-shadow: 0 1px 0 rgba(26,39,68,0.04);
}
.cv-header:not(.solid) .cv-header-actions button { color: var(--blanco-lienzo); }
.cv-header:not(.solid) .cv-header-actions button:hover { color: var(--accent); }
.cv-header.solid {
  background: rgba(250,248,244,0.94);
  border-bottom: 1px solid var(--border-faint);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
}
.cv-header-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr minmax(220px,auto) 1fr;
  align-items: center;
  padding: 18px 56px; gap: 32px;
}
.cv-header-inner > * { min-width: 0; }
.cv-header-logo { justify-self: center; }
.cv-header-nav { display: flex; gap: 36px; }
.cv-header-nav a {
  font-size: 10.5px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--indigo-noche); font-weight: 400;
  transition: color 0.25s var(--ease-calm);
}
.cv-header-nav a:hover, .cv-header-nav a.active { color: var(--accent); }
.cv-header-logo {
  font-family: var(--font-display);
  font-size: 22px; font-weight: 300;
  letter-spacing: 0.28em; color: var(--indigo-noche);
  text-align: center; cursor: pointer;
  display: inline-flex; align-items: center; gap: 14px;
  white-space: nowrap;
  transition: background 0.4s, padding 0.4s, border-radius 0.4s, box-shadow 0.4s, backdrop-filter 0.4s;
}
.cv-header-logo .cv-mark-mini { display: inline-flex; color: var(--accent); }
.cv-header-actions { display: flex; gap: 22px; justify-content: flex-end; align-items: center; }
.cv-header-actions button {
  background: none; border: none; color: var(--indigo-noche);
  display: flex; align-items: center; gap: 6px;
  font-size: 10.5px; letter-spacing: 0.3em; text-transform: uppercase;
  transition: color 0.25s var(--ease-calm);
}

/* ── HERO ────────────────────────────────────────────────── */
.cv-hero {
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 100vh; position: relative;
}
.cv-hero-half {
  position: relative; overflow: hidden;
  display: flex; flex-direction: column; justify-content: center;
  padding: 140px 80px 110px;
}
.cv-hero-half.calma {
  background: var(--blanco-lienzo);
  align-items: flex-end; padding-right: 120px;
}
.cv-hero-half.viva {
  background: var(--indigo-noche);
  color: var(--blanco-lienzo); padding-left: 120px;
}
.cv-hero-half.calma::before {
  content:''; position:absolute;
  width:720px; height:720px; border-radius:50%;
  border:1px solid rgba(26,39,68,0.06);
  top:-200px; left:-260px;
}
.cv-hero-half.calma::after {
  content:''; position:absolute;
  width:460px; height:460px; border-radius:50%;
  border:1px solid rgba(26,39,68,0.04);
  bottom:-160px; right:30%;
}
.cv-hero-half.viva::before {
  content:''; position:absolute;
  width:820px; height:820px; border-radius:50%;
  border:1px solid rgba(232,213,168,0.08);
  bottom:-300px; right:-300px;
}
.cv-hero-half.viva::after {
  content:''; position:absolute;
  width:380px; height:380px; border-radius:50%;
  border:1px solid rgba(232,213,168,0.05);
  top:12%; left:25%;
}
.cv-hero-eyebrow {
  font-size:10px; letter-spacing:0.55em; text-transform:uppercase;
  color:var(--accent); margin-bottom:32px; font-weight:400;
}
.cv-hero-half.calma .cv-hero-eyebrow { color:var(--indigo-cielo); }
.cv-hero-word {
  font-family:var(--font-display); font-weight:300;
  font-size: clamp(96px,14vw,200px);
  line-height:0.95; letter-spacing:0.02em;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
.cv-hero-half.calma .cv-hero-word { color:var(--indigo-noche); text-align:right; }
.cv-hero-half.viva .cv-hero-word { color:var(--blanco-lienzo); font-style:italic; }
.cv-hero-sub {
  font-family:var(--font-body); font-size:12px;
  letter-spacing:0.32em; text-transform:uppercase;
  margin-top:36px; color:var(--tinta-suave); font-weight:400;
}
.cv-hero-half.viva .cv-hero-sub { color:rgba(232,213,168,0.7); }

.cv-hero-seam {
  position:absolute; left:50%; top:50%;
  transform:translate(-50%,-50%); z-index:5;
  width:96px; height:96px; border-radius:50%;
  background:var(--accent); color:var(--indigo-noche);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 0 16px var(--blanco-lienzo),0 0 0 17px rgba(201,169,110,0.25),0 30px 80px rgba(26,39,68,0.18);
  animation:cv-breathe 4.5s var(--ease-breathe) infinite;
}
.cv-hero-seam::after {
  content:''; position:absolute; inset:-28px;
  border-radius:50%; border:1px solid rgba(201,169,110,0.35);
  animation:cv-breathe-ring 4.5s var(--ease-breathe) infinite;
}
@keyframes cv-breathe {
  0%,100% { transform:translate(-50%,-50%) scale(1); }
  50% { transform:translate(-50%,-50%) scale(1.07); }
}
@keyframes cv-breathe-ring {
  0%,100% { opacity:0.35; transform:scale(1); }
  50% { opacity:0.55; transform:scale(1.12); }
}
.cv-hero-cta-row {
  position:absolute; left:50%; bottom:56px;
  transform:translateX(-50%); z-index:6;
  display:flex; align-items:center; gap:20px;
}
.cv-cta-link {
  font-size:10.5px; letter-spacing:0.4em; text-transform:uppercase;
  color:var(--accent); font-weight:500;
  padding:14px 28px; background:rgba(250,248,244,0.85);
  border-radius:999px; backdrop-filter:blur(8px);
  border:1px solid rgba(201,169,110,0.35);
  transition:all 0.3s var(--ease-calm);
}
.cv-cta-link:hover { background:var(--accent); color:var(--indigo-noche); border-color:var(--accent); }

/* ── BRAND LINE ──────────────────────────────────────────── */
.cv-brandline {
  padding:140px 80px; text-align:center;
  background:var(--blanco-lienzo); position:relative;
}
.cv-brandline-mark {
  display:inline-flex; color:var(--accent);
  margin-bottom:36px; opacity:0.7;
}
.cv-brandline-quote {
  font-family:var(--font-display); font-style:italic;
  font-weight:300; font-size:clamp(32px,4.2vw,56px);
  line-height:1.4; letter-spacing:0.01em;
  color:var(--indigo-noche); max-width:920px; margin:0 auto;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
.cv-brandline-quote em { color:var(--accent); font-style:italic; }
.cv-brandline-attr {
  margin-top:48px; font-size:9.5px; letter-spacing:0.55em;
  text-transform:uppercase; color:var(--indigo-cielo);
}

/* ── COLLECTION SECTION ──────────────────────────────────── */
.cv-section { padding:130px 80px; }
.cv-section-head {
  display:flex; justify-content:space-between; align-items:flex-end;
  margin-bottom:72px; gap:80px;
}
.cv-section-eyebrow {
  font-size:10px; letter-spacing:0.55em; text-transform:uppercase;
  color:var(--accent); margin-bottom:18px; font-weight:400;
}
.cv-section-title {
  font-family:var(--font-display); font-weight:300;
  font-size:clamp(38px,4.4vw,60px); line-height:1.1;
  letter-spacing:0.03em; color:var(--indigo-noche);
  font-variation-settings:"opsz" 96,"SOFT" 30; max-width:700px;
}
.cv-section-title em { font-style:italic; color:var(--accent); }
.cv-section-head-end {
  font-family:var(--font-body); font-size:13.5px;
  line-height:1.85; color:var(--tinta-suave);
  max-width:320px; font-weight:300;
}
.cv-collections { display:grid; gap:4px; }
.cv-collections.layout-3 { grid-template-columns:repeat(3,1fr); }
.cv-coll {
  position:relative; height:460px;
  padding:36px; display:flex; flex-direction:column;
  justify-content:space-between; overflow:hidden; cursor:pointer;
}
.cv-coll-bg { position:absolute; inset:0; transition:transform 0.8s var(--ease-calm); }
.cv-coll:hover .cv-coll-bg { transform:scale(1.05); }
.cv-coll-anise {
  position:absolute; right:-40px; top:-40px;
  width:280px; height:280px; opacity:0.13; pointer-events:none;
}
.cv-coll-content, .cv-coll-foot { position:relative; z-index:2; }
.cv-coll-num {
  font-family:var(--font-display); font-size:14px;
  font-weight:300; letter-spacing:0.5em; opacity:0.55;
}
.cv-coll-name {
  font-family:var(--font-display); font-weight:300;
  font-size:38px; line-height:1.1; letter-spacing:0.04em;
  font-variation-settings:"opsz" 96,"SOFT" 30;
}
.cv-coll-desc {
  font-size:11.5px; letter-spacing:0.18em; text-transform:uppercase;
  margin-top:12px; opacity:0.72; font-weight:400;
}
.cv-coll-cta {
  margin-top:24px; font-size:9.5px; letter-spacing:0.42em;
  text-transform:uppercase; font-weight:500;
  display:inline-flex; align-items:center; gap:10px;
  padding-bottom:6px; border-bottom:1px solid currentColor;
  align-self:flex-start;
}

/* Collection backgrounds */
.cv-coll.tisanas { color:var(--indigo-noche); }
.cv-coll.tisanas .cv-coll-bg { background:radial-gradient(circle at 20% 30%,rgba(201,169,110,0.18),transparent 50%),linear-gradient(150deg,#efe5db 0%,#e0d1c2 100%); }
.cv-coll.cacao { color:var(--blanco-lienzo); }
.cv-coll.cacao .cv-coll-bg { background:radial-gradient(circle at 80% 30%,rgba(201,169,110,0.22),transparent 50%),linear-gradient(155deg,#1a2744 0%,#0f1a30 100%); }
.cv-coll.especias { color:var(--indigo-noche); }
.cv-coll.especias .cv-coll-bg { background:radial-gradient(circle at 25% 70%,rgba(255,255,255,0.18),transparent 60%),linear-gradient(160deg,#d6b27c 0%,#b8935a 100%); }
.cv-coll.sales { color:var(--indigo-noche); }
.cv-coll.sales .cv-coll-bg { background:radial-gradient(circle at 75% 25%,rgba(255,255,255,0.25),transparent 55%),linear-gradient(155deg,#b8c2ad 0%,#8fa085 100%); }
.cv-coll.pausa { color:var(--blanco-lienzo); }
.cv-coll.pausa .cv-coll-bg { background:radial-gradient(circle at 30% 80%,rgba(232,213,168,0.18),transparent 55%),linear-gradient(155deg,#2d3f6b 0%,#1c2a4a 100%); }
.cv-coll.cajas { color:var(--indigo-noche); }
.cv-coll.cajas .cv-coll-bg { background:radial-gradient(circle at 50% 30%,rgba(201,169,110,0.14),transparent 60%),linear-gradient(160deg,#faf8f4 0%,#ede9e1 100%); border:1px solid rgba(26,39,68,0.06); }

/* ── SPOTLIGHT ───────────────────────────────────────────── */
.cv-spotlight {
  display:grid; grid-template-columns:1.05fr 1fr; min-height:760px;
  background:var(--blanco-calido); position:relative;
}
.cv-spotlight-img { position:relative; overflow:hidden; }
.cv-spot-tin {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
}
.cv-spotlight-img[data-fam="tisanas"] .cv-spot-tin {
  background:radial-gradient(ellipse at 60% 42%,rgba(255,255,255,0.18),transparent 55%),linear-gradient(155deg,#efe5db 0%,#cdb9a3 100%);
}
.cv-tin-shape {
  width:320px; aspect-ratio:4/5; border-radius:6px;
  background:linear-gradient(180deg,rgba(255,255,255,0.18) 0%,transparent 30%,transparent 70%,rgba(0,0,0,0.16) 100%),linear-gradient(170deg,#1a2744 0%,#2d3f6b 60%,#1a2744 100%);
  box-shadow:0 36px 90px rgba(26,39,68,0.32),inset 0 0 0 1px rgba(232,213,168,0.18);
  position:relative; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  color:var(--blanco-lienzo); text-align:center; padding:40px 36px;
  transform:rotate(-2deg);
}
.cv-tin-shape::before, .cv-tin-shape::after {
  content:''; position:absolute; left:8%; right:8%;
  height:1px; background:rgba(232,213,168,0.25);
}
.cv-tin-shape::before { top:16%; }
.cv-tin-shape::after { bottom:16%; }
.cv-tin-eyebrow { font-size:8.5px; letter-spacing:0.55em; text-transform:uppercase; color:var(--oro-suave); }
.cv-tin-mark { margin:22px 0; color:var(--oro-suave); opacity:0.95; }
.cv-tin-name {
  font-family:var(--font-display); font-style:italic; font-weight:300;
  font-size:36px; line-height:1; letter-spacing:0.04em;
  color:var(--oro-suave); font-variation-settings:"opsz" 144,"SOFT" 30;
}
.cv-tin-desc { margin-top:14px; font-size:8.5px; letter-spacing:0.4em; text-transform:uppercase; color:rgba(232,213,168,0.6); }
.cv-tin-meta {
  position:absolute; bottom:22px; left:50%; transform:translateX(-50%);
  font-size:7px; letter-spacing:0.55em; text-transform:uppercase;
  color:rgba(232,213,168,0.45); white-space:nowrap;
}
.cv-spotlight-info {
  display:flex; flex-direction:column; justify-content:center;
  padding:110px 110px 110px 96px; position:relative;
}
.cv-spotlight-info::before {
  content:''; position:absolute; width:380px; height:380px; border-radius:50%;
  border:1px solid rgba(26,39,68,0.05); bottom:-100px; right:-120px;
}
.cv-spot-eyebrow {
  font-size:10px; letter-spacing:0.55em; text-transform:uppercase;
  color:var(--accent); font-weight:400; margin-bottom:22px;
  display:flex; align-items:center; gap:14px;
}
.cv-spot-eyebrow::before { content:''; width:32px; height:1px; background:var(--accent); }
.cv-spot-name {
  font-family:var(--font-display); font-weight:300;
  font-size:clamp(48px,5.4vw,84px); line-height:1; letter-spacing:0.02em;
  color:var(--indigo-noche); font-variation-settings:"opsz" 144,"SOFT" 30;
}
.cv-spot-name em { font-style:italic; color:var(--accent); }
.cv-spot-mood {
  font-family:var(--font-display); font-style:italic;
  font-size:22px; line-height:1.5; color:var(--indigo-cielo);
  margin-top:24px; max-width:440px; font-weight:300;
}
.cv-spot-ingreds {
  margin:40px 0 36px; display:flex; flex-wrap:wrap; gap:0;
  border-top:1px solid rgba(26,39,68,0.1);
  border-bottom:1px solid rgba(26,39,68,0.1);
  max-width:480px;
}
.cv-spot-ing {
  flex:1 1 50%; padding:18px 0;
  border-bottom:1px solid rgba(26,39,68,0.06);
  display:flex; align-items:baseline; gap:14px;
}
.cv-spot-ing:nth-child(odd) { padding-right:24px; }
.cv-spot-ing:nth-child(even) { padding-left:24px; border-left:1px solid rgba(26,39,68,0.06); }
.cv-spot-ing:nth-last-child(-n+2) { border-bottom:none; }
.cv-spot-ing-num { font-family:var(--font-display); font-size:12px; color:var(--accent); letter-spacing:0.2em; }
.cv-spot-ing-name { font-size:11px; letter-spacing:0.32em; text-transform:uppercase; color:var(--indigo-noche); font-weight:400; }
.cv-spot-ing-origin { font-size:9.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--tinta-suave); margin-top:4px; }
.cv-spot-actions { display:flex; align-items:center; gap:32px; }
.cv-spot-price { font-family:var(--font-display); font-size:24px; color:var(--indigo-noche); letter-spacing:0.06em; font-weight:300; }
.cv-spot-price small { font-family:var(--font-body); font-size:11px; letter-spacing:0.3em; color:var(--tinta-suave); margin-left:12px; font-weight:300; text-transform:uppercase; }
.cv-btn-primary {
  background:var(--indigo-noche); color:var(--blanco-lienzo);
  border:none; border-radius:2px; padding:18px 36px;
  font-size:9.5px; font-weight:500; letter-spacing:0.42em; text-transform:uppercase;
  transition:background 0.3s var(--ease-calm);
}
.cv-btn-primary:hover { background:var(--indigo-mar); }
.cv-btn-ghost {
  background:transparent; color:var(--indigo-noche);
  border:1px solid var(--indigo-noche); border-radius:2px; padding:18px 36px;
  font-size:9.5px; font-weight:500; letter-spacing:0.42em; text-transform:uppercase;
  transition:all 0.3s var(--ease-calm);
}
.cv-btn-ghost:hover { background:var(--indigo-noche); color:var(--blanco-lienzo); }

/* ── EDITORIAL ───────────────────────────────────────────── */
.cv-editorial {
  padding:130px 80px; background:var(--indigo-noche);
  color:var(--blanco-lienzo); position:relative; overflow:hidden;
}
.cv-editorial::before {
  content:''; position:absolute; width:900px; height:900px; border-radius:50%;
  border:1px solid rgba(232,213,168,0.06); top:-300px; left:-300px;
}
.cv-edit-wrap {
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1.4fr;
  gap:96px; align-items:center; position:relative;
}
.cv-edit-img {
  aspect-ratio:4/5; border-radius:4px;
  background:radial-gradient(circle at 30% 30%,rgba(232,213,168,0.18),transparent 55%),linear-gradient(160deg,#2d3f6b 0%,#0f1a30 100%);
  position:relative; display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(232,213,168,0.15);
  box-shadow:0 30px 70px rgba(0,0,0,0.3);
}
.cv-edit-img-mark {
  width:64%; aspect-ratio:1; border-radius:50%;
  border:1px solid rgba(232,213,168,0.2);
  display:flex; align-items:center; justify-content:center;
  position:relative; color:var(--accent);
}
.cv-edit-img-mark::before { content:''; position:absolute; inset:12%; border-radius:50%; border:1px solid rgba(232,213,168,0.12); }
.cv-edit-meta {
  font-size:9.5px; letter-spacing:0.55em; text-transform:uppercase;
  color:var(--accent); font-weight:400;
  display:flex; align-items:center; gap:18px;
}
.cv-edit-meta span { color:rgba(232,213,168,0.6); }
.cv-edit-tag {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px; border-radius:999px;
  border:1px solid rgba(232,213,168,0.25); color:var(--oro-suave);
  font-size:9px; letter-spacing:0.42em;
}
.cv-edit-title {
  font-family:var(--font-display); font-weight:300;
  font-size:clamp(40px,4.6vw,64px); line-height:1.12; letter-spacing:0.02em;
  color:var(--blanco-lienzo); margin-top:36px;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
.cv-edit-title em { font-style:italic; color:var(--accent); }
.cv-edit-excerpt {
  font-size:14px; line-height:1.95; color:rgba(250,248,244,0.65);
  margin-top:32px; max-width:560px; font-weight:300;
}
.cv-edit-cta {
  margin-top:48px; display:inline-flex; align-items:center; gap:16px;
  font-size:10px; letter-spacing:0.42em; text-transform:uppercase;
  color:var(--accent); font-weight:500;
  padding-bottom:10px; border-bottom:1px solid var(--accent);
  transition:gap 0.3s var(--ease-calm);
}
.cv-edit-cta:hover { gap:24px; }

/* ── VALUES ──────────────────────────────────────────────── */
.cv-values {
  background:var(--blanco-calido); padding:80px 80px;
  border-top:1px solid var(--border-faint); border-bottom:1px solid var(--border-faint);
}
.cv-values-row {
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:repeat(4,1fr); gap:0;
}
.cv-value {
  padding:8px 32px; display:flex; align-items:center; gap:20px;
  border-right:1px solid rgba(26,39,68,0.08);
}
.cv-value:last-child { border-right:none; }
.cv-value:first-child { padding-left:0; }
.cv-value-num { font-family:var(--font-display); font-style:italic; font-size:22px; font-weight:300; color:var(--accent); letter-spacing:0.04em; }
.cv-value-name { font-family:var(--font-display); font-weight:300; font-size:20px; color:var(--indigo-noche); letter-spacing:0.04em; line-height:1.2; }

/* ── NEWSLETTER ──────────────────────────────────────────── */
.cv-news {
  padding:160px 80px; background:var(--blanco-lienzo);
  text-align:center; position:relative;
}
.cv-news::before {
  content:''; position:absolute; width:1px; height:64px;
  background:var(--accent); top:60px; left:50%; transform:translateX(-50%); opacity:0.5;
}
.cv-news-eyebrow { font-size:10px; letter-spacing:0.55em; text-transform:uppercase; color:var(--accent); margin-bottom:28px; font-weight:400; }
.cv-news-title {
  font-family:var(--font-display); font-style:italic; font-weight:300;
  font-size:clamp(34px,4vw,52px); line-height:1.3; color:var(--indigo-noche);
  letter-spacing:0.01em; max-width:720px; margin:0 auto;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
.cv-news-form {
  margin:56px auto 0; max-width:520px;
  display:grid; grid-template-columns:1fr auto; gap:0;
  border-bottom:1px solid var(--indigo-noche);
}
.cv-news-form input {
  background:transparent; border:none; outline:none;
  padding:18px 4px; font-size:14px; font-weight:300; color:var(--indigo-noche);
}
.cv-news-form input::placeholder { color:var(--fg-mute); }
.cv-news-form button {
  background:transparent; border:none; padding:18px 24px;
  font-size:9.5px; letter-spacing:0.42em; text-transform:uppercase;
  color:var(--accent); font-weight:500;
  display:inline-flex; align-items:center; gap:12px;
  transition:gap 0.3s var(--ease-calm);
}
.cv-news-form button:hover { gap:18px; }
.cv-news-fine { margin-top:36px; font-size:9.5px; letter-spacing:0.42em; text-transform:uppercase; color:var(--fg-mute); }

/* ── FOOTER ──────────────────────────────────────────────── */
.cv-footer {
  background:var(--indigo-noche); color:var(--blanco-lienzo);
  padding:110px 80px 40px; position:relative; overflow:hidden;
}
.cv-footer::before {
  content:''; position:absolute; width:600px; height:600px;
  bottom:-200px; right:-100px; opacity:0.04; pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-50 -50 100 100' fill='none' stroke='%23C9A96E' stroke-width='2.5' stroke-linejoin='round'%3E%3Cg%3E%3Cg transform='rotate(0)'%3E%3Cpath d='M0,5 C-13,-4 -15,-20 0,-38 C15,-20 13,-4 0,5Z'/%3E%3Cpath d='M0,-7 C-5,-15 -5,-26 0,-33 C5,-26 5,-15 0,-7Z'/%3E%3C/g%3E%3Cg transform='rotate(45)'%3E%3Cpath d='M0,5 C-13,-4 -15,-20 0,-38 C15,-20 13,-4 0,5Z'/%3E%3Cpath d='M0,-7 C-5,-15 -5,-26 0,-33 C5,-26 5,-15 0,-7Z'/%3E%3C/g%3E%3Cg transform='rotate(90)'%3E%3Cpath d='M0,5 C-13,-4 -15,-20 0,-38 C15,-20 13,-4 0,5Z'/%3E%3Cpath d='M0,-7 C-5,-15 -5,-26 0,-33 C5,-26 5,-15 0,-7Z'/%3E%3C/g%3E%3Cg transform='rotate(135)'%3E%3Cpath d='M0,5 C-13,-4 -15,-20 0,-38 C15,-20 13,-4 0,5Z'/%3E%3Cpath d='M0,-7 C-5,-15 -5,-26 0,-33 C5,-26 5,-15 0,-7Z'/%3E%3C/g%3E%3Cg transform='rotate(180)'%3E%3Cpath d='M0,5 C-13,-4 -15,-20 0,-38 C15,-20 13,-4 0,5Z'/%3E%3Cpath d='M0,-7 C-5,-15 -5,-26 0,-33 C5,-26 5,-15 0,-7Z'/%3E%3C/g%3E%3Cg transform='rotate(225)'%3E%3Cpath d='M0,5 C-13,-4 -15,-20 0,-38 C15,-20 13,-4 0,5Z'/%3E%3Cpath d='M0,-7 C-5,-15 -5,-26 0,-33 C5,-26 5,-15 0,-7Z'/%3E%3C/g%3E%3Cg transform='rotate(270)'%3E%3Cpath d='M0,5 C-13,-4 -15,-20 0,-38 C15,-20 13,-4 0,5Z'/%3E%3Cpath d='M0,-7 C-5,-15 -5,-26 0,-33 C5,-26 5,-15 0,-7Z'/%3E%3C/g%3E%3Cg transform='rotate(315)'%3E%3Cpath d='M0,5 C-13,-4 -15,-20 0,-38 C15,-20 13,-4 0,5Z'/%3E%3Cpath d='M0,-7 C-5,-15 -5,-26 0,-33 C5,-26 5,-15 0,-7Z'/%3E%3C/g%3E%3C/g%3E%3Ccircle cx='0' cy='0' r='3.5' fill='%23C9A96E' stroke='none'/%3E%3C/svg%3E") center/contain no-repeat;
}
.cv-footer-inner { max-width:1280px; margin:0 auto; position:relative; }
.cv-footer-top {
  display:grid; grid-template-columns:2.4fr 1fr 1fr 1fr;
  gap:64px; padding-bottom:80px;
  border-bottom:1px solid rgba(232,213,168,0.15);
}
.cv-footer-mark { display:flex; align-items:center; gap:18px; margin-bottom:28px; color:var(--accent); }
.cv-footer-brand { font-family:var(--font-display); font-size:26px; font-weight:300; letter-spacing:0.28em; color:var(--blanco-lienzo); }
.cv-footer-tagline { font-family:var(--font-display); font-style:italic; font-size:18px; line-height:1.6; color:rgba(250,248,244,0.65); margin-top:20px; max-width:360px; font-weight:300; }
.cv-footer-meta-line { margin-top:36px; font-size:9px; letter-spacing:0.55em; text-transform:uppercase; color:rgba(250,248,244,0.4); }
.cv-footer-col h4 { font-size:9.5px; letter-spacing:0.42em; text-transform:uppercase; color:var(--accent-soft); font-weight:500; margin-bottom:22px; }
.cv-footer-col a { display:block; font-size:13px; color:rgba(250,248,244,0.6); padding:7px 0; font-weight:300; transition:color 0.25s; }
.cv-footer-col a:hover { color:var(--blanco-lienzo); }
.cv-footer-bot { display:flex; justify-content:space-between; align-items:center; padding-top:32px; }
.cv-footer-bot-meta { font-size:9.5px; letter-spacing:0.42em; text-transform:uppercase; color:rgba(250,248,244,0.35); }

/* ── COOKIE ──────────────────────────────────────────────── */
.cv-cookie {
  position:fixed; left:0; right:0; bottom:0; z-index:90;
  background:var(--indigo-noche); color:var(--blanco-lienzo);
  padding:18px 56px; display:flex; align-items:center;
  justify-content:space-between; gap:32px;
  border-top:1px solid rgba(232,213,168,0.18);
  transform:translateY(0); opacity:1;
  transition:transform 0.5s var(--ease-calm), opacity 0.4s;
}
.cv-cookie.hidden { transform:translateY(100%); opacity:0; pointer-events:none; }
.cv-cookie-text { font-size:12px; line-height:1.65; color:rgba(250,248,244,0.75); font-weight:300; max-width:720px; }
.cv-cookie-text em { font-style:italic; color:var(--accent); }
.cv-cookie-actions { display:flex; gap:8px; flex-shrink:0; }
.cv-cookie-btn {
  background:transparent; border:1px solid rgba(232,213,168,0.3);
  color:var(--blanco-lienzo); padding:10px 22px; border-radius:2px;
  font-size:9px; letter-spacing:0.42em; text-transform:uppercase;
  font-weight:500; transition:all 0.25s;
}
.cv-cookie-btn:hover { border-color:var(--accent); color:var(--accent); }
.cv-cookie-btn.primary { background:var(--accent); color:var(--indigo-noche); border-color:var(--accent); }
.cv-cookie-btn.primary:hover { background:var(--oro-suave); border-color:var(--oro-suave); }

/* ── ABOUT ───────────────────────────────────────────────── */
.cv-about-hero {
  padding:220px 80px 130px; background:var(--blanco-lienzo);
  text-align:center; position:relative; overflow:hidden;
}
.cv-about-hero::before {
  content:''; position:absolute; width:800px; height:800px; border-radius:50%;
  border:1px solid rgba(26,39,68,0.05); top:50%; left:50%; transform:translate(-50%,-50%);
}
.cv-about-hero-eyebrow { font-size:10px; letter-spacing:0.55em; text-transform:uppercase; color:var(--accent); position:relative; }
.cv-about-quote {
  font-family:var(--font-display); font-weight:300;
  font-size:clamp(40px,5vw,72px); line-height:1.18; letter-spacing:0.02em;
  color:var(--indigo-noche); max-width:1100px; margin:48px auto 0;
  position:relative; font-variation-settings:"opsz" 144,"SOFT" 30;
}
.cv-about-quote em { font-style:italic; color:var(--accent); }
.cv-origin { padding:130px 80px; background:var(--blanco-calido); }
.cv-origin-wrap { max-width:1240px; margin:0 auto; display:grid; grid-template-columns:1fr 1.1fr; gap:110px; align-items:center; }
.cv-origin-img {
  aspect-ratio:4/5; border-radius:4px;
  background:radial-gradient(circle at 30% 35%,rgba(255,255,255,0.2),transparent 55%),linear-gradient(160deg,#efe5db 0%,#cdb9a3 100%);
  position:relative; display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-lg);
}
.cv-origin-text h3 {
  font-family:var(--font-display); font-weight:300;
  font-size:clamp(34px,4vw,52px); line-height:1.15; letter-spacing:0.03em;
  color:var(--indigo-noche); font-variation-settings:"opsz" 96,"SOFT" 30;
}
.cv-origin-text h3 em { font-style:italic; color:var(--accent); }
.cv-origin-text p { font-size:14.5px; line-height:1.95; color:var(--tinta-suave); margin-top:28px; font-weight:300; }
.cv-section-eyebrow { font-size:10px; letter-spacing:0.55em; text-transform:uppercase; color:var(--accent); margin-bottom:18px; font-weight:400; }
.cv-principles { padding:130px 80px; background:var(--blanco-lienzo); }
.cv-principles-grid { max-width:1240px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:80px; }
.cv-principle-num { font-family:var(--font-display); font-style:italic; font-weight:300; font-size:56px; line-height:1; color:var(--accent); letter-spacing:0.04em; }
.cv-principle-text { font-family:var(--font-display); font-weight:300; font-size:24px; line-height:1.45; letter-spacing:0.02em; color:var(--indigo-noche); margin-top:36px; font-variation-settings:"opsz" 96,"SOFT" 30; }
.cv-principle-text em { font-style:italic; color:var(--accent); }
.cv-ingreds { padding:130px 80px; background:var(--indigo-noche); color:var(--blanco-lienzo); }
.cv-ingreds-head { text-align:center; max-width:720px; margin:0 auto 80px; }
.cv-ingreds-head .cv-section-title { color:var(--oro-suave); }
.cv-ingreds-grid { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(232,213,168,0.15); }
.cv-ingred { background:var(--indigo-noche); padding:48px 40px; display:flex; flex-direction:column; gap:18px; }
.cv-ingred-mark { width:48px; height:48px; border-radius:50%; border:1px solid rgba(232,213,168,0.25); display:flex; align-items:center; justify-content:center; color:var(--accent); margin-bottom:16px; }
.cv-ingred-name { font-family:var(--font-display); font-weight:300; font-size:28px; letter-spacing:0.04em; color:var(--blanco-lienzo); font-variation-settings:"opsz" 96,"SOFT" 30; }
.cv-ingred-origin { font-size:9.5px; letter-spacing:0.42em; text-transform:uppercase; color:var(--accent); font-weight:500; }
.cv-ingred-why { font-size:13px; line-height:1.85; color:rgba(250,248,244,0.6); font-weight:300; margin-top:8px; }

/* ── COLLECTION PAGE ─────────────────────────────────────── */
.cv-coll-hero {
  padding:220px 80px 130px;
  background:radial-gradient(circle at 22% 30%,rgba(201,169,110,0.16),transparent 55%),linear-gradient(160deg,#efe5db 0%,#d4c4b1 100%);
  position:relative; overflow:hidden; text-align:center;
}
.cv-coll-hero-eyebrow { font-size:10px; letter-spacing:0.55em; text-transform:uppercase; color:var(--indigo-cielo); font-weight:400; }
.cv-coll-hero-title {
  font-family:var(--font-display); font-weight:300;
  font-size:clamp(80px,11vw,168px); line-height:1; letter-spacing:0.04em;
  color:var(--indigo-noche); margin-top:32px;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
.cv-coll-hero-mood {
  font-family:var(--font-display); font-style:italic; font-weight:300;
  font-size:clamp(20px,2.4vw,30px); line-height:1.5; color:var(--indigo-cielo);
  margin:36px auto 0; max-width:700px;
}
.cv-coll-hero-meta {
  margin-top:56px; display:inline-flex; align-items:center; gap:32px;
  padding:16px 32px; border-radius:999px;
  border:1px solid rgba(26,39,68,0.18);
  font-size:10px; letter-spacing:0.42em; text-transform:uppercase;
  color:var(--indigo-noche); font-weight:500;
}
.cv-coll-hero-meta span { color:var(--indigo-cielo); }
.cv-products { padding:130px 80px; background:var(--blanco-lienzo); }
.cv-products-bar { max-width:1280px; margin:0 auto 64px; display:flex; justify-content:space-between; align-items:center; gap:32px; }
.cv-products-count { font-size:10px; letter-spacing:0.42em; text-transform:uppercase; color:var(--indigo-cielo); font-weight:400; }
.cv-products-sort { display:flex; gap:24px; font-size:10px; letter-spacing:0.32em; text-transform:uppercase; color:var(--indigo-cielo); font-weight:400; }
.cv-products-sort a { cursor:pointer; transition:color 0.25s; }
.cv-products-sort a.active { color:var(--accent); }
.cv-products-grid { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:56px 32px; }
.cv-product { cursor:pointer; transition:transform 0.4s var(--ease-calm); }
.cv-product:hover { transform:translateY(-4px); }
.cv-product-thumb {
  aspect-ratio:4/5; border-radius:4px; overflow:hidden;
  position:relative; display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-md);
}
.cv-product-thumb.tisanas { background:linear-gradient(160deg,#efe5db 0%,#d4c4b1 100%); }
.cv-product-thumb .cv-tin-shape { width:65%; transform:rotate(-2deg) scale(0.92); }
.cv-product-fam { font-size:9.5px; letter-spacing:0.55em; text-transform:uppercase; color:var(--accent); font-weight:400; margin-top:22px; }
.cv-product-name { font-family:var(--font-display); font-weight:300; font-size:26px; letter-spacing:0.04em; color:var(--indigo-noche); margin-top:8px; font-variation-settings:"opsz" 96,"SOFT" 30; }
.cv-product-name em { font-style:italic; color:var(--accent); }
.cv-product-sub { font-size:11.5px; line-height:1.7; color:var(--tinta-suave); margin-top:8px; font-weight:300; }
.cv-product-foot { margin-top:16px; display:flex; justify-content:space-between; align-items:center; }
.cv-product-price { font-family:var(--font-display); font-size:17px; color:var(--indigo-noche); letter-spacing:0.06em; font-weight:300; }
.cv-product-add {
  background:transparent; border:1px solid rgba(26,39,68,0.18);
  border-radius:999px; padding:7px 16px;
  font-size:9px; letter-spacing:0.42em; text-transform:uppercase;
  color:var(--indigo-noche); font-weight:500; transition:all 0.25s;
}
.cv-product-add:hover { background:var(--indigo-noche); color:var(--blanco-lienzo); border-color:var(--indigo-noche); }
.cv-ritual-note { padding:130px 80px; background:var(--blanco-calido); text-align:center; }
.cv-ritual-note-mark { display:inline-flex; color:var(--accent); margin-bottom:36px; opacity:0.6; }
.cv-ritual-note-text {
  font-family:var(--font-display); font-style:italic; font-weight:300;
  font-size:clamp(26px,3vw,40px); line-height:1.55; color:var(--indigo-noche);
  max-width:880px; margin:0 auto; font-variation-settings:"opsz" 144,"SOFT" 30;
}
.cv-ritual-note-text em { color:var(--accent); }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 960px) {
  .cv-section, .cv-editorial, .cv-news, .cv-brandline,
  .cv-origin, .cv-principles, .cv-ingreds,
  .cv-products, .cv-ritual-note { padding-left:32px; padding-right:32px; }
  .cv-header-inner { padding:16px 24px; }
  .cv-header-nav { display:none; }
  .cv-hero { grid-template-columns:1fr; min-height:auto; }
  .cv-hero-half { padding:100px 32px 80px; min-height:70vh; }
  .cv-hero-half.calma { padding-right:32px; align-items:flex-start; }
  .cv-hero-half.calma .cv-hero-word { text-align:left; }
  .cv-hero-half.viva { padding-left:32px; }
  .cv-collections.layout-3 { grid-template-columns:1fr; }
  .cv-spotlight { grid-template-columns:1fr; }
  .cv-spotlight-info { padding:80px 32px; }
  .cv-edit-wrap { grid-template-columns:1fr; gap:56px; }
  .cv-values-row { grid-template-columns:1fr 1fr; gap:24px; }
  .cv-value { border-right:none; padding:0; }
  .cv-footer-top { grid-template-columns:1fr; gap:48px; }
  .cv-origin-wrap { grid-template-columns:1fr; gap:56px; }
  .cv-principles-grid { grid-template-columns:1fr; gap:56px; }
  .cv-ingreds-grid { grid-template-columns:1fr; }
  .cv-products-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .cv-cookie { flex-direction:column; align-items:flex-start; gap:16px; padding:18px 24px; }
  .cv-about-hero, .cv-coll-hero { padding-left:32px; padding-right:32px; }
}
