/* ===========================================================================
   LineUp — Marketing site
   Dark / premium. Built on the LineUp app's deep-purple brand.
   Plain CSS, shared across Home / Features / Liquidity & Engine / Contact.
   =========================================================================== */

/* ---------- Tokens ---------- */
:root{
  --font-ui: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --font-num: 'Space Grotesk', 'Plus Jakarta Sans', monospace;

  --bg: #0A0718;
  --bg-2: #0C0820;
  --panel: #14102C;
  --panel-2: #1A1440;
  --panel-3: #221A52;
  --line: #2A2356;
  --line-2: #372D6B;

  --text: #F4F2FF;
  --text-2: #ABA4D2;
  --text-3: #756E9C;

  --up: #29D49A;
  --up-bg: rgba(41,212,154,.12);
  --down: #FF5B7C;
  --down-bg: rgba(255,91,124,.12);
  --warn: #F0A94B;

  /* accent (tweakable) */
  --accent: #5B4BD6;
  --accent-2: #8B7BF5;
  --accent-ink: #ffffff;

  --maxw: 1200px;
  --radius: 22px;
  --shadow: 0 1px 2px rgba(0,0,0,.3), 0 18px 50px rgba(0,0,0,.45);
  --shadow-glow: 0 30px 80px -30px rgba(91,75,214,.55);
}

