/* ================================================================
   DANCE MORE — shared design system
   Premium black & gold. Sora (display) · Hanken Grotesk (body).
   Subtle gold camera-bracket accents. Used by every page.
   ================================================================ */

:root{
  --black:     #080807;
  --bg-alt:    #0e0d0b;
  --charcoal:  #121110;
  --onyx:      #161412;
  --cream:     #f5efe4;
  --cream-2:   #fbf8f1;
  --ink:       #1a1612;
  --ink-soft:  #6a6256;
  --ivory:     #f6f1e8;
  --mute:      #b3aa99;
  --gold:      #f0b22a;
  --gold-2:    #f8cf6e;
  --gold-deep: #b5781f;

  --g-grad: linear-gradient(135deg, #f8cf6e, #f0b22a 50%, #b5781f);
  --line-d: rgba(246,241,232,.12);
  --line-l: rgba(26,22,18,.12);
  --gold-soft: rgba(240,178,42,.32);

  --disp: "Sora", system-ui, sans-serif;
  --body: "Hanken Grotesk", system-ui, sans-serif;

  --maxw: 1200px;
  --gut: clamp(20px, 5vw, 80px);
  --shadow-soft: 0 24px 60px -20px rgba(0,0,0,.6);
  --shadow-gold: 0 18px 50px -18px rgba(240,178,42,.45);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
body{ background:var(--black); color:var(--ivory); font-family:var(--body); font-size:17px; line-height:1.65; overflow-x:hidden; }
::selection{ background:var(--gold); color:#1a1208; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--disp); font-weight:700; line-height:1.08; letter-spacing:-.02em; }
.gold{ color:var(--gold); }
.gold-grad{ background:var(--g-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.kicker{ font-family:var(--body); font-weight:600; font-size:12px; letter-spacing:.26em; text-transform:uppercase; color:var(--gold); display:inline-flex; align-items:center; gap:.7em; }
.kicker::before{ content:""; width:26px; height:1px; background:var(--gold); display:inline-block; }
.kicker.c::before{ display:none; }
.h-xl{ font-size:clamp(2.6rem,6.4vw,5.4rem); font-weight:800; line-height:1.02; }
.h-lg{ font-size:clamp(2rem,4.4vw,3.4rem); font-weight:700; }
.lead{ font-size:clamp(1.02rem,1.3vw,1.18rem); color:var(--mute); line-height:1.7; }
.balance{ text-wrap:balance; }
.italic-grad{ font-style:italic; }

/* ---------- camera bracket accent ---------- */
.framed{ position:relative; }
.framed::before,.framed::after{ content:""; position:absolute; width:26px; height:26px; border:2px solid var(--gold); z-index:4; pointer-events:none; transition:width .45s, height .45s; }
.framed::before{ top:-9px; right:-9px; border-left:0; border-bottom:0; }
.framed::after{ bottom:-9px; left:-9px; border-right:0; border-top:0; }
.framed:hover::before,.framed:hover::after{ width:38px; height:38px; }

/* ---------- buttons ---------- */
.btn{ font-family:var(--body); font-weight:600; font-size:.95rem; display:inline-flex; align-items:center; justify-content:center; gap:.5em; padding:1.02em 1.7em; border-radius:6px; cursor:pointer; border:1.5px solid transparent; transition:transform .3s cubic-bezier(.2,.8,.2,1), background .3s, color .3s, box-shadow .3s; }
.btn-gold{ background:var(--gold); color:#1a1208; box-shadow:var(--shadow-gold); }
.btn-gold:hover{ background:var(--gold-2); transform:translateY(-2px); }
.btn-line{ border-color:rgba(246,241,232,.7); color:var(--ivory); }
.btn-line:hover{ border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }
.btn-line.dark{ border-color:rgba(26,22,18,.5); color:var(--ink); }
.btn-line.dark:hover{ border-color:var(--gold-deep); color:var(--gold-deep); }
.btn-green{ background:#25D366; color:#06210f; }
.btn-green:hover{ background:#2ee676; transform:translateY(-2px); }
.btn .ar{ transition:transform .3s; }
.btn:hover .ar{ transform:translate(2px,-2px); }
.btn-block{ width:100%; }

/* ---------- section helpers ---------- */
.pad{ padding-block:clamp(64px,9vw,128px); }
.pad-sm{ padding-block:clamp(48px,6vw,84px); }
.dark-sec{ background:var(--black); color:var(--ivory); }
.charcoal{ background:var(--charcoal); color:var(--ivory); }
.light-sec{ background:var(--cream); color:var(--ink); }
.light-sec .lead{ color:var(--ink-soft); }
.light-sec .kicker{ color:var(--gold-deep); } .light-sec .kicker::before{ background:var(--gold-deep); }
.sec-head{ max-width:760px; }
.center{ text-align:center; margin-inline:auto; }
.border-y-d{ border-block:1px solid var(--line-d); }
.border-y-l{ border-block:1px solid var(--line-l); }

/* ================================================================
   ANNOUNCEMENT + NAV
   ================================================================ */
.announce{ background:rgba(240,178,42,.07); border-bottom:1px solid var(--gold-soft); }
.announce p{ text-align:center; padding:10px 16px; font-family:var(--body); font-weight:500; font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }

.nav{ position:sticky; top:0; z-index:200; background:rgba(8,8,7,.82); backdrop-filter:blur(14px); border-bottom:1px solid transparent; transition:border-color .3s, background .3s; }
.nav.scrolled{ border-color:var(--line-d); background:rgba(8,8,7,.94); }
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; height:88px; }
.logo-img{ height:38px; width:auto; mix-blend-mode:screen; }
.nav-links{ display:flex; align-items:center; gap:2.1rem; list-style:none; }
.nav-links a{ font-size:.92rem; font-weight:500; color:var(--mute); position:relative; padding-block:.4em; transition:color .3s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; height:1.5px; width:0; background:var(--gold); transition:width .3s; }
.nav-links a:hover,.nav-links a.active{ color:var(--ivory); } .nav-links a:hover::after,.nav-links a.active::after{ width:100%; }
.nav-right{ display:flex; align-items:center; gap:1rem; }
.nav-right .btn{ padding:.65em 1.25em; font-size:.88rem; }
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.burger span{ width:24px; height:2px; background:var(--gold); display:block; }
@media(max-width:980px){ .nav-links{ display:none; } .nav-right .btn{ display:none; } .burger{ display:flex; } }
.mobile-menu{ position:fixed; inset:0; z-index:300; background:var(--black); display:flex; flex-direction:column; justify-content:center; padding:var(--gut); transform:translateY(-100%); transition:transform .55s cubic-bezier(.7,0,.2,1); visibility:hidden; }
.mobile-menu.open{ transform:none; visibility:visible; }
.mobile-menu a{ font-family:var(--disp); font-weight:700; font-size:1.9rem; padding:.26em 0; color:var(--ivory); border-bottom:1px solid var(--line-d); }
.mobile-menu a:hover{ color:var(--gold); }
.mobile-menu .x{ position:absolute; top:26px; right:var(--gut); background:none; border:0; color:var(--gold); font-size:13px; letter-spacing:.15em; cursor:pointer; font-weight:600; }

/* ================================================================
   HERO (homepage full-bleed)
   ================================================================ */
.hero{ position:relative; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; object-position:center; }
.hero-bg .v1{ position:absolute; inset:0; background:rgba(8,8,7,.55); }
.hero-bg .v2{ position:absolute; inset:0; background:radial-gradient(ellipse 70% 60% at 50% 42%, rgba(0,0,0,.55), rgba(0,0,0,.25) 55%, transparent 85%); }
.hero-bg .v3{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(8,8,7,.5), transparent 30%, var(--black)); }
.hero-inner{ position:relative; z-index:2; min-height:calc(100vh - 138px); display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding-block:clamp(48px,7vw,90px); }
.hero .badge{ display:inline-flex; align-items:center; gap:.6em; border:1px solid var(--gold-soft); background:rgba(8,8,7,.4); backdrop-filter:blur(6px); padding:.5em 1.1em; border-radius:999px; font-family:var(--body); font-weight:600; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); }
.hero .badge .dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); animation:pulse 1.9s infinite; }
@keyframes pulse{ 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.7)} }
.hero h1{ margin-top:1.5rem; max-width:16ch; font-size:clamp(2.7rem,8vw,6.4rem); font-weight:800; line-height:1.0; letter-spacing:-.025em; text-shadow:0 2px 30px rgba(0,0,0,.55); }
.hero p.sub{ margin-top:1.6rem; max-width:50ch; font-size:clamp(1.02rem,1.3vw,1.2rem); color:rgba(246,241,232,.86); text-shadow:0 1px 14px rgba(0,0,0,.6); }
.hero-cta{ display:flex; gap:.8rem; flex-wrap:wrap; justify-content:center; margin-top:2rem; }
.hero .spots{ margin-top:1.3rem; font-weight:600; font-size:.92rem; color:var(--gold); display:inline-flex; align-items:center; gap:.5em; }
.hero .trust{ margin-top:1.4rem; display:flex; align-items:center; justify-content:center; gap:.8rem; flex-wrap:wrap; font-size:.9rem; color:var(--mute); }
.stars{ color:var(--gold); letter-spacing:.1em; }
.trust strong{ color:var(--ivory); font-weight:600; }
.hero-video{ position:relative; z-index:2; width:100%; max-width:880px; margin:clamp(36px,5vw,64px) auto 0; }
.hero-video .vframe{ position:relative; aspect-ratio:16/9; border-radius:10px; overflow:hidden; background:var(--charcoal); box-shadow:var(--shadow-soft); }
.hero-video iframe,.hero-video video{ position:absolute; inset:0; width:100%; height:100%; border:0; object-fit:cover; }
@media(max-width:600px){ .hero-inner{ min-height:auto; padding-top:60px; } }

/* hero reel (salsa) — responsive video with elegant sound toggle */
.hero-reel{ position:relative; width:100%; max-width:720px; margin:clamp(28px,4vw,44px) auto 0; }
.hero-reel .reel{ position:relative; aspect-ratio:16/9; border-radius:16px; overflow:hidden; background:var(--charcoal); box-shadow:var(--shadow-soft); }
.hero-reel .reel-player{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.sound-btn{ position:absolute; right:14px; bottom:14px; z-index:6; display:inline-flex; align-items:center; gap:.45em; background:rgba(8,8,7,.62); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); border:1px solid var(--gold-soft); color:var(--gold); border-radius:999px; padding:.5em .85em; cursor:pointer; font-family:var(--body); font-weight:600; font-size:.8rem; line-height:1; transition:background .3s, color .3s, transform .3s; }
.sound-btn:hover{ background:var(--gold); color:#1a1208; transform:translateY(-1px); }
.sound-btn svg{ width:16px; height:16px; display:inline-block; }
.sound-btn .ic-on{ display:none; }
.sound-btn.on .ic-off{ display:none; }
.sound-btn.on .ic-on{ display:inline-block; }
@media(max-width:560px){ .sound-btn .sound-label{ display:none; } .sound-btn{ padding:.6em; gap:0; } }

/* ---------- compact / inner-page hero ---------- */
.subhero{ position:relative; overflow:hidden; text-align:center; }
.subhero .glow{ position:absolute; inset:0; background:radial-gradient(ellipse 60% 70% at 50% 0%, rgba(240,178,42,.16), transparent 62%); pointer-events:none; }
.subhero .inner{ position:relative; }
.subhero h1{ font-size:clamp(2.5rem,6.4vw,5rem); font-weight:800; line-height:1.02; max-width:18ch; margin:1.4rem auto 0; }
.subhero .sub{ margin:1.4rem auto 0; max-width:54ch; color:var(--mute); font-size:clamp(1.02rem,1.3vw,1.18rem); }
.subhero .meta{ margin-top:1rem; font-weight:600; font-size:.9rem; color:var(--ivory); letter-spacing:.02em; }
.subhero .hero-cta{ margin-top:2rem; }

/* ================================================================
   STATS
   ================================================================ */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(20px,4vw,40px); }
.stats.five{ grid-template-columns:repeat(5,1fr); }
.stat{ text-align:center; }
.stat .fig{ font-family:var(--disp); font-weight:800; font-size:clamp(2.2rem,5vw,3.6rem); line-height:1; letter-spacing:-.03em; }
.stat .lbl{ margin-top:.7rem; font-weight:600; font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }
.dark-sec .stat .lbl,.charcoal .stat .lbl{ color:var(--mute); }
@media(max-width:680px){ .stats,.stats.five{ grid-template-columns:1fr 1fr; gap:30px; } }

/* ================================================================
   GENERIC FEATURE / CARD GRIDS (reusable)
   ================================================================ */
.cards{ display:grid; gap:18px; margin-top:clamp(40px,5vw,60px); }
.cards.c2{ grid-template-columns:repeat(2,1fr); }
.cards.c3{ grid-template-columns:repeat(3,1fr); }
.cards.c4{ grid-template-columns:repeat(4,1fr); }
@media(max-width:980px){ .cards.c3,.cards.c4{ grid-template-columns:1fr 1fr; } }
@media(max-width:600px){ .cards.c2,.cards.c3,.cards.c4{ grid-template-columns:1fr; } }

.fcard{ border-radius:18px; padding:clamp(22px,2.4vw,32px); transition:transform .35s, border-color .35s, background .35s; }
.dark-sec .fcard,.charcoal .fcard{ background:var(--charcoal); border:1px solid var(--line-d); }
.dark-sec .fcard:hover,.charcoal .fcard:hover{ transform:translateY(-4px); border-color:var(--gold-soft); }
.light-sec .fcard{ background:var(--cream-2); border:1px solid var(--line-l); box-shadow:0 18px 36px -30px rgba(26,22,18,.4); }
.light-sec .fcard:hover{ transform:translateY(-4px); }
.fcard .em{ font-size:2rem; }
.fcard .n{ font-family:var(--disp); font-weight:800; font-size:clamp(2rem,3.4vw,2.8rem); line-height:1; letter-spacing:-.03em; }
.fcard .bar{ width:36px; height:2px; background:var(--gold-soft); margin:1rem 0; }
.fcard h3{ margin-top:1rem; font-size:1.22rem; }
.dark-sec .fcard h3{ color:var(--ivory); } .light-sec .fcard h3{ color:var(--ink); }
.fcard p{ margin-top:.55rem; font-size:.96rem; line-height:1.65; }
.dark-sec .fcard p,.charcoal .fcard p{ color:var(--mute); }
.light-sec .fcard p{ color:var(--ink-soft); }
.fcard .eyebrow{ font-weight:700; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); }
.light-sec .fcard .eyebrow{ color:var(--gold-deep); }
.checklist{ list-style:none; margin-top:1.2rem; display:flex; flex-direction:column; gap:.7rem; }
.checklist li{ display:flex; gap:.6rem; align-items:flex-start; font-size:.95rem; line-height:1.55; }
.dark-sec .checklist li,.charcoal .checklist li{ color:var(--mute); }
.light-sec .checklist li{ color:var(--ink-soft); }
.checklist .tick{ color:var(--gold); flex:0 0 auto; margin-top:1px; }

