/* =====================================================================
   BLOQ — shared chrome for the functional (site.js) pages
   Loads AFTER styles.css. Provides the redesign nav / footer / chat
   launcher / button system so the functional pages match the marketing
   pages. Defines ONLY the design tokens that styles.css does not, to
   avoid changing styles.css component styling.
   ===================================================================== */
:root{
  --ink:#f2f5f8;
  --ink-soft:#9099a4;
  --ink-faint:#5d6671;
  --line:rgba(255,255,255,.06);
  --line-2:rgba(255,255,255,.12);
  --card:#12161c;
  --card-2:#161b22;
  --bg-3:#11151b;
  --accent-soft:rgba(110, 120, 255,.1);
  --accent-line:rgba(110, 120, 255,.28);
  --maxw:1180px;
  --display:"Space Grotesk",system-ui,sans-serif;
  --body:"Space Grotesk",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --shadow-lg:0 40px 90px rgba(0,0,0,.55);
}

.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}}

/* ---- redesign buttons (chrome) ---- */
.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 (sticky on functional pages so content is not overlapped) ---- */
nav{position:sticky;top:0;left:0;right:0;z-index:200;transition:background .3s,border-color .3s;
  border-bottom:1px solid transparent;background:rgba(10,12,15,.82);backdrop-filter:blur(16px)}
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:none}
  .burger{display:grid;place-items:center;margin-left:auto;order:3}
  .nav-cta{margin-left:0}
}

/* ---- 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}

/* ---- 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-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}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
