/* ============================================================
   Magic Wand's — styles.css
   Port of ui_kits/website/kit.css + mobile menu
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--midnight);color:var(--cream);font-family:var(--font-body);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{max-width:100%;display:block;}
button{font:inherit;cursor:pointer;}
::selection{background:var(--gold);color:var(--midnight);}

/* ----- primitives ----- */
.container{max-width:1200px;margin:0 auto;padding:0 24px;}
.display{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;letter-spacing:-0.02em;line-height:0.98;color:var(--cream);text-wrap:balance;}
.accent{font-family:var(--font-accent);font-weight:400;color:var(--gold);font-style:normal;letter-spacing:-0.01em;}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;padding:10px 20px;border-radius:999px;border:1px solid var(--midnight-edge);background:rgba(245,200,66,0.06);color:var(--cream);}
.eyebrow .sp{color:var(--gold);font-size:14px;line-height:1;}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--font-body);font-weight:600;font-size:17px;padding:18px 32px;border-radius:20px;border:none;text-decoration:none;transition:transform 200ms var(--ease-chunky),box-shadow 200ms ease,background 200ms ease;white-space:nowrap;cursor:pointer;}
.btn-gold{background:var(--gold);color:var(--midnight);box-shadow:var(--shadow-gold);}
.btn-gold:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow);color:var(--midnight);}
.btn-gold:active{transform:scale(0.98);background:var(--gold-deep);}
.btn-outline{background:transparent;color:var(--cream);border:2px solid var(--cream);padding:16px 30px;}
.btn-outline:hover{background:rgba(248,241,216,0.08);color:var(--cream);}

