/* ============================================
   WINIFRED — Estación de Flores
   Tokens derivados de su propio portfolio:
   blush + olive + cream + terracota
   ============================================ */

:root{
  --cream:      #F2EAE2;
  --cream-deep: #E7DED9;
  --blush:      #E9CCD3;
  --blush-deep: #D9AEB7;
  --olive:      #6F6A40;
  --olive-deep: #524E30;
  --terracotta: #C97D3B;
  --terracotta-deep: #A8632B;
  --tan:        #D9B487;
  --ink:        #2B2820;
  --paper:      #FBF8F4;

  --display: 'Fraunces', ui-serif, Georgia, serif;
  --body: 'Montserrat', ui-sans-serif, system-ui, sans-serif;

  --gap: clamp(1.25rem, 3vw, 2.5rem);
  --radius: 2px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:500; margin:0 0 .5em; letter-spacing:-0.01em; line-height:1.12; }
h2{ text-wrap:balance; }
p{ margin:0 0 1em; }
section{ position:relative; }

.eyebrow{
  font-family:var(--body);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.72rem;
  font-weight:600;
  color:var(--terracotta-deep);
  margin-bottom:1rem;
}
.eyebrow--light{ color:var(--tan); }

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
}

/* ============ reveal-on-scroll ============ */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s ease, transform .8s ease; }
.reveal.is-visible{ opacity:1; transform:translateY(0); }

/* ================= NAV ================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem clamp(1.25rem,4vw,3rem);
  background:transparent;
  transition:background .35s ease, box-shadow .35s ease, padding .35s ease;
}
.nav.is-scrolled{
  background:rgba(242,234,226,.92);
  backdrop-filter:blur(8px);
  box-shadow:0 1px 0 rgba(43,40,32,.08);
  padding-top:.75rem; padding-bottom:.75rem;
}
.nav__logo{
  font-family:var(--display); font-style:italic; font-size:1.4rem;
  text-decoration:none; color:var(--ink); letter-spacing:.02em;
}
.nav__links{
  display:flex; align-items:center; gap:clamp(1rem,2.5vw,2.2rem);
  font-size:.88rem; font-weight:500;
}
.nav__links a{ text-decoration:none; opacity:.85; transition:opacity .2s; white-space:nowrap; }
.nav__links a:hover{ opacity:1; }
.nav__links a.is-active{
  opacity:1; color:var(--terracotta-deep);
  text-decoration:underline; text-underline-offset:.45em; text-decoration-thickness:1px;
}
.nav__cta{
  background:var(--olive); color:var(--paper) !important;
  padding:.55rem 1.15rem; border-radius:999px; opacity:1 !important;
}
.nav__cta:hover{ background:var(--olive-deep); }
.nav__toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:.4rem;
}
.nav__toggle span{ width:22px; height:2px; background:var(--ink); display:block; }

@media (max-width:1080px){
  .nav__toggle{ display:flex; z-index:110; }
  .nav__links{
    position:fixed; inset:0 0 auto 0; top:0;
    flex-direction:column; align-items:flex-start; justify-content:center;
    gap:1.6rem; padding:6rem 2rem 3rem; height:100vh;
    background:var(--cream-deep);
    transform:translateY(-100%); transition:transform .4s ease;
    font-size:1.3rem;
  }
  .nav__links.is-open{ transform:translateY(0); }
  .nav__cta{ margin-top:1rem; }
}

/* ================= HERO ================= */
.hero{
  position:relative; height:100svh; min-height:520px;
  display:flex; flex-direction:column; justify-content:flex-end;
  overflow:hidden; background:var(--ink);
}
.hero__media{ position:absolute; inset:0; }
.hero__media img{ width:100%; height:100%; object-fit:cover; object-position:60% 30%; }
.hero__scrim{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(242,234,226,.55) 0%, rgba(242,234,226,0) 14%, rgba(20,18,12,.15) 55%, rgba(231,222,217,.98) 92%);
}
.hero__wordmark{
  position:relative; z-index:2; margin:0;
  padding:0 clamp(1rem,4vw,3rem);
  font-size:clamp(3.4rem, 14vw, 10rem); line-height:.88;
  letter-spacing:.01em; color:var(--paper);
  margin-bottom:clamp(-.8rem,-1.5vw,-.4rem);
}
.hero__wordmark-a{ font-style:italic; font-weight:400; }
.hero__wordmark-b{ font-weight:600; }
.hero__foot{
  position:relative; z-index:2; background:var(--cream-deep);
  padding:1.8rem clamp(1rem,4vw,3rem) 2.2rem;
  display:flex; justify-content:space-between; align-items:flex-end; gap:1.5rem; flex-wrap:wrap;
}
.hero__intro .eyebrow{ margin-bottom:.5rem; }
.hero__tagline{ margin:0; font-size:.95rem; font-weight:500; max-width:48ch; line-height:1.55; }
.hero__tagline em{ font-family:var(--display); font-style:italic; font-size:1.15em; color:var(--terracotta-deep); }
.hero__scroll{
  display:flex; align-items:center; gap:.6rem; text-decoration:none; font-size:.8rem;
  font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--ink);
}
.hero__scroll-line{ width:34px; height:1px; background:var(--ink); position:relative; overflow:hidden; }
.hero__scroll-line::after{
  content:''; position:absolute; inset:0; background:var(--terracotta);
  animation:scrollline 1.8s ease-in-out infinite;
}
@keyframes scrollline{
  0%{ transform:translateX(-100%); } 50%{ transform:translateX(0); } 100%{ transform:translateX(100%); }
}

