/* =============================================================================
   Angel App Studio — main stylesheet
   Edit colors, type, and layout here. Per-section blocks are labelled below.
   Breakpoints used:
     ≤960px  tablet
     ≤640px  phone
     ≤480px  small phone
   ============================================================================= */


/* ============================================================
   Tokens
   ============================================================ */
:root{
  --bg:#EFECE8;            /* warm cream */
  --bg-2:#E8E4DE;
  --ink:#1A1A1A;
  --ink-soft:#5A5854;
  --ink-mute:#8B8782;
  --accent:#EBA8F2;        /* lilac-pink pill */
  --accent-ink:#1A1A1A;
  --line:#1A1A1A;
  --card:#FFFFFF;
  --serif:"EB Garamond","Apple Garamond",Garamond,"Times New Roman",serif;
  --sans:Arial,Helvetica,sans-serif;
  --hand:"Caveat",cursive;
  --radius-sm:18px;
  --radius-md:24px;
  --radius-lg:32px;
}


/* ============================================================
   Globals & utilities
   ============================================================ */
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased}
html,body{overflow-x:hidden;max-width:100vw}
img{max-width:100%;display:block}
a{color:inherit}
button{font-family:inherit}
.serif{font-family:var(--serif);font-weight:500;letter-spacing:-0.01em}
.hand{font-family:var(--hand);font-weight:600}
.it{font-style:italic}

section{padding:120px 0;position:relative}
section + section{padding-top:0}

.container{max-width:1240px;margin:0 auto;padding:0 32px}
.eyebrow{font-family:var(--sans);font-size:13px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-mute);font-weight:600}

.section-head{max-width:880px;margin:0 auto 56px;text-align:center}
.section-head h2{margin:14px 0 0;font-family:var(--serif);font-weight:500;font-size:clamp(40px,5.5vw,72px);line-height:1.04;letter-spacing:-0.02em;text-wrap:balance}
.section-head p{margin:20px auto 0;max-width:640px;color:var(--ink-soft);font-size:17px;line-height:1.55}

.scribble{display:block;margin:0 auto;color:var(--ink)}
.marquee-rule{height:1px;background:var(--ink);opacity:.12;width:100%}
.asterisk-line{font-family:var(--serif);font-style:italic;color:var(--ink-soft);font-size:15px;letter-spacing:-0.005em;margin-top:18px}

.pill-btn{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--accent);color:var(--accent-ink);
  border:1.5px solid var(--ink);
  border-radius:999px;
  padding:14px 28px;
  font-weight:700;letter-spacing:0.14em;text-transform:uppercase;font-size:13px;
  cursor:pointer;text-decoration:none;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  box-shadow:0 1px 0 var(--ink);
}
.pill-btn:hover{transform:translateY(-1px);box-shadow:0 3px 0 var(--ink)}
.pill-btn:active{transform:translateY(1px);box-shadow:0 0 0 var(--ink)}
.pill-btn.lg{padding:18px 40px;font-size:14px}
.ghost-btn{
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;color:var(--ink);border:1.5px solid var(--ink);
  border-radius:999px;padding:14px 28px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;font-size:13px;cursor:pointer;
}

@media (max-width:960px){
  section{padding:96px 0}
  .container{padding:0 24px}
  .section-head{margin-bottom:40px}
  .section-head p{font-size:16px}
}
@media (max-width:640px){
  section{padding:80px 0}
  .container{padding:0 20px}
  .pill-btn{padding:12px 22px;font-size:12px;letter-spacing:0.12em}
  .pill-btn.lg{padding:14px 28px;font-size:13px}
  .asterisk-line{font-size:14px}
}
@media (max-width:480px){
  section{padding:64px 0}
  .container{padding:0 16px}
  .pill-btn{padding:11px 18px;font-size:11px}
  .pill-btn.lg{padding:13px 24px;font-size:12px}
  .eyebrow{font-size:11px;letter-spacing:0.16em}
  .section-head{margin-bottom:32px}
  .section-head p{font-size:15px;margin-top:14px}
}


/* ============================================================
   Nav  — components/sections/nav.jsx
   ============================================================ */
