/* ============================================================
   DECOWE — Sistema visual
   Premium minimalista · rosa coquette + champagne gold
   Tipografía: Cormorant Garamond (display) + Jost (texto)
   ============================================================ */

:root{
  /* Color */
  --cream:    #fcf6f2;   /* fondo cálido base */
  --cream-2:  #f9efe9;   /* secciones alternas */
  --blush:    #fbe9ee;   /* tinte rosa suave */
  --blush-2:  #f6dde6;

  --rose:      #d486a0;  /* primario */
  --rose-deep: #b25f7c;  /* texto/acentos sobre claro */
  --rose-soft: #f0d6df;  /* bordes y fondos sutiles */

  --gold:      #c2a25e;  /* champagne */
  --gold-deep: #9b7e3f;
  --gold-soft: #ece0c6;

  --ink:    #463338;     /* texto principal (aubergine cálido) */
  --ink-2:  #6f5a60;     /* secundario */
  --ink-3:  #9a868c;     /* terciario / captions */
  --line:   #ecdcd9;     /* hairlines */
  --white:  #ffffff;

  /* Tipografía */
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Jost", "Helvetica Neue", Arial, sans-serif;
  --mono:  "DM Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Medidas */
  --pad: clamp(20px, 5vw, 64px);
  --maxw: 1240px;
  --r: 4px;          /* radio sobrio */
  --r-lg: 10px;

  --shadow-sm: 0 1px 2px rgba(70,51,56,.05), 0 6px 20px rgba(178,95,124,.06);
  --shadow-md: 0 4px 14px rgba(70,51,56,.07), 0 24px 60px rgba(178,95,124,.10);
}

/* ---------- Reset ---------- */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  font-weight:400;
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }

/* ---------- Tipografía base ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.06; color:var(--ink); letter-spacing:.005em; }
h1{ font-size:clamp(2.5rem, 5vw, 4.3rem); }
h2{ font-size:clamp(2.1rem, 4.2vw, 3.4rem); }
h3{ font-size:clamp(1.5rem, 2.4vw, 2rem); }
.serif-it{ font-style:italic; }
p{ text-wrap:pretty; }
::selection{ background:var(--rose-soft); color:var(--rose-deep); }

/* eyebrow / label */
.eyebrow{
  font-family:var(--sans);
  font-weight:500;
  font-size:.74rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex;
  align-items:center;
  gap:.7em;
}
.eyebrow::before{
  content:"";
  width:26px; height:1px; background:var(--gold);
  display:inline-block;
}
.eyebrow.center::after{
  content:""; width:26px; height:1px; background:var(--gold); display:inline-block;
}
.eyebrow.center{ justify-content:center; }

.lede{
  font-size:clamp(1.05rem, 1.5vw, 1.28rem);
  line-height:1.65;
  color:var(--ink-2);
  font-weight:300;
}

