/* Atopa Design System — "Calm Green Brutalism + liquid-glass jewel"
 * Single source of truth for all Atopa surfaces. Served at /static/atopa.css.
 * Type: Bricolage Grotesque (display) · Hanken Grotesk (body) · Space Mono (mono/code).
 * Glass: CSS provides a frosted-blur base (Safari / no-JS fallback); atopa.js upgrades
 * capable browsers to true SVG-displacement refraction. Progressive enhancement. */

/* Self-hosted fonts (latin + latin-ext), served from /static/fonts — no third-party
 * requests, so no visitor IP ever reaches a font CDN (privacy + EU/GDPR friendly). */
@font-face{font-family:"Bricolage Grotesque";font-style:normal;font-weight:400 700;font-display:swap;src:url(/static/fonts/bricolage-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Bricolage Grotesque";font-style:normal;font-weight:400 700;font-display:swap;src:url(/static/fonts/bricolage-latinext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Hanken Grotesk";font-style:normal;font-weight:400 700;font-display:swap;src:url(/static/fonts/hanken-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Hanken Grotesk";font-style:normal;font-weight:400 700;font-display:swap;src:url(/static/fonts/hanken-latinext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Space Mono";font-style:normal;font-weight:400;font-display:swap;src:url(/static/fonts/spacemono-400-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Space Mono";font-style:normal;font-weight:400;font-display:swap;src:url(/static/fonts/spacemono-400-latinext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Space Mono";font-style:normal;font-weight:700;font-display:swap;src:url(/static/fonts/spacemono-700-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Space Mono";font-style:normal;font-weight:700;font-display:swap;src:url(/static/fonts/spacemono-700-latinext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}

*{box-sizing:border-box;}

:root{
  --bg:#F2F6F1;--bg-alt:#EAF1E9;--surface:#FFFFFF;--plate:#DDE9DA;
  --ink:#162616;--text:#20381F;--muted:#2A4A28;
  --primary:#3F6F3A;--primary-h:#345C31;--soft:#6F9C6A;--accent:#2E4D2C;
  --rule:#94B88F;--rule-minor:#BBD3B6;--danger:#B42318;
  --maxw:1140px;
  --fs-display:clamp(2.3rem,6vw,4.4rem);--fs-h2:clamp(1.5rem,3.2vw,2.2rem);
  --fs-kicker:.76rem;--fs-sub:clamp(1.02rem,2.1vw,1.2rem);
}

html{scroll-behavior:smooth;}
body{margin:0;background:var(--bg);color:var(--text);font-family:"Hanken Grotesk",system-ui,sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden;}

/* Calm soft-green ambiance — no busy patterns (locked decision). */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(60vw 52vw at 50% -12%,rgba(111,156,106,.16),transparent 70%);}
.deco{position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(46vw 46vw at 86% 0%,rgba(111,156,106,.32),transparent 60%),radial-gradient(40vw 40vw at -6% 100%,rgba(148,184,143,.26),transparent 64%),radial-gradient(30vw 30vw at 60% 70%,rgba(63,111,58,.16),transparent 62%);filter:blur(10px);}

.wrap{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,5vw,52px);}
.mono{font-family:"Space Mono",monospace;text-transform:uppercase;letter-spacing:.14em;}

/* ---- Navigation ---- */
.nav{position:sticky;top:0;z-index:20;background:rgba(242,246,241,.5);backdrop-filter:saturate(1.2) blur(8px);-webkit-backdrop-filter:saturate(1.2) blur(8px);border-bottom:2px solid var(--rule);}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:14px clamp(18px,5vw,52px);display:flex;align-items:center;justify-content:space-between;gap:14px;}
.brand{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.45rem;letter-spacing:-.02em;color:var(--accent);white-space:nowrap;text-decoration:none;}
.brand .net{color:var(--primary);}
.nav-right{display:flex;align-items:center;gap:14px;}
.applinks{display:flex;gap:18px;}
.applinks a{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding-bottom:3px;border-bottom:2px solid transparent;}
.applinks a.active{color:var(--accent);border-color:var(--primary);}
@media(max-width:620px){.applinks{display:none;}}

/* Language pill (design-system switcher) */
.pill{display:inline-flex;border:1.5px solid var(--rule);border-radius:999px;overflow:hidden;background:rgba(255,255,255,.42);}
.pill a{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.08em;padding:6px 10px;text-decoration:none;color:var(--muted);}
.pill a.active{background:var(--primary);color:#F2F6F1;font-weight:700;}
.pill a:focus-visible{outline:2px solid var(--primary);outline-offset:1px;}
.enter{font-family:"Space Mono",monospace;text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:var(--accent);text-decoration:none;}
.adminbadge{font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.14em;background:var(--accent);color:#F2F6F1;padding:3px 8px;border-radius:5px;}

/* ---- Type & hero ---- */
.kicker{font-family:"Space Mono",monospace;font-size:var(--fs-kicker);letter-spacing:.18em;text-transform:uppercase;color:var(--primary);display:inline-flex;align-items:center;gap:9px;}
.kicker.rule::before{content:"";width:24px;height:2px;background:var(--primary);}
h1{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:var(--fs-display);line-height:.96;letter-spacing:-.03em;color:var(--ink);margin:16px 0 0;}
h1 .accent{color:var(--primary);}
.lede{font-size:var(--fs-sub);color:var(--muted);max-width:46ch;margin:20px 0 0;}
.cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px;}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 24px;border-radius:11px;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1rem;cursor:pointer;text-decoration:none;border:2px solid var(--primary);transition:background .25s,transform .15s;}
.btn-primary{background:var(--primary);color:#F2F6F1;}
.btn-primary:hover{background:var(--primary-h);transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--accent);border-color:var(--rule);}
.btn-ghost:hover{border-color:var(--primary);transform:translateY(-2px);}
.btn-block{width:100%;}
.trustline{margin-top:22px;font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);}

/* ---- Glass chips: make inline clickable text read as tappable (frosted pill).
 * Subtle by default; .chip--primary for the main action on a surface. ---- */
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 13px;border-radius:999px;
  font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.07em;text-transform:uppercase;font-weight:700;
  line-height:1;white-space:nowrap;text-decoration:none;cursor:pointer;color:var(--accent);
  border:1.5px solid var(--rule);background:rgba(255,255,255,.42);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6);
  backdrop-filter:saturate(1.35) blur(7px);-webkit-backdrop-filter:saturate(1.35) blur(7px);
  transition:border-color .2s,background .2s,transform .15s,box-shadow .2s;}
