/* tools.mphinance.com - "after-hours trading terminal"
   Chakra Petch (display) / IBM Plex Mono (terminal) / IBM Plex Sans (body)
   Dominant near-black, sharp neon accents. Atmosphere: perspective grid,
   banded sun, grain, scanlines. One orchestrated staggered page-load. */

:root{
  --bg:#07070f; --bg2:#0c0c18; --panel:#12122a; --panel2:#0e0e1f;
  --line:#262649; --line2:#34345f;
  --ink:#eef0ff; --dim:#9595c4; --faint:#6a6a96;
  --pink:#ff2d95; --pink-soft:#ff6ab0;
  --cyan:#00e5ff; --green:#39ff9e; --amber:#ffb020; --violet:#7b5cff;
  --glow-pink:0 0 24px rgba(255,45,149,.40);
  --glow-cyan:0 0 22px rgba(0,229,255,.35);
  --display:"Chakra Petch",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,Menlo,monospace;
  --sans:"IBM Plex Sans",system-ui,sans-serif;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.6;
  letter-spacing:.1px;-webkit-font-smoothing:antialiased;min-height:100vh;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}

/* ---------- atmospheric background ---------- */
.bg{position:fixed;inset:0;z-index:-1;overflow:hidden;background:
  radial-gradient(120% 80% at 50% -10%, rgba(123,92,255,.16), transparent 55%),
  radial-gradient(90% 60% at 90% 0%, rgba(0,229,255,.08), transparent 50%),
  var(--bg);}
