/* ============================================================
   BASE BUILDER INDEX . $BBI
   A serious product page with a live data-fed cube mascot.
   ============================================================ */

:root{
  --s:1;
  --base-blue:#0052ff;
  --base-blue-2:#2563ff;
  --base-blue-deep:#002fc4;
  --base-blue-soft:#e6efff;
  --bg:#f3f6fb;
  --white:#ffffff;
  --ink:#0a1126;
  --ink-2:#1b2540;
  --soft:#5e6680;
  --softer:#9099b0;
  --border:#e3e7f0;
  --border-strong:#cdd4e2;
  --green:#16a34a;
  --green-soft:#dcfae6;
  --amber:#e08605;
  --amber-soft:#fff1d6;
  --red:#dc2626;
  --gray-led:#9ca3af;
  --f-display:'Bricolage Grotesque',system-ui,-apple-system,sans-serif;
  --f-body:'Public Sans',system-ui,-apple-system,sans-serif;
  --f-mono:'B612 Mono',ui-monospace,SFMono-Regular,monospace;
}

*{box-sizing:border-box;margin:0;padding:0;}

html{scroll-behavior:smooth;}

body{
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
  min-height:100vh;
  position:relative;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 90% 50% at 50% -10%,rgba(0,82,255,.10),transparent 60%),
    radial-gradient(circle at 90% 110%,rgba(0,82,255,.07),transparent 50%);
}
body>*{position:relative;z-index:1;}

.vh{
  position:absolute;width:1px;height:1px;overflow:hidden;
  clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;
}

img{display:block;max-width:100%;}

a{color:var(--base-blue);text-decoration:none;}
a:hover{color:var(--base-blue-deep);}

code{font-family:var(--f-mono);font-size:.92em;}

/* ---- topbar ----------------------------------------------- */
.topbar{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px clamp(16px,4vw,40px);
  background:rgba(243,246,251,.84);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--border);
}
.brand{
  display:flex;align-items:center;gap:11px;
  text-decoration:none;color:var(--ink);
}
.brand-mark{
  width:36px;height:36px;border-radius:8px;
  box-shadow:0 2px 8px rgba(0,82,255,.18);
}
.brand-text{display:flex;flex-direction:column;line-height:1.1;}
.brand-name{
  font-family:var(--f-display);font-weight:700;font-size:1.04rem;
  letter-spacing:-.01em;
}
.brand-tick{
  font-family:var(--f-mono);font-size:.7rem;
  color:var(--soft);letter-spacing:.04em;margin-top:2px;
}
.topnav{display:flex;align-items:center;gap:10px;}
.x-link{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:9px;
  background:var(--ink);color:var(--white);
  transition:transform .15s ease,background .15s ease;
}
.x-link:hover{background:var(--base-blue);transform:translateY(-1px);}
.x-link svg{width:16px;height:16px;fill:currentColor;}
.x-link.is-disabled{background:var(--border-strong);cursor:default;}
.x-link.is-disabled:hover{transform:none;background:var(--border-strong);}

/* ---- hero ------------------------------------------------- */
.hero{
  max-width:780px;margin:0 auto;
  padding:clamp(34px,7vh,68px) clamp(20px,4vw,40px) clamp(18px,3vh,28px);
  text-align:center;
}
.mascot-stage{
  position:relative;
  width:clamp(220px,42vw,300px);
  height:clamp(220px,42vw,300px);
  margin:0 auto clamp(16px,3vh,28px);
  perspective:1000px;
}
.mascot-tilt{
  position:absolute;inset:0;
  transform-style:preserve-3d;
  transform:rotateX(var(--tx,0deg)) rotateY(var(--ty,0deg));
  transition:transform .14s cubic-bezier(.22,1,.36,1);
  will-change:transform;
}
.aura{
  position:absolute;inset:-10%;
  border-radius:50%;
  background:radial-gradient(circle,rgba(0,82,255,.28),transparent 65%);
  filter:blur(8px);
  transition:background .6s ease,transform .6s ease,opacity .6s ease;
}
.mascot{
  position:absolute;left:50%;top:50%;
  width:78%;
  transform:translate(-50%,-50%) scale(var(--s,1));
  transition:transform .55s cubic-bezier(.22,1,.36,1),filter .4s ease;
  filter:drop-shadow(0 18px 30px rgba(0,30,120,.22));
  animation:mascotFloat 5s ease-in-out infinite;
}
@keyframes mascotFloat{50%{margin-top:-8px;}}
.floats{position:absolute;inset:0;pointer-events:none;overflow:visible;}
.float-bit{
  position:absolute;
  font-family:var(--f-display);font-weight:700;font-size:1.4rem;
  color:var(--base-blue);
  pointer-events:none;
  animation:floatUp 1.2s ease-out forwards;
}
@keyframes floatUp{
  0%{opacity:0;transform:translate(-50%,0) scale(.6);}
  20%{opacity:1;}
  100%{opacity:0;transform:translate(-50%,-80px) scale(1.1);}
}

