/* ===== LetSplitit — design system ===== */
:root{
  --ink:#15171C; --ink-2:#4B525A; --ink-3:#869099;
  --line:#E9ECEF; --line-2:#F4F6F8;
  --surface:#FFFFFF; --bg:#EDEFF2;
  /* one refined green as the single accent; ink carries actions */
  --brand:#0E9E86; --brand-2:#0E9E86; --brand-ink:#0A7B68; --brand-soft:#E7F4F0;
  --owe:#15171C; --owe-soft:#EFF1F4;        /* coral retired — owe handled with ink + green */
  --paid:#0E9E86; --paid-soft:#E7F4F0;
  --r-sm:10px; --r:14px; --r-lg:20px; --r-xl:26px;
  --sh-sm:0 1px 2px rgba(20,24,30,.05), 0 1px 3px rgba(20,24,30,.04);
  --sh:0 4px 16px rgba(20,24,30,.08);
  --sh-lg:0 16px 44px rgba(20,24,30,.16);
  --grad:#0E9E86;                            /* flattened: no gradient fills */
  --ease:cubic-bezier(.22,1,.36,1);
  --font:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important} /* author display rules (.modal/#manual-editor/etc) otherwise beat the UA hidden rule */
html,body{height:100%}
body{
  font-family:var(--font); color:var(--ink); background:#15171C;
  background:radial-gradient(120% 90% at 50% -10%,#24272F 0%,#16181D 65%,#0F1013 100%);
  display:flex; align-items:center; justify-content:center; min-height:100vh;
  -webkit-font-smoothing:antialiased; font-feature-settings:"tnum" 1,"cv05" 1;
}
button{font-family:inherit; cursor:pointer; border:none; background:none; color:inherit}
.tnum{font-variant-numeric:tabular-nums}

/* ===== phone frame ===== */
#phone{
  position:relative; width:100%; max-width:430px; height:100vh; max-height:920px;
  background:var(--bg); overflow:hidden; display:flex; flex-direction:column;
  border-radius:0;
}
@media(min-width:480px){
  #phone{height:90vh; border-radius:44px; box-shadow:var(--sh-lg),0 0 0 11px #1a1d22,0 0 0 13px #2b2f37;}
}

