/* ============================================================
   DERILA ERGO PILLOW V2 — css/style.css
   Domain: en-us-derilaergo-pillow.com
   Colors: Midnight Plum #2e1760 + Warm Gold #d4a843 + Soft Ivory #fdf9f3
   + Dusty Rose #c4907a as accent
   Theme: Dark Luxury Sleep Wellness — completely different from V1
   V1 was: white hero, marine/teal/coral, benefit strip, 3-col reviews
   V2: Dark plum centred hero, gold strip, horizontal timeline HIW,
       alternating benefit rows dark bg, 2-col magazine reviews,
       gold guarantee band, icon pillars, ivory/gold palette light sections
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,400&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --plum:        #2e1760;
  --plum-mid:    #3d2280;
  --plum-lgt:    #4f2ea8;
  --plum-soft:   #6b44c4;
  --plum-pale:   #f3f0fb;
  --plum-xp:     #f8f6fd;
  --gold:        #d4a843;
  --gold-dk:     #b8892a;
  --gold-lgt:    #e8c068;
  --gold-xl:     #f5d98a;
  --gold-pale:   #fdf8ec;
  --gold-xp:     #fffdf5;
  --rose:        #c4907a;
  --rose-dk:     #a8705a;
  --rose-lgt:    #ddb09c;
  --rose-pale:   #fdf4f1;
  --ivory:       #fdf9f3;
  --ivory-dk:    #f5ede0;
  --ivory-mid:   #ede1d0;
  --white:       #ffffff;
  --off:         #fafaf8;
  --silver:      #94a3b8;
  --silver-lgt:  #e4e4e7;
  --muted:       #64748b;
  --muted-dk:    #475569;
  --text:        #2e1760;
  --text-body:   #2d2d2d;
  --border-lt:   #e4e4e7;
  --border-g:    #e8c068;
  --radius:      10px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --radius-pill: 50px;
  --sh-sm:       0 2px 12px rgba(0,0,0,.06);
  --sh:          0 4px 24px rgba(0,0,0,.10);
  --sh-h:        0 12px 40px rgba(0,0,0,.16);
  --sh-p:        0 4px 20px rgba(46,23,96,.30);
  --sh-pb:       0 8px 28px rgba(46,23,96,.16);
  --sh-g:        0 4px 20px rgba(212,168,67,.44);
  --sh-gb:       0 8px 28px rgba(212,168,67,.24);
  --sh-r:        0 4px 20px rgba(196,144,122,.36);
}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;font-size:18px;color:var(--text-body);
  background:var(--ivory);overflow-x:hidden;line-height:1.75}
a{color:inherit;text-decoration:none;transition:color .2s}
img{max-width:100%;height:auto;display:block}

/* NAV — Dark plum with gold bottom border */
nav{position:sticky;top:0;z-index:1000;background:var(--plum);
  height:70px;padding:0 32px;
  box-shadow:0 2px 24px rgba(0,0,0,.45);
  border-bottom:3px solid var(--gold)}
.nav-inner{max-width:1200px;margin:0 auto;height:100%;
  display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{font-family:'Jost',sans-serif;font-size:1.35rem;font-weight:900;
  color:var(--white);letter-spacing:.3px;text-transform:uppercase;
  text-decoration:none;flex-shrink:0;display:flex;align-items:center;gap:10px}
.logo-gem{width:38px;height:38px;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--gold-dk),var(--gold-lgt));
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;
  box-shadow:var(--sh-g)}
.nav-logo .hl{color:var(--gold-lgt)}
.nav-links{display:flex;align-items:center;gap:20px;list-style:none}
.nav-links a{color:rgba(255,255,255,.50);font-size:.88rem;font-weight:600;
  white-space:nowrap;transition:color .2s}
.nav-links a:hover{color:var(--gold-xl)}
.btn-nav{background:var(--gold)!important;color:var(--plum)!important;
  font-weight:900!important;font-size:.84rem!important;padding:10px 18px!important;
  border-radius:var(--radius-pill)!important;text-transform:uppercase;
  box-shadow:var(--sh-g)!important;transition:filter .2s!important;border:none!important}
