/* ═══════════════════════════════════════════════════════════
   ASCELYX v3 — Clarity & Ascent
   Growth & strategy consultancy · Bone/Spruce/Signal-green
   Fraunces display · Hanken Grotesk body · Geist Mono data
   ═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,600&family=Hanken+Grotesk:wght@300;400;500;600&family=Geist+Mono:wght@400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bone:     #F6F5F1;
  --white:    #FFFFFF;
  --spruce:   #0C1219;
  --onyx:     #14110F;
  --signal:   #1F9486;
  --mist:     #C9D6CF;
  --stone:    #6B7570;
  --line:     #E2E0D9;
  --sig-light:#e3f4f2;
  --f-disp:   'Fraunces',Georgia,'Times New Roman',serif;
  --f-body:   'Hanken Grotesk',ui-sans-serif,system-ui,sans-serif;
  --f-mono:   'Geist Mono',ui-monospace,monospace;
  /* spruce dark band */
  --spruce-text:rgba(214,228,224,.8);
}
html{scroll-behavior:smooth}
body{background:var(--bone);color:var(--onyx);font-family:var(--f-body);font-size:16px;
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:var(--spruce);text-decoration:none}
::selection{background:var(--signal);color:var(--spruce)}
:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(31,148,134,.4);border-radius:6px}
h1,h2,h3,h4{font-family:var(--f-disp);color:var(--onyx);font-weight:600;line-height:1.08;
  letter-spacing:-.01em;text-wrap:balance}

/* ── Layout ── */
.wrap{max-width:1080px;margin:0 auto;padding:0 36px}
.narrow{max-width:780px;margin:0 auto;padding:0 36px}
.pad{padding:96px 0}
.pad-sm{padding:64px 0}
@media(max-width:768px){.pad{padding:64px 0}.pad-sm{padding:44px 0}}
@media(max-width:560px){.wrap,.narrow{padding:0 22px}}

/* ── Eyebrow ── */
.ey{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:12px;
  font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--signal);margin-bottom:18px}
.ey::before{content:"";width:16px;height:1.5px;background:currentColor;flex-shrink:0}
.dark .ey{color:var(--signal)}

/* ── Section header ── */
.sh{max-width:640px;margin-bottom:48px}
.sh.center{margin-left:auto;margin-right:auto;text-align:center}
.sh h2{font-size:clamp(28px,4.2vw,42px);margin-bottom:16px;color:var(--onyx)}
.sh p{font-size:17.5px;line-height:1.65;color:var(--stone)}
.dark .sh h2{color:var(--bone)}
.dark .sh p{color:var(--spruce-text)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--f-body);font-weight:500;
  font-size:15.5px;padding:14px 26px;border-radius:6px;border:none;cursor:pointer;
  text-decoration:none;white-space:nowrap;line-height:1;
  transition:background .15s,border-color .15s,transform .1s,box-shadow .15s,opacity .15s}
.btn:active{transform:scale(.985)}
.btn svg{flex-shrink:0}
.btn .arr{transition:transform .18s}.btn:hover .arr{transform:translateX(3px)}
.btn-primary{background:var(--spruce);color:#fff;box-shadow:0 4px 14px rgba(15,61,51,.2)}
.btn-primary:hover{background:#0c3329;box-shadow:0 6px 18px rgba(15,61,51,.26)}
.btn-sig{background:var(--signal);color:var(--spruce);font-weight:600}
.btn-sig:hover{background:#13a873}
.btn-outline{background:transparent;color:var(--onyx);border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--onyx)}
.btn-ghost{background:transparent;color:var(--bone);border:1.5px solid rgba(214,228,224,.36)}
.btn-ghost:hover{border-color:rgba(214,228,224,.72)}
.btn-lg{font-size:16.5px;padding:16px 32px}
.btn-sm{font-size:14px;padding:10px 18px}

/* ── Sticky header ── */
#v3-header{position:sticky;top:0;z-index:100;background:rgba(246,245,241,.9);
  backdrop-filter:saturate(150%) blur(14px);border-bottom:1px solid var(--line)}
.v3-nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.v3-brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.v3-brand{flex-shrink:0}
.v3-links{display:flex;gap:26px;align-items:center;list-style:none}
.v3-link{font-size:14.5px;font-weight:400;color:var(--stone);transition:color .15s;
  position:relative;padding:4px 0}
.v3-link:hover,.v3-link.active{color:var(--onyx)}
.v3-link.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;
  height:2px;background:var(--signal);border-radius:2px}
.v3-actions{display:flex;gap:11px;align-items:center}
.v3-ham{display:none;background:none;border:none;cursor:pointer;color:var(--onyx);padding:8px}
.v3-mobile{position:fixed;inset:72px 0 auto 0;background:var(--bone);z-index:99;
  border-bottom:1px solid var(--line);transform:translateY(-12px);opacity:0;
  pointer-events:none;transition:opacity .25s,transform .25s;padding:16px 36px 28px}
.v3-mobile.open{opacity:1;transform:none;pointer-events:auto}
.v3-mobile a{display:block;font-family:var(--f-disp);font-weight:600;font-size:20px;
  color:var(--onyx);padding:13px 0;border-bottom:1px solid var(--line)}
