@font-face{font-family:'Hanken Grotesk Fallback';src:local('Arial');size-adjust:123.47%;ascent-override:80.99%;descent-override:24.54%;line-gap-override:0%}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;min-height:100vh;font-family:var(--body);color:var(--fg);line-height:1.6;
letter-spacing:-.005em;background:var(--page-bg);background-attachment:fixed}
::selection{background:var(--accent);color:var(--accent-ink)}
a{color:var(--accent-text);text-decoration:none}a:hover{text-decoration:underline;text-underline-offset:3px}
.wrap{max-width:44rem;margin:0 auto;padding:1.25rem}
header.site{position:sticky;top:0;z-index:20;background:var(--header-bg);
backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--border)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem}
.brand{font-family:var(--display);font-weight:800;font-size:1.2rem;letter-spacing:-.02em;color:var(--fg);white-space:nowrap}
.brand:hover{text-decoration:none;color:var(--accent-text)}
nav a{margin-left:1.1rem;color:var(--muted);font-size:.92rem}nav a:hover{color:var(--fg);text-decoration:none}
h1,h2{font-family:var(--display);letter-spacing:-.025em}
h1{font-size:2rem;line-height:1.08;font-weight:800;margin:.2rem 0 .6rem}
h2{font-size:1.25rem;font-weight:700;margin:1.5rem 0 .5rem}
/* In-place editable title (Google-Docs style): looks like the h1 until focused. */
.titleform{margin:0;position:relative}
/* Always-visible rename hint — hover alone never tells a touch user the title is
   editable. Recedes on focus (you're already editing). */
.titleform::after{content:'\270E';position:absolute;right:.5rem;top:50%;transform:translateY(-50%);
color:var(--muted);opacity:.55;font-size:1rem;pointer-events:none}
.titleform:focus-within::after{content:''}
.title-edit{display:block;width:100%;box-sizing:border-box;font-family:var(--display);font-size:2rem;line-height:1.08;font-weight:800;letter-spacing:-.025em;color:var(--fg);margin:.2rem 0 .6rem;padding:.15rem .35rem;border:0;border-radius:.45rem;background:transparent;cursor:text}
.title-edit:hover{background:var(--card-2)}
.title-edit:focus{outline:2px solid var(--accent);outline-offset:1px;background:var(--card)}
/* Owner-only risk warning under the Write/Photo parts, and the self-scan banner. */
.riskwarn{display:flex;gap:.5rem;align-items:flex-start;background:var(--warnbg);border:1px solid var(--warn-line);color:var(--fg);border-radius:.6rem;padding:.55rem .7rem;margin:.3rem 0 0;font-size:.85rem;line-height:1.45}
.riskwarn[hidden]{display:none}
.selfscan{display:flex;justify-content:space-between;align-items:center;gap:.6rem;background:var(--card-2);border:1px solid var(--accent-line);border-radius:.7rem;padding:.6rem .85rem;margin:0 0 1rem}
p{margin:.5rem 0}
.muted{color:var(--muted)}
.eyebrow{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
color:var(--accent-text);margin-bottom:.5rem}
.hero{padding:2.6rem 0 1.2rem;text-align:center}
.hero h1{font-size:clamp(2.2rem,8vw,3.2rem);background:var(--hero-grad);
-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:1.15rem;color:var(--muted);max-width:32rem;margin:.5rem auto 1.6rem}
.card{position:relative;background:linear-gradient(180deg,var(--card-2),var(--card));
border:1px solid var(--border);border-radius:var(--radius);padding:1.15rem;margin:.9rem 0;
backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--inset) inset,0 18px 40px -24px var(--shadow)}
.btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent);color:var(--accent-ink);
border:0;border-radius:.7rem;padding:.7rem 1.25rem;font-family:var(--body);font-size:1rem;font-weight:700;
letter-spacing:-.01em;cursor:pointer;box-shadow:0 6px 22px -10px var(--accent-glow)}
.btn:hover{box-shadow:var(--glow);text-decoration:none}
.btn.lg{padding:.9rem 1.8rem;font-size:1.1rem}
.btn.secondary{background:transparent;color:var(--fg);border:1px solid var(--border-2);font-weight:600;box-shadow:none}
.btn.secondary:hover{border-color:var(--accent-text);color:var(--accent-text);box-shadow:none}
.btn:disabled,.btn[disabled],.btn[aria-disabled=true]{filter:grayscale(.75);opacity:.38;cursor:not-allowed;
box-shadow:none;pointer-events:none}
.row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
input,select,textarea{font:inherit;color:var(--fg);padding:.65rem .75rem;border:1px solid var(--border);
border-radius:.6rem;background:var(--field-bg);max-width:100%}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--accent-text);
box-shadow:0 0 0 3px var(--accent-soft)}
input::placeholder,textarea::placeholder{color:var(--muted)}
input[type=checkbox],input[type=radio]{accent-color:var(--accent-text)}
input[type=text],input[name=dest],input[name=label],textarea{width:100%}
textarea{resize:vertical}
label.choice{display:flex;align-items:center;gap:.65rem;margin:.5rem 0;padding:.85rem 1rem;
border:1px solid var(--border);border-radius:.75rem;cursor:pointer;background:var(--card)}
label.choice:hover{border-color:var(--border-2);background:var(--card-2)}
label.choice:has(input:checked){border-color:var(--accent-text);background:var(--accent-soft);
box-shadow:0 0 0 1px var(--accent) inset}
label.choice input{accent-color:var(--accent-text)}
/* Read-only Pick preview on a sign-in-gated scan page: same shape as a choice,
   visibly inert (no control, no hover) so the Sender sees what sign-in unlocks. */
