/* AppointmentTurn — shared design system (matches the landing page) */
:root{
  --ink:#15161b; --ink-soft:#43464f; --ink-faint:#6f727b;
  --cream:#faf6ef; --cream-2:#f2eae0; --card:#fffdf9;
  --orange:#ff5a2c; --orange-deep:#df3f0e;
  --teal:#0d7d6c; --teal-soft:#e3f1ee;
  --line:rgba(21,22,27,.10); --line-strong:rgba(21,22,27,.16);
  --shadow:0 1px 2px rgba(21,22,27,.04), 0 12px 40px -16px rgba(21,22,27,.18);
  --radius:18px; --maxw:1080px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,sans-serif;color:var(--ink);background:var(--cream);line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
h1,h2,h3{font-family:"Bricolage Grotesque",sans-serif;line-height:1.06;letter-spacing:-.02em;font-weight:700}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--orange-deep);display:inline-flex;align-items:center;gap:8px}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--orange);display:inline-block}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 26px;border-radius:999px;font-weight:700;font-size:16px;border:1.5px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;font-family:inherit}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 8px 22px -8px rgba(255,90,44,.7)}
.btn-primary:hover{background:var(--orange-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:var(--cream)}
.btn-dark:hover{transform:translateY(-2px);background:#23252c}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(250,246,239,.82);backdrop-filter:saturate(150%) blur(12px);-webkit-backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.logo{font-family:"Bricolage Grotesque";font-weight:800;font-size:21px;letter-spacing:-.03em;display:flex;align-items:center;gap:9px}
.logo .dot{width:11px;height:11px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(255,90,44,.18)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a.lk{font-weight:500;color:var(--ink-soft);font-size:15.5px;transition:color .15s}
.nav-links a.lk:hover{color:var(--ink)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.25s}

/* Plan hero */
.phero{position:relative;padding:70px 0 60px;overflow:hidden}
.phero::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(820px 440px at 82% -10%,rgba(255,90,44,.14),transparent 60%),radial-gradient(680px 400px at 4% 12%,rgba(13,125,108,.10),transparent 60%);pointer-events:none}
.phero .wrap{position:relative;z-index:1}
.back{font-size:14.5px;font-weight:600;color:var(--ink-faint);display:inline-block;margin-bottom:22px}
.back:hover{color:var(--orange-deep)}
.phero h1{font-size:clamp(34px,5.4vw,56px);max-width:18ch;margin-top:10px}
.phero .who{font-size:18px;color:var(--ink-soft);margin-top:16px;max-width:54ch}
.price-row{display:flex;align-items:baseline;gap:12px;margin-top:30px}
.price-row .amt{font-family:"Bricolage Grotesque";font-weight:800;font-size:clamp(40px,6vw,58px);letter-spacing:-.03em}
.price-row .per{font-size:17px;color:var(--ink-faint);font-weight:600}
.price-row .tag{margin-left:6px;background:var(--teal-soft);color:var(--teal);font-size:13px;font-weight:700;padding:5px 12px;border-radius:999px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.facts{display:flex;gap:10px 14px;flex-wrap:wrap;margin-top:30px}
.fact{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:9px 16px;font-size:14px;font-weight:600;color:var(--ink-soft);box-shadow:var(--shadow)}
.fact b{color:var(--teal);font-weight:700}

section.block{padding:66px 0}
.sec-head{max-width:60ch}
.sec-head h2{font-size:clamp(27px,3.8vw,40px);margin-top:14px}
.sec-head p{color:var(--ink-soft);margin-top:14px;font-size:17px}

/* Feature grid */
.fgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px;margin-top:42px}
.fcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}
.fcard:hover{transform:translateY(-4px);box-shadow:0 18px 50px -22px rgba(21,22,27,.3)}
.fcard .ic{width:44px;height:44px;border-radius:12px;background:var(--teal-soft);color:var(--teal);display:flex;align-items:center;justify-content:center;font-size:20px;font-family:"Bricolage Grotesque";font-weight:800}
.fcard h3{font-size:18px;margin:16px 0 7px}
.fcard p{font-size:15px;color:var(--ink-soft)}

/* Included checklist */
.included{background:var(--cream-2)}
.checklist{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;margin-top:36px}
.checklist li{list-style:none;display:flex;gap:12px;align-items:flex-start;font-size:16px;color:var(--ink-soft)}
.checklist li::before{content:"";flex:0 0 22px;height:22px;margin-top:1px;border-radius:50%;background:var(--teal-soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%230d7d6c' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.checklist li b{color:var(--ink);font-weight:600}

/* FAQ */
.faq{max-width:760px;margin:38px auto 0}
details{border-bottom:1px solid var(--line);padding:20px 0}
summary{font-family:"Bricolage Grotesque";font-weight:600;font-size:18px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-size:24px;color:var(--orange);font-weight:400;transition:transform .2s}
details[open] summary::after{transform:rotate(45deg)}
details p{color:var(--ink-soft);margin-top:13px;font-size:16px}

/* Final CTA */
.final{background:var(--ink);color:var(--cream);border-radius:28px;margin:0 24px 70px;padding:64px 36px;text-align:center;position:relative;overflow:hidden}
.final::before{content:"";position:absolute;inset:0;background:radial-gradient(640px 340px at 50% -20%,rgba(255,90,44,.28),transparent 60%)}
.final .inner{position:relative;z-index:1}
.final h2{color:#fff;font-size:clamp(28px,4.2vw,44px);max-width:18ch;margin:0 auto}
.final p{color:rgba(250,246,239,.74);margin:16px auto 28px;max-width:50ch}

footer{padding:48px 0 38px;border-top:1px solid var(--line)}
.foot-grid{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot-grid .col h4{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:14px}
.foot-grid .col a{display:block;color:var(--ink-soft);font-size:15px;margin-bottom:9px}
.foot-grid .col a:hover{color:var(--orange-deep)}
.foot-bottom{margin-top:38px;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:var(--ink-faint);font-size:14px}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

@media (max-width:760px){
  .nav-links{position:fixed;inset:70px 0 auto 0;background:var(--cream);flex-direction:column;gap:0;padding:10px 24px 24px;border-bottom:1px solid var(--line);display:none}
  .nav-links.open{display:flex}
  .nav-links a.lk{padding:14px 0;width:100%;border-bottom:1px solid var(--line)}
  .nav-links .btn{width:100%;margin-top:14px}
  .menu-toggle{display:block}
  .checklist{grid-template-columns:1fr}
  section.block{padding:50px 0}
  .final{margin:0 16px 52px;padding:48px 22px}
}
/* ---- Landing page components ---- */
.hero{position:relative;padding:84px 0 76px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(900px 460px at 78% -8%,rgba(255,90,44,.14),transparent 60%),radial-gradient(720px 420px at 6% 14%,rgba(13,125,108,.10),transparent 60%);pointer-events:none}
.hero .wrap{position:relative;z-index:1}
.hero h1{font-size:clamp(38px,6vw,68px);max-width:16ch}
.hero h1 .hl{color:var(--orange-deep);white-space:nowrap}
.hero p.lede{font-size:clamp(18px,2.2vw,21px);color:var(--ink-soft);max-width:60ch;margin-top:22px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.pill{display:inline-flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-size:14px;font-weight:600;color:var(--ink-soft);margin-bottom:26px;box-shadow:var(--shadow)}
.pill b{color:var(--teal);font-weight:700}
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:58px;border-top:1px solid var(--line);padding-top:34px}
.stat .num{font-family:"Bricolage Grotesque";font-weight:800;font-size:clamp(28px,4vw,42px);letter-spacing:-.03em}
.stat .num.o{color:var(--orange-deep)}
.stat .num.t{color:var(--teal)}
.stat .lbl{font-size:14px;color:var(--ink-faint);margin-top:4px}
.trust{padding:30px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--cream-2)}
.trust .wrap{display:flex;align-items:center;justify-content:center;gap:14px 44px;flex-wrap:wrap}
.trust span.t-lbl{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-weight:700}
.trust b{font-family:"Bricolage Grotesque";font-weight:700;font-size:18px;color:var(--ink-soft);opacity:.8}
.prob{background:var(--ink);color:var(--cream)}
.prob .eyebrow{color:#ff8a63}.prob .eyebrow::before{background:#ff8a63}
.prob h2{color:#fff}
.prob p{color:rgba(250,246,239,.72)}
.prob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.prob-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:28px}
.prob-card .big{font-family:"Bricolage Grotesque";font-weight:800;font-size:40px;color:#ff8a63;letter-spacing:-.03em}
.prob-card h3{font-size:18px;margin:10px 0 8px;color:#fff}
.prob-card p{font-size:15px;color:rgba(250,246,239,.66)}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-top:48px;counter-reset:step}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;position:relative;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}
.step:hover{transform:translateY(-4px);box-shadow:0 18px 50px -22px rgba(21,22,27,.3)}
.step .n{counter-increment:step;font-family:"Bricolage Grotesque";font-weight:800;font-size:15px;color:#fff;background:var(--orange);width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center}
.step .n::before{content:"0" counter(step)}
.step h3{font-size:18px;margin:18px 0 8px}
.step p{font-size:15px;color:var(--ink-soft)}
.demo{background:var(--cream-2)}
.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:46px}
.video-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.video-frame{position:relative;aspect-ratio:16/9;background:linear-gradient(135deg,#1c1e25,#2b2e38);display:flex;align-items:center;justify-content:center}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.play{width:74px;height:74px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px -8px rgba(255,90,44,.8)}
.play::after{content:"";border-left:22px solid #fff;border-top:13px solid transparent;border-bottom:13px solid transparent;margin-left:6px}
.video-frame .ph-text{position:absolute;bottom:16px;left:18px;color:rgba(255,255,255,.8);font-size:13.5px;font-weight:600;letter-spacing:.02em}
.video-meta{padding:22px 24px}
.video-meta .tag{font-size:12.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--teal)}
.video-meta h3{font-size:20px;margin:8px 0 6px}
.video-meta p{font-size:15px;color:var(--ink-soft)}
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:50px;align-items:stretch}
.price-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;display:flex;flex-direction:column;box-shadow:var(--shadow);transition:transform .2s}
.price-card:hover{transform:translateY(-5px)}
.price-card.feat{border:1.5px solid var(--orange);box-shadow:0 24px 60px -28px rgba(255,90,44,.6);position:relative}
.price-card.feat .badge{position:absolute;top:-13px;left:26px;background:var(--orange);color:#fff;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 13px;border-radius:999px}
.price-card .tier{font-family:"Bricolage Grotesque";font-weight:700;font-size:20px}
.price-card .amt{font-family:"Bricolage Grotesque";font-weight:800;font-size:42px;letter-spacing:-.03em;margin-top:14px}
.price-card .amt span{font-size:16px;font-weight:600;color:var(--ink-faint);font-family:"Hanken Grotesk"}
.price-card .who{font-size:14.5px;color:var(--ink-faint);margin-top:4px;min-height:22px}
.price-card ul{list-style:none;margin:22px 0 26px;display:flex;flex-direction:column;gap:11px}
.price-card li{font-size:14.5px;color:var(--ink-soft);display:flex;gap:10px;align-items:flex-start}
.price-card li::before{content:"";flex:0 0 18px;height:18px;margin-top:2px;border-radius:50%;background:var(--teal-soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%230d7d6c' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.price-card .btn{margin-top:auto;width:100%}
.price-note{text-align:center;color:var(--ink-faint);font-size:14px;margin-top:24px}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:46px}
.why-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;display:flex;gap:18px}
.why-card .ic{flex:0 0 46px;height:46px;border-radius:12px;background:var(--teal-soft);display:flex;align-items:center;justify-content:center;color:var(--teal);font-weight:800;font-family:"Bricolage Grotesque";font-size:20px}
.why-card h3{font-size:18px;margin-bottom:6px}
.why-card p{font-size:15px;color:var(--ink-soft)}
@media (max-width:900px){
  .stat-strip{grid-template-columns:repeat(2,1fr);gap:28px}
  .prob-grid{grid-template-columns:1fr}
  .demo-grid{grid-template-columns:1fr}
  .price-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  .price-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

/* ---- Waitlist / SMS opt-in form ---- */
.waitlist{background:var(--cream-2)}
.wl-form{max-width:560px;margin:36px auto 0;display:flex;flex-direction:column;gap:14px}
.wl-row{display:flex;gap:14px}
.wl-form input[type=text],.wl-form input[type=email],.wl-form input[type=tel]{flex:1;width:100%;font-family:inherit;font-size:16px;padding:14px 16px;border:1.5px solid var(--line-strong);border-radius:12px;background:var(--card);color:var(--ink)}
.wl-form input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,90,44,.15)}
.wl-consent{display:flex;gap:12px;align-items:flex-start;font-size:13.5px;line-height:1.5;color:var(--ink-soft);text-align:left;cursor:pointer;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.wl-consent input[type=checkbox]{flex:0 0 20px;width:20px;height:20px;margin-top:1px;accent-color:var(--orange);cursor:pointer}
.wl-form .btn{width:100%}
.wl-msg{text-align:center;font-size:14.5px;font-weight:600;min-height:20px;margin:0}
.wl-fine{text-align:center;font-size:13px;color:var(--ink-faint);margin-top:16px}
.wl-fine a{color:var(--ink-soft);text-decoration:underline}
.wl-fine a:hover{color:var(--orange-deep)}
@media (max-width:560px){.wl-row{flex-direction:column}}

/* Terms/Privacy consent gate on pricing pages */
.trial-consent-block{max-width:520px;margin:24px 0 6px}
