/* The Coach in Your Pocket — microsite
   Quiet Ledger brand system. Self-contained (tokens inlined). */

:root {
  --paper:#FBFAF7; --paper-tint:#F3F1EB; --paper-card:#FFFFFF;
  --ink:#2A2A28; --ink-soft:#5C5A54; --ink-mute:#6E6B64; --hairline:#ECE8DF;
  --terracotta:#C6613F;        /* MARKS ONLY (rule, caret, tags, SVG) — large/graphical, AA-ok */
  --terracotta-tint:#FFF6F2;
  --terracotta-deep:#8A5A44;   /* TEXT + buttons — passes AA 4.5:1 on paper */
  --terracotta-hover:#6F4636;
  --green:#12A277; --green-deep:#0E7D5C; --blue:#40638F; --amber:#E0A94E;
  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-mono:"IBM Plex Mono",ui-monospace,Menlo,Consolas,monospace;
  --measure:64ch; --radius:14px; --maxw:1060px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top:68px}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--font-body); font-size:18px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img,svg{max-width:100%; height:auto; display:block}
a{color:var(--terracotta-deep); text-underline-offset:3px; text-decoration-thickness:1px}
a:hover{color:var(--terracotta-hover)}

.wrap{max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(1.1rem,4vw,2rem)}
section{padding-block:clamp(3rem,7vw,5.5rem)}
.tint{background:var(--paper-tint)}

/* Type */
h1,h2,h3{font-family:var(--font-display); font-weight:600; line-height:1.08; letter-spacing:-0.01em; margin:0 0 .5em}
h1{font-size:clamp(2.5rem,6.2vw,4.2rem); line-height:1.02}
h2{font-size:clamp(1.7rem,3.4vw,2.3rem)}
h3{font-size:1.28rem; line-height:1.2}
p{margin:0 0 1rem; max-width:var(--measure)}
.lead{font-size:clamp(1.15rem,2.2vw,1.4rem); line-height:1.5; color:var(--ink-soft)}
.eyebrow{font-family:var(--font-body); font-weight:700; font-size:.78rem; text-transform:uppercase; letter-spacing:.09em; color:var(--terracotta-deep); margin:0 0 .8rem}
.muted{color:var(--ink-mute)}
.center{text-align:center; margin-inline:auto}
.center p{margin-inline:auto}

/* The house signature: terracotta rule */
.rule::after{content:""; display:block; width:52px; height:3px; background:var(--terracotta); border-radius:2px; margin-top:.7rem}
.center.rule::after{margin-inline:auto}

/* Header */
header.site{position:sticky; top:0; z-index:20; background:color-mix(in srgb,var(--paper) 88%, transparent); backdrop-filter:blur(8px); border-bottom:1px solid var(--hairline)}
.nav{display:flex; align-items:center; justify-content:space-between; gap:1rem; padding-block:.7rem}
.brand{display:flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-weight:600; font-size:1.05rem; color:var(--ink); text-decoration:none}
.brand svg{width:30px; height:30px}
.nav-links{display:flex; gap:1.4rem; align-items:center; font-size:.92rem}
.nav-links a:not(.btn){color:var(--ink-soft); text-decoration:none}
.nav-links a:not(.btn):hover{color:var(--terracotta-deep)}
.nav-links .btn{padding:.45rem .9rem}
@media(max-width:640px){ .nav-links a:not(.btn){display:none} }

/* Buttons */
.btn{display:inline-flex; align-items:center; gap:.5rem; font-family:var(--font-body); font-weight:600; font-size:1rem; border-radius:10px; padding:.85rem 1.4rem; text-decoration:none; cursor:pointer; border:1.5px solid transparent; transition:transform .06s ease, background .15s ease}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--terracotta-deep); color:#fff}
.btn-primary:hover{background:var(--terracotta-hover); color:#fff}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--hairline)}
.btn-ghost:hover{border-color:var(--terracotta); color:var(--terracotta-deep)}
.cta-row{display:flex; flex-wrap:wrap; gap:.8rem; align-items:center}
.cta-note{font-size:.85rem; color:var(--ink-mute); font-family:var(--font-mono)}

/* Hero */
.hero{padding-top:clamp(2.5rem,5vw,4rem)}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(1.5rem,4vw,3rem); align-items:center}
@media(max-width:860px){ .hero-grid{grid-template-columns:1fr} }
.hero h1{margin-bottom:.3em}