.choice-prev{display:flex;align-items:center;gap:.65rem;margin:.5rem 0;padding:.85rem 1rem;
border:1px dashed var(--border);border-radius:.75rem;background:var(--card);color:var(--fg)}
.pill{display:inline-block;padding:.15rem .6rem;border-radius:1rem;font-size:.72rem;font-weight:700;
letter-spacing:.02em;border:1px solid transparent}
.pill.ok{background:var(--okbg);color:var(--ok);border-color:var(--ok-line)}
.pill.off{background:var(--warnbg);color:var(--warn);border-color:var(--warn-line)}
.pill.claimable{background:var(--claimbg);color:var(--claim);border-color:var(--claim-line)}
code{font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;background:var(--code-bg);
padding:.12rem .4rem;border-radius:.35rem;font-size:.88em;border:1px solid var(--border)}
/* First-run setup checklist. Status is carried by SHAPE, not colour: an empty
   circle = to-do, a check = done (so it never collides with the green/red status
   meaning people expect, and accent stays reserved for ACTIONS). The next step is
   the only emphasised one — bold, with an accent arrow link to where it's done;
   completed steps recede, later ones stay faint. No numbering → no gaps. */
.setup-head{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}
.setup-meta{display:flex;align-items:center;gap:.5rem;flex:0 0 auto}
.setup-prog{font-size:.78rem;font-weight:700;color:var(--muted);letter-spacing:.04em;white-space:nowrap}
.setup-x{background:transparent;border:0;color:var(--muted);font-size:1.2rem;line-height:1;
cursor:pointer;padding:.1rem .3rem;border-radius:.4rem}
.setup-x:hover{color:var(--fg);background:var(--card-2)}
/* Segmented control (print options): a pill track where EVERY option reads as a
   selectable slot — inactive options aren't bare text, they light up on hover so
   it's obvious the whole row is clickable, not just the filled one. */