.nav{position:sticky;top:0;z-index:50;background:transparent;border-bottom:1px solid transparent;transition:background .2s ease, border-color .2s ease, backdrop-filter .2s ease}
.nav.is-active{background:rgba(239,236,232,0.92);backdrop-filter:blur(10px);border-bottom-color:rgba(0,0,0,0.06)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding-top:18px;padding-bottom:18px}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.nav-logo-mark{
  width:38px;height:38px;border-radius:99px;border:1.5px solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  background:var(--bg);position:relative;flex-shrink:0;
}
.nav-logo-mark span{font-family:var(--serif);font-style:italic;font-size:22px;font-weight:500;line-height:1}
.nav-logo-img{height:36px;width:auto;flex-shrink:0;display:block}
.nav-logo-text{display:none}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-link{font-size:12px;letter-spacing:0.16em;text-transform:uppercase;font-weight:700;text-decoration:none;color:var(--ink)}
.nav-cta{padding:12px 22px;font-size:12px}
.nav-cta-sm{padding:10px 18px;font-size:11px}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-toggle{
  width:42px;height:42px;border-radius:99px;border:1.5px solid var(--ink);
  background:transparent;color:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;padding:0;flex-shrink:0;
}
.nav-toggle.is-open{background:var(--ink);color:var(--bg)}
.nav-drawer{padding-bottom:20px}
.nav-drawer-list{display:flex;flex-direction:column;gap:4px;padding-top:8px;border-top:1px solid rgba(0,0,0,0.08)}
.nav-drawer-link{padding:14px 4px;border-bottom:1px solid rgba(0,0,0,0.06);font-size:13px;letter-spacing:0.16em;text-transform:uppercase;font-weight:700;text-decoration:none;color:var(--ink)}
.nav-drawer-cta{margin-top:14px;align-self:flex-start}

@media (max-width:960px){
  .nav-inner{padding-top:16px;padding-bottom:16px}
}
@media (max-width:640px){
  .nav-inner{padding-top:14px;padding-bottom:14px}
  .nav-logo-mark{width:34px;height:34px}
  .nav-logo-mark span{font-size:19px}
  .nav-logo-img{height:24px;width:auto}
  .nav-logo-text{font-size:17px}
}


/* ============================================================
   Hero  — components/sections/hero.jsx
   ============================================================ */
