/* ======================================================================
   OKTOMBO COCKPIT — Design System (light transposition)
   Tokens per Contract §7.1 · honesty-as-a-feature
   ====================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;450;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  /* surfaces */
  --bg:#F1F4F8;
  --bg-grid:rgba(11,14,20,0.022);
  --surface:#FFFFFF;
  --surface-2:#F9FAFC;
  --sunken:#EDF0F5;
  --rail:#FFFFFF;

  /* ink */
  --ink:#0B0E14;
  --ink-2:#39414F;
  --ink-3:#69707E;
  --ink-4:#9DA3B0;
  --ink-5:#BCC1CC;

  /* lines */
  --line:rgba(11,14,20,0.075);
  --line-2:rgba(11,14,20,0.13);
  --line-3:rgba(11,14,20,0.20);

  /* status tokens (R3 + organ states) */
  --built:#0E9D6B;        --built-bg:rgba(14,157,107,0.10);  --built-line:rgba(14,157,107,0.30);
  --stub:#B57407;         --stub-bg:rgba(214,150,20,0.12);   --stub-line:rgba(214,150,20,0.34);
  --planned:#6D54E8;      --planned-bg:rgba(109,84,232,0.10); --planned-line:rgba(109,84,232,0.28);
  --running:#0791C2;      --running-bg:rgba(8,150,200,0.10);  --running-line:rgba(8,150,200,0.30);
  --gated:#5C6471;        --gated-bg:rgba(92,100,113,0.09);   --gated-line:rgba(92,100,113,0.26);
  --danger:#CF3D3D;       --danger-bg:rgba(207,61,61,0.10);   --danger-line:rgba(207,61,61,0.30);
  --afferent:#2E8FF0;     --efferent:#10B3A3;

  /* brand gradient — used ONLY as accent (spine core, logo, trust anchor edge) */
  --grad:linear-gradient(110deg,#0DA886 0%,#2E97F7 36%,#7B5BF5 66%,#D8348A 100%);
  --grad-soft:linear-gradient(110deg,rgba(13,168,134,.16),rgba(46,151,247,.16),rgba(123,91,245,.16),rgba(216,52,138,.14));

  /* type */
  --display:'Space Grotesk',sans-serif;
  --body:'Inter',sans-serif;
  --mono:'JetBrains Mono',monospace;

  /* radii + shadow */
  --r-sm:8px; --r:12px; --r-lg:16px; --r-xl:22px;
  --sh-1:0 1px 2px rgba(11,14,20,.05), 0 1px 1px rgba(11,14,20,.03);
  --sh-2:0 2px 4px rgba(11,14,20,.04), 0 8px 22px rgba(11,14,20,.07);
  --sh-3:0 18px 50px rgba(11,14,20,.16), 0 4px 12px rgba(11,14,20,.08);

  --rail-w:78px;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; height:100%; }
body{
  font-family:var(--body);
  background:var(--bg);
  background-image:
    linear-gradient(var(--bg-grid) 1px,transparent 1px),
    linear-gradient(90deg,var(--bg-grid) 1px,transparent 1px);
  background-size:34px 34px;
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-size:14px;
}
::selection{ background:rgba(46,151,247,.18); }
button{ font-family:inherit; cursor:pointer; }
::-webkit-scrollbar{ width:11px; height:11px; }
::-webkit-scrollbar-thumb{ background:rgba(11,14,20,.16); border-radius:99px; border:3px solid transparent; background-clip:content-box; }
::-webkit-scrollbar-thumb:hover{ background:rgba(11,14,20,.28); background-clip:content-box; }

.mono{ font-family:var(--mono); font-variant-numeric:tabular-nums; }
.disp{ font-family:var(--display); }
.grad-text{ background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; }

/* ===================== APP SHELL ===================== */
.app{ display:grid; grid-template-columns:var(--rail-w) 1fr; height:100vh; overflow:hidden; }

.rail{
  background:var(--rail);
  border-right:1px solid var(--line);
  display:flex; flex-direction:column; align-items:center;
  padding:18px 0 16px; gap:6px; z-index:30;
}
.rail__logo{ width:40px; height:40px; object-fit:contain; margin-bottom:18px; filter:drop-shadow(0 4px 12px rgba(123,91,245,.18)); }
.rail-item{
  width:54px; padding:11px 0 9px; border:0; background:transparent; border-radius:var(--r);
  display:flex; flex-direction:column; align-items:center; gap:5px;
  color:var(--ink-4); position:relative; transition:.16s;
}
.rail-item svg{ width:21px; height:21px; stroke-width:1.7; }
.rail-item span{ font-size:9.5px; font-weight:600; letter-spacing:.04em; font-family:var(--body); }
.rail-item:hover{ color:var(--ink-2); background:var(--sunken); }
.rail-item.active{ color:var(--ink); }
.rail-item.active::before{
  content:""; position:absolute; left:-12px; top:50%; transform:translateY(-50%);
  width:3px; height:24px; border-radius:99px; background:var(--grad);
}
.rail-item.active{ background:var(--grad-soft); }
.rail__spacer{ margin-top:auto; }
.rail-item--sm span{ display:none; }

.main{ display:flex; flex-direction:column; overflow:hidden; position:relative; }

/* ===================== TOPBAR ===================== */
.topbar{
  height:58px; flex:0 0 58px; background:rgba(255,255,255,.86); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line); display:flex; align-items:center; gap:18px;
  padding:0 26px; z-index:20;
}
.topbar__title{ font-family:var(--display); font-weight:600; font-size:17px; letter-spacing:-.01em; }
.topbar__crumb{ font-family:var(--mono); font-size:11px; color:var(--ink-4); letter-spacing:.12em; text-transform:uppercase; }
.topbar__spacer{ margin-left:auto; }
.topbar__clock{ font-family:var(--mono); font-size:12px; color:var(--ink-3); }
.acct-pill{
  display:flex; align-items:center; gap:8px; padding:6px 13px; border:1px solid var(--line-2);
  border-radius:99px; font-size:12px; font-weight:600; color:var(--ink-2); background:var(--surface);
}
.acct-pill i{ width:7px; height:7px; border-radius:50%; background:var(--stub); box-shadow:0 0 0 3px var(--stub-bg); }