/* ================= ABOUT ================= */
.about{
  background:var(--blush);
  display:grid; grid-template-columns:.85fr 1.15fr;
  align-items:stretch;
}
.about__media{ overflow:hidden; min-height:420px; }
.about__media img{ width:100%; height:100%; object-fit:cover; }
.about__copy{
  padding:clamp(2.5rem,6vw,5.5rem) clamp(1.5rem,6vw,5rem);
  display:flex; flex-direction:column; justify-content:center;
}
.about__copy h2{ font-size:clamp(2rem,4vw,3rem); }
.about__copy h2 em{ font-style:italic; color:var(--terracotta-deep); }
.about__lede{ font-size:1.15rem; font-weight:500; }
.about__quote{
  font-family:var(--display); font-style:italic; font-size:1.2rem;
  border-left:2px solid var(--olive); padding-left:1.2rem; margin-top:1.5rem; color:var(--olive-deep);
}
@media (max-width:900px){
  .about{ grid-template-columns:1fr; }
  .about__media{ min-height:340px; }
}

/* ================= PHILOSOPHY ================= */
.philosophy{
  background:var(--olive); color:var(--paper);
  padding:clamp(3rem,8vw,6rem) clamp(1.25rem,4vw,3rem) clamp(4rem,8vw,6rem);
  text-align:center;
}
.philosophy__title{
  font-size:clamp(2.6rem,7vw,5rem); font-style:italic; color:var(--cream);
  margin-bottom:clamp(2.5rem,6vw,4rem);
}
.philosophy__timeline{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(2rem,4vw,3rem);
  max-width:1100px; margin:0 auto; position:relative;
}
.philosophy__timeline::before{
  content:''; position:absolute; top:22px; left:8%; right:8%; height:1px; background:rgba(251,248,244,.3);
}
.philosophy__col{ position:relative; padding-top:2.5rem; }
.philosophy__col::before{
  content:''; position:absolute; top:14px; left:50%; transform:translateX(-50%);
  width:9px; height:9px; border-radius:50%; background:var(--paper);
}
.philosophy__icon{ display:inline-flex; width:40px; height:40px; margin-bottom:1rem; color:var(--tan); }
.philosophy__icon svg{ width:100%; height:100%; fill:none; stroke:currentColor; stroke-width:1.4; stroke-linecap:round; }
.philosophy__col h3{
  font-size:1.15rem; text-transform:uppercase; letter-spacing:.14em; font-weight:500; color:var(--cream);
}
.philosophy__col p{ font-size:.94rem; opacity:.88; }
@media (max-width:760px){
  .philosophy__timeline{ grid-template-columns:1fr; text-align:left; gap:2.2rem; }
  .philosophy__timeline::before{ display:none; }
  .philosophy__col::before{ left:0; transform:none; }
  .philosophy__col{ padding-left:1.6rem; padding-top:0; }
}