.hero{padding-top:48px;padding-bottom:0;overflow:visible}
.hero-inner{text-align:center;position:relative}
.hero-eyebrow{margin-top:36px}
.hero-title{
  margin:18px auto 0;
  font-size:clamp(48px,7.6vw,104px);
  line-height:1.0;letter-spacing:-0.025em;
  max-width:900px;text-wrap:pretty;font-weight:500;
}
.hero-sub{
  margin:24px auto 0;max-width:560px;
  color:var(--ink-soft);font-size:17px;line-height:1.55;
}
.hero-sparkle{color:#E2B93B}
.hero-cta-row{
  margin-top:34px;display:flex;align-items:center;justify-content:center;
  gap:18px;flex-wrap:wrap;
}
.hero-cta-arrow{color:var(--ink-mute)}
.hero-phones{
  margin-top:36px;
  display:flex;align-items:flex-end;justify-content:center;
  gap:0px;position:relative;flex-wrap:nowrap;
  overflow-x:visible;overflow-y:visible;
  padding-bottom:8px;
}
.hero-phone{position:relative;flex-shrink:0}
.hero-annotation{position:absolute;color:var(--ink-soft);opacity:.85}
.hero-annotation--left{top:-64px;left:18%}
.hero-annotation--right{top:-48px;right:14%}
.hero-annotation span{font-size:34px;display:inline-block}
.hero-annotation--right span{transform:rotate(-6deg)}

@media (max-width:960px){
  .hero-phones{gap:18px;margin-top:36px}
  .hero-phones::before,
  .hero-phones::after{
    content:'';position:absolute;top:-40px;bottom:-100px;width:22vw;
    pointer-events:none;z-index:10;
  }
  .hero-phones::before{left: calc(50% - 50vw);  background:linear-gradient(to right, var(--bg), rgba(0,0,0,0));}
  .hero-phones::after { right:calc(50% - 50vw); background:linear-gradient(to left,  var(--bg), rgba(0,0,0,0));}
}
@media (max-width:640px){
  .hero{padding-top:16px}
  .hero-eyebrow{margin-top:24px}
  .hero-title{font-size:clamp(40px,10vw,64px)}
  .hero-sub{font-size:15px;padding:0 4px}
  .hero-cta-row{margin-top:26px;gap:10px}
  .hero-phones{gap:10px;margin-top:32px}
  .hero-phones::before,
  .hero-phones::after{width:28vw}
}
@media (max-width:480px){
  .hero-title{font-size:clamp(36px,11vw,56px)}
  .hero-phones{gap:6px}
}


/* ============================================================
   Marquee — components/sections/marquee.jsx
   ============================================================ */
@keyframes aas-marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.marquee{padding-top:180px;padding-bottom:24px}
.marquee-eyebrow-wrap{text-align:center;margin-bottom:28px}
.marquee-rail{
  position:relative;
  overflow-x:clip;overflow-y:visible;
  -webkit-mask-image:linear-gradient(to right, transparent 0, #000 6%, #000 94%, transparent 100%);
  mask-image:linear-gradient(to right, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.marquee-track{
  display:flex;align-items:center;
  gap:64px;width:max-content;
  padding-top:10px;padding-bottom:22px;
  animation: aas-marquee-scroll 48s linear infinite;
  will-change:transform;
}
.marquee-word{
  font-family:var(--serif);font-style:italic;font-weight:500;
  white-space:nowrap;
  font-size:clamp(44px,4.5vw,64px);
  line-height:1.4;letter-spacing:-0.01em;
  color:var(--ink);
  display:inline-block;padding-bottom:0.12em;
}
.marquee-spark{display:inline-flex;color:var(--accent);opacity:.85;flex-shrink:0}
@media (prefers-reduced-motion: reduce){
  .marquee-track{animation:none}
}
@media (max-width:960px){
  .marquee-track{gap:48px}
  .marquee-word{font-size:clamp(36px,6vw,48px)}
}
@media (max-width:640px){
  .marquee{padding-top:88px;padding-bottom:16px}
  .marquee-eyebrow-wrap{margin-bottom:22px}
  .marquee-track{gap:32px;padding-top:6px;padding-bottom:14px}
  .marquee-word{font-size:clamp(28px,9vw,36px)}
}


/* ============================================================
   Pain — components/sections/pain.jsx
   ============================================================ */
.pain{padding-top:130px}
.pain-list{max-width:880px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:0}
.pain-row{
  display:flex;gap:18px;align-items:baseline;
  padding:22px 4px;border-top:1px solid rgba(0,0,0,0.1);
}
.pain-row:last-child{border-bottom:1px solid rgba(0,0,0,0.1)}
.pain-num{
  font-family:var(--serif);font-style:italic;
  font-size:32px;color:var(--ink-mute);
  min-width:64px;flex-shrink:0;
}
.pain-text{font-size:20px;line-height:1.4}
.pain-text-em{font-family:var(--serif);font-style:italic;font-size:22px}
.pain-pull{
  max-width:680px;margin:56px auto 0;
  text-align:center;font-size:19px;line-height:1.55;color:var(--ink);
}
.pain-pull-em{font-family:var(--serif);font-style:italic;font-size:22px}

@media (max-width:960px){
  .pain{padding-top:120px}
}
@media (max-width:640px){
  .pain{padding-top:80px}
  .pain-row{gap:12px;padding:18px 4px}
  .pain-num{font-size:24px;min-width:40px}
  .pain-text{font-size:16px}
  .pain-text-em{font-size:18px}
  .pain-pull{margin-top:40px;font-size:16px}
  .pain-pull-em{font-size:19px}
}


/* ============================================================
   Solution — components/sections/solution.jsx
   ============================================================ */
.solution-card{
  background:var(--ink);color:var(--bg);
  border-radius:var(--radius-lg);
  padding:90px 60px;
  text-align:center;position:relative;overflow:hidden;
}
.solution-eyebrow{color:var(--accent)}
.solution-title{
  font-family:var(--serif);
  font-size:clamp(40px,6vw,84px);
  line-height:1.04;letter-spacing:-0.025em;
  margin:14px auto 0;max-width:920px;
  font-weight:500;text-wrap:balance;
}
.solution-sub{
  font-size:18px;line-height:1.6;max-width:640px;
  margin:24px auto 0;color:#C9C5BE;
}
.solution-pills{margin-top:30px;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;align-items:center}
.solution-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border:1px solid rgba(255,255,255,0.2);border-radius:99px;
  font-weight:600;letter-spacing:.04em;
  background:transparent;color:var(--bg);
  font-family:var(--sans);font-size:15px;line-height:1.2;
}
.solution-pill--active{
  background:var(--accent);color:var(--ink);border-color:var(--accent);
  font-style:italic;font-family:var(--serif);font-weight:500;
}
.solution-spark{position:absolute}
.solution-spark--1{top:40px;left:60px;opacity:.4}
.solution-spark--2{bottom:60px;right:80px;opacity:.3}
.solution-spark--3{top:50%;right:40px;opacity:.2}

@media (max-width:960px){
  .solution-card{padding:72px 40px;border-radius:var(--radius-lg)}
}
@media (max-width:640px){
  .solution-card{padding:60px 24px;border-radius:var(--radius-md)}
  .solution-title{font-size:clamp(34px,9vw,52px)}
  .solution-sub{font-size:16px}
  .solution-pill{padding:8px 14px;font-size:13px}
}


/* ============================================================
   Build — components/sections/build.jsx
   ============================================================ */
.build-rows{display:flex;flex-direction:column;gap:80px}
.build-row{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center}
.build-row.is-reversed{grid-template-columns:1fr 1.2fr}
.build-row.is-reversed .build-text{order:2}
.build-row.is-reversed .build-preview{order:1}
.build-text-head{display:flex;align-items:baseline;gap:12px}
.build-num{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--ink-mute)}
.build-title{
  margin:0;font-family:var(--serif);
  font-size:clamp(32px,3.6vw,48px);
  line-height:1.05;letter-spacing:-0.02em;font-weight:500;
}
.build-list{margin-top:24px;display:flex;flex-direction:column;gap:14px}
.build-item{display:flex;gap:14px;align-items:flex-start}
.build-bullet{margin-top:7px;width:6px;height:6px;border-radius:99px;background:var(--accent);flex-shrink:0}
.build-item-text{font-size:16px;line-height:1.55;color:var(--ink)}
.build-preview{
  display:flex;justify-content:center;align-items:center;
  background:var(--bg-2);
  border-radius:var(--radius-lg);
  padding:56px 0;
  position:relative;overflow:hidden;
}
.build-preview-spark{position:absolute;top:24px;right:24px;opacity:.4}
.build-callout{
  margin:80px auto 0;text-align:center;max-width:640px;
  padding:36px 44px;
  border:1.5px dashed rgba(0,0,0,0.2);border-radius:var(--radius-md);
}
.build-callout-em{font-family:var(--serif);font-style:italic;font-size:26px;display:block}
.build-callout-sub{margin-top:10px;font-family:var(--hand);font-size:24px;color:var(--accent)}
.build-callout-list{
  list-style:none;padding:0;margin:22px auto 0;max-width:520px;
  text-align:left;font-size:15px;color:var(--ink);line-height:1.55;
}
.build-callout-list li{padding:8px 0;border-bottom:1px dashed rgba(0,0,0,0.08)}
.build-callout-list li:last-child{border-bottom:none}
.build-callout-key{font-weight:700}
.build-callout-foot{margin-top:18px;font-size:14px;color:var(--ink-soft);font-style:italic}

@media (max-width:960px){
  .build-rows{gap:64px}
  .build-row,
  .build-row.is-reversed{grid-template-columns:1fr;gap:32px}
  .build-row .build-text,
  .build-row.is-reversed .build-text{order:2}
  .build-row .build-preview,
  .build-row.is-reversed .build-preview{order:1}
  .build-preview{padding:44px 0}
}
@media (max-width:640px){
  .build-rows{gap:56px}
  .build-num{font-size:24px}
  .build-title{font-size:clamp(26px,7vw,34px)}
  .build-list{margin-top:18px}
  .build-item-text{font-size:15px}
  .build-preview{padding:36px 0;border-radius:var(--radius-md)}
  .build-callout{margin-top:56px;padding:24px 22px}
  .build-callout-em{font-size:22px}
  .build-callout-sub{font-size:20px}
  .build-callout-list{font-size:14px}
  .build-callout-foot{font-size:13px}
}


/* ============================================================
   How It Works — components/sections/how-it-works.jsx
   ============================================================ */
.how-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;position:relative;
}
.how-line{
  position:absolute;top:38px;left:12.5%;right:12.5%;height:1px;
  background-image:repeating-linear-gradient(to right, rgba(0,0,0,0.25) 0 4px, transparent 4px 10px);
}
.how-step{padding:0 18px;position:relative;text-align:center}
.how-step-num{
  width:76px;height:76px;border-radius:99px;
  background:var(--bg);border:1.5px solid var(--ink);
  display:flex;align-items:center;justify-content:center;margin:0 auto;
  position:relative;z-index:1;
}
.how-step-num span{font-family:var(--serif);font-size:30px;font-style:italic}
.how-step-title{
  margin:22px 0 10px;font-family:var(--serif);
  font-size:26px;font-weight:500;letter-spacing:-0.01em;
}
.how-step-body{margin:0;font-size:14px;line-height:1.55;color:var(--ink-soft);max-width:360px;margin-inline:auto}

@media (max-width:960px){
  .how-grid{grid-template-columns:repeat(2,1fr);gap:48px}
  .how-line{display:none}
  .how-step{padding:0}
}
@media (max-width:640px){
  .how-grid{grid-template-columns:1fr;gap:40px}
  .how-step-num{width:64px;height:64px}
  .how-step-num span{font-size:26px}
  .how-step-title{margin:18px 0 8px;font-size:22px}
}


/* ============================================================
   Eligibility — components/sections/eligibility.jsx
   ============================================================ */
.eligible-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}
.eligible-title{
  font-family:var(--serif);
  font-size:clamp(40px,5vw,68px);
  line-height:1.04;letter-spacing:-0.02em;
  margin:14px 0 0;font-weight:500;text-wrap:balance;
}
.eligible-sub{margin-top:24px;font-size:17px;line-height:1.6;color:var(--ink-soft);max-width:460px}
.eligible-aside{
  margin-top:28px;padding:18px 22px;
  background:rgba(235,168,242,0.18);
  border:1px solid rgba(0,0,0,0.08);
  border-radius:var(--radius-sm);
  max-width:460px;
}
.eligible-aside-title{font-family:var(--serif);font-style:italic;font-size:20px}
.eligible-aside-sub{font-size:15px;color:var(--ink-soft);margin-top:4px}
.eligible-card{
  background:#fff;border-radius:28px;
  padding:40px 44px;border:1px solid rgba(0,0,0,0.08);
}
.eligible-card-label{font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute)}
.eligible-list{margin-top:18px;display:flex;flex-direction:column;gap:18px}
.eligible-row{display:flex;gap:14px;align-items:flex-start}
.eligible-check{
  width:26px;height:26px;border-radius:99px;background:var(--accent);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;flex-shrink:0;border:1.5px solid var(--ink);
}
.eligible-text{font-size:16px;line-height:1.5}