.chip:hover{border-color:var(--primary);background:rgba(255,255,255,.66);transform:translateY(-1px);
  box-shadow:0 8px 18px -12px rgba(22,38,22,.55),inset 0 1px 0 rgba(255,255,255,.7);}
.chip:focus-visible{outline:3px solid var(--primary);outline-offset:2px;}
.chip svg{width:14px;height:14px;display:block;}
.chip--primary{color:#F2F6F1;border-color:var(--primary);
  background:linear-gradient(180deg,rgba(90,140,84,.96),rgba(63,111,58,.96));}
.chip--primary:hover{background:linear-gradient(180deg,var(--primary),var(--primary-h));color:#F2F6F1;}
.chip--danger{color:var(--danger);border-color:rgba(180,35,24,.4);}
.chip--danger:hover{border-color:var(--danger);background:rgba(251,238,236,.7);color:var(--danger);}
.chip-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
/* Keep chip colours inside app surfaces — .app-admin a / .app-owner a (0,1,1)
 * would otherwise override the chip text colour and paint it green-on-green. */
.app-admin a.chip,.app-owner a.chip{color:var(--accent);}
.app-admin a.chip--primary,.app-owner a.chip--primary,.chip.chip--primary{color:#F2F6F1;}
.app-admin a.chip--primary:hover,.app-owner a.chip--primary:hover{color:#F2F6F1;}
.app-admin a.chip--danger,.app-owner a.chip--danger,.chip.chip--danger{color:var(--danger);}

/* ---- Status line ---- */
.status{display:flex;flex-wrap:wrap;gap:8px 22px;align-items:baseline;padding:14px 0;border-bottom:2px solid var(--rule-minor);color:var(--muted);font-size:var(--fs-kicker);}
.status .tag{color:var(--primary);font-weight:700;}.status .ok{color:var(--primary);}.status .code{color:var(--ink);}

/* ---- Signature jewel (the glass focal point) ---- */
.jewelwrap{display:flex;justify-content:center;}
.token{position:relative;width:280px;height:280px;max-width:84vw;border-radius:30px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.6);box-shadow:0 32px 70px -28px rgba(22,38,22,.5),inset 0 1.5px 0 rgba(255,255,255,.85),inset 0 -22px 42px -26px rgba(46,77,44,.5);transition:transform .45s cubic-bezier(.2,.7,.2,1);backdrop-filter:saturate(1.4) blur(7px);-webkit-backdrop-filter:saturate(1.4) blur(7px);}
.token::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:2;background:linear-gradient(140deg,rgba(255,255,255,.6),rgba(255,255,255,0) 40%);}
.token:hover{transform:translateY(-5px);}
.token .cap,.token .code2{position:absolute;left:0;right:0;text-align:center;font-family:"Space Mono",monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);z-index:3;}
.token .cap{top:18px;}.token .code2{bottom:18px;}
.token .plate{width:166px;height:166px;background:#fff;border-radius:18px;padding:18px;box-shadow:0 7px 20px rgba(22,38,22,.22);position:relative;z-index:3;display:flex;align-items:center;justify-content:center;}
.token .plate svg{width:100%;height:100%;display:block;color:var(--primary);}

.hero{display:grid;grid-template-columns:1fr;gap:clamp(30px,5vw,60px);align-items:center;padding:clamp(36px,7vw,84px) 0 clamp(28px,5vw,52px);}
@media(min-width:880px){.hero{grid-template-columns:1.05fr .95fr;}}

/* ---- Cards & forms ---- */
.card{position:relative;background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:clamp(20px,3vw,26px);box-shadow:0 22px 50px -34px rgba(22,38,22,.4);backdrop-filter:saturate(1.3) blur(7px);-webkit-backdrop-filter:saturate(1.3) blur(7px);}
.ttl{font-family:"Space Mono",monospace;text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:var(--muted);margin-bottom:14px;}
.field{margin-bottom:14px;display:grid;gap:6px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--text);}
.field input,.field textarea,.field select{width:100%;padding:13px 14px;border-radius:10px;border:2px solid var(--rule);background:var(--bg);color:var(--text);font:inherit;font-size:15px;min-height:44px;}
.field textarea{min-height:120px;resize:vertical;}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(63,111,58,.22);}
.fineprint{margin:12px 0 0;font-size:12.5px;color:var(--muted);}
.helper{margin:0;color:var(--soft);font-size:13px;}
.alt{margin-top:14px;font-size:13.5px;color:var(--muted);}.alt a{color:var(--primary);font-weight:700;text-decoration:none;}