/* Conversation card — the hero device */
.convo{background:var(--paper-card); border:1px solid var(--hairline); border-radius:var(--radius); padding:1.2rem 1.3rem; box-shadow:0 1px 0 var(--hairline); font-size:1rem}
.convo .q{font-family:var(--font-mono); color:var(--ink); margin:0 0 .6rem; display:flex; gap:.5rem}
.convo .q .caret{color:var(--terracotta); font-weight:700}
.convo .a{color:var(--ink-soft); margin:0; padding-left:1.05rem; border-left:2px solid var(--terracotta-tint)}
.convo + .convo{margin-top:.8rem}
.convo .fig{font-family:var(--font-mono); color:var(--ink); font-weight:500; font-variant-numeric:tabular-nums}

/* Receipt row — dotted-leader list */
.receipt{font-family:var(--font-mono); font-size:.98rem; max-width:var(--measure)}
.receipt li{display:flex; align-items:baseline; gap:.5rem; padding:.5rem 0; border:0; list-style:none}
.receipt li .lbl{white-space:nowrap}
.receipt li .dots{flex:1; border-bottom:1.5px dotted var(--ink-mute); transform:translateY(-.25em); min-width:1.5rem}
.receipt li .val{white-space:nowrap; color:var(--ink); font-weight:500}
ul.receipt{padding:0; margin:0}

