/* Tom Timney PT — dark editorial design system (matches A5 flyer + Kickstart landing)
   Base #21201D · deep #1A1917 · surface #262521 · panel #37312A · cream #F6F2EA · blue #7AB8D4 */

:root{
  --bg:#21201D;            /* page base (flyer background) */
  --bg-deep:#1A1917;       /* alternate bands + footer (landing page tone) */
  --surface:#262521;       /* cards */
  --panel:#37312A;         /* signature offer panel (flyer) */
  --cream:#F6F2EA;
  --cream-2:#FBF8F2;
  --ink:#1C1B19;           /* text on cream/blue elements only */
  --blue:#7AB8D4;
  --text:var(--cream);
  --muted:rgba(246,242,234,0.78);
  --soft:rgba(246,242,234,0.58);
  --line:rgba(246,242,234,0.15);
  --line-strong:rgba(246,242,234,0.32);
  --cream-muted:var(--muted);   /* legacy aliases used by inline styles */
  --cream-soft:var(--soft);
  --cream-line:var(--line);
  --charcoal:var(--bg);
  --serif:'Fraunces',Georgia,serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  --max:1160px;
  --pad:clamp(20px,4.5vw,48px);
  --r:3px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--sans);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit}
::selection{background:var(--blue);color:var(--ink)}

/* ---------- type ---------- */
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.06;letter-spacing:-0.015em;margin:0;color:var(--cream-2)}
h1{font-size:clamp(2.4rem,5.6vw,4.1rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}
h3{font-size:clamp(1.22rem,2vw,1.45rem);line-height:1.2}
p{margin:0}
.lede{font-size:clamp(1.05rem,1.6vw,1.25rem);line-height:1.55;color:var(--muted)}
.eyebrow{
  display:block;font-family:var(--sans);font-size:0.72rem;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;color:var(--soft);margin-bottom:14px;
}
.bar{display:block;width:36px;height:2px;background:var(--blue);margin-bottom:18px}
.serif-i{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--cream)}

/* ---------- layout ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.section{padding:clamp(64px,9vw,110px) 0}
.section-tight{padding:clamp(44px,6vw,72px) 0}
.dark{background:var(--bg-deep)}   /* alternate band, slightly deeper than base */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,32px)}
@media(max-width:880px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;background:rgba(33,32,29,0.92);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;transition:border-color .25s ease;
}
.site-header.scrolled{border-bottom-color:var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{font-family:var(--serif);font-weight:600;font-size:1.28rem;text-decoration:none;letter-spacing:-0.01em;color:var(--cream-2)}
.logo span{font-weight:400;opacity:0.7}
.nav-links{display:flex;align-items:center;gap:clamp(18px,2.4vw,32px)}
.nav-links a{
  font-size:0.92rem;font-weight:500;text-decoration:none;color:var(--muted);
  transition:color .18s ease;
}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--cream-2)}
.nav-links a[aria-current="page"]{box-shadow:0 2px 0 var(--blue)}
.nav-cta{margin-left:6px}
.burger{display:none;background:none;border:0;padding:10px;cursor:pointer}
.burger span{display:block;width:22px;height:2px;background:var(--cream);margin:5px 0;transition:transform .25s ease,opacity .25s ease}
@media(max-width:960px){
  .nav-links{
    position:fixed;inset:72px 0 0 0;background:var(--bg);flex-direction:column;
    justify-content:flex-start;padding-top:8vh;gap:26px;transform:translateY(-110%);
    transition:transform .3s ease;border-top:1px solid var(--line);
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{font-size:1.25rem;font-family:var(--serif)}
  .burger{display:block}
  .burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:52px;padding:0 28px;border-radius:var(--r);
  font-family:var(--sans);font-size:0.98rem;font-weight:600;text-decoration:none;
  transition:background .18s ease,color .18s ease,border-color .18s ease,transform .18s ease;
  border:1px solid transparent;cursor:pointer;
}
.btn:active{transform:translateY(1px)}
/* primary: solid cream on dark (both legacy names resolve identically) */
.btn-ink,.btn-cream{background:var(--cream);color:var(--ink)}
.btn-ink:hover,.btn-cream:hover{background:#fff}
.btn-line{background:transparent;color:var(--cream);border-color:var(--line-strong)}
.btn-line:hover{border-color:var(--cream)}
.btn-sm{min-height:44px;padding:0 20px;font-size:0.9rem}
.btn-wa svg{flex-shrink:0;color:#25D366}
.text-link{
  font-weight:600;font-size:0.95rem;color:var(--cream);text-decoration:underline;
  text-underline-offset:4px;text-decoration-color:var(--blue);text-decoration-thickness:2px;
}
.text-link:hover{color:#fff}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--bg-deep);overflow:hidden}
.hero-media{position:absolute;inset:0}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:50% 38%}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,19,17,0.46) 0%,rgba(20,19,17,0.22) 40%,rgba(33,32,29,0.94) 100%);
}
.hero-inner{position:relative;padding:clamp(120px,20vh,220px) 0 clamp(56px,9vw,96px)}
.hero h1{max-width:13ch}
.hero .lede{max-width:52ch;margin-top:22px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-note{margin-top:22px;font-size:0.85rem;color:var(--soft)}
.page-hero{
  background:var(--bg-deep);border-bottom:1px solid var(--line);
  padding:clamp(84px,12vw,140px) 0 clamp(48px,7vw,84px);
}
.page-hero h1{max-width:16ch}
.page-hero .lede{margin-top:18px;max-width:56ch}

/* ---------- signature panel (flyer offer panel) ---------- */
.panel{
  background:var(--panel);border-top:3px solid var(--blue);
  border-radius:var(--r);padding:clamp(28px,4.5vw,48px);
}
.panel .eyebrow{color:var(--blue)}

/* ---------- stats band ---------- */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-deep)}
.stats-inner{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(24px,6vw,84px);padding:30px 0;text-align:center}
.stat b{display:block;font-family:var(--serif);font-weight:600;font-size:clamp(1.7rem,3vw,2.2rem);line-height:1;color:var(--cream-2)}
.stat span{display:block;margin-top:6px;font-size:0.8rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--soft)}
.stars{color:var(--blue);letter-spacing:2px;font-size:0.95rem}