/* ================= SKILLS ================= */
.skills{
  background:var(--cream);
  display:grid; grid-template-columns:1.2fr .8fr; align-items:stretch;
}
.skills__copy{ padding:clamp(2.5rem,6vw,5.5rem) clamp(1.5rem,6vw,4rem); }
.skills__copy h2{ font-size:clamp(2rem,4vw,2.8rem); max-width:12ch; }
.skills__group{ margin-top:1.8rem; }
.skills__group h4{
  font-family:var(--body); text-transform:uppercase; letter-spacing:.12em; font-size:.78rem;
  font-weight:700; color:var(--terracotta-deep); margin-bottom:.6rem;
}
.skills__list{ list-style:none; margin:0; padding:0; display:grid; gap:.55rem; }
.skills__list li{ position:relative; padding-left:1.2rem; font-size:.96rem; }
.skills__list li::before{ content:'—'; position:absolute; left:0; color:var(--olive); }
.skills__media{ min-height:340px; overflow:hidden; }
.skills__media img{ width:100%; height:100%; object-fit:cover; }
@media (max-width:900px){
  .skills{ grid-template-columns:1fr; }
  .skills__media{ order:-1; min-height:300px; }
}

/* ================= PORTFOLIO ================= */
.portfolio{ background:var(--cream); padding:clamp(3rem,7vw,6rem) clamp(1.25rem,4vw,3rem); }
.portfolio > .eyebrow, .portfolio > h2{ text-align:center; }
.portfolio > h2{ font-size:clamp(2rem,4.5vw,3rem); margin-bottom:clamp(1.4rem,3vw,2rem); }

/* --- Marquee de tópicos --- */
.marquee{
  overflow:hidden; margin:0 auto clamp(2.5rem,5vw,3.8rem); padding:.4rem 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
}
.marquee__track{
  display:inline-flex; align-items:center; white-space:nowrap; will-change:transform;
  animation:marquee 46s linear infinite;
}
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__track span{
  font-family:var(--display); font-style:italic; font-weight:400;
  font-size:clamp(1.1rem,2.2vw,1.55rem); color:var(--olive-deep); opacity:.8; padding:0 .3rem;
}
.marquee__track i{
  font-style:normal; color:var(--terracotta); font-size:.75em; opacity:.7; padding:0 1rem;
}
@keyframes marquee{ from{ transform:translateX(-50%); } to{ transform:translateX(0); } }
.portfolio__grid{
  display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:340px; gap:1.4rem;
  max-width:1300px; margin:0 auto;
}
.proj{
  position:relative; overflow:hidden; border-radius:var(--radius); background:var(--ink);
}
.proj--tall{ grid-row:span 2; }
.proj img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.proj:hover img{ transform:scale(1.06); }
.proj::before{
  content:''; position:absolute; left:0; top:0; width:6px; height:100%; background:var(--tag,var(--terracotta));
  z-index:2;
}
.proj__info{
  position:absolute; left:0; right:0; bottom:0; z-index:2; color:var(--paper);
  padding:1.4rem 1.3rem 1.2rem 1.6rem;
  background:linear-gradient(0deg, rgba(20,18,12,.88) 0%, rgba(20,18,12,.55) 55%, rgba(20,18,12,0) 100%);
  transform:translateY(calc(100% - 2.4rem)); transition:transform .4s ease;
}
.proj:hover .proj__info, .proj:focus-within .proj__info{ transform:translateY(0); }
.proj__year{
  font-size:.7rem; text-transform:uppercase; letter-spacing:.12em; font-weight:700; color:var(--tan);
}
.proj__info h3{ font-size:1.05rem; margin:.25rem 0 .4rem; font-family:var(--display); font-weight:500; }
.proj__info p{ font-size:.85rem; opacity:.9; margin:0; }

@media (max-width:980px){
  .portfolio__grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:300px; }
}
@media (max-width:640px){
  .portfolio__grid{ grid-template-columns:1fr; grid-auto-rows:320px; }
  .proj--tall{ grid-row:span 1; }
  .proj__info{ transform:translateY(0); background:linear-gradient(0deg, rgba(20,18,12,.85) 0%, rgba(20,18,12,.15) 70%, rgba(20,18,12,0) 100%); }
}