/* Honest note — left-border callout */
.honest{border-left:3px solid var(--terracotta); background:var(--terracotta-tint); border-radius:0 10px 10px 0; padding:1.1rem 1.3rem; max-width:var(--measure)}
.honest .h-label{font-family:var(--font-body); font-weight:700; font-size:.75rem; text-transform:uppercase; letter-spacing:.09em; color:var(--terracotta-deep); margin:0 0 .4rem}
.honest p{margin:0; color:var(--terracotta-deep)}
.honest.blue{border-left-color:var(--blue); background:#F1F5FA}
.honest.blue .h-label,.honest.blue p{color:#33507a}

/* Cards / grids */
.cards{display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1rem}
.card{background:var(--paper-card); border:1px solid var(--hairline); border-radius:var(--radius); padding:1.3rem}
.card h3{margin-top:0}
.card .tag{font-family:var(--font-body); font-weight:700; font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; padding:.2rem .5rem; border-radius:6px; display:inline-block; margin-bottom:.6rem}
.tag.green{color:var(--green-deep); background:#E7F4EF}
.tag.terra{color:var(--terracotta-deep); background:var(--terracotta-tint)}
.two-col{display:grid; grid-template-columns:1fr 1fr; gap:1rem}
@media(max-width:720px){ .two-col{grid-template-columns:1fr} }

/* index numbers */
.numbered{display:grid; gap:1.1rem}
.numbered .row{display:grid; grid-template-columns:auto 1fr; gap:1rem; align-items:start; max-width:var(--measure)}
.numbered .n{font-family:var(--font-mono); color:var(--terracotta); font-weight:600; font-size:.95rem; padding-top:.15rem}
.numbered .row p{margin:0}
.numbered .row strong{font-weight:600}

/* Pricing */
.price-card{background:var(--paper-card); border:1px solid var(--hairline); border-radius:18px; padding:clamp(1.4rem,3vw,2.2rem); max-width:520px; margin-inline:auto; box-shadow:0 2px 0 var(--hairline)}
.price-big{font-family:var(--font-display); font-size:3rem; font-weight:600; line-height:1}
.price-big .sub{font-family:var(--font-mono); font-size:1rem; color:var(--ink-mute); font-weight:400}
.price-card .btn-primary{width:100%; justify-content:center; margin-top:1rem; font-size:1.05rem; padding-block:1rem}

/* Author block */
.author{display:grid; grid-template-columns:auto 1fr; gap:1.3rem; align-items:center; max-width:var(--measure)}
.author .avatar{width:96px; height:96px; border-radius:50%; background:var(--paper-tint); border:1px solid var(--hairline); display:flex; align-items:center; justify-content:center; color:var(--ink-mute); font-family:var(--font-mono); font-size:.7rem; text-align:center; object-fit:cover}
@media(max-width:520px){ .author{grid-template-columns:1fr} }

/* Email capture */
.capture{display:flex; gap:.6rem; flex-wrap:wrap; max-width:480px}
.capture input[type=email]{flex:1; min-width:200px; padding:.85rem 1rem; border:1.5px solid var(--hairline); border-radius:10px; font-family:var(--font-body); font-size:1rem; background:var(--paper-card); color:var(--ink)}
.capture input[type=email]:focus{outline:none; border-color:var(--terracotta)}

/* FAQ */
details{border-bottom:1px solid var(--hairline); padding:1rem 0; max-width:var(--measure)}
details summary{font-family:var(--font-display); font-weight:600; font-size:1.15rem; cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:1rem}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"+"; color:var(--terracotta); font-family:var(--font-mono); font-weight:600}
details[open] summary::after{content:"–"}
details p{margin:.8rem 0 0; color:var(--ink-soft)}

/* Diagram figure */
figure.diagram{margin:1.5rem 0 0; max-width:var(--measure)}
figure.diagram img{border-radius:var(--radius); border:1px solid var(--hairline)}
figure.diagram figcaption{font-size:.85rem; color:var(--ink-mute); margin-top:.5rem; font-family:var(--font-mono)}

/* Footer */
footer.site{border-top:1px solid var(--hairline); background:var(--paper-tint); font-size:.9rem}
footer.site .cols{display:flex; flex-wrap:wrap; justify-content:space-between; gap:1.5rem; padding-block:2.5rem 1.2rem}
footer.site a{color:var(--ink-soft); text-decoration:none}
footer.site a:hover{color:var(--terracotta)}
.disclaimer{color:var(--ink-mute); font-size:.82rem; border-top:1px solid var(--hairline); padding-block:1.2rem; max-width:none}

.stack-sm > * + *{margin-top:.6rem}
.mt-2{margin-top:1.4rem}
.hero .cta-row{margin-top:1.6rem}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0}

/* Hero conversation reveal: question pops in → typing dots → reply fades up.
   Opacity/transform only (no layout reflow); degrades to all-visible without JS or with reduced-motion. */
.typing{display:none; gap:6px; align-items:center; padding:.4rem 0 .2rem 1.05rem}
.typing span{width:7px; height:7px; border-radius:50%; background:var(--ink-mute); opacity:.35}
body.anim-on .convo .q,
body.anim-on .convo .a{opacity:0; transform:translateY(8px) scale(.99); transition:opacity .5s ease, transform .55s cubic-bezier(.2,.9,.25,1)}
body.anim-on .convo .q.show,
body.anim-on .convo .a.show{opacity:1; transform:none}
body.anim-on .convo .typing.show{display:flex}
body.anim-on .convo .typing.show span{animation:tblink 1.1s infinite ease-in-out}
body.anim-on .convo .typing.show span:nth-child(2){animation-delay:.18s}
body.anim-on .convo .typing.show span:nth-child(3){animation-delay:.36s}
@keyframes tblink{0%,72%,100%{opacity:.3; transform:translateY(0)} 36%{opacity:.95; transform:translateY(-4px)}}
@media (prefers-reduced-motion: reduce){
  body.anim-on .convo .q, body.anim-on .convo .a{opacity:1 !important; transform:none !important; transition:none}
}