/* ===================== EDGE-STATE BANNER (trust anchor) ===================== */
.edge-banner{
  flex:0 0 auto; margin:16px 26px 0; border-radius:var(--r-lg);
  background:linear-gradient(180deg,#fff, #FCFBF6);
  border:1px solid var(--stub-line); box-shadow:var(--sh-1);
  display:flex; align-items:stretch; overflow:hidden; position:relative;
}
.edge-banner::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--grad); }
.edge-banner__lead{ padding:15px 22px 15px 26px; display:flex; flex-direction:column; gap:3px; border-right:1px solid var(--line); min-width:250px; }
.edge-banner__k{ font-family:var(--mono); font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--ink-4); }
.edge-banner__state{ font-family:var(--display); font-weight:700; font-size:21px; letter-spacing:-.01em; display:flex; align-items:center; gap:11px; }
.edge-banner__state .no{ color:var(--stub); }
.edge-banner__dot{ width:9px; height:9px; border-radius:50%; background:var(--stub); box-shadow:0 0 0 4px var(--stub-bg); }
.edge-banner__metrics{ display:flex; flex:1; align-items:center; }
.edge-banner__m{ padding:0 24px; display:flex; flex-direction:column; gap:4px; border-right:1px solid var(--line); }
.edge-banner__m:last-child{ border-right:0; }
.edge-banner__m .lbl{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); }
.edge-banner__m .val{ font-family:var(--mono); font-size:16px; font-weight:600; color:var(--ink); }
.edge-banner__note{ margin-left:auto; padding:0 24px; max-width:280px; font-size:11.5px; line-height:1.4; color:var(--ink-3); align-self:center; }

/* ===================== VIEW / SCROLL ===================== */
.scroll{ flex:1; overflow-y:auto; overflow-x:hidden; }
.view{ padding:22px 26px 60px; max-width:1640px; margin:0 auto; }
.view__head{ display:flex; align-items:flex-end; gap:16px; margin-bottom:18px; }
.view__head h1{ font-family:var(--display); font-weight:600; font-size:25px; letter-spacing:-.02em; margin:0; }
.view__head p{ margin:0; font-size:13px; color:var(--ink-3); }
.view__kick{ font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-4); margin:0 0 5px; }

/* ===================== GRID ===================== */
.grid{ display:grid; gap:16px; }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }
.span-2{ grid-column:span 2; }
.span-3{ grid-column:span 3; }

/* ===================== CARD ===================== */
.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-1); display:flex; flex-direction:column; overflow:hidden; }
.card__head{ display:flex; align-items:center; gap:11px; padding:15px 18px 13px; border-bottom:1px solid var(--line); }
.card__head h3{ font-family:var(--display); font-weight:600; font-size:14.5px; letter-spacing:-.005em; margin:0; }
.card__head .sub{ font-size:11px; color:var(--ink-4); font-family:var(--mono); }
.card__head .right{ margin-left:auto; display:flex; align-items:center; gap:8px; }
.card__body{ padding:18px; }
.card__body--flush{ padding:0; }

/* ===================== BADGES (R3 / state — designed first class) ===================== */
.badge{
  display:inline-flex; align-items:center; gap:6px; height:21px; padding:0 9px;
  border-radius:99px; font-family:var(--mono); font-size:10px; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase; white-space:nowrap; border:1px solid transparent;
}
.badge i{ width:6px; height:6px; border-radius:50%; flex:0 0 auto; }
.badge--real{ color:var(--built); background:var(--built-bg); border-color:var(--built-line); }
.badge--real i{ background:var(--built); }
.badge--stub{ color:var(--stub); background:var(--stub-bg); border-color:var(--stub-line); }
.badge--stub i{ background:var(--stub); }
.badge--approx{ color:var(--running); background:var(--running-bg); border-color:var(--running-line); }
.badge--approx i{ background:var(--running); }
.badge--planned{ color:var(--planned); background:var(--planned-bg); border-color:var(--planned-line); }
.badge--planned i{ background:var(--planned); }
.badge--gated{ color:var(--gated); background:var(--gated-bg); border-color:var(--gated-line); }
.badge--gated i{ background:var(--gated); }
.badge--danger{ color:var(--danger); background:var(--danger-bg); border-color:var(--danger-line); }
.badge--danger i{ background:var(--danger); }

.tag{ font-family:var(--mono); font-size:10.5px; color:var(--ink-3); background:var(--sunken); border:1px solid var(--line); padding:2px 8px; border-radius:6px; letter-spacing:.02em; }

/* ===================== KPI ===================== */
.kpi{ display:flex; flex-direction:column; gap:9px; }
.kpi__label{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-4); display:flex; align-items:center; gap:8px; }
.kpi__val{ font-family:var(--display); font-weight:700; font-size:38px; letter-spacing:-.03em; line-height:.95; }
.kpi__val.is-stub{ color:var(--ink-2); }
.kpi__val small{ font-size:.5em; font-weight:500; color:var(--ink-4); margin-left:3px; }
.kpi__sub{ font-family:var(--mono); font-size:11px; color:var(--ink-4); }

/* neutral (R3): stub PnL must NOT read as green=win */
.num-neutral{ color:var(--ink-2); }
.num-stub{ color:var(--stub); }

/* ===================== PROGRESS / GAUGE ===================== */
.prog{ height:8px; border-radius:99px; background:var(--sunken); overflow:hidden; position:relative; }
.prog__bar{ height:100%; border-radius:99px; background:var(--grad); }
.prog__bar--built{ background:var(--built); }
.prog__bar--stub{ background:var(--stub); }
.prog__bar--running{ background:var(--running); }
.prog-row{ display:flex; justify-content:space-between; font-family:var(--mono); font-size:11px; color:var(--ink-3); margin-bottom:7px; }
.prog-row b{ color:var(--ink); font-weight:600; }

.gauge{ display:flex; flex-direction:column; gap:8px; }
.gauge__top{ display:flex; justify-content:space-between; align-items:baseline; }
.gauge__name{ font-size:12.5px; font-weight:600; color:var(--ink-2); }
.gauge__val{ font-family:var(--mono); font-size:12px; color:var(--ink-3); }