/* ---------- Layout ---------- */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(64px, 9vw, 132px); }
.section.tight{ padding-block:clamp(48px,6vw,84px); }
.bg-blush{ background:var(--blush); }
.bg-cream2{ background:var(--cream-2); }
.bg-ink{ background:#2f2226; color:#f4e7ea; }
.bg-rose{ background:var(--rose); color:#fff; }
.divider{ height:1px; background:var(--line); border:0; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--sans); font-weight:500; font-size:.86rem;
  letter-spacing:.08em; text-transform:uppercase;
  padding:15px 26px; border-radius:var(--r);
  border:1px solid transparent; cursor:pointer;
  transition:all .25s ease; white-space:nowrap;
}
.btn svg{ width:17px; height:17px; }
.btn-primary{ background:var(--rose); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary:hover{ background:var(--rose-deep); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--rose); color:var(--rose-deep); background:#fff; }
.btn-gold{ background:transparent; color:var(--gold-deep); border-color:var(--gold); }
.btn-gold:hover{ background:var(--gold); color:#fff; }
.btn-lg{ padding:18px 34px; font-size:.9rem; }
.btn-wa{ background:#25d366; color:#fff; }
.btn-wa:hover{ background:#1fae54; transform:translateY(-2px); box-shadow:var(--shadow-md); }

.link-arrow{
  display:inline-flex; align-items:center; gap:.5em;
  font-weight:500; font-size:.82rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--rose-deep); border-bottom:1px solid transparent; padding-bottom:2px;
  transition:.25s;
}
.link-arrow svg{ width:15px; height:15px; transition:transform .25s; }
.link-arrow:hover{ border-color:var(--rose); }
.link-arrow:hover svg{ transform:translateX(4px); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:60;
  background:color-mix(in srgb, var(--cream) 86%, transparent);
  backdrop-filter:blur(12px) saturate(1.1);
  border-bottom:1px solid var(--line);
  transition:background .3s;
}
.site-header .bar{
  display:flex; align-items:center; justify-content:space-between;
  height:78px; gap:24px;
}
.brand{
  font-family:var(--serif); font-style:italic; font-weight:500;
  font-size:1.92rem; letter-spacing:.01em; color:var(--ink);
  line-height:1; display:inline-flex; align-items:baseline; gap:.18em;
}
.brand .dot{ width:6px; height:6px; border-radius:50%; background:var(--rose); display:inline-block; transform:translateY(-2px); }
.nav{ display:flex; align-items:center; gap:34px; }
.nav a{
  font-family:var(--sans); font-size:.82rem; font-weight:400;
  letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2);
  position:relative; padding:6px 0; transition:color .2s;
}
.nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px;
  background:var(--rose); transition:width .28s ease;
}
.nav a:hover{ color:var(--ink); }
.nav a:hover::after,.nav a[aria-current="page"]::after{ width:100%; }
.nav a[aria-current="page"]{ color:var(--rose-deep); }
.header-cta{ display:flex; align-items:center; gap:14px; }

.menu-btn{ display:none; background:none; border:0; width:42px; height:42px; align-items:center; justify-content:center; color:var(--ink); }
.menu-btn svg{ width:24px; height:24px; }

/* mobile drawer */
.m-nav{
  position:fixed; inset:0; z-index:80; background:var(--cream);
  display:flex; flex-direction:column; padding:26px var(--pad);
  transform:translateX(100%); transition:transform .35s cubic-bezier(.4,0,.1,1);
}
.m-nav.open{ transform:translateX(0); }
.m-nav .top{ display:flex; justify-content:space-between; align-items:center; }
.m-nav nav{ display:flex; flex-direction:column; gap:6px; margin-top:48px; }
.m-nav nav a{
  font-family:var(--serif); font-size:2.4rem; color:var(--ink);
  padding:10px 0; border-bottom:1px solid var(--line);
}
.m-nav nav a:last-child{ border-bottom:0; }
.m-nav .m-foot{ margin-top:auto; }

/* ============================================================
   HERO (3 variantes vía data-hero)
   ============================================================ */
.hero{ position:relative; overflow:hidden; }
.hero .eyebrow{ margin-bottom:22px; }
.hero h1{ margin-bottom:0; }
.hero .accent{ color:var(--rose-deep); }
.hero h1{ font-size:clamp(2.2rem, 4.2vw, 3.7rem); line-height:1.1; }
.hero .lede{ margin-top:24px; max-width:42ch; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:38px; }
.hero-meta{ display:flex; gap:28px; margin-top:46px; flex-wrap:wrap; }
.hero-meta .m{ }
.hero-meta .m b{ font-family:var(--serif); font-size:1.9rem; font-weight:500; color:var(--rose-deep); display:block; line-height:1; }
.hero-meta .m span{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); }

/* trust row */
.hero-trust{ list-style:none; display:flex; flex-wrap:wrap; gap:13px 26px; margin-top:42px; }
.hero-trust li{ display:flex; align-items:center; gap:10px; font-size:.86rem; letter-spacing:.03em; color:var(--ink-2); }
.hero-trust li::before{ content:"✓"; display:flex; align-items:center; justify-content:center; width:21px; height:21px; border-radius:50%; background:var(--blush); border:1px solid var(--rose-soft); color:var(--rose-deep); font-size:.68rem; flex:none; }
[data-hero="b"] .hero-trust{ justify-content:center; }

/* soft balloon dots decoration */
.balloons{ position:absolute; inset:0; pointer-events:none; z-index:0; overflow:hidden; display:none; }
[data-hero="b"] .balloons{ display:block; }
.balloons i{ position:absolute; border-radius:50% 50% 50% 50%/ 46% 46% 54% 54%; opacity:.5; }
.balloons i::after{ content:""; position:absolute; left:50%; bottom:-7px; width:1px; height:24px; background:currentColor; opacity:.4; transform:translateX(-50%); }

/* Variant A — editorial split */
[data-hero="a"] .hero-inner{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,72px);
  align-items:center; padding-block:clamp(56px,8vw,108px);
}
[data-hero="a"] .hero-art{ aspect-ratio:4/5; }