/* simple stacked rows (differentiators / includes) */
.rows{ max-width:760px; margin:clamp(36px,4vw,52px) auto 0; display:flex; flex-direction:column; gap:14px; }
.row-item{ display:flex; gap:1rem; align-items:flex-start; border-radius:14px; padding:1.2rem 1.4rem; }
.dark-sec .row-item,.charcoal .row-item{ background:var(--charcoal); border:1px solid var(--line-d); }
.light-sec .row-item{ background:var(--cream-2); border:1px solid var(--line-l); }
.row-item .num{ flex:0 0 32px; width:32px; height:32px; border-radius:50%; display:grid; place-items:center; font-weight:700; background:rgba(240,178,42,.14); color:var(--gold); }
.light-sec .row-item .num{ color:var(--gold-deep); }
.row-item p{ font-size:1rem; line-height:1.55; }
.dark-sec .row-item p,.charcoal .row-item p{ color:var(--ivory); }
.light-sec .row-item p{ color:var(--ink); }

/* ================================================================
   PRICING (tiers reused everywhere)
   ================================================================ */
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:clamp(44px,4vw,60px); align-items:stretch; }
.tiers.two{ grid-template-columns:repeat(2,1fr); max-width:760px; margin-inline:auto; }
.tier{ position:relative; background:var(--onyx); color:var(--ivory); border:1px solid var(--gold-soft); border-radius:20px; padding:clamp(26px,2.6vw,38px); display:flex; flex-direction:column; transition:transform .35s; }
.tier:hover{ transform:translateY(-5px); }
.tier.feat{ border:2px solid var(--gold); box-shadow:var(--shadow-gold); }
@media(min-width:901px){ .tier.feat{ transform:translateY(-14px); } .tier.feat:hover{ transform:translateY(-19px); } }
.tier .ribbon{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--gold); color:#1a1208; font-weight:700; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; padding:5px 12px; border-radius:6px; white-space:nowrap; }
.tier .ribbon.outline{ background:var(--onyx); color:var(--gold); border:1px solid var(--gold-soft); }
.tier .tname{ font-weight:700; font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.tier .tsub{ font-size:.82rem; color:var(--mute); text-transform:uppercase; letter-spacing:.12em; margin-top:.4rem; }
.tier .tdesc{ margin-top:.8rem; font-size:.96rem; color:var(--mute); line-height:1.45; }
.tier .price{ font-family:var(--disp); font-weight:800; font-size:clamp(2.6rem,3.6vw,3.2rem); margin-top:1.1rem; letter-spacing:-.03em; }
.tier .gst{ display:block; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--mute); margin-top:.5rem; font-weight:500; }
.tier .note{ font-size:.85rem; color:var(--gold); margin-top:.4rem; font-weight:600; }
.tier ul{ list-style:none; margin-top:1.6rem; display:flex; flex-direction:column; gap:.7rem; flex:1; }
.tier ul li{ display:flex; gap:.6rem; align-items:flex-start; font-size:.92rem; color:rgba(246,241,232,.82); }
.tier ul li .tick{ color:var(--gold); flex:0 0 auto; margin-top:1px; }
.tier .btn{ margin-top:1.8rem; }
.tier .refund{ margin-top:1rem; text-align:center; font-size:.82rem; color:var(--gold); font-style:italic; }
@media(max-width:900px){ .tiers,.tiers.two{ grid-template-columns:1fr; } .tier.feat{ transform:none; } .tier.feat:hover{ transform:translateY(-5px); } }