/* ===================== TABLE ===================== */
.tbl{ width:100%; border-collapse:collapse; font-size:12.5px; }
.tbl th{ text-align:left; font-family:var(--mono); font-size:10px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); padding:11px 14px; border-bottom:1px solid var(--line); position:sticky; top:0; background:var(--surface); z-index:2; }
.tbl td{ padding:11px 14px; border-bottom:1px solid var(--line); color:var(--ink-2); }
.tbl tr:last-child td{ border-bottom:0; }
.tbl tbody tr{ transition:background .12s; }
.tbl tbody tr:hover{ background:var(--surface-2); }
.tbl .mono{ color:var(--ink); }

/* ===================== FIREHOSE LIST ===================== */
.fh-bar{ display:flex; align-items:center; gap:10px; padding:11px 16px; border-bottom:1px solid var(--line); background:var(--surface-2); position:sticky; top:0; z-index:3; flex-wrap:wrap; }
.fh-chip{ font-family:var(--mono); font-size:11px; padding:5px 11px; border-radius:99px; border:1px solid var(--line-2); background:var(--surface); color:var(--ink-3); }
.fh-chip.on{ color:var(--ink); border-color:var(--ink-3); background:var(--sunken); }
.fh-scroll{ max-height:520px; overflow-y:auto; }
.trow{ display:grid; grid-template-columns:96px 64px 52px 1fr 110px 96px; align-items:center; gap:12px; padding:0 16px; height:48px; border-bottom:1px solid var(--line); cursor:pointer; transition:background .1s; }
.trow:hover{ background:var(--surface-2); }
.trow__coin{ font-family:var(--display); font-weight:600; font-size:13.5px; display:flex; align-items:center; gap:8px; }
.trow__coin .dot{ width:7px; height:7px; border-radius:50%; background:var(--built); }
.trow__side{ font-family:var(--mono); font-size:10.5px; font-weight:600; color:var(--afferent); }
.trow__h{ font-family:var(--mono); font-size:11px; color:var(--ink-4); }
.trow__mtm{ font-family:var(--mono); font-size:12px; }
.trow__mat{ display:flex; flex-direction:column; gap:4px; }
.trow__mat .pbar{ height:4px; border-radius:99px; background:var(--sunken); overflow:hidden; }
.trow__mat .pbar i{ display:block; height:100%; background:var(--running); border-radius:99px; }
.trow__mat .t{ font-family:var(--mono); font-size:10px; color:var(--ink-4); }
.spark{ display:block; }