/* Inline focus visibility for all interactive controls (a11y floor) */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--primary);outline-offset:2px;}

/* ---- Found / public-recovery specifics ---- */
.body-copy,.owner-fallback,.privacy{margin:16px 0 0;color:var(--muted);}
.owner-message{margin:24px 0;padding:16px 18px;border-left:3px solid var(--primary);background:var(--bg);border-radius:0 10px 10px 0;}
.owner-message__label{margin:0 0 8px;color:var(--primary);font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;}
.owner-message blockquote{margin:0;color:var(--text);font-size:1.02rem;}
.error-summary{margin:0 0 4px;padding:12px 16px;border-left:3px solid var(--danger);background:#FBEEEC;color:var(--ink);border-radius:0 10px 10px 0;}
.error-summary p{margin:0;}
.field-error{margin:0;color:var(--danger);font-size:13px;font-weight:600;}
.honeypot{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden;}
.secondary-link{margin-top:24px;display:inline-flex;align-items:center;justify-content:center;width:max-content;max-width:100%;padding:12px 18px;border:2px solid var(--rule);border-radius:11px;background:transparent;color:var(--accent);text-decoration:none;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;}
.secondary-link:hover{border-color:var(--primary);}

/* ---- Sections / steps / values (landing, legal) ---- */
/* Landing hero privacy reassurance — a quiet green-bordered note under the CTA. */
.hero .reassure{margin:22px 0 0;padding:10px 0 10px 14px;border-left:3px solid var(--primary);color:var(--muted);font-size:.97rem;line-height:1.5;max-width:46ch;}
.sec{padding:clamp(36px,5vw,64px) 0;border-top:2px solid var(--rule);}
.eyebrow{font-family:"Space Mono",monospace;font-size:var(--fs-kicker);letter-spacing:.18em;text-transform:uppercase;color:var(--primary);}
.sec h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:var(--fs-h2);letter-spacing:-.02em;color:var(--ink);margin:10px 0 0;}
.prose{max-width:720px;padding:clamp(28px,5vw,56px) 0;}
.prose h1{font-size:clamp(2rem,4vw,2.8rem);}
.prose h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.3rem;letter-spacing:-.01em;color:var(--ink);margin:30px 0 8px;}
.prose p{color:var(--muted);margin:0 0 14px;font-size:1.02rem;max-width:66ch;}
.mini{font-family:"Space Mono",monospace;font-size:11px;color:var(--soft);letter-spacing:.06em;}