.v3-mobile .btn{display:flex;justify-content:center;margin-top:16px}
@media(max-width:900px){.v3-links{display:none}.v3-ham{display:flex}
  .v3-actions .v3-hide{display:none}}

/* ── Dark spruce band ── */
.dark{background:var(--spruce);color:var(--spruce-text)}
.dark h1,.dark h2,.dark h3,.dark h4{color:var(--bone)}

/* ── Cards ── */
.card{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:28px;
  box-shadow:0 1px 3px rgba(20,17,15,.04),0 8px 24px rgba(20,17,15,.06)}
.card.hover{transition:transform .2s,box-shadow .2s,border-color .2s}
.card.hover:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(20,17,15,.1);
  border-color:rgba(31,148,134,.4)}

/* ── Pill tag ── */
.tag{display:inline-flex;align-items:center;gap:5px;font-family:var(--f-mono);font-size:11px;
  font-weight:500;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px}
.tag-sig{background:var(--sig-light);color:var(--spruce)}
.tag-mist{background:var(--mist);color:var(--spruce)}

/* ── Reveal ── */
html.v3-ready .rev{opacity:0;transform:translateY(20px);
  transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
html.v3-ready .rev.in{opacity:1;transform:none}
html.v3-ready .rev.d1{transition-delay:.08s}html.v3-ready .rev.d2{transition-delay:.15s}
html.v3-ready .rev.d3{transition-delay:.22s}html.v3-ready .rev.d4{transition-delay:.29s}
@media(prefers-reduced-motion:reduce){html.v3-ready .rev{opacity:1;transform:none;transition:none}}

/* ── FAQ ── */
.faq{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:none;cursor:pointer;display:flex;
  justify-content:space-between;align-items:center;gap:18px;padding:22px 0;text-align:left;
  font-family:var(--f-disp);font-weight:500;font-size:18px;color:var(--onyx)}
.faq-ic{width:26px;height:26px;flex-shrink:0;border-radius:50%;border:1.5px solid var(--mist);
  position:relative;transition:border-color .2s,transform .25s}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);background:var(--stone);border-radius:2px}
.faq-ic::before{width:11px;height:1.8px}.faq-ic::after{width:1.8px;height:11px;transition:opacity .2s}
.faq-item.open .faq-ic{border-color:var(--signal);transform:rotate(90deg)}
.faq-item.open .faq-ic::after{opacity:0}
.faq-body{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-body .in{padding:0 0 22px;font-size:16px;line-height:1.7;color:var(--stone);max-width:64ch}

/* ── Placeholder ── */
.flag{font-family:var(--f-mono);font-size:.82em;font-weight:500;color:var(--spruce);
  background:var(--sig-light);border:1px dashed rgba(31,148,134,.5);border-radius:4px;padding:1px 6px}
.ph-box{font-family:var(--f-mono);font-size:13px;color:var(--mist);border:1.5px dashed var(--line);
  border-radius:12px;display:flex;align-items:center;justify-content:center;text-align:center;padding:28px;line-height:1.6}

/* ── Footer ── */
#v3-footer{background:var(--spruce)}
.v3-foot-cta{border-bottom:1px solid rgba(214,228,224,.14);padding:52px 0;text-align:center}
.v3-foot-cta h3{font-family:var(--f-disp);color:var(--bone);font-size:clamp(22px,3.2vw,32px);
  margin-bottom:20px;font-weight:500;text-wrap:balance}
.v3-foot-main{padding:48px 0 36px;display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:40px}
.v3-foot-brand .v3-brand{margin-bottom:14px}.v3-foot-brand .v3-logo span{background:var(--mist)}
.v3-foot-brand .v3-wordmark{color:var(--bone)}.v3-foot-brand p{font-size:14px;color:var(--spruce-text);line-height:1.6;max-width:260px}
.v3-foot-col h5{font-family:var(--f-mono);font-size:11px;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;color:var(--mist);margin-bottom:14px}
.v3-foot-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.v3-foot-col a{font-size:14px;color:var(--spruce-text)}
.v3-foot-col a:hover{color:var(--bone)}
.v3-foot-ph{font-family:var(--f-mono);font-size:11px;color:rgba(214,228,224,.5);
  border:1px dashed rgba(214,228,224,.28);padding:2px 6px;border-radius:4px;display:inline-block}
.v3-foot-bottom{border-top:1px solid rgba(214,228,224,.14);padding:18px 0;display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:10px;font-family:var(--f-mono);
  font-size:11.5px;color:rgba(214,228,224,.4)}
@media(max-width:760px){.v3-foot-main{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:480px){.v3-foot-main{grid-template-columns:1fr}}

/* ── Risk reversal strip ── */
.risk{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.r{display:flex;gap:16px;align-items:flex-start}
.r svg{flex-shrink:0;color:var(--signal);margin-top:2px}
.r h4{font-family:var(--f-disp);font-weight:600;font-size:17px;color:var(--onyx);margin-bottom:5px}
.r p{font-size:14.5px;color:var(--stone);line-height:1.55}
@media(max-width:760px){.risk{grid-template-columns:1fr}}
/* price in package teaser cards */
.pk .price{font-family:var(--f-disp);font-weight:700;color:var(--onyx);margin:8px 0;line-height:1}
.pk .price b{font-size:32px;letter-spacing:-.02em}
.pk .price .from{font-family:var(--f-mono);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);margin-right:3px}