.btn-nav:hover{filter:brightness(1.08)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{width:26px;height:2px;background:rgba(255,255,255,.65);display:block;border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--plum-mid);
  position:absolute;top:70px;left:0;right:0;padding:22px 32px;gap:16px;z-index:999;
  border-bottom:2px solid var(--gold)}
.mobile-menu.open{display:flex}
.mobile-menu a{color:rgba(255,255,255,.72);font-size:1rem;font-weight:600}
.mobile-menu .btn-mob{background:var(--gold);color:var(--plum);text-align:center;
  padding:13px;border-radius:var(--radius-pill);font-weight:900;margin-top:4px;text-transform:uppercase}

/* BUTTONS */
.btn-gold{display:inline-block;background:var(--gold);color:var(--plum);
  font-family:'Jost',sans-serif;font-weight:900;font-size:1.05rem;text-transform:uppercase;
  padding:15px 38px;border-radius:var(--radius-pill);text-decoration:none;
  transition:filter .2s,transform .15s;box-shadow:var(--sh-g);letter-spacing:.5px}
.btn-gold:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-plum{display:inline-block;background:var(--plum);color:var(--white);
  font-family:'Jost',sans-serif;font-weight:900;font-size:1.05rem;text-transform:uppercase;
  padding:15px 38px;border-radius:var(--radius-pill);text-decoration:none;
  transition:filter .2s,transform .15s;box-shadow:var(--sh-p);letter-spacing:.5px}
.btn-plum:hover{filter:brightness(1.15);transform:translateY(-2px)}
.btn-outline-g{display:inline-block;background:transparent;color:var(--gold-dk);
  font-family:'Jost',sans-serif;font-weight:700;font-size:1rem;text-transform:uppercase;
  padding:13px 32px;border-radius:var(--radius-pill);border:2px solid var(--gold);
  text-decoration:none;transition:all .2s}
.btn-outline-g:hover{background:var(--gold);color:var(--plum)}
.btn-outline-w{display:inline-block;background:transparent;color:rgba(255,255,255,.80);
  font-family:'Jost',sans-serif;font-weight:700;font-size:1rem;text-transform:uppercase;
  padding:13px 32px;border-radius:var(--radius-pill);border:2px solid rgba(255,255,255,.28);
  text-decoration:none;transition:all .2s}
.btn-outline-w:hover{border-color:var(--gold-xl);color:var(--gold-xl)}

/* SECTION BANDS */
.sec-band{padding:52px 40px 44px;text-align:center}
.sec-band h2{font-family:'Jost',sans-serif;font-size:2.3rem;font-weight:900;line-height:1.2}
.sec-band p.sub{font-size:1rem;margin-top:10px}
.plum-band{background:var(--plum);border-top:3px solid var(--gold);border-bottom:3px solid var(--gold)}
.plum-band h2{color:var(--white)}.plum-band .hl{color:var(--gold-xl)}.plum-band p.sub{color:rgba(255,255,255,.48)}
.gold-band{background:var(--gold);border-top:2px solid var(--gold-dk);border-bottom:2px solid var(--gold-dk)}
.gold-band h2{color:var(--plum)}.gold-band p.sub{color:rgba(46,23,96,.68)}
.ivory-band{background:var(--ivory);border-top:2px solid var(--ivory-mid);border-bottom:2px solid var(--ivory-mid)}
.ivory-band h2{color:var(--plum)}.ivory-band .hl{color:var(--gold-dk)}.ivory-band p.sub{color:var(--muted)}
.gold-pale-band{background:var(--gold-pale);border-top:2px solid var(--border-g);border-bottom:2px solid var(--border-g)}
.gold-pale-band h2{color:var(--plum)}.gold-pale-band .hl{color:var(--gold-dk)}.gold-pale-band p.sub{color:var(--muted-dk)}
.plum-pale-band{background:var(--plum-pale);border-top:2px solid rgba(46,23,96,.12);border-bottom:2px solid rgba(46,23,96,.12)}
.plum-pale-band h2{color:var(--plum)}.plum-pale-band .hl{color:var(--rose-dk)}.plum-pale-band p.sub{color:var(--muted)}
.plum-mid-band{background:var(--plum-mid);border-top:2px solid rgba(212,168,67,.22);border-bottom:2px solid rgba(212,168,67,.22)}
.plum-mid-band h2{color:var(--white)}.plum-mid-band .hl{color:var(--gold-xl)}.plum-mid-band p.sub{color:rgba(255,255,255,.42)}
.white-band{background:var(--white);border-top:2px solid var(--silver-lgt);border-bottom:2px solid var(--silver-lgt)}
.white-band h2{color:var(--plum)}.white-band .hl{color:var(--rose-dk)}.white-band p.sub{color:var(--muted)}