body[data-mood="happy"]{--s:1.06;}
body[data-mood="happy"] .aura{background:radial-gradient(circle,rgba(22,163,74,.34),transparent 64%);transform:scale(1.06);}
body[data-mood="neutral"] .aura{background:radial-gradient(circle,rgba(0,82,255,.28),transparent 65%);}
body[data-mood="sad"]{--s:.94;}
body[data-mood="sad"] .aura{background:radial-gradient(circle,rgba(224,134,5,.30),transparent 64%);transform:scale(.92);}
body[data-mood="sad"] .mascot{animation:mascotSway 5s ease-in-out infinite;}
@keyframes mascotSway{0%,100%{margin-top:0;}50%{margin-top:6px;}}
body[data-mood="offline"] .aura{background:radial-gradient(circle,rgba(156,163,175,.30),transparent 64%);}
body[data-mood="offline"] .mascot{filter:drop-shadow(0 18px 30px rgba(0,30,120,.22)) grayscale(.4);}
body[data-mood="loading"] .aura{animation:auraPulse 1.6s ease-in-out infinite;}
@keyframes auraPulse{50%{opacity:.55;transform:scale(.96);}}

.mascot-stage.eat .mascot{animation:mascotMunch .6s ease-out;}
@keyframes mascotMunch{
  0%{transform:translate(-50%,-50%) scale(var(--s,1));}
  35%{transform:translate(-50%,-50%) scale(calc(var(--s,1) * .84)) rotate(-2deg);}
  60%{transform:translate(-50%,-50%) scale(calc(var(--s,1) * 1.10)) rotate(2deg);}
  100%{transform:translate(-50%,-50%) scale(var(--s,1));}
}

/* status eyebrow */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--f-mono);font-size:.78rem;
  color:var(--soft);
  background:var(--white);
  padding:7px 14px;border-radius:999px;
  border:1px solid var(--border);
  margin-bottom:18px;
}
.led{
  width:9px;height:9px;border-radius:50%;
  background:var(--gray-led);
  box-shadow:0 0 0 0 currentColor;
}
body[data-mood="loading"] .led{background:var(--base-blue);animation:ledBlink 1.2s steps(2) infinite;}
body[data-mood="happy"] .led{background:var(--green);box-shadow:0 0 10px rgba(22,163,74,.6);}
body[data-mood="neutral"] .led{background:var(--base-blue);box-shadow:0 0 10px rgba(0,82,255,.55);}
body[data-mood="sad"] .led{background:var(--amber);box-shadow:0 0 10px rgba(224,134,5,.55);}
body[data-mood="offline"] .led{background:var(--red);}
@keyframes ledBlink{50%{opacity:.3;}}

.hero-title{
  font-family:var(--f-display);font-weight:800;
  font-size:clamp(2.2rem,5.6vw,3.8rem);
  letter-spacing:-.02em;line-height:1.04;
  color:var(--ink);
}
.hero-sub{
  max-width:560px;margin:18px auto 26px;
  font-size:1.06rem;color:var(--ink-2);
}
.hero-sub code{
  background:var(--base-blue-soft);
  color:var(--base-blue-deep);
  padding:1px 7px;border-radius:5px;font-weight:600;
}

.hero-cta{
  display:flex;justify-content:center;gap:11px;flex-wrap:wrap;
}
.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;
  height:50px;padding:0 26px;
  background:var(--base-blue);color:var(--white);
  font-family:var(--f-body);font-weight:600;font-size:1.04rem;
  text-decoration:none;border:0;cursor:pointer;
  border-radius:12px;
  box-shadow:0 1px 0 var(--base-blue-deep) inset,0 8px 20px -8px rgba(0,82,255,.5);
  transition:transform .12s ease,box-shadow .15s ease,background .15s ease;
}
.btn-primary:hover{background:var(--base-blue-2);transform:translateY(-1px);box-shadow:0 1px 0 var(--base-blue-deep) inset,0 12px 24px -8px rgba(0,82,255,.55);color:var(--white);}
.btn-primary:active{transform:translateY(1px);}
.btn-primary.is-disabled{background:var(--border-strong);box-shadow:none;color:var(--white);cursor:default;}
.btn-primary.is-disabled:hover{background:var(--border-strong);transform:none;box-shadow:none;}

