/* ============================================================
   The Forge — landing page styles
   Palette: Black anchor + warm sunset gradient
   ============================================================ */
:root{
  --ink:#0A0A0A;
  --midnight:#211A3D;
  --mauve:#9C7888;
  --rose:#D29488;
  --peach:#F2A574;
  --cream:#FCD9A8;
  --bone:#F5F1EA;

  --sunset: linear-gradient(135deg, #D29488 0%, #F2A574 55%, #FCD9A8 100%);

  --font-head: "Barlow Condensed", system-ui, sans-serif;
  --font-body: "Inter", system-ui, sans-serif;

  --maxw: 1120px;
  --radius: 16px;
  --shadow: 0 18px 50px rgba(10,10,10,.18);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--font-body);
  font-weight:400;
  color:var(--midnight);
  background:var(--bone);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }

.container{
  width:100%;
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:24px;
}
.container--narrow{ max-width:760px; }

/* ---------- Eyebrow (signature move) ---------- */
.eyebrow{
  font-family:var(--font-head);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.85rem;
  color:var(--peach);
  margin:0 0 .75rem;
}
.eyebrow--onDark{ color:var(--peach); }

/* ---------- Section titles ---------- */
.section__title{
  font-family:var(--font-head);
  font-weight:800;
  font-size:clamp(2rem, 4vw, 3rem);
  line-height:1.05;
  color:var(--ink);
  margin:0 0 2.5rem;
}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--font-head);
  font-weight:700;
  letter-spacing:.02em;
  border:none;
  border-radius:999px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5ch;
  text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease;
  line-height:1;
}
.btn:focus-visible{ outline:3px solid var(--midnight); outline-offset:2px; }
.btn--sm{ font-size:1rem; padding:.6rem 1.2rem; }
.btn--lg{ font-size:1.4rem; padding:1rem 2rem; text-transform:uppercase; }
.btn--block{ width:100%; }

.btn--peach{ background:var(--peach); color:var(--ink); box-shadow:0 8px 22px rgba(242,165,116,.45); }
.btn--peach:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(242,165,116,.6); }

.btn--ink{ background:var(--ink); color:var(--cream); }
.btn--ink:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }

.btn--ghost{ background:transparent; color:var(--mauve); padding:.5rem .25rem; }
.btn--ghost:hover{ color:var(--midnight); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(156,120,136,.3);
}
.nav__inner{ display:flex; align-items:center; gap:1.5rem; min-height:68px; }
.nav__brand{
  font-family:var(--font-head);
  font-weight:800;
  font-size:1.5rem;
  color:var(--bone);
  text-decoration:none;
  display:flex; align-items:center; gap:.5ch;
  letter-spacing:.01em;
}
.nav__mark{ color:var(--peach); font-size:.8em; }
.brandLogo{ height:36px; width:auto; display:block; }
.nav__links{ display:flex; gap:1.5rem; margin-left:auto; }
.nav__links a{
  font-family:var(--font-body);
  font-weight:500;
  font-size:.95rem;
  color:var(--bone);
  text-decoration:none;
  opacity:.85;
}
.nav__links a:hover{ opacity:1; color:var(--peach); }
.nav .btn--sm{ margin-left:.5rem; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  background:
    radial-gradient(1200px 500px at 50% -10%, rgba(242,165,116,.22), transparent 60%),
    var(--ink);
  color:var(--bone);
  text-align:center;
  padding:72px 0 88px;
}
.hero__inner{ max-width:840px; }
.hero__title{
  font-family:var(--font-head);
  font-weight:800;
  font-size:clamp(2.6rem, 6vw, 4.6rem);
  line-height:.98;
  margin:0 0 1.25rem;
  color:#fff;
}
.hero__sub{
  font-size:1.18rem;
  color:rgba(245,241,234,.82);
  max-width:620px;
  margin:0 auto 2.25rem;
}
.hero__video{
  position:relative;
  width:100%;
  border-radius:var(--radius);
  margin:0 auto 2.25rem;
  box-shadow:var(--shadow);
  overflow:hidden;
  background:var(--ink);
}
.hero__play{
  width:78px; height:78px;
  border-radius:50%;
  border:none;
  background:rgba(10,10,10,.85);
  color:var(--cream);
  font-size:1.6rem;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:transform .15s ease;
}
.hero__play:hover{ transform:scale(1.08); }
.hero__playIcon{ margin-left:4px; }
.hero__videoNote{
  font-family:var(--font-head);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.85rem;
  color:rgba(10,10,10,.7);
}
.hero__reassure{
  margin:1rem 0 0;
  font-size:.95rem;
  color:rgba(245,241,234,.65);
}