/* HERO — Dark plum full-bleed, centred, product floats */
.hero{background:linear-gradient(160deg,var(--plum) 0%,var(--plum-mid) 55%,var(--plum-lgt) 100%);
  overflow:hidden;position:relative;padding:0;min-height:700px}
/* Gold glow top */
.hero::before{content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);
  width:600px;height:300px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(212,168,67,.18) 0%,transparent 65%);pointer-events:none}
/* Rose glow bottom right */
.hero::after{content:'';position:absolute;bottom:-60px;right:-40px;
  width:340px;height:340px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(196,144,122,.14) 0%,transparent 65%);pointer-events:none}
.hero-wave{position:absolute;bottom:-2px;left:0;right:0;line-height:0;pointer-events:none;z-index:2}
.hero-inner{max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;min-height:700px;
  padding:64px 48px 90px;position:relative;z-index:1}
/* LEFT — text */
.hero-text{display:flex;flex-direction:column;gap:22px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;
  color:var(--gold-lgt);font-size:.72rem;font-weight:900;
  letter-spacing:3px;text-transform:uppercase;width:fit-content}
.hero-eyebrow::before{content:'';display:block;width:30px;height:2px;background:var(--gold)}
.hero-h1{font-family:'Jost',sans-serif;font-size:3.1rem;font-weight:900;
  color:var(--white);line-height:1.06;letter-spacing:-.5px}
.hero-h1 .hl-g{color:var(--gold-xl)}
.hero-h1 .hl-r{color:var(--rose-lgt)}
.hero-desc{font-size:1.05rem;line-height:1.80;color:rgba(255,255,255,.58);max-width:480px}
/* Gold feature pills */
.hero-pills{display:flex;flex-wrap:wrap;gap:8px}
.hpill{display:inline-flex;align-items:center;gap:7px;border-radius:var(--radius-pill);
  padding:7px 16px;font-size:.80rem;font-weight:700}
.hpill.gp{background:rgba(212,168,67,.14);border:1px solid rgba(212,168,67,.32);color:var(--gold-xl)}
.hpill.wp{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.75)}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px}
.hero-note{font-size:.79rem;color:rgba(255,255,255,.28)}
.hero-note strong{color:var(--gold-lgt)}
/* RIGHT — product with gold frame */
.hero-img-col{display:flex;justify-content:center;align-items:center;position:relative}
.hero-img-frame{position:relative;display:inline-block}
.hero-img-frame::before{content:'';position:absolute;inset:-18px;
  border-radius:var(--radius-xl);border:1.5px solid rgba(212,168,67,.25);pointer-events:none}
.hero-img-frame::after{content:'';position:absolute;inset:-36px;
  border-radius:var(--radius-xl);border:1px solid rgba(212,168,67,.10);pointer-events:none}
.hero-img-frame a img{max-height:520px;width:auto;object-fit:contain;
  filter:drop-shadow(0 0 48px rgba(212,168,67,.22)) drop-shadow(0 20px 50px rgba(0,0,0,.80));
  transition:transform .6s ease;display:block;margin:0 auto;position:relative;z-index:1}