.bg-sun{
  position:absolute;left:50%;bottom:16%;width:min(70vw,560px);aspect-ratio:1;
  transform:translateX(-50%);border-radius:50%;
  background:
    repeating-linear-gradient(180deg, transparent 0 22px, rgba(7,7,15,.85) 22px 27px),
    radial-gradient(circle at 50% 38%, var(--amber), var(--pink) 42%, var(--violet) 70%, transparent 72%);
  -webkit-mask-image:radial-gradient(circle, #000 60%, transparent 63%);
  mask-image:radial-gradient(circle, #000 60%, transparent 63%);
  filter:blur(.4px) saturate(1.15);opacity:.35;
  animation:sun-breathe 9s var(--ease) infinite;
}
.bg-grid{
  position:absolute;left:50%;bottom:-12%;width:320%;height:78%;
  transform:translateX(-50%) perspective(320px) rotateX(66deg);
  transform-origin:50% 100%;
  background-image:
    linear-gradient(90deg, rgba(0,229,255,.18) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,45,149,.18) 1px, transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:linear-gradient(to top, #000 2%, transparent 72%);
  mask-image:linear-gradient(to top, #000 2%, transparent 72%);
  animation:grid-scroll 7s linear infinite;
}
.bg-vignette{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(130% 100% at 50% -5%, transparent 45%, rgba(0,0,0,.6) 100%)}
.bg-grain{position:absolute;inset:0;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.bg-scan{position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(0deg, rgba(255,255,255,.015) 0 1px, transparent 1px 3px)}

@keyframes grid-scroll{from{background-position:0 0}to{background-position:0 54px}}
@keyframes sun-breathe{0%,100%{opacity:.30}50%{opacity:.42}}

/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;
  justify-content:space-between;gap:16px;padding:15px clamp(18px,4vw,40px);
  background:linear-gradient(180deg, rgba(7,7,15,.92), rgba(7,7,15,.55));
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--mono);
  font-weight:600;letter-spacing:.4px}
.brand-mark{display:grid;place-items:center;width:28px;height:28px;border-radius:6px;
  font-family:var(--display);font-weight:700;color:#150016;
  background:linear-gradient(135deg,var(--pink),var(--amber));box-shadow:var(--glow-pink)}
.brand-text{font-size:15px}
.brand-dim{color:var(--faint)}
.brand-live{display:inline-flex;align-items:center;gap:6px;margin-left:6px;
  font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--green)}
.brand-live i{width:7px;height:7px;border-radius:50%;background:var(--green);
  box-shadow:0 0 8px var(--green);animation:pulse 2s infinite}
.topnav{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:13px}
.topnav a{color:var(--dim);padding:7px 12px;border-radius:7px;transition:.2s}
.topnav a:hover{color:var(--ink);background:rgba(255,255,255,.04)}
.topnav a.ghost{border:1px solid var(--line2);color:var(--cyan)}
.topnav a.ghost:hover{border-color:var(--cyan);box-shadow:var(--glow-cyan)}

/* ---------- status ticker ---------- */
.ticker{position:relative;z-index:10;overflow:hidden;border-bottom:1px solid var(--line);
  background:rgba(12,12,28,.6);height:30px;display:flex;align-items:center;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.ticker-track{display:flex;gap:0;white-space:nowrap;animation:ticker 32s linear infinite}
.ticker-track span{font-family:var(--mono);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;color:var(--faint);padding:0 26px;display:inline-flex;align-items:center}
.ticker-track span::before{content:"◆";color:var(--pink);margin-right:26px;font-size:8px}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- layout ---------- */
.wrap{position:relative;z-index:2;max-width:1080px;margin:0 auto;
  padding:clamp(28px,5vw,56px) clamp(18px,4vw,40px) 80px}

/* ---------- flash ---------- */
.flash{position:relative;z-index:10;max-width:1080px;margin:14px auto 0;
  padding:0 clamp(18px,4vw,40px)}
.flash-item{font-family:var(--mono);font-size:13px;color:var(--cyan);
  background:rgba(0,229,255,.07);border:1px solid rgba(0,229,255,.3);
  border-left:3px solid var(--cyan);padding:11px 15px;border-radius:8px}

/* ---------- hero ---------- */
.hero,.wall-hero{padding:clamp(24px,6vw,64px) 0 clamp(20px,3vw,36px);position:relative}
.hero-boot,.access-head{font-family:var(--mono);font-size:12px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--cyan);display:inline-flex;align-items:center;gap:9px;
  animation:fade-up .6s both}
.hero-boot .dot,.access-head .dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 10px var(--cyan);animation:pulse 1.8s infinite}
.hero-title{font-family:var(--display);font-weight:700;
  font-size:clamp(46px,9.2vw,104px);line-height:.92;margin:16px 0 18px;
  text-transform:uppercase;letter-spacing:-1px;
  background:linear-gradient(96deg,var(--ink) 8%,var(--pink-soft) 48%,var(--cyan) 92%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 60px rgba(255,45,149,.25);animation:fade-up .7s .05s both}
.cursor{-webkit-text-fill-color:var(--cyan);color:var(--cyan);animation:blink 1.1s steps(1) infinite}
.lede{max-width:60ch;color:var(--dim);font-size:clamp(16px,2vw,18px);
  animation:fade-up .7s .12s both}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px;animation:fade-up .7s .2s both}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border-radius:9px;
  font-family:var(--mono);font-weight:600;font-size:14px;letter-spacing:.4px;cursor:pointer;
  border:1px solid transparent;transition:.22s var(--ease)}
.btn .ar{transition:transform .22s var(--ease)}
.btn:hover .ar{transform:translateX(4px)}
.btn-primary{color:#180012;background:linear-gradient(135deg,var(--pink),var(--pink-soft));
  box-shadow:var(--glow-pink)}
.btn-primary:hover{filter:brightness(1.08);box-shadow:0 0 34px rgba(255,45,149,.6);transform:translateY(-2px)}
.btn-ghost{color:var(--cyan);border-color:var(--line2);background:rgba(0,229,255,.03)}
.btn-ghost:hover{border-color:var(--cyan);box-shadow:var(--glow-cyan);transform:translateY(-2px)}
.btn-block{width:100%;justify-content:center}

/* ---------- section rule ---------- */
.rule{display:flex;align-items:center;gap:16px;margin:clamp(40px,6vw,68px) 0 24px;
  font-family:var(--mono);font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--faint)}
.rule span{display:inline-flex;align-items:center;gap:10px;white-space:nowrap}
.rule span::before{content:"//";color:var(--pink)}
.rule::after{content:"";flex:1;height:1px;
  background:linear-gradient(90deg,var(--line2),transparent)}