/* ---------- cards ---------- */
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:clamp(24px,3vw,34px);display:flex;flex-direction:column;gap:12px;
}
.card .bar{margin-bottom:6px}
.card p{color:var(--muted);font-size:0.98rem}
.card .text-link{margin-top:auto;padding-top:8px}

/* testimonials */
.testi{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:26px 26px 22px;display:flex;flex-direction:column;gap:14px;
}
.testi q{font-family:var(--serif);font-style:italic;font-size:1.02rem;line-height:1.5;quotes:"\201C" "\201D";color:var(--cream)}
.testi footer{border-top:1px solid var(--line);padding-top:12px;font-size:0.85rem;color:var(--muted)}
.testi footer b{display:block;font-weight:700;letter-spacing:0.02em;font-style:normal;color:var(--cream)}
.testi footer span{color:var(--soft)}
.badge{
  align-self:flex-start;background:var(--blue);color:var(--ink);border-radius:2px;
  font-size:0.68rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:4px 9px;
}

/* pricing tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,28px);align-items:stretch}
@media(max-width:920px){.tiers{grid-template-columns:1fr}}
.tier{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:clamp(26px,3vw,36px);display:flex;flex-direction:column;
}
.tier.featured{border-color:var(--blue);box-shadow:0 18px 48px -24px rgba(0,0,0,0.6)}
.tier .tag{align-self:flex-start;margin-bottom:14px;background:var(--blue);color:var(--ink);border-radius:2px;font-size:0.68rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:4px 9px}
.tier h3{font-size:1.25rem}
.tier .freq{margin-top:4px;font-size:0.9rem;color:var(--soft)}
.tier .price{margin:18px 0 4px;font-family:var(--serif);font-weight:600;font-size:2.1rem;line-height:1;color:var(--cream-2)}
.tier .per{font-size:0.85rem;color:var(--soft)}
.tier ul{list-style:none;margin:18px 0 22px;padding:0;display:flex;flex-direction:column;gap:10px}
.tier ul li{position:relative;padding-left:24px;font-size:0.94rem;color:var(--muted)}
.tier ul li::before{content:"";position:absolute;left:0;top:9px;width:12px;height:2px;background:var(--blue)}
.tier .btn{margin-top:auto}

/* ---------- how it works ---------- */
.steps{counter-reset:step;display:grid;gap:0}
.step{
  counter-increment:step;display:grid;grid-template-columns:64px 1fr;gap:20px;
  padding:26px 0;border-top:1px solid var(--line);
}
.step:last-child{border-bottom:1px solid var(--line)}
.step::before{
  content:counter(step,decimal-leading-zero);
  font-family:var(--serif);font-weight:500;font-size:1.5rem;color:var(--blue);line-height:1.3;
}
.step h3{font-size:1.12rem;margin-bottom:6px}
.step p{color:var(--muted);font-size:0.98rem;max-width:62ch}

