/* =====================================================================
   BLOQ — shared stylesheet  (assets/bloq.css)
   Dark · clean · professional (TradingView-grade)
   ===================================================================== */

/* Fonts: a precise modern sans for UI/headings + a technical mono for data.
   Loaded in each HTML <head>; declared here for reference.
   --display / --body : Space Grotesk (clean, geometric, professional)
   --mono             : IBM Plex Mono (technical, used for numbers/labels) */

:root{
  --bg:#0a0c0f;
  --bg-2:#0e1116;
  --bg-3:#11151b;
  --card:#12161c;
  --card-2:#161b22;
  --ink:#f2f5f8;
  --ink-soft:#9099a4;
  --ink-faint:#5d6671;
  --line:rgba(255,255,255,.06);
  --line-2:rgba(255,255,255,.12);
  --accent:#6E78FF;
  --accent-2:#21b88a;
  --accent-soft:rgba(110, 120, 255,.1);
  --accent-line:rgba(110, 120, 255,.28);
  --up:#6E78FF;
  --down:#ff5d6c;
  --amber:#f5b942;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 24px 60px rgba(0,0,0,.45);
  --shadow-lg:0 40px 90px rgba(0,0,0,.55);
  --display:"Space Grotesk",system-ui,sans-serif;
  --body:"Space Grotesk",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --r:14px;
  --r-lg:20px;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);font-family:var(--body);font-weight:400;
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  font-feature-settings:"ss01","cv01";letter-spacing:-.005em;
}
::selection{background:var(--accent);color:#04140d}
a{color:inherit}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---- typography ---- */
h1,h2,h3,h4,h5{font-family:var(--display);font-weight:600;letter-spacing:-.025em;line-height:1.08}
.kicker{font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
h1.display{font-size:clamp(40px,7vw,76px);font-weight:700;letter-spacing:-.04em;line-height:1.0;max-width:16ch}
h2{font-size:clamp(28px,4.2vw,46px);font-weight:700;letter-spacing:-.035em;max-width:22ch}
h3{font-size:20px;font-weight:600}
.lead{color:var(--ink-soft);font-size:clamp(16px,1.8vw,19px);max-width:56ch;margin-top:18px;font-weight:400}
.center{text-align:center}.center h1,.center h2{margin-inline:auto}.center .lead{margin-inline:auto}
.accent{color:var(--accent)}

/* ---- buttons ---- */
.btn{font-family:var(--body);font-size:14.5px;font-weight:600;cursor:pointer;border-radius:11px;
  padding:11px 20px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;
  border:1px solid transparent;transition:all .2s cubic-bezier(.2,.8,.2,1);white-space:nowrap;letter-spacing:-.01em}
.btn svg{width:17px;height:17px}
.btn-solid{background:var(--accent);color:#04140d}
.btn-solid:hover{background:#8A92FF;transform:translateY(-1px);box-shadow:0 10px 28px rgba(110, 120, 255,.26)}
.btn-ghost{color:var(--ink);border-color:var(--line-2);background:transparent}
.btn-ghost:hover{border-color:var(--ink-soft);background:rgba(255,255,255,.03)}
.btn-lg{padding:14px 26px;font-size:15.5px}

/* ---- nav ---- */
nav{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .3s,border-color .3s;
  border-bottom:1px solid transparent}
nav.scrolled{background:rgba(10,12,15,.82);backdrop-filter:blur(16px);border-bottom-color:var(--line)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:16px 26px;display:flex;align-items:center;gap:32px}
.logo{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.03em;text-decoration:none;color:var(--ink)}
.logo .dot{width:26px;height:26px;border-radius:0;background:none;box-shadow:none;flex:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cdefs%3E%3ClinearGradient id='g' x1='8' y1='8' x2='56' y2='56' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%238A92FF'/%3E%3Cstop offset='1' stop-color='%235862F5'/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect x='8' y='8' width='48' height='48' rx='14' fill='url(%23g)'/%3E%3Cpath d='M24 22h12a6 6 0 0 1 6 6v8a6 6 0 0 1-6 6h-2v-6h2v-8H24z' fill='%230D0F13'/%3E%3Crect x='24' y='34' width='6' height='8' rx='1.5' fill='%230D0F13'/%3E%3C/svg%3E");
  background-size:contain;background-repeat:no-repeat;background-position:center}
.nav-links{display:flex;gap:28px;margin-left:4px}
.nav-links a{color:var(--ink-soft);text-decoration:none;font-size:14.5px;font-weight:500;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:10px}
.burger{display:none;background:none;border:none;color:var(--ink);cursor:pointer;width:40px;height:40px}
.burger svg{width:24px;height:24px}
@media(max-width:880px){
  .nav-links{display:none;position:absolute;top:70px;left:16px;right:16px;flex-direction:column;gap:4px;
    background:var(--card);border:1px solid var(--line-2);border-radius:16px;padding:12px;box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links a{padding:11px 14px;border-radius:9px}.nav-links a:hover{background:var(--bg-3)}
  .nav-cta .btn-ghost{display:inline-flex;padding:8px 12px;font-size:13px}
  .nav-cta .btn-solid{padding:8px 12px;font-size:13px}
  .burger{display:grid;place-items:center;order:3}
  .nav-cta{margin-left:0;gap:7px}
}
@media(max-width:380px){
  .nav-cta .btn-ghost{padding:7px 10px}
  .nav-cta .btn-solid{padding:7px 10px}
  .nav-cta{gap:6px}
}

/* ---- page header (interior pages) ---- */
.page-head{padding:150px 0 50px;position:relative}
.page-head::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(680px 360px at 50% -10%,var(--accent-soft),transparent 62%)}
.page-head .kicker{margin-bottom:18px}
.breadcrumb{font-family:var(--mono);font-size:12px;color:var(--ink-faint);margin-bottom:22px}
.breadcrumb a{color:var(--ink-faint);text-decoration:none}.breadcrumb a:hover{color:var(--ink-soft)}

/* ---- pill tag ---- */
.pill-tag{display:inline-flex;align-items:center;gap:9px;background:var(--accent-soft);color:var(--accent);
  font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.06em;border:1px solid var(--accent-line);
  border-radius:999px;padding:7px 14px}
.pill-tag .d{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ---- generic section ---- */
section{padding:88px 0;position:relative}
.divider{border-block:1px solid var(--line);background:var(--bg-2)}

/* ---- cards grid ---- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:880px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;transition:transform .3s,border-color .3s}
.card:hover{transform:translateY(-4px);border-color:var(--line-2)}
.card .ic{width:48px;height:48px;border-radius:13px;background:var(--accent-soft);border:1px solid var(--accent-line);
  display:grid;place-items:center;color:var(--accent);margin-bottom:18px}
.card .ic svg{width:23px;height:23px}
.card h3{margin-bottom:8px}
.card p{color:var(--ink-soft);font-size:14.5px}
.card .num{font-family:var(--mono);font-size:12px;color:var(--ink-faint);letter-spacing:.08em;margin-bottom:14px}

/* ---- mono data label ---- */
.mono{font-family:var(--mono)}
.up{color:var(--up)}.down{color:var(--down)}

/* ---- footer ---- */
footer{padding:62px 0 38px;border-top:1px solid var(--line);background:var(--bg-2)}
.fg{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:34px}
@media(max-width:820px){.fg{grid-template-columns:1fr 1fr}}
.fg h5{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:15px}
.fg a{display:block;color:var(--ink-soft);text-decoration:none;font-size:14px;margin-bottom:9px;font-weight:500;transition:color .2s}
.fg a:hover{color:var(--ink)}
.fa p{color:var(--ink-soft);font-size:14px;max-width:34ch;margin-top:13px}
.fb{display:flex;justify-content:space-between;align-items:center;margin-top:44px;padding-top:22px;border-top:1px solid var(--line);flex-wrap:wrap;gap:12px}
.fb p{font-family:var(--mono);font-size:12px;color:var(--ink-faint)}
.fb .soc{display:flex;gap:10px}
.fb .soc a{width:34px;height:34px;border-radius:9px;border:1px solid var(--line-2);display:grid;place-items:center;color:var(--ink-soft);transition:all .2s}
.fb .soc a:hover{color:var(--accent);border-color:var(--accent-line)}
.fb .soc svg{width:16px;height:16px}
.disc{font-size:12.5px;color:var(--ink-faint);max-width:90ch;margin-top:16px;line-height:1.7}

/* ---- prose (legal/support pages) ---- */
.prose{max-width:760px}
.prose h2{font-size:24px;margin:38px 0 14px;letter-spacing:-.02em}
.prose h3{font-size:18px;margin:26px 0 10px}
.prose p{color:var(--ink-soft);font-size:15.5px;margin-bottom:14px}
.prose ul{color:var(--ink-soft);font-size:15.5px;margin:0 0 16px 20px;display:flex;flex-direction:column;gap:8px}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--accent);text-decoration:none}.prose a:hover{text-decoration:underline}
.prose .updated{font-family:var(--mono);font-size:12px;color:var(--ink-faint);margin-bottom:30px}

/* =====================================================================
   CHAT WIDGET (shared)
   ===================================================================== */
.bloq-launcher{position:fixed;right:22px;bottom:22px;z-index:9999;width:58px;height:58px;border-radius:17px;
  border:1px solid var(--line-2);background:linear-gradient(160deg,var(--card-2),var(--card));color:var(--accent);
  cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow);transition:transform .25s}
.bloq-launcher:hover{transform:translateY(-3px) scale(1.03)}
.bloq-launcher svg{width:25px;height:25px}
.bloq-launcher .pl{position:absolute;top:11px;right:11px;width:9px;height:9px;border-radius:50%;background:var(--accent);animation:bloqPulse 2s infinite}
@keyframes bloqPulse{0%{box-shadow:0 0 0 0 rgba(110, 120, 255,.45)}70%{box-shadow:0 0 0 11px rgba(110, 120, 255,0)}100%{box-shadow:0 0 0 0 rgba(110, 120, 255,0)}}
.bloq-launcher svg{fill:none}
@media(max-width:560px){
  .bloq-launcher{width:50px;height:50px;right:14px;bottom:calc(14px + env(safe-area-inset-bottom,0px));border-radius:14px}
  .bloq-launcher svg{width:21px;height:21px}
  .bloq-launcher .pl{top:9px;right:9px;width:8px;height:8px}
  .bloq-panel{right:10px;left:10px;width:auto;bottom:72px;height:min(72vh,520px);border-radius:18px}
}
.bloq-panel{position:fixed;right:22px;bottom:92px;z-index:9999;width:min(370px,calc(100vw - 32px));height:min(540px,calc(100vh - 130px));
  background:var(--card);border:1px solid var(--line-2);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:var(--shadow-lg);transform:translateY(14px) scale(.98);opacity:0;pointer-events:none;transition:opacity .2s,transform .25s}
.bloq-panel.open{opacity:1;transform:none;pointer-events:auto}
.bloq-h{display:flex;align-items:center;gap:11px;padding:15px 16px;border-bottom:1px solid var(--line);background:radial-gradient(360px 110px at 0% 0%,var(--accent-soft),transparent 70%)}
.bloq-h .mk{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent);font-family:var(--mono);font-weight:600;font-size:13px;border:1px solid var(--accent-line)}
.bloq-h b{font-size:14px;font-weight:600}.bloq-h span{display:block;font-size:11px;color:var(--ink-soft);margin-top:2px}.bloq-h span i{color:var(--accent);font-style:normal}
.bloq-h .x{margin-left:auto;background:none;border:none;color:var(--ink-soft);cursor:pointer;width:30px;height:30px;border-radius:8px;font-size:18px}
.bloq-h .x:hover{background:rgba(255,255,255,.05);color:var(--ink)}
.bloq-log{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:11px}
.bloq-log::-webkit-scrollbar{width:7px}.bloq-log::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:10px}
.bloq-m{max-width:84%;padding:10px 13px;border-radius:14px;font-size:13.5px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}
.bloq-m.bot{align-self:flex-start;background:var(--bg-3);border:1px solid var(--line);border-bottom-left-radius:5px}
.bloq-m.me{align-self:flex-end;background:var(--accent);color:#03150f;border-bottom-right-radius:5px;font-weight:500}
.bloq-chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 8px}
.bloq-chip{font-family:var(--body);font-size:12px;color:var(--ink);background:var(--bg-3);border:1px solid var(--line);border-radius:999px;padding:7px 11px;cursor:pointer;transition:border-color .15s}
.bloq-chip:hover{border-color:var(--accent)}
.bloq-in{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:var(--bg-2)}
.bloq-in textarea{flex:1;resize:none;max-height:90px;background:var(--bg-3);color:var(--ink);border:1px solid var(--line);border-radius:12px;padding:11px;font-family:var(--body);font-size:13.5px;outline:none}
.bloq-in textarea:focus{border-color:var(--accent)}
.bloq-in button{width:44px;border:none;border-radius:12px;background:var(--accent);color:#03150f;cursor:pointer;display:grid;place-items:center}
.bloq-in button svg{width:19px;height:19px}
.bloq-typ{align-self:flex-start;display:flex;gap:4px;padding:11px 14px;background:var(--bg-3);border:1px solid var(--line);border-radius:14px}
.bloq-typ i{width:6px;height:6px;border-radius:50%;background:var(--ink-soft);animation:bloqDot 1.2s infinite}
.bloq-typ i:nth-child(2){animation-delay:.2s}.bloq-typ i:nth-child(3){animation-delay:.4s}
@keyframes bloqDot{0%,60%,100%{opacity:.3}30%{opacity:1}}
.bloq-ft{font-family:var(--mono);font-size:10px;color:var(--ink-faint);text-align:center;padding:0 16px 11px}