/* Variant B — centered serif over blush */
[data-hero="b"]{ background:linear-gradient(180deg,var(--blush) 0%, var(--cream) 100%); }
[data-hero="b"] .hero-inner{
  text-align:center; max-width:920px; margin-inline:auto;
  padding-block:clamp(64px,9vw,120px); position:relative; z-index:2;
}
[data-hero="b"] .eyebrow{ justify-content:center; }
[data-hero="b"] .hero-cta{ justify-content:center; }
[data-hero="b"] .lede{ margin-inline:auto; }
[data-hero="b"] .hero-meta{ justify-content:center; }
[data-hero="b"] .hero-art{ display:none; }
[data-hero="b"] .hero-strip{ display:grid; }

/* full-width image strip below for B */
.hero-strip{ display:none; grid-template-columns:repeat(3,1fr); gap:14px; padding-bottom:clamp(40px,6vw,80px); }
.hero-strip .ph{ aspect-ratio:3/4; }
.hero-strip .ph:nth-child(2){ transform:translateY(-22px); }

/* Variant C — full bleed image, card overlay */
[data-hero="c"] .hero-inner{ position:relative; padding:0; }
[data-hero="c"] .hero-bleed{
  aspect-ratio:16/8.5; min-height:560px; position:relative; overflow:hidden; border-radius:0;
}
[data-hero="c"] .hero-card{
  position:absolute; left:clamp(20px,5vw,72px); bottom:clamp(28px,5vw,64px);
  background:color-mix(in srgb, var(--cream) 92%, transparent);
  backdrop-filter:blur(8px);
  padding:clamp(30px,4vw,52px); max-width:560px; border-radius:var(--r-lg);
  box-shadow:var(--shadow-md); border:1px solid rgba(255,255,255,.5);
}
[data-hero="c"] .hero-art{ display:none; }
[data-hero="c"] h1{ font-size:clamp(2.1rem,3.6vw,3.3rem); margin-bottom:18px; }
[data-hero="c"] .hero-card .lede{ margin-top:0; }
[data-hero] .hero-art-default{ }
[data-hero="a"] .hero-bleed-wrap, [data-hero="b"] .hero-bleed-wrap{ display:none; }
[data-hero="c"] .hero-text-default{ display:none; }
[data-hero="a"] .hero-bleed-wrap{ display:none; }

/* ============================================================
   PLACEHOLDERS (imagería)
   ============================================================ */
.ph{
  position:relative; overflow:hidden; border-radius:var(--r-lg);
  background:
    repeating-linear-gradient(135deg, var(--blush) 0 11px, var(--blush-2) 11px 22px);
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--rose-soft);
}
.ph::after{
  content:attr(data-label);
  font-family:var(--mono); font-size:.72rem; letter-spacing:.04em;
  color:var(--rose-deep); opacity:.62; text-align:center; padding:10px 14px;
  background:color-mix(in srgb, var(--cream) 74%, transparent);
  border-radius:40px; max-width:84%;
}
.ph.gold{
  background:repeating-linear-gradient(135deg, var(--gold-soft) 0 11px, #e3d3b2 11px 22px);
  border-color:var(--gold-soft);
}
.ph.gold::after{ color:var(--gold-deep); }
.ph.full{ width:100%; height:100%; border-radius:0; }

/* foto real dentro de un marco .ph */
.ph > img{ width:100%; height:100%; object-fit:cover; display:block; }
.ph.has-img{ background:none; border:0; }
.ph.has-img::after{ display:none; }
.ph.has-img video{ width:100%; height:100%; object-fit:cover; display:block; }

/* ============================================================
   SECCIÓN: encabezados de página
   ============================================================ */
.page-hero{ padding-block:clamp(60px,8vw,104px) clamp(36px,4vw,56px); text-align:center; background:linear-gradient(180deg,var(--blush),var(--cream)); }
.page-hero .eyebrow{ justify-content:center; margin-bottom:18px; }
.page-hero h1{ font-size:clamp(2.6rem,5.4vw,4.4rem); }
.page-hero p{ max-width:54ch; margin:22px auto 0; }
.crumb{ display:flex; gap:8px; justify-content:center; font-size:.76rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-bottom:18px; }
.crumb a:hover{ color:var(--rose-deep); }

/* ============================================================
   SERVICIOS — grid de tarjetas
   ============================================================ */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,30px); }
