/* Stitchwork marketing site — zero-build static (Cloudflare Pages). Brand mirrors App/Stitchwork/Theme.swift:
 * warm linen canvas · off-white card · ink text · heritage teal · terracotta accent · serif display (NY/Georgia).
 * Light + dark via prefers-color-scheme. */
:root {
    --canvas:#F6F1E7; --canvas-2:#F1EADC; --card:#FFFDF8; --ink:#2C2A24; --ink-soft:#6A6256;
    --teal:#1F665E; --teal-soft:#2C8478; --terracotta:#B04A32; --gold:#8C641E;
    --border:rgba(44,42,36,.12); --shadow:0 10px 40px rgba(48,32,16,.10); --shadow-sm:0 4px 18px rgba(48,32,16,.08);
    --bg:var(--canvas); --surface:var(--card);
}
@media (prefers-color-scheme: dark){:root{
    --canvas:#161410; --canvas-2:#1B1813; --card:#211E18; --ink:#F0EBE0; --ink-soft:#A8A095;
    --teal:#5EC4B6; --teal-soft:#6FD0C2; --terracotta:#E07D63; --gold:#E0B258;
    --border:rgba(240,235,224,.14); --shadow:0 10px 40px rgba(0,0,0,.45); --shadow-sm:0 4px 18px rgba(0,0,0,.4);
}}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--ink);
    line-height:1.65;-webkit-font-smoothing:antialiased}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
.narrow{max-width:720px;margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:"New York",Georgia,"Times New Roman",serif;font-weight:600;letter-spacing:-.015em;line-height:1.12;color:var(--ink)}
h1{font-size:clamp(2.4rem,6vw,3.8rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.3rem)}
h3{font-size:1.2rem}
p{margin-bottom:.85rem}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--ink-soft)}
img{max-width:100%;display:block}

/* Header */
header.site{position:sticky;top:0;z-index:20;backdrop-filter:saturate(150%) blur(12px);
    background:color-mix(in srgb,var(--canvas) 82%,transparent);border-bottom:1px solid var(--border)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:60px}
.brand{font-family:"New York",Georgia,serif;font-weight:600;font-size:1.25rem;color:var(--ink)}
.brand:hover{text-decoration:none}
nav.site a{color:var(--ink-soft);margin-left:22px;font-size:.95rem}
nav.site a.cta{color:#fff}
.btn{display:inline-block;background:var(--terracotta);color:#fff;font-weight:600;padding:12px 24px;border-radius:13px;
    box-shadow:var(--shadow-sm)}
.btn:hover{text-decoration:none;filter:brightness(1.05)}
.btn.ghost{background:transparent;color:var(--teal);box-shadow:none;border:1px solid var(--border)}
nav.site .btn{padding:8px 16px;font-size:.92rem}

/* Hero */
.hero{text-align:center;padding:72px 0 24px}
.badge{display:inline-block;font-size:.82rem;font-weight:600;color:var(--teal);
    background:color-mix(in srgb,var(--teal) 13%,transparent);padding:6px 15px;border-radius:999px;margin-bottom:20px}
.hero p.lede{font-size:1.22rem;color:var(--ink-soft);max-width:620px;margin:16px auto 26px}
.hero-shot{margin:36px auto 0;max-width:300px;border-radius:34px;box-shadow:var(--shadow);
    border:1px solid var(--border)}
.subtle{font-size:.85rem;color:var(--ink-soft);margin-top:14px}

/* Feature rows */
.row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:56px 0;border-top:1px solid var(--border)}
.row .shot img{max-width:280px;margin:0 auto;border-radius:30px;box-shadow:var(--shadow);border:1px solid var(--border)}
.row.reverse .copy{order:2}
.row h2{margin-bottom:.5rem}
.row p{color:var(--ink-soft);font-size:1.05rem}
.row ul{list-style:none;margin-top:14px}
.row li{position:relative;padding-left:26px;margin-bottom:8px;color:var(--ink)}
.row li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:700}
@media (max-width:760px){.row{grid-template-columns:1fr;gap:28px;padding:40px 0}.row.reverse .copy{order:0}}

/* Text band */
.band{text-align:center;padding:54px 0;border-top:1px solid var(--border)}
.band .narrow p{color:var(--ink-soft);font-size:1.08rem}
.band ul{list-style:none;display:inline-flex;flex-wrap:wrap;gap:10px 22px;justify-content:center;margin-top:14px}
.band li{color:var(--ink);font-size:.98rem}
.band li::before{content:"✓ ";color:var(--teal);font-weight:700}

/* FAQ */
.faq{padding:48px 0;border-top:1px solid var(--border)}
.faq details{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:4px 18px;margin-bottom:10px;box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;font-weight:600;padding:14px 0;list-style:none;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--teal);font-size:1.2rem;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--ink-soft);padding-bottom:14px;margin:0}

/* Final CTA */
.final{text-align:center;padding:64px 24px;margin:56px 0 0;background:var(--canvas-2);border-top:1px solid var(--border)}
.price{font-weight:600;color:var(--terracotta)}

/* Blog */
.posts{padding:24px 0 8px}
.post-card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:22px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.post-card:hover{text-decoration:none;transform:translateY(-1px)}
.post-card h3{color:var(--ink);margin-bottom:4px}
.post-card p{color:var(--ink-soft);margin:0}
article.post{padding:40px 0 32px}
article.post h1{margin-bottom:6px}
article.post .dek{color:var(--ink-soft);font-size:1.15rem;margin-bottom:8px}
article.post h2{font-size:1.5rem;margin:1.8rem 0 .5rem}
article.post p,article.post li{color:var(--ink);font-size:1.06rem}
article.post ul{margin:0 0 1rem 1.3rem}

/* Doc pages (privacy/support/press) */
main.doc{padding:40px 0 56px}
main.doc h2{font-size:1.3rem;margin:1.8rem 0 .5rem}
main.doc ul{margin:0 0 1rem 1.3rem}
.facts{list-style:none;margin:0}
.facts li{padding:10px 0;border-bottom:1px solid var(--border);display:flex;gap:14px}
.facts li b{min-width:140px;color:var(--ink)}

footer{border-top:1px solid var(--border);margin-top:48px;padding:30px 0 56px;text-align:center}
footer a{margin:0 10px;color:var(--ink-soft);font-size:.92rem}
footer .fine{display:block;margin-top:14px;color:var(--ink-soft);font-size:.8rem;max-width:640px;margin-left:auto;margin-right:auto}