.hero-img-frame a:hover img{transform:scale(1.04) translateY(-10px)}

/* GOLD STAT STRIP */
.stat-strip{background:var(--gold);padding:18px 48px}
.stat-strip-inner{max-width:1100px;margin:0 auto;display:flex;
  flex-wrap:wrap;justify-content:center;align-items:center;gap:0}
.ss-item{display:flex;align-items:center;gap:10px;
  padding:6px 32px;border-right:2px solid rgba(46,23,96,.14)}
.ss-item:last-child{border-right:none}
.ss-icon{font-size:1.4rem;flex-shrink:0}
.ss-text{font-size:.88rem;font-weight:800;color:var(--plum);text-transform:uppercase;letter-spacing:.5px}

/* ABOUT — ivory bg, text LEFT image RIGHT */
.about-section{background:var(--ivory);padding:72px 48px}
.about-inner{max-width:1160px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr;align-items:center;gap:60px}
.about-tag{display:inline-block;background:var(--gold);color:var(--plum);
  font-size:.70rem;font-weight:900;text-transform:uppercase;letter-spacing:2px;
  padding:4px 12px;border-radius:var(--radius-pill);margin-bottom:14px}
.about-text h3{font-family:'Jost',sans-serif;font-size:2rem;font-weight:900;
  color:var(--plum);margin-bottom:16px;line-height:1.2}
.about-text h3 span{color:var(--gold-dk)}
.about-text p{font-size:1.03rem;line-height:1.85;color:var(--muted);margin-bottom:14px}
.about-img img{width:100%;max-width:420px;height:auto;object-fit:contain;
  filter:drop-shadow(0 8px 24px rgba(46,23,96,.14)) drop-shadow(0 4px 12px rgba(212,168,67,.12));margin:0 auto}

/* HIW — Horizontal timeline connector (completely different from V1) */
.hiw-section{background:var(--plum);padding:72px 48px}
.hiw-timeline{max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;position:relative}
.hiw-timeline::before{content:'';position:absolute;
  top:36px;left:calc(16.5%);right:calc(16.5%);height:2px;
  background:linear-gradient(90deg,var(--gold-dk),var(--gold-xl),var(--gold-dk));z-index:0}
.hiw-item{display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:0 24px;position:relative;z-index:1}
.hiw-dot{width:72px;height:72px;border-radius:50%;
  background:var(--gold);display:flex;align-items:center;justify-content:center;
  font-family:'Jost',sans-serif;font-size:1.8rem;font-weight:900;color:var(--plum);
  margin:0 auto 20px;box-shadow:var(--sh-g);border:4px solid var(--plum-mid)}
.hiw-item:nth-child(2) .hiw-dot{background:var(--white);border-color:var(--plum-lgt)}
.hiw-item:nth-child(3) .hiw-dot{background:var(--rose);color:var(--white);box-shadow:var(--sh-r)}
.hiw-tag{font-family:'Jost',sans-serif;font-size:.70rem;font-weight:900;
  text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;display:block}
.hiw-item:nth-child(1) .hiw-tag{color:var(--gold-lgt)}
.hiw-item:nth-child(2) .hiw-tag{color:rgba(255,255,255,.55)}
.hiw-item:nth-child(3) .hiw-tag{color:var(--rose-lgt)}
.hiw-title{font-family:'Jost',sans-serif;font-size:1.05rem;font-weight:800;
  color:var(--white);margin-bottom:10px;line-height:1.3}
.hiw-item p{font-size:.88rem;line-height:1.65;color:rgba(255,255,255,.48)}

/* ORDER / PAYMENT IMG */
.order-img-section{background:var(--gold-pale);padding:52px 48px;text-align:center;
  border-top:2px solid var(--border-g);border-bottom:2px solid var(--border-g)}
.order-img-section a{display:block;margin:0 auto;max-width:900px}
.order-img-section a img{width:100%;height:auto;object-fit:contain;
  border-radius:var(--radius-lg);box-shadow:var(--sh-gb);transition:transform .3s;margin:0 auto}