/* ---------- gated tenants ---------- */
.tenants{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.tenant{position:relative;padding:22px 20px;border-radius:6px;overflow:hidden;
  background:linear-gradient(160deg,rgba(18,18,42,.85),rgba(10,10,24,.9));
  border:1px solid var(--line);
  animation:fade-up .6s both;animation-delay:calc(var(--i,0)*70ms + .15s)}
.tenant::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,var(--green),transparent)}
.tenant:hover{border-color:var(--line2);transform:translateY(-3px);
  box-shadow:0 16px 44px -18px rgba(0,229,255,.4);transition:.25s var(--ease)}
.tenant-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}
.tenant-head h3{margin:0;font-family:var(--display);font-weight:600;font-size:19px;letter-spacing:.2px}
.tenant p{margin:0 0 16px;color:var(--dim);font-size:14px}
.go{font-family:var(--mono);font-size:13px;color:var(--green);display:inline-flex;align-items:center;gap:6px}
.go:hover{text-shadow:0 0 12px rgba(57,255,158,.6)}
.go.locked{color:var(--amber)}
.go.locked:hover{text-shadow:0 0 12px rgba(255,176,32,.5)}

/* ---------- tags ---------- */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;
  letter-spacing:1.5px;text-transform:uppercase;padding:4px 9px;border-radius:5px;
  border:1px solid var(--line2);color:var(--dim)}
.tag i{width:6px;height:6px;border-radius:50%;background:currentColor}
.tag-live{color:var(--green);border-color:rgba(57,255,158,.45);background:rgba(57,255,158,.06)}
.tag-live i{animation:pulse 1.8s infinite;box-shadow:0 0 8px var(--green)}
.tag-building{color:var(--cyan);border-color:rgba(0,229,255,.45);background:rgba(0,229,255,.06)}
.tag-shipped{color:var(--green);border-color:rgba(57,255,158,.45)}
.tag-parked{color:var(--faint)}

/* ---------- free shelf ---------- */
.shelf-group{margin-bottom:30px}
.group{display:flex;align-items:center;gap:11px;margin:0 0 14px;
  font-family:var(--mono);font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--cyan)}
.group-emoji{font-size:17px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:14px}
.card{position:relative;display:flex;flex-direction:column;gap:9px;padding:20px 18px;
  border-radius:5px;overflow:hidden;isolation:isolate;
  background:linear-gradient(158deg,rgba(20,20,44,.9),rgba(11,11,24,.92));
  border:1px solid var(--line);
  transition:transform .25s var(--ease),border-color .25s,box-shadow .25s;
  animation:fade-up .55s both;animation-delay:calc(var(--i,0)*55ms + .1s)}
.card::before,.card::after{content:"";position:absolute;width:14px;height:14px;
  border:1.5px solid var(--cyan);opacity:0;transition:opacity .25s,inset .25s}
.card::before{top:9px;left:9px;border-right:0;border-bottom:0}
.card::after{bottom:9px;right:9px;border-left:0;border-top:0}
.card:hover{transform:translateY(-4px);border-color:rgba(255,45,149,.55);
  box-shadow:0 18px 46px -16px rgba(255,45,149,.45)}
.card:hover::before,.card:hover::after{opacity:.8}
.card-icon{font-size:21px;width:42px;height:42px;display:grid;place-items:center;
  border:1px solid var(--line2);border-radius:7px;background:rgba(0,229,255,.05)}
.card-title{font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:.2px}
.card-blurb{flex:1;color:var(--dim);font-size:13.5px;line-height:1.5}
.card-go{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;
  color:var(--cyan);transition:transform .22s var(--ease)}
.card:hover .card-go{transform:translateX(3px)}

/* ---------- login ---------- */
.access{min-height:60vh;display:grid;place-items:center}
.access-panel{position:relative;width:min(440px,92vw);padding:34px 30px;border-radius:8px;
  background:linear-gradient(160deg,rgba(18,18,42,.9),rgba(10,10,22,.94));
  border:1px solid var(--line2);box-shadow:0 30px 80px -30px rgba(255,45,149,.4);
  animation:fade-up .6s both}