.btn-secondary{
  display:inline-flex;align-items:center;justify-content:center;
  height:50px;padding:0 22px;
  background:var(--white);color:var(--base-blue);
  font-family:var(--f-body);font-weight:600;font-size:1.02rem;
  border:1.5px solid var(--base-blue);cursor:pointer;
  border-radius:12px;
  transition:background .12s ease,color .12s ease,transform .12s ease;
}
.btn-secondary:hover{background:var(--base-blue-soft);transform:translateY(-1px);}
.btn-secondary:active{transform:translateY(1px);}

.feed-count{
  margin-top:14px;
  font-family:var(--f-mono);font-size:.84rem;color:var(--soft);
  min-height:1.4em;
}

/* ---- dashboard ------------------------------------------- */
.dashboard{
  max-width:1080px;margin:0 auto;
  padding:0 clamp(16px,4vw,40px);
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
  gap:12px;
}
.panel{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:12px;
  padding:18px 18px 16px;
  display:flex;flex-direction:column;
  min-width:0;
  transition:border-color .15s ease,transform .15s ease;
}
.panel:hover{border-color:var(--border-strong);transform:translateY(-1px);}
.panel-label{
  font-family:var(--f-mono);font-size:.7rem;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--soft);
}
.panel-num{
  font-family:var(--f-display);font-weight:700;
  font-size:clamp(1.7rem,3.2vw,2.4rem);
  line-height:1.05;letter-spacing:-.02em;
  color:var(--ink);
  margin-top:10px;
}
.panel-sub{
  font-family:var(--f-mono);font-size:.7rem;
  color:var(--softer);margin-top:6px;
}
.panel-num.skeleton{
  display:inline-block;color:transparent;
  background:linear-gradient(90deg,#e3e7f0 0%,#f4f6fb 50%,#e3e7f0 100%);
  background-size:200% 100%;
  border-radius:6px;height:1em;
  animation:shimmer 1.4s ease-in-out infinite;
}
@keyframes shimmer{0%{background-position:100% 0;}100%{background-position:-100% 0;}}

/* ---- data line ------------------------------------------- */
.data-line{
  max-width:1080px;margin:20px auto 0;
  padding:0 clamp(16px,4vw,40px);
  display:flex;flex-wrap:wrap;align-items:center;gap:12px;
  font-family:var(--f-mono);font-size:.84rem;color:var(--soft);
}
.data-tag{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--base-blue);color:var(--white);
  padding:4px 10px;border-radius:6px;
  font-family:var(--f-mono);font-weight:700;font-size:.66rem;
  letter-spacing:.1em;text-transform:uppercase;
}
.link-btn{
  font-family:var(--f-mono);font-size:.84rem;
  color:var(--base-blue);background:none;border:0;cursor:pointer;
  text-decoration:underline;text-underline-offset:3px;
  padding:0;
}
.link-btn:hover{color:var(--base-blue-deep);}
.link-inline{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--f-mono);font-size:.84rem;color:var(--base-blue);
  text-decoration:none;
}
.link-inline:hover{color:var(--base-blue-deep);}
.link-inline.is-disabled{color:var(--softer);cursor:default;}
.spark{
  width:20px;height:10px;fill:none;
  stroke:currentColor;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;
}