.guarantee{ max-width:760px; margin:clamp(34px,4vw,48px) auto 0; background:var(--cream-2); border:1px solid var(--gold-soft); border-radius:16px; padding:1.5rem 1.8rem; display:flex; gap:1rem; align-items:flex-start; box-shadow:0 18px 36px -30px rgba(26,22,18,.4); }
.guarantee .ic-sh{ color:var(--gold-deep); flex:0 0 auto; font-size:1.3rem; }
.guarantee p{ color:var(--ink-soft); font-size:.96rem; line-height:1.6; }
.guarantee b{ color:var(--ink); }

/* ================================================================
   GALLERY
   ================================================================ */
.gal{ display:grid; grid-template-columns:repeat(12,1fr); gap:14px; margin-top:clamp(36px,4vw,56px); }
.gal figure{ position:relative; border-radius:12px; overflow:hidden; }
.gal img{ width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(.2,.8,.2,1); }
.gal figure:hover img{ transform:scale(1.05); }
.gal .cap{ position:absolute; left:12px; bottom:12px; z-index:3; background:rgba(8,8,7,.7); backdrop-filter:blur(4px); color:var(--ivory); font-weight:600; font-size:11px; letter-spacing:.06em; padding:5px 10px; border-radius:6px; }
.gA{ grid-column:span 5; grid-row:span 2; aspect-ratio:3/4; }
.gB{ grid-column:span 4; aspect-ratio:3/4; }
.gC{ grid-column:span 3; aspect-ratio:3/4; }
.gD{ grid-column:span 4; aspect-ratio:5/4; }
.gE{ grid-column:span 3; aspect-ratio:1/1.05; }
/* even 4-up gallery (salsa) */
.gal4{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:clamp(36px,4vw,56px); }
.gal4 figure{ position:relative; border-radius:12px; overflow:hidden; aspect-ratio:4/5; }
.gal4 img{ width:100%; height:100%; object-fit:cover; transition:transform .7s ease; }
.gal4 figure:hover img{ transform:scale(1.06); }
@media(max-width:760px){
  .gal{ grid-template-columns:repeat(2,1fr); } .gal figure{ grid-column:span 1!important; grid-row:auto!important; aspect-ratio:3/4!important; }
  .gal4{ grid-template-columns:repeat(2,1fr); }
}
.namestrip{ margin-top:30px; overflow:hidden; border-block:1px solid var(--line-d); padding:14px 0; }
.namestrip .track{ display:flex; width:max-content; animation:scroll 40s linear infinite; }
.namestrip span{ font-family:var(--disp); font-weight:600; color:var(--mute); white-space:nowrap; display:flex; align-items:center; font-size:1.1rem; }
.namestrip i{ color:var(--gold); margin:0 1.2rem; font-style:normal; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ================================================================
   TESTIMONIALS / REVIEWS
   ================================================================ */
.reviews{ columns:3; column-gap:18px; margin-top:clamp(40px,4vw,56px); }
.rev{ break-inside:avoid; margin-bottom:18px; border-radius:16px; padding:1.7rem 1.6rem; }
.light-sec .rev{ background:var(--cream-2); border:1px solid var(--line-l); box-shadow:0 18px 36px -30px rgba(26,22,18,.4); }
.dark-sec .rev,.charcoal .rev{ background:var(--charcoal); border:1px solid var(--line-d); }
.rev .stars{ color:var(--gold); font-size:.9rem; }
.rev blockquote{ margin-top:.8rem; line-height:1.6; font-size:1rem; }
.light-sec .rev blockquote{ color:var(--ink); } .dark-sec .rev blockquote,.charcoal .rev blockquote{ color:var(--ivory); }
.rev .who{ margin-top:1.1rem; font-weight:700; font-size:.92rem; display:flex; align-items:center; gap:.6rem; }
.light-sec .rev .who{ color:var(--ink); } .dark-sec .rev .who,.charcoal .rev .who{ color:var(--ivory); }
.rev .src{ font-size:.78rem; color:var(--ink-soft); font-weight:500; }
.dark-sec .rev .src,.charcoal .rev .src{ color:var(--mute); }
.rev .avatar{ width:38px; height:38px; border-radius:50%; background:rgba(240,178,42,.16); color:var(--gold); display:grid; place-items:center; font-family:var(--disp); font-weight:700; flex:0 0 auto; }
@media(max-width:900px){ .reviews{ columns:2; } }
@media(max-width:560px){ .reviews{ columns:1; } }
/* single big quote */
.bigquote{ max-width:820px; margin-inline:auto; border:1px solid var(--gold-soft); border-radius:20px; padding:clamp(30px,4vw,56px); text-align:center; }
.dark-sec .bigquote,.charcoal .bigquote{ background:var(--charcoal); } .light-sec .bigquote{ background:var(--cream-2); }
.bigquote blockquote{ font-family:var(--disp); font-weight:600; font-size:clamp(1.4rem,2.6vw,2rem); line-height:1.3; margin-top:1.2rem; }
.bigquote .who{ margin-top:1.2rem; color:var(--mute); font-size:.92rem; }
.light-sec .bigquote .who{ color:var(--ink-soft); }

.rev-cta{ display:flex; gap:1rem; flex-wrap:wrap; justify-content:center; margin-top:2.4rem; }
.glink{ display:inline-flex; align-items:center; gap:.5rem; font-weight:600; font-size:.88rem; padding:.9em 1.4em; border-radius:8px; transition:.3s; }
.light-sec .glink{ border:1px solid var(--line-l); background:var(--cream-2); color:var(--ink); }
.light-sec .glink:hover{ border-color:var(--gold-deep); color:var(--gold-deep); }
.dark-sec .glink,.charcoal .glink{ border:1px solid var(--line-d); color:var(--ivory); }
.dark-sec .glink:hover,.charcoal .glink:hover{ border-color:var(--gold); color:var(--gold); }

/* ================================================================
   COMPARISON (worth-it)
   ================================================================ */
.compare{ margin-top:clamp(40px,4vw,56px); display:flex; flex-direction:column; gap:14px; max-width:1000px; margin-inline:auto; }
.crow{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cell{ border-radius:16px; padding:1.4rem 1.6rem; display:flex; gap:1rem; align-items:flex-start; line-height:1.5; }
.cell.no{ background:rgba(217,133,111,.06); border:1px solid rgba(217,133,111,.3); color:rgba(246,241,232,.72); }
.cell.yes{ background:rgba(240,178,42,.05); border:1px solid var(--gold-soft); color:var(--ivory); }
.cell .ic{ width:30px; height:30px; flex:0 0 30px; border-radius:50%; display:grid; place-items:center; font-size:13px; font-weight:700; }
.cell.no .ic{ background:rgba(217,133,111,.18); color:#d9856f; }
.cell.yes .ic{ background:rgba(240,178,42,.16); color:var(--gold); }
.worth-foot{ font-family:var(--disp); font-weight:600; font-size:clamp(1.3rem,2.4vw,1.9rem); text-align:center; max-width:42ch; margin:clamp(36px,4vw,52px) auto 0; line-height:1.35; }
@media(max-width:680px){ .crow{ grid-template-columns:1fr; } }

/* ================================================================
   FAQ
   ================================================================ */
.faq{ max-width:840px; margin:clamp(40px,4vw,56px) auto 0; border-radius:18px; padding:.4rem clamp(20px,3vw,36px); }
.light-sec .faq{ background:var(--cream-2); border:1px solid var(--line-l); box-shadow:0 24px 50px -34px rgba(26,22,18,.35); }
.dark-sec .faq,.charcoal .faq{ background:var(--charcoal); border:1px solid var(--line-d); }
.faq details{ border-bottom:1px solid var(--line-l); }
.dark-sec .faq details,.charcoal .faq details{ border-bottom:1px solid var(--line-d); }
.faq details:last-child{ border-bottom:0; }
.faq summary{ list-style:none; cursor:pointer; padding:1.4rem 0; display:flex; gap:1rem; align-items:baseline; font-family:var(--disp); font-weight:600; font-size:1.08rem; transition:color .3s; }
.light-sec .faq summary{ color:var(--ink); } .dark-sec .faq summary,.charcoal .faq summary{ color:var(--ivory); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .pl{ margin-left:auto; color:var(--gold-deep); font-size:1.4rem; line-height:1; transition:transform .3s; flex:0 0 auto; font-weight:400; }
.dark-sec .faq summary .pl,.charcoal .faq summary .pl{ color:var(--gold); }
.faq details[open] summary{ color:var(--gold-deep); } .dark-sec .faq details[open] summary,.charcoal .faq details[open] summary{ color:var(--gold); }
.faq details[open] summary .pl{ transform:rotate(45deg); }
.faq .ans{ padding:0 0 1.5rem; line-height:1.75; font-size:.98rem; }
.light-sec .faq .ans{ color:var(--ink-soft); } .dark-sec .faq .ans,.charcoal .faq .ans{ color:var(--mute); }

/* ================================================================
   PROBLEM/SOLUTION + METHOD (homepage)
   ================================================================ */
.ps-wrap{ max-width:760px; margin-inline:auto; display:flex; flex-direction:column; gap:clamp(24px,3vw,40px); margin-top:clamp(40px,5vw,64px); }
.card{ border-radius:22px; padding:clamp(28px,4vw,52px); }
.card.dark{ background:var(--onyx); color:var(--ivory); border:1px solid var(--gold-soft); box-shadow:var(--shadow-soft); }
.card.lightc{ background:var(--cream-2); border:1px solid var(--line-l); box-shadow:0 24px 50px -30px rgba(26,22,18,.3); }
.tag{ font-weight:600; font-size:12px; letter-spacing:.2em; text-transform:uppercase; }
.tag.bad{ color:#d9856f; } .tag.good{ color:#3f8a5e; }
.card h2{ margin-top:1rem; } .card.dark h2{ color:var(--ivory); }
.card .checklist{ margin-top:1.8rem; gap:1rem; }
.card .checklist li{ font-size:1.02rem; }
.card.dark .checklist li{ color:rgba(246,241,232,.82); } .card.lightc .checklist li{ color:var(--ink); }
.ic-round{ flex:0 0 24px; width:24px; height:24px; border-radius:50%; display:grid; place-items:center; font-size:12px; font-weight:700; margin-top:2px; }
.ic-round.x{ background:rgba(217,133,111,.18); color:#d9856f; }
.ic-round.c{ background:rgba(63,138,94,.16); color:#3f8a5e; }
.media-9-16{ position:relative; width:100%; max-width:340px; margin:clamp(28px,4vw,44px) auto 0; aspect-ratio:9/16; border-radius:14px; overflow:hidden; background:var(--charcoal); }
.media-9-16 img,.media-9-16 iframe{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border:0; }
.media-badge{ position:absolute; top:12px; left:12px; z-index:5; background:var(--g-grad); color:#1a1208; font-weight:700; font-size:10px; letter-spacing:.12em; text-transform:uppercase; padding:5px 10px; border-radius:6px; }
.media-cap{ margin-top:.9rem; text-align:center; font-size:.92rem; font-style:italic; }
.card.dark .media-cap{ color:rgba(246,241,232,.55); } .card.lightc .media-cap{ color:var(--ink-soft); }
.testimonial{ margin-top:clamp(30px,4vw,48px); padding-top:clamp(24px,3vw,40px); border-top:1px solid var(--line-l); display:flex; gap:1.4rem; align-items:flex-start; flex-wrap:wrap; }
.testimonial img{ width:120px; height:120px; border-radius:14px; object-fit:cover; flex:0 0 auto; border:1px solid var(--gold-soft); }
.testimonial blockquote{ font-size:1.05rem; line-height:1.6; color:var(--ink); font-style:italic; }
.testimonial .who{ margin-top:.8rem; font-weight:600; font-size:.9rem; color:var(--gold-deep); }
.testimonial .src{ font-size:.8rem; color:var(--ink-soft); }

.method-card{ position:relative; max-width:920px; margin-inline:auto; background:var(--onyx); border:1px solid var(--gold-soft); border-radius:28px; padding:clamp(34px,5vw,72px); text-align:center; overflow:hidden; box-shadow:var(--shadow-soft); }
.method-card .glow{ position:absolute; inset:0; background:radial-gradient(ellipse 60% 50% at 50% 0%, rgba(240,178,42,.16), transparent 65%); pointer-events:none; }
.method-card .inner{ position:relative; }
.method-card h2{ color:var(--ivory); }
.method-card h2 .l1{ display:block; font-size:clamp(1.7rem,3.2vw,2.6rem); font-weight:600; }
.method-card h2 .l2{ display:block; margin-top:.4rem; font-size:clamp(2.1rem,4.6vw,3.6rem); font-weight:800; }
.method-card .body{ margin-top:1.6rem; max-width:640px; margin-inline:auto; color:rgba(246,241,232,.74); line-height:1.7; }
.mlist{ list-style:none; margin-top:2.4rem; display:flex; flex-direction:column; gap:12px; max-width:560px; margin-inline:auto; text-align:left; }
.mlist li{ display:flex; gap:1rem; align-items:center; background:rgba(246,241,232,.03); border:1px solid var(--gold-soft); border-radius:14px; padding:1.1rem 1.3rem; font-size:1.02rem; }
.mlist .em{ font-size:1.4rem; }

/* styles cards (homepage) */
.styles{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:clamp(40px,5vw,60px); }
.style{ background:var(--charcoal); border:1px solid var(--line-d); border-radius:18px; padding:clamp(22px,2.4vw,30px); transition:transform .35s, border-color .35s; }
.style:hover{ transform:translateY(-4px); border-color:var(--gold-soft); }
.style.feat{ border:2px solid var(--gold); box-shadow:var(--shadow-gold); }
.style .em{ font-size:2rem; } .style h3{ margin-top:1rem; font-size:1.25rem; } .style p{ margin-top:.5rem; font-size:.93rem; color:var(--mute); }
@media(max-width:880px){ .styles{ grid-template-columns:1fr 1fr; } }

/* ================================================================
   FINAL CTA + CONTACT
   ================================================================ */
.final{ position:relative; overflow:hidden; text-align:center; }
.final .glow{ position:absolute; inset:0; background:radial-gradient(ellipse 60% 60% at 50% 40%, rgba(240,178,42,.14), transparent 62%); pointer-events:none; }
.final .inner{ position:relative; }
.final h2{ max-width:18ch; margin-inline:auto; }
.final .trust2{ margin-top:2rem; display:flex; flex-direction:column; gap:1rem; align-items:center; }

.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,68px); align-items:start; }
.contact-info p{ color:var(--mute); margin-top:1.2rem; max-width:38ch; }
.contact-info ul{ list-style:none; margin-top:1.6rem; display:flex; flex-direction:column; gap:.8rem; }
.contact-info ul li{ display:flex; gap:.7rem; align-items:center; font-size:.96rem; color:var(--ivory); }
.contact-info .addr{ margin-top:2rem; padding-top:1.5rem; border-top:1px solid var(--line-d); }
.contact-info .addr strong{ display:block; font-family:var(--disp); font-weight:700; font-size:1.15rem; }
.contact-info .addr span{ color:var(--mute); font-size:.92rem; }
.form{ background:var(--charcoal); border:1px solid var(--line-d); border-radius:18px; padding:clamp(24px,3vw,40px); }
.field{ margin-bottom:1.1rem; }
.field label{ font-weight:600; font-size:.82rem; color:var(--ivory); display:block; margin-bottom:.5rem; }
.field input,.field select,.field textarea{ width:100%; background:var(--black); border:1px solid var(--line-d); color:var(--ivory); padding:.85rem 1rem; border-radius:8px; font-family:var(--body); font-size:.98rem; transition:border .3s; }
.field input::placeholder,.field textarea::placeholder{ color:rgba(179,170,153,.55); }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold); }
.field select option{ background:var(--charcoal); }
.frow{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.fineprint{ font-size:.74rem; color:var(--mute); text-align:center; margin-top:1rem; }
@media(max-width:840px){ .contact-grid{ grid-template-columns:1fr; } }
@media(max-width:480px){ .frow{ grid-template-columns:1fr; } }

/* reserve / gold-glow CTA band */
.reserve{ position:relative; overflow:hidden; text-align:center; }
.reserve .glow{ position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 50% 50%, rgba(240,178,42,.16), transparent 60%); pointer-events:none; }
.reserve .inner{ position:relative; max-width:680px; margin-inline:auto; }

/* ================================================================
   FOOTER + WHATSAPP
   ================================================================ */
.footer{ background:var(--bg-alt); border-top:1px solid var(--line-d); padding-block:clamp(48px,6vw,72px); text-align:center; }
.foot-logo{ height:62px; width:auto; mix-blend-mode:screen; margin-inline:auto; }
.foot-tag{ color:var(--mute); margin-top:1.2rem; max-width:30ch; margin-inline:auto; }
.foot-links{ display:flex; justify-content:center; gap:1.6rem; flex-wrap:wrap; margin-top:2rem; list-style:none; }
.foot-links a{ font-weight:500; font-size:.9rem; color:var(--mute); transition:color .3s; }
.foot-links a:hover{ color:var(--gold); }
.foot-copy{ margin-top:2rem; font-size:.8rem; color:var(--ink-soft); }

.wa{ position:fixed; right:20px; bottom:20px; z-index:150; width:56px; height:56px; border-radius:50%; background:#25923a; color:#fff; display:grid; place-items:center; box-shadow:0 16px 32px -10px rgba(0,0,0,.5); transition:transform .3s; }
.wa:hover{ transform:scale(1.08); }

/* ================================================================
   BLOG / PROSE
   ================================================================ */
.blog-header{ max-width:760px; margin-inline:auto; text-align:center; }
.blog-header .cat{ font-weight:600; font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.blog-header h1{ font-size:clamp(2.2rem,5.2vw,4rem); font-weight:800; line-height:1.05; margin-top:1.2rem; }
.blog-header h1 em{ font-style:italic; color:var(--gold); }
.blog-header .byline{ margin-top:1.2rem; font-size:.85rem; color:var(--mute); letter-spacing:.04em; }
.blog-header .intro{ margin-top:1.4rem; font-size:1.12rem; line-height:1.7; color:rgba(246,241,232,.86); }
.breadcrumb{ font-size:.85rem; color:var(--mute); margin-bottom:1.4rem; }
.breadcrumb a:hover{ color:var(--gold); }
.breadcrumb .sep{ margin:0 .5em; color:var(--gold-deep); }

.prose{ max-width:720px; margin-inline:auto; color:rgba(246,241,232,.85); font-size:1.06rem; line-height:1.85; }
.prose > p{ margin-bottom:1.4rem; }
.prose h2{ font-size:clamp(1.6rem,3vw,2.1rem); color:var(--ivory); margin:2.8rem 0 1rem; line-height:1.2; }
.prose h3{ font-size:1.25rem; color:var(--gold); margin:2rem 0 .7rem; }
.prose strong{ color:var(--ivory); }
.prose em{ color:var(--gold-2); font-style:italic; }
.prose a{ color:var(--gold); text-decoration:underline; text-underline-offset:3px; }
.prose a:hover{ color:var(--gold-2); }
.prose ul,.prose ol{ margin:1rem 0 1.6rem 1.4rem; }
.prose li{ margin-bottom:.6rem; }
.prose .comparison-table{ width:100%; border-collapse:collapse; margin:2rem 0; font-size:.96rem; }
.prose .comparison-table th,.prose .comparison-table td{ padding:.85rem 1rem; text-align:left; border-bottom:1px solid var(--line-d); }
.prose .comparison-table th{ color:var(--gold); font-family:var(--disp); font-weight:600; letter-spacing:.01em; }
.prose .highlight-box{ background:rgba(240,178,42,.07); border-left:3px solid var(--gold); padding:1.3rem 1.6rem; margin:2rem 0; border-radius:0 10px 10px 0; }
.prose .highlight-box p{ margin:0; font-style:italic; color:var(--gold-2); }
.prose .verdict-box{ background:var(--charcoal); border:1px solid var(--gold-soft); border-radius:14px; padding:1.4rem 1.7rem; margin:1.4rem 0; }
.prose .verdict-box h3{ margin:0 0 .5rem; color:var(--ivory); }
.prose .verdict-box p{ margin:0; }
.prose .faq-section{ margin-top:3.4rem; padding-top:2.4rem; border-top:1px solid var(--gold-soft); }
.prose .faq-item{ margin-bottom:1.6rem; padding-bottom:1.6rem; border-bottom:1px solid var(--line-d); }
.prose .faq-item:last-child{ border-bottom:0; }
.prose .faq-item h3{ color:var(--ivory); margin:0 0 .6rem; font-family:var(--disp); font-size:1.18rem; }
.prose .faq-item p{ margin:0; color:var(--mute); }
.prose .cta-section{ background:rgba(240,178,42,.06); border:1px solid var(--gold-soft); border-radius:18px; padding:clamp(28px,4vw,48px); text-align:center; margin-top:3.4rem; }
.prose .cta-section h2{ margin:0 0 1rem; font-size:clamp(1.5rem,2.6vw,2rem); }
.prose .cta-section p{ margin-bottom:1.4rem; color:rgba(246,241,232,.82); }
.prose .cta-btn{ display:inline-flex; align-items:center; gap:.5em; background:var(--gold); color:#1a1208; padding:1em 2.2em; border-radius:6px; text-decoration:none; font-weight:700; transition:transform .3s, background .3s; }
.prose .cta-btn:hover{ background:var(--gold-2); transform:translateY(-2px); }
.prose .cta-note{ font-size:.85rem; color:var(--mute); margin-top:1rem; }
.prose .back{ margin-top:2.6rem; text-align:center; }

/* ================================================================
   REVEAL ANIMATION
   ================================================================ */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.hero .load,.subhero .load{ opacity:0; transform:translateY(30px); animation:loadup .9s cubic-bezier(.2,.8,.2,1) forwards; }
@keyframes loadup{ to{ opacity:1; transform:none; } }
@media(prefers-reduced-motion:reduce){ .reveal,.hero .load,.subhero .load{ opacity:1; transform:none; animation:none; transition:none; } *{ animation:none!important; } }

/* ================================================================
   SALSA PAGE — video testimonials, photo reviews, reasons
   ================================================================ */
/* video testimonials (2-up grid of portrait reels) */
.vt-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; max-width:760px; margin:clamp(40px,5vw,56px) auto 0; }
.vt-card{ position:relative; }
.vt-media{ position:relative; aspect-ratio:9/16; border-radius:16px; overflow:hidden; background:var(--charcoal); border:1px solid var(--line-d); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1rem; box-shadow:var(--shadow-soft); }
.vt-media .vt-frame,.vt-media iframe,.vt-media video{ position:absolute; inset:0; width:100%; height:100%; border:0; object-fit:cover; }
.vt-play{ width:60px; height:60px; border-radius:50%; background:var(--gold); color:#1a1208; display:grid; place-items:center; font-size:1.3rem; box-shadow:var(--shadow-gold); }
.vt-cap{ font-family:var(--body); font-weight:600; font-size:.85rem; color:var(--mute); }
.vt-name{ text-align:center; margin-top:.85rem; font-weight:700; color:var(--ivory); font-size:1rem; }
@media(max-width:600px){ .vt-grid{ grid-template-columns:1fr; max-width:380px; } }

/* photo reviews (2-col grid) */
.rev-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:clamp(40px,4vw,56px); align-items:start; }
.rev-grid .rev{ margin:0; }
.rev .avatar{ position:relative; overflow:hidden; flex:0 0 auto; width:50px; height:50px; border:1px solid var(--gold-soft); }
.rev .avatar img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:50%; }
.rev .avatar i{ font-style:normal; }
.who-meta{ display:flex; flex-direction:column; }
.read-more{ background:none; border:0; color:var(--gold); font-family:var(--body); font-weight:600; font-size:.85rem; cursor:pointer; padding:.5rem 0 0; }
.read-more:hover{ text-decoration:underline; }
@media(max-width:640px){ .rev-grid{ grid-template-columns:1fr; } }

/* reasons to join (vertical checklist) */
.reasons{ list-style:none; max-width:760px; margin:clamp(40px,5vw,56px) auto 0; display:flex; flex-direction:column; gap:12px; }
.reasons li{ display:flex; gap:1rem; align-items:flex-start; background:var(--charcoal); border:1px solid var(--line-d); border-radius:14px; padding:1.1rem 1.3rem; font-size:1.05rem; line-height:1.5; color:var(--ivory); }
.reasons .rk{ flex:0 0 auto; font-size:1.2rem; line-height:1.3; }

/* photo-card reviews — big rounded photo on the left, review on the right */
.greviews{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:clamp(40px,4vw,56px); }
.greview{ display:flex; gap:1.3rem; align-items:flex-start; background:var(--onyx); border:1px solid var(--line-d); border-radius:16px; padding:1.5rem 1.6rem; box-shadow:var(--shadow-soft); }
.greview .gphoto{ flex:0 0 auto; width:128px; height:158px; border-radius:12px; object-fit:cover; object-position:center 22%; border:1px solid var(--gold-soft); background:var(--charcoal); }
.greview .gbody{ flex:1; min-width:0; }
.greview .stars{ color:var(--gold); font-size:.95rem; letter-spacing:.06em; }
.greview blockquote{ margin-top:.6rem; font-style:italic; line-height:1.55; color:var(--ivory); font-size:.98rem; }
.greview .nm{ margin-top:.9rem; font-weight:700; color:var(--gold); }
.greview .src{ font-size:.8rem; color:var(--mute); margin-top:.1rem; }
.greview .read-more{ padding:.5rem 0 0; }
@media(max-width:1000px){ .greviews{ grid-template-columns:1fr; } }
@media(max-width:460px){ .greview{ flex-direction:column; } .greview .gphoto{ width:100%; height:240px; object-position:center 25%; } }