@media (max-width:960px){
  .eligible-grid{grid-template-columns:1fr;gap:40px}
}
@media (max-width:640px){
  .eligible-grid{gap:32px}
  .eligible-sub{font-size:16px}
  .eligible-card{padding:28px 24px;border-radius:22px}
  .eligible-list{gap:14px}
  .eligible-text{font-size:15px}
}


/* ============================================================
   Pricing — components/sections/pricing.jsx
   ============================================================ */
.pricing-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  max-width:1080px;margin:0 auto;
}
.pricing-card{
  background:#fff;border-radius:28px;
  padding:40px 36px;
  border:1px solid rgba(0,0,0,0.08);position:relative;
}
.pricing-card.is-dark{
  background:var(--ink);color:var(--bg);
  border:none;overflow:hidden;
}
.pricing-card-head{display:flex;flex-direction:column;align-items:flex-start;gap:4px}
.pricing-card.is-dark .pricing-card-head{padding-right:0}
.pricing-card-meta{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}
.pricing-card.is-dark .pricing-card-meta{color:#C9C5BE}
.pricing-card.is-dark .eyebrow{color:var(--accent)}
.pricing-price{
  font-family:var(--serif);font-size:88px;font-weight:500;
  letter-spacing:-0.03em;line-height:1;margin-top:18px;
}
.pricing-price-sub{font-style:italic;font-size:36px;color:#C9C5BE;font-family:var(--serif)}
.pricing-tagline{font-size:14px;color:var(--ink-soft);margin-top:6px}
.pricing-card.is-dark .pricing-tagline{color:#C9C5BE}
.pricing-features{margin-top:28px;display:flex;flex-direction:column;gap:10px}
.pricing-feature{font-size:14px;display:flex;gap:10px}
.pricing-feature-dash{color:var(--ink-mute)}
.pricing-card.is-dark .pricing-feature{color:var(--bg)}
.pricing-card.is-dark .pricing-feature-dash{color:var(--accent)}
.pricing-popular,
.pricing-badge{
  position:absolute;top:36px;right:36px;
  padding:5px 12px;border-radius:99px;background:var(--accent);color:var(--ink);
  font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  border:1.5px solid var(--ink);
}
.pricing-price-prefix{
  display:block;
  font-family:var(--serif);font-style:italic;
  font-size:0.3em;color:var(--ink-soft);
  letter-spacing:-0.01em;line-height:1;
  margin-bottom:2px;
}
.pricing-price-was{
  font-family:var(--serif);font-style:italic;
  font-size:0.45em;color:var(--ink-mute);
  text-decoration:line-through;
  margin-left:6px;letter-spacing:-0.02em;
  vertical-align:0.35em;
}
.pricing-promo-note{
  font-size:20px;color:var(--ink-soft);margin-top:6px;
}
.pricing-foot{text-align:center;margin-top:32px;font-size:14px;color:var(--ink-soft)}
.pricing-cta{display:flex;justify-content:center;margin-top:40px}

@media (max-width:960px){
  .pricing-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .pricing-grid{gap:16px}
  .pricing-card{padding:32px 26px;border-radius:22px}
  .pricing-card .pricing-card-head{padding-right:120px}
  .pricing-popular,
  .pricing-badge{top:28px;right:26px}
  .pricing-price{font-size:clamp(54px,14vw,72px)}
  .pricing-price-sub{font-size:26px}
  .pricing-popular{font-size:10px}
  .pricing-foot{padding:0 8px}
}


/* ============================================================
   FAQs — components/sections/faqs.jsx
   ============================================================ */
.faqs-head{
  text-align:left;max-width:none;
  display:flex;flex-direction:row;justify-content:space-between;align-items:flex-end;
  gap:24px;margin-bottom:40px;
}
.faqs-head h2{text-align:left;margin:14px 0 0}
.faqs-head-sub{color:var(--ink-soft);font-size:15px;max-width:320px}
.faqs-list{border-bottom:1px solid rgba(0,0,0,0.12)}
.faq{border-top:1px solid rgba(0,0,0,0.12)}
.faq-button{
  width:100%;text-align:left;background:transparent;border:none;cursor:pointer;
  padding:26px 4px;color:var(--ink);font:inherit;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
}
.faq-q{
  font-family:var(--serif);
  font-size:clamp(22px,2.4vw,28px);
  font-weight:500;letter-spacing:-0.01em;text-align:left;text-wrap:balance;
}
.faq-toggle{
  width:36px;height:36px;border-radius:99px;border:1.5px solid var(--ink);
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:transform .2s, background .2s;
  background:transparent;
}
.faq.is-open .faq-toggle{transform:rotate(45deg);background:var(--accent)}
.faq-collapse{overflow:hidden;max-height:0;transition:max-height .35s ease}
.faq.is-open .faq-collapse{max-height:800px}
.faq-body{padding:0 4px 26px;font-size:16px;line-height:1.65;color:var(--ink-soft);max-width:780px}

@media (max-width:960px){
  .faqs-head{flex-direction:column;align-items:flex-start;gap:12px}
}
@media (max-width:640px){
  .faqs-head{margin-bottom:24px}
  .faq-button{padding:20px 4px;gap:14px}
  .faq-q{font-size:clamp(18px,5vw,22px)}
  .faq-toggle{width:30px;height:30px}
  .faq-body{padding:0 4px 22px;font-size:15px}
}


/* ============================================================
   Final CTA — components/sections/final-cta.jsx
   ============================================================ */
.final-cta{padding-bottom:60px}
.final-cta-card{
  background:var(--accent);
  border-radius:var(--radius-lg);
  padding:100px 40px 90px;
  border:1.5px solid var(--ink);
  text-align:center;position:relative;overflow:hidden;
}
.final-cta-title{
  margin:14px auto 0;font-family:var(--serif);
  font-size:clamp(48px,7vw,104px);
  line-height:1.0;letter-spacing:-0.025em;
  max-width:920px;font-weight:500;text-wrap:balance;
}
.final-cta-sub{
  margin:24px auto 0;max-width:540px;
  font-size:17px;line-height:1.6;color:var(--ink);
}
.final-cta-actions{margin-top:34px;display:flex;justify-content:center;gap:12px;align-items:center}
.final-cta-btn{background:var(--ink);color:var(--accent);border-color:var(--ink)}
.final-cta-spark{position:absolute}
.final-cta-spark--1{top:60px;left:80px;opacity:.5}
.final-cta-spark--2{bottom:80px;right:120px;opacity:.4}
.final-cta-spark--3{top:40%;right:60px;opacity:.3}
.final-cta-spark--4{bottom:40px;left:30%;opacity:.35}
.final-cta-spark--mob-1{top:24px;left:24px;opacity:.5}
.final-cta-spark--mob-2{bottom:24px;right:24px;opacity:.4}
.final-cta-spark--mob{display:none}

@media (max-width:960px){
  .final-cta-card{padding:80px 32px 72px}
}
@media (max-width:640px){
  .final-cta{padding-bottom:40px}
  .final-cta-card{padding:64px 24px 56px;border-radius:var(--radius-md)}
  .final-cta-title{font-size:clamp(40px,11vw,60px)}
  .final-cta-sub{font-size:15px}
  .final-cta-spark--1,
  .final-cta-spark--2,
  .final-cta-spark--3,
  .final-cta-spark--4{display:none}
  .final-cta-spark--mob{display:block}
}


/* ============================================================
   Footer — components/sections/footer.jsx
   ============================================================ */
.footer{padding:60px 0 80px;border-top:1px solid rgba(0,0,0,0.08)}
.footer-inner{
  display:flex;flex-direction:row;
  justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:20px;
}
.footer-logo{display:flex;align-items:center;gap:12px}
.footer-logo-mark{
  width:34px;height:34px;border-radius:99px;border:1.5px solid var(--ink);
  display:flex;align-items:center;justify-content:center;
}
.footer-logo-mark span{font-family:var(--serif);font-style:italic;font-size:20px}
.footer-logo-img{height:36px;width:auto;display:block}
.footer-logo-text{display:none}
.footer-links{
  display:flex;flex-wrap:wrap;gap:28px;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  color:var(--ink-soft);
}
.footer-links a{text-decoration:none;color:inherit}
.footer-copy{font-size:12px;color:var(--ink-mute)}

@media (max-width:640px){
  .footer{padding:40px 0 60px}
  .footer-inner{flex-direction:column;align-items:center;text-align:center;gap:18px}
  .footer-links{gap:16px}
}
