/* Bilby marketing site — all styling.
   Colours & fonts come exclusively from css/tokens.css via var(--…).
   Translucent fills/shadows are derived from tokens with color-mix(), never raw hex. */

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--font-display);line-height:1.12;letter-spacing:-0.005em}
img{max-width:100%;display:block}
a{color:inherit}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.eyebrow{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--green);font-weight:700}

/* Accessibility: skip link + visible focus */
.skip{position:absolute;left:-9999px;top:0;background:var(--green);color:var(--bg);padding:10px 16px;border-radius:0 0 10px 0;z-index:200;font-weight:700;text-decoration:none}
.skip:focus{left:0}
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,select:focus-visible{
  outline:3px solid var(--green);outline-offset:2px;border-radius:4px}

/* Buttons */
.btn{display:inline-block;background:var(--green);color:var(--bg);text-decoration:none;font-weight:700;font-size:15.5px;padding:13px 26px;border-radius:999px;border:1.5px solid var(--green);cursor:pointer;transition:transform .15s ease, box-shadow .15s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px -10px color-mix(in srgb,var(--green) 50%,transparent)}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn.ghost:hover{box-shadow:none}

/* ---------- Nav ---------- */
nav{position:sticky;top:0;background:color-mix(in srgb,var(--bg) 94%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);z-index:50}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:66px;gap:18px}
.logo{font-family:var(--font-display);font-weight:700;font-size:23px;display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--ink)}
.logo .dot{width:11px;height:11px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px var(--green-soft);flex-shrink:0}
.nav-links{display:flex;gap:28px;font-size:15px;font-weight:600;color:var(--ink-soft);list-style:none}
.nav-links a{text-decoration:none;color:inherit}
.nav-links a:hover{color:var(--ink)}
.nav-cta{display:inline-block}
.nav-toggle{display:none;background:none;border:1.5px solid var(--line);border-radius:10px;padding:8px 10px;cursor:pointer;color:var(--ink)}
.nav-toggle svg{display:block}

/* ---------- Hero ---------- */
.hero-bg{background:linear-gradient(180deg,var(--bg-soft),var(--bg) 85%)}
.hero{padding:88px 0 72px;display:grid;grid-template-columns:1.02fr .98fr;gap:60px;align-items:center}
.hero h1{font-size:clamp(38px,4.8vw,60px);font-weight:600}
.hero h1 em{font-style:italic;color:var(--green)}
.hero p.lede{font-size:19px;color:var(--ink-soft);max-width:48ch;margin:22px 0 30px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px;align-items:center}
.hero-proof{display:flex;align-items:center;gap:10px;font-size:14.5px;color:var(--ink-soft)}
.hero-proof .chip{background:var(--green-soft);color:var(--green-deep);font-weight:700;font-size:13px;padding:4px 12px;border-radius:99px}

/* Hero artifacts: SMS thread + morning brief */
.stage{position:relative;min-height:480px}
.phone{position:relative;z-index:2;width:min(330px,86%);background:var(--bg);border:1px solid var(--line);border-radius:24px;box-shadow:0 30px 70px -30px color-mix(in srgb,var(--ink) 30%,transparent);padding:18px 16px 16px}
.phone-head{display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:1px solid var(--line);margin-bottom:12px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--green-soft);color:var(--green-deep);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.phone-head .who{font-weight:700;font-size:14.5px}
.phone-head .sub{font-size:12px;color:var(--ink-soft)}
.msgs{display:flex;flex-direction:column;gap:9px;font-size:13.8px}
.msg{max-width:88%;padding:9px 13px;border-radius:16px}
.msg.out{background:var(--green-soft);color:var(--green-deep);border-bottom-left-radius:5px;align-self:flex-start}
.msg.in{background:var(--blue-soft);color:var(--ink-blue);border-bottom-right-radius:5px;align-self:flex-end}
.brief{position:absolute;z-index:3;right:0;bottom:-6px;width:min(300px,80%);background:var(--bg);border:1px solid var(--line);border-left:5px solid var(--green);border-radius:16px;box-shadow:0 24px 60px -28px color-mix(in srgb,var(--ink) 35%,transparent);padding:18px 20px}
.brief .b-eyebrow{font-family:var(--font-data);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.brief h3{font-size:18px;margin:6px 0 10px}
.brief ul{list-style:none;font-size:14px;color:var(--ink-soft);display:flex;flex-direction:column;gap:6px}
.brief ul li b{color:var(--ink)}
.brief .total{margin-top:12px;padding-top:11px;border-top:1px dashed var(--line);font-weight:700;font-size:15px;color:var(--green-deep)}

/* JS-on entrance animation for the hero messages (reduced-motion + no-JS safe) */
.js .anim .msg{opacity:0;animation:pop .45s ease forwards}
.js .anim .msg:nth-child(1){animation-delay:.3s}
.js .anim .msg:nth-child(2){animation-delay:1.1s}
.js .anim .msg:nth-child(3){animation-delay:1.9s}
.js .anim .msg:nth-child(4){animation-delay:2.7s}
@keyframes pop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .js .anim .msg{animation:none;opacity:1}
  .btn:hover,.agent:hover{transform:none}
}