.order-img-section a:hover img{transform:scale(1.01)}

.payment-section{background:var(--plum-pale);padding:52px 48px;text-align:center;
  border-top:2px solid rgba(46,23,96,.12);border-bottom:2px solid rgba(46,23,96,.12)}
.payment-section a{display:block;margin:0 auto;max-width:900px}
.payment-section a img{width:100%;height:auto;object-fit:contain;
  border-radius:var(--radius-lg);box-shadow:var(--sh-pb);transition:transform .3s;margin:0 auto}
.payment-section a:hover img{transform:scale(1.01)}

/* BENEFITS — alternating rows on plum bg */
.benefits-section{background:var(--plum-mid);padding:72px 48px}
.benefits-row{max-width:1100px;margin:0 auto 44px;
  display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:56px}
.benefits-row:last-child{margin-bottom:0}
.benefits-row.rev{direction:rtl}.benefits-row.rev>*{direction:ltr}
.ben-img img{width:100%;max-width:440px;height:auto;object-fit:contain;
  filter:drop-shadow(0 8px 24px rgba(212,168,67,.18)) drop-shadow(0 4px 12px rgba(0,0,0,.50));margin:0 auto}
.ben-text-tag{display:inline-block;background:var(--gold);color:var(--plum);
  font-size:.70rem;font-weight:900;text-transform:uppercase;letter-spacing:1.5px;
  padding:4px 12px;border-radius:var(--radius-pill);margin-bottom:12px}
.ben-text h3{font-family:'Jost',sans-serif;font-size:1.85rem;font-weight:900;
  color:var(--white);line-height:1.2;margin-bottom:14px}
.ben-text h3 span{color:var(--gold-xl)}
.ben-text p{font-size:1.03rem;line-height:1.85;color:rgba(255,255,255,.52);margin-bottom:14px}
.ben-check-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px}
.ben-check-list li{display:flex;align-items:flex-start;gap:10px;font-size:.93rem;
  color:rgba(255,255,255,.70);line-height:1.5}
.ben-check-list li::before{content:'✓';color:var(--gold-lgt);font-weight:900;flex-shrink:0;font-size:.93rem}

/* FEATURES — Icon pillars on gold-pale */
.feat-section{background:var(--gold-pale);padding:72px 48px}
.feat-inner{max-width:900px;margin:0 auto}
.feat-pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px}
.feat-pillar{background:var(--white);border-radius:var(--radius-xl);
  padding:28px 16px;text-align:center;
  border-bottom:4px solid var(--gold);
  box-shadow:var(--sh-sm);transition:box-shadow .3s,transform .3s}
.feat-pillar:hover{box-shadow:var(--sh-gb);transform:translateY(-4px)}
.feat-pillar-icon{font-size:2.2rem;display:block;margin-bottom:12px}
.feat-pillar-title{font-family:'Jost',sans-serif;font-size:.90rem;font-weight:800;
  color:var(--plum);margin-bottom:6px;line-height:1.3}
.feat-pillar-desc{font-size:.78rem;line-height:1.58;color:var(--muted)}
/* wide spec row */
.feat-spec-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.feat-spec{background:var(--white);border-radius:var(--radius-lg);
  padding:18px 20px;display:flex;align-items:center;gap:14px;
  border-left:4px solid var(--plum);box-shadow:var(--sh-sm)}
.feat-spec-icon{font-size:1.4rem;flex-shrink:0}
.feat-spec-body{}
.feat-spec-title{font-family:'Jost',sans-serif;font-size:.88rem;font-weight:800;color:var(--plum);margin-bottom:2px}
.feat-spec-val{font-size:.80rem;color:var(--muted)}

/* BENEFITS IMG */
.ben-img-full{background:var(--ivory-dk);padding:52px 48px;text-align:center;
  border-top:2px solid var(--ivory-mid);border-bottom:2px solid var(--ivory-mid)}