.svc-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg);
  overflow:hidden; transition:transform .3s, box-shadow .3s, border-color .3s;
  display:flex; flex-direction:column;
}
.svc-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:var(--rose-soft); }
.svc-card .ph{ aspect-ratio:4/3; border-radius:0; border:0; border-bottom:1px solid var(--line); }
.svc-card .c{ padding:26px 26px 30px; display:flex; flex-direction:column; gap:10px; flex:1; }
.svc-card .num{ font-family:var(--mono); font-size:.72rem; color:var(--gold-deep); letter-spacing:.1em; }
.svc-card h3{ font-size:1.55rem; }
.svc-card p{ color:var(--ink-2); font-size:.96rem; font-weight:300; line-height:1.6; }
.svc-card .link-arrow{ margin-top:auto; padding-top:8px; }

/* lista de servicios (página Servicios) */
.svc-row{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(28px,5vw,72px); align-items:center; }
.svc-row.rev .ph{ order:2; }
.svc-row .ph{ aspect-ratio:5/4; }
.svc-row .txt .eyebrow{ margin-bottom:16px; }
.svc-row .txt h2{ margin-bottom:16px; }
.svc-row .txt p{ color:var(--ink-2); font-weight:300; }
.svc-row .feats{ list-style:none; display:flex; flex-direction:column; gap:10px; margin-top:22px; }
.svc-row .feats li{ display:flex; gap:10px; align-items:flex-start; font-size:.96rem; color:var(--ink-2); }
.svc-row .feats li::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--rose); margin-top:8px; flex:none; }

/* ============================================================
   VALORES / por qué
   ============================================================ */
.values{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(20px,3vw,40px); }
.value{ display:flex; flex-direction:column; gap:12px; }
.value .ico{ width:52px; height:52px; border-radius:50%; border:1px solid var(--rose-soft); display:flex; align-items:center; justify-content:center; color:var(--rose-deep); background:var(--blush); }
.value .ico svg{ width:24px; height:24px; }
.value h3{ font-size:1.32rem; }
.value p{ color:var(--ink-2); font-size:.94rem; font-weight:300; }

/* ============================================================
   PROCESO
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(18px,2.4vw,34px); counter-reset:s; }
.step{ position:relative; padding-top:30px; }
.step::before{
  counter-increment:s; content:counter(s,decimal-leading-zero);
  font-family:var(--serif); font-style:italic; font-size:1.8rem; color:var(--gold);
  position:absolute; top:-6px; left:0;
}
.step .ln{ height:1px; background:var(--line); margin-bottom:18px; }
.step h3{ font-size:1.28rem; margin-bottom:8px; }
.step p{ color:var(--ink-2); font-size:.92rem; font-weight:300; }

/* ============================================================
   GALERÍA
   ============================================================ */
.filters{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-bottom:42px; }
.filters button{
  font-family:var(--sans); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase;
  padding:9px 20px; border-radius:40px; border:1px solid var(--line); background:transparent; color:var(--ink-2);
  transition:.22s; white-space:nowrap;
}
.filters button:hover{ border-color:var(--rose); color:var(--rose-deep); }
.filters button.active{ background:var(--rose); color:#fff; border-color:var(--rose); }

/* nota contextual de categoría (ej. guirnaldas) */
.cat-note{ display:flex; gap:16px; align-items:flex-start; max-width:720px; margin:0 auto 38px; padding:20px 26px; background:var(--blush); border:1px solid var(--rose-soft); border-radius:var(--r-lg); }
.cat-note[hidden]{ display:none; }
.cat-note-ico{ font-size:1.2rem; color:var(--gold-deep); line-height:1.5; flex:none; }
.cat-note p{ font-size:1rem; color:var(--ink-2); font-weight:300; line-height:1.6; }
.cat-note b{ font-weight:500; color:var(--rose-deep); font-family:var(--serif); font-size:1.12rem; }
.gal{ columns:3; column-gap:18px; }.gal .item{ break-inside:avoid; margin-bottom:18px; transition:opacity .3s, transform .3s; }
.gal .item .ph{ width:100%; }
.gal .item.h1x{ aspect-ratio:4/5; }
.gal .item.h2x{ aspect-ratio:1/1; }
.gal .item.h3x{ aspect-ratio:3/4; }
.gal .item .ph{ height:100%; }
.gal .item.hide{ display:none; }
.cap{ font-family:var(--mono); font-size:.7rem; color:var(--ink-3); margin-top:7px; letter-spacing:.03em; }

/* hover-to-play video en galería */
.hover-vid .ph{ position:relative; cursor:pointer; }
.hover-video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  opacity:0; transition:opacity .45s ease; pointer-events:none; z-index:1;
}
.hover-vid.playing .hover-video{ opacity:1; }
.play-badge{
  position:absolute; right:12px; bottom:12px; z-index:2;
  width:38px; height:38px; border-radius:50%;
  background:color-mix(in srgb, var(--rose-deep) 88%, transparent);
  color:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 12px rgba(70,51,56,.25); transition:opacity .3s, transform .3s;
  backdrop-filter:blur(2px);
}
.play-badge svg{ width:18px; height:18px; transform:translateX(1px); }
.hover-vid.playing .play-badge{ opacity:0; transform:scale(.8); }
@media (hover:hover){
  .hover-vid:hover .play-badge{ transform:scale(1.08); }
  .hover-vid.playing:hover .play-badge{ transform:scale(.8); }
}