/* ===================== FUNNEL ===================== */
.funnel{ display:flex; flex-direction:column; gap:9px; }
.funnel__row{ display:flex; align-items:center; gap:12px; }
.funnel__bar{ height:34px; border-radius:8px; display:flex; align-items:center; padding:0 13px; font-family:var(--mono); font-size:12px; font-weight:600; color:#fff; min-width:54px; }
.funnel__lbl{ font-size:12px; color:var(--ink-2); flex:1; }
.funnel__n{ font-family:var(--mono); font-size:13px; font-weight:600; color:var(--ink); }

/* ===================== PIPELINE PULSE ===================== */
.pulse{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.pulse__cell{ border:1px solid var(--line); border-radius:var(--r); padding:12px 13px; background:var(--surface-2); display:flex; flex-direction:column; gap:9px; }
.pulse__name{ font-family:var(--mono); font-size:11px; color:var(--ink-2); display:flex; align-items:center; justify-content:space-between; }
.pulse__name b{ font-weight:600; }
.pulse__bars{ display:flex; align-items:flex-end; gap:2px; height:30px; }
.pulse__bars i{ flex:1; background:var(--running-bg); border-radius:2px 2px 0 0; min-height:2px; }
.pulse__bars i.hot{ background:var(--running); }
.pulse__thru{ font-family:var(--mono); font-size:10px; color:var(--ink-4); }

/* ===================== SPINE ===================== */
.spine-wrap{ display:grid; grid-template-columns:1fr 380px; gap:16px; align-items:start; }
.spine-stage{ background:
    radial-gradient(120% 90% at 50% -10%, rgba(46,151,247,.05), transparent 60%),
    var(--surface);
  border:1px solid var(--line); border-radius:var(--r-xl); box-shadow:var(--sh-1); padding:8px; position:relative; overflow:hidden; }
.spine-stage svg{ width:100%; height:auto; display:block; }
.organ-node{ cursor:pointer; }
.organ-node .body{ transition:.18s; }
.organ-node:hover .body{ filter:brightness(1.04); }
.organ-detail{ position:sticky; top:0; }

.legend{ display:flex; flex-wrap:wrap; gap:8px 16px; padding:13px 16px; }
.legend span{ display:flex; align-items:center; gap:7px; font-size:11px; color:var(--ink-3); font-family:var(--mono); }
.legend i{ width:18px; height:3px; border-radius:2px; }

/* ===================== TRADE CARD (großes Kino) ===================== */
.sheet{ position:fixed; inset:0; z-index:120; display:flex; justify-content:flex-end; }
.sheet__scrim{ position:absolute; inset:0; background:rgba(11,14,20,.34); backdrop-filter:blur(3px); opacity:0; transition:.24s; }
.sheet.open .sheet__scrim{ opacity:1; }
.sheet__panel{
  position:relative; width:min(720px,94vw); height:100%; background:var(--bg);
  box-shadow:var(--sh-3); overflow-y:auto; transform:translateX(40px); opacity:0; transition:.28s cubic-bezier(.2,.7,.2,1);
}
.sheet.open .sheet__panel{ transform:none; opacity:1; }
.tc-hero{ padding:24px 28px 22px; background:var(--surface); border-bottom:1px solid var(--line); position:sticky; top:0; z-index:5; }
.tc-close{ position:absolute; right:20px; top:20px; width:34px; height:34px; border-radius:9px; border:1px solid var(--line-2); background:var(--surface); color:var(--ink-3); display:flex; align-items:center; justify-content:center; }
.tc-close:hover{ background:var(--sunken); color:var(--ink); }
.tc-coin{ font-family:var(--display); font-weight:700; font-size:30px; letter-spacing:-.02em; display:flex; align-items:center; gap:12px; }
.tc-why{ margin:8px 0 0; font-size:14px; color:var(--ink-2); line-height:1.5; max-width:90%; }
.tc-section{ margin:18px 22px; }
.tc-chain{ display:flex; flex-direction:column; gap:0; }
.tc-stage{ display:grid; grid-template-columns:30px 1fr; gap:14px; }
.tc-stage__rail{ display:flex; flex-direction:column; align-items:center; }
.tc-stage__node{ width:28px; height:28px; border-radius:50%; border:2px solid var(--line-2); background:var(--surface); display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:11px; font-weight:600; color:var(--ink-3); z-index:1; }
.tc-stage__node.stub{ border-color:var(--stub-line); color:var(--stub); background:var(--stub-bg); }
.tc-stage__node.real{ border-color:var(--built-line); color:var(--built); background:var(--built-bg); }
.tc-stage__line{ flex:1; width:2px; background:var(--line); margin:2px 0; }
.tc-stage:last-child .tc-stage__line{ display:none; }
.tc-stage__card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:13px 15px; margin-bottom:11px; }
.tc-stage__card h4{ margin:0 0 3px; font-size:13px; font-weight:600; display:flex; align-items:center; gap:9px; }
.tc-stage__card .org{ font-family:var(--mono); font-size:10px; color:var(--ink-4); }
.tc-kv{ display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:8px 16px; margin-top:9px; }
.tc-kv div{ display:flex; flex-direction:column; gap:1px; }
.tc-kv .k{ font-family:var(--mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-4); }
.tc-kv .v{ font-family:var(--mono); font-size:12.5px; color:var(--ink); font-weight:500; }
.feat-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(82px,1fr)); gap:5px; }
.feat-cell{ background:var(--surface); border:1px solid var(--line); border-radius:6px; padding:6px 7px; }
.feat-cell .fn{ font-family:var(--mono); font-size:8.5px; color:var(--ink-4); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.feat-cell .fv{ font-family:var(--mono); font-size:11px; color:var(--ink); }
.btn{ display:inline-flex; align-items:center; gap:8px; height:34px; padding:0 15px; border-radius:9px; border:1px solid var(--line-2); background:var(--surface); color:var(--ink-2); font-size:12.5px; font-weight:600; }
.btn:hover{ background:var(--sunken); color:var(--ink); }

/* ===================== GATED OVERLAY ===================== */
.gated-host{ position:relative; }
.gated-overlay{
  position:absolute; inset:0; z-index:8; border-radius:var(--r-lg);
  background:repeating-linear-gradient(135deg,rgba(92,100,113,.05) 0 12px,rgba(92,100,113,.085) 12px 24px), rgba(247,248,250,.72);
  backdrop-filter:blur(2.5px); display:flex; align-items:center; justify-content:center;
}
.gated-card{ background:var(--surface); border:1px solid var(--gated-line); border-radius:var(--r-lg); box-shadow:var(--sh-2); padding:26px 30px; max-width:420px; text-align:center; }
.gated-card .lock{ width:46px; height:46px; border-radius:13px; background:var(--gated-bg); border:1px solid var(--gated-line); display:flex; align-items:center; justify-content:center; margin:0 auto 14px; color:var(--gated); }
.gated-card h3{ font-family:var(--display); font-weight:600; font-size:18px; margin:0 0 7px; }
.gated-card p{ font-size:12.5px; color:var(--ink-3); line-height:1.5; margin:0 0 14px; }

/* ===================== LOGIN ===================== */
.login{ position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center;
  background:radial-gradient(120% 80% at 50% 0%, rgba(46,151,247,.07), transparent 55%), var(--bg);
  background-size:auto, 34px 34px; }
.login__card{ width:392px; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl); box-shadow:var(--sh-3); padding:38px 36px 30px; text-align:center; }
.login__mark{ width:74px; height:74px; object-fit:contain; margin:0 auto 18px; display:block; filter:drop-shadow(0 8px 22px rgba(123,91,245,.2)); }
.login__card h1{ font-family:var(--display); font-weight:700; font-size:26px; letter-spacing:.04em; margin:0; }
.login__card .sub{ font-family:var(--mono); font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--ink-4); margin:5px 0 26px; }
.fld{ text-align:left; margin-bottom:14px; }
.fld label{ font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-4); display:block; margin-bottom:6px; }
.fld input{ width:100%; height:44px; border:1px solid var(--line-2); border-radius:10px; padding:0 14px; font-family:var(--body); font-size:14px; color:var(--ink); background:var(--surface-2); transition:.15s; }
.fld input:focus{ outline:none; border-color:var(--afferent); background:#fff; box-shadow:0 0 0 3px rgba(46,151,247,.12); }
.login__btn{ width:100%; height:46px; border:0; border-radius:10px; background:var(--grad); color:#fff; font-weight:600; font-size:14px; letter-spacing:.01em; margin-top:6px; box-shadow:0 6px 18px rgba(46,151,247,.22); }
.login__btn:hover{ filter:brightness(1.04); }
.login__verify{ margin-top:18px; font-family:var(--mono); font-size:10px; color:var(--ink-4); line-height:1.5; }

.hidden{ display:none !important; }

/* ---- Loader (Neuro-Oktopus splash, transparent, Logo-Morph) ---- */
.loader{ position:fixed; inset:0; z-index:300; display:flex; align-items:center; justify-content:center;
  background:radial-gradient(130% 90% at 50% 18%, rgba(46,151,247,.07), transparent 60%), var(--bg);
  background-size:auto, 34px 34px;
  opacity:1; }
.loader.out{ animation:loaderOut .7s ease both; }
@keyframes loaderOut{ to{ opacity:0; visibility:hidden; } }
.loader__inner{ display:flex; flex-direction:column; align-items:center; }
.loader__stage{ position:relative; width:min(460px,82vw); aspect-ratio:1; display:flex; align-items:center; justify-content:center; }
.loader__stage canvas{ position:absolute; inset:0; width:100%; height:100%; display:block;
  opacity:0; transform:scale(.34); transition:opacity 2.4s ease 0.6s, transform 3.4s cubic-bezier(.22,.62,.2,1) .35s; }
.loader__mark{ position:absolute; width:34%; height:auto; object-fit:contain; z-index:2;
  transition:opacity 1.8s ease .35s, transform 3.4s cubic-bezier(.55,0,.78,.16); filter:drop-shadow(0 8px 24px rgba(123,91,245,.22)); }
.loader.morph .loader__stage canvas{ opacity:1; transform:scale(1); }
.loader.morph .loader__mark{ opacity:0; transform:scale(7.5); }   /* zoom INTO the brain (slow) */
.loader__word{ font-family:var(--display); font-weight:700; font-size:34px; letter-spacing:.14em; padding-left:.14em;
  margin:18px 0 0; color:var(--ink); opacity:0; transition:opacity 1s ease 1.7s; }
.loader.morph .loader__word{ opacity:1; }
.loader__sub{ font-size:11px; letter-spacing:.34em; text-transform:uppercase; color:var(--ink-4); margin:11px 0 0; opacity:0; transition:opacity 1s ease 2s; }
.loader.morph .loader__sub{ opacity:1; }
.loader__dots span{ animation:lblink 1.4s infinite; } .loader__dots span:nth-child(2){ animation-delay:.22s; } .loader__dots span:nth-child(3){ animation-delay:.44s; }
@keyframes lblink{ 0%,60%,100%{ opacity:.2; } 30%{ opacity:1; } }
@media (max-width:860px){ .loader__word{ font-size:27px; } }

/* ===================== RESPONSIVE ===================== */
@media (max-width:1180px){
  .g-4{ grid-template-columns:repeat(2,1fr); }
  .g-3{ grid-template-columns:repeat(2,1fr); }
  .spine-wrap{ grid-template-columns:1fr; }
  .edge-banner__note{ display:none; }
}
@media (max-width:860px){
  :root{ --rail-w:0px; }
  .app{ grid-template-columns:1fr; }
  .rail{ position:fixed; bottom:0; left:0; right:0; top:auto; flex-direction:row; justify-content:space-around;
    border-right:0; border-top:1px solid var(--line); padding:8px 6px; height:62px; overflow-x:auto; }
  .rail__logo{ display:none; } .rail__spacer{ display:none; }
  .rail-item.active::before{ left:50%; top:-9px; transform:translateX(-50%); width:22px; height:3px; }
  .scroll{ padding-bottom:70px; }
  .g-2,.g-3,.g-4{ grid-template-columns:1fr; } .span-2,.span-3{ grid-column:span 1; }
  .edge-banner{ flex-wrap:wrap; margin:12px; } .edge-banner__metrics{ flex-wrap:wrap; }
  .view{ padding:16px 14px 80px; } .topbar{ padding:0 14px; }
  .sheet__panel{ width:100vw; }
  .trow{ grid-template-columns:80px 1fr 90px; } .trow__h,.trow__side{ display:none; }
}

/* ====================================================================
   v1.2 ADDITIONS
   ==================================================================== */

/* shell wrapper with top ticker */
.shell{ display:flex; flex-direction:column; height:100vh; overflow:hidden; }
.shell .app{ flex:1; height:auto; min-height:0; }

/* ---- Live-Ticker (5.0.1) ---- */
.ticker{ flex:0 0 34px; height:34px; background:#0B0E14; color:#E7EAF0; display:flex; align-items:center; overflow:hidden; position:relative; z-index:40; }
.ticker__tag{ flex:0 0 auto; height:100%; display:flex; align-items:center; gap:7px; padding:0 14px; background:#000; font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:#7E8595; border-right:1px solid rgba(255,255,255,.08); }
.ticker__tag i{ width:6px; height:6px; border-radius:50%; background:var(--built); box-shadow:0 0 8px var(--built); }
.ticker__track{ display:flex; align-items:center; gap:30px; white-space:nowrap; animation:tmarq 60s linear infinite; padding-left:30px; }
.ticker:hover .ticker__track{ animation-play-state:paused; }
@keyframes tmarq{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
.tk{ display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:11.5px; }
.tk b{ font-weight:600; color:#fff; }
.tk .v{ color:#B8BEC9; }
.tk .venue{ font-size:9px; color:#5E6473; letter-spacing:.05em; }
.tk .up{ color:#39D39B; } .tk .dn{ color:#FF6B6B; }
@media (prefers-reduced-motion:reduce){ .ticker__track{ animation:none; flex-wrap:nowrap; overflow:hidden; } }

/* ---- Neuro-Oktopus liveness (transparent, kein Hintergrund) ---- */
.oktopus{ position:fixed; left:14px; bottom:14px; z-index:60; width:72px; height:72px;
  display:flex; align-items:center; justify-content:center; cursor:pointer; transition:.2s; }
.oktopus:hover{ transform:translateY(-2px) scale(1.04); }
.oktopus canvas{ width:100%; height:100%; display:block; }
.oktopus.dim{ opacity:.7; } .oktopus.stop{ opacity:.45; }
.oktopus__pulse{ position:absolute; right:4px; top:4px; width:9px; height:9px; border-radius:50%; background:var(--built); box-shadow:0 0 0 3px rgba(14,157,107,.16); z-index:1; }
.oktopus.dim .oktopus__pulse{ background:var(--stub); box-shadow:0 0 0 3px var(--stub-bg); }
.oktopus.stop .oktopus__pulse{ background:var(--danger); box-shadow:0 0 0 3px var(--danger-bg); }
@media (max-width:860px){ .oktopus{ width:50px; height:50px; left:8px; bottom:70px; } }

/* ---- Command palette (5.0.3) ---- */
.cmdk{ position:fixed; inset:0; z-index:150; display:none; align-items:flex-start; justify-content:center; padding-top:14vh; background:rgba(11,14,20,.34); backdrop-filter:blur(3px); }
.cmdk.open{ display:flex; }
.cmdk__box{ width:min(560px,92vw); background:var(--surface); border:1px solid var(--line-2); border-radius:16px; box-shadow:var(--sh-3); overflow:hidden; }
.cmdk__in{ width:100%; height:54px; border:0; border-bottom:1px solid var(--line); padding:0 20px; font-family:var(--body); font-size:16px; color:var(--ink); outline:none; }
.cmdk__list{ max-height:320px; overflow-y:auto; padding:8px; }
.cmdk__item{ display:flex; align-items:center; gap:12px; padding:11px 13px; border-radius:9px; cursor:pointer; font-size:13.5px; color:var(--ink-2); }
.cmdk__item:hover, .cmdk__item.sel{ background:var(--sunken); color:var(--ink); }
.cmdk__item .k{ margin-left:auto; font-family:var(--mono); font-size:10px; color:var(--ink-4); border:1px solid var(--line-2); border-radius:5px; padding:2px 6px; }
.cmdk__item svg{ width:17px; height:17px; color:var(--ink-3); }

/* ---- Role switch (5.0.4) ---- */
.role-switch{ display:flex; background:var(--sunken); border:1px solid var(--line); border-radius:9px; padding:3px; gap:2px; }
.role-switch button{ border:0; background:transparent; padding:6px 12px; border-radius:7px; font-size:12px; font-weight:600; color:var(--ink-4); }
.role-switch button.on{ background:var(--surface); color:var(--ink); box-shadow:var(--sh-1); }

/* ---- Journal (5.3.2) ---- */
.jrow{ display:grid; grid-template-columns:120px 80px 60px 1fr 90px 90px; align-items:center; gap:12px; padding:0 16px; height:46px; border-bottom:1px solid var(--line); cursor:pointer; }
.jrow:hover{ background:var(--surface-2); }
.jrow .corr{ font-family:var(--mono); font-size:10.5px; color:var(--ink-4); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* ---- Heatmap (5.5.5) ---- */
.heat{ display:flex; flex-direction:column; gap:5px; }
.heat__row{ display:grid; grid-template-columns:60px 1fr 70px; align-items:center; gap:10px; }
.heat__bar{ height:24px; border-radius:6px; background:linear-gradient(90deg,var(--afferent),var(--planned)); }
.heat__coin{ font-family:var(--display); font-weight:600; font-size:13px; }
.heat__n{ font-family:var(--mono); font-size:11px; color:var(--ink-3); text-align:right; }

/* ---- coverage matrix (5.4.4) ---- */
.covm{ display:grid; gap:3px; }
.covm__cell{ aspect-ratio:1.6; border-radius:5px; display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:9px; color:#fff; }
.covm__lbl{ font-family:var(--mono); font-size:10px; color:var(--ink-4); display:flex; align-items:center; }

/* ---- reliability (5.5.7) ---- */
.reliability text{ font-family:var(--mono); font-size:9px; fill:var(--ink-4); }

/* ---- latency bars (5.4.3) ---- */
.lat-row{ display:grid; grid-template-columns:200px 1fr 56px; align-items:center; gap:12px; margin-bottom:9px; }
.lat-row .nm{ font-family:var(--mono); font-size:11.5px; color:var(--ink-2); }
.lat-row .bar{ height:18px; border-radius:5px; background:var(--running); }
.lat-row .ms{ font-family:var(--mono); font-size:11.5px; color:var(--ink-3); text-align:right; }

/* ---- anomaly feed (5.4.2) ---- */
.anom{ display:flex; align-items:flex-start; gap:12px; padding:11px 0; border-bottom:1px solid var(--line); }
.anom:last-child{ border-bottom:0; }
.anom__t{ font-family:var(--mono); font-size:10.5px; color:var(--ink-4); flex:0 0 auto; padding-top:2px; }
.anom__b{ flex:1; } .anom__b h4{ margin:0 0 2px; font-size:12.5px; font-weight:600; }
.anom__b p{ margin:0; font-size:11.5px; color:var(--ink-3); }

/* ---- gated/prepared layer (5.9 / 5.12) ---- */
.prep{ position:relative; }
.prep__veil{ position:absolute; inset:0; border-radius:var(--r-lg); background:repeating-linear-gradient(135deg,rgba(92,100,113,.04) 0 11px,rgba(92,100,113,.075) 11px 22px),rgba(248,249,251,.55); display:flex; align-items:center; justify-content:center; z-index:5; }
.prep__chip{ background:var(--surface); border:1px solid var(--gated-line); border-radius:99px; padding:7px 15px; font-family:var(--mono); font-size:11px; color:var(--gated); display:flex; align-items:center; gap:8px; box-shadow:var(--sh-1); }

/* ---- G9 mission (5.11) ---- */
.gate-card{ border:1px solid var(--line); border-radius:var(--r); padding:16px; display:flex; flex-direction:column; gap:11px; background:var(--surface-2); }
.gate-card .gname{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; color:var(--ink-3); display:flex; justify-content:space-between; }
.gate-card .gbig{ font-family:var(--display); font-weight:700; font-size:22px; }
.milestone{ display:flex; align-items:center; gap:10px; padding:10px 0; border-bottom:1px solid var(--line); font-size:12.5px; }
.milestone:last-child{ border-bottom:0; }
.milestone .dot{ width:9px; height:9px; border-radius:50%; background:var(--gated); flex:0 0 auto; }

/* ---- user frontend (5.12) ---- */
.user-hero{ background:var(--grad-soft); border:1px solid var(--line); border-radius:var(--r-xl); padding:30px 32px; display:flex; align-items:center; gap:26px; }
.user-actions{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.uact{ position:relative; border:1px solid var(--line); border-radius:var(--r); padding:18px; background:var(--surface); display:flex; flex-direction:column; gap:8px; min-height:104px; }
.uact h4{ margin:0; font-size:13.5px; font-weight:600; }
.uact p{ margin:0; font-size:11.5px; color:var(--ink-4); line-height:1.4; }
.uact .ghost{ position:absolute; top:12px; right:12px; }
.uact.live-ok{ cursor:pointer; } .uact.live-ok:hover{ background:var(--surface-2); }
@media(max-width:860px){ .user-actions{ grid-template-columns:1fr; } .reliability{ width:100%; } }

/* ====================================================================
   USER DASHBOARD v2 (sexy light)
   ==================================================================== */
.u-hero{ display:flex; align-items:center; gap:20px; margin-bottom:18px; }
.u-hero__greet{ font-family:var(--display); font-weight:600; font-size:25px; letter-spacing:-.02em; margin:0; }
.u-hero__sub{ font-size:13px; color:var(--ink-3); margin:2px 0 0; }
.u-hero__spacer{ margin-left:auto; }

/* balance cards */
.bal-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.bal{ position:relative; border-radius:var(--r-lg); padding:22px 24px; overflow:hidden; border:1px solid var(--line); box-shadow:var(--sh-1); background:var(--surface); }
.bal--live{ background:linear-gradient(135deg,#fff, #F4F9FF); border-color:rgba(46,151,247,.22); }
.bal--live::after{ content:""; position:absolute; right:-40px; top:-40px; width:160px; height:160px; border-radius:50%; background:radial-gradient(circle,rgba(46,151,247,.12),transparent 70%); }
.bal__k{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-4); display:flex; align-items:center; gap:8px; }
.bal__k i{ width:7px; height:7px; border-radius:50%; }
.bal__v{ font-family:var(--display); font-weight:700; font-size:38px; letter-spacing:-.03em; margin:10px 0 0; line-height:1; }
.bal__v small{ font-size:.42em; font-weight:500; color:var(--ink-4); margin-left:5px; }
.bal__meta{ font-size:12px; color:var(--ink-3); margin-top:8px; display:flex; align-items:center; gap:8px; }

/* trading toggle */
.trade-toggle{ display:flex; align-items:center; gap:16px; padding:16px 20px; border:1px solid var(--line); border-radius:var(--r-lg); background:var(--surface); box-shadow:var(--sh-1); }
.trade-toggle__lbl{ display:flex; flex-direction:column; gap:2px; }
.trade-toggle__lbl b{ font-size:14px; }
.trade-toggle__lbl span{ font-size:11.5px; color:var(--ink-3); }
.switch{ margin-left:auto; width:62px; height:34px; border-radius:99px; background:var(--sunken); border:1px solid var(--line-2); position:relative; cursor:pointer; transition:.22s; flex:0 0 auto; }
.switch::after{ content:""; position:absolute; top:3px; left:3px; width:26px; height:26px; border-radius:50%; background:#fff; box-shadow:0 2px 5px rgba(11,14,20,.2); transition:.22s; }
.switch.on{ background:var(--grad); border-color:transparent; }
.switch.on::after{ left:33px; }
.switch__state{ font-family:var(--mono); font-size:12px; font-weight:600; min-width:64px; text-align:right; }
.switch__state.on{ color:var(--built); } .switch__state.off{ color:var(--ink-4); }

/* P/L period */
.pl-tabs{ display:flex; gap:4px; background:var(--sunken); border:1px solid var(--line); border-radius:9px; padding:3px; }
.pl-tabs button{ flex:1; border:0; background:transparent; padding:7px 6px; border-radius:7px; font-size:12px; font-weight:600; color:var(--ink-4); }
.pl-tabs button.on{ background:var(--surface); color:var(--ink); box-shadow:var(--sh-1); }
.pl-big{ font-family:var(--display); font-weight:700; font-size:44px; letter-spacing:-.03em; line-height:1; margin:18px 0 6px; }
.pl-usdc{ font-family:var(--mono); font-size:15px; }
.pos{ color:var(--built); } .neg{ color:var(--danger); }

/* win-rate filter */
.win-filter{ display:flex; gap:6px; flex-wrap:wrap; }
.win-filter button{ border:1px solid var(--line-2); background:var(--surface); border-radius:99px; padding:6px 13px; font-family:var(--mono); font-size:11.5px; color:var(--ink-3); }
.win-filter button.on{ background:var(--ink); color:#fff; border-color:var(--ink); }
.win-dial{ display:flex; align-items:baseline; gap:8px; margin-top:16px; }
.win-dial b{ font-family:var(--display); font-size:46px; font-weight:700; letter-spacing:-.03em; }

/* user open trades */
.uot{ display:grid; grid-template-columns:90px 70px 1fr 100px; align-items:center; gap:12px; padding:0 16px; height:50px; border-bottom:1px solid var(--line); }
.uot:last-child{ border-bottom:0; }
.uot__coin{ font-family:var(--display); font-weight:600; font-size:14px; }
.uot__side{ font-family:var(--mono); font-size:10.5px; font-weight:600; padding:3px 8px; border-radius:6px; display:inline-block; }
.uot__side.long{ color:var(--built); background:var(--built-bg); }
.uot__side.short{ color:var(--danger); background:var(--danger-bg); }

/* account sub-nav */
.acc-subnav{ display:flex; gap:4px; background:var(--surface); border:1px solid var(--line); border-radius:12px; padding:5px; margin-bottom:18px; box-shadow:var(--sh-1); overflow-x:auto; }
.acc-subnav button{ flex:1; border:0; background:transparent; padding:11px 14px; border-radius:8px; font-size:13px; font-weight:600; color:var(--ink-4); white-space:nowrap; display:flex; align-items:center; justify-content:center; gap:8px; }
.acc-subnav button.on{ background:var(--grad-soft); color:var(--ink); }
.acc-subnav button .nb{ background:var(--danger); color:#fff; border-radius:99px; font-size:9px; padding:1px 6px; font-family:var(--mono); }

/* notification */
.notif{ display:flex; align-items:center; gap:16px; padding:18px 20px; border:1px solid var(--stub-line); border-radius:var(--r-lg); background:linear-gradient(180deg,#fff,#FCFBF6); margin-bottom:14px; }
.notif__ic{ width:42px; height:42px; border-radius:11px; background:var(--stub-bg); border:1px solid var(--stub-line); display:flex; align-items:center; justify-content:center; color:var(--stub); flex:0 0 auto; }
.notif__b{ flex:1; } .notif__b h4{ margin:0 0 3px; font-size:14px; } .notif__b p{ margin:0; font-size:12.5px; color:var(--ink-3); line-height:1.4; }
.btn-primary{ display:inline-flex; align-items:center; gap:8px; height:40px; padding:0 18px; border:0; border-radius:10px; background:var(--grad); color:#fff; font-weight:600; font-size:13px; box-shadow:0 6px 16px rgba(46,151,247,.22); white-space:nowrap; }
.btn-primary:hover{ filter:brightness(1.05); }
.btn-danger{ color:var(--danger); border-color:var(--danger-line); }
.btn-danger:hover{ background:var(--danger-bg); }

/* settings rows */
.set-row{ display:flex; align-items:center; gap:14px; padding:16px 0; border-bottom:1px solid var(--line); }
.set-row:last-child{ border-bottom:0; }
.set-row__b{ flex:1; } .set-row__b b{ font-size:13.5px; } .set-row__b span{ display:block; font-size:11.5px; color:var(--ink-4); margin-top:2px; }
.inp{ width:100%; height:42px; border:1px solid var(--line-2); border-radius:10px; padding:0 14px; font-family:var(--body); font-size:14px; color:var(--ink); background:var(--surface-2); }
.inp:focus{ outline:none; border-color:var(--afferent); background:#fff; box-shadow:0 0 0 3px rgba(46,151,247,.12); }

/* friends */
.fr-hero{ text-align:center; padding:10px 0 4px; }
.fr-gift{ width:64px; height:64px; border-radius:18px; background:var(--grad-soft); display:flex; align-items:center; justify-content:center; margin:0 auto 16px; color:var(--planned); }
.fr-link{ display:flex; gap:8px; margin-top:18px; }
.fr-stats{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:18px; }
.fr-stat{ text-align:center; padding:18px; border:1px solid var(--line); border-radius:var(--r); background:var(--surface-2); }
.fr-stat b{ font-family:var(--display); font-size:30px; font-weight:700; display:block; }
.fr-stat span{ font-size:11.5px; color:var(--ink-4); }

/* legal */
.legal-links{ display:flex; flex-direction:column; gap:2px; margin-top:14px; }
.legal-links a{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; border-bottom:1px solid var(--line); color:var(--ink); font-size:13.5px; font-weight:500; text-decoration:none; }
.legal-links a:hover{ color:var(--afferent); }

/* contact sheet (octopus) */
.contact{ position:fixed; left:96px; bottom:18px; z-index:130; width:min(380px,86vw); background:var(--surface); border:1px solid var(--line-2); border-radius:var(--r-xl); box-shadow:var(--sh-3); padding:22px 22px 20px; transform:translateY(16px) scale(.96); opacity:0; pointer-events:none; transition:.24s cubic-bezier(.2,.7,.2,1); transform-origin:bottom left; }
.contact.open{ transform:none; opacity:1; pointer-events:auto; }
.contact h3{ font-family:var(--display); font-weight:600; font-size:20px; margin:0; letter-spacing:-.01em; }
.contact p{ font-size:12.5px; color:var(--ink-3); margin:6px 0 16px; line-height:1.45; }
.contact textarea{ width:100%; min-height:96px; border:1px solid var(--line-2); border-radius:12px; padding:12px 14px; font-family:var(--body); font-size:13.5px; resize:vertical; background:var(--surface-2); }
.contact textarea:focus{ outline:none; border-color:var(--afferent); background:#fff; box-shadow:0 0 0 3px rgba(46,151,247,.12); }
.contact__close{ position:absolute; right:14px; top:14px; width:28px; height:28px; border:1px solid var(--line); border-radius:8px; background:var(--surface); color:var(--ink-3); display:flex; align-items:center; justify-content:center; }
@media(max-width:860px){ .contact{ left:8px; right:8px; bottom:130px; width:auto; } }

/* language switch */
.lang-switch{ display:flex; background:var(--sunken); border:1px solid var(--line); border-radius:8px; overflow:hidden; }
.lang-switch button{ border:0; background:transparent; padding:6px 10px; font-family:var(--mono); font-size:11px; font-weight:600; color:var(--ink-4); }
.lang-switch button.on{ background:var(--surface); color:var(--ink); }

/* login role + social */
.login__role{ display:flex; gap:4px; background:var(--sunken); border:1px solid var(--line); border-radius:10px; padding:4px; margin-bottom:20px; }
.login__role button{ flex:1; border:0; background:transparent; padding:10px; border-radius:7px; font-size:13px; font-weight:600; color:var(--ink-4); }
.login__role button.on{ background:var(--surface); color:var(--ink); box-shadow:var(--sh-1); }
.login__rolehint{ font-size:10.5px; color:var(--ink-4); margin:-12px 0 16px; }
.login__more{ margin-top:18px; }
.login__more summary{ list-style:none; cursor:pointer; font-size:12.5px; color:var(--ink-3); text-align:center; padding:8px; border-radius:8px; }
.login__more summary::-webkit-details-marker{ display:none; }
.login__more summary:hover{ color:var(--ink); background:var(--sunken); }
.login__more[open] summary{ color:var(--ink-4); }
.social{ display:flex; flex-direction:column; gap:9px; margin-top:12px; }
.social button{ display:flex; align-items:center; gap:11px; width:100%; height:46px; padding:0 16px; border:1px solid var(--line-2); border-radius:11px; background:var(--surface); font-size:13.5px; font-weight:600; color:var(--ink); transition:.14s; }
.social button:hover{ background:var(--surface-2); border-color:var(--line-3); }
.social button svg, .social button img{ width:19px; height:19px; flex:0 0 auto; }
.social__xrp{ background:#0B0E14 !important; color:#fff !important; border-color:#0B0E14 !important; }
.social__xrp:hover{ filter:brightness(1.15); }
.social button.soon{ opacity:.62; }
.social button.soon::after{ content:"bald"; margin-left:auto; font-family:var(--mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-4); border:1px solid var(--line-2); border-radius:99px; padding:2px 7px; }
.social__xrp.soon::after{ color:rgba(255,255,255,.7); border-color:rgba(255,255,255,.25); }
.social button.shake{ animation:shakeX .4s; }
@keyframes shakeX{ 0%,100%{transform:translateX(0)} 25%{transform:translateX(-4px)} 75%{transform:translateX(4px)} }