.ben-img-full img{max-width:900px;width:100%;height:auto;margin:0 auto;
  border-radius:var(--radius-xl);box-shadow:var(--sh-pb);object-fit:contain}

/* REVIEWS — 2-col magazine style */
.reviews-section{background:var(--plum);padding:72px 48px}
.reviews-top{max-width:1100px;margin:0 auto 36px;text-align:center}
.reviews-top img{max-width:800px;width:100%;height:auto;margin:0 auto;
  border-radius:var(--radius-xl);box-shadow:0 8px 40px rgba(0,0,0,.50)}
.reviews-grid{max-width:1100px;margin:0 auto;display:grid;
  grid-template-columns:1fr 1fr;gap:22px}
.rv-card{background:rgba(255,255,255,.06);border:1px solid rgba(212,168,67,.16);
  border-radius:var(--radius-xl);padding:32px;
  position:relative;overflow:hidden;transition:background .3s,transform .3s}
.rv-card::before{content:'\201C';position:absolute;top:-10px;right:18px;
  font-family:Georgia,serif;font-size:8rem;color:var(--gold);opacity:.08;line-height:1}
.rv-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold-dk),var(--gold-xl))}
.rv-card:hover{background:rgba(255,255,255,.10);transform:translateY(-3px)}
.rv-stars{display:flex;gap:3px;margin-bottom:14px}
.rv-s{width:18px;height:18px;border-radius:3px;background:var(--gold);
  display:flex;align-items:center;justify-content:center;font-size:.70rem;color:var(--plum)}
.rv-quote{font-family:'Jost',sans-serif;font-size:1rem;font-weight:700;
  color:var(--white);font-style:italic;line-height:1.45;margin-bottom:12px;
  border-left:3px solid var(--gold);padding-left:14px}
.rv-text{font-size:.88rem;line-height:1.70;color:rgba(255,255,255,.50);
  margin-bottom:18px;font-style:italic}
.rv-footer{display:flex;align-items:center;gap:12px;
  padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}
.rv-photo{width:48px;height:48px;border-radius:50%;object-fit:cover;
  flex-shrink:0;border:2px solid var(--gold)}
.rv-name{font-family:'Jost',sans-serif;font-size:.86rem;font-weight:800;
  color:var(--white);margin-bottom:2px}
.rv-verified{font-size:.72rem;font-weight:700;color:var(--gold-lgt)}
/* 3rd review — full width */
.rv-card.wide{grid-column:1/-1}

/* GUARANTEE — Gold band with plum card (opposite of V1 light card) */
.guarantee-section{background:var(--gold);padding:72px 48px}
.guarantee-inner{max-width:1000px;margin:0 auto}
.guarantee-card{background:var(--plum);border-radius:var(--radius-xl);overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;box-shadow:var(--sh-gb)}
.guar-left{padding:44px 48px;display:flex;flex-direction:column;justify-content:center;gap:16px}
.guar-left h3{font-family:'Jost',sans-serif;font-size:1.85rem;font-weight:900;
  color:var(--white);line-height:1.2;margin-bottom:0}
.guar-left h3 span{color:var(--gold-xl)}
.guar-left p{font-size:1.03rem;line-height:1.85;color:rgba(255,255,255,.55);margin-bottom:0}
.guar-right{background:rgba(255,255,255,.06);padding:44px 40px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;
  border-left:2px solid rgba(212,168,67,.20)}
.guar-img{max-width:180px;width:100%;height:auto;object-fit:contain;margin:0 auto}
.guar-badge{background:var(--gold);color:var(--plum);border-radius:var(--radius-xl);
  padding:18px 20px;text-align:center;box-shadow:var(--sh-g);width:100%}
.gbt{font-family:'Jost',sans-serif;font-size:1rem;font-weight:900;margin-bottom:4px}
.gbs{font-size:.82rem;color:rgba(46,23,96,.75)}

