:root{
  --ink:#f0f6ff;
  --muted:#b4c7e5;
  --dim:#a9c4ea;
  --bg-void:#060a1a;
  --bg-base:#0a1228;
  --bg-raised:#101a33;
  --bg-surface:#1a2238;
  --panel:rgba(10,18,40,.66);
  --panel-strong:rgba(10,18,40,.92);
  --line:rgba(122,192,255,.22);
  --line-strong:rgba(122,192,255,.46);
  --cyan:#7ac0ff;
  --mint:#7ac0ff;
  --rose:#3f8ae0;
  --gold:#7aa9dd;
  --violet:#22325a;
  --danger:#ff5c7a;
  --shadow:0 24px 90px rgba(0,0,0,.58);
  --glow:0 0 36px rgba(63,138,224,.2);
  --grain:url("../assets/design/textures/ui_grain.png");
  --ease-exp:cubic-bezier(.16,1,.3,1);
  --ease-out:cubic-bezier(.2,.9,.3,1);
  color-scheme:dark;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{width:100%;height:100%;overflow:hidden;overscroll-behavior:none;-webkit-text-size-adjust:100%}
body{
  font-family:"Geist",Dubai,"Avenir Next",Verdana,-apple-system,"SF Pro Text","Segoe UI",Roboto,ui-sans-serif,system-ui,sans-serif;
  background:var(--bg-void);
  color:var(--ink);
  letter-spacing:0;
  font-feature-settings:"kern" 1;
  touch-action:manipulation;
}
#stage,#stage canvas,#sparkCanvas{touch-action:none}
button,a{touch-action:manipulation}
button,input,select{font-family:inherit}
input,select{touch-action:manipulation;font-size:16px}
button{border:0}
#stage{position:fixed;inset:0;z-index:0}
canvas{display:block}
#sparkCanvas{position:fixed;inset:0;z-index:25;pointer-events:none}
.wash{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:3;
  background:
    linear-gradient(180deg,rgba(6,10,26,.08),rgba(6,10,26,.36)),
    radial-gradient(ellipse at center,transparent 44%,rgba(0,0,0,.7) 100%);
  mix-blend-mode:screen;
}
.grain{
  position:fixed;
  inset:0;
  z-index:4;
  opacity:.09;
  pointer-events:none;
  background-image:var(--grain);
  background-size:256px 256px;
  mix-blend-mode:screen;
  mask-image:radial-gradient(ellipse at center,#000 16%,transparent 88%);
}
.topbar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:50;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding:18px max(18px,env(safe-area-inset-right)) 0 max(18px,env(safe-area-inset-left));
  pointer-events:none;
}
.brand{
  pointer-events:auto;
  display:flex;
  align-items:center;
  gap:11px;
  min-width:0;
  font-size:13px;
  font-weight:600;
  letter-spacing:0;
  text-shadow:0 0 24px rgba(127,230,255,.35);
}
.brand-mark{
  width:22px;
  height:22px;
  display:block;
  filter:drop-shadow(0 0 16px rgba(122,192,255,.48));
  flex:0 0 auto;
}
.brand-name{color:var(--ink)}
body.mystery-revealed .brand{
  max-width:min(360px,38vw);
}
body.mystery-revealed .brand-name{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.app-tabs{
  pointer-events:auto;
  position:absolute;
  left:50%;
  top:16px;
  transform:translateX(-50%);
  display:flex;
  gap:4px;
  padding:4px;
  border:1px solid rgba(122,192,255,.24);
  border-radius:8px;
  background:linear-gradient(180deg,rgba(16,26,51,.72),rgba(6,10,26,.68));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 18px 54px rgba(0,0,0,.22);
  backdrop-filter:blur(20px) saturate(1.2);
}
.tab-button{
  min-width:104px;
  min-height:32px;
  padding:0 12px;
  border-radius:6px;
  color:var(--muted);
  background:transparent;
  cursor:pointer;
  font-size:11px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition:transform .16s cubic-bezier(.2,.8,.2,1),border-color .16s ease,background .16s ease,color .16s ease;
}
.tab-button:hover{color:var(--ink);background:rgba(255,255,255,.06)}
.tab-button.active{
  color:var(--ink);
  background:linear-gradient(180deg,rgba(34,50,90,.95),rgba(10,18,40,.95));
  border:1px solid rgba(122,192,255,.66);
  box-shadow:0 0 24px rgba(63,138,224,.32),inset 0 1px 0 rgba(240,246,255,.22);
}
.top-actions{pointer-events:auto;display:flex;align-items:center;gap:10px}
.legal-link{
  min-height:30px;
  display:grid;
  place-items:center;
  padding:0 9px;
  color:var(--dim);
  border:1px solid rgba(122,192,255,.14);
  border-radius:8px;
  background:rgba(5,9,22,.38);
  font-size:10px;
  font-weight:600;
  letter-spacing:.08em;
  text-decoration:none;
  text-transform:uppercase;
  backdrop-filter:blur(14px);
}
.legal-link:hover{color:var(--ink);border-color:var(--line-strong)}
.live-pill,.icon-button,.small-button{
  min-height:34px;
  border:1px solid var(--line);
  border-radius:8px;
  background:rgba(5,9,22,.58);
  color:var(--ink);
  backdrop-filter:blur(16px);
}
.live-pill{
  display:flex;
  align-items:center;
  gap:8px;
  padding:0 12px;
  color:var(--muted);
  font-size:11px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
}
.live-dot{
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--danger);
  box-shadow:0 0 12px var(--danger);
  animation:pulseDot 1.4s ease-in-out infinite;
}
.live-pill.offline .live-dot{
  background:rgba(245,247,255,.38);
  box-shadow:none;
  animation:none;
}
@keyframes pulseDot{50%{opacity:.38;transform:scale(.68)}}
.icon-button{
  width:36px;
  display:grid;
  place-items:center;
  cursor:pointer;
  transition:transform .18s ease,border-color .18s ease,background .18s ease;
}
.icon-button:hover,.small-button:hover{border-color:var(--line-strong);background:rgba(11,18,41,.78)}
.icon-button:active,.small-button:active{transform:translateY(1px)}
.icon-button svg{width:17px;height:17px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.hud{
  position:fixed;
  left:max(18px,env(safe-area-inset-left));
  bottom:max(18px,env(safe-area-inset-bottom));
  z-index:45;
  width:min(330px,calc(100vw - 36px));
  pointer-events:auto;
}
.panel{
  background:linear-gradient(180deg,rgba(16,26,51,.68),rgba(6,10,26,.62));
  border:1px solid rgba(122,192,255,.22);
  border-radius:8px;
  box-shadow:var(--shadow),var(--glow),inset 0 1px 0 rgba(255,255,255,.075);
  backdrop-filter:blur(24px) saturate(1.18);
}
.metrics{
  padding:15px;
  display:grid;
  gap:10px;
}
.metrics-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.metric-icon-button,
.metric-arrow{
  display:grid;
  place-items:center;
  border:1px solid rgba(122,192,255,.2);
  border-radius:8px;
  background:rgba(5,9,22,.46);
  color:var(--muted);
  cursor:pointer;
  transition:color .16s ease,border-color .16s ease,background .16s ease,opacity .16s ease;
}
.metric-icon-button{
  width:32px;
  height:28px;
}
.metric-icon-button:hover,
.metric-arrow:hover{color:var(--ink);border-color:var(--line-strong);background:rgba(11,18,41,.78)}
.metric-icon-button svg,
.metric-arrow svg{width:17px;height:17px;stroke:currentColor;stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.metric-carousel{
  display:grid;
  grid-template-columns:30px minmax(0,1fr) 30px;
  align-items:stretch;
  gap:8px;
}
.metric-arrow{
  width:30px;
  height:auto;
  min-height:150px;
  align-self:stretch;
}
.metric-arrow[disabled]{
  cursor:default;
  opacity:.34;
}
.metric-pages{
  display:flex;
  gap:0;
  overflow-x:auto;
  overscroll-behavior-x:contain;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scrollbar-width:none;
  touch-action:pan-x;
}
.metric-pages::-webkit-scrollbar{display:none}
.metric-page{
  flex:0 0 100%;
  min-width:0;
  min-height:150px;
  padding:2px;
  scroll-snap-align:center;
  scroll-snap-stop:always;
}
.metric-dots{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:7px;
  min-height:12px;
}
.metric-dots button{
  width:6px;
  height:6px;
  padding:0;
  border-radius:999px;
  background:rgba(169,196,234,.28);
  border:0;
  cursor:pointer;
  transition:width .18s ease,background .18s ease,opacity .18s ease;
}
.metric-dots button.active{
  width:16px;
  background:rgba(216,236,255,.9);
}
.metric-page-progress{
  display:grid;
  gap:12px;
  align-content:center;
}
.metric-page-progress .label{
  font-size:15px;
  font-weight:700;
  letter-spacing:0;
  text-transform:none;
  color:rgba(240,246,255,.9);
}
.progress-head{
  display:flex;
  align-items:center;
}
.label{
  color:rgba(169,196,234,.82);
  font-size:10px;
  font-weight:500;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.progress-caption{
  margin-top:5px;
  color:var(--dim);
  font-size:11px;
  line-height:1.35;
}
.value{
  margin-top:4px;
  font-family:"Geist Mono","SFMono-Regular","Roboto Mono",ui-monospace,monospace;
  font-size:28px;
  line-height:1;
  font-weight:500;
  color:var(--ink);
  text-shadow:0 0 18px rgba(122,192,255,.3);
}
.progress-track{
  height:12px;
  overflow:hidden;
  border-radius:999px;
  border:1px solid rgba(122,192,255,.26);
  background:rgba(255,255,255,.045);
  box-shadow:inset 0 1px 6px rgba(0,0,0,.35);
}
.progress-track i{
  display:block;
  width:0%;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,#3f8ae0,var(--cyan),#d8ecff);
  box-shadow:0 0 20px rgba(122,192,255,.45);
  transition:width .45s var(--ease-out);
}
.stat-section{
  display:grid;
  gap:6px;
  align-content:center;
}
.stat-section-title{
  color:var(--ink);
  font-size:11px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.stat-row{
  min-height:29px;
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:10px;
  padding:6px 8px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:7px;
  background:rgba(255,255,255,.035);
}
.stat-row span,
.reveal-estimate span,
.reveal-estimate small{
  color:var(--dim);
  font-size:11px;
  line-height:1.25;
}
.stat-row b,
.reveal-estimate b{
  color:var(--cyan);
  font-family:"Geist Mono","SFMono-Regular","Roboto Mono",ui-monospace,monospace;
  font-size:13px;
  font-weight:800;
  text-align:right;
  white-space:nowrap;
}
.reveal-estimate{
  display:grid;
  gap:4px;
  align-content:center;
  padding:11px 10px;
  border:1px solid rgba(122,192,255,.2);
  border-radius:8px;
  background:linear-gradient(180deg,rgba(122,192,255,.08),rgba(255,255,255,.035));
}
.show-stats-button{
  position:fixed;
  left:max(18px,env(safe-area-inset-left));
  bottom:max(18px,env(safe-area-inset-bottom));
  z-index:46;
  min-height:40px;
  min-width:132px;
  padding:0 15px;
  border:1px solid rgba(122,192,255,.24);
  border-radius:8px;
  color:var(--ink);
  background:linear-gradient(180deg,rgba(16,26,51,.72),rgba(6,10,26,.68));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 18px 54px rgba(0,0,0,.22);
  backdrop-filter:blur(20px) saturate(1.2);
  cursor:pointer;
  font-size:11px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.show-stats-button[hidden]{display:none}
body.stats-minimized .hud{display:none}
body.stats-minimized .show-stats-button:not(.view-hidden){display:block}
.reveal-estimate b{
  color:var(--ink);
  font-size:15px;
  text-align:left;
  text-shadow:0 0 18px rgba(122,192,255,.22);
}
.feed{
  position:fixed;
  top:64px;
  right:max(18px,env(safe-area-inset-right));
  z-index:45;
  width:258px;
  padding:13px;
  pointer-events:none;
}
.feed-list{margin-top:8px;display:grid;gap:6px}
.feed-item{
  min-height:34px;
  display:grid;
  align-content:center;
  gap:1px;
  padding:7px 9px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:7px;
  background:rgba(255,255,255,.035);
  animation:feedIn .28s ease both;
}
.feed-item b{
  font-size:12px;
  font-weight:800;
  color:var(--cyan);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.feed-item span{
  font-size:11px;
  color:var(--dim);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.feed-item.compact{
  grid-template-columns:1fr auto;
  align-items:center;
  min-height:32px;
}
.feed-item.compact span{font-weight:500;text-transform:uppercase;letter-spacing:.08em}
.feed-item.compact b{font-family:"Geist Mono","SFMono-Regular","Roboto Mono",ui-monospace,monospace;text-align:right}
@keyframes feedIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.checkout-launch{
  position:fixed;
  right:max(18px,env(safe-area-inset-right));
  bottom:max(18px,env(safe-area-inset-bottom));
  z-index:50;
  width:min(306px,calc(100vw - 36px));
  pointer-events:auto;
}
.break-button{
  width:100%;
  min-height:58px;
  border-radius:8px;
  color:var(--ink);
  background:linear-gradient(180deg,rgba(26,34,56,.98),rgba(10,18,40,.98));
  border:1px solid rgba(122,192,255,.58);
  box-shadow:0 16px 55px rgba(63,138,224,.28),0 0 28px rgba(122,192,255,.16),inset 0 1px 0 rgba(240,246,255,.2);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-size:14px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition:transform .16s var(--ease-exp),filter .16s ease,box-shadow .16s ease,background .16s ease;
}
.break-button:hover{transform:translateY(-2px);filter:saturate(1.08);box-shadow:0 18px 62px rgba(63,138,224,.34),0 0 32px rgba(122,192,255,.22),inset 0 1px 0 rgba(240,246,255,.24)}
.break-button:active{transform:translateY(0)}
.break-button[disabled]{cursor:not-allowed;filter:grayscale(.6);opacity:.7;transform:none}
.break-button svg{width:18px;height:18px;stroke:currentColor;stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.pay-note{
  margin-top:8px;
  color:var(--dim);
  font-size:11px;
  font-weight:500;
  letter-spacing:0;
  text-align:center;
}
.small-button{
  padding:0 12px;
  cursor:pointer;
  color:var(--ink);
  font-size:11px;
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition:transform .16s cubic-bezier(.2,.8,.2,1),border-color .16s ease,background .16s ease,color .16s ease;
}
.small-button.accent{
  color:var(--ink);
  border-color:rgba(122,192,255,.55);
  background:linear-gradient(180deg,rgba(26,34,56,.96),rgba(10,18,40,.96));
  box-shadow:0 0 22px rgba(63,138,224,.22),inset 0 1px 0 rgba(240,246,255,.16);
}
.small-button[disabled]{
  cursor:not-allowed;
  opacity:.42;
  transform:none;
}
.ticker{
  position:fixed;
  left:50%;
  bottom:104px;
  transform:translateX(-50%);
  z-index:46;
  width:min(560px,calc(100vw - 36px));
  text-align:center;
  color:var(--cyan);
  font-size:12px;
  font-weight:500;
  letter-spacing:.06em;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease,transform .35s ease;
  text-shadow:0 0 16px rgba(122,192,255,.45);
}
.ticker.show{opacity:1;transform:translate(-50%,-4px)}
.view-hidden{display:none!important}
.recent-view{
  position:fixed;
  top:64px;
  right:auto;
  bottom:max(18px,env(safe-area-inset-bottom));
  left:50%;
  transform:translateX(-50%);
  z-index:44;
  display:grid;
  place-items:start center;
  width:min(840px,calc(100vw - 36px));
  min-width:0;
  overflow:auto;
  padding:18px 0 0;
  pointer-events:auto;
}
.recent-view[hidden]{display:none}
.log-shell{
  width:100%;
  min-width:0;
  padding:18px;
  background:
    linear-gradient(180deg,rgba(16,26,51,.72),rgba(6,10,26,.58)),
    var(--grain);
  border:1px solid rgba(122,192,255,.24);
  border-radius:8px;
  box-shadow:var(--shadow),var(--glow),inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(22px) saturate(1.24);
}
.log-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  margin-bottom:16px;
}
.log-header h2{
  font-size:20px;
  line-height:1.1;
  letter-spacing:.06em;
  font-weight:600;
  text-transform:uppercase;
}
.log-header p{margin-top:5px;color:var(--dim);font-size:13px}
.log-summary{
  display:grid;
  grid-template-columns:repeat(2,minmax(100px,1fr));
  gap:8px;
  width:min(300px,100%);
}
.log-summary .feed-item{min-height:48px;background:rgba(26,34,56,.5)}
.log-table{
  width:100%;
  min-width:0;
  max-width:100%;
  display:grid;
  border:1px solid rgba(122,192,255,.16);
  border-radius:8px;
  overflow-x:auto;
  overflow-y:hidden;
  overscroll-behavior-x:contain;
}
#breakLogRows{
  max-height:min(62dvh,640px);
  overflow-y:auto;
  overflow-x:visible;
  overscroll-behavior:contain;
}
.log-row{
  display:grid;
  grid-template-columns:minmax(120px,1fr) minmax(120px,1fr) minmax(220px,1.5fr) minmax(86px,.7fr) minmax(130px,1fr);
  gap:12px;
  align-items:center;
  min-width:720px;
  min-height:42px;
  padding:0 12px;
  border-top:1px solid rgba(122,192,255,.12);
  color:var(--muted);
  font-size:12px;
  background:rgba(10,18,40,.22);
}
.log-row:first-child{border-top:0}
.log-row.head{
  min-height:36px;
  color:var(--dim);
  background:rgba(26,34,56,.4);
  font-size:10px;
  font-weight:900;
  letter-spacing:1.4px;
  text-transform:uppercase;
}
.log-row b{color:var(--ink);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.log-row span,.log-row time{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.log-row .count{
  color:var(--cyan);
  font-family:"Geist Mono","SFMono-Regular","Roboto Mono",ui-monospace,monospace;
  font-weight:500;
}
.empty-log{
  min-width:720px;
  padding:18px;
  color:var(--dim);
  text-align:center;
  font-size:13px;
  border-top:1px solid rgba(255,255,255,.07);
}
.log-controls{
  min-width:0;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:12px;
  margin-top:12px;
}
.log-controls span{margin-right:auto}
.log-controls span{
  color:var(--dim);
  font-size:11px;
  font-weight:900;
  letter-spacing:1px;
  text-transform:uppercase;
  text-align:center;
}
.overlay{
  position:fixed;
  inset:0;
  z-index:100;
  display:grid;
  place-items:center;
  padding:18px;
  background:rgba(6,10,26,.58);
  backdrop-filter:blur(18px) saturate(1.2);
  opacity:0;
  pointer-events:none;
  transition:opacity .24s ease;
}
.overlay.open{opacity:1;pointer-events:auto}
.checkout-panel{
  width:min(520px,100%);
  max-height:min(760px,calc(100dvh - 36px));
  overflow:auto;
  background:
    linear-gradient(180deg,rgba(16,26,51,.94),rgba(6,10,26,.9)),
    var(--grain);
  border:1px solid var(--line-strong);
  border-radius:8px;
  box-shadow:var(--shadow),0 0 52px rgba(63,138,224,.18),inset 0 1px 0 rgba(240,246,255,.08);
  transform:translateY(12px) scale(.98);
  transition:transform .28s var(--ease-out);
}
.overlay.open .checkout-panel{transform:translateY(0) scale(1)}
.checkout-top{
  position:sticky;
  top:0;
  z-index:2;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  padding:18px 18px 12px;
  background:linear-gradient(rgba(16,26,51,.98),rgba(10,18,40,.88));
  backdrop-filter:blur(18px) saturate(1.12);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.checkout-top h2{
  font-size:19px;
  line-height:1.1;
  letter-spacing:.06em;
  font-weight:600;
  text-transform:uppercase;
}
.checkout-top p{margin-top:5px;color:var(--dim);font-size:13px;line-height:1.35}
.checkout-top p{white-space:pre-line}
.close-button{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border-radius:8px;
  color:var(--muted);
  background:rgba(255,255,255,.05);
  border:1px solid var(--line);
  cursor:pointer;
  font-size:22px;
  line-height:1;
}
.close-button:hover{color:var(--ink);border-color:var(--line-strong)}
.checkout-body{padding:16px 18px 18px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:grid;gap:6px;margin-bottom:12px}
.field.full{grid-column:1/-1}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.field label{
  color:var(--dim);
  font-size:10px;
  font-weight:500;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.field input,.field select{
  width:100%;
  min-height:48px;
  padding:0 13px;
  color:var(--ink);
  background:rgba(26,34,56,.66);
  border:1px solid var(--line);
  border-radius:8px;
  outline:0;
  transition:border-color .16s ease,box-shadow .16s ease,background .16s ease;
}
.field input::placeholder{color:rgba(180,199,229,.72)}
.field select{
  appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,rgba(248,251,255,.7) 50%),linear-gradient(135deg,rgba(248,251,255,.7) 50%,transparent 50%);
  background-position:calc(100% - 17px) 21px,calc(100% - 11px) 21px;
  background-size:6px 6px,6px 6px;
  background-repeat:no-repeat;
}
.field input:focus,.field select:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(122,192,255,.12),0 0 22px rgba(63,138,224,.16)}
.field input.err,.field select.err{border-color:var(--danger);box-shadow:0 0 0 3px rgba(255,92,122,.12)}
.field select:disabled{opacity:.5}
.city-custom-wrap[hidden]{display:none}
.error{display:none;color:var(--danger);font-size:11px;font-weight:800}
.error.show{display:block}
.field-hint{
  color:rgba(180,199,229,.78);
  font-size:11px;
  line-height:1.4;
}
.qty-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px}
.qty-button,.rail-button{
  min-height:42px;
  border-radius:8px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(26,34,56,.82),rgba(10,18,40,.78));
  color:var(--muted);
  cursor:pointer;
  font-size:13px;
  font-weight:600;
  transition:transform .16s var(--ease-exp),border-color .18s ease,background .18s ease,color .18s ease,box-shadow .18s ease;
}
.qty-button{display:grid;place-items:center;gap:2px;padding:7px 4px}
.qty-button[hidden]{display:none}
.qty-button span{font-weight:600}
.qty-button small{font-size:10px;color:inherit;opacity:.72}
.qty-button:hover,.rail-button:hover{border-color:var(--line-strong);color:var(--ink);transform:translateY(-1px)}
.qty-button[disabled]{cursor:not-allowed;opacity:.45;transform:none}
.qty-button.active,.rail-button.active{
  color:var(--ink);
  border-color:rgba(122,192,255,.62);
  background:linear-gradient(180deg,rgba(34,50,90,.95),rgba(10,18,40,.95));
  box-shadow:0 0 24px rgba(63,138,224,.24),inset 0 1px 0 rgba(240,246,255,.18);
}
.rail-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.rail-button{
  position:relative;
  min-height:50px;
  display:grid;
  place-items:center;
  overflow:hidden;
  padding:4px;
}
.apple-pay-button,.google-pay-shell{
  background:#000;
  border-color:rgba(255,255,255,.22);
}
.apple-pay-button.active,.google-pay-shell.active{
  color:#fff;
  background:#000;
  border:1px solid rgba(127,230,255,.72);
  box-shadow:0 0 0 3px rgba(127,230,255,.12),0 0 28px rgba(127,230,255,.18);
}
.apple-pay-native{
  display:block;
  width:100%;
  height:40px;
  border-radius:6px;
  -webkit-appearance:-apple-pay-button;
  -apple-pay-button-type:plain;
  -apple-pay-button-style:black;
}
.apple-pay-fallback{display:none;color:#fff;font-weight:800}
@supports not (-webkit-appearance: -apple-pay-button){
  .apple-pay-native{display:none}
  .apple-pay-fallback{display:block}
}
.google-pay-mount{
  display:none;
  width:100%;
  height:40px;
}
.google-pay-mount.mounted{display:block}
.google-pay-mount.mounted + .google-pay-fallback{display:none}
.google-pay-mount button{
  width:100%!important;
  min-width:100%!important;
  height:40px!important;
  border-radius:6px!important;
}
.google-pay-fallback{
  height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  color:#fff;
  font-size:17px;
  letter-spacing:.1px;
}
.google-pay-fallback b{
  color:#4285f4;
  font-size:18px;
  font-weight:900;
  letter-spacing:0;
}
.card-rail{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.card-rail svg{
  width:18px;
  height:18px;
  stroke:currentColor;
  stroke-width:1.9;
  fill:none;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.total-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding:12px 0 16px;
  border-top:1px solid rgba(255,255,255,.08);
  margin-top:4px;
}
.total-row span:first-child{color:var(--dim);font-weight:900;font-size:11px;letter-spacing:1.8px;text-transform:uppercase}
.total-row strong{
  font-family:"Geist Mono","SFMono-Regular","Roboto Mono",ui-monospace,monospace;
  font-size:28px;
  line-height:1;
  color:var(--cyan);
  text-shadow:0 0 16px rgba(122,192,255,.3);
}
.confirm-button{
  width:100%;
  min-height:50px;
  border-radius:8px;
  color:var(--ink);
  border:1px solid rgba(122,192,255,.62);
  background:linear-gradient(180deg,rgba(26,34,56,.98),rgba(10,18,40,.98));
  box-shadow:0 0 28px rgba(63,138,224,.24),inset 0 1px 0 rgba(240,246,255,.18);
  cursor:pointer;
  font-size:14px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.confirm-button[disabled]{cursor:progress;filter:grayscale(.35);opacity:.82}
.status-line{
  min-height:18px;
  margin-top:10px;
  text-align:center;
  color:var(--dim);
  font-size:11px;
  font-weight:500;
  letter-spacing:.04em;
}
.checkout-legal{
  color:var(--dim);
  font-size:11px;
  line-height:1.45;
  text-align:center;
}
.checkout-legal a{
  color:var(--cyan);
  font-weight:700;
  text-decoration:none;
}
.checkout-legal a:hover{text-decoration:underline}
.turnstile-wrap[hidden]{display:none}
.turnstile-wrap{
  padding:10px;
  border:1px solid rgba(122,192,255,.16);
  border-radius:8px;
  background:rgba(255,255,255,.035);
}
.success-overlay{
  background:rgba(6,10,26,.38);
  backdrop-filter:blur(10px) saturate(1.12);
}
.success-panel{
  position:relative;
  width:min(440px,100%);
  display:grid;
  justify-items:center;
  gap:14px;
  padding:28px 24px 24px;
  border:1px solid rgba(122,192,255,.36);
  border-radius:8px;
  background:
    linear-gradient(180deg,rgba(16,26,51,.94),rgba(6,10,26,.88)),
    var(--grain);
  box-shadow:var(--shadow),0 0 52px rgba(63,138,224,.2),inset 0 1px 0 rgba(240,246,255,.1);
  text-align:center;
  transform:translateY(12px) scale(.98);
  transition:transform .28s var(--ease-out);
}
.overlay.open .success-panel{transform:translateY(0) scale(1)}
.success-close{position:absolute;top:12px;right:12px}
.success-mark{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border:1px solid rgba(122,192,255,.5);
  border-radius:8px;
  background:linear-gradient(180deg,rgba(34,50,90,.9),rgba(10,18,40,.88));
  box-shadow:0 0 32px rgba(63,138,224,.28),inset 0 1px 0 rgba(240,246,255,.18);
}
.success-mark svg{width:30px;height:30px;stroke:var(--cyan);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.success-panel h2{
  max-width:100%;
  font-size:24px;
  line-height:1.12;
  font-weight:600;
  letter-spacing:0;
  overflow-wrap:anywhere;
}
.success-panel p{
  color:var(--muted);
  font-size:16px;
  line-height:1.45;
}
.boot{
  position:fixed;
  left:50%;
  top:50%;
  z-index:80;
  transform:translate(-50%,-50%);
  min-width:220px;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:8px;
  background:linear-gradient(180deg,rgba(16,26,51,.92),rgba(6,10,26,.9));
  color:var(--muted);
  text-align:center;
  font-size:12px;
  font-weight:500;
  letter-spacing:.12em;
  text-transform:uppercase;
  backdrop-filter:blur(18px);
  transition:opacity .3s ease,transform .3s ease;
}
.boot.hide{opacity:0;transform:translate(-50%,-46%);pointer-events:none}
.void{
  position:fixed;
  inset:0;
  z-index:90;
  display:grid;
  place-items:center;
  background:radial-gradient(circle at center,rgba(122,192,255,.18),rgba(6,10,26,.96) 58%);
  color:var(--cyan);
  font-size:12px;
  font-weight:500;
  letter-spacing:.16em;
  text-transform:uppercase;
  opacity:0;
  pointer-events:none;
  transition:opacity .16s ease;
}
.void.show{opacity:1}
.reveal-media{
  position:fixed;
  inset:112px 72px 92px;
  z-index:22;
  display:grid;
  place-items:center;
  pointer-events:none;
  opacity:0;
  transform:scale(.985);
  transition:opacity .45s ease,transform .45s ease;
}
.reveal-media.show{
  opacity:1;
  transform:scale(1);
}
.reveal-media[hidden]{display:none}
.reveal-media img,
.reveal-media video{
  max-width:min(920px,100%);
  max-height:100%;
  object-fit:contain;
  border-radius:8px;
  box-shadow:0 34px 120px rgba(0,0,0,.48),0 0 80px rgba(122,192,255,.18);
}
body.mystery-revealed .hud,
body.mystery-revealed .show-stats-button,
body.mystery-revealed .checkout-launch{
  display:none!important;
}
body.mystery-revealed .log-summary{
  display:none;
}
.onboarding{
  position:fixed;
  inset:0;
  z-index:110;
  display:grid;
  place-items:center;
  padding:18px;
  opacity:0;
  pointer-events:none;
  background:
    linear-gradient(180deg,rgba(6,10,26,.44),rgba(6,10,26,.72)),
    rgba(6,10,26,.58);
  backdrop-filter:blur(18px) saturate(1.2);
  transition:opacity .2s ease;
}
.onboarding.open{opacity:1;pointer-events:auto}
.onboarding-panel{
  width:min(560px,100%);
  min-height:520px;
  max-height:calc(100dvh - 36px);
  overflow:auto;
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
  padding:22px;
  border:1px solid rgba(122,192,255,.28);
  border-radius:8px;
  background:
    linear-gradient(180deg,rgba(16,26,51,.96),rgba(6,10,26,.92)),
    var(--grain);
  box-shadow:0 24px 90px rgba(0,0,0,.58),0 0 60px rgba(63,138,224,.18),inset 0 1px 0 rgba(240,246,255,.08);
  backdrop-filter:blur(22px) saturate(1.18);
  transform:translateY(10px) scale(.98);
  transition:transform .28s var(--ease-out);
}
.onboarding.open .onboarding-panel{transform:translateY(0) scale(1)}
.onboarding-copy{
  align-self:stretch;
  min-height:300px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:12px 6px 2px;
  text-shadow:0 2px 18px rgba(0,0,0,.48);
}
.onboarding-logo-lockup{
  align-self:center;
  display:inline-flex;
  align-items:center;
  gap:9px;
  margin-bottom:12px;
  padding:7px 9px 7px 7px;
  border:1px solid rgba(122,192,255,.16);
  border-radius:8px;
  background:rgba(255,255,255,.035);
  color:rgba(240,246,255,.78);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.onboarding-logo-lockup img{
  width:22px;
  height:22px;
  opacity:.86;
}
.onboarding-copy h2{
  margin-top:8px;
  font-size:29px;
  line-height:1.12;
  letter-spacing:0;
  font-weight:600;
}
.onboarding-body,
.onboarding-copy p{
  margin-top:12px;
  color:var(--muted);
  font-size:15px;
  line-height:1.55;
}
.onboarding-body p + p{margin-top:10px}
.onboarding-body ul{
  margin-top:12px;
  padding-left:18px;
  display:grid;
  gap:8px;
}
.onboarding-body li::marker{color:var(--cyan)}
.onboarding-body strong{color:var(--ink);font-weight:800}
.onboarding-note{
  margin-top:12px;
  padding-top:10px;
  border-top:1px solid rgba(122,192,255,.16);
  color:var(--cyan)!important;
  font-size:15px;
  line-height:1.55;
  white-space:pre-line;
}
.onboarding-progress{
  display:flex;
  gap:7px;
  margin:18px 0;
  grid-column:2;
}
.onboarding-progress i{
  width:32px;
  height:3px;
  border-radius:999px;
  background:rgba(169,196,234,.18);
}
.onboarding-progress i.active{background:linear-gradient(90deg,var(--cyan),#c8dbf4)}
.onboarding-actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  grid-column:2;
}
.onboarding-step-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
}
.onboarding-step-actions [hidden]{display:none}
.cookie-banner{
  position:fixed;
  left:max(18px,env(safe-area-inset-left));
  right:auto;
  bottom:max(18px,env(safe-area-inset-bottom));
  z-index:49;
  width:min(440px,calc(100vw - 36px));
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:16px;
  padding:14px;
  border:1px solid rgba(122,192,255,.28);
  border-radius:8px;
  background:linear-gradient(180deg,rgba(16,26,51,.96),rgba(6,10,26,.94));
  box-shadow:var(--shadow),0 0 40px rgba(63,138,224,.16);
  backdrop-filter:blur(20px) saturate(1.2);
}
.cookie-banner[hidden]{display:none}
.cookie-banner strong{
  display:block;
  margin-bottom:4px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.cookie-banner p{
  max-width:820px;
  color:var(--muted);
  font-size:12px;
  line-height:1.45;
}
.cookie-banner nav{
  display:flex;
  gap:12px;
  margin-top:7px;
}
.cookie-banner a{
  color:var(--cyan);
  font-size:11px;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  text-decoration:none;
}
.cookie-banner a:hover{text-decoration:underline}
.legal-doc,
.legal-doc body{
  width:auto;
  height:auto;
  min-height:100%;
  overflow:auto;
}
body.legal-page{
  background:
    radial-gradient(circle at 30% 0%,rgba(63,138,224,.18),transparent 34rem),
    linear-gradient(180deg,#060a1a,#0a1228 52%,#060a1a);
}
.legal-shell{
  width:min(860px,calc(100vw - 32px));
  margin:0 auto;
  padding:56px 0 80px;
}
.legal-back{
  display:inline-flex;
  margin-bottom:24px;
  color:var(--cyan);
  font-size:12px;
  font-weight:700;
  letter-spacing:.12em;
  text-decoration:none;
  text-transform:uppercase;
}
.legal-shell h1{
  margin-bottom:20px;
  font-size:34px;
  line-height:1.05;
  font-weight:600;
}
.legal-shell h2{
  margin:28px 0 10px;
  font-size:16px;
  line-height:1.25;
  color:var(--ink);
}
.legal-shell p,
.legal-shell li{
  color:var(--muted);
  font-size:14px;
  line-height:1.7;
}
.legal-shell p + p{margin-top:12px}
.legal-shell ul{
  display:grid;
  gap:6px;
  margin:8px 0 16px 20px;
}
.legal-shell li::marker{color:var(--cyan)}
.legal-shell a{color:var(--cyan)}
.site-footer{
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  bottom:max(18px,env(safe-area-inset-bottom));
  z-index:45;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  color:var(--dim);
  font-size:11px;
  font-weight:500;
  letter-spacing:0;
  pointer-events:auto;
  white-space:nowrap;
}
.site-footer a{
  color:var(--dim);
  text-decoration:none;
  border-bottom:1px solid rgba(122,192,255,.22);
}
.site-footer a:hover{color:var(--ink);border-color:rgba(122,192,255,.62)}
@media (max-width:980px){
  .app-tabs{top:54px}
  .feed{top:96px;left:max(18px,env(safe-area-inset-left));right:auto;width:min(330px,calc(100vw - 36px));padding:10px}
  .checkout-launch{width:min(300px,calc(100vw - 36px))}
  .recent-view{inset:96px 18px 18px;left:18px;right:18px;transform:none;width:auto;min-width:0;place-items:start center}
  .log-header{display:grid}
  .log-summary{width:100%;grid-template-columns:repeat(2,1fr)}
  .onboarding-panel{grid-template-columns:1fr;width:min(560px,100%);min-height:520px;height:auto}
  .onboarding-copy{padding:12px 6px 2px}
  .onboarding-progress,.onboarding-actions{grid-column:1}
}
@media (max-width:720px){
  .topbar{padding-top:12px}
  .brand{font-size:12px;letter-spacing:0;gap:9px}
  body.mystery-revealed .brand{
    max-width:calc(100vw - 190px);
    font-size:11px;
  }
  .app-tabs{top:50px}
  .tab-button{min-width:74px;padding:0 9px}
  .top-actions{gap:7px}
  .legal-link{display:none}
  .live-pill{padding:0 9px;font-size:10px;letter-spacing:1.4px}
  .hud{
    left:max(12px,env(safe-area-inset-left));
    right:max(12px,env(safe-area-inset-right));
    bottom:max(122px,calc(env(safe-area-inset-bottom) + 122px));
    width:auto;
    pointer-events:auto;
  }
  .metrics{
    padding:11px 11px 9px;
    gap:9px;
    pointer-events:auto;
    touch-action:pan-x;
  }
  .metric-carousel{grid-template-columns:28px minmax(0,1fr) 28px;gap:6px}
  .metric-arrow{width:28px;height:auto;min-height:128px}
  .metric-page{
    min-height:128px;
    padding:2px;
  }
  .metric-page-progress{
    align-content:center;
    gap:18px;
  }
  .progress-head{align-items:center}
  .value{font-size:23px}
  .progress-track{height:16px}
  .stat-section{gap:7px}
  .stat-row{min-height:32px;padding:7px 9px}
  .reveal-estimate{
    min-height:128px;
    align-content:center;
    padding:15px 13px;
  }
  .reveal-estimate b{font-size:22px}
  .show-stats-button{
    left:max(18px,env(safe-area-inset-left));
    right:max(18px,env(safe-area-inset-right));
    bottom:max(122px,calc(env(safe-area-inset-bottom) + 122px));
    width:auto;
  }
  .checkout-launch{
    left:max(18px,env(safe-area-inset-left));
    right:max(18px,env(safe-area-inset-right));
    bottom:max(18px,env(safe-area-inset-bottom));
    width:auto;
  }
  .pay-note{
    margin-top:10px;
    font-size:11px;
    line-height:1.35;
  }
  .site-footer{
    display:none;
  }
  .feed{top:92px;left:max(18px,env(safe-area-inset-left));right:max(18px,env(safe-area-inset-right));width:auto}
  .feed-list{grid-template-columns:repeat(2,1fr)}
  .feed-item.compact{min-height:30px;padding:6px 8px}
  .ticker{top:auto;bottom:max(302px,calc(env(safe-area-inset-bottom) + 302px));font-size:11px}
  .overlay{place-items:start center;padding:12px}
  .checkout-panel{max-height:calc(100dvh - 24px)}
  .form-grid{grid-template-columns:1fr}
  .qty-row{grid-template-columns:repeat(2,1fr)}
  .rail-row{grid-template-columns:1fr}
  .recent-view{inset:92px 12px 12px;left:12px;right:12px;transform:none;width:auto;min-width:0;padding-top:10px}
  .log-shell{padding:12px}
  .log-summary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .log-controls{display:grid;grid-template-columns:1fr;gap:8px;justify-content:stretch}
  .log-controls span{margin-right:0}
  .log-controls .small-button{width:100%;min-height:38px}
  .onboarding-panel{padding:18px;min-height:min(540px,calc(100dvh - 24px));height:auto;overflow:auto;touch-action:pan-y}
  .onboarding-copy{
    padding:8px 2px 0;
    margin-top:0;
    border-radius:0;
    background:transparent;
    box-shadow:none;
  }
  .onboarding-copy h2{font-size:22px}
  .cookie-banner{
    grid-template-columns:1fr;
    gap:12px;
    bottom:max(302px,calc(env(safe-area-inset-bottom) + 302px));
  }
  .cookie-banner .small-button{width:100%;min-height:42px}
  .reveal-media{inset:118px 18px 76px}
  .legal-shell{padding-top:34px}
  .legal-shell h1{font-size:28px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
    scroll-behavior:auto!important;
  }
}
