/* ── tokens ─────────────────────────────────────────── */
:root{
  --bone:#F8F5EF; --surface:#FFFFFF; --surface-alt:#F3EFF8;
  --lavender:#B6A6D6; --lavender-deep:#6C5AA0; --lavender-night:#3F3563;
  --sage:#9FC6A9; --peach:#F0B8A8; --butter:#F3E2B3;
  --ink:#3A3645; --muted:#6E6878; --divider:#EBE6EF;
  --night:#161519; --night-surface:#211F26; --night-ink:#EFEAF3; --night-muted:#B0A8BC;
  --r-card:24px;
  --r-xs:8px; --r-sm:14px; --r-md:18px; --r-lg:24px; --r-frame:30px;
  --shadow-sm:0 16px 40px rgba(58,54,69,.08);
  --shadow-md:0 24px 60px rgba(58,54,69,.10);
  --shadow-lg:0 30px 64px rgba(58,54,69,.20);
  --shadow-cta:0 10px 30px rgba(108,90,160,.35);
  --shadow-cta-hover:0 14px 36px rgba(108,90,160,.45);
  --serif:"Fraunces",Georgia,serif; --hand:"Caveat",cursive; --body:"Nunito",-apple-system,sans-serif;
}

/* ── base resets ────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bone);color:var(--ink);line-height:1.65;font-size:17px;overflow-x:hidden}
::selection{background:var(--lavender);color:#fff}
:focus-visible{outline:3px solid var(--lavender-deep);outline-offset:3px;border-radius:var(--r-xs)}
.skip{position:absolute;left:-9999px;top:0;background:var(--lavender-deep);color:#fff;font-weight:800;padding:12px 20px;border-radius:var(--r-sm);z-index:99}
.skip:focus{left:0}

/* ── layout ─────────────────────────────────────────── */
.wrap{max-width:1020px;margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.15;letter-spacing:-.01em}
.hand{font-family:var(--hand);font-weight:600}
.muted{color:var(--muted)}

/* ── grain atmosphere ───────────────────────────────── */
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9;opacity:.35;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0.96 0 0 0 0 0.95 0 0 0 0 0.93 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ── nav ────────────────────────────────────────────── */
nav{position:relative;z-index:5;display:flex;align-items:center;justify-content:space-between;padding:26px 0}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:24px;font-weight:600;color:var(--ink);text-decoration:none}
.logo svg{flex:none}
.nav-right{display:flex;align-items:center;gap:10px}
.pill{font-size:14px;font-weight:700;color:var(--lavender-deep);background:rgba(255,255,255,.7);border:1px solid var(--divider);padding:8px 18px;border-radius:999px;white-space:nowrap;backdrop-filter:blur(6px)}
.lang-switch{font-size:14px;font-weight:800;color:var(--lavender-deep);background:rgba(255,255,255,.7);border:1px solid var(--divider);padding:8px 14px;border-radius:999px;text-decoration:none;backdrop-filter:blur(6px);transition:border-color .2s ease,background .2s ease}
.lang-switch:hover{border-color:var(--lavender);background:var(--surface-alt)}