/* ---- how it works ---------------------------------------- */
.how,.token{
  max-width:980px;margin:clamp(60px,9vh,108px) auto;
  padding:0 clamp(16px,4vw,40px);
}
.kicker{
  font-family:var(--f-mono);font-size:.72rem;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--base-blue);
}
.section-title{
  font-family:var(--f-display);font-weight:700;
  font-size:clamp(1.9rem,4.4vw,2.8rem);
  letter-spacing:-.02em;line-height:1.1;
  color:var(--ink);margin-top:8px;
}
.steps{
  list-style:none;
  margin-top:30px;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(18px,3vw,32px);
}
.steps li{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:12px;
  padding:22px 22px 24px;
  transition:border-color .15s ease;
}
.steps li:hover{border-color:var(--border-strong);}
.step-num{
  display:inline-block;
  font-family:var(--f-mono);font-weight:700;font-size:.78rem;
  letter-spacing:.1em;
  background:var(--base-blue-soft);color:var(--base-blue-deep);
  padding:4px 9px;border-radius:5px;
}
.steps h4{
  font-family:var(--f-display);font-weight:700;font-size:1.18rem;
  color:var(--ink);margin:13px 0 8px;letter-spacing:-.01em;
}
.steps p{color:var(--soft);font-size:.96rem;}

/* ---- token section --------------------------------------- */
.token{text-align:center;}
.token .kicker,.token .section-title{text-align:center;}
.token-lede{
  max-width:520px;margin:14px auto 28px;color:var(--ink-2);
}
.ca-pill{
  display:inline-flex;align-items:stretch;
  background:var(--white);border:1.5px solid var(--border-strong);
  border-radius:11px;overflow:hidden;
  font-family:var(--f-mono);font-size:.94rem;
  cursor:pointer;
  transition:border-color .15s ease,box-shadow .15s ease;
  max-width:100%;
}
.ca-pill:hover{border-color:var(--base-blue);box-shadow:0 6px 14px -8px rgba(0,82,255,.4);}
.ca-tag{
  background:var(--ink);color:var(--white);
  padding:11px 14px;
  font-family:var(--f-mono);font-weight:700;font-size:.72rem;
  letter-spacing:.1em;text-transform:uppercase;
  display:flex;align-items:center;
}
.ca-num{
  padding:11px 16px;color:var(--ink);
  align-self:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:50vw;
}
.ca-copy{
  background:var(--base-blue-soft);color:var(--base-blue-deep);
  padding:11px 16px;
  font-family:var(--f-mono);font-weight:700;font-size:.78rem;
  letter-spacing:.06em;text-transform:uppercase;
  display:flex;align-items:center;
  border-left:1px solid var(--border);
}
.ca-pill.is-copied{border-color:var(--green);}
.ca-pill.is-copied .ca-copy{background:var(--green-soft);color:var(--green);}

.token-cta{
  margin-top:26px;
  display:flex;gap:18px;justify-content:center;align-items:center;flex-wrap:wrap;
}

/* ---- tilt aside ------------------------------------------ */
.tilt-aside{
  max-width:680px;margin:clamp(60px,8vh,90px) auto 0;
  padding:24px clamp(16px,4vw,40px);
  display:flex;align-items:center;gap:24px;
  border-top:1px dashed var(--border-strong);
  padding-top:36px;
}
.tilt-mascot{
  width:120px;flex:0 0 auto;
  filter:drop-shadow(0 12px 18px rgba(0,30,120,.18));
}
.tilt-words{display:flex;flex-direction:column;gap:2px;}
.tilt-eyebrow{
  font-family:var(--f-mono);font-size:.7rem;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--base-blue);
}
.tilt-line{
  font-family:var(--f-display);font-weight:700;font-size:1.4rem;
  letter-spacing:-.01em;color:var(--ink);margin-top:4px;
}

/* ---- footer ---------------------------------------------- */
.foot{
  max-width:780px;margin:clamp(48px,7vh,80px) auto 0;
  padding:32px clamp(16px,4vw,40px) 64px;
  text-align:center;
  border-top:1px solid var(--border);
}
.foot-name{
  font-family:var(--f-display);font-weight:700;font-size:1.08rem;
  color:var(--ink);
}
.foot-disc{
  max-width:600px;margin:14px auto 0;
  font-size:.84rem;color:var(--soft);line-height:1.7;
}
.foot-thanks{
  margin-top:14px;
  font-family:var(--f-mono);font-size:.72rem;color:var(--softer);
}

/* ---- toast ----------------------------------------------- */
.toast{
  position:fixed;left:50%;bottom:24px;z-index:50;
  transform:translate(-50%,160%);
  max-width:min(380px,90vw);
  background:var(--ink);color:var(--white);
  padding:11px 18px;border-radius:10px;
  font-family:var(--f-body);font-size:.88rem;font-weight:500;
  box-shadow:0 14px 28px -10px rgba(10,17,38,.45);
  transition:transform .35s cubic-bezier(.2,.9,.25,1);
}
.toast.show{transform:translate(-50%,0);}