.access-panel::before,.access-panel::after{content:"";position:absolute;width:20px;height:20px;
  border:2px solid var(--pink);opacity:.7}
.access-panel::before{top:12px;left:12px;border-right:0;border-bottom:0}
.access-panel::after{bottom:12px;right:12px;border-left:0;border-top:0}
.access-panel h1{font-family:var(--display);font-weight:700;font-size:34px;
  text-transform:uppercase;letter-spacing:-.5px;margin:14px 0 8px}
.access-panel .lede{margin:0 0 22px}
.field{display:block;margin-bottom:16px}
.field-label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--faint);margin-bottom:7px}
input[type=password],input[type=text]{width:100%;padding:13px 15px;border-radius:8px;
  background:#08081480;border:1px solid var(--line2);color:var(--ink);
  font-family:var(--mono);font-size:15px;transition:.2s}
input::placeholder{color:var(--faint)}
input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(0,229,255,.14)}
.fineprint{margin:20px 0 0;color:var(--dim);font-size:14px;text-align:center}
.fineprint a,.lede a{color:var(--cyan)}

/* ---------- voting wall ---------- */
.submit{display:flex;gap:12px;align-items:stretch;margin:6px 0 30px;flex-wrap:wrap}
.submit-fields{flex:1 1 320px;display:flex;flex-direction:column;gap:10px}
.submit .btn{align-self:stretch}
.ideas{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;counter-reset:none}
.idea{position:relative;display:grid;grid-template-columns:auto auto 1fr;align-items:center;gap:16px;
  padding:16px 18px;border-radius:6px;overflow:hidden;
  background:linear-gradient(160deg,rgba(18,18,40,.82),rgba(11,11,24,.9));
  border:1px solid var(--line);
  animation:fade-up .5s both;animation-delay:calc(var(--i,0)*45ms + .12s)}
.idea:hover{border-color:var(--line2)}
.idea.mine{border-color:rgba(255,45,149,.45);box-shadow:inset 3px 0 0 var(--pink)}
.idea:first-child{border-color:rgba(255,176,32,.4);
  background:linear-gradient(160deg,rgba(34,26,18,.7),rgba(11,11,24,.9))}
.idea:first-child .rank{color:var(--amber)}
.rank{font-family:var(--mono);font-size:15px;font-weight:600;color:var(--faint);
  min-width:24px;text-align:center}
.vote{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;
  min-width:58px;padding:9px 6px;border-radius:9px;cursor:pointer;
  background:#08081480;border:1px solid var(--line2);color:var(--dim);transition:.16s var(--ease)}
.vote .arrow{font-size:12px;transition:transform .16s}
.vote .count{font-family:var(--mono);font-size:19px;font-weight:600;line-height:1}
.vote:hover{border-color:var(--pink);color:var(--ink);transform:translateY(-2px)}
.vote:hover .arrow{transform:translateY(-2px)}
.vote.voted{border-color:var(--pink);color:var(--pink);background:#1a0a18;box-shadow:var(--glow-pink)}
.vote.locked,.vote:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}
.idea-title{font-family:var(--display);font-weight:600;font-size:16px;display:flex;
  align-items:center;gap:10px;flex-wrap:wrap}
.idea-detail{color:var(--dim);font-size:13.5px;margin-top:3px}
.wall-note{margin:20px 2px 0;color:var(--faint);font-family:var(--mono);font-size:12px;letter-spacing:.5px}

/* ---------- footer ---------- */
.foot{position:relative;z-index:2;max-width:1080px;margin:0 auto;
  padding:26px clamp(18px,4vw,40px);border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;
  font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:.5px}
.foot a{color:var(--cyan)}

/* ---------- keyframes ---------- */
@keyframes fade-up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes blink{50%{opacity:0}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

@media (max-width:560px){
  .topnav a{padding:6px 9px}
  .idea{grid-template-columns:auto auto 1fr;gap:12px;padding:14px}
  .foot{flex-direction:column}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .bg-grid,.bg-sun,.ticker-track{animation:none!important}
}