/* ---------- PMS strip ---------- */
.pms{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg);padding:20px 0}
.pms-in{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center;font-size:14px;color:var(--ink-soft)}
.pms-in .p{font-weight:700;color:var(--ink);background:var(--bg-soft);border:1px solid var(--line);padding:7px 16px;border-radius:99px;font-size:14px}

/* ---------- Sections ---------- */
section{padding:88px 0}
.sec-head{max-width:64ch;margin-bottom:46px}
.sec-head h2{font-size:clamp(28px,3.4vw,42px);font-weight:600;margin:14px 0 14px}
.sec-head p{color:var(--ink-soft);font-size:18px}

/* Numbers band */
.nums{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.num-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.num-card .n{font-family:var(--font-display);font-size:42px;font-weight:700;color:var(--green-deep)}
.num-card p{font-size:15px;color:var(--ink-soft);margin-top:6px}

/* Agents */
.agents{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.agent{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:0 0 32px;overflow:hidden;transition:box-shadow .2s ease}
.agent:hover{box-shadow:0 18px 44px -24px color-mix(in srgb,var(--ink) 22%,transparent)}
.agent img{width:100%;height:auto;aspect-ratio:4 / 3;object-fit:cover;border-bottom:1px solid var(--line);background:var(--bg-soft)}
.agent .agent-body{padding:28px 32px 0}
.agent .role{font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--green-deep);font-weight:700;background:var(--green-soft);padding:5px 12px;border-radius:99px;display:inline-block;margin-bottom:16px}
.agent h3{font-size:23px;margin-bottom:10px;font-weight:600}
.agent p{color:var(--ink-soft);font-size:15.5px}
.agent .outcome{margin-top:18px;padding-top:16px;border-top:1px dashed var(--line);font-size:14.5px;font-weight:700}
.agent .outcome span{color:var(--green)}

/* Testimonial */
.quote{background:var(--bg-soft);border-radius:24px;padding:64px;display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:start}
.quote .mark{font-family:var(--font-display);font-size:90px;line-height:.7;color:var(--green);font-weight:700}
.quote blockquote{font-family:var(--font-display);font-size:clamp(21px,2.4vw,27px);line-height:1.45;font-weight:500}
.quote .attr{margin-top:18px;font-family:var(--font-body);font-size:15px;color:var(--ink-soft)}
.quote .attr b{color:var(--ink)}
.pilot-tag{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--amber-ink);background:var(--amber-soft);padding:5px 12px;border-radius:99px;margin-bottom:18px}

/* Growth module */
.growth-wrap{background:var(--bg-soft);border-radius:24px;padding:64px}
.growth-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:42px}
.g-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:32px}
.g-card .g-tag{font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;padding:5px 12px;border-radius:99px;display:inline-block;margin-bottom:16px}
.g-card.consult .g-tag{background:var(--blue-soft);color:var(--blue)}
.g-card.campaign .g-tag{background:var(--green-soft);color:var(--green-deep)}
.g-card h3{font-size:23px;font-weight:600;margin-bottom:10px}
.g-card p{color:var(--ink-soft);font-size:15.5px;margin-bottom:14px}
.g-card ul{list-style:none;font-size:14.8px;color:var(--ink-soft);display:flex;flex-direction:column;gap:8px}
.g-card ul li::before{content:"→  ";color:var(--green);font-weight:700}
.radar{margin-top:22px;background:var(--bg);border:1px solid var(--line);border-left:5px solid var(--blue);border-radius:16px;padding:22px 26px;display:grid;grid-template-columns:repeat(3,1fr) 1.4fr;gap:18px;align-items:center}
.radar .r-item .r-n{font-family:var(--font-display);font-size:26px;font-weight:700}
.radar .r-item .r-l{font-size:12.5px;color:var(--ink-soft)}
.radar .r-play{background:var(--blue-soft);border-radius:12px;padding:14px 16px;font-size:13.8px;color:var(--ink-blue)}
.radar .r-play b{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;color:var(--blue)}
.ahpra-ribbon{margin-top:22px;display:flex;gap:14px;align-items:flex-start;background:var(--bg);border:1px dashed var(--green);border-radius:14px;padding:18px 22px;font-size:14.5px;color:var(--ink-soft)}
.ahpra-ribbon .shield{font-size:20px;line-height:1.2}
.ahpra-ribbon b{color:var(--ink)}