/* ---- responsive ------------------------------------------ */
@media (max-width:920px){
  .steps{grid-template-columns:1fr;}
}
@media (max-width:680px){
  .topbar{padding:10px 14px;}
  .brand-mark{width:32px;height:32px;}
  .brand-name{font-size:.96rem;}
  .brand-tick{font-size:.66rem;}
  .hero-cta{flex-direction:column;}
  .btn-primary,.btn-secondary{width:100%;}
  .ca-pill{font-size:.84rem;width:100%;}
  .ca-num{max-width:100%;}
  .tilt-aside{flex-direction:column;text-align:center;gap:14px;}
}
/* ---- reduced motion -------------------------------------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;}
}

/* ---- keyboard focus polish ------------------------------- */
a:focus-visible,button:focus-visible{
  outline:2px solid var(--base-blue);
  outline-offset:3px;
  border-radius:8px;
}
.x-link:focus-visible,.btn-primary:focus-visible,.btn-secondary:focus-visible,
.ca-pill:focus-visible,.link-btn:focus-visible{
  outline-offset:4px;
}

/* ---- leaderboards ---------------------------------------- */
.lb{min-width:0;}
.leaderboards{
  max-width:1080px;margin:clamp(54px,8vh,90px) auto 0;
  padding:0 clamp(16px,4vw,40px);
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(28px,4vw,52px);
}
.lb-lead{
  margin-top:10px;color:var(--soft);font-size:.96rem;max-width:440px;
}
.lb-placeholder{
  margin-top:18px;
  font-family:var(--f-mono);font-size:.84rem;color:var(--softer);
  padding:18px;background:var(--white);
  border:1px dashed var(--border-strong);border-radius:10px;
}

/* top orgs : ranked bar list */
.org-list{
  margin-top:20px;
  display:flex;flex-direction:column;gap:6px;
  background:var(--white);
  border:1px solid var(--border);border-radius:12px;
  padding:8px;
}
.org-row{
  display:grid;
  grid-template-columns:32px 1fr 1fr 60px;
  align-items:center;gap:14px;
  padding:10px 12px;border-radius:8px;
  text-decoration:none;color:var(--ink);
  transition:background .12s ease;
}
.org-row:hover{background:var(--base-blue-soft);color:var(--ink);}
.org-rank{
  font-family:var(--f-mono);font-weight:700;font-size:.78rem;
  color:var(--softer);text-align:center;
}
.org-name{
  font-family:var(--f-display);font-weight:700;font-size:1rem;
  letter-spacing:-.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;
}
.org-bar{
  position:relative;height:8px;border-radius:5px;
  background:var(--base-blue-soft);overflow:hidden;
  min-width:0;
}
.org-fill{
  display:block;height:100%;
  background:linear-gradient(90deg,var(--base-blue),var(--base-blue-2));
  transition:width .6s cubic-bezier(.22,1,.36,1);
}
.org-count{
  font-family:var(--f-mono);font-weight:700;font-size:.92rem;
  color:var(--ink);text-align:right;
}
.org-row.is-err{opacity:.55;}
.org-row.is-err .org-fill{background:var(--border-strong);}

/* top builders : avatar grid */
.builders-grid{
  margin-top:20px;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:12px;
}
.builder{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;text-decoration:none;color:var(--ink);
  background:var(--white);
  border:1px solid var(--border);border-radius:12px;
  padding:14px 10px 12px;
  transition:border-color .15s ease,transform .15s ease;
}
.builder:hover{border-color:var(--base-blue);transform:translateY(-2px);color:var(--ink);}
.builder-avatar{
  width:48px;height:48px;border-radius:50%;
  background:var(--base-blue-soft);
  border:2px solid var(--white);
  box-shadow:0 0 0 1px var(--border);
  margin-bottom:9px;
  object-fit:cover;
}
.builder-handle{
  font-family:var(--f-mono);font-size:.78rem;
  color:var(--ink-2);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:100%;display:block;
}
.builder-count{
  margin-top:5px;
  font-family:var(--f-mono);font-size:.7rem;color:var(--soft);
}
.builder-count b{
  font-family:var(--f-display);font-weight:700;font-size:.96rem;
  color:var(--base-blue);margin-right:3px;
}