/* ---- App layout (owner/admin) ---- */
.apphead{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;justify-content:space-between;padding:clamp(28px,4vw,48px) 0 24px;}
.app-h{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:-.025em;color:var(--ink);margin:8px 0 0;}
.auth-h{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.9rem;letter-spacing:-.02em;color:var(--ink);margin:10px 0 20px;}
.authwrap{display:flex;justify-content:center;padding:clamp(40px,9vw,120px) 0;}
.authcard{width:100%;max-width:430px;}
/* Auth forms keep their <label>-wraps-<input> markup; style them within the card. */
.authcard form label{display:grid;gap:6px;margin:0 0 14px;font-size:13px;font-weight:600;color:var(--text);}
.authcard input{width:100%;padding:13px 14px;border-radius:10px;border:2px solid var(--rule);background:var(--bg);color:var(--text);font:inherit;font-size:15px;min-height:44px;}
.authcard input:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(63,111,58,.22);}
.authcard button{width:100%;margin-top:4px;display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 24px;border-radius:11px;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1rem;cursor:pointer;border:2px solid var(--primary);background:var(--primary);color:#F2F6F1;transition:background .25s,transform .15s;}
.authcard button:hover{background:var(--primary-h);transform:translateY(-2px);}
.authcard .helper{margin:-6px 0 14px;color:var(--soft);font-size:13px;}
.authcard .message{margin:0 0 14px;padding:12px 14px;border-left:3px solid var(--primary);background:var(--bg);border-radius:0 10px 10px 0;color:var(--text);}
.authcard p{margin:12px 0 0;color:var(--muted);font-size:13.5px;}
.authcard a{color:var(--primary);font-weight:700;text-decoration:none;}
.cols{display:grid;grid-template-columns:1fr;gap:20px;margin-top:8px;}
@media(min-width:880px){.cols{grid-template-columns:1fr 1.1fr;align-items:start;}}

/* ---- Tables ---- */
.tablewrap{overflow-x:auto;border:2px solid var(--rule);border-radius:14px;background:var(--surface);}
table.tbl{width:100%;border-collapse:collapse;min-width:560px;}
table.tbl th{text-align:left;font-family:"Space Mono",monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:14px 18px;border-bottom:2px solid var(--rule);font-weight:700;}
table.tbl td{padding:15px 18px;border-bottom:1px solid var(--rule-minor);font-size:14px;color:var(--text);overflow-wrap:anywhere;}
table.tbl tr:last-child td{border-bottom:0;}
table.tbl .code{font-family:"Space Mono",monospace;font-size:12.5px;color:var(--accent);}
table.tbl .st{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;}
table.tbl .st.on{color:var(--primary);}table.tbl .st.off{color:var(--soft);}
table.tbl a{color:var(--primary);font-weight:700;text-decoration:none;font-family:"Space Mono",monospace;font-size:12px;}

/* Shared table polish (applies to .tbl, admin & owner tables): aligned numerics,
 * quiet row hover, tighter head rule — "subtle rule borders + good alignment". */
table.tbl td,table.tbl th,
.app-admin .admin-table td,.app-admin .admin-table th,
.app-owner .tag-table td,.app-owner .tag-table th{font-variant-numeric:tabular-nums;vertical-align:middle;}
table.tbl tbody tr,.app-admin .admin-table tbody tr,.app-owner .tag-table tbody tr{transition:background .15s;}
table.tbl tbody tr:hover,.app-admin .admin-table tbody tr:hover,.app-owner .tag-table tbody tr:hover{background:rgba(63,111,58,.05);}
/* Right-align numeric columns; keep header aligned with its column. */
.num,td.num,th.num{text-align:right;font-variant-numeric:tabular-nums;}
/* Compact action cell so chips sit on one tidy row. */
td.actions,.app-admin .admin-table td.actions{white-space:nowrap;}
td.actions .chip{padding:5px 11px;}
/* Row title links read as names, not mono codes. */
table.tbl a.rowname,.app-owner .tag-table a.rowname{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:14px;letter-spacing:-.01em;text-transform:none;color:var(--primary);text-decoration:none;}

/* ---- How-it-works steps ---- */
.how-steps{list-style:none;margin:28px 0 8px;padding:0;display:grid;gap:20px;}
.how-step{display:flex;gap:16px;align-items:flex-start;}
.how-step .how-num{flex:0 0 auto;width:40px;height:40px;display:grid;place-items:center;border-radius:12px;background:var(--primary);color:#F2F6F1;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.1rem;}
.how-step h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.2rem;letter-spacing:-.01em;color:var(--ink);margin:6px 0 4px;}
.how-step p{margin:0;color:var(--muted);font-size:1.02rem;line-height:1.55;max-width:60ch;}
.prose.how .cta{margin-top:30px;}

/* ---- KPI stats ---- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:6px;}
@media(min-width:760px){.stats{grid-template-columns:repeat(4,1fr);}}
.stat{background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:20px;box-shadow:0 22px 50px -34px rgba(22,38,22,.4);backdrop-filter:saturate(1.3) blur(7px);-webkit-backdrop-filter:saturate(1.3) blur(7px);}
.stat .num{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:2rem;color:var(--ink);line-height:1;}
.stat .lab{font-family:"Space Mono",monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-top:8px;}

/* ---- 404 ---- */
.notfound{min-height:58vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;}
.notfound .big{font-family:"Space Mono",monospace;font-size:clamp(3.4rem,13vw,7rem);color:var(--primary);letter-spacing:.08em;line-height:1;}
.notfound h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;color:var(--ink);margin:10px 0 0;font-size:1.7rem;}
.notfound .lede{margin-left:auto;margin-right:auto;}