/* FAQ */
.faq-section{background:var(--ivory);padding:72px 48px}
.faq-list{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-item{background:var(--white);border:1.5px solid var(--silver-lgt);
  border-radius:var(--radius-lg);overflow:hidden;
  border-bottom:3px solid transparent;transition:border-color .25s}
.faq-item.open{border-bottom-color:var(--gold)}
.faq-question{width:100%;background:none;border:none;text-align:left;padding:18px 22px;
  font-family:'Jost',sans-serif;font-size:.98rem;font-weight:700;color:var(--plum);
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  gap:14px;transition:background .2s;line-height:1.4}
.faq-question:hover{background:var(--gold-xp)}
.faq-arrow{font-size:1.1rem;transition:transform .3s;color:var(--gold-dk);flex-shrink:0;font-weight:700}
.faq-answer{display:none;padding:0 22px 18px;font-size:.96rem;line-height:1.80;
  color:var(--muted);border-top:1px solid var(--silver-lgt)}
.faq-item.open .faq-answer{display:block}
.faq-item.open .faq-arrow{transform:rotate(180deg)}

/* CTA FINAL */
.cta-final{background:linear-gradient(135deg,var(--plum) 0%,var(--plum-mid) 55%,var(--plum-lgt) 100%);
  padding:80px 48px;text-align:center;position:relative;overflow:hidden;border-top:4px solid var(--gold)}
.cta-final::before{content:'';position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:700px;height:200px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(212,168,67,.20) 0%,transparent 65%);pointer-events:none}
.cta-final h2{font-family:'Jost',sans-serif;font-size:2.6rem;font-weight:900;
  color:var(--white);margin-bottom:14px;line-height:1.2;position:relative;z-index:1}
.cta-final h2 .hl-g{color:var(--gold-xl)}
.cta-sub{font-size:1rem;color:rgba(255,255,255,.42);margin:0 auto 36px;
  max-width:700px;position:relative;z-index:1}
.cta-img{max-width:260px;margin:0 auto 32px;position:relative;z-index:1}
.cta-img a img{width:100%;height:auto;object-fit:contain;
  filter:drop-shadow(0 0 40px rgba(212,168,67,.28)) drop-shadow(0 14px 40px rgba(0,0,0,.80));
  transition:transform .4s}
.cta-img a:hover img{transform:scale(1.05) translateY(-8px)}
.cta-btns{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;position:relative;z-index:1}
.cta-note{font-size:.80rem;color:rgba(255,255,255,.28);margin-top:14px;position:relative;z-index:1}

/* FOOTER */
footer{background:var(--plum);border-top:2px solid rgba(212,168,67,.25)}
.footer-main{max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr;
  padding:44px 48px;border-bottom:1px solid rgba(255,255,255,.07)}
.fb-brand{padding-right:44px;border-right:1px solid rgba(255,255,255,.08)}
.fb-logo{font-family:'Jost',sans-serif;font-size:1.3rem;font-weight:900;
  color:var(--white);display:block;margin-bottom:8px;
  letter-spacing:.3px;text-transform:uppercase;text-decoration:none}
.fb-logo span{color:var(--gold-xl)}
.fb-tagline{font-size:.82rem;color:rgba(255,255,255,.28);line-height:1.70;margin-bottom:14px}
.fb-pills{display:flex;flex-wrap:wrap;gap:6px}
.fbp{background:rgba(212,168,67,.14);border:1px solid rgba(212,168,67,.24);
  color:var(--gold-xl);font-size:.70rem;font-weight:800;padding:3px 10px;border-radius:var(--radius-pill)}
.fb-nav{padding:0 24px}
.fb-nav h5{font-family:'Jost',sans-serif;font-size:.70rem;font-weight:800;
  text-transform:uppercase;letter-spacing:2px;color:var(--gold-lgt);
  margin-bottom:12px;padding-bottom:7px;border-bottom:1px solid rgba(212,168,67,.20)}
.fb-nav ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:9px}
.fb-nav ul li a{color:rgba(255,255,255,.28);font-size:.88rem;font-weight:500;
  transition:color .2s;display:flex;align-items:center;gap:5px}