/* ── footer ─────────────────────────────────────────── */
footer{border-top:1px solid var(--divider);padding:32px 0 46px;font-size:14.5px;color:var(--muted)}
footer .row{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
footer a{display:inline-block;color:var(--lavender-deep);text-decoration:none;font-weight:700;margin:0 8px;padding:10px 4px;transition:color .2s ease}
footer a:hover{color:var(--lavender-night);text-decoration:underline}

/* ── content pages ──────────────────────────────────── */
main.content{position:relative;z-index:2;padding:18px 0 64px}
.content article{max-width:720px;margin:0 auto}
.content h1{font-size:clamp(32px,5vw,46px);margin:18px 0 18px}
.content h2{font-size:26px;margin:42px 0 14px}
.content h3{font-size:20px;margin:28px 0 10px}
.content p,.content li{font-size:17px;color:var(--ink)}
.content p{margin:0 0 18px}
.content ul,.content ol{margin:0 0 18px 22px}
.content li{margin-bottom:8px}
.content a{color:var(--lavender-deep);font-weight:700;text-decoration:none}
.content a:hover{text-decoration:underline}
.content .lead-answer{font-size:19px;background:var(--surface);border:1px solid var(--divider);border-left:5px solid var(--lavender);border-radius:var(--r-sm);padding:18px 22px;margin:0 0 26px}
.content table{width:100%;border-collapse:collapse;margin:0 0 18px;font-size:15.5px}
.content th,.content td{border:1px solid var(--divider);padding:10px 12px;text-align:left;vertical-align:top}
.content th{background:var(--surface-alt);font-weight:800}
.breadcrumb{font-size:14px;color:var(--muted);margin:10px 0 0}
.breadcrumb a{color:var(--lavender-deep);text-decoration:none;font-weight:700}
.disclosure{font-size:14.5px;background:var(--surface-alt);border:1px solid var(--divider);border-radius:var(--r-xs);padding:12px 16px;margin:0 0 22px;color:var(--muted)}
.faq{max-width:720px;margin:30px auto 0}
.faq h2{font-size:26px;margin-bottom:14px}
.faq details{background:var(--surface);border:1px solid var(--divider);border-radius:var(--r-sm);padding:14px 18px;margin-bottom:10px}
.faq summary{font-weight:800;cursor:pointer;font-size:16.5px}
.faq details p{margin:10px 0 2px;color:var(--muted)}
.waitlist{max-width:620px;margin:54px auto 0;text-align:center;background:var(--surface);border:1px solid var(--divider);border-radius:var(--r-card);padding:32px 28px;box-shadow:var(--shadow-sm)}
.waitlist h2{font-size:24px;margin-bottom:8px}
.waitlist p{color:var(--muted);font-size:15.5px;margin-bottom:18px}
.wl-form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.wl-form input[type=email]{flex:1;min-width:220px;font-family:var(--body);font-size:16px;padding:13px 16px;border:1.5px solid var(--divider);border-radius:var(--r-sm);background:var(--bone)}
.wl-form input[type=email]:focus{border-color:var(--lavender-deep);outline:none}
.wl-form button{font-family:var(--body);font-weight:800;font-size:16px;color:#fff;background:linear-gradient(135deg,var(--lavender-deep),var(--lavender-night));border:none;border-radius:var(--r-sm);padding:13px 22px;cursor:pointer}
.wl-form .hp{position:absolute;left:-9999px}
.wl-note{font-size:13px!important;margin-top:12px!important}
.wl-ok{color:var(--lavender-deep);font-weight:800}
.wl-err{color:#B4593E;font-weight:700}
.wl-count{display:inline-block;font-size:14px!important;font-weight:700;color:var(--lavender-deep);background:#F1ECF9;border:1px solid #E1D7F0;border-radius:999px;padding:6px 16px;margin:0 auto 16px!important}
.wl-count strong{font-weight:900}
.share-kicker{font-family:var(--hand);font-size:24px;color:var(--lavender-deep);display:block;margin-bottom:6px}
.share-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:6px}
.share-row input{flex:1;min-width:240px;font-family:var(--body);font-size:15px;padding:13px 16px;border:1.5px solid var(--divider);border-radius:var(--r-sm);background:var(--bone);color:var(--ink)}
.share-row button{font-family:var(--body);font-weight:800;font-size:16px;color:#fff;background:linear-gradient(135deg,var(--lavender-deep),var(--lavender-night));border:none;border-radius:var(--r-sm);padding:13px 22px;cursor:pointer}
@media(max-width:600px){.content h1{font-size:30px}}

/* ── tools ──────────────────────────────────────────── */
main.tool{position:relative;z-index:2;padding:18px 0 64px}
.tool-hero{max-width:760px;margin:0 auto 30px;text-align:center}
.tool-kicker{font-family:var(--hand);font-size:23px;color:var(--lavender-deep);display:block;margin-bottom:4px}
.tool-hero h1{font-size:clamp(30px,5vw,44px);margin:0 0 14px}
.tool-hero p{color:var(--muted);font-size:18px;max-width:620px;margin:0 auto}
.tool-panel{max-width:820px;margin:0 auto;background:var(--surface);border:1px solid var(--divider);border-radius:var(--r-card);padding:30px 30px 34px;box-shadow:var(--shadow-sm)}
.tool-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:26px auto 0;max-width:820px}
.btn{font-family:var(--body);font-weight:800;font-size:17px;color:#fff;background:linear-gradient(135deg,var(--lavender-deep),var(--lavender-night));border:none;border-radius:var(--r-md);padding:16px 30px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;text-decoration:none;box-shadow:var(--shadow-cta);transition:transform .2s ease, box-shadow .2s ease}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-cta-hover)}
.btn-ghost{color:var(--lavender-deep);background:var(--surface);border:1.5px solid var(--divider);box-shadow:none}
.btn-ghost:hover{border-color:var(--lavender);transform:translateY(-2px);box-shadow:none}
.tool-note{max-width:820px;margin:16px auto 0;text-align:center;font-size:14px;color:var(--muted)}

/* checklist */
.chk-progress{position:sticky;top:0;z-index:4;background:var(--surface-alt);border:1px solid var(--divider);border-radius:999px;padding:12px 16px;margin:0 auto 22px;max-width:820px;display:flex;align-items:center;gap:14px;font-weight:800;color:var(--lavender-deep)}
.chk-bar{flex:1;height:8px;background:var(--divider);border-radius:999px;overflow:hidden}
.chk-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--lavender),var(--lavender-deep));transition:width .35s ease}
.chk-group{margin:0 0 8px}
.chk-group+.chk-group{border-top:1px solid var(--divider);margin-top:16px;padding-top:16px}
.chk-group h3{font-size:20px;margin:0 0 12px;display:flex;align-items:center;gap:9px}
.chk-group h3 .dot{width:11px;height:11px;border-radius:50%;background:var(--lavender);flex:none}
.chk{display:flex;align-items:flex-start;gap:12px;padding:8px 12px;border-radius:var(--r-xs);cursor:pointer;transition:background .15s ease}
.chk:hover{background:var(--surface-alt)}
.chk input{appearance:none;-webkit-appearance:none;width:22px;height:22px;flex:none;border:2px solid var(--lavender);border-radius:var(--r-xs);margin-top:1px;cursor:pointer;position:relative;background:var(--surface)}
.chk input:checked{background:var(--lavender-deep);border-color:var(--lavender-deep)}
.chk input:checked::after{content:"";position:absolute;left:6px;top:2px;width:6px;height:11px;border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg)}
.chk span{font-size:16.5px;line-height:1.5}
.chk input:checked+span{color:var(--muted);text-decoration:line-through}

