/* ============================================================
   AI Review Responder — shared boutique design system
   Warm paper · forest green · terracotta · Fraunces + Schibsted + Caveat
   ============================================================ */
:root {
  --paper:#fbf7f0; --paper-2:#f3ecdd; --card:#fffdf8; --inset:#f6efe2;
  --ink:#211c17; --ink-soft:#4b4239; --muted:#857769; --faint:#a99c8b;
  --line:#e7dfcf; --line-2:#efe8da;
  --green:#2f6b46; --green-d:#255539; --green-soft:#e7efe8;
  --terra:#bd633a; --terra-soft:#fbeee2;
  --r-lg:20px; --r-md:13px; --r-sm:10px;
  --sh-1:0 1px 2px rgba(74,52,30,.06);
  --sh-2:0 10px 26px -12px rgba(74,52,30,.20);
  --sh-3:0 30px 70px -30px rgba(54,40,22,.40), 0 10px 24px -16px rgba(54,40,22,.20);
  --ease:cubic-bezier(.22,1,.36,1); --spring:cubic-bezier(.34,1.56,.64,1);
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Schibsted Grotesk",system-ui,-apple-system,Segoe UI,sans-serif;
  --hand:"Caveat","Segoe Print",cursive;
  --maxw:1180px;
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; min-height:100vh; color:var(--ink); background:var(--paper);
  font-family:var(--sans); -webkit-font-smoothing:antialiased; line-height:1.55; position:relative; overflow-x:hidden; }
a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }

/* fixed warm backdrop */
.glow { position:fixed; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(70% 46% at 50% -6%, rgba(255,247,228,.9), transparent 62%),
             radial-gradient(36% 30% at 96% 4%, rgba(189,99,58,.07), transparent 60%),
             radial-gradient(40% 40% at 2% 96%, rgba(47,107,70,.06), transparent 60%); }