/* ============================================================
   TESTIMONIOS
   ============================================================ */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,28px); }
.quote{ background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); padding:32px 30px; display:flex; flex-direction:column; gap:18px; }
.quote .stars{ display:flex; gap:3px; color:var(--gold); }
.quote .stars svg{ width:16px; height:16px; }
.quote p{ font-family:var(--serif); font-style:italic; font-size:1.32rem; line-height:1.45; color:var(--ink); }
.quote .who{ display:flex; align-items:center; gap:12px; margin-top:auto; }
.quote .who .av{ width:40px; height:40px; border-radius:50%; background:var(--blush); border:1px solid var(--rose-soft); display:flex; align-items:center; justify-content:center; font-family:var(--serif); color:var(--rose-deep); font-size:1.1rem; }
.quote .who b{ font-family:var(--sans); font-weight:500; font-size:.92rem; }
.quote .who span{ display:block; font-size:.78rem; color:var(--ink-3); letter-spacing:.04em; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{ text-align:center; }
.cta-band h2{ color:inherit; }
.cta-band .lede{ color:inherit; opacity:.85; max-width:52ch; margin:18px auto 0; }
.cta-band .row{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:34px; }

/* ============================================================
   FORM (Contacto)
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,72px); align-items:start; }
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.field label{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2); font-weight:500; }
.field input,.field select,.field textarea{
  font-family:var(--sans); font-size:1rem; color:var(--ink);
  padding:13px 16px; border:1px solid var(--line); border-radius:var(--r);
  background:var(--white); transition:.2s; width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--rose); box-shadow:0 0 0 3px var(--rose-soft); }
.field textarea{ resize:vertical; min-height:120px; }
.field.two{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field.two > div{ display:flex; flex-direction:column; gap:8px; }
.info-block{ display:flex; flex-direction:column; gap:26px; }
.info-item{ display:flex; gap:16px; align-items:flex-start; }
.info-item .ico{ width:44px; height:44px; border-radius:50%; background:var(--blush); border:1px solid var(--rose-soft); display:flex; align-items:center; justify-content:center; color:var(--rose-deep); flex:none; }
.info-item .ico svg{ width:20px; height:20px; }
.info-item h4{ font-family:var(--sans); font-weight:500; font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-bottom:4px; }
.info-item p{ font-size:1.05rem; color:var(--ink); }
.info-item a:hover{ color:var(--rose-deep); }

/* mapa embed */
.map-embed{ margin-top:6px; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-sm); }
.map-embed iframe{ width:100%; height:300px; border:0; display:block; filter:saturate(.92); }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:760px; margin-inline:auto; }.faq details{ border-bottom:1px solid var(--line); padding:22px 0; }
.faq summary{ list-style:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:20px; font-family:var(--serif); font-size:1.45rem; color:var(--ink); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .pm{ width:26px; height:26px; flex:none; position:relative; }
.faq summary .pm::before,.faq summary .pm::after{ content:""; position:absolute; background:var(--rose); top:50%; left:50%; transform:translate(-50%,-50%); transition:.25s; }
.faq summary .pm::before{ width:14px; height:1.5px; }
.faq summary .pm::after{ width:1.5px; height:14px; }
.faq details[open] summary .pm::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq details p{ color:var(--ink-2); font-weight:300; margin-top:14px; max-width:62ch; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:#2f2226; color:#e8d6da; padding-block:clamp(56px,7vw,84px) 30px; }
.site-footer a{ color:#e8d6da; }
.foot-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.1); }
.foot-brand .brand{ color:#fff; font-size:2.2rem; }
.foot-brand p{ color:#c5aeb4; font-weight:300; margin-top:16px; max-width:34ch; font-size:.96rem; }
.foot-col h5{ font-family:var(--sans); font-weight:500; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.foot-col ul{ list-style:none; display:flex; flex-direction:column; gap:11px; }
.foot-col a{ color:#c5aeb4; font-size:.95rem; transition:.2s; }
.foot-col a:hover{ color:#fff; }
.foot-bot{ display:flex; justify-content:space-between; align-items:center; padding-top:26px; gap:16px; flex-wrap:wrap; font-size:.8rem; color:#9c8086; letter-spacing:.04em; }
.foot-social{ display:flex; gap:12px; }
.foot-social a{ width:38px; height:38px; border-radius:50%; border:1px solid rgba(255,255,255,.16); display:flex; align-items:center; justify-content:center; transition:.22s; }
.foot-social a:hover{ background:var(--rose); border-color:var(--rose); }
.foot-social svg{ width:18px; height:18px; }

/* ============================================================
   WHATSAPP FLOAT
   ============================================================ */
.wa-float{
  position:fixed; right:22px; bottom:22px; z-index:70;
  width:58px; height:58px; border-radius:50%; background:#25d366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 26px rgba(37,211,102,.42); transition:transform .25s;
}
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:30px; height:30px; position:relative; z-index:1; pointer-events:none; }
.wa-float::before{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid #25d366; animation:wa 2.4s ease-out infinite; pointer-events:none; }
@keyframes wa{ 0%{ transform:scale(1); opacity:.7; } 100%{ transform:scale(1.7); opacity:0; } }

/* ============================================================
   GLOBOS FLOTANTES (animación de fondo)
   ============================================================ */
.fb-layer{
  position:fixed; inset:0; pointer-events:none; z-index:45; overflow:hidden;
}
.fb{
  position:fixed; bottom:-120px; width:var(--size);
  animation:fb-rise var(--dur) linear var(--delay) forwards;
  will-change:transform; opacity:0;
  filter:drop-shadow(0 8px 14px rgba(178,95,124,.16));
}
.fb svg{ display:block; animation:fb-sway calc(var(--dur)/5) ease-in-out infinite alternate; }
@keyframes fb-rise{
  0%{ transform:translateY(0) translateX(0) rotate(0deg); opacity:0; }
  8%{ opacity:.78; }
  88%{ opacity:.78; }
  100%{ transform:translateY(-118vh) translateX(var(--sway)) rotate(var(--rot)); opacity:0; }
}
@keyframes fb-sway{
  0%{ transform:translateX(calc(var(--sway) * -0.18)); }
  100%{ transform:translateX(calc(var(--sway) * 0.18)); }
}
/* el contenido va por encima de los globos */
.site-header{ z-index:60; }
.section, .page-hero, .hero, .site-footer{ position:relative; z-index:2; }

/* el WhatsApp flotante late suavemente para llamar la atención */
@media (prefers-reduced-motion: no-preference){
  .wa-float{ animation:wa-bob 3.2s ease-in-out infinite; }
  @keyframes wa-bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-6px); } }
  .wa-float:hover{ animation:none; }
}

/* ============================================================
   Animaciones de entrada (progressive enhancement)
   ============================================================ */
.reveal{ opacity:1; transform:none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1000px){
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .values{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); row-gap:34px; }
  .quotes{ grid-template-columns:1fr; }
  .foot-top{ grid-template-columns:1fr 1fr; row-gap:36px; }
  .gal{ columns:2; }
}
@media (max-width: 860px){
  .nav{ display:none; }
  .header-cta .btn:not(.menu-btn){ display:none; }
  .menu-btn{ display:flex; }
  [data-hero="a"] .hero-inner{ grid-template-columns:1fr; }
  [data-hero="a"] .hero-art{ aspect-ratio:16/10; order:-1; }
  .svc-row{ grid-template-columns:1fr; }
  .svc-row.rev .ph{ order:0; }
  .contact-grid{ grid-template-columns:1fr; }
}
@media (max-width: 560px){
  body{ font-size:16px; }
  .svc-grid,.values{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .gal{ columns:1; }
  .field.two{ grid-template-columns:1fr; }
  .foot-top{ grid-template-columns:1fr; }
  .hero-strip{ grid-template-columns:repeat(3,1fr); }
  [data-hero="c"] .hero-bleed{ min-height:460px; }
}