/* Compliance */
.compliance{background:var(--green-deep);border-radius:24px}
.compliance .inner{padding:64px;display:grid;grid-template-columns:1fr 1fr;gap:56px}
.compliance .eyebrow{color:var(--green-light)}
.compliance h2{color:var(--bg);font-size:clamp(26px,3vw,38px);margin:14px 0 16px;font-weight:600}
.compliance p{color:var(--on-deep);font-size:16.5px}
.rule-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.rule-list li{display:flex;gap:14px;font-size:15.5px;color:var(--on-deep);background:color-mix(in srgb,var(--bg) 6%,transparent);border:1px solid color-mix(in srgb,var(--bg) 10%,transparent);border-radius:12px;padding:16px 18px}
.rule-list .ic{color:var(--green-light);font-weight:700;flex-shrink:0}
.fine{font-size:12.5px;color:var(--on-deep-soft);margin-top:22px}

/* Pricing */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tier{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:34px;display:flex;flex-direction:column}
.tier.feature{border:2px solid var(--green);position:relative}
.tier.feature::after{content:"Most clinics choose this";position:absolute;top:-14px;left:24px;background:var(--green);color:var(--bg);font-size:12.5px;font-weight:700;padding:4px 14px;border-radius:99px}
.tier h3{font-size:20px;margin-bottom:6px;font-weight:600}
.tier .price{font-family:var(--font-display);font-size:40px;font-weight:700;margin:10px 0 2px}
.tier .per{font-size:13.5px;color:var(--ink-soft);margin-bottom:20px}
.tier ul{list-style:none;font-size:15px;color:var(--ink-soft);display:flex;flex-direction:column;gap:9px;margin-bottom:26px}
.tier ul li::before{content:"✓  ";color:var(--green);font-weight:700}
.tier .btn{margin-top:auto}
.addon{margin-top:22px;background:var(--blue-soft);color:var(--ink-blue);border-radius:14px;padding:18px 22px;font-size:15px;font-weight:600;text-align:center}
.guarantee{margin-top:22px;background:var(--amber-soft);color:var(--amber-ink);border-radius:14px;padding:18px 22px;font-size:15px;font-weight:600;text-align:center}

/* Final / contact */
.final{background:var(--green-soft);border-radius:24px;text-align:center;padding:76px 32px}
.final h2{font-size:clamp(28px,3.4vw,40px);margin-bottom:14px;font-weight:600}
.final p{color:var(--ink-soft);max-width:54ch;margin:0 auto 30px}
.contact-form{max-width:520px;margin:0 auto;text-align:left;display:grid;gap:16px}
.contact-form .field{display:flex;flex-direction:column;gap:6px}
.contact-form label{font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--ink)}
.contact-form label .opt{font-weight:500;color:var(--ink-soft);letter-spacing:0}
.contact-form input,.contact-form select{font-family:var(--font-body);font-size:16px;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:12px 14px;width:100%}
.contact-form .actions{margin-top:6px;display:flex;flex-direction:column;gap:12px;align-items:center}
.contact-form .btn{width:100%;text-align:center}
.form-alt{font-size:14px;color:var(--ink-soft);text-align:center}
.form-alt a{color:var(--green);font-weight:700}
.form-status{font-size:15px;font-weight:600;color:var(--green-deep);background:var(--green-soft);border:1px solid var(--green);border-radius:12px;padding:16px 18px;text-align:center}
[hidden]{display:none !important}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--line);padding:34px 0;font-size:13.5px;color:var(--ink-soft)}
.footer-in{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;align-items:center}
.footer-in a{color:var(--ink-soft);text-decoration:underline;text-underline-offset:2px}
.footer-in a:hover{color:var(--ink)}
.footer-compliance{margin-top:14px;font-size:12.5px;color:var(--ink-soft)}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;padding-top:52px}
  .stage{min-height:520px;margin-top:10px}
  .agents,.tiers,.nums,.growth-grid{grid-template-columns:1fr}
  .compliance .inner{grid-template-columns:1fr;padding:40px 28px}
  .quote{grid-template-columns:1fr;padding:40px 28px}
  .growth-wrap{padding:40px 28px}
  .radar{grid-template-columns:1fr 1fr}
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:inline-flex}
  /* Mobile menu: shown when JS toggles [data-open], or always reachable without JS */
  .nav-links.open{display:flex;position:absolute;top:66px;left:0;right:0;flex-direction:column;gap:0;background:var(--bg);border-bottom:1px solid var(--line);padding:8px var(--gutter) 16px}
  .nav-links.open li{padding:10px 0;border-bottom:1px solid var(--line)}
  .nav-links.open li:last-child{border-bottom:none}
}
@media(max-width:560px){
  section{padding:60px 0}
  .quote,.growth-wrap,.compliance .inner,.final{padding-left:24px;padding-right:24px}
  .compliance .inner,.growth-wrap{padding-top:36px;padding-bottom:36px}
  .radar{grid-template-columns:1fr}
}

/* No-JS fallback: the mobile menu must still be usable.
   When JS is absent the toggle is hidden and links are shown stacked. */
.no-js .nav-toggle{display:none}
@media(max-width:900px){
  .no-js .nav-links{display:flex;flex-wrap:wrap;gap:16px;font-size:14px}
}