.seg{display:inline-flex;flex-wrap:wrap;gap:2px;background:var(--track);border:1px solid var(--border-2);
border-radius:.6rem;padding:3px}
.seg a{padding:.45rem .8rem;border-radius:.45rem;font-size:.82rem;font-weight:700;color:var(--muted);
text-decoration:none;white-space:nowrap}
.seg a:hover{color:var(--fg);background:var(--card)}
.seg a.on,.seg a.on:hover{background:var(--fg);color:#fff}
.steps{list-style:none;padding:0;margin:.6rem 0 0}
.steps li{position:relative;padding:.7rem 0 .7rem 2.1rem;border-top:1px solid var(--border)}
.steps li:first-child{border-top:0}
/* to-do marker: an empty, unchecked circle */
.steps li::before{content:'';position:absolute;left:.1rem;top:.92rem;width:1.05rem;height:1.05rem;
box-sizing:border-box;border-radius:50%;background:transparent;border:1.5px solid var(--border-2)}
/* the next step's circle gets a slightly stronger ring, but stays hollow (not a
   filled colour swatch) so it reads as the current target, not a status light */
.steps li.next::before{border-color:var(--muted)}
/* done marker: a neutral check (shape carries the meaning, no status colour) */
.steps li.done::before{content:'\2713';border:0;background:transparent;color:var(--muted);
left:.05rem;font-size:1rem;font-weight:800;line-height:1.05rem;text-align:center}
/* The landing how-it-works list reuses the step layout but is a SEQUENCE, not a
   checklist — numbered markers, so the circles can't read as unchecked to-dos. */
.steps.how{counter-reset:step}
.steps.how li::before{content:counter(step);counter-increment:step;color:var(--muted);
font-size:.72rem;font-weight:800;line-height:1rem;text-align:center}
.steps .step{display:inline-flex;align-items:center;gap:.4rem;color:var(--muted);text-decoration:none}
.steps li.next .step{color:var(--fg);font-weight:700}
.steps a.step:hover{color:var(--accent-text)}
.steps .step-go{color:var(--accent-text);font-weight:800}        /* arrow = the only accent (an action) */
footer.site{border-top:1px solid var(--border);margin-top:2.5rem;color:var(--muted);font-size:.9rem}
.toolbar{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:.5rem}
.toolbar form{display:inline}
.center{text-align:center}.mt{margin-top:1rem}
.saved-banner{background:var(--okbg);color:var(--ok);border:1px solid var(--ok-line);
border-radius:var(--radius);padding:.7rem 1.1rem;margin:.5rem 0;font-weight:600}
/* Listing scan page — the 'offer ticket' */
.lot{padding:1.6rem 0 .3rem}
.lot .eyebrow{margin-bottom:.45rem}
.lot h1{font-size:clamp(1.9rem,7vw,2.9rem);line-height:1.05;margin:.1rem 0 .55rem}
.lot .desc{color:var(--muted);font-size:1.06rem;max-width:34rem;white-space:pre-wrap}
/* Scan-page trust chip — the stranger's 'this is safe/private' reassurance */
.trust{display:flex;gap:.55rem;align-items:flex-start;background:var(--card-2);
border:1px solid var(--accent-line);border-radius:.8rem;padding:.7rem .85rem;margin:1rem 0 0;
font-size:.92rem;color:var(--fg);line-height:1.4;max-width:34rem}
.trust svg{flex:0 0 auto;margin-top:.15rem;color:var(--accent-text)}
.lot-meta{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.8rem}
.offer-form{margin-top:1.2rem}
.offer-label{font-family:var(--display);font-weight:700;font-size:1.05rem;margin:.4rem 0 .65rem}
.offer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(8rem,1fr));gap:.55rem;margin:0 0 1rem}
.offer-opt{position:relative;display:flex;align-items:center;justify-content:center;text-align:center;
min-height:3.4rem;padding:.75rem .85rem;border:1px solid var(--border);border-radius:.85rem;
background:var(--card);cursor:pointer;font-weight:600;line-height:1.25}
.offer-opt:hover{border-color:var(--border-2)}
.offer-opt input{position:absolute;inset:0;opacity:0;margin:0;cursor:pointer}
.offer-opt:has(input:checked){border-color:var(--accent-text);background:var(--accent-soft);
box-shadow:0 0 0 1px var(--accent) inset,0 10px 26px -14px var(--accent-glow)}
.offer-opt:has(input:checked)::after{content:'\2713';position:absolute;top:.3rem;right:.5rem;
color:var(--accent-text);font-size:.72rem;font-weight:800}
.offer-or{display:flex;align-items:center;gap:.7rem;color:var(--muted);font-size:.74rem;
text-transform:uppercase;letter-spacing:.16em;margin:.1rem 0 .7rem}
.offer-or::before,.offer-or::after{content:'';height:1px;flex:1;background:var(--border)}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.9rem;color:var(--muted);margin:.9rem 0}
.consent input{accent-color:var(--accent-text);margin-top:.18rem;flex:0 0 auto}
.btn.block{display:flex;width:100%;justify-content:center}
.imgcap{margin:.2rem 0 .4rem}
/* Owner identity in the header (owner-facing only — ADR 0020) */
.userbox{display:flex;align-items:center;gap:.55rem}
.userbox .avatar{width:1.9rem;height:1.9rem;border-radius:50%;object-fit:cover;
border:1px solid var(--border-2);background:var(--card-2)}
.userbox .avatar.ph{display:inline-flex;align-items:center;justify-content:center;
font-weight:800;font-size:.85rem;color:var(--accent-text)}
.userbox .uname{color:var(--fg);font-size:.92rem;max-width:8rem;overflow:hidden;
text-overflow:ellipsis;white-space:nowrap}
.userbox form{display:inline;margin:0}
.userbox .userlink{display:flex;align-items:center;gap:.45rem;text-decoration:none}
.userbox .userlink:hover{text-decoration:none}
.userbox .userlink:hover .uname{color:var(--accent-text)}
.signout{background:transparent;border:1px solid var(--border-2);color:var(--muted);
border-radius:.6rem;padding:.32rem .7rem;font:inherit;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap}
.signout:hover{border-color:var(--accent-text);color:var(--accent-text)}
/* Narrow phones: hide the display name so the header (brand · nav · avatar ·
   Sign out, all now nowrap) fits one line without wrapping. The name still shows
   on /account, and the avatar keeps identity visible here. */