.grain { position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.05; 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='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

.container { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.page { position:relative; z-index:1; }

/* ---------- scroll-reveal utilities ---------- */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .75s var(--ease), transform .75s var(--ease); transition-delay:var(--d,0s); }
.reveal.rl { transform:translateX(-34px); }
.reveal.rr { transform:translateX(34px); }
.reveal.rs { transform:scale(.9); }
.reveal.is-in { opacity:1 !important; transform:none !important; }

/* ---------- nav ---------- */
.nav { position:sticky; top:0; z-index:40; background:rgba(251,247,240,.78); backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s, background .3s; }
.nav.scrolled { border-bottom-color:var(--line-2); box-shadow:0 6px 20px -16px rgba(54,40,22,.5); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:70px; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.brand { display:flex; align-items:center; gap:12px; }
.mark { position:relative; width:40px; height:40px; border-radius:50%; background:var(--green); display:grid; place-items:center;
  box-shadow:0 6px 16px -6px rgba(47,107,70,.6), inset 0 1px 0 rgba(255,255,255,.18); flex:none; }
.mark svg { width:19px; height:19px; }
.mark .spark { position:absolute; top:-4px; right:-4px; width:11px; height:11px; color:var(--terra); animation:twinkle 3.6s ease-in-out infinite; }
@keyframes twinkle { 0%,100%{ opacity:.25; transform:scale(.7) rotate(0);} 50%{ opacity:1; transform:scale(1.1) rotate(90deg);} }
.brand b { font-family:var(--serif); font-weight:600; font-size:1.08rem; line-height:1.05; }
.brand small { display:block; color:var(--muted); font-size:.74rem; font-weight:500; margin-top:2px; }
.nav-links { display:flex; align-items:center; gap:26px; }
.nav-links a { color:var(--ink-soft); font-size:.92rem; font-weight:600; position:relative; transition:color .2s; }
.nav-links a.lnk::after { content:""; position:absolute; left:0; right:100%; bottom:-5px; height:2px; background:var(--green); border-radius:2px; transition:right .3s var(--ease); }
.nav-links a.lnk:hover { color:var(--green-d); }
.nav-links a.lnk:hover::after, .nav-links a.lnk.active::after { right:0; }
.nav-toggle { display:none; background:none; border:1px solid var(--line); border-radius:10px; padding:8px; cursor:pointer; color:var(--ink); }

/* ---------- buttons ---------- */
.btn { font-family:var(--sans); font-weight:600; cursor:pointer; border:none; border-radius:var(--r-md); display:inline-flex; align-items:center; justify-content:center; gap:9px;
  transition:transform .15s var(--spring), box-shadow .22s, background .2s; }
.btn-primary { position:relative; overflow:hidden; isolation:isolate; background:var(--green); color:#fdfaf3; padding:13px 22px; font-size:.98rem;
  box-shadow:0 12px 26px -12px rgba(47,107,70,.6), inset 0 1px 0 rgba(255,255,255,.16); }
.btn-primary::after { content:""; position:absolute; top:0; left:-60%; width:35%; height:100%; background:linear-gradient(100deg,transparent,rgba(255,255,255,.22),transparent); transform:skewX(-18deg); animation:sweep 4.2s ease-in-out infinite; }
@keyframes sweep { 0%{ left:-60%;} 55%,100%{ left:135%;} }
.btn-primary:hover { background:var(--green-d); transform:translateY(-2px); box-shadow:0 18px 34px -14px rgba(47,107,70,.7); }
.btn-primary:active { transform:translateY(0) scale(.97); }
.btn-primary .label { position:relative; z-index:1; display:inline-flex; align-items:center; gap:9px; }
.btn-ghost { background:transparent; color:var(--ink); padding:12px 18px; font-size:.94rem; border:1px solid var(--line); }
.btn-ghost:hover { background:var(--card); border-color:var(--green); color:var(--green-d); transform:translateY(-2px); }
.btn-lg { padding:16px 28px; font-size:1.04rem; }

/* ---------- shared bits ---------- */
.eyebrow { display:inline-flex; align-items:center; gap:10px; font-size:.74rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--terra); }
.eyebrow .stars { letter-spacing:.14em; color:var(--green); }
.hl-word { position:relative; font-style:italic; color:var(--green); font-weight:500; white-space:nowrap; }
.hl-word .hl { position:absolute; left:-4px; right:-4px; bottom:-8px; width:calc(100% + 8px); height:18px; overflow:visible; }
.hl-word .hl path { fill:none; stroke:var(--terra); stroke-width:7; stroke-linecap:round; opacity:.85; stroke-dasharray:320; stroke-dashoffset:320; }
.is-in .hl-word .hl path, .hl-word.draw .hl path { animation:draw 1.05s var(--ease) .25s forwards; }
@keyframes draw { to{ stroke-dashoffset:0; } }
.seal { width:104px; height:104px; transform:rotate(-9deg); }
.seal .ring { transform-origin:50px 50px; animation:spin360 26s linear infinite; }
.seal text { font-family:var(--sans); font-size:8.3px; font-weight:700; letter-spacing:1.5px; fill:var(--green); text-transform:uppercase; }
.seal .seal-star { fill:var(--terra); }
.seal .seal-edge { fill:none; stroke:var(--line); stroke-width:1; }
@keyframes spin360 { to{ transform:rotate(360deg); } }
.divider { line-height:0; margin:12px 0 4px; }
.divider svg { width:100%; height:9px; display:block; }
.divider path { fill:none; stroke:#dccdb2; stroke-width:2; stroke-linecap:round; }
.chip { display:inline-flex; align-items:center; gap:7px; font-size:.71rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  padding:6px 11px; border-radius:999px; border:1px solid var(--line); background:var(--card); color:var(--muted); box-shadow:var(--sh-1); }
.chip .dot { width:7px; height:7px; border-radius:50%; background:var(--faint); }
.chip.live { color:var(--green-d); border-color:#bcd6c4; background:var(--green-soft); }
.chip.live .dot { background:var(--green); animation:pulse 1.9s infinite; }
@keyframes pulse { 0%{ box-shadow:0 0 0 0 rgba(47,107,70,.5);} 70%{ box-shadow:0 0 0 6px rgba(47,107,70,0);} 100%{ box-shadow:0 0 0 0 rgba(47,107,70,0);} }
.hand { font-family:var(--hand); color:var(--terra); font-weight:700; }

/* ---------- sections / headings ---------- */
section.block { padding:88px 0; position:relative; }
section.tint { background:var(--paper-2); border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2); }
.kicker { text-align:center; color:var(--terra); font-weight:700; font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; }
.h2 { text-align:center; font-family:var(--serif); font-weight:600; font-size:clamp(1.8rem,3.6vw,2.7rem); letter-spacing:-.02em; line-height:1.1; margin:12px auto 0; max-width:20ch; }
.h2-sub { text-align:center; color:var(--muted); max-width:54ch; margin:14px auto 0; font-size:1.04rem; }

/* ---------- hero (home) ---------- */
.hero { position:relative; padding:72px 0 56px; }
.hero-grid { display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.hero h1 { font-family:var(--serif); font-weight:600; font-size:clamp(2.6rem,5vw,4rem); line-height:1.02; letter-spacing:-.025em; margin:16px 0 0; text-shadow:0 1px 0 rgba(255,255,255,.6); }
.hero p.lede { color:var(--muted); font-size:1.14rem; max-width:46ch; margin:18px 0 0; }
.hero-cta { display:flex; gap:14px; flex-wrap:wrap; margin-top:28px; align-items:center; }
.hero-cta .hand-note { font-family:var(--hand); color:var(--terra); font-weight:700; font-size:1.1rem; transform:rotate(-3deg); display:inline-flex; align-items:center; gap:4px; }
.hero-trust { display:flex; gap:22px; margin-top:26px; color:var(--muted); font-size:.9rem; flex-wrap:wrap; }
.hero-trust span { display:inline-flex; align-items:center; gap:7px; }
.hero-trust svg { color:var(--green); flex:none; }
.hero-seal { position:absolute; top:24px; right:8px; }

/* hero device / looping demo */
.device { position:relative; background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-3); padding:20px; transform:rotate(1.5deg); }
.device::after { content:""; position:absolute; inset:8px; border:1px solid var(--line-2); border-radius:calc(var(--r-lg) - 6px); pointer-events:none; }
.device .dev-head { display:flex; align-items:center; gap:8px; margin-bottom:14px; }
.device .dev-dots { display:flex; gap:5px; } .device .dev-dots i { width:9px; height:9px; border-radius:50%; background:var(--line); display:block; }
.device .dev-title { font-size:.74rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--faint); }
.device .rev { background:var(--inset); border:1px solid var(--line); border-radius:var(--r-md); padding:11px 13px; font-size:.86rem; color:var(--ink-soft); }
.device .rev .who { font-family:var(--hand); font-size:1rem; color:var(--terra); font-weight:700; }
.device .draft { position:relative; background:var(--inset); border:1px solid var(--line); border-radius:var(--r-md); padding:13px 14px 13px 18px; margin-top:12px; min-height:84px; }
.device .draft::before { content:""; position:absolute; left:0; top:12px; bottom:12px; width:3px; border-radius:3px; background:var(--green); }
.device .draft .num { font-family:var(--hand); color:var(--terra); font-weight:700; font-size:1rem; display:block; margin-bottom:2px; transform:rotate(-2deg); }
.device .draft p { margin:0; font-family:var(--serif); font-weight:500; font-size:.95rem; line-height:1.55; color:var(--ink-soft); }
.caret { display:inline-block; width:2px; height:1.05em; background:var(--green); margin-left:1px; vertical-align:-2px; animation:blink .9s steps(1) infinite; border-radius:2px; }
@keyframes blink { 50%{ opacity:0; } }

/* ---------- marquee ---------- */
.marquee { overflow:hidden; padding:18px 0; border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2); background:var(--card); -webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); }
.marquee-track { display:inline-flex; gap:40px; white-space:nowrap; animation:scrollx 26s linear infinite; will-change:transform; }
.marquee:hover .marquee-track { animation-play-state:paused; }
.marquee span { font-family:var(--serif); font-style:italic; font-size:1.15rem; color:var(--muted); display:inline-flex; align-items:center; gap:40px; }
.marquee span::after { content:"★"; color:var(--terra); font-style:normal; }
@keyframes scrollx { to{ transform:translateX(-50%); } }