@media (max-width:880px){
  .leaderboards{grid-template-columns:1fr;gap:34px;}
}
@media (max-width:520px){
  .org-row{grid-template-columns:28px 1fr 36px;gap:10px;}
  .org-bar{display:none;}
}

/* ---- live commit ticker ---------------------------------- */
.ticker-wrap{
  max-width:1080px;margin:clamp(28px,4vh,40px) auto 0;
  padding:0 clamp(16px,4vw,40px);
  display:flex;align-items:stretch;
  gap:10px;
}
.ticker-pill{
  flex:0 0 auto;
  display:inline-flex;align-items:center;gap:6px;
  background:var(--base-blue);color:var(--white);
  padding:0 14px;border-radius:8px;
  font-family:var(--f-mono);font-weight:700;font-size:.7rem;
  letter-spacing:.18em;text-transform:uppercase;
  position:relative;
}
.ticker-pill::before{
  content:"";width:7px;height:7px;border-radius:50%;
  background:#fff;box-shadow:0 0 8px #fff;
  animation:blink 1.3s steps(2) infinite;
}
.ticker-track{
  flex:1 1 auto;min-width:0;
  background:var(--white);
  border:1px solid var(--border);border-radius:8px;
  overflow:hidden;
  display:flex;align-items:center;
  position:relative;
  height:38px;
}
.ticker-track:hover .ticker-row{animation-play-state:paused;}
.ticker-row{
  display:inline-flex;align-items:center;gap:30px;
  white-space:nowrap;
  padding-left:100%;
  animation:tickerScroll 64s linear infinite;
}
@keyframes tickerScroll{to{transform:translateX(-100%);}}
.ticker-item{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-mono);font-size:.84rem;
  color:var(--ink);text-decoration:none;
}
.ticker-item:hover{color:var(--base-blue);}
.ticker-item b{font-weight:700;color:var(--base-blue);}
.ticker-item .dot-sep{color:var(--softer);}
.ticker-empty{
  padding:0 16px;
  font-family:var(--f-mono);font-size:.82rem;color:var(--softer);
}

/* ---- confetti on milestones ------------------------------ */
.confetti-layer{position:absolute;inset:0;pointer-events:none;overflow:visible;z-index:5;}
.confetti{
  position:absolute;left:50%;top:50%;
  width:9px;height:9px;border-radius:2px;
  background:var(--base-blue);
  transform:translate(-50%,-50%);
  animation:confettiFly 1.2s cubic-bezier(.2,.7,.3,1) forwards;
}
.confetti.c2{background:var(--base-blue-2);width:7px;height:7px;}
.confetti.c3{background:var(--gold,#ffd24e);width:7px;height:11px;border-radius:1px;}
.confetti.c4{background:#fff;border:1.5px solid var(--base-blue);}
@keyframes confettiFly{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.4) rotate(0deg);}
  10%{opacity:1;}
  100%{opacity:0;transform:translate(calc(-50% + var(--dx,0px)),calc(-50% + var(--dy,0px))) scale(1) rotate(var(--rot,360deg));}
}

/* ---- auto-refresh sync chip ------------------------------ */
.sync-pill{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--white);
  border:1px solid var(--border);border-radius:999px;
  padding:3px 11px;
  font-family:var(--f-mono);font-size:.72rem;color:var(--soft);
}
.sync-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--base-blue);
  box-shadow:0 0 6px rgba(0,82,255,.5);
}
.sync-pill.is-syncing{color:var(--base-blue-deep);border-color:var(--base-blue);}
.sync-pill.is-syncing .sync-dot{animation:syncPulse .9s ease-in-out infinite;}
@keyframes syncPulse{50%{transform:scale(1.6);opacity:.5;}}
.sync-pill.is-off{opacity:.55;}
.sync-pill.is-off .sync-dot{background:var(--softer);box-shadow:none;}

/* ---- keyboard hints in footer ---------------------------- */
.foot-keys{
  margin-top:14px;
  font-family:var(--f-mono);font-size:.7rem;color:var(--softer);
  letter-spacing:.06em;
}
.foot-keys kbd{
  display:inline-block;
  font-family:var(--f-mono);font-size:.66rem;font-weight:700;
  background:var(--white);color:var(--ink);
  border:1px solid var(--border-strong);
  border-bottom-width:2px;
  border-radius:5px;
  padding:1px 7px;margin-right:4px;
}

@media (max-width:680px){
  .ticker-pill{padding:0 10px;font-size:.66rem;}
}