/* ===== splash ===== */
#splash{
  position:absolute; inset:0; z-index:40; color:#fff;
  background:radial-gradient(120% 80% at 50% 0%,#1a2b28,#0e1715);
  display:flex; align-items:center; justify-content:center; text-align:center;
  transition:opacity .45s ease, transform .45s ease;
}
#splash.gone{opacity:0; transform:scale(1.04); pointer-events:none}
.splash-inner{padding:32px; width:100%; max-width:360px; animation:rise .6s ease both}
.splash-mark{width:88px; height:88px; filter:drop-shadow(0 12px 30px rgba(0,0,0,.4)); animation:pop .6s cubic-bezier(.22,1,.36,1) both}
.wordmark{font-weight:800; font-size:38px; letter-spacing:-.03em; margin-top:18px}
.wordmark span{background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}
.splash-tag{color:#aeb9b6; margin-top:6px; font-weight:500}
.qr-card{
  margin:30px 0 26px; padding:16px; display:flex; align-items:center; gap:14px; text-align:left;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:var(--r-lg);
  backdrop-filter:blur(8px);
}
.qr-glyph{position:relative; width:64px; height:64px; border-radius:12px; background:#fff; overflow:hidden; flex:none}
.qr-dots{position:absolute; inset:8px;
  background:
    conic-gradient(from 0deg,#0f1115 25%,transparent 0) 0 0/12px 12px,
    conic-gradient(from 180deg,#0f1115 25%,transparent 0) 6px 6px/12px 12px;
  opacity:.92; border-radius:3px;
}
.qr-scan{position:absolute; left:0; right:0; height:8px; top:0;
  background:linear-gradient(transparent,rgba(60,224,139,.9),transparent);
  box-shadow:0 0 14px 3px rgba(60,224,139,.7); animation:scan 1.9s ease-in-out infinite}
.qr-meta strong{display:block; font-size:16px}
.qr-meta span{color:#9fb0ac; font-size:13px; font-weight:500}
.splash-foot{color:#7f8d8a; font-size:12.5px; margin-top:18px; font-weight:500}

/* ===== buttons ===== */
.btn{border-radius:999px; font-weight:700; font-size:16px; padding:15px 22px; transition:transform .12s ease, box-shadow .2s ease, filter .2s ease}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--brand); color:#062B23; box-shadow:var(--sh-sm)}
.btn-primary:hover{filter:brightness(1.03)}
.btn-lg{width:100%; padding:17px; font-size:17px}

/* ===== topbar ===== */
#topbar{
  display:flex; align-items:center; gap:10px; padding:14px 14px 12px;
  background:var(--surface); border-bottom:1px solid var(--line); flex:none; position:relative; z-index:5;
}
.icon-btn{font-size:30px; line-height:1; color:var(--ink-2); width:34px; height:34px; border-radius:10px}
.icon-btn:active{background:var(--line-2)}
.topbar-title{flex:1; text-align:center; line-height:1.15}
.topbar-title strong{display:block; font-size:16px; font-weight:700}
.topbar-title span{font-size:12px; color:var(--ink-3); font-weight:600}
.brand-chip img{width:32px; height:32px; display:block}

/* ===== app scroll ===== */
#app{flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch}
.view{padding:18px 16px 28px; animation:fade .25s ease both}
.section-h{font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-3); margin:22px 4px 10px}
.card{background:var(--surface); border-radius:var(--r); box-shadow:var(--sh-sm)}

/* ===== hero amount ===== */
.hero-amount{text-align:center; padding:8px 0 18px}
.hero-label{display:block; font-size:13px; font-weight:600; color:var(--ink-3); text-transform:uppercase; letter-spacing:.05em}
.hero-num{display:block; font-size:42px; font-weight:700; letter-spacing:-.03em; margin:3px 0; font-variant-numeric:tabular-nums}
.hero-sub{display:block; font-size:13px; color:var(--ink-3); font-weight:600}

/* ===== segmented ===== */
.seg{display:flex; background:#E6EAEE; border-radius:14px; padding:4px; gap:4px}
.seg button{flex:1; padding:10px; border-radius:10px; font-weight:700; font-size:14px; color:var(--ink-2); transition:.18s}
.seg button.active{background:var(--surface); color:var(--ink); box-shadow:var(--sh-sm)}

.claim-hint{font-size:13px; color:var(--ink-3); font-weight:600; text-align:center; margin:12px 0 2px; min-height:18px}

/* ===== items ===== */
.items{display:flex; flex-direction:column; gap:9px; margin-top:8px}
.item{display:flex; align-items:center; gap:12px; padding:12px 13px; background:var(--surface); border-radius:var(--r); box-shadow:var(--sh-sm); border:1.5px solid transparent; transition:.15s}
.item.claimed{border-color:rgba(16,181,166,.35); background:#FBFFFE}
.item-emoji{font-size:24px; width:42px; height:42px; display:grid; place-items:center; background:var(--line-2); border-radius:12px; flex:none}
.item-main{flex:1; min-width:0}
.item-name{font-weight:700; font-size:15px}
.item-price{font-size:13px; color:var(--ink-3); font-weight:600}
.claimers{display:flex; align-items:center}
.claimers .av{margin-left:-8px; box-shadow:0 0 0 2px var(--surface)}
.claimers .av:first-child{margin-left:0}
.item .add-av{width:30px; height:30px; border-radius:50%; border:2px dashed #C7CDD4; color:var(--ink-3); font-size:18px; display:grid; place-items:center; margin-left:4px}

/* avatar */
.av{width:30px; height:30px; border-radius:50%; color:#fff; font-weight:800; font-size:11px; display:grid; place-items:center; letter-spacing:.02em; flex:none}
.av.lg{width:44px; height:44px; font-size:15px}
.av.sm{width:26px; height:26px; font-size:10px}

/* ===== claim picker (inline avatars under item) ===== */
.picker{display:flex; gap:8px; flex-wrap:wrap; padding:0 4px 4px; margin-top:-2px}
.picker .pick{display:flex; align-items:center; gap:6px; padding:5px 11px 5px 5px; border-radius:999px; background:var(--surface); box-shadow:var(--sh-sm); font-size:13px; font-weight:700; color:var(--ink-2); border:1.5px solid transparent}
.picker .pick.on{border-color:var(--brand); color:var(--brand-ink); background:var(--paid-soft)}

/* ===== tip ===== */
.tip-row{display:flex; align-items:center; justify-content:space-between; margin:20px 2px 0; font-weight:700}
.tip-pills{display:flex; gap:7px}
.tip-pills button{padding:8px 13px; border-radius:999px; background:var(--surface); box-shadow:var(--sh-sm); font-weight:700; font-size:13px; color:var(--ink-2)}
.tip-pills button.on{background:var(--ink); color:#fff}

/* ===== payer ===== */
.payer{margin-top:22px}
.payer-q{font-weight:700; font-size:14px; display:block; margin:0 2px 10px}
.payer-avatars{display:flex; gap:10px}
.payer-avatars .pa{display:flex; flex-direction:column; align-items:center; gap:5px; opacity:.5; transition:.15s; filter:grayscale(.3)}
.payer-avatars .pa.on{opacity:1; filter:none}
.payer-avatars .pa.on .av{box-shadow:0 0 0 3px var(--surface),0 0 0 5px var(--brand)}
.payer-avatars .pa span{font-size:11px; font-weight:700; color:var(--ink-2)}

/* ===== totals ===== */
.totals{margin-top:22px; padding:14px 16px}
.totals div{display:flex; justify-content:space-between; padding:7px 0; font-size:14px; color:var(--ink-2); font-weight:600}
.totals .grand{border-top:1px dashed var(--line); margin-top:4px; padding-top:12px; font-size:17px; color:var(--ink); font-weight:800}
.totals b{font-variant-numeric:tabular-nums}

/* ===== settle ===== */
.owed-hero{background:var(--ink); color:#fff; border-radius:var(--r-lg); padding:22px; text-align:center; box-shadow:var(--sh); position:relative; overflow:hidden}
.owed-hero::after{content:""; position:absolute; inset:0; background:radial-gradient(90% 130% at 100% 0,rgba(255,255,255,.05),transparent 60%)}
.owed-label{font-size:12px; font-weight:600; color:#9AA3AB; text-transform:uppercase; letter-spacing:.06em; position:relative}
.owed-num{display:block; font-size:40px; font-weight:700; letter-spacing:-.03em; margin:4px 0; position:relative; font-variant-numeric:tabular-nums}
.owed-sub{font-size:13.5px; color:#C4CBD2; font-weight:500; position:relative}

.shares{display:flex; flex-direction:column; gap:10px; margin-top:16px}
.share{display:flex; align-items:center; gap:12px; padding:13px; background:var(--surface); border-radius:var(--r); box-shadow:var(--sh-sm)}
.share-main{flex:1; min-width:0}
.share-name{font-weight:700; font-size:15px; display:flex; align-items:center; gap:6px}
.share-amt{font-size:13px; color:var(--ink-3); font-weight:600; font-variant-numeric:tabular-nums}
.share.is-payer{background:linear-gradient(135deg,#F2FBF8,#FFFFFF); border:1.5px solid rgba(16,181,166,.3)}
.tag{font-size:10.5px; font-weight:800; padding:2px 7px; border-radius:999px; text-transform:uppercase; letter-spacing:.03em}
.tag.payer{background:var(--brand-soft); color:var(--brand-ink)}
.tag.you{background:var(--line); color:var(--ink-2)}
.pay-btn{padding:10px 16px; border-radius:999px; background:var(--ink); color:#fff; font-weight:700; font-size:13.5px; box-shadow:var(--sh-sm); transition:transform .12s}
.pay-btn:active{transform:scale(.94)}
.paid-chip{display:flex; align-items:center; gap:5px; padding:8px 13px; border-radius:999px; background:var(--paid-soft); color:var(--brand-ink); font-weight:700; font-size:13px}

/* share the split */
.share-all{display:block; width:100%; margin-top:14px; padding:14px; border-radius:var(--r-lg); background:var(--paid-soft); color:#0E7A48; font-weight:800; font-size:15px; border:1.5px solid rgba(22,193,114,.25); transition:transform .12s ease}
.share-all:active{transform:scale(.98)}

/* spin */
.spin-btn{display:flex; align-items:center; gap:14px; width:100%; margin-top:18px; padding:16px; border-radius:var(--r-lg);
  background:linear-gradient(120deg,#191c22,#2a2030); color:#fff; box-shadow:var(--sh); text-align:left}
.spin-dice{font-size:30px; filter:drop-shadow(0 3px 6px rgba(0,0,0,.4))}
.spin-btn b{display:block; font-size:16px}
.spin-btn small{color:#b9aecb; font-weight:600; font-size:12.5px}

/* ledger */
.ledger{display:flex; flex-direction:column; gap:8px}
.ledger .row{display:flex; align-items:center; gap:11px; padding:11px 13px; background:var(--surface); border-radius:var(--r); box-shadow:var(--sh-sm)}
.ledger .row .txt{flex:1; font-size:14px; font-weight:600}
.ledger .row .txt b{font-weight:800}
.ledger .k{font-weight:800; color:var(--paid); font-size:13px}
.empty{color:var(--ink-3); font-weight:600; text-align:center; padding:22px; font-size:14px}

/* ===== leaderboard ===== */
.lead-sub{color:var(--ink-3); font-weight:600; font-size:13px; margin:0 4px 14px}
.board{display:flex; flex-direction:column; gap:10px}
.board .rank{display:flex; align-items:center; gap:13px; padding:14px; background:var(--surface); border-radius:var(--r); box-shadow:var(--sh-sm)}
.board .pos{font-size:18px; font-weight:800; width:26px; text-align:center; color:var(--ink-3)}
.board .rank:nth-child(1) .pos{color:#E8B100}
.board .who{flex:1}
.board .who .n{font-weight:700; font-size:15px}
.board .who .badges{display:flex; gap:3px; margin-top:3px; font-size:14px}
.board .karma{text-align:right}
.board .karma .num{font-weight:800; font-size:17px; color:var(--brand-ink)}
.board .karma .lab{font-size:10.5px; color:var(--ink-3); font-weight:700; text-transform:uppercase; letter-spacing:.04em}
.streak{font-size:11.5px; font-weight:800; color:var(--owe)}

/* ===== tabbar ===== */
#tabbar{display:flex; background:var(--surface); border-top:1px solid var(--line); flex:none; padding:6px 8px calc(6px + env(safe-area-inset-bottom))}
#tabbar button{flex:1; display:flex; flex-direction:column; align-items:center; gap:2px; padding:8px 0; font-size:11px; font-weight:700; color:var(--ink-3)}
#tabbar button span{font-size:21px; line-height:1; filter:grayscale(.4) opacity(.7); transition:.15s}
#tabbar button.active{color:var(--brand-ink)}
#tabbar button.active span{filter:none; transform:translateY(-1px) scale(1.06)}

/* ===== toast popups ===== */
#toast-host{position:absolute; left:0; right:0; top:64px; z-index:60; display:flex; flex-direction:column; align-items:center; gap:8px; pointer-events:none}
.pop{display:flex; align-items:center; gap:9px; padding:11px 16px; border-radius:999px; background:var(--ink); color:#fff; font-weight:700; font-size:14px; box-shadow:var(--sh); animation:popin .35s cubic-bezier(.22,1,.36,1) both}
.pop.badge{background:var(--brand); color:#062B23}
.pop .big{font-size:18px}
.pop.out{animation:popout .3s ease forwards}

/* ===== confetti ===== */
#confetti{position:absolute; inset:0; z-index:55; pointer-events:none}

/* ===== spin modal ===== */
.modal{position:absolute; inset:0; z-index:70; background:rgba(8,14,12,.6); backdrop-filter:blur(4px); display:grid; place-items:center; padding:28px; animation:fade .2s ease both}
.modal-card{background:var(--surface); border-radius:var(--r-xl); padding:30px 26px; text-align:center; width:100%; max-width:320px; box-shadow:var(--sh-lg); animation:pop .4s cubic-bezier(.22,1,.36,1) both}
.spin-wheel{font-size:64px; margin-bottom:10px; display:inline-block}
.spin-wheel.go{animation:spin 1s cubic-bezier(.2,.8,.2,1)}
.modal-card h2{font-size:24px; font-weight:800; letter-spacing:-.02em}
.modal-card p{color:var(--ink-2); font-weight:600; margin:8px 0 20px; font-size:14.5px}
.modal-card .btn{width:100%}

/* ===== settle sheet (bottom-sheet variant of .modal) ===== */
.modal.sheet{place-items:end center; padding:0}
.sheet-card{max-width:430px; width:100%; border-radius:var(--r-xl) var(--r-xl) 0 0; padding:26px 22px calc(24px + env(safe-area-inset-bottom)); text-align:center; position:relative; animation:sheetup .34s cubic-bezier(.2,.9,.25,1) both}
.sheet-close{position:absolute; top:14px; right:16px; font-size:26px; line-height:1; color:var(--ink-3); width:34px; height:34px; border-radius:10px}
.sheet-close:active{background:var(--line-2)}
.sheet-eyebrow{display:block; font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-3)}
.sheet-card h2{font-size:40px; font-weight:800; letter-spacing:-.03em; margin-top:2px; font-variant-numeric:tabular-nums}
.sheet-card>p{margin:6px 0 18px; font-size:14px}
.sheet-foot{color:var(--ink-3)!important; font-weight:600; font-size:12px; margin:14px 0 0!important}

/* pay-link buttons */
.pay-links{display:flex; flex-direction:column; gap:9px; margin-bottom:16px}
.pay-link{display:flex; align-items:center; gap:12px; padding:14px 16px; border-radius:var(--r); background:var(--surface); box-shadow:var(--sh-sm); border:1.5px solid var(--line); font-weight:800; font-size:15px; color:var(--ink); text-decoration:none; transition:transform .12s ease, box-shadow .2s ease}
.pay-link:active{transform:scale(.98)}
.pay-link .pl-mark{width:38px; height:38px; border-radius:11px; display:grid; place-items:center; font-size:18px; color:#fff; font-weight:800; flex:none}
.pay-link .pl-text{flex:1; text-align:left}
.pay-link .pl-text small{display:block; font-size:12px; font-weight:600; color:var(--ink-3)}
.pay-link .pl-go{color:var(--ink-3); font-size:20px; font-weight:700}
.pl-mark.venmo{background:#3D95CE}
.pl-mark.cash{background:#00D632}
.pl-mark.apple{background:#000}
.pl-mark.paypal{background:#003087}

/* stripe payment element */
#pe-mount{min-height:44px; margin:8px 0 14px}
.pe-loading{color:var(--ink-3); font-weight:600; font-size:14px; text-align:center; padding:20px}

/* remind nudge (settle row) */
.remind-btn{width:34px; height:34px; border-radius:50%; background:var(--line-2); color:var(--ink-2); font-size:16px; display:grid; place-items:center; margin-right:2px; transition:transform .12s ease, background .15s}
.remind-btn:active{transform:scale(.88)}
.remind-btn:hover{background:var(--owe-soft)}
.share-actions{display:flex; align-items:center; gap:8px}

@keyframes sheetup{from{opacity:0; transform:translateY(40px)}to{opacity:1; transform:none}}

/* ===== secondary buttons + splash extras ===== */
.btn-ghost{background:var(--surface); color:var(--ink); box-shadow:var(--sh-sm); border:1.5px solid var(--line)}
.btn-ghost:active{transform:scale(.97)}
.btn-danger{background:#FFECEC; color:#D43B3B; font-weight:800; border-radius:999px; padding:13px 20px; font-size:15px}
#manual-btn{margin-top:10px}
.splash-profile{display:inline-flex; align-items:center; gap:7px; margin-top:18px; color:#cdd8d5; font-weight:700; font-size:13.5px; padding:8px 14px; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12)}
.splash-profile:active{transform:scale(.96)}

/* ===== forms (profile / friend sheets) ===== */
.sheet-h{font-size:22px!important}
.form{display:flex; flex-direction:column; gap:11px; margin-bottom:18px}
.form label{display:flex; flex-direction:column; gap:5px; font-size:12.5px; font-weight:700; color:var(--ink-2)}
.form input{font-family:inherit; font-size:15px; font-weight:600; padding:12px 13px; border:1.5px solid var(--line); border-radius:12px; background:var(--surface); color:var(--ink)}
.form input:focus{outline:none; border-color:var(--brand)}
.fr-actions{display:flex; gap:10px}
.fr-actions .btn{flex:1}

/* ===== manual bill editor ===== */
#manual-editor{margin-top:12px; display:flex; flex-direction:column; gap:10px}
.add-item-row{display:flex; gap:8px}
.add-item-row input{font-family:inherit; font-weight:600; font-size:15px; padding:12px; border:1.5px solid var(--line); border-radius:12px; background:var(--surface); min-width:0}
.add-item-row #mi-name{flex:1}
.add-item-row .mi-price-in{width:84px; text-align:right; font-variant-numeric:tabular-nums}
.add-item-row input:focus{outline:none; border-color:var(--brand)}
.mi-add{padding:0 18px; border-radius:12px; background:var(--ink); color:#fff; font-weight:800; font-size:14px; flex:none}
.mi-add:active{transform:scale(.95)}
.tax-row{display:flex; align-items:center; gap:10px; font-weight:700; font-size:13.5px; color:var(--ink-2)}
.tax-row input{width:70px; padding:9px 11px; border:1.5px solid var(--line); border-radius:10px; font-weight:700; text-align:right; font-family:inherit; font-variant-numeric:tabular-nums}
.item-del{width:28px; height:28px; border-radius:50%; background:var(--line-2); color:var(--ink-3); font-size:18px; line-height:1; flex:none}
.item-del:active{transform:scale(.9); background:#FFE3E3; color:#D43B3B}

/* ===== crew management ===== */
.crew-manage{display:flex; flex-direction:column; gap:9px}
.cm-row{display:flex; align-items:center; gap:12px; padding:11px 13px; background:var(--surface); border-radius:var(--r); box-shadow:var(--sh-sm); text-align:left; width:100%}
.cm-row:active{transform:scale(.99)}
.cm-main{flex:1; min-width:0}
.cm-name{font-weight:700; font-size:15px}
.cm-sub{font-size:12.5px; color:var(--ink-3); font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.cm-go{color:var(--ink-3); font-size:18px; font-weight:700}
.add-friend{margin-top:14px}
.payer-avatars{flex-wrap:wrap}

/* ===== multi-device: invite + join ===== */
.invite-row{display:flex; align-items:center; justify-content:center; gap:5px; width:100%; margin:2px 0 16px; padding:10px; border-radius:999px; background:var(--brand-soft); color:var(--brand-ink); font-weight:600; font-size:13px; transition:transform .12s ease}
.invite-row:active{transform:scale(.98)}
.invite-row b{font-weight:800; letter-spacing:.12em}
.sheet-h.code{letter-spacing:.16em; font-size:34px!important}
.invite-qr{width:200px; height:200px; margin:8px auto 18px; display:block; border-radius:14px; background:var(--line-2); object-fit:contain}
.join-code-in{width:100%; text-align:center; font-size:30px; font-weight:800; letter-spacing:.32em; text-transform:uppercase; padding:15px 10px; border:1.5px solid var(--line); border-radius:14px; font-family:inherit; margin-bottom:14px; color:var(--ink)}
.join-code-in:focus{outline:none; border-color:var(--brand)}
.join-err{color:#C0392B!important; font-weight:600; font-size:13px; margin:10px 0 0!important}

/* ===== animations ===== */
@keyframes scan{0%,100%{top:2px}50%{top:54px}}
@keyframes rise{from{opacity:0; transform:translateY(16px)}to{opacity:1; transform:none}}
@keyframes pop{from{opacity:0; transform:scale(.7)}to{opacity:1; transform:scale(1)}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes popin{from{opacity:0; transform:translateY(-12px) scale(.9)}to{opacity:1; transform:none}}
@keyframes popout{to{opacity:0; transform:translateY(-10px) scale(.9)}}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(900deg)}}

@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important; transition-duration:.05ms!important}}
:focus-visible{outline:3px solid var(--brand); outline-offset:2px; border-radius:8px}