.fb-nav ul li a::before{content:'›';color:var(--gold-lgt);font-size:.9rem;font-weight:700}
.fb-nav ul li a:hover{color:var(--white)}
.footer-legal{max-width:1200px;margin:0 auto;padding:14px 48px 20px;text-align:center}
.footer-legal p{font-size:.78rem;color:rgba(255,255,255,.20);line-height:1.72;margin-bottom:6px}
.footer-legal a{color:rgba(255,255,255,.28)}
.footer-legal a:hover{color:var(--gold-xl)}
.footer-copy{font-size:.78rem;color:rgba(255,255,255,.16);margin-top:8px;
  padding-top:8px;border-top:1px solid rgba(255,255,255,.07)}

/* SCROLL TOP */
#scrollTop{position:fixed;bottom:28px;right:20px;z-index:999;display:none;
  width:46px;height:46px;background:var(--gold);color:var(--plum);
  border-radius:50%;border:none;font-size:1.3rem;font-weight:900;
  cursor:pointer;box-shadow:var(--sh-g);align-items:center;justify-content:center}

/* ANIMATIONS */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.fade-left{opacity:0;transform:translateX(-28px);transition:opacity .65s ease,transform .65s ease}
.fade-right{opacity:0;transform:translateX(28px);transition:opacity .65s ease,transform .65s ease}
.scale-in{opacity:0;transform:scale(.95);transition:opacity .65s ease,transform .65s ease}
.fade-up.visible,.fade-left.visible,.fade-right.visible,.scale-in.visible{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero-h1{font-size:2.6rem}
  .feat-pillars{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;min-height:auto;padding:48px 24px 80px;text-align:center}
  .hero-img-col{order:-1}.hero-h1{font-size:2.2rem}
  .hero-pills,.hero-ctas{justify-content:center}.hero-desc{margin:0 auto}
  .hero-eyebrow{justify-content:center;width:auto}
  .about-inner{grid-template-columns:1fr}.about-img{order:-1;text-align:center}
  .hiw-timeline{grid-template-columns:1fr}.hiw-timeline::before{display:none}
  .benefits-row,.benefits-row.rev{grid-template-columns:1fr;direction:ltr}
  .ben-img{text-align:center}
  .feat-pillars{grid-template-columns:repeat(2,1fr)}
  .feat-spec-row{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr}.rv-card.wide{grid-column:auto}
  .guarantee-card{grid-template-columns:1fr}.guar-right{border-left:none;border-top:2px solid rgba(212,168,67,.20)}
  .stat-strip-inner{flex-direction:column;gap:8px}
  .ss-item{border-right:none;border-bottom:1px solid rgba(46,23,96,.10);padding:8px 0;width:100%;justify-content:center}
  .ss-item:last-child{border-bottom:none}
  .footer-main{grid-template-columns:1fr 1fr}
  .fb-brand{grid-column:1/-1;border-right:none;border-bottom:1px solid rgba(255,255,255,.08);padding-right:0;padding-bottom:20px;margin-bottom:8px}
}
@media(max-width:640px){
  nav{padding:0 16px}.nav-links{display:none}.hamburger{display:flex}
  .hero-h1{font-size:2rem}
  .sec-band{padding:36px 20px 30px}.sec-band h2{font-size:1.65rem}
  .feat-pillars{grid-template-columns:1fr 1fr}
  .feat-spec-row{grid-template-columns:1fr}
  .about-section,.hiw-section,.benefits-section,.feat-section,.reviews-section,
  .guarantee-section,.faq-section{padding:44px 20px}
  .order-img-section,.payment-section,.ben-img-full{padding:34px 20px}
  .cta-final{padding:56px 20px}.cta-final h2{font-size:1.85rem}
  .footer-main,.footer-legal{padding:28px 20px}.fb-nav{padding:0}.footer-main{grid-template-columns:1fr}
  .guar-left{padding:28px 24px}.guar-right{padding:28px 24px}
}