/* ---------- steps ---------- */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; counter-reset:s; }
.step { position:relative; background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-1); padding:26px; transition:transform .25s var(--ease), box-shadow .25s; }
.step::after { content:""; position:absolute; inset:8px; border:1px solid var(--line-2); border-radius:calc(var(--r-lg) - 6px); pointer-events:none; }
.step:hover { transform:translateY(-5px) rotate(-.4deg); box-shadow:var(--sh-2); }
.step .n { width:42px; height:42px; border-radius:50%; background:var(--green-soft); color:var(--green-d); border:1px solid #bcd6c4; display:grid; place-items:center; font-family:var(--serif); font-weight:700; margin-bottom:16px; }
.step h3 { font-family:var(--serif); font-weight:600; font-size:1.18rem; margin:0 0 6px; }
.step p { margin:0; color:var(--muted); font-size:.96rem; }

/* ---------- feature grid ---------- */
.feat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.feat { background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-1); padding:26px; transition:transform .25s var(--ease), box-shadow .25s; }
.feat:hover { transform:translateY(-5px) rotate(.4deg); box-shadow:var(--sh-2); }
.feat .ic { width:46px; height:46px; border-radius:13px; background:var(--green-soft); color:var(--green); display:grid; place-items:center; margin-bottom:16px; }
.feat h3 { font-family:var(--serif); font-weight:600; font-size:1.12rem; margin:0 0 6px; }
.feat p { margin:0; color:var(--muted); font-size:.95rem; }