[data-accent="indigo"]{ --accent:#5B4BD6; --accent-2:#8B7BF5; }
[data-accent="violet"]{ --accent:#7C4DE0; --accent-2:#A77BF5; }
[data-accent="electric"]{ --accent:#4F46E5; --accent-2:#7C82FF; }
[data-accent="magenta"]{ --accent:#C13BB0; --accent-2:#E978D8; }

/* ---------- Reset ---------- */
*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin: 0;
  font-family: var(--font-ui);
  color: var(--text);
  background: var(--bg);
  letter-spacing: -0.011em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a{ color: inherit; text-decoration: none; }
img{ display: block; max-width: 100%; }
button{ font-family: inherit; cursor: pointer; }
.num{ font-family: var(--font-num); font-feature-settings:"tnum" 1; letter-spacing: -0.02em; }
::selection{ background: var(--accent); color: #fff; }

/* page background — layered radial glows (no grid) */
.page-bg{
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(60% 50% at 12% -4%, rgba(91,75,214,.20), transparent 60%),
    radial-gradient(50% 44% at 92% 4%, rgba(124,77,224,.16), transparent 62%),
    radial-gradient(60% 50% at 78% 102%, rgba(58,46,122,.22), transparent 60%),
    var(--bg);
}

/* ---------- Layout primitives ---------- */
.container{ width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }
.section{ padding: 96px 0; position: relative; }
.section.tight{ padding: 64px 0; }
.eyebrow{
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12.5px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase;
  color: var(--accent-2);
}
.eyebrow::before{ content:''; width: 18px; height: 2px; border-radius: 2px; background: var(--accent-2); }
.section-head{ max-width: 640px; margin-bottom: 48px; }
.section-head.center{ margin-left: auto; margin-right: auto; text-align: center; }
.section-head.center .eyebrow::before{ display: none; }
h1,h2,h3,h4{ margin: 0; letter-spacing: -0.035em; line-height: 1.05; font-weight: 800; }
.h-display{ font-size: clamp(40px, 6.2vw, 78px); line-height: 1.0; }
h2.h-sec{ font-size: clamp(30px, 4vw, 48px); margin-top: 16px; }
h3.h-sub{ font-size: clamp(22px, 2.4vw, 30px); }
.lede{ font-size: clamp(16px, 1.5vw, 19px); line-height: 1.6; color: var(--text-2); margin-top: 16px; }
.lede.big{ font-size: clamp(18px, 1.8vw, 22px); }
.text-grad{ background: linear-gradient(100deg, var(--accent-2), #d9d2ff 55%, var(--accent-2)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.muted{ color: var(--text-2); }

/* ---------- Buttons ---------- */
.btn{
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  height: 52px; padding: 0 24px; border-radius: 14px; border: none;
  font-size: 15.5px; font-weight: 700; letter-spacing: -0.01em;
  transition: transform .14s ease, filter .18s ease, background .18s ease, border-color .18s;
  white-space: nowrap;
}
.btn svg{ width: 18px; height: 18px; }
.btn:active{ transform: translateY(1px) scale(.99); }
.btn-primary{ background: var(--accent); color: var(--accent-ink); box-shadow: 0 14px 32px -12px var(--accent); }
.btn-primary:hover{ filter: brightness(1.08); }
.btn-ghost{ background: rgba(255,255,255,.06); color: var(--text); border: 1px solid var(--line-2); }
.btn-ghost:hover{ background: rgba(255,255,255,.1); }
.btn-sm{ height: 42px; padding: 0 16px; font-size: 14px; border-radius: 11px; }
.btn-lg{ height: 58px; padding: 0 30px; font-size: 17px; border-radius: 16px; }

/* ---------- Chips / badges / pills ---------- */
.chip{
  display: inline-flex; align-items: center; gap: 7px;
  height: 30px; padding: 0 13px; border-radius: 999px;
  background: rgba(255,255,255,.05); border: 1px solid var(--line);
  font-size: 12.5px; font-weight: 700; color: var(--text-2);
}
.chip svg{ width: 14px; height: 14px; }
.tag{ display:inline-flex; align-items:center; gap:6px; height:24px; padding:0 9px; border-radius:7px; font-size:11px; font-weight:800; letter-spacing:.02em; }
.pill-up{ color: var(--up); background: var(--up-bg); }
.pill-down{ color: var(--down); background: var(--down-bg); }
.live-dot{ width:8px; height:8px; border-radius:50%; background:var(--down); box-shadow:0 0 0 0 var(--down); animation:pulse 1.7s infinite; flex-shrink:0; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(255,91,124,.5);} 70%{box-shadow:0 0 0 8px rgba(255,91,124,0);} 100%{box-shadow:0 0 0 0 rgba(255,91,124,0);} }

/* ---------- Card ---------- */
.card{
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.card.pad{ padding: 28px; }
.glow-edge{ position: relative; }
.glow-edge::before{
  content:''; position:absolute; inset:-1px; border-radius: inherit; padding:1px;
  background: linear-gradient(140deg, var(--accent-2), transparent 40%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; opacity:.6; pointer-events:none;
}

/* ===========================================================================
   Navbar
   =========================================================================== */
.nav{
  position: sticky; top: 0; z-index: 100;
  backdrop-filter: blur(18px) saturate(140%); -webkit-backdrop-filter: blur(18px) saturate(140%);
  background: linear-gradient(var(--bg) 30%, rgba(10,7,24,.72));
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.nav-inner{ height: 72px; display: flex; align-items: center; gap: 28px; }
.brand{ display: inline-flex; align-items: center; gap: 11px; flex-shrink: 0; }
.brand .wordmark{ font-weight: 800; font-size: 21px; letter-spacing: -0.04em; }
.brand .wordmark b{ color: var(--accent-2); font-weight: 800; }
.nav-links{ display: flex; align-items: center; gap: 4px; margin-left: 8px; }
.nav-links a{
  position: relative; padding: 9px 14px; border-radius: 10px;
  font-size: 14.5px; font-weight: 600; color: var(--text-2);
  transition: color .15s, background .15s;
}
.nav-links a:hover{ color: var(--text); background: rgba(255,255,255,.05); }
.nav-links a.active{ color: var(--text); }
.nav-links a.active::after{
  content:''; position:absolute; left:14px; right:14px; bottom:2px; height:2px; border-radius:2px;
  background: var(--accent-2);
}
.nav-right{ margin-left: auto; display: flex; align-items: center; gap: 12px; }
.nav-toggle{ display: none; width: 44px; height: 44px; border-radius: 12px; background: rgba(255,255,255,.06); border:1px solid var(--line); color: var(--text); align-items:center; justify-content:center; }
.nav-toggle svg{ width: 22px; height: 22px; }

@media (max-width: 880px){
  .nav-links, .nav-right .btn{ display: none; }
  .nav-toggle{ display: inline-flex; }
  .nav-right{ gap: 8px; }
  .mobile-menu.open{ display: block; }
}
.mobile-menu{
  display: none; border-bottom: 1px solid var(--line); background: var(--bg-2);
}
.mobile-menu .container{ padding-top: 10px; padding-bottom: 18px; }
.mobile-menu a{ display: block; padding: 14px 6px; font-size: 17px; font-weight: 600; border-bottom: 1px solid var(--line); color: var(--text); }
.mobile-menu a:last-of-type{ border-bottom: none; }
.mobile-menu .btn{ margin-top: 14px; width: 100%; }

/* ===========================================================================
   Hero
   =========================================================================== */
.hero{ position: relative; padding: 70px 0 40px; overflow: hidden; }
.hero-grid{ position: relative; z-index: 1; display: grid; grid-template-columns: 1.08fr .92fr; gap: 56px; align-items: center; }

/* ---------- Animated hero background ---------- */
.hero-fx{ position:absolute; inset:-10% -5%; z-index:0; pointer-events:none; overflow:hidden; }
.hero-fx .orb{ position:absolute; border-radius:50%; filter: blur(70px); opacity:.4; mix-blend-mode:screen; will-change: transform; }
.hero-fx .orb.o1{ width:460px; height:460px; left:-70px; top:-90px; background: radial-gradient(circle at 30% 30%, var(--accent), transparent 65%); animation: orbDrift1 22s ease-in-out infinite; }
.hero-fx .orb.o2{ width:420px; height:420px; right:-50px; top:30px; background: radial-gradient(circle at 60% 40%, var(--accent-2), transparent 64%); opacity:.32; animation: orbDrift2 26s ease-in-out infinite; }
@keyframes orbDrift1{ 0%,100%{ transform: translate(0,0) scale(1);} 50%{ transform: translate(60px,40px) scale(1.12);} }
@keyframes orbDrift2{ 0%,100%{ transform: translate(0,0) scale(1);} 50%{ transform: translate(-50px,30px) scale(1.1);} }

@media (prefers-reduced-motion: reduce){
  .hero-fx .orb{ animation: none; }
}
.hero h1{ margin-top: 22px; }
.hero .cta-row{ display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.hero .trust-row{ display: flex; flex-wrap: wrap; align-items:center; gap: 22px 28px; margin-top: 34px; color: var(--text-3); font-size: 13.5px; font-weight: 600; }
.hero .trust-row .stat{ display:flex; flex-direction:column; gap:2px; }
.hero .trust-row .stat b{ font-family: var(--font-num); font-size: 22px; color: var(--text); font-weight: 700; letter-spacing:-.02em; }
.hero-visual{ position: relative; display: flex; justify-content: center; }
.hero-glow{ position:absolute; width: 380px; height: 380px; border-radius:50%; background: radial-gradient(circle, var(--accent), transparent 65%); filter: blur(40px); opacity:.45; top: 50%; left:50%; transform: translate(-50%,-50%); z-index:-1; }

@media (max-width: 960px){
  .hero-grid{ grid-template-columns: 1fr; gap: 40px; }
  .hero-visual{ order: -1; }
  .section{ padding: 72px 0; }
}

/* ---------- Trading players rail (sticky marquee, every page) ---------- */
.players-rail{ position:sticky; top:72px; z-index:90; overflow:hidden;
  border-bottom:1px solid var(--line);
  background: rgba(11,8,28,.78); -webkit-backdrop-filter: blur(16px) saturate(140%); backdrop-filter: blur(16px) saturate(140%); }
.players-rail::before, .players-rail::after{ content:''; position:absolute; top:0; bottom:0; width:60px; z-index:2; pointer-events:none; }
.players-rail::before{ left:0; background:linear-gradient(90deg, var(--bg), transparent); }
.players-rail::after{ right:0; background:linear-gradient(270deg, var(--bg), transparent); }
.rail-track{ display:inline-flex; align-items:center; white-space:nowrap; animation: railscroll 50s linear infinite; }
.players-rail:hover .rail-track{ animation-play-state: paused; }
@keyframes railscroll{ from{ transform: translateX(0); } to{ transform: translateX(-50%); } }
.pchip{ display:inline-flex; align-items:center; gap:9px; padding:8px 18px; border-right:1px solid var(--line); flex-shrink:0; }
.pchip .pc-img{ width:30px; height:30px; border-radius:9px; flex-shrink:0; overflow:hidden; display:block; }
.pchip .pc-name{ font-weight:800; font-size:12.5px; letter-spacing:-.01em; }
.pchip .pc-price{ font-family:var(--font-num); font-weight:700; font-size:12px; color:var(--text-2); }
.pchip .pc-chg{ font-family:var(--font-num); font-weight:800; font-size:11.5px; }
.pchip .pc-chg.up{ color:var(--up); } .pchip .pc-chg.down{ color:var(--down); }
@media (prefers-reduced-motion: reduce){ .rail-track{ animation:none; } }

/* ---------- Ticker marquee ---------- */
.ticker{
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,.02); overflow: hidden; position: relative;
}
.ticker::before, .ticker::after{
  content:''; position:absolute; top:0; bottom:0; width: 90px; z-index: 2; pointer-events:none;
}
.ticker::before{ left:0; background: linear-gradient(90deg, var(--bg), transparent); }
.ticker::after{ right:0; background: linear-gradient(270deg, var(--bg), transparent); }
.ticker-track{ display: inline-flex; align-items: center; gap: 0; white-space: nowrap; animation: ticker 46s linear infinite; }
.ticker:hover .ticker-track{ animation-play-state: paused; }
@keyframes ticker{ from{ transform: translateX(0);} to{ transform: translateX(-50%);} }
.tk{ display:inline-flex; align-items:center; gap:10px; padding: 16px 26px; border-right: 1px solid var(--line); }
.tk .tk-av{ width:26px; height:26px; border-radius:8px; display:grid; place-items:center; font-size:10px; font-weight:800; color:#fff; }
.tk .tk-name{ font-weight: 700; font-size: 14px; }
.tk .tk-price{ font-family: var(--font-num); font-weight: 700; font-size: 14px; color: var(--text-2); }
.tk .tk-chg{ font-family: var(--font-num); font-weight: 700; font-size: 13px; }
.tk .up{ color: var(--up); } .tk .down{ color: var(--down); }

/* ===========================================================================
   Device mockup (reuse of app screens, static)
   =========================================================================== */
.device{
  position: relative; width: 320px; flex-shrink: 0;
  border-radius: 42px; padding: 9px;
  background: linear-gradient(150deg, #2b2545, #100c24 55%);
  box-shadow: 0 0 0 1.5px rgba(255,255,255,.05), 0 50px 90px -28px rgba(0,0,0,.75), var(--shadow-glow);
}
.device.sm{ width: 268px; border-radius: 38px; }
.device-screen{
  position: relative; border-radius: 34px; overflow: hidden;
  background: var(--bg-2); background-image: radial-gradient(120% 80% at 50% -10%, #1C1542 0%, #0C0820 55%);
  height: 660px; display: flex; flex-direction: column;
}
.device.sm .device-screen{ height: 552px; }
.device-notch{ position:absolute; top:12px; left:50%; transform:translateX(-50%); width:96px; height:24px; border-radius:14px; background:#07040f; z-index:5; }
.dev-status{ display:flex; align-items:center; justify-content:space-between; padding:14px 22px 6px; font-size:12px; font-weight:700; color:var(--text); }
.dev-status .dots{ display:flex; gap:5px; align-items:center; }
.dev-scroll{ flex:1; overflow:hidden; padding: 6px 16px 18px; display:flex; flex-direction:column; gap:13px; }

/* app-ish components inside device */
.d-appbar{ display:flex; align-items:center; gap:10px; padding: 6px 2px 2px; }
.d-appbar .who{ flex:1; } 
.d-appbar .who .hi{ font-size:12px; color:var(--text-2); font-weight:600; }
.d-appbar .who .nm{ font-size:17px; font-weight:800; letter-spacing:-.02em; }
.d-av{ width:38px; height:38px; border-radius:12px; display:grid; place-items:center; color:#fff; font-weight:800; font-size:14px; }
.d-icon{ width:36px; height:36px; border-radius:11px; background:rgba(255,255,255,.06); border:1px solid var(--line); display:grid; place-items:center; color:var(--text-2); }
.d-icon svg{ width:18px; height:18px; }

.d-balance{ border-radius:20px; padding:16px 17px; background: linear-gradient(155deg, var(--accent), #2E2566); color:#fff; position:relative; overflow:hidden; }
.d-balance .lbl{ font-size:11.5px; font-weight:700; opacity:.8; letter-spacing:.04em; }
.d-balance .amt{ font-family:var(--font-num); font-size:30px; font-weight:700; letter-spacing:-.02em; margin-top:4px; }
.d-balance .sub{ display:flex; align-items:center; gap:8px; margin-top:8px; font-size:12.5px; font-weight:700; }
.d-balance .spark{ position:absolute; right:0; bottom:0; opacity:.55; }

.d-card{ background: rgba(255,255,255,.04); border:1px solid var(--line); border-radius:17px; padding:13px; }
.d-section-t{ display:flex; align-items:center; justify-content:space-between; padding: 2px 2px; }
.d-section-t .t{ font-size:14.5px; font-weight:800; }
.d-section-t .more{ font-size:12px; font-weight:700; color:var(--accent-2); }

.d-match{ background: linear-gradient(150deg, rgba(255,91,124,.10), rgba(91,75,214,.08)); border:1px solid var(--line); border-radius:17px; padding:13px; }
.d-match .top{ display:flex; align-items:center; gap:7px; font-size:11px; font-weight:800; color:var(--down); letter-spacing:.04em; }
.d-match .teams{ display:flex; align-items:center; justify-content:space-between; margin-top:9px; }
.d-match .team{ display:flex; align-items:center; gap:8px; font-weight:800; font-size:14px; }
.d-flag{ width:24px; height:24px; border-radius:7px; display:grid; place-items:center; font-size:11px; color:#fff; font-weight:800; }
.d-match .score{ font-family:var(--font-num); font-weight:700; font-size:15px; }

.d-row{ display:flex; align-items:center; gap:11px; padding:9px 4px; }
.d-row .nm{ flex:1; }
.d-row .nm .a{ font-weight:800; font-size:13.5px; }
.d-row .nm .b{ font-size:11px; color:var(--text-3); font-weight:700; margin-top:2px; }
.d-row .pr{ text-align:right; }
.d-row .pr .a{ font-family:var(--font-num); font-weight:700; font-size:13.5px; }
.d-row .pr .b{ font-family:var(--font-num); font-weight:700; font-size:11.5px; }

/* ===========================================================================
   Feature / content blocks
   =========================================================================== */
.grid{ display: grid; gap: 20px; }
.grid-2{ grid-template-columns: repeat(2, 1fr); }
.grid-3{ grid-template-columns: repeat(3, 1fr); }
.grid-4{ grid-template-columns: repeat(4, 1fr); }
@media (max-width: 960px){ .grid-3, .grid-4{ grid-template-columns: repeat(2,1fr);} }
@media (max-width: 640px){ .grid-2, .grid-3, .grid-4{ grid-template-columns: 1fr;} }

.feature-card{ padding: 26px; border-radius: 20px; background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)); border: 1px solid var(--line); transition: transform .2s ease, border-color .2s ease, background .2s; }
.feature-card:hover{ transform: translateY(-4px); border-color: var(--line-2); background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); }
.f-ico{ width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; margin-bottom: 18px; color: #fff; }
.f-ico svg{ width: 24px; height: 24px; }
.feature-card h4{ font-size: 19px; letter-spacing: -0.02em; }
.feature-card p{ margin: 9px 0 0; color: var(--text-2); font-size: 14.5px; line-height: 1.55; }

/* horizon cards */
.hz-card{ position: relative; padding: 24px; border-radius: 20px; background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)); border: 1px solid var(--line); overflow:hidden; transition: transform .2s, border-color .2s; }
.hz-card:hover{ transform: translateY(-4px); }
.hz-card .bar{ position:absolute; left:0; top:0; bottom:0; width:4px; }
.hz-card .ic{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; color:#fff; margin-bottom:16px; }
.hz-card .ic svg{ width:22px; height:22px; }
.hz-card h4{ font-size:18px; display:flex; align-items:center; gap:9px; }
.hz-card .when{ font-family:var(--font-num); font-size:12px; font-weight:700; padding:3px 9px; border-radius:7px; }
.hz-card p{ margin:10px 0 0; color:var(--text-2); font-size:14px; line-height:1.55; }

/* alternating feature row */
.feat-row{ display:grid; grid-template-columns: 1fr 1fr; gap:56px; align-items:center; }
.feat-row + .feat-row{ margin-top: 96px; }
.feat-row.rev .feat-media{ order: 2; }
@media (max-width: 880px){ .feat-row{ grid-template-columns:1fr; gap:36px; } .feat-row.rev .feat-media{ order: 0; } }
.feat-media{ display:flex; justify-content:center; }
.feat-list{ list-style:none; padding:0; margin:22px 0 0; display:flex; flex-direction:column; gap:13px; }
.feat-list li{ display:flex; gap:12px; align-items:flex-start; font-size:15px; color:var(--text-2); line-height:1.5; }
.feat-list li svg{ width:20px; height:20px; flex-shrink:0; margin-top:1px; color: var(--up); }

/* visual panel (used for charts/diagrams inside feature media) */
.panel{ width:100%; max-width:480px; border-radius:24px; border:1px solid var(--line); background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.012)); box-shadow: var(--shadow); padding:22px; }
.panel-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.panel-title{ font-size:14px; font-weight:800; }

/* ===========================================================================
   Stats band
   =========================================================================== */
.stats-band{ display:grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--line); border:1px solid var(--line); border-radius: 22px; overflow:hidden; }
@media (max-width:640px){ .stats-band{ grid-template-columns: repeat(2,1fr);} }
.stat-cell{ background: var(--bg); padding: 30px 26px; }
.stat-cell .v{ font-family: var(--font-num); font-size: clamp(30px,3.6vw,42px); font-weight: 700; letter-spacing:-.03em; background: linear-gradient(120deg, var(--accent-2), #e7e2ff); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat-cell .k{ margin-top: 6px; color: var(--text-2); font-size: 13.5px; font-weight: 600; }

/* ===========================================================================
   Engine page diagrams
   =========================================================================== */
.orderbook{ font-family: var(--font-num); }
.ob-head{ display:grid; grid-template-columns: 1fr 1fr 1fr; font-size:11px; font-weight:700; color:var(--text-3); letter-spacing:.04em; padding: 0 4px 8px; text-transform:uppercase; }
.ob-row{ position:relative; display:grid; grid-template-columns: 1fr 1fr 1fr; align-items:center; padding: 7px 8px; border-radius:7px; font-size:13.5px; font-weight:700; }
.ob-row .depth{ position:absolute; top:2px; bottom:2px; border-radius:6px; z-index:0; }
.ob-row span{ position:relative; z-index:1; }
.ob-row .px{ font-weight:800; }
.ob-ask .depth{ right:0; background: var(--down-bg); }
.ob-ask .px{ color: var(--down); }
.ob-bid .depth{ left:0; background: var(--up-bg); }
.ob-bid .px{ color: var(--up); }
.ob-mid{ display:flex; align-items:center; justify-content:space-between; padding:11px 10px; margin:7px 0; border-radius:9px; background: rgba(255,255,255,.05); border:1px dashed var(--line-2); }
.ob-mid .lp{ font-size:18px; font-weight:800; }
.ob-mid .sp{ font-size:11.5px; color:var(--text-3); font-weight:700; }

/* flow diagram (matching / price formation) */
.flow{ display:flex; align-items:stretch; gap:14px; flex-wrap:wrap; }
.flow-node{ flex:1; min-width: 150px; border-radius:16px; border:1px solid var(--line); background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.01)); padding:18px; position:relative; }
.flow-node .n-ic{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center; color:#fff; margin-bottom:12px; }
.flow-node .n-ic svg{ width:20px;height:20px; }
.flow-node h5{ margin:0; font-size:15px; font-weight:800; }
.flow-node p{ margin:6px 0 0; font-size:13px; color:var(--text-2); line-height:1.5; }
.flow-arrow{ display:grid; place-items:center; color:var(--text-3); flex:0 0 24px; }
.flow-arrow svg{ width:22px; height:22px; }
@media (max-width:760px){ .flow{ flex-direction:column; } .flow-arrow{ transform: rotate(90deg); } }

/* step list */
.steps{ counter-reset: s; display:flex; flex-direction:column; gap:18px; }
.step{ display:flex; gap:18px; align-items:flex-start; }
.step .n{ counter-increment:s; flex:0 0 44px; width:44px; height:44px; border-radius:13px; display:grid; place-items:center; font-family:var(--font-num); font-weight:700; font-size:18px; color:#fff; background:linear-gradient(150deg,var(--accent),var(--accent-2)); }
.step .n::before{ content:counter(s); }
.step h4{ font-size:18px; }
.step p{ margin:7px 0 0; color:var(--text-2); font-size:14.5px; line-height:1.55; }

/* ===========================================================================
   Testimonials
   =========================================================================== */
.quote-card{ padding: 26px; border-radius: 20px; background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.012)); border:1px solid var(--line); display:flex; flex-direction:column; gap:18px; }
.quote-card p{ margin:0; font-size:16px; line-height:1.6; color: var(--text); }
.quote-card .by{ display:flex; align-items:center; gap:12px; }
.quote-card .by .av{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; color:#fff; font-weight:800; }
.quote-card .by .nm{ font-weight:800; font-size:14px; }
.quote-card .by .hd{ font-size:12.5px; color:var(--text-3); font-weight:600; }
.stars{ display:flex; gap:3px; color: var(--warn); }
.stars svg{ width:16px; height:16px; }

/* ===========================================================================
   Trust / safety
   =========================================================================== */
.trust-item{ display:flex; gap:15px; align-items:flex-start; padding: 20px; border-radius:18px; border:1px solid var(--line); background: rgba(255,255,255,.02); }
.trust-item .ti-ic{ width:44px; height:44px; flex-shrink:0; border-radius:12px; display:grid; place-items:center; background: rgba(91,75,214,.16); color: var(--accent-2); }
.trust-item .ti-ic svg{ width:22px; height:22px; }
.trust-item h4{ font-size:16px; }
.trust-item p{ margin:6px 0 0; font-size:13.5px; color:var(--text-2); line-height:1.5; }

/* ===========================================================================
   Social contribution / give-back
   =========================================================================== */
.give{ position:relative; overflow:hidden; border-radius:32px; border:1px solid var(--line-2);
  background: linear-gradient(150deg, rgba(31,170,110,.16), rgba(91,75,214,.12) 55%, rgba(255,255,255,.02));
  padding: 52px; }
.give::after{ content:''; position:absolute; width:380px; height:380px; border-radius:50%;
  background: radial-gradient(circle, var(--up), transparent 65%); filter: blur(60px); opacity:.18; top:-160px; right:-80px; }
.give-grid{ position:relative; z-index:1; display:grid; grid-template-columns: 1fr 1fr; gap:48px; align-items:center; }
@media (max-width:880px){ .give{ padding:34px; } .give-grid{ grid-template-columns:1fr; gap:32px; } }
.give-badge{ display:inline-flex; align-items:baseline; gap:10px; margin-top:18px; }
.give-badge .pct{ font-family:var(--font-num); font-size:clamp(48px,7vw,76px); font-weight:700; letter-spacing:-.04em;
  background: linear-gradient(120deg, var(--up), #9af5cf); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:.9; }
.give-badge .of{ font-size:16px; font-weight:700; color:var(--text-2); }
.sport-grid{ display:grid; grid-template-columns: repeat(2,1fr); gap:14px; }
.sport-card{ padding:20px; border-radius:18px; border:1px solid var(--line); background: rgba(255,255,255,.035);
  display:flex; flex-direction:column; gap:12px; transition: transform .2s, border-color .2s; }
.sport-card:hover{ transform: translateY(-4px); border-color: var(--line-2); }
.sport-card .s-ic{ width:48px; height:48px; border-radius:14px; display:grid; place-items:center; color:#fff; }
.sport-card .s-ic svg{ width:26px; height:26px; }
.sport-card .s-name{ font-weight:800; font-size:15.5px; }
.sport-card .s-sub{ font-size:12.5px; color:var(--text-3); font-weight:700; }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; overflow:hidden; border-radius:32px; padding: 56px; text-align:center; border:1px solid var(--line-2); background: linear-gradient(150deg, rgba(91,75,214,.22), rgba(124,77,224,.10) 60%, rgba(255,255,255,.02)); }
.cta-band::after{ content:''; position:absolute; width:420px; height:420px; border-radius:50%; background: radial-gradient(circle, var(--accent), transparent 65%); filter: blur(50px); opacity:.3; top:-180px; left:50%; transform:translateX(-50%); }
.cta-band .inner{ position:relative; z-index:1; max-width: 620px; margin:0 auto; }
.store-row{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:28px; }
.store-btn{ display:inline-flex; align-items:center; gap:12px; height:58px; padding:0 22px; border-radius:15px; background:#fff; color:#0A0718; }
.store-btn svg{ width:26px; height:26px; }
.store-btn .st-s{ font-size:11px; font-weight:700; opacity:.7; line-height:1; }
.store-btn .st-b{ font-size:17px; font-weight:800; line-height:1.1; letter-spacing:-.02em; }

/* ===========================================================================
   Contact
   =========================================================================== */
.cat-card{ padding:22px; border-radius:18px; border:1px solid var(--line); background: rgba(255,255,255,.025); transition: border-color .2s, transform .2s; }
.cat-card:hover{ transform: translateY(-3px); border-color: var(--line-2); }
.cat-card .c-ic{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; color:#fff; margin-bottom:14px; }
.cat-card .c-ic svg{ width:22px; height:22px; }
.cat-card h4{ font-size:17px; }
.cat-card p{ margin:7px 0 12px; font-size:13.5px; color:var(--text-2); line-height:1.5; }
.cat-card a.lk{ font-size:13.5px; font-weight:700; color:var(--accent-2); display:inline-flex; align-items:center; gap:5px; }
.cat-card a.lk svg{ width:15px; height:15px; }

.form-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:16px; }
@media (max-width:640px){ .form-grid{ grid-template-columns:1fr; } }
.field-l{ display:flex; flex-direction:column; gap:8px; }
.field-l.full{ grid-column: 1 / -1; }
.field-l label{ font-size:12.5px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--text-3); }
.input, .textarea, .select{
  width:100%; background: rgba(255,255,255,.04); border:1.5px solid var(--line);
  border-radius:13px; padding:14px 15px; color:var(--text); font-size:15px; font-family:inherit; font-weight:500;
  outline:none; transition: border-color .15s, background .15s;
}
.input::placeholder, .textarea::placeholder{ color: var(--text-3); }
.input:focus, .textarea:focus, .select:focus{ border-color: var(--accent-2); background: rgba(255,255,255,.06); }
.textarea{ min-height:140px; resize:vertical; line-height:1.5; }
.select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23756E9C' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position: right 14px center; padding-right:40px; }

/* map placeholder */
.map{ position:relative; border-radius:20px; overflow:hidden; border:1px solid var(--line); height:100%; min-height:280px; background:
  radial-gradient(80% 60% at 70% 30%, rgba(91,75,214,.18), transparent 60%),
  repeating-linear-gradient(0deg, rgba(255,255,255,.04) 0 1px, transparent 1px 46px),
  repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px 46px),
  var(--panel); }
.map .pin{ position:absolute; top:46%; left:60%; transform:translate(-50%,-100%); color:var(--accent-2); }
.map .pin svg{ width:40px; height:40px; filter: drop-shadow(0 8px 14px rgba(0,0,0,.5)); }
.map .addr{ position:absolute; left:18px; bottom:18px; right:18px; background: rgba(10,7,24,.82); backdrop-filter:blur(8px); border:1px solid var(--line); border-radius:14px; padding:14px 16px; }
.map .addr .t{ font-weight:800; font-size:14px; }
.map .addr .d{ font-size:13px; color:var(--text-2); margin-top:3px; line-height:1.45; }

/* FAQ accordion */
.faq{ border:1px solid var(--line); border-radius:18px; overflow:hidden; background: rgba(255,255,255,.02); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item:last-child{ border-bottom:none; }
.faq-q{ width:100%; text-align:left; background:none; border:none; color:var(--text); padding:20px 22px; display:flex; align-items:center; justify-content:space-between; gap:16px; font-size:16px; font-weight:700; }
.faq-q .ico{ flex-shrink:0; width:26px; height:26px; border-radius:8px; background:rgba(255,255,255,.05); display:grid; place-items:center; transition:transform .25s, background .2s; color:var(--accent-2); }
.faq-q .ico svg{ width:16px; height:16px; }
.faq-item.open .faq-q .ico{ transform: rotate(45deg); background: var(--accent); color:#fff; }
.faq-a{ max-height:0; overflow:hidden; transition: max-height .3s ease; }
.faq-a .inner{ padding: 0 22px 22px; color: var(--text-2); font-size: 14.5px; line-height:1.6; }

.social-row{ display:flex; gap:12px; flex-wrap:wrap; }
.social-btn{ width:48px; height:48px; border-radius:13px; border:1px solid var(--line); background: rgba(255,255,255,.03); display:grid; place-items:center; color:var(--text-2); transition: all .18s; }
.social-btn:hover{ color:#fff; border-color: var(--accent); background: rgba(91,75,214,.16); transform: translateY(-2px); }
.social-btn svg{ width:21px; height:21px; }

/* ===========================================================================
   Footer
   =========================================================================== */
.footer{ border-top:1px solid var(--line); margin-top: 40px; padding: 64px 0 36px; background: linear-gradient(180deg, transparent, rgba(91,75,214,.05)); }
.footer-grid{ display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap:40px; }
@media (max-width:880px){ .footer-grid{ grid-template-columns: 1fr 1fr; gap:32px; } }
@media (max-width:480px){ .footer-grid{ grid-template-columns: 1fr 1fr; } }
.footer .f-about{ max-width:300px; }
.footer .f-about p{ color:var(--text-2); font-size:14px; line-height:1.6; margin:16px 0 0; }
.footer h5{ font-size:12px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); margin:0 0 16px; }
.footer .f-links{ display:flex; flex-direction:column; gap:11px; }
.footer .f-links a{ color:var(--text-2); font-size:14px; font-weight:500; transition:color .15s; }
.footer .f-links a:hover{ color:var(--text); }
.footer-disc{ margin-top:48px; padding-top:26px; border-top:1px solid var(--line); display:flex; flex-wrap:wrap; gap:18px; align-items:center; justify-content:space-between; }
.footer-disc .age{ display:inline-flex; align-items:center; gap:9px; }
.age-badge{ width:38px; height:38px; border-radius:10px; border:2px solid var(--down); color:var(--down); display:grid; place-items:center; font-weight:800; font-family:var(--font-num); font-size:13px; flex-shrink:0; }
.footer-disc p{ margin:0; font-size:12.5px; color:var(--text-3); line-height:1.5; max-width: 720px; }
.footer-copy{ margin-top:24px; font-size:13px; color:var(--text-3); display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; }

.risk-strip{ background: rgba(255,91,124,.06); border:1px solid rgba(255,91,124,.18); border-radius:14px; padding:14px 18px; display:flex; gap:12px; align-items:flex-start; }
.risk-strip svg{ width:20px; height:20px; color:var(--down); flex-shrink:0; margin-top:1px; }
.risk-strip p{ margin:0; font-size:13px; color:var(--text-2); line-height:1.55; }
.risk-strip b{ color: var(--text); }

/* ===========================================================================
   Reveal on scroll
   =========================================================================== */
.reveal{ opacity:0; transform: translateY(22px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.06s; } .reveal.d2{ transition-delay:.12s; } .reveal.d3{ transition-delay:.18s; } .reveal.d4{ transition-delay:.24s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } .ticker-track{ animation:none; } }

/* ===========================================================================
   Tweaks panel (vanilla)
   =========================================================================== */
.twk{ position: fixed; right:18px; bottom:18px; z-index: 2147483646; width: 264px;
  background: rgba(20,16,44,.86); -webkit-backdrop-filter: blur(22px) saturate(150%); backdrop-filter: blur(22px) saturate(150%);
  border:1px solid var(--line-2); border-radius:16px; box-shadow: 0 20px 50px rgba(0,0,0,.5);
  color: var(--text); font-size:12.5px; overflow:hidden; display:none; }
.twk.show{ display:block; }
.twk-hd{ display:flex; align-items:center; justify-content:space-between; padding:13px 14px; border-bottom:1px solid var(--line); cursor:move; }
.twk-hd .t{ font-weight:800; font-size:13px; letter-spacing:-.01em; display:flex; align-items:center; gap:8px; }
.twk-hd .t svg{ width:15px; height:15px; color:var(--accent-2); }
.twk-x{ width:26px; height:26px; border-radius:8px; background:rgba(255,255,255,.06); border:none; color:var(--text-2); display:grid; place-items:center; }
.twk-x svg{ width:15px; height:15px; }
.twk-body{ padding:14px; display:flex; flex-direction:column; gap:16px; }
.twk-grp .lab{ font-size:11px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--text-3); margin-bottom:9px; }
.twk-chips{ display:flex; gap:9px; }
.twk-chip{ width:34px; height:34px; border-radius:10px; border:2px solid transparent; display:grid; place-items:center; position:relative; transition: transform .12s; }
.twk-chip:hover{ transform: scale(1.08); }
.twk-chip[data-on="1"]{ border-color:#fff; }
.twk-chip svg{ width:15px; height:15px; }
.twk-seg{ display:flex; gap:5px; background: rgba(255,255,255,.05); padding:5px; border-radius:12px; }
.twk-seg button{ flex:1; height:34px; border-radius:9px; border:none; background:transparent; color:var(--text-2); font-weight:700; font-size:12.5px; font-family:inherit; transition: all .15s; }
.twk-seg button[data-on="1"]{ background: var(--accent); color:#fff; }