@media(max-width:30rem){.userbox .uname{display:none}}
/* Footer language switch — links padded for 44 px tap target */
.langs{margin-top:.45rem;font-size:.82rem;color:var(--muted);margin-left:-.5rem}
.langs a{color:var(--muted);display:inline-block;padding:.5rem .5rem}
.langs a.on{color:var(--accent-text);font-weight:700}
/* Quiet navigation link — padded for 44 px tap target on mobile */
a.nav{display:inline-block;color:var(--accent-text);font-weight:600;font-size:.92rem;white-space:nowrap;padding:.3rem 0}
/* Dashboard Print-selection checkbox */
.stk-sel{width:1.05rem;height:1.05rem;accent-color:var(--accent-text);flex:0 0 auto}
/* Dashboard sticker row: title is the link to the sticker page (no separate Edit) */
.stk-title{font-family:var(--display);font-weight:700;font-size:1.02rem;color:var(--fg);letter-spacing:-.02em}
.stk-title:hover{color:var(--accent-text);text-decoration:none}
/* Responses chip — lit when the sticker has any responses, dim when none */
.resp{display:inline-flex;align-items:center;gap:.35rem;font-weight:700;font-size:.85rem;padding:.45rem .65rem;
min-height:2.75rem;border-radius:.6rem;border:1px solid var(--border-2);color:var(--muted);white-space:nowrap}
.resp.has{color:var(--accent-text);border-color:var(--accent-line);background:var(--accent-soft)}
.resp.has:hover{box-shadow:var(--glow);text-decoration:none}
/* Sticker-quota usage meter on the mint card */
.usage{font-size:.82rem;color:var(--muted);font-weight:600;text-align:right}
.meter{width:8rem;height:.4rem;border-radius:1rem;background:var(--track);overflow:hidden;margin-top:.25rem;margin-left:auto}
.meter span{display:block;height:100%;background:var(--accent);border-radius:1rem}
.meter.full span{background:var(--warn)}
.quota-warn{font-size:.85rem;color:var(--warn);margin:.7rem 0 0}
/* Quiet disclosure toggle (mint 'more options') */
.disc{font-size:.85rem;color:var(--muted);cursor:pointer;user-select:none}
.disc:hover{color:var(--fg)}
/* Responses views (relay feed / offers) */
.who-row{display:flex;align-items:center;gap:.5rem}
.who{display:flex;align-items:center;gap:.5rem}
.av{width:1.9rem;height:1.9rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.8rem;flex:0 0 auto}
.av.anon{border:1px dashed var(--border-2);color:var(--muted)}
.av.id{background:var(--accent-soft);color:var(--accent-text);border:1px solid var(--accent-line)}
.when{margin-left:auto;color:var(--muted);font-size:.8rem}
.pick{font-family:var(--display);font-weight:700;font-size:1.06rem;margin:.5rem 0 .1rem}
.quote{border-left:2px solid var(--border-2);padding-left:.7rem;color:var(--quote-fg);margin:.4rem 0;white-space:pre-wrap}
.vote-track{height:.7rem;border-radius:1rem;background:var(--track);overflow:hidden}
.vote-bar{display:block;height:100%;border-radius:1rem;background:var(--accent)}
.qr-tile{border-radius:.5rem;background:var(--qr-bg);padding:5px;display:block}
.pill.loc{background:var(--accent-2-soft);color:var(--accent-2);border-color:var(--accent-2-line)}
.pill.win{background:var(--accent-soft);color:var(--accent-text);border-color:var(--accent-line)}
/* Landing feature cards — single column on narrow phones */
.feat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(9rem,1fr));gap:.7rem;margin:1.2rem 0}
@media(max-width:29rem){.feat-cards{grid-template-columns:1fr}}