/* ---------- stats ---------- */
.stats { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; text-align:center; }
.stat .big { font-family:var(--serif); font-weight:700; font-size:clamp(2.4rem,5vw,3.4rem); color:var(--green); letter-spacing:-.02em; line-height:1; }
.stat .big .u { color:var(--terra); }
.stat .lbl { color:var(--muted); margin-top:8px; font-size:.95rem; }

/* ---------- pricing ---------- */
.price-card { max-width:440px; margin:48px auto 0; background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-3); padding:36px 34px; text-align:center; position:relative; }
.price-card::after { content:""; position:absolute; inset:9px; border:1px solid var(--line-2); border-radius:calc(var(--r-lg) - 7px); pointer-events:none; }
.price-card .seal-pin { position:absolute; top:-26px; right:-18px; }
.price-card .amt { font-family:var(--serif); font-weight:700; font-size:3.4rem; letter-spacing:-.03em; line-height:1; }
.price-card .amt .per { font-family:var(--sans); font-size:1rem; font-weight:600; color:var(--muted); }
.price-card ul { list-style:none; padding:0; margin:24px 0; text-align:left; display:grid; gap:13px; }
.price-card li { display:flex; align-items:center; gap:11px; color:var(--ink-soft); font-size:.98rem; }
.price-card li svg { color:var(--green); flex:none; }
.price-note { color:var(--muted); font-size:.86rem; margin-top:14px; }

/* ---------- story ---------- */
.story-wrap { max-width:680px; margin:0 auto; }
.story-wrap p { font-family:var(--serif); font-weight:500; font-size:1.18rem; line-height:1.7; color:var(--ink-soft); margin:0 0 22px; }
.story-wrap p .hl-word { font-size:inherit; }
.story-pull { font-family:var(--hand); color:var(--terra); font-size:1.7rem; font-weight:700; text-align:center; margin:34px 0; transform:rotate(-1.5deg); }
.story-sign { font-family:var(--hand); color:var(--green-d); font-size:1.5rem; font-weight:700; transform:rotate(-3deg); }

/* ---------- faq ---------- */
.faq-list { max-width:720px; margin:40px auto 0; }
.faq-item { border:1px solid var(--line); border-radius:var(--r-md); background:var(--card); box-shadow:var(--sh-1); margin-bottom:14px; overflow:hidden; }
.faq-q { display:flex; align-items:center; justify-content:space-between; gap:14px; width:100%; text-align:left; background:none; border:none; cursor:pointer;
  font-family:var(--serif); font-weight:600; font-size:1.08rem; color:var(--ink); padding:18px 20px; }