/* ================= QUOTE ================= */
.quote{
  background:var(--tan); color:var(--olive-deep);
  padding:clamp(3.5rem,8vw,6rem) 1.5rem; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:1.5rem;
}
.quote__vine{ width:min(220px,40vw); height:32px; overflow:visible; }
.quote__vine path{
  fill:none; stroke:var(--olive-deep); stroke-width:1.4;
  stroke-dasharray:260; stroke-dashoffset:260; transition:stroke-dashoffset 1.6s ease;
}
.quote.is-visible .quote__vine path{ stroke-dashoffset:0; }
blockquote{
  font-family:var(--display); font-weight:400; font-size:clamp(1.4rem,3.4vw,2.3rem);
  max-width:18ch; margin:0; line-height:1.35;
}
blockquote strong{ font-weight:600; }
blockquote em{ font-style:italic; color:var(--terracotta-deep); }
.quote__sign{ font-family:var(--display); font-style:italic; font-size:1.1rem; margin:0; }

/* ================= CONTACT ================= */
.contact{
  background:var(--blush-deep); display:grid; grid-template-columns:.9fr 1.1fr;
}
.contact__media{ min-height:360px; overflow:hidden; }
.contact__media img{ width:100%; height:100%; object-fit:cover; }
.contact__box{ padding:clamp(2.5rem,6vw,5.5rem) clamp(1.5rem,6vw,4.5rem); }
.contact__box h2{ font-size:clamp(2rem,4.4vw,2.8rem); }
.contact__intro{ max-width:38ch; }

.btn{
  display:inline-block; background:var(--olive); color:var(--paper); border:0; cursor:pointer;
  font-family:var(--body); font-weight:600; font-size:.92rem; letter-spacing:.03em;
  padding:.9rem 1.8rem; border-radius:999px; text-decoration:none;
  transition:background .2s ease, transform .2s ease;
}
.btn:hover{ background:var(--olive-deep); transform:translateY(-1px); }

.contact__direct{ display:flex; flex-direction:column; margin-top:2.2rem; max-width:520px; }
.contact__channel{
  display:flex; flex-direction:column; gap:.2rem; text-decoration:none;
  padding:1.15rem 0; border-top:1px solid rgba(43,40,32,.22);
  transition:padding-left .25s ease;
}
.contact__channel:last-child{ border-bottom:1px solid rgba(43,40,32,.22); }
.contact__channel-label{
  font-size:.7rem; text-transform:uppercase; letter-spacing:.16em;
  font-weight:700; color:var(--olive-deep);
}
.contact__channel-value{
  font-family:var(--display); font-size:clamp(1.15rem,2.3vw,1.55rem); line-height:1.25;
  transition:color .2s ease;
}
.contact__channel:hover{ padding-left:.65rem; }
.contact__channel:hover .contact__channel-value{ color:var(--olive-deep); }

@media (max-width:900px){
  .contact{ grid-template-columns:1fr; }
  .contact__media{ min-height:260px; order:-1; }
}

/* ================= FOOTER ================= */
.footer{
  background:var(--ink); color:var(--cream-deep); text-align:center;
  padding:3rem 1.5rem 2rem; font-size:.85rem;
}
.footer__logo{ font-family:var(--display); font-style:italic; font-size:1.6rem; margin-bottom:.6rem; color:var(--paper); }
.footer__credit{ opacity:.6; margin-top:1.2rem; margin-bottom:0; }