/* ---- Footer ---- */
footer{position:relative;z-index:1;border-top:2px solid var(--rule);margin-top:clamp(28px,5vw,56px);}
.foot{max-width:var(--maxw);margin:0 auto;padding:24px clamp(18px,5vw,52px);display:flex;flex-wrap:wrap;gap:10px 22px;justify-content:space-between;color:var(--muted);font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;}
.foot a{color:inherit;text-decoration:none;border-bottom:1px solid var(--rule);padding-bottom:1px;}
.foot a:hover{color:var(--primary);border-color:var(--primary);}

/* ---- Owner app (tags.rs): restyle the existing owner markup in the design language.
 * Scoped to .app-owner so it never leaks onto public/auth pages. ---- */
.app-owner{padding-top:6px;}
.app-owner h1{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:clamp(1.7rem,4vw,2.5rem);line-height:1.04;letter-spacing:-.025em;color:var(--ink);margin:0;}
.app-owner h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.3rem;letter-spacing:-.01em;color:var(--ink);}
.app-owner a{color:var(--primary);font-weight:600;text-decoration:none;}
.app-owner .owner-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;padding:clamp(20px,3vw,32px) 0 22px;margin-bottom:24px;border-bottom:2px solid var(--rule-minor);}
.app-owner .owner-actions,.app-owner .actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
.app-owner .button,.app-owner button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:11px;padding:12px 20px;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1rem;cursor:pointer;text-decoration:none;border:2px solid var(--rule);background:transparent;color:var(--accent);transition:background .25s,transform .15s,border-color .2s;}
.app-owner .button:hover,.app-owner button:hover{border-color:var(--primary);}
.app-owner .button.primary,.app-owner button.primary,.app-owner .primary{background:var(--primary);color:#F2F6F1;border-color:var(--primary);}
.app-owner .button.primary:hover,.app-owner button.primary:hover,.app-owner .primary:hover{background:var(--primary-h);transform:translateY(-2px);}
.app-owner .button.secondary,.app-owner .secondary{background:transparent;color:var(--accent);border-color:var(--rule);}
.app-owner .button.secondary:hover,.app-owner .secondary:hover{border-color:var(--primary);}
.app-owner .message{padding:12px 16px;border-left:3px solid var(--primary);background:var(--bg);border-radius:0 10px 10px 0;color:var(--text);margin-bottom:16px;}
.app-owner .empty-state,.app-owner .tag-form,.app-owner .qr-panel{background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:clamp(20px,3vw,26px);box-shadow:0 22px 50px -34px rgba(22,38,22,.4);backdrop-filter:saturate(1.3) blur(7px);-webkit-backdrop-filter:saturate(1.3) blur(7px);}
/* Owner dashboard table lives inside .tablewrap (same container as admin tables):
 * the wrapper owns the border/radius/surface and the horizontal-scroll fallback, so
 * the table itself just sets a sane min-width and never forces page overflow. */
.app-owner .tag-table{width:100%;border-collapse:collapse;min-width:660px;}
.app-owner .tag-table th{text-align:left;font-family:"Space Mono",monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:14px 18px;border-bottom:2px solid var(--rule);font-weight:700;}
.app-owner .tag-table td{padding:15px 18px;border-bottom:1px solid var(--rule-minor);font-size:14px;color:var(--text);text-align:left;vertical-align:middle;}
.app-owner .tag-table tr:last-child td{border-bottom:0;}
/* Status pill + created date never wrap; only the URL cell breaks hard. */
.app-owner .tag-table .status{white-space:nowrap;}
.app-owner .tag-table td.datecell{white-space:nowrap;}
/* Public URL column: mono, wraps hard, capped so it can't push the table wide. */
.app-owner .tag-table td.urlcell{max-width:300px;overflow-wrap:anywhere;}
.app-owner .tag-table td.urlcell code{font-family:"Space Mono",monospace;font-size:12px;color:var(--accent);}
.app-owner .tag-table td.urlcell span{display:inline-block;font-family:"Space Mono",monospace;font-size:11.5px;color:var(--soft);word-break:break-all;}
/* Actions cell stays a real table-cell; controls sit on one compact wrapping row. */
.app-owner .tag-table td.actions{display:table-cell;white-space:normal;}
.app-owner .tag-table td.actions .rowactions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.app-owner .tag-table td.actions .qr-download-form{display:inline-flex;flex-wrap:wrap;gap:8px;align-items:center;margin:0;}
.app-owner .tag-table td.actions form{margin:0;}
.app-owner .tag-table td.actions button,.app-owner .tag-table td.actions .button{min-height:34px;padding:6px 12px;font-size:12.5px;border-radius:9px;}
.app-owner .tag-table td.actions select{width:auto;min-width:88px;min-height:34px;padding:6px 10px;font-size:12.5px;}
.app-owner .tag-cards{display:none;}
.app-owner .tag-card{background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:18px;margin-bottom:16px;}
.app-owner .status{display:inline-block;border:0;margin-left:8px;padding:4px 10px;border-radius:999px;font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;}
.app-owner .status.active{background:var(--rule-minor);color:var(--accent);}
.app-owner .status.paused{background:var(--bg-alt);color:var(--muted);}
.app-owner label{display:grid;gap:6px;margin:16px 0;color:var(--text);font-size:13px;font-weight:600;}
.app-owner input,.app-owner textarea,.app-owner select{width:100%;min-height:44px;border:2px solid var(--rule);border-radius:10px;padding:12px 14px;font:inherit;font-size:15px;background:var(--bg);color:var(--text);}
.app-owner input[type="checkbox"]{width:auto;min-height:auto;margin:0 8px 0 0;}
.app-owner textarea{min-height:120px;resize:vertical;}
.app-owner input:focus,.app-owner textarea:focus,.app-owner select:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(63,111,58,.22);}
.app-owner .helper{color:var(--soft);font-size:13px;}
.app-owner .detail-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;}
.app-owner .read-only-list{display:grid;grid-template-columns:160px minmax(0,1fr);gap:12px 16px;margin:0;}
.app-owner .read-only-list dt{color:var(--soft);font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;}
.app-owner .read-only-list dd{margin:0;overflow-wrap:anywhere;}
.app-owner .qr-preview,.app-owner .qr-placeholder{width:100%;aspect-ratio:1;display:grid;place-items:center;background:#fff;border:2px solid var(--rule);border-radius:12px;margin:16px 0;overflow:hidden;}
.app-owner .qr-preview svg{width:100%;height:auto;display:block;}
.app-owner .sticker-filters{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;align-items:end;background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:clamp(20px,3vw,26px);margin-bottom:24px;}
.app-owner .sticker-filters label{margin:0;}
.app-owner .sticker-results{display:grid;gap:16px;}
.app-owner .export-actions{margin-top:8px;}
.app-owner .pagination{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0;}
.app-owner .pagination a,.app-owner .pagination strong{min-width:44px;min-height:44px;display:grid;place-items:center;border-radius:10px;border:2px solid var(--rule);font-family:"Space Mono",monospace;font-size:13px;text-decoration:none;}
.app-owner .pagination strong{background:var(--primary);color:#F2F6F1;border-color:var(--primary);}
.app-owner .logout-form{margin-top:32px;}
@media(max-width:760px){
  .app-owner .owner-header{display:grid;align-items:start;}
  .app-owner .owner-actions,.app-owner .actions{display:grid;}
  .app-owner .button,.app-owner button{width:100%;}
  .app-owner .tablewrap.has-cards{display:none;}
  .app-owner .tag-cards{display:block;}
  .app-owner .detail-grid{grid-template-columns:1fr;}
  .app-owner .read-only-list{grid-template-columns:1fr;}
  .app-owner .sticker-filters{grid-template-columns:1fr;}
}

/* ---- Admin app (admin.rs): restyle the existing admin markup in the design language.
 * Scoped to .app-admin so it never leaks onto other surfaces. ---- */
.app-admin{padding-top:6px;}
.app-admin h1{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:clamp(1.7rem,4vw,2.5rem);line-height:1.04;letter-spacing:-.025em;color:var(--ink);margin:0;}
.app-admin h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.25rem;letter-spacing:-.01em;color:var(--ink);}
.app-admin a{color:var(--primary);font-weight:600;text-decoration:none;}
.app-admin .admin-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;padding:clamp(20px,3vw,32px) 0 22px;margin-bottom:24px;border-bottom:2px solid var(--rule-minor);}
.app-admin .admin-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
.app-admin .admin-actions .logout-form{margin:0;}
.app-admin .helper{margin:8px 0 0;color:var(--soft);font-size:13px;}
.app-admin .button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:11px;padding:12px 20px;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1rem;cursor:pointer;text-decoration:none;border:2px solid var(--rule);background:transparent;color:var(--accent);transition:background .25s,transform .15s,border-color .2s;}
.app-admin .button:hover{border-color:var(--primary);}
.app-admin .button.primary,.app-admin .primary{background:var(--primary);color:#F2F6F1;border-color:var(--primary);}
.app-admin .button.primary:hover,.app-admin .primary:hover{background:var(--primary-h);transform:translateY(-2px);}
.app-admin .button.secondary,.app-admin .secondary{background:transparent;color:var(--accent);border-color:var(--rule);}
.app-admin .button.secondary:hover,.app-admin .secondary:hover{border-color:var(--primary);}
.app-admin .danger{min-height:44px;border:2px solid var(--danger);background:transparent;color:var(--danger);border-radius:11px;padding:12px 18px;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;cursor:pointer;transition:background .2s,color .2s;}
.app-admin .danger:hover{background:var(--danger);color:#fff;}
.app-admin .admin-resource-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;}
.app-admin .resource-link{min-height:88px;display:flex;align-items:center;background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:18px;text-decoration:none;color:var(--ink);font-family:"Bricolage Grotesque",sans-serif;font-weight:700;backdrop-filter:saturate(1.3) blur(7px);-webkit-backdrop-filter:saturate(1.3) blur(7px);transition:border-color .2s,transform .15s;}
.app-admin .resource-link:hover{border-color:var(--primary);transform:translateY(-2px);}
.app-admin .admin-forbidden{width:min(560px,100%);background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:clamp(20px,3vw,32px);backdrop-filter:saturate(1.3) blur(7px);-webkit-backdrop-filter:saturate(1.3) blur(7px);}
.app-admin .admin-filters{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;align-items:end;background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:clamp(20px,3vw,24px);margin-bottom:24px;}
.app-admin label{display:grid;gap:6px;color:var(--text);font-size:13px;font-weight:600;}
.app-admin input{width:100%;min-height:44px;border:2px solid var(--rule);border-radius:10px;padding:12px 14px;font:inherit;font-size:15px;background:var(--bg);color:var(--text);}
.app-admin input:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(63,111,58,.22);}
.app-admin .filter-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
/* Admin tables live inside .tablewrap (same canonical container as .tbl): the
 * wrapper owns border/radius/surface + horizontal-scroll, so the table just sets
 * a min-width and never forces page overflow. */