.faq-q .pm { width:26px; height:26px; flex:none; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; color:var(--green-d); transition:transform .3s var(--spring), background .2s; font-size:1.1rem; }
.faq-item.open .faq-q .pm { transform:rotate(45deg); background:var(--green-soft); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a-in { padding:0 20px 18px; color:var(--muted); font-size:.98rem; }

/* ---------- footer ---------- */
.foot { position:relative; z-index:1; border-top:1px solid var(--line-2); background:var(--paper-2); margin-top:0; }
.foot-inner { max-width:var(--maxw); margin:0 auto; padding:44px 28px; display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:30px; }
.foot .brand b { font-size:1.04rem; }
.foot-col h4 { font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin:0 0 12px; font-weight:700; }
.foot-col a { display:block; color:var(--ink-soft); font-size:.92rem; margin-bottom:9px; transition:color .2s; }
.foot-col a:hover { color:var(--green-d); }
.foot-tag { color:var(--muted); font-size:.9rem; margin:12px 0 0; max-width:30ch; }
.foot-bottom { border-top:1px solid var(--line); }
.foot-bottom-in { max-width:var(--maxw); margin:0 auto; padding:18px 28px; display:flex; justify-content:space-between; gap:12px; color:var(--faint); font-size:.84rem; flex-wrap:wrap; }

/* ============================================================
   APP / TOOL styles (app.html)
   ============================================================ */
main.app { position:relative; z-index:1; max-width:var(--maxw); margin:0 auto; padding:40px 28px 80px; }
.masthead { position:relative; text-align:center; margin-bottom:34px; }
.masthead h1 { font-family:var(--serif); font-weight:600; font-size:clamp(2.2rem,4.6vw,3.2rem); line-height:1.04; letter-spacing:-.02em; margin:14px auto 0; max-width:16ch; text-shadow:0 1px 0 rgba(255,255,255,.6); }
.masthead h1 .hl-word .hl path { animation:draw 1.05s var(--ease) .55s forwards; }
.masthead p { margin:16px auto 0; color:var(--muted); font-size:1.04rem; max-width:52ch; }
.masthead .seal { position:absolute; top:-20px; right:6px; animation:sealpop .8s var(--spring) .3s both; }
@keyframes sealpop { from{ opacity:0; transform:rotate(-9deg) scale(.5);} to{ opacity:1; transform:rotate(-9deg) scale(1);} }
.masthead .app-chip { position:absolute; top:0; left:0; }

.workspace { display:grid; grid-template-columns:minmax(0,1.04fr) minmax(0,.96fr); gap:26px; align-items:stretch; }
.card { position:relative; isolation:isolate; background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-3); padding:26px; display:flex; flex-direction:column; }
.card::after { content:""; position:absolute; inset:9px; border:1px solid var(--line-2); border-radius:calc(var(--r-lg) - 7px); pointer-events:none; z-index:2; }
.output::before { content:"\201C"; position:absolute; z-index:-1; top:-40px; right:10px; font-family:var(--serif); font-weight:700; font-size:160px; line-height:1; color:var(--terra); opacity:.07; pointer-events:none; }
.card-head { display:flex; align-items:baseline; gap:10px; }
.card-head .ch-title { font-family:var(--serif); font-weight:600; font-size:1.18rem; }
.card-head .ch-sub { font-size:.78rem; color:var(--faint); font-weight:500; }
.card-head .count { margin-left:auto; font-size:.72rem; font-weight:700; color:var(--green-d); background:var(--green-soft); border:1px solid #bcd6c4; padding:2px 9px; border-radius:999px; }
label { display:block; font-family:var(--sans); font-size:.71rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin:16px 0 8px; }
.row { display:flex; gap:12px; flex-wrap:wrap; } .row > div { flex:1 1 160px; }
input, textarea { width:100%; background:var(--inset); color:var(--ink); border:1px solid var(--line); border-radius:var(--r-md); padding:12px 14px; font-size:.96rem; font-family:var(--sans); transition:border-color .18s var(--ease), box-shadow .18s var(--ease), background .18s; }
input::placeholder, textarea::placeholder { color:var(--faint); }
textarea { min-height:150px; resize:vertical; line-height:1.6; }
input:focus, textarea:focus { outline:none; border-color:var(--green); background:var(--card); box-shadow:0 0 0 4px rgba(47,107,70,.12); }
details summary { cursor:pointer; color:var(--muted); font-size:.82rem; font-weight:600; list-style:none; display:inline-flex; align-items:center; gap:8px; user-select:none; padding:2px 0; }
details summary::-webkit-details-marker { display:none; }
details summary .chev { transition:transform .25s var(--spring); color:var(--green); display:inline-block; }
details[open] summary .chev { transform:rotate(90deg); }
.profile-body { animation:slideDown .35s var(--ease); }
@keyframes slideDown { from{ opacity:0; transform:translateY(-6px);} to{ opacity:1; transform:none;} }
.seg-label { display:flex; align-items:center; justify-content:space-between; }
.hint-k { font-size:.7rem; color:var(--faint); font-weight:500; }
.kbd { font:600 .66rem var(--sans); background:var(--inset); border:1px solid var(--line); border-bottom-width:2px; border-radius:5px; padding:2px 6px; color:var(--muted); }
.segment { position:relative; display:grid; grid-template-columns:repeat(3,1fr); gap:4px; background:var(--inset); border:1px solid var(--line); border-radius:var(--r-md); padding:4px; margin-top:8px; }
.seg-pill { position:absolute; top:4px; left:4px; height:calc(100% - 8px); border-radius:9px; background:var(--card); box-shadow:var(--sh-2); transition:transform .42s var(--spring), width .42s var(--spring); z-index:0; }
.seg { position:relative; z-index:1; border:none; background:transparent; cursor:pointer; font-family:var(--sans); font-size:.87rem; font-weight:600; color:var(--muted); padding:9px 6px; border-radius:9px; transition:color .25s; }
.seg[aria-pressed="true"] { color:var(--green-d); }
.seg:hover { color:var(--ink-soft); }
.generate-wrap { margin-top:20px; }
.generate { position:relative; overflow:hidden; isolation:isolate; width:100%; margin-top:auto; border:none; cursor:pointer; color:#fdfaf3; font-family:var(--sans); font-size:1rem; font-weight:600; letter-spacing:.01em; padding:15px; border-radius:var(--r-md); background:var(--green); box-shadow:0 12px 26px -12px rgba(47,107,70,.65), inset 0 1px 0 rgba(255,255,255,.16); transition:transform .16s var(--spring), box-shadow .22s, background .2s; }
.generate::after { content:""; position:absolute; top:0; left:-60%; width:35%; height:100%; background:linear-gradient(100deg,transparent,rgba(255,255,255,.22),transparent); transform:skewX(-18deg); animation:sweep 4.2s ease-in-out infinite; }
.generate:hover { background:var(--green-d); transform:translateY(-2px); box-shadow:0 18px 34px -14px rgba(47,107,70,.7); }
.generate:active { transform:translateY(0) scale(.975); }
.generate:disabled { cursor:default; filter:saturate(.9); } .generate:disabled::after { animation:none; }
.generate .label { position:relative; z-index:1; display:inline-flex; align-items:center; justify-content:center; gap:9px; }
.spinner { width:16px; height:16px; border:2px solid rgba(255,255,255,.45); border-top-color:#fff; border-radius:50%; animation:spin .7s linear infinite; }
@keyframes spin { to{ transform:rotate(360deg);} }
.ripple { position:absolute; border-radius:50%; transform:scale(0); background:rgba(255,255,255,.4); animation:rip .65s var(--ease); pointer-events:none; z-index:0; }
@keyframes rip { to{ transform:scale(4.2); opacity:0;} }
.err { color:#b2371f; margin-top:12px; font-size:.88rem; min-height:1em; }
.hand-cue { display:flex; align-items:center; justify-content:flex-end; gap:6px; margin:0 4px 9px 0; color:var(--terra); font-family:var(--hand); font-weight:700; font-size:1.12rem; transform:rotate(-2.5deg); }
.hand-cue svg { width:26px; height:26px; flex:none; }
.hand-cue svg path { fill:none; stroke:var(--terra); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
#results { flex:1; display:flex; flex-direction:column; margin-top:14px; }
.empty { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:4px; padding:18px 10px; color:var(--muted); }
.empty .art { width:150px; height:120px; margin-bottom:8px; transform:rotate(-2deg); }
.empty .art .ln { stroke:var(--green); opacity:.55; } .empty .art .bub { stroke:var(--green); } .empty .art .st { fill:var(--terra); }
.empty strong { font-family:var(--hand); font-weight:700; color:var(--ink-soft); font-size:1.55rem; line-height:1.05; }
.empty span { font-size:.86rem; color:var(--faint); } .empty span b { color:var(--green-d); font-weight:600; }
.reply { position:relative; background:var(--inset); border:1px solid var(--line); border-radius:var(--r-md); padding:15px 18px 15px 20px; margin-bottom:15px; opacity:0; transform:translateY(16px) scale(.985) rotate(var(--rot,0deg)); will-change:transform; transition:opacity .55s var(--ease), transform .55s var(--spring), box-shadow .25s var(--ease), border-color .25s; }
.reply:last-child { margin-bottom:0; }
.reply:nth-of-type(odd){ --rot:-0.6deg; } .reply:nth-of-type(even){ --rot:0.7deg; }
.reply.in { opacity:1; transform:translateY(0) scale(1) rotate(var(--rot,0deg)); }
.reply::before { content:""; position:absolute; left:0; top:13px; bottom:13px; width:3px; border-radius:3px; background:var(--green); transform:scaleY(0); transform-origin:top; transition:transform .5s var(--ease) .15s; }
.reply.in::before { transform:scaleY(1); }
.reply:hover { background:var(--card); box-shadow:var(--sh-2); border-color:#dccfba; transform:translateY(-3px) scale(1) rotate(0deg); z-index:3; }
.reply .num { font-family:var(--hand); font-weight:700; font-size:1.05rem; color:var(--terra); margin-bottom:2px; display:inline-block; transform:rotate(-2.5deg); }
.reply p { margin:0 60px 0 0; color:var(--ink-soft); font-family:var(--serif); font-weight:500; font-size:1rem; line-height:1.6; min-height:1.4em; }
.copy { position:absolute; top:13px; right:13px; cursor:pointer; background:var(--card); color:var(--green-d); border:1px solid var(--line); border-radius:9px; padding:6px 11px; font-size:.74rem; font-weight:600; font-family:var(--sans); display:inline-flex; align-items:center; gap:5px; transition:transform .14s var(--spring), background .18s, color .18s, border-color .18s; }
.copy:hover { background:var(--green-soft); border-color:#bcd6c4; transform:translateY(-1px); }
.copy:active { transform:scale(.9); }
.copy.copied { background:var(--green-soft); color:var(--green); border-color:#bcd6c4; }
.skeleton { height:84px; border-radius:var(--r-md); margin-bottom:13px; border:1px solid var(--line-2); background:linear-gradient(100deg,var(--inset) 30%,#ede4d3 50%,var(--inset) 70%); background-size:200% 100%; animation:shimmer 1.2s infinite; }
.thinking { display:inline-flex; align-items:center; gap:7px; color:var(--muted); font-size:.78rem; font-weight:600; margin-bottom:12px; }
.thinking i { width:6px; height:6px; border-radius:50%; background:var(--green); display:inline-block; animation:bob 1s infinite var(--ease); }
.thinking i:nth-child(2){ animation-delay:.15s; } .thinking i:nth-child(3){ animation-delay:.3s; }
@keyframes bob { 0%,100%{ transform:translateY(0); opacity:.4;} 50%{ transform:translateY(-5px); opacity:1;} }
@keyframes shimmer { from{ background-position:200% 0;} to{ background-position:-200% 0;} }
.pill { font-size:.68rem; font-weight:600; padding:3px 9px; border-radius:999px; background:var(--terra-soft); color:var(--terra); border:1px solid #ecd5c1; margin-left:8px; }

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero-grid { grid-template-columns:1fr; gap:34px; }
  .hero-seal { width:88px; top:8px; }
  .steps, .feat-grid, .stats, .foot-inner { grid-template-columns:1fr; }
  .workspace { grid-template-columns:1fr; }
  .masthead .seal { width:84px; }
}
@media (max-width:760px){
  .nav-links { position:fixed; inset:70px 0 auto 0; flex-direction:column; align-items:stretch; gap:0; background:var(--paper); border-bottom:1px solid var(--line); padding:10px 22px 18px; transform:translateY(-12px); opacity:0; pointer-events:none; transition:opacity .25s, transform .25s; }
  .nav-links.open { opacity:1; transform:none; pointer-events:auto; }
  .nav-links a { padding:13px 4px; border-bottom:1px solid var(--line-2); }
  .nav-links a.btn { margin-top:10px; justify-content:center; }
  .nav-toggle { display:inline-grid; place-items:center; }
}
@media (max-width:560px){ .masthead .seal, .hero-seal { display:none; } .container,.nav-inner,main.app { padding-left:18px; padding-right:18px; } }
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after { animation:none !important; transition:none !important; }
  .reveal { opacity:1 !important; transform:none !important; }
  .reply { opacity:1; transform:none; } .reply::before { transform:scaleY(1); }
}