/* ================= LÍNEAS DE PRODUCTO ================= */
.lines{ background:var(--cream-deep); padding:clamp(3rem,7vw,6rem) clamp(1.25rem,4vw,3rem); }
.lines > .eyebrow, .lines > h2{ text-align:center; }
.lines > h2{ font-size:clamp(2rem,4.5vw,3rem); margin-bottom:clamp(2.5rem,5vw,3.6rem); }
.lines__grid{
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:clamp(1.4rem,3vw,2.2rem); max-width:1080px; margin:0 auto;
}
.line-card{
  display:flex; flex-direction:column; text-decoration:none; color:inherit;
  background:var(--paper); border-radius:var(--radius); overflow:hidden;
  box-shadow:0 1px 0 rgba(43,40,32,.06);
  transition:transform .35s ease, box-shadow .35s ease;
}
.line-card:hover{ transform:translateY(-5px); box-shadow:0 22px 44px -24px rgba(43,40,32,.5); }
.line-card__media{ aspect-ratio:16/11; overflow:hidden; }
.line-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.line-card:hover .line-card__media img{ transform:scale(1.05); }
.line-card__body{ padding:clamp(1.5rem,3vw,2rem) clamp(1.5rem,3vw,2rem) clamp(1.7rem,3vw,2.2rem); display:flex; flex-direction:column; gap:.5rem; }
.line-card__eyebrow{
  font-size:.7rem; text-transform:uppercase; letter-spacing:.16em;
  font-weight:700; color:var(--terracotta-deep);
}
.line-card__body h3{ font-size:clamp(1.6rem,3vw,2.1rem); margin:0; }
.line-card__body p{ font-size:.95rem; margin:0; opacity:.85; }
.line-card__cta{
  display:inline-flex; align-items:center; gap:.6rem; margin-top:.7rem;
  font-weight:600; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--olive-deep);
}
.line-card__cta svg{ width:22px; height:11px; fill:none; stroke:currentColor; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; transition:transform .3s ease; }
.line-card:hover .line-card__cta svg{ transform:translateX(6px); }
@media (max-width:760px){ .lines__grid{ grid-template-columns:1fr; max-width:460px; } }

/* ============================================
   SUBPÁGINAS — Flores Frescas & Ramos Secos
   ============================================ */

/* Ramos Secos — paleta beige/tierra en vez del rosa de Flores Frescas */
.page--seco .how{ background:var(--tan); }
.page--seco .cta-band{ background:var(--cream-deep); }
.page--seco .how__note{ background:rgba(251,248,244,.55); }

/* --- Hero de página --- */
.page-hero{
  background:var(--cream);
  padding:clamp(7.5rem,18vw,11rem) clamp(1.25rem,4vw,3rem) clamp(2.8rem,6vw,4.5rem);
}
.page-hero__inner{ max-width:1100px; margin:0 auto; }
.page-hero h1{ font-size:clamp(2.3rem,5.5vw,3.8rem); max-width:22ch; }
.page-hero h1 em{ font-style:italic; color:var(--terracotta-deep); }
.page-hero__lede{ font-size:1.12rem; font-weight:500; max-width:56ch; margin-top:.4rem; }

/* --- Sección "cómo funciona" --- */
.how{ background:var(--blush); padding:clamp(3rem,7vw,5.5rem) clamp(1.25rem,4vw,3rem); }
.how__inner{ max-width:1100px; margin:0 auto; }
.how h2{ font-size:clamp(1.8rem,3.6vw,2.5rem); }
.info-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:clamp(1rem,2.5vw,1.8rem); margin-top:2.2rem;
}
.info-card{
  background:var(--paper); border-radius:var(--radius);
  padding:1.5rem 1.4rem 1.6rem;
}
.info-card__icon{ display:inline-flex; width:34px; height:34px; margin-bottom:.9rem; color:var(--terracotta-deep); }
.info-card__icon svg{ width:100%; height:100%; fill:none; stroke:currentColor; stroke-width:1.4; stroke-linecap:round; stroke-linejoin:round; }
.info-card h3{
  font-family:var(--body); font-size:.78rem; text-transform:uppercase;
  letter-spacing:.14em; font-weight:700; color:var(--olive-deep); margin-bottom:.5rem;
}
.info-card p{ font-size:.93rem; margin:0; opacity:.92; }
.how__note{
  margin-top:1.8rem; padding:1.1rem 1.4rem; max-width:680px;
  background:rgba(251,248,244,.65); border-left:2px solid var(--terracotta);
  font-size:.95rem;
}
.how__note p{ margin:0; }

/* --- Banda de créditos / cita --- */
.credit{
  background:var(--tan); color:var(--olive-deep); text-align:center;
  padding:clamp(2.8rem,6vw,4.5rem) 1.5rem;
}
.credit p{
  font-family:var(--display); font-size:clamp(1.2rem,2.6vw,1.7rem);
  max-width:36ch; margin:0 auto; line-height:1.4;
}
.credit em{ font-style:italic; color:var(--terracotta-deep); }