/* milestone cards */
.opts{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:center;margin:0 auto 24px;max-width:820px}
.opt-chip{font-weight:700;font-size:14.5px;border:1.5px solid var(--divider);background:var(--surface);border-radius:999px;padding:8px 16px;cursor:pointer;color:var(--ink)}
.opt-chip[aria-pressed=true]{border-color:var(--lavender-deep);background:var(--surface-alt);color:var(--lavender-deep)}
.swatch{width:26px;height:26px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1.5px var(--divider);cursor:pointer;transition:transform .12s ease, box-shadow .15s ease}
.swatch[aria-pressed=true]{box-shadow:0 0 0 2.5px var(--lavender-deep)}
.swatch:focus-visible{outline:3px solid var(--lavender-deep);outline-offset:3px}
.swatch:active{transform:scale(.92)}
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px;max-width:920px;margin:0 auto}
.mcard{aspect-ratio:3/4;border-radius:var(--r-md);border:2px solid var(--card-ink,#6C5AA0);background:var(--card-bg,#F3EFF8);color:var(--card-ink,#6C5AA0);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:22px 18px;position:relative;overflow:hidden}
.mcard .mc-moon{position:absolute;top:14px;right:16px;opacity:.55}
.mcard .mc-kicker{font-family:var(--hand);font-size:22px;opacity:.85}
.mcard .mc-title{font-family:var(--serif);font-size:28px;font-weight:600;line-height:1.1;margin:6px 0 10px}
.mcard .mc-line{font-size:13px;opacity:.7;border-top:1px dashed currentColor;padding-top:8px;width:78%}
.mcard.off{display:none}

/* letter writer */
.lt-steps{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:0 auto 22px}
.lt-field{margin:0 0 18px}
.lt-field label{display:block;font-weight:800;margin-bottom:6px;font-size:15.5px}
.lt-field .hint{font-weight:600;color:var(--muted);font-size:13.5px;margin-left:6px}
.lt-field textarea,.lt-field input[type=text]{width:100%;font-family:var(--body);font-size:16px;padding:12px 14px;border:1.5px solid var(--divider);border-radius:var(--r-xs);background:var(--bone);line-height:1.55;resize:vertical}
.lt-field textarea:focus,.lt-field input:focus{border-color:var(--lavender-deep);outline:none}
.lt-preview{background:var(--surface-alt);border:1px solid var(--divider);border-radius:var(--r-sm);padding:24px 28px;font-family:var(--serif);font-size:18px;line-height:1.7;white-space:pre-wrap;min-height:160px}
.lt-preview.empty{color:var(--muted);font-family:var(--body);font-style:italic}

/* tool cross-links */
.tool-more{max-width:820px;margin:46px auto 0}
.tool-more h2{font-size:22px;text-align:center;margin-bottom:16px}
.tool-more .row2{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.tool-more a{display:block;background:var(--surface);border:1px solid var(--divider);border-radius:var(--r-sm);padding:16px 18px;text-decoration:none;color:var(--ink);font-weight:700}
.tool-more a:hover{border-color:var(--lavender)}
.tool-more a span{display:block;color:var(--muted);font-weight:600;font-size:14px;margin-top:4px}

/* homepage tools teaser */
.tools-teaser{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.tools-teaser a{display:block;background:var(--surface);border:1px solid var(--divider);border-radius:var(--r-card);padding:22px 22px 24px;text-decoration:none;color:var(--ink);transition:transform .2s ease,border-color .2s ease}
.tools-teaser a:hover{transform:translateY(-3px);border-color:var(--lavender)}
.tools-teaser h3{font-size:19px;margin:10px 0 6px}
.tools-teaser p{color:var(--muted);font-size:14.5px;margin:0}
.tools-teaser .tt-ic{width:38px;height:38px;border-radius:var(--r-xs);display:flex;align-items:center;justify-content:center;background:var(--surface-alt);color:var(--lavender-deep)}

@media print{
  body::before,nav,footer,.skip,.breadcrumb,.tool-hero,.tool-actions,.tool-note,.tool-more,.waitlist,.chk-progress,.opts,.lt-steps,#letterForm,.print-hide{display:none!important}
  body{background:#fff}
  .tool-panel{box-shadow:none;border:none;padding:0;max-width:none}
  .chk input{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .cards-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .mcard{break-inside:avoid;border-color:#6C5AA0!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .lt-preview{border:none;background:#fff;padding:0;font-size:16px}
}

@media (max-width:390px){
  .tool-hero{padding-left:16px;padding-right:16px}
  .btn{padding:14px 22px;font-size:16px}
}