/* ---------- value stack ---------- */
.stack{border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.stack-row{display:flex;justify-content:space-between;gap:18px;padding:16px 20px;border-top:1px solid var(--line);font-size:0.97rem;color:var(--muted)}
.stack-row:first-child{border-top:0}
.stack-row span:last-child{white-space:nowrap;color:var(--soft)}
.stack-total{background:rgba(122,184,212,0.14);font-weight:700;color:var(--cream)}
.stack-total span:last-child{color:var(--cream)}

/* ---------- media frames ---------- */
.frame{border-radius:var(--r);overflow:hidden;position:relative}
.frame img{width:100%;height:100%;object-fit:cover}
.frame-tall{aspect-ratio:4/5}
.frame-wide{aspect-ratio:3/2}
.frame-caption{
  position:absolute;left:0;right:0;bottom:0;padding:14px 18px;
  background:linear-gradient(180deg,rgba(20,19,17,0) 0%,rgba(20,19,17,0.78) 100%);
  color:var(--cream);font-size:0.8rem;letter-spacing:0.06em;text-transform:uppercase;font-weight:600;
}

/* ---------- faq ---------- */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:20px 2px;font-family:var(--serif);font-weight:500;font-size:1.08rem;color:var(--cream);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--sans);font-weight:400;font-size:1.4rem;color:var(--blue);transition:transform .2s ease}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .faq-a{padding:0 2px 22px;color:var(--muted);max-width:68ch}

/* ---------- forms ---------- */
.form{display:flex;flex-direction:column;gap:16px}
.field label{display:block;font-size:0.78rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:7px;color:var(--soft)}
.field input,.field select,.field textarea{
  width:100%;background:rgba(246,242,234,0.06);border:1px solid rgba(246,242,234,0.24);
  border-radius:var(--r);color:var(--cream);font-family:var(--sans);font-size:1rem;
  padding:14px 16px;transition:border-color .18s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23F6F2EA' stroke-width='1.6' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.field select option{color:var(--ink);background:#fff}
.form-note{font-size:0.82rem;color:var(--soft)}
.or-divider{display:flex;align-items:center;gap:14px;margin:8px 0}
.or-divider::before,.or-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.or-divider span{font-size:0.72rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--soft)}

/* ---------- footer ---------- */
.site-footer{background:var(--bg-deep);border-top:1px solid var(--line);padding:clamp(48px,7vw,80px) 0 32px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
@media(max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{font-family:var(--sans);font-size:0.74rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--soft);margin:0 0 14px}
.site-footer a{color:var(--muted);text-decoration:none;font-size:0.95rem}
.site-footer a:hover{color:var(--cream)}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-brand p{color:var(--soft);font-size:0.92rem;max-width:34ch;margin-top:10px}
.footer-bottom{
  margin-top:48px;padding-top:22px;border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;
  font-size:0.8rem;color:var(--soft);
}
.footer-bottom a{font-size:0.8rem;color:var(--soft)}

/* ---------- mobile sticky cta ---------- */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:55;display:none;
  background:rgba(26,25,23,0.97);backdrop-filter:blur(8px);
  padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  gap:10px;border-top:1px solid var(--line);
}
.sticky-cta .btn{flex:1;min-height:46px;font-size:0.9rem;padding:0 12px}
@media(max-width:720px){.sticky-cta{display:flex}body{padding-bottom:70px}}

/* ---------- reveal motion ---------- */
.rv{opacity:0;transform:translateY(14px);transition:opacity .65s ease,transform .65s ease}
.rv.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* ---------- utilities ---------- */
.center{text-align:center}
.center .bar{margin-left:auto;margin-right:auto}
.mt-1{margin-top:14px}.mt-2{margin-top:24px}.mt-3{margin-top:38px}.mt-4{margin-top:56px}
.maxw{max-width:66ch}
.center .maxw{margin-left:auto;margin-right:auto}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px}
.skip{position:absolute;left:-9999px;top:0;background:var(--cream);color:var(--ink);padding:10px 16px;z-index:99}
.skip:focus{left:12px;top:12px}