/* --- Catálogo de productos --- */
.catalog{ background:var(--cream); padding:clamp(3rem,7vw,6rem) clamp(1.25rem,4vw,3rem); }
.catalog__inner{ max-width:1200px; margin:0 auto; }
.catalog__inner > .eyebrow, .catalog__inner > h2{ text-align:center; }
.catalog__inner > h2{ font-size:clamp(1.9rem,4vw,2.7rem); margin-bottom:clamp(2rem,4vw,3rem); }
.catalog__grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:clamp(1.3rem,3vw,2.2rem);
}
.catalog__grid--duo{ grid-template-columns:repeat(2,1fr); max-width:820px; margin:0 auto; }
.product{
  background:var(--paper); border-radius:var(--radius); overflow:hidden;
  display:flex; flex-direction:column;
  box-shadow:0 1px 0 rgba(43,40,32,.06);
}
.product__media{ aspect-ratio:4/5; overflow:hidden; position:relative; }
.product__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.product:hover .product__media img{ transform:scale(1.05); }
.product__tag{
  position:absolute; left:0; bottom:0; z-index:2;
  background:var(--olive); color:var(--paper);
  font-size:.68rem; text-transform:uppercase; letter-spacing:.14em; font-weight:700;
  padding:.4rem .8rem;
}
.product__body{ padding:1.5rem 1.4rem 1.7rem; display:flex; flex-direction:column; flex:1; }
.product__body h3{ font-size:1.45rem; margin-bottom:.35rem; }
.product__quote{
  font-family:var(--display); font-style:italic; color:var(--terracotta-deep);
  font-size:1.02rem; line-height:1.4; margin-bottom:.7rem;
}
.product__desc{ font-size:.9rem; opacity:.85; margin-bottom:1.2rem; }
.product__prices{
  list-style:none; margin:auto 0 0; padding:1rem 0 0;
  border-top:1px solid rgba(43,40,32,.14);
}
.product__prices li{
  display:flex; justify-content:space-between; align-items:baseline;
  padding:.32rem 0; gap:1rem;
}
.product__size{
  font-size:.72rem; text-transform:uppercase; letter-spacing:.13em;
  font-weight:700; color:var(--olive-deep);
}
.product__price{ font-family:var(--display); font-weight:600; font-size:1.08rem; }

/* --- Descuentos por volumen --- */
.discounts{
  background:var(--olive); color:var(--paper); text-align:center;
  padding:clamp(3rem,7vw,5.5rem) clamp(1.25rem,4vw,3rem);
}
.discounts h2{ color:var(--cream); font-size:clamp(1.8rem,3.6vw,2.5rem); }
.discounts__intro{ opacity:.85; max-width:44ch; margin:0 auto 1em; }
.tiers{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,3vw,2.5rem);
  max-width:900px; margin:2.5rem auto 0; position:relative;
}
.tier{ padding:0 1rem; }
.tier__pct{
  display:block; font-family:var(--display); font-style:italic; font-weight:500;
  font-size:clamp(2.6rem,6vw,3.8rem); line-height:1; color:var(--tan);
  margin-bottom:.5rem;
}
.tier__label{ font-size:.92rem; opacity:.9; margin:0; }
.tier + .tier{ border-left:1px solid rgba(251,248,244,.25); }

/* --- Banda CTA final --- */
.cta-band{
  background:var(--blush-deep); text-align:center;
  padding:clamp(3.5rem,8vw,6rem) 1.5rem;
}
.cta-band h2{ font-size:clamp(1.9rem,4.2vw,2.8rem); }
.cta-band p{ max-width:46ch; margin:0 auto 1.8em; }
.cta-band .btn{ font-size:1rem; padding:1rem 2.2rem; }

/* --- Aviso de catálogo pendiente (Ramos Secos) --- */
.pending{
  margin:2rem auto 0; max-width:680px; text-align:center;
  font-family:var(--display); font-style:italic; font-size:1.05rem;
  color:var(--olive-deep);
}

@media (max-width:900px){
  .info-grid{ grid-template-columns:repeat(2,1fr); }
  .catalog__grid, .catalog__grid--duo{ grid-template-columns:1fr; max-width:480px; margin:0 auto; }
  .product__media{ aspect-ratio:5/4; }
}
@media (max-width:680px){
  .info-grid{ grid-template-columns:1fr; }
  .tiers{ grid-template-columns:1fr; gap:2rem; }
  .tier + .tier{ border-left:0; border-top:1px solid rgba(251,248,244,.25); padding-top:2rem; }
}