.app-admin .admin-table{width:100%;border-collapse:collapse;min-width:680px;}
.app-admin .admin-table th{text-align:left;font-family:"Space Mono",monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:14px 18px;border-bottom:2px solid var(--rule);font-weight:700;}
.app-admin .admin-table td{padding:15px 18px;border-bottom:1px solid var(--rule-minor);font-size:14px;color:var(--text);text-align:left;vertical-align:middle;overflow-wrap:anywhere;}
.app-admin .admin-table tr:last-child td{border-bottom:0;}
.app-admin .admin-cards{display:none;}
.app-admin .admin-card,.app-admin .empty-state{background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:18px;margin-bottom:16px;}
.app-admin .export-actions{margin:0 0 24px;}
.app-admin .detail-list{display:grid;grid-template-columns:220px minmax(0,1fr);gap:12px 16px;background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:clamp(20px,3vw,24px);}
.app-admin .detail-list dt{color:var(--soft);font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;}
.app-admin .detail-list dd{margin:0;overflow-wrap:anywhere;}
.app-admin .moderation-panel{margin-top:24px;background:rgba(255,255,255,.52);border:2px solid var(--rule);border-radius:14px;padding:clamp(20px,3vw,24px);}
.app-admin .moderation-panel h2{margin:0 0 16px;}
.app-admin .moderation-form{display:grid;gap:12px;max-width:520px;}
.app-admin .pagination{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:24px 0;}
.app-admin .pagination a,.app-admin .pagination strong{min-width:44px;min-height:44px;display:grid;place-items:center;border-radius:10px;border:2px solid var(--rule);font-family:"Space Mono",monospace;font-size:13px;text-decoration:none;padding:0 10px;}
.app-admin .pagination strong{background:var(--primary);color:#F2F6F1;border-color:var(--primary);}
@media(max-width:760px){
  .app-admin .admin-header{display:grid;align-items:start;}
  .app-admin .button{width:100%;}
  .app-admin .admin-resource-grid{grid-template-columns:1fr;}
  .app-admin .admin-filters{grid-template-columns:1fr;}
  .app-admin .filter-actions{display:grid;}
  .app-admin .tablewrap.has-cards{display:none;}
  .app-admin .admin-cards{display:block;}
  .app-admin .detail-list{grid-template-columns:1fr;}
}

/* ---- Legal pages (legal.rs): reading layout layered on .prose ---- */
.legal nav{display:flex;flex-wrap:wrap;gap:8px 18px;margin:0 0 28px;}
.legal nav a{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;border-bottom:2px solid transparent;padding-bottom:2px;}
.legal nav a:hover{color:var(--primary);border-color:var(--primary);}
.legal .updated{margin:6px 0 0;color:var(--soft);font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.06em;}
.legal .intro{color:var(--muted);font-size:1.05rem;}
.legal #legal-review-required{margin:20px 0;padding:12px 16px;border-left:3px solid var(--primary);background:var(--bg-alt);border-radius:0 10px 10px 0;color:var(--text);}
.legal .related-links{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:32px;padding-top:18px;border-top:2px solid var(--rule-minor);}
.legal .related-links a{color:var(--primary);font-weight:700;text-decoration:none;}

/* ---- "Modo calma" / focus mode: flatten glass, kill ambiance & motion ---- */
body.calm::before{display:none;}
body.calm .deco{display:none;}
body.calm .nav,body.calm .pill,body.calm .card,body.calm .stat,body.calm .token{backdrop-filter:none !important;-webkit-backdrop-filter:none !important;}
body.calm .card,body.calm .stat{background:var(--surface);box-shadow:none;}
body.calm .token{background:var(--surface);box-shadow:0 8px 24px -16px rgba(22,38,22,.4);}
body.calm .token::before{display:none;}
body.calm *{transition:none !important;}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce){*{transition:none !important;}.token:hover{transform:none;}html{scroll-behavior:auto;}}