/* ----- stars + reveal ----- */
.stars{position:absolute;inset:0;pointer-events:none;background-image:
  radial-gradient(1.5px 1.5px at 12% 14%, #f5c842 100%, transparent),
  radial-gradient(1px 1px at 28% 62%, #ffe28a 100%, transparent),
  radial-gradient(2px 2px at 47% 24%, #f8f1d8 100%, transparent),
  radial-gradient(1.2px 1.2px at 65% 78%, #f5c842 100%, transparent),
  radial-gradient(1px 1px at 82% 14%, #ffe28a 100%, transparent),
  radial-gradient(1.4px 1.4px at 92% 56%, #f8f1d8 100%, transparent),
  radial-gradient(1px 1px at 18% 86%, #cdc3a4 100%, transparent),
  radial-gradient(1.6px 1.6px at 38% 92%, #f5c842 100%, transparent),
  radial-gradient(1px 1px at 55% 48%, #ffe28a 100%, transparent),
  radial-gradient(1.2px 1.2px at 72% 38%, #f8f1d8 100%, transparent);opacity:0.7;}
.stars-faint{opacity:0.35;}
.stars-dense{position:absolute;inset:0;pointer-events:none;background-image:
  radial-gradient(1.5px 1.5px at 4% 7%, #f5c842 100%, transparent),
  radial-gradient(1px 1px at 9% 38%, #ffe28a 100%, transparent),
  radial-gradient(1.8px 1.8px at 14% 68%, #f8f1d8 100%, transparent),
  radial-gradient(1px 1px at 19% 22%, #f5c842 100%, transparent),
  radial-gradient(1.3px 1.3px at 24% 84%, #ffe28a 100%, transparent),
  radial-gradient(2px 2px at 29% 51%, #f8f1d8 100%, transparent),
  radial-gradient(1px 1px at 33% 13%, #f5c842 100%, transparent),
  radial-gradient(1.5px 1.5px at 38% 77%, #ffe28a 100%, transparent),
  radial-gradient(1px 1px at 43% 44%, #cdc3a4 100%, transparent),
  radial-gradient(1.8px 1.8px at 47% 91%, #f5c842 100%, transparent),
  radial-gradient(1px 1px at 52% 29%, #ffe28a 100%, transparent),
  radial-gradient(1.4px 1.4px at 57% 62%, #f8f1d8 100%, transparent),
  radial-gradient(1px 1px at 62% 18%, #f5c842 100%, transparent),
  radial-gradient(2px 2px at 66% 82%, #ffe28a 100%, transparent),
  radial-gradient(1px 1px at 71% 47%, #f8f1d8 100%, transparent),
  radial-gradient(1.6px 1.6px at 75% 9%, #f5c842 100%, transparent),
  radial-gradient(1px 1px at 80% 71%, #ffe28a 100%, transparent),
  radial-gradient(1.3px 1.3px at 85% 35%, #f8f1d8 100%, transparent),
  radial-gradient(1px 1px at 89% 57%, #f5c842 100%, transparent),
  radial-gradient(1.8px 1.8px at 93% 24%, #ffe28a 100%, transparent),
  radial-gradient(1px 1px at 97% 78%, #f8f1d8 100%, transparent),
  radial-gradient(1.2px 1.2px at 7% 55%, #f5c842 100%, transparent),
  radial-gradient(1px 1px at 17% 4%, #ffe28a 100%, transparent),
  radial-gradient(1.5px 1.5px at 36% 33%, #f8f1d8 100%, transparent),
  radial-gradient(1px 1px at 54% 96%, #f5c842 100%, transparent),
  radial-gradient(2px 2px at 63% 67%, #ffe28a 100%, transparent),
  radial-gradient(1px 1px at 78% 88%, #cdc3a4 100%, transparent),
  radial-gradient(1.4px 1.4px at 91% 42%, #f8f1d8 100%, transparent);opacity:0.85;}
@keyframes twinkle{0%,100%{opacity:.3;transform:scale(0.75);}50%{opacity:1;transform:scale(1.1);}}
.twinkle{position:absolute;width:18px;height:18px;animation:twinkle 4s ease-in-out infinite;}

.reveal{opacity:0;transform:translateY(24px);transition:opacity 600ms var(--ease-out),transform 600ms var(--ease-out);}
.reveal.is-visible{opacity:1;transform:none;}

/* ----- nav ----- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 24px;transition:padding 200ms var(--ease-out),background 200ms ease,backdrop-filter 200ms ease,box-shadow 200ms ease;}
.nav-inner{max-width:1440px;margin:0 auto;display:flex;align-items:center;gap:24px;}
.nav.is-condensed{background:rgba(26,13,46,0.7);backdrop-filter:blur(20px) saturate(140%);padding:10px 24px;box-shadow:0 1px 0 0 var(--midnight-edge);}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:22px;letter-spacing:-0.02em;color:var(--cream);text-decoration:none;line-height:1;}
.logo em{font-family:var(--font-accent);font-style:normal;font-weight:400;color:var(--gold);}
.nav-links{display:flex;align-items:center;gap:8px;list-style:none;margin:0 0 0 auto;padding:0;}
.nav-links a{color:var(--cream);font-size:15px;font-weight:500;padding:8px 14px;border-radius:999px;text-decoration:none;position:relative;}
.nav-links a::after{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;background:var(--gold);border-radius:2px;transform-origin:left;transform:scaleX(0);transition:transform 250ms var(--ease-out);}
.nav-links a:hover{color:var(--gold-glow);}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-cta{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:var(--midnight);padding:11px 22px;border-radius:999px;font-weight:600;font-size:15px;transition:transform 200ms var(--ease-chunky),box-shadow 200ms ease;box-shadow:var(--shadow-gold);text-decoration:none;}
.nav-cta:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow);color:var(--midnight);}

/* ----- mobile menu ----- */
.menu-btn{display:none;background:none;border:none;color:var(--cream);padding:8px;border-radius:12px;cursor:pointer;}
@media (max-width:880px){
  .nav-links,.nav-cta{display:none;}
  .menu-btn{display:flex;}
  .nav.is-open .nav-links{display:flex;flex-direction:column;align-items:stretch;gap:4px;position:absolute;top:100%;left:16px;right:16px;background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:28px;padding:12px;margin-top:8px;box-shadow:var(--shadow-card);}
  .nav.is-open .nav-links a{padding:14px 18px;border-radius:20px;}
  .nav.is-open .nav-cta{display:inline-flex;margin-top:6px;justify-content:center;}
}

/* ----- hero ----- */
.hero{position:relative;overflow:hidden;height:100vh;padding:140px 24px 80px;display:flex;align-items:center;}
.hero-grid{max-width:1440px;margin:0 auto;width:100%;display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;}
.hero-headline{font-size:clamp(56px,9vw,128px);margin:0 0 24px;}
.hero-sub{font-size:clamp(18px,2.2vw,22px);color:var(--cream-dim);margin:0 0 40px;max-width:560px;line-height:1.5;}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:56px;}
.hero-stats{display:flex;gap:14px;flex-wrap:wrap;}
.stat{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border-radius:999px;border:1px solid var(--midnight-edge);background:rgba(248,241,216,0.04);font-size:14px;font-weight:500;color:var(--cream);}
.stat svg{width:14px;height:14px;color:var(--gold);}
.hero-art{display:flex;justify-content:center;align-items:center;}
.hero-art svg.illo{width:100%;max-width:680px;filter:drop-shadow(0 24px 48px rgba(245,200,66,.15));}
@media (max-width:880px){
  .hero{padding:120px 20px 60px;height:auto;min-height:100vh;}
  .hero-grid{grid-template-columns:1fr;gap:40px;}
  .hero-art{order:-1;}
}

/* ----- section common ----- */
section{position:relative;padding:120px 24px;}
.section-head{max-width:760px;margin:0 auto 64px;text-align:center;}
.section-head .eyebrow{margin-bottom:24px;}
.section-head h2{font-size:clamp(40px,6vw,80px);margin:0 0 16px;}
.section-head .sub{font-size:19px;color:var(--cream-dim);margin:0;}
@media (max-width:760px){section{padding:80px 20px;}}

/* ----- services ----- */
#services{background:var(--midnight-deep);}
.services-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(6,1fr);gap:20px;}
.service-card{grid-column:span 2;}
.service-card:nth-child(4),.service-card:nth-child(5){grid-column:span 3;}
@media (max-width:980px){
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .service-card,.service-card:nth-child(4),.service-card:nth-child(5){grid-column:span 1;}
}
.service-card{background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:28px;padding:28px;position:relative;min-height:200px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--shadow-card);transition:transform 250ms var(--ease-out),box-shadow 250ms ease,border-color 250ms ease;}
.service-spark{position:absolute;top:22px;left:24px;width:30px;height:30px;}
.service-title{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:30px;line-height:1.05;letter-spacing:-0.02em;margin:48px 0 8px;color:var(--cream);}
.service-desc{font-size:15px;color:var(--cream-dim);margin:0;max-width:340px;}
.service-price{align-self:flex-end;background:var(--gold);color:var(--midnight);font-weight:700;font-size:20px;padding:11px 22px;border-radius:999px;margin-top:20px;}
.services-foot{max-width:1200px;margin:40px auto 0;text-align:center;font-size:14px;color:var(--cream-dim);}

/* ----- how it works ----- */
.steps{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
@media (max-width:880px){.steps{grid-template-columns:1fr;}}
.step{background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:28px;padding:36px 32px;position:relative;box-shadow:var(--shadow-card);}
.step-num{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:72px;line-height:1;color:var(--gold);margin-bottom:20px;letter-spacing:-0.03em;}
.step-illo{position:absolute;top:32px;right:32px;width:64px;height:64px;}
.step-title{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:26px;line-height:1.15;letter-spacing:-0.02em;margin:0 0 8px;color:var(--cream);}
.step-desc{font-size:16px;color:var(--cream-dim);margin:0;}

/* ----- before/after ----- */
#before-after{background:var(--midnight-deep);}
.ba-masonry{max-width:1440px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:100px;gap:12px;}
.ba-masonry .ba-pair{display:flex;flex-direction:column;}
.ba-masonry .ba-pair-imgs{flex:1;min-height:0;}
.ba-masonry .ba-slot{aspect-ratio:unset;height:100%;}
@media (max-width:760px){
  .ba-masonry{grid-template-columns:repeat(2,1fr);grid-auto-rows:80px;}
  .ba-masonry .ba-pair{grid-column:auto!important;grid-row:span 4!important;}
}
@media (max-width:480px){
  .ba-masonry{grid-template-columns:1fr;}
  .ba-masonry .ba-pair{grid-row:span 5!important;}
}
.ba-pair-imgs{display:grid;grid-template-columns:1fr 1fr;border-radius:24px;overflow:hidden;border:1px solid var(--midnight-edge);position:relative;box-shadow:var(--shadow-card);}
.ba-slot{aspect-ratio:3/4;background:linear-gradient(135deg,#2a1855 0%,#1a0d2e 100%);display:flex;align-items:center;justify-content:center;color:var(--cream-dim);font-size:13px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;position:relative;overflow:hidden;}
.ba-slot.after{background:linear-gradient(135deg,#3a2370 0%,#251544 100%);}
.ba-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.ba-slot .lbl{position:relative;z-index:1;background:rgba(26,13,46,.4);padding:8px 14px;border-radius:999px;backdrop-filter:blur(4px);}
.ba-divider{position:absolute;top:0;bottom:0;left:50%;width:3px;background:repeating-linear-gradient(to bottom,var(--gold) 0 6px,transparent 6px 12px);transform:translateX(-50%);z-index:2;}
.ba-divider::before,.ba-divider::after{content:"";position:absolute;left:50%;transform:translateX(-50%);width:12px;height:12px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px var(--midnight-deep);}
.ba-divider::before{top:-2px;}
.ba-divider::after{bottom:-2px;}
.ba-caption{text-align:center;margin-top:16px;font-size:15px;color:var(--cream-dim);}
.ba-caption strong{color:var(--cream);font-weight:600;}

/* ----- reviews ----- */
.reviews-grid{max-width:1200px;margin:0 auto;columns:3;column-gap:24px;}
@media (max-width:980px){.reviews-grid{columns:2;}}
@media (max-width:640px){.reviews-grid{columns:1;}}
.review{break-inside:avoid;background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:28px;padding:40px;margin:0 0 24px;box-shadow:var(--shadow-card);}
.review-stars{display:flex;gap:4px;margin-bottom:16px;}
.review-stars svg{width:20px;height:20px;color:var(--gold);}
.review-quote{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:22px;line-height:1.3;letter-spacing:-0.01em;margin:0 0 20px;color:var(--cream);}
.review-who{display:flex;align-items:center;gap:10px;font-size:15px;color:var(--cream-dim);}
.review-who .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);}
.review-who .name{color:var(--cream);font-weight:500;}
.reviews-foot{max-width:1200px;margin:40px auto 0;display:flex;justify-content:center;align-items:center;gap:10px;font-size:14px;color:var(--cream-dim);}
.reviews-foot a{display:inline-flex;align-items:center;gap:6px;color:var(--gold);}
.reviews-foot a:hover{color:var(--gold-glow);}

/* ----- contact ----- */
#contact{background:var(--midnight-deep);}
.contact-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative;z-index:1;}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;}}
.contact-card{background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:28px;padding:36px 28px;text-align:center;color:var(--cream);text-decoration:none;display:flex;flex-direction:column;align-items:center;gap:12px;min-height:240px;justify-content:center;transition:transform 250ms var(--ease-out),box-shadow 250ms ease,border-color 250ms ease;box-shadow:var(--shadow-card);}
.contact-card:hover{transform:translateY(-4px);border-color:rgba(245,200,66,0.3);color:var(--cream);}
.contact-icon{width:72px;height:72px;border-radius:50%;background:rgba(245,200,66,0.12);display:flex;align-items:center;justify-content:center;border:1px solid rgba(245,200,66,0.2);}
.contact-icon svg{width:36px;height:36px;color:var(--gold);}
.contact-label{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--cream-dim);font-weight:500;}
.contact-value{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:22px;letter-spacing:-0.01em;line-height:1.2;color:var(--cream);}
.area-note{max-width:680px;margin:48px auto 0;text-align:center;font-size:16px;color:var(--cream-dim);position:relative;z-index:1;}
.area-note strong{color:var(--cream);font-weight:500;}

/* ----- footer ----- */
.footer{background:var(--midnight-deep);border-top:1px solid var(--midnight-edge);padding:64px 24px 32px;}
.footer-grid{max-width:1440px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--midnight-edge);}
@media (max-width:760px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr;}}
.footer-mark{display:flex;align-items:center;gap:14px;margin-bottom:16px;}
.footer-mark svg{width:44px;height:44px;}
.footer-mark .word{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:28px;letter-spacing:-0.02em;color:var(--cream);}
.footer-mark .word em{font-family:var(--font-accent);font-style:normal;font-weight:400;color:var(--gold);}
.footer-tagline{font-size:14px;color:var(--cream-dim);line-height:1.6;max-width:280px;margin:0;}
.footer-col-label{display:block;font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}
.footer-nav,.footer-contact{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.footer-nav a,.footer-contact a{font-size:15px;color:var(--cream-dim);text-decoration:none;}
.footer-nav a:hover,.footer-contact a:hover{color:var(--gold);}
.footer-bottom{max-width:1440px;margin:28px auto 0;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--cream-dim);}
.footer-bottom a{color:var(--gold);text-decoration:none;}
.footer-bottom a:hover{color:var(--gold-glow);}

:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:6px;}

/* ----- active nav link ----- */
.nav-links a.active{color:var(--gold);}
.nav-links a.active::after{transform:scaleX(1);}

/* ----- page hero (inner pages) ----- */
.page-hero{position:relative;overflow:hidden;padding:180px 24px 96px;text-align:left;}
.page-hero-inner{max-width:1440px;margin:0 auto;width:100%;position:relative;}
.page-hero .eyebrow{margin-bottom:28px;}
.page-hero h1{font-size:clamp(48px,7vw,96px);margin:0 0 24px;}
.page-hero p{font-size:clamp(17px,2vw,20px);color:var(--cream-dim);max-width:580px;margin:0;}
@media (max-width:760px){.page-hero{padding:130px 20px 64px;}}

/* ----- about page ----- */
.about-body{font-size:18px;color:var(--cream-dim);line-height:1.8;margin:0 0 20px;}
.about-body:last-of-type{margin-bottom:0;}

/* intro split */
.about-split{max-width:1440px;margin:0 auto;display:grid;grid-template-columns:3fr 2fr;gap:80px;align-items:start;position:relative;z-index:1;}
@media (max-width:800px){.about-split{grid-template-columns:1fr;gap:48px;}}
.about-big-headline{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:clamp(36px,4.5vw,62px);letter-spacing:-0.025em;line-height:1.06;color:var(--cream);margin:0 0 40px;}

/* credentials card */
.about-card{background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:32px;padding:40px;position:sticky;top:108px;}
.about-card-header{display:flex;align-items:center;gap:12px;margin-bottom:36px;}
.about-card-header svg{width:32px;height:32px;}
.about-card-header span{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:20px;letter-spacing:-0.02em;color:var(--cream);}
.about-card-header em{font-family:var(--font-accent);font-style:normal;color:var(--gold);}
.about-card-ring{width:180px;height:180px;border-radius:50%;border:1.5px solid rgba(245,200,66,0.25);display:flex;align-items:center;justify-content:center;margin:0 auto 36px;position:relative;box-shadow:0 0 60px rgba(245,200,66,0.06);}
.about-card-ring::before{content:"";position:absolute;inset:12px;border-radius:50%;border:1px solid rgba(245,200,66,0.12);}
.about-card-ring svg.wand{width:72px;height:72px;}
.about-card-facts{display:flex;flex-direction:column;gap:14px;border-top:1px solid var(--midnight-edge);padding-top:28px;}
.about-card-fact{display:flex;align-items:center;gap:12px;font-size:15px;color:var(--cream-dim);line-height:1.4;}
.about-card-fact svg{width:15px;height:15px;color:var(--gold);flex-shrink:0;}
.about-card-fact strong{color:var(--cream);font-weight:600;}

/* pull quote */
.about-quote{background:var(--midnight-deep);padding:100px 24px;position:relative;overflow:hidden;}
.about-quote-inner{max-width:960px;margin:0 auto;text-align:center;position:relative;}
.about-quote-mark{font-family:var(--font-accent);font-size:140px;line-height:0.6;color:var(--gold);opacity:0.25;display:block;margin-bottom:16px;user-select:none;}
.about-quote-text{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:clamp(26px,4vw,52px);letter-spacing:-0.02em;line-height:1.15;color:var(--cream);margin:0 0 36px;}
.about-quote-attr{display:inline-flex;align-items:center;gap:10px;font-size:13px;letter-spacing:0.18em;text-transform:uppercase;color:var(--cream-dim);}
.about-quote-attr::before{content:"";width:24px;height:1px;background:var(--gold);opacity:0.6;}

/* pillars */
.about-pillars-grid{max-width:1440px;margin:0 auto;display:flex;flex-direction:column;gap:12px;position:relative;z-index:1;}
.about-pillar{background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:24px;display:grid;grid-template-columns:148px 108px 1fr;align-items:stretch;overflow:hidden;transition:border-color 250ms ease;box-shadow:var(--shadow-card);}
.about-pillar-num-cell{display:flex;align-items:center;justify-content:center;border-right:1px solid var(--midnight-edge);padding:48px 24px;}
.about-pillar-num{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:60px;line-height:1;color:var(--gold);letter-spacing:-0.04em;}
.about-pillar-icon-cell{display:flex;align-items:center;justify-content:center;border-right:1px solid var(--midnight-edge);padding:48px 24px;}
.about-pillar-icon{width:54px;height:54px;border-radius:16px;background:rgba(245,200,66,0.08);border:1px solid rgba(245,200,66,0.18);display:flex;align-items:center;justify-content:center;}
.about-pillar-icon svg{width:27px;height:27px;color:var(--gold);}
.about-pillar-content{padding:48px 56px;display:flex;flex-direction:column;justify-content:center;}
.about-pillar h3{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:clamp(26px,2.8vw,40px);letter-spacing:-0.025em;line-height:1.05;margin:0 0 14px;color:var(--cream);}
.about-pillar p{font-size:16px;color:var(--cream-dim);margin:0;line-height:1.75;max-width:680px;}
@media (max-width:760px){
  .about-pillar{grid-template-columns:80px 1fr;}
  .about-pillar-icon-cell{display:none;}
  .about-pillar-num-cell{padding:32px 16px;}
  .about-pillar-num{font-size:40px;}
  .about-pillar-content{padding:32px 28px;}
}

/* ----- page CTA strip ----- */
.cta-strip{background:var(--midnight-deep);border-top:1px solid var(--midnight-edge);padding:80px 24px;text-align:center;}
.cta-strip h2{font-size:clamp(36px,5vw,64px);margin:0 0 20px;}
.cta-strip p{font-size:18px;color:var(--cream-dim);margin:0 0 36px;}
.cta-strip .btn-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;}

/* ----- homepage sections ----- */
.hp-section-inner{max-width:1440px;margin:0 auto;position:relative;z-index:1;}
.hp-section-cta{text-align:center;margin-top:48px;}

.hp-services{background:var(--midnight-deep);padding:120px 24px;position:relative;overflow:hidden;}
.hp-price-list{max-width:760px;margin:48px auto 0;}
.hp-price-row{display:flex;align-items:center;justify-content:space-between;padding:22px 0;border-bottom:1px solid var(--midnight-edge);}
.hp-price-row:first-child{border-top:1px solid var(--midnight-edge);}
.hp-price-name{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:clamp(20px,2.5vw,28px);letter-spacing:-0.02em;color:var(--cream);}
.hp-price-amount{background:var(--gold);color:var(--midnight);font-weight:700;font-size:17px;padding:9px 22px;border-radius:14px;flex-shrink:0;}

.hp-gallery{padding:120px 24px;position:relative;overflow:hidden;}
.hp-gallery-row{max-width:1440px;margin:48px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
@media (max-width:760px){.hp-gallery-row{grid-template-columns:1fr;}}

.hp-about{background:var(--midnight-deep);padding:120px 24px;position:relative;overflow:hidden;}
.hp-about-inner{max-width:1440px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1;}
@media (max-width:800px){.hp-about-inner{grid-template-columns:1fr;gap:48px;}}
.hp-about-left .eyebrow{margin-bottom:24px;}
.hp-about-left h2{font-size:clamp(40px,6vw,80px);margin:0 0 24px;}
.hp-about-body{font-size:18px;color:var(--cream-dim);line-height:1.7;margin:0 0 40px;}
.hp-about-facts{display:flex;flex-direction:column;gap:16px;}
.hp-about-fact{background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:20px;padding:24px 28px;display:flex;align-items:center;gap:20px;box-shadow:var(--shadow-card);}
.hp-about-fact-icon{width:48px;height:48px;border-radius:14px;background:rgba(245,200,66,0.08);border:1px solid rgba(245,200,66,0.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.hp-about-fact-icon svg{width:22px;height:22px;color:var(--gold);}
.hp-about-fact-text strong{display:block;font-size:17px;font-weight:600;color:var(--cream);margin-bottom:2px;}
.hp-about-fact-text span{font-size:14px;color:var(--cream-dim);}

/* ----- services v2 ----- */
.svc-group{max-width:1440px;margin:0 auto 96px;}
.svc-group:last-child{margin-bottom:0;}
.svc-group-head{margin-bottom:56px;}
.svc-group-head .eyebrow{margin-bottom:24px;}
.svc-group-head h2{font-size:clamp(40px,5vw,64px);margin:0;}

.svc-ovens-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
@media (max-width:800px){.svc-ovens-grid{grid-template-columns:1fr;}}

.svc-oven-card{background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:32px;padding:48px;display:flex;flex-direction:column;box-shadow:var(--shadow-card);}
.svc-oven-top{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:28px;}
.svc-oven-eyebrow{font-size:12px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.svc-oven-name{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:clamp(30px,3vw,44px);letter-spacing:-0.025em;line-height:1.05;color:var(--gold);margin:0;}
.svc-oven-price-badge{background:var(--gold);color:var(--midnight);font-weight:800;font-size:24px;padding:14px 26px;border-radius:20px;white-space:nowrap;flex-shrink:0;}
.svc-oven-desc{font-size:17px;color:var(--cream-dim);line-height:1.65;margin:0 0 28px;}
.svc-oven-divider{height:1px;background:var(--midnight-edge);margin:0 0 28px;}
.svc-oven-list{list-style:none;padding:0;margin:0 0 36px;display:flex;flex-direction:column;gap:13px;}
.svc-oven-list li{display:flex;align-items:center;gap:14px;font-size:16px;color:var(--cream-dim);line-height:1.4;}
.svc-oven-list li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0;}
.svc-oven-foot{margin-top:auto;}
.svc-oven-time{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--cream-dim);}
.svc-oven-time svg{width:14px;height:14px;color:var(--gold);}

.svc-addons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media (max-width:880px){.svc-addons-grid{grid-template-columns:1fr;}}
.svc-addon-card{background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:24px;padding:36px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-card);}
.svc-addon-icon{width:52px;height:52px;border-radius:16px;background:rgba(245,200,66,0.07);border:1px solid rgba(245,200,66,0.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:4px;}
.svc-addon-icon svg{width:24px;height:24px;color:var(--gold);}
.svc-addon-top{display:flex;align-items:baseline;justify-content:space-between;gap:16px;}
.svc-addon-name{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:26px;letter-spacing:-0.02em;line-height:1.1;color:var(--cream);margin:0;}
.svc-addon-price{background:rgba(245,200,66,0.1);color:var(--gold);font-weight:700;font-size:20px;padding:8px 18px;border-radius:12px;white-space:nowrap;border:1px solid rgba(245,200,66,0.2);}
.svc-addon-desc{font-size:15px;color:var(--cream-dim);margin:0;line-height:1.6;}

/* always included */
.includes-section{position:relative;overflow:hidden;background:var(--midnight-deep);padding:120px 24px;}
.includes-inner{max-width:1440px;margin:0 auto;position:relative;z-index:1;}
.includes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:64px;}
@media (max-width:880px){.includes-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:540px){.includes-grid{grid-template-columns:1fr;}}
.include-item{background:var(--midnight-lift);border:1px solid var(--midnight-edge);border-radius:24px;padding:32px;display:flex;gap:20px;align-items:flex-start;box-shadow:var(--shadow-card);}
.include-icon{width:48px;height:48px;border-radius:14px;background:rgba(245,200,66,0.08);border:1px solid rgba(245,200,66,0.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.include-icon svg{width:22px;height:22px;color:var(--gold);}
.include-text h3{font-family:var(--font-display);font-weight:900;font-variation-settings:"SOFT" 100,"opsz" 144;font-size:20px;letter-spacing:-0.02em;line-height:1.1;color:var(--cream);margin:0 0 8px;}
.include-text p{font-size:14px;color:var(--cream-dim);margin:0;line-height:1.55;}

/* ----- reduced motion ----- */
@media (prefers-reduced-motion: reduce){
  .twinkle-spark{animation:none !important;opacity:0.7;}
  .twinkle{animation:none !important;opacity:0.7;}
  .reveal{opacity:1;transform:none;transition:none;}
}