/* ============================================================
   PILLARS
   ============================================================ */
.pillars{ padding:84px 0; background:var(--bone); text-align:center; }
.pillars__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  text-align:left;
}
.pillar{
  background:#fff;
  border:1px solid rgba(156,120,136,.25);
  border-radius:var(--radius);
  padding:2rem 1.75rem;
  box-shadow:0 6px 20px rgba(33,26,61,.05);
}
.pillar__icon{
  width:54px; height:54px;
  border-radius:14px;
  background:var(--cream);
  color:var(--ink);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:1.25rem;
}
.pillar__icon svg{ width:28px; height:28px; }
.pillar__num{
  font-family:var(--font-head);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.9rem;
  color:var(--peach);
  margin:0 0 .35rem;
}
.pillar__title{
  font-family:var(--font-head);
  font-weight:700;
  font-size:1.6rem;
  color:var(--ink);
  margin:0 0 .6rem;
}
.pillar__body{ margin:0; color:var(--midnight); }
.pillars__cta{ margin-top:3rem; }

/* ============================================================
   FEATURES
   ============================================================ */
.features{ padding:84px 0; background:#fff; text-align:center; }
.feature{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:center;
  text-align:left;
  margin-bottom:3.5rem;
}
.feature:last-child{ margin-bottom:0; }
.feature--reverse .feature__media{ order:2; }
.feature__media{
  aspect-ratio:4/3;
  border-radius:var(--radius);
  background:var(--sunset);
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.feature__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.feature__media span{
  font-family:var(--font-head);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:rgba(10,10,10,.6);
  font-size:.9rem;
}
.feature__title{
  font-family:var(--font-head);
  font-weight:700;
  font-size:2rem;
  color:var(--ink);
  margin:0 0 .75rem;
}
.feature__text p{ margin:0; color:var(--midnight); font-size:1.08rem; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ padding:84px 0; background:var(--bone); text-align:center; }
.faq__item{
  text-align:left;
  background:#fff;
  border:1px solid rgba(156,120,136,.25);
  border-radius:12px;
  margin-bottom:.85rem;
  overflow:hidden;
}
.faq__item summary{
  cursor:pointer;
  list-style:none;
  padding:1.15rem 1.4rem;
  font-family:var(--font-head);
  font-weight:600;
  font-size:1.25rem;
  color:var(--ink);
  display:flex; align-items:center; justify-content:space-between;
}
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{
  content:"+";
  color:var(--peach);
  font-size:1.5rem;
  font-weight:700;
  margin-left:1rem;
}
.faq__item[open] summary::after{ content:"\2212"; }
.faq__body{ padding:0 1.4rem 1.25rem; }
.faq__body p{ margin:0; color:var(--midnight); }
.faq__cta{ margin-top:2.5rem; }

/* ============================================================
   FINAL CTA
   ============================================================ */
.finalCta{ padding:84px 0; background:var(--sunset); }
.finalCta__inner{ text-align:center; }
.finalCta .eyebrow{ color:var(--ink); }
.finalCta__title{
  font-family:var(--font-head);
  font-weight:800;
  font-size:clamp(2rem,4.5vw,3.2rem);
  line-height:1.04;
  color:var(--ink);
  margin:0 0 1rem;
}
.finalCta__sub{
  font-size:1.15rem;
  color:var(--midnight);
  max-width:560px;
  margin:0 auto 2rem;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink); color:var(--bone); padding:56px 0 28px; }
.footer__inner{
  display:flex; justify-content:space-between; gap:2rem;
  flex-wrap:wrap;
  padding-bottom:2rem;
  border-bottom:1px solid rgba(156,120,136,.3);
}
.footer__brand{
  font-family:var(--font-head);
  font-weight:800;
  font-size:1.5rem;
  display:flex; align-items:center; gap:.5ch;
  flex-wrap:wrap;
}
.footer__tag{
  flex-basis:100%;
  font-family:var(--font-body);
  font-weight:400;
  font-size:.95rem;
  color:rgba(245,241,234,.6);
  margin:.5rem 0 0;
}
.footer__links{ display:flex; gap:1.5rem; flex-wrap:wrap; align-items:center; }
.footer__links a{ color:rgba(245,241,234,.85); text-decoration:none; font-size:.95rem; }
.footer__links a:hover{ color:var(--peach); }
.footer__legal{ padding-top:1.25rem; }
.footer__legal p{ margin:0; font-size:.85rem; color:rgba(245,241,234,.5); }

/* ============================================================
   MODAL (two-step form)
   ============================================================ */
.modal{
  position:fixed; inset:0; z-index:100;
  display:none;
  align-items:flex-start; justify-content:center;
  padding:24px;
  overflow-y:auto;
}
.modal.is-open{ display:flex; }
.modal__backdrop{
  position:fixed; inset:0;
  background:rgba(10,10,10,.6);
  backdrop-filter:blur(3px);
}
.modal__dialog{
  position:relative;
  z-index:1;
  width:100%;
  max-width:560px;
  margin:auto;
  background:var(--bone);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:2.25rem 2rem 2rem;
}
.modal__close{
  position:absolute; top:.85rem; right:1rem;
  background:none; border:none;
  font-size:1.8rem; line-height:1;
  color:var(--mauve); cursor:pointer;
}
.modal__close:hover{ color:var(--ink); }

.modal__steps{ display:flex; align-items:center; gap:.5rem; margin-bottom:1.25rem; }
.modal__step{
  width:30px; height:30px; border-radius:50%;
  background:#fff; border:2px solid var(--mauve);
  color:var(--mauve);
  font-family:var(--font-head); font-weight:700;
  display:flex; align-items:center; justify-content:center;
  font-size:.95rem;
}
.modal__step.is-active{ background:var(--peach); border-color:var(--peach); color:var(--ink); }
.modal__stepLine{ flex:0 0 36px; height:2px; background:var(--mauve); }

.modal__panel{ display:none; }
.modal__panel.is-active{ display:block; animation:fade .25s ease; }
@keyframes fade{ from{opacity:0; transform:translateY(6px);} to{opacity:1; transform:none;} }

.modal__title{
  font-family:var(--font-head);
  font-weight:800;
  font-size:2rem;
  line-height:1.05;
  color:var(--ink);
  margin:0 0 .5rem;
}
.modal__lead{ margin:0 0 1.5rem; color:var(--midnight); }

.field{ margin-bottom:1rem; text-align:left; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field label{
  display:block;
  font-weight:600;
  font-size:.9rem;
  color:var(--midnight);
  margin-bottom:.35rem;
}
.field__opt{ font-weight:400; color:var(--mauve); }
.field input,
.field select,
.field textarea{
  width:100%;
  font-family:var(--font-body);
  font-size:1rem;
  color:var(--ink);
  background:#fff;
  border:1.5px solid rgba(156,120,136,.45);
  border-radius:10px;
  padding:.7rem .85rem;
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;
  border-color:var(--peach);
  box-shadow:0 0 0 3px rgba(242,165,116,.3);
}
.field input.invalid,
.field select.invalid{ border-color:#c0392b; box-shadow:0 0 0 3px rgba(192,57,43,.18); }
.field textarea{ resize:vertical; }

.modal__error{ color:#c0392b; font-size:.9rem; margin:.25rem 0 1rem; }

.modal__calendly{
  min-height:580px;
  border-radius:12px;
  overflow:hidden;
  margin-bottom:1rem;
}
.modal__calendly--placeholder{
  background:#fff;
  border:1.5px dashed var(--mauve);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center;
  padding:2rem;
  color:var(--midnight);
}
.modal__calendly--placeholder strong{
  font-family:var(--font-head);
  font-size:1.3rem;
  color:var(--ink);
  display:block; margin-bottom:.5rem;
}
.modal__calendly--placeholder code{
  background:var(--bone);
  padding:.2rem .45rem;
  border-radius:6px;
  font-size:.85rem;
}

/* lock background scroll when modal open */
body.modal-open{ overflow:hidden; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:860px){
  .pillars__grid{ grid-template-columns:1fr; }
  .feature{ grid-template-columns:1fr; gap:1.5rem; }
  .feature--reverse .feature__media{ order:0; }
  .nav__links{ display:none; }
}
@media (max-width:560px){
  .field-row{ grid-template-columns:1fr; }
  .btn--lg{ font-size:1.15rem; padding:.9rem 1.4rem; }
  .modal__dialog{ padding:2rem 1.25rem 1.5rem; }
  .hero{ padding:52px 0 64px; }
}
