/* =========================================================================
   Whirl Design — "Fingerprint" design system
   Warm CRT terminal on cream paper. Ink type, single orange accent,
   JetBrains Mono for code/eyebrows, dark terminal panels as signature.
   ========================================================================= */

:root {
  /* Colors */
  --color-cream-paper: #fafaf8;
  --color-card-white: #ffffff;
  --color-pebble-gray: #f0f0ef;
  --color-linen-border: #e4e5e1;
  --color-ash: #d9d9d9;
  --color-ink: #141415;
  --color-graphite: #2e2e2c;
  --color-carbon: #454542;
  --color-slate: #6e6f6c;
  --color-stone: #8c8c89;
  --color-fog: #b7b7b4;
  --color-signal-orange: #f35b22;
  --color-ember: #ff5e24;
  --color-apricot: #f77c55;
  --color-burnt-orange: #be400f;
  --color-persimmon: #d14200;
  --color-peach-blush: #ffcab5;
  --color-teal-token: #88d2c3;
  --color-sky-token: #8bc5f3;
  --color-orchid-token: #c678dd;
  --color-forest: #165424;
  --color-success-green: #62b06d;
  --color-coral-alert: #f67976;
  --color-rose-blush: #f9aea9;

  /* Type */
  --font-inter: 'Inter', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;

  --text-eyebrow: 11px;
  --text-heading-sm: 30px;
  --text-heading: 36px;
  --text-display: 48px;

  /* Spacing */
  --s-4: 4px;  --s-8: 8px;  --s-12: 12px; --s-16: 16px; --s-20: 20px;
  --s-24: 24px; --s-28: 28px; --s-32: 32px; --s-48: 48px; --s-56: 56px;
  --s-72: 72px; --s-96: 96px;

  --page-max: 1200px;
  --section-gap: 72px;

  /* Radius */
  --r-sm: 4px; --r-md: 12px; --r-lg: 16px;

  /* Shadows / elevation */
  --sh-nav: rgba(24,25,22,.02) 0 2px 1px 0, rgba(24,25,22,.1) 0 -1px 0 0 inset;
  --sh-card: rgba(228,229,225,.3) 0 1px 0 0 inset, rgba(110,111,109,.1) 0 -1px 0 0 inset;
  --sh-btn: rgba(255,255,255,.2) 0 1px 0 0 inset, rgba(24,25,22,.06) 0 1px 2px 0, rgba(24,25,22,.1) 0 -1px 0 0 inset;
  --sh-link: rgba(24,25,22,.06) 0 1px 2px 0;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
}

body {
  font-family: var(--font-inter);
  font-feature-settings: "calt" 0, "liga" 0;
  font-optical-sizing: auto;
  background-color: var(--color-cream-paper);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='150' height='150'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  color: var(--color-ink);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

/* ---------- Layout helpers ---------- */
.wrap { width: 100%; max-width: var(--page-max); margin-inline: auto; padding-inline: var(--s-24); }

/* ===== Fingerprint-style dotted grid rails ===== */
main { position: relative; }
main::before, main::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 1px;
  background-image: repeating-linear-gradient(to bottom, var(--color-linen-border) 0 3px, transparent 3px 5px);
  pointer-events: none;
  z-index: 0;
}
main::before { left: max(var(--s-24), calc(50% - (var(--page-max) / 2) + var(--s-24))); }
main::after  { right: max(var(--s-24), calc(50% - (var(--page-max) / 2) + var(--s-24))); }
main > section { position: relative; z-index: 1; }
main > section + section:not(.section--band):not(.section--dark)::before {
  content: "";
  position: absolute;
  top: 0;
  left: max(var(--s-24), calc(50% - (var(--page-max) / 2) + var(--s-24)));
  right: max(var(--s-24), calc(50% - (var(--page-max) / 2) + var(--s-24)));
  height: 1px;
  background-image: repeating-linear-gradient(to right, var(--color-linen-border) 0 3px, transparent 3px 5px);
  pointer-events: none;
}
@media (max-width: 1080px) {
  main::before, main::after { display: none; }
  main > section + section::before { display: none; }
}

.section { padding-block: var(--section-gap); }
.section--band { background: var(--color-pebble-gray); border-top: 1px solid var(--color-linen-border); border-bottom: 1px solid var(--color-linen-border); }
.section--tight { padding-block: var(--s-48); }
.stack-sm > * + * { margin-top: var(--s-12); }
.center { text-align: center; }
.mt-8{margin-top:var(--s-8)} .mt-16{margin-top:var(--s-16)} .mt-24{margin-top:var(--s-24)}
.mt-32{margin-top:var(--s-32)} .mt-48{margin-top:var(--s-48)}

/* ---------- Typography ---------- */
.eyebrow {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--text-eyebrow);
  line-height: 1.45;
  letter-spacing: .88px;
  text-transform: uppercase;
  color: var(--color-signal-orange);
}
.eyebrow--muted { color: var(--color-slate); }

h1, h2, h3 { font-weight: 600; letter-spacing: -.02em; line-height: 1.15; }
.display { font-size: clamp(34px, 5.4vw, var(--text-display)); letter-spacing: -.031em; line-height: 1.12; }
.heading { font-size: clamp(28px, 3.6vw, var(--text-heading)); letter-spacing: -.02em; }
.heading-sm { font-size: var(--text-heading-sm); letter-spacing: -.02em; line-height: 1.17; }

.lead { font-size: 16px; color: var(--color-slate); line-height: 1.6; max-width: 60ch; }
.hl { color: var(--color-signal-orange); }         /* inline highlighted word */
.muted { color: var(--color-slate); }
.small { font-size: 14px; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-8);
  font-family: var(--font-inter); font-weight: 500; font-size: 15px; letter-spacing: 0;
  padding: 13px 26px; border-radius: 8px; border: 1px solid transparent;
  transition: background-color .18s ease, border-color .18s ease, color .18s ease, transform .12s ease;
}
.btn--primary { background: var(--color-signal-orange); color: #fff; border-color: var(--color-signal-orange); }
.btn--primary:hover { background: #e24d18; border-color: #e24d18; }
.btn--ghost { background: var(--color-card-white); color: var(--color-ink); border-color: var(--color-linen-border); }
.btn--ghost:hover { background: var(--color-pebble-gray); border-color: var(--color-linen-border); }
.btn--ghost-dark { background: transparent; color: #fff; border-color: rgba(255,255,255,.22); }
.btn--ghost-dark:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.22); }
.btn:active { transform: translateY(1px); }
.btn-row { display: flex; flex-wrap: wrap; gap: var(--s-12); }

/* ---------- Focus (a11y floor) ---------- */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible {
  outline: 2px solid var(--color-signal-orange); outline-offset: 2px; border-radius: var(--r-sm);
}

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250,250,248,.85);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  box-shadow: var(--sh-nav);
}
.nav__inner { display: flex; align-items: center; gap: var(--s-24); height: 64px; }
.brand { display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: 16px; letter-spacing: -.01em; }
.brand__img { height: 38px; width: auto; display: block; }
@media (max-width: 600px) { .brand__img { height: 32px; } }
.brand__mark { width: 24px; height: 24px; flex: none; }
.nav__links { display: flex; align-items: center; gap: var(--s-8); margin-inline: auto; }
.nav__link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: 500; color: var(--color-ink);
  padding: 8px 12px; border-radius: var(--r-sm);
}
.nav__link:hover { background: var(--color-pebble-gray); }
.nav__actions { display: flex; align-items: center; gap: var(--s-12); }
.nav__actions .btn { padding: 9px 18px; font-size: 14px; }

/* Mega menu */
.has-mega { position: relative; }
.mega {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(-6px);
  margin-top: 10px;
  width: min(880px, 92vw);
  background: var(--color-card-white);
  border: 1px solid var(--color-linen-border);
  border-radius: var(--r-md);
  box-shadow: rgba(24,25,22,.08) 0 8px 24px -6px, var(--sh-card);
  padding: var(--s-24);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-24);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .16s ease, transform .16s ease, visibility .16s;
}
/* Invisible bridge so moving the mouse from the link to the panel doesn't drop the hover */
.mega::before {
  content: ""; position: absolute; left: 0; right: 0; top: -14px; height: 16px;
}
.has-mega:hover .mega,
.has-mega:focus-within .mega,
.mega[data-open="true"] { opacity: 1; visibility: visible; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.mega__col h4 { font-family: var(--font-mono); font-weight: 500; font-size: 11px; letter-spacing: .88px; text-transform: uppercase; color: var(--color-slate); margin-bottom: var(--s-8); }
.mega__item { display: flex; align-items: flex-start; gap: 11px; padding: 11px 10px; margin-inline: -10px; border-radius: var(--r-sm); font-size: 14px; font-weight: 500; position: relative; }
/* Dotted horizontal separator between items in a column */
.mega__item + .mega__item::before {
  content: ""; position: absolute; top: 0; left: 10px; right: 10px; height: 1px;
  background-image: repeating-linear-gradient(to right, var(--color-linen-border) 0 3px, transparent 3px 6px);
}
.mega__item-ic { flex: none; width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; background: var(--color-pebble-gray); border: 1px solid var(--color-linen-border); color: var(--color-slate); transition: all .15s; }
.mega__item-ic svg { width: 17px; height: 17px; }
.mega__item-body { display: block; min-width: 0; }
.mega__item-body b { display: block; font-weight: 600; color: var(--color-ink); }
.mega__item span span, .mega__item-body span { display: block; font-weight: 400; font-size: 12px; color: var(--color-stone); margin-top: 2px; line-height: 1.45; }
.mega__item:hover { background: var(--color-pebble-gray); }
.mega__item:hover .mega__item-ic { background: var(--color-signal-orange); border-color: var(--color-signal-orange); color: #fff; }

/* Mobile nav */
.nav__toggle { display: none; background: transparent; border: 1px solid var(--color-ash); border-radius: var(--r-sm); padding: 8px 10px; }
.nav__toggle svg { display: block; }
.mobile-menu { display: none; }   /* hidden on desktop; shown via media query + toggle */

@media (max-width: 900px) {
  .nav__links, .nav__actions .btn--ghost { display: none; }
  .nav__actions { margin-left: auto; }
  .nav__toggle { display: inline-flex; }
  .mobile-menu { display: none; border-top: 1px solid var(--color-linen-border); background: var(--color-cream-paper); padding: var(--s-16) var(--s-24) var(--s-24); }
  .mobile-menu[data-open="true"] { display: block; }
  .mobile-menu a { display: block; padding: 10px 0; font-weight: 500; border-bottom: 1px solid var(--color-linen-border); }
  .mobile-menu details summary { padding: 10px 0; font-weight: 600; cursor: pointer; list-style: none; }
  .mobile-menu details summary::-webkit-details-marker { display: none; }
  .mobile-menu details a { padding-left: 12px; font-weight: 400; color: var(--color-carbon); }
  .mobile-menu .btn { display: flex; justify-content: center; margin-top: var(--s-16); }
}

/* ---------- Hero ---------- */
.hero { padding-block: var(--s-72) var(--s-48); }
.hero__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: var(--s-48); align-items: center; }
@media (max-width: 900px) { .hero__grid { grid-template-columns: 1fr; gap: var(--s-32); } }

/* ---------- Terminal panel (signature) ---------- */
.terminal {
  background: var(--color-ink);
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow: rgba(24,25,22,.18) 0 12px 32px -12px;
  font-family: var(--font-mono);
}
.terminal__bar { display: flex; align-items: center; gap: 8px; padding: 12px 16px; border-bottom: 1px solid #2a2a29; }
.terminal__dot { width: 10px; height: 10px; border-radius: 50%; background: #3a3a38; }
.terminal__tab { margin-left: 10px; font-size: 11px; letter-spacing: .88px; text-transform: uppercase; color: #8b8b88; font-weight: 500; }
.terminal__body { padding: var(--s-24); font-size: 13px; line-height: 1.62; color: #cfcfcc; white-space: pre; overflow-x: auto; }
.terminal__body .tk-key { color: var(--color-sky-token); }
.terminal__body .tk-str { color: var(--color-teal-token); }
.terminal__body .tk-kw  { color: var(--color-orchid-token); }
.terminal__body .tk-num { color: var(--color-orchid-token); }
.terminal__body .tk-pun { color: #abb2bf; }
.terminal__body .tk-cmt { color: #6b6b68; }
.terminal__body .tk-ok  { color: var(--color-success-green); }
.terminal__body .tk-prompt { color: var(--color-signal-orange); }
.cursor { display: inline-block; width: 8px; height: 15px; vertical-align: -2px; background: var(--color-signal-orange); animation: blink 1.1s step-end infinite; }
@keyframes blink { 50% { opacity: 0; } }

/* ---------- Cards ---------- */
.card {
  background: var(--color-card-white);
  border: 1px solid var(--color-linen-border);
  border-radius: var(--r-md);
  padding: var(--s-24);
  box-shadow: var(--sh-card);
}
.card__icon { color: var(--color-signal-orange); margin-bottom: var(--s-16); }
.card__icon svg { width: 22px; height: 22px; stroke-width: 1.5; }
.card h3 { font-size: 16px; font-weight: 600; }
.card p { font-size: 14px; color: var(--color-slate); line-height: 1.6; margin-top: var(--s-8); }
.card--link { transition: border-color .15s ease, transform .15s ease; }
.card--link:hover { border-color: var(--color-burnt-orange); transform: translateY(-2px); }
.card__more { display: inline-block; margin-top: var(--s-16); font-size: 13px; font-weight: 500; color: var(--color-persimmon); font-family: var(--font-mono); letter-spacing: .2px; }

.grid { display: grid; gap: var(--s-24); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 900px) { .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .grid-3, .grid-4, .grid-2 { grid-template-columns: 1fr; } }

/* ---------- Section head ---------- */
.section-head { max-width: 640px; margin-bottom: var(--s-48); }
.section-head .heading { margin-top: var(--s-12); }
.section-head .lead { margin-top: var(--s-16); }

/* ---------- Stats ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-48); }
@media (max-width: 720px) { .stats { grid-template-columns: repeat(2, 1fr); gap: var(--s-32); } }
.stat__num { font-size: var(--text-heading); font-weight: 600; color: var(--color-signal-orange); letter-spacing: -.02em; line-height: 1; }
.stat__cap { font-size: 14px; color: var(--color-slate); line-height: 1.5; margin-top: var(--s-8); }

/* ---------- Tech / platform chips ---------- */
.chips { display: flex; flex-wrap: wrap; gap: var(--s-8); }
.chip { font-family: var(--font-mono); font-size: 13px; font-weight: 470; padding: 8px 14px; border: 1px solid var(--color-linen-border); border-radius: var(--r-sm); background: var(--color-card-white); color: var(--color-carbon); }
.chip b { color: var(--color-signal-orange); font-weight: 470; }

/* ---------- Areas served ---------- */
.area-card { display: flex; gap: var(--s-16); align-items: flex-start; }
.area-card__pin { color: var(--color-signal-orange); flex: none; margin-top: 2px; }
.area-card h3 { font-size: 16px; }
.area-card p { font-size: 14px; color: var(--color-slate); margin-top: var(--s-4); line-height: 1.6; }

/* ---------- CTA band ---------- */
/* ---------- CTA band (light + textured) ---------- */
.cta-band {
  position: relative; overflow: hidden;
  border: 1px solid var(--color-linen-border);
  border-radius: var(--r-lg);
  padding: 44px 32px;
  text-align: center;
  color: var(--color-ink);
  background-color: var(--color-card-white);
  background-image:
    radial-gradient(circle at 12% 16%, rgba(243,91,34,.07), transparent 42%),
    radial-gradient(circle at 88% 92%, rgba(243,91,34,.05), transparent 46%),
    radial-gradient(rgba(20,20,21,.05) 1px, transparent 1px);
  background-size: auto, auto, 18px 18px;
}
.cta-band .heading { color: var(--color-ink); }
.cta-band .lead { color: var(--color-slate); margin: var(--s-16) auto 0; }
.cta-band .btn-row { justify-content: center; margin-top: var(--s-32); position: relative; }
@media (max-width: 600px) { .cta-band { padding: 32px 20px; } }

/* Dark full-width CTA (startup style) */
.section--cta { padding-block: var(--s-48); }
.cta-band--dark {
  background-color: var(--color-ink);
  background-image:
    radial-gradient(circle at 12% 16%, rgba(243,91,34,.18), transparent 45%),
    radial-gradient(circle at 88% 90%, rgba(243,91,34,.12), transparent 48%),
    radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: auto, auto, 20px 20px;
  border: none;
  padding: 64px 48px;
}
.cta-band--dark .eyebrow { color: rgba(255,255,255,.45); }
.cta-band--dark .heading { color: #fff; }
.cta-band--dark .heading .hl { color: var(--color-apricot); }
.cta-band--dark .lead { color: rgba(255,255,255,.65); max-width: 48ch; }
.cta-band--dark .btn--ghost { background: transparent; border-color: rgba(255,255,255,.22); color: #fff; }
.cta-band--dark .btn--ghost:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.22); }
@media (max-width: 600px) { .cta-band--dark { padding: 40px 24px; } }

/* ---------- Blog ---------- */
.post-card { display: flex; flex-direction: column; height: 100%; }
.post-card__meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: .6px; text-transform: uppercase; color: var(--color-stone); }
.post-card h3 { font-size: 18px; margin-top: var(--s-12); }
.post-card p { flex: 1; }
.post-card__read { margin-top: var(--s-16); }

.article { padding-block: var(--s-56) var(--s-72); }
.article__wrap { max-width: 720px; margin-inline: auto; padding-inline: var(--s-24); }
.article__head { text-align: center; }
.article__title { font-size: clamp(30px, 5vw, 46px); font-weight: 700; letter-spacing: -.03em; line-height: 1.1; color: var(--color-ink); }
.article__lead { font-size: 19px; line-height: 1.6; color: var(--color-slate); margin-top: var(--s-20); max-width: 620px; margin-inline: auto; }
.article__meta { font-family: var(--font-mono); font-size: 12px; letter-spacing: .4px; text-transform: uppercase; color: var(--color-stone); margin-top: var(--s-16); }

/* Fixed-ratio featured cover — same size regardless of upload dimensions */
.article__cover { margin: var(--s-40) 0; border-radius: 16px; overflow: hidden; border: 1px solid var(--color-linen-border); aspect-ratio: 16 / 9; background: var(--color-pebble-gray); }
.article__cover img { width: 100%; height: 100%; object-fit: cover; display: block; }

.article__body { font-size: 17px; line-height: 1.8; color: var(--color-carbon); margin-top: var(--s-40); }
.article__body h2 { font-size: 26px; margin-top: var(--s-48); margin-bottom: var(--s-16); color: var(--color-ink); letter-spacing: -.02em; }
.article__body h3 { font-size: 20px; margin-top: var(--s-32); margin-bottom: var(--s-12); color: var(--color-ink); }
.article__body p { margin-bottom: var(--s-24); }
.article__body ul, .article__body ol { margin: 0 0 var(--s-24) var(--s-20); }
.article__body li { margin-bottom: var(--s-8); }
.article__body a { color: var(--color-persimmon); text-decoration: underline; text-underline-offset: 3px; }
.article__body code { font-family: var(--font-mono); font-size: 14px; background: var(--color-pebble-gray); padding: 2px 6px; border-radius: var(--r-sm); }
.article__body pre { background: var(--color-ink); color: #cfcfcc; padding: var(--s-24); border-radius: var(--r-md); overflow-x: auto; margin-bottom: var(--s-24); font-family: var(--font-mono); font-size: 13px; line-height: 1.6; }

/* Dotted divider (matches homepage rails) */
.article__dots { height: 1px; margin-top: var(--s-56); background-image: repeating-linear-gradient(to right, var(--color-linen-border) 0 3px, transparent 3px 5px); }

.article__foot { display: flex; flex-wrap: wrap; gap: 16px; justify-content: space-between; align-items: center; margin-top: var(--s-24); }
.article__published { font-family: var(--font-mono); font-size: 12px; letter-spacing: .4px; text-transform: uppercase; color: var(--color-stone); }
.article__foot-actions { display: flex; gap: 12px; }
@media (max-width: 560px){
  .article { padding-block: var(--s-32) var(--s-48); }
  .article__wrap { padding-inline: var(--s-20); }
  .article__body { font-size: 16px; }
  .article__foot { flex-direction: column-reverse; align-items: stretch; gap: 20px; }
  .article__foot-actions { width: 100%; }
  .article__foot-actions .btn { flex: 1; justify-content: center; }
  .article__published { text-align: center; }
}
.article__body pre code { background: none; padding: 0; color: inherit; }
.article__body blockquote { border-left: 3px solid var(--color-signal-orange); padding-left: var(--s-20); color: var(--color-slate); margin: 0 0 var(--s-20); }
/* Blog inline images */
.article__body img { max-width: 100%; height: auto; border-radius: 10px; margin: var(--s-24) 0; display: block; }
.article__body figure { margin: var(--s-24) 0; }
.article__body figure img { margin: 0; }
.article__body figcaption { font-size: 13px; color: var(--color-stone); text-align: center; margin-top: 8px; }
.post-card__thumb { display: block; margin: -4px -4px 14px; border-radius: 10px; overflow: hidden; aspect-ratio: 16/9; background: var(--color-pebble-gray); }
.post-card__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---------- Footer (light, polished) ---------- */
/* ---- Footer (Fingerprint-style) ---- */
.footer { background-color: var(--color-card-white); border-top: 1px solid var(--color-linen-border); padding-block: var(--s-72) 0; margin-top: var(--section-gap); position: relative; overflow: hidden; }
.footer__top { display: grid; grid-template-columns: 1.7fr 1fr 1fr 1fr 1fr 1.1fr; gap: var(--s-32); align-items: start; }
@media (max-width: 1080px) { .footer__top { grid-template-columns: 1fr 1fr 1fr; gap: var(--s-32); } .footer__intro { grid-column: 1 / -1; margin-bottom: var(--s-16); } }
@media (max-width: 620px) { .footer__top { grid-template-columns: 1fr 1fr; gap: var(--s-24); } }
@media (max-width: 400px) { .footer__top { grid-template-columns: 1fr; } }

.footer__intro { max-width: 300px; }
.footer__brand { display: inline-flex; align-items: center; margin-bottom: var(--s-24); }
.footer__logo { height: 40px; width: auto; max-width: 100%; display: block; }

/* Newsletter */
.footer__newsletter-label { font-size: 14px; color: var(--color-slate); margin-bottom: 12px; }
.footer__newsletter-accent { color: var(--color-signal-orange); font-family: var(--font-mono); font-size: 14px; }
.footer__newsletter-form { display: flex; align-items: center; border: 1px solid var(--color-linen-border); border-radius: var(--r-sm); background: var(--color-card-white); overflow: hidden; max-width: 280px; }
.footer__newsletter-form input { flex: 1; border: none; background: transparent; padding: 11px 14px; font-size: 14px; color: var(--color-ink); outline: none; font-family: var(--font-inter); min-width: 0; }
.footer__newsletter-form input::placeholder { color: var(--color-fog); }
.footer__newsletter-form button { flex-shrink: 0; width: 42px; height: 42px; display: grid; place-items: center; background: transparent; border: none; border-left: 1px solid var(--color-linen-border); cursor: pointer; color: var(--color-slate); transition: color .15s, background-color .15s; }
.footer__newsletter-form button:hover { color: var(--color-signal-orange); background: var(--color-pebble-gray); }
.footer__newsletter-msg { font-size: 13px; margin-top: 10px; min-height: 18px; }
.footer__newsletter-msg.is-ok { color: var(--color-success-green); }
.footer__newsletter-msg.is-err { color: var(--color-persimmon); }

/* Link columns */
.footer__col h4 { color: var(--color-ink); font-size: 15px; font-weight: 600; margin-bottom: var(--s-16); }
.footer__col a { display: block; color: var(--color-slate); font-size: 14px; padding: 5px 0; transition: color .15s; }
.footer__col a:hover { color: var(--color-signal-orange); }
.footer__more { color: var(--color-persimmon) !important; font-family: var(--font-mono); font-size: 12px !important; margin-top: 8px; }
.footer__nap { font-size: 13px; line-height: 1.7; color: var(--color-slate); margin-top: var(--s-8); }
.footer__nap b { color: var(--color-graphite); font-weight: 600; }

/* Watermark */
.footer__wordmark { font-size: clamp(48px, 13vw, 190px); font-weight: 700; letter-spacing: -.04em; line-height: .85; color: rgba(20,20,21,.05); margin-top: var(--s-48); white-space: nowrap; user-select: none; pointer-events: none; overflow: hidden; }

/* Bottom bar */
.footer__bottombar { background: var(--color-cream-paper); border-top: 1px solid var(--color-linen-border); margin-top: var(--s-24); }
.footer__bottom { padding-block: var(--s-20); display: flex; justify-content: space-between; align-items: center; gap: var(--s-16); flex-wrap: wrap; font-size: 13px; color: var(--color-stone); }
.footer__bottom-left { display: flex; align-items: center; gap: var(--s-24); flex-wrap: wrap; }
.footer__bottom-left a { color: var(--color-stone); transition: color .15s; }
.footer__bottom-left a:hover { color: var(--color-signal-orange); }
.footer__bottom-right { display: flex; align-items: center; gap: var(--s-20); }
.footer__social { display: flex; gap: var(--s-16); }
.footer__social a { color: var(--color-stone); display: grid; place-items: center; transition: color .15s; }
.footer__social a svg { width: 18px; height: 18px; }
.footer__social a:hover { color: var(--color-ink); }
@media (max-width: 620px) { .footer__bottom { flex-direction: column; align-items: flex-start; gap: var(--s-16); } }


/* ---------- Build2 — side-by-side tab layout ---------- */
.build2 { display: grid; grid-template-columns: 1fr 1.2fr; gap: 48px; align-items: start; }
@media (max-width: 860px) { .build2 { grid-template-columns: 1fr; } }
.build2__tabs { display: flex; flex-direction: column; gap: 4px; }
.build2__tab { display: flex; align-items: flex-start; gap: 14px; padding: 16px; border-radius: 10px; border: 1px solid transparent; background: transparent; text-align: left; width: 100%; cursor: pointer; transition: all .15s; }
.build2__tab:hover { background: var(--color-pebble-gray); }
.build2__tab.active { background: var(--color-card-white); border-color: var(--color-linen-border); box-shadow: 0 2px 8px rgba(20,20,21,.05); }
.build2__tab-icon { width: 34px; height: 34px; border-radius: 8px; background: var(--color-pebble-gray); border: 1px solid var(--color-linen-border); display: grid; place-items: center; flex-shrink: 0; color: var(--color-slate); transition: all .15s; }
.build2__tab-icon svg { width: 16px; height: 16px; }
.build2__tab.active .build2__tab-icon { background: var(--color-signal-orange); border-color: var(--color-signal-orange); color: #fff; }
.build2__tab-body h3 { font-size: 14px; font-weight: 600; color: var(--color-ink); margin-bottom: 3px; }
.build2__tab-body p { font-size: 13px; color: var(--color-slate); line-height: 1.55; }
.build2__stage { position: sticky; top: 80px; }
.build2__slide { display: none; }
.build2__slide.active { display: block; }
@media (max-width: 860px) {
  .build2__stage { display: none; }
  .build2__slide.active { display: block; margin: 4px 0 12px; }
  .build2__tab { border: 1px solid var(--color-linen-border); background: var(--color-card-white); }
  .build2__tab.active { border-color: var(--color-signal-orange); }
}

/* ---------- Tech stack grid ---------- */
.stack-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; }
@media (max-width: 900px) { .stack-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 560px) { .stack-grid { grid-template-columns: repeat(3, 1fr); } }
.stack-item { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; padding: 18px 10px; background: var(--color-card-white); border: 1px solid var(--color-linen-border); border-radius: var(--r-md); transition: border-color .15s, box-shadow .15s; }
.stack-item:hover { border-color: var(--color-ash); box-shadow: 0 2px 10px rgba(20,20,21,.06); }
.stack-item img { width: 34px; height: 34px; object-fit: contain; }
.stack-item span { font-size: 11px; font-family: var(--font-mono); color: var(--color-slate); text-align: center; letter-spacing: -.01em; }

/* ---------- Testimonial ---------- */
.testi { max-width: 720px; margin: 0 auto; text-align: center; }
.testi__quote { font-size: clamp(17px, 2.2vw, 22px); font-weight: 500; line-height: 1.55; color: var(--color-ink); margin: 20px 0 28px; font-style: normal; }
.testi__quote em { color: var(--color-signal-orange); font-style: normal; }
.testi__who { display: flex; align-items: center; justify-content: center; gap: 12px; }
.testi__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--color-pebble-gray); border: 2px solid var(--color-linen-border); display: grid; place-items: center; font-weight: 700; font-size: 16px; color: var(--color-slate); flex-shrink: 0; }
.testi__name { font-size: 14px; font-weight: 600; color: var(--color-ink); }
.testi__role { font-size: 12px; color: var(--color-slate); margin-top: 2px; }
.logo-strip { display: flex; align-items: center; justify-content: center; gap: 40px; flex-wrap: wrap; margin-top: 36px; padding-top: 28px; border-top: 1px solid var(--color-linen-border); }

/* ---------- Dark developer section ---------- */
.dev-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
@media (max-width: 800px) { .dev-grid { grid-template-columns: 1fr; gap: 40px; } }
.dev-features { display: flex; flex-direction: column; gap: 12px; margin-top: 28px; }
.dev-feat { display: flex; align-items: flex-start; gap: 14px; padding: 16px; border-radius: 10px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); }
.dev-feat__icon { width: 32px; height: 32px; border-radius: 8px; background: rgba(243,91,34,.15); display: grid; place-items: center; flex-shrink: 0; color: var(--color-apricot); }
.dev-feat__icon svg { width: 16px; height: 16px; }
.dev-feat h4 { font-size: 13px; font-weight: 600; color: #fff; margin-bottom: 3px; }
.dev-feat p { font-size: 12px; color: rgba(255,255,255,.5); line-height: 1.55; }
.dev-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.dev-stat { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); border-radius: 10px; padding: 20px; }
.dev-stat__num { font-size: 30px; font-weight: 700; color: #fff; letter-spacing: -.02em; }
.dev-stat__cap { font-size: 12px; color: rgba(255,255,255,.4); margin-top: 4px; }
.section--dark .heading .hl { color: var(--color-apricot); }

/* ---------- Forms ---------- */
.field { margin-bottom: var(--s-16); }
.field label { display: block; font-size: 13px; font-weight: 500; color: var(--color-carbon); margin-bottom: 6px; }
.field input, .field textarea, .field select {
  width: 100%; font-family: var(--font-inter); font-size: 14px; color: var(--color-ink);
  background: var(--color-card-white); border: 1px solid var(--color-ash); border-radius: var(--r-sm);
  padding: 10px 12px;
}
.field textarea { min-height: 140px; resize: vertical; }
.field--mono textarea, .field--mono input { font-family: var(--font-mono); }

/* ---------- Admin ---------- */
.admin-shell { min-height: 100vh; background: var(--color-pebble-gray); }
.admin-top { background: var(--color-ink); color: #fff; }
.admin-top .wrap { display: flex; align-items: center; justify-content: space-between; height: 60px; }
.admin-top a { color: #b7b7b4; font-size: 14px; }
.admin-top a:hover { color: #fff; }
.admin-card { background: #fff; border: 1px solid var(--color-linen-border); border-radius: var(--r-md); padding: var(--s-24); box-shadow: var(--sh-card); }
.admin-login { max-width: 380px; margin: 96px auto; }
.table { width: 100%; border-collapse: collapse; }
.table th { text-align: left; font-family: var(--font-mono); font-size: 11px; letter-spacing: .6px; text-transform: uppercase; color: var(--color-slate); padding: 10px 12px; border-bottom: 1px solid var(--color-linen-border); }
.table td { padding: 12px; border-bottom: 1px solid var(--color-linen-border); font-size: 14px; vertical-align: middle; }
.badge { font-family: var(--font-mono); font-size: 11px; letter-spacing: .4px; padding: 3px 8px; border-radius: var(--r-sm); }
.badge--pub { background: rgba(98,176,109,.15); color: var(--color-forest); }
.badge--draft { background: var(--color-pebble-gray); color: var(--color-slate); }

.alert { padding: 12px 16px; border-radius: var(--r-sm); font-size: 14px; margin-bottom: var(--s-16); }
.alert--err { background: rgba(246,121,118,.14); color: var(--color-burnt-orange); border: 1px solid rgba(246,121,118,.3); }
.alert--ok { background: rgba(98,176,109,.14); color: var(--color-forest); border: 1px solid rgba(98,176,109,.3); }

/* ---------- Breadcrumb ---------- */
.crumb { font-family: var(--font-mono); font-size: 12px; color: var(--color-stone); letter-spacing: .3px; }
.crumb a:hover { color: var(--color-persimmon); }
.crumb .sep { color: var(--color-persimmon); margin-inline: 6px; }

/* ---------- Skip link ---------- */
.skip { position: absolute; left: -9999px; top: 0; background: var(--color-ink); color: #fff; padding: 10px 16px; border-radius: var(--r-sm); z-index: 100; }
.skip:focus { left: 12px; top: 12px; }

/* ---------- Page hero (interior) ---------- */
.page-hero { padding-block: var(--s-56) var(--s-32); }
.page-hero .display { margin-top: var(--s-16); max-width: 16ch; }
.page-hero .lead { margin-top: var(--s-16); }

/* =========================================================================
   RICHER HOMEPAGE COMPONENTS (v2): logo strip, dark stat band,
   feature rows, browser + dashboard mockups, API panels, device cards.
   ========================================================================= */

/* ---- Tech logo strip ---- */
.logostrip { border-block: 1px solid var(--color-linen-border); background: var(--color-card-white); }
.logostrip__row { display: flex; align-items: center; justify-content: flex-start; gap: var(--s-32); padding-block: 18px; }
.logostrip__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .88px; text-transform: uppercase; color: var(--color-stone); white-space: nowrap; }
.logostrip__logos { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; }
.logostrip__logos span { display: inline-flex; align-items: center; gap: 8px; color: var(--color-fog); font-weight: 600; font-size: 15px; letter-spacing: -.01em; transition: color .15s ease; }
.logostrip__logos span:hover { color: var(--color-carbon); }
.logostrip__logos svg { width: 20px; height: 20px; }

/* ---- Dark section (rhythm) ---- */
.section--dark { background: var(--color-ink); color: #d7d7d4; }
.section--dark .heading, .section--dark .heading-sm { color: #fff; }
.section--dark .lead { color: #9a9a97; }
.section--dark .eyebrow--muted { color: #7a7a77; }

/* Stats on dark */
.stats--dark .stat__num { color: var(--color-signal-orange); }
.stats--dark .stat__cap { color: #9a9a97; }
.stats--dark { border: 0; }

/* ---- Feature rows (alternating text / visual) ---- */
.feature { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-56); align-items: center; }
.feature + .feature { margin-top: var(--s-96); }
.feature--flip .feature__text { order: 2; }
.feature--flip .feature__visual { order: 1; }
.feature__text .eyebrow { margin-bottom: var(--s-16); }
.feature__text .heading-sm { max-width: 16ch; }
.feature__text .lead { margin-top: var(--s-16); }
.feature__list { margin-top: var(--s-20); display: flex; flex-direction: column; gap: var(--s-12); }
.feature__list li { list-style: none; display: flex; gap: 10px; font-size: 15px; color: var(--color-carbon); }
.feature__list svg { color: var(--color-signal-orange); flex: none; margin-top: 3px; width: 16px; height: 16px; }
.feature__more { margin-top: var(--s-24); }
@media (max-width: 860px) {
  .feature { grid-template-columns: 1fr; gap: var(--s-32); }
  .feature--flip .feature__text { order: 1; }
  .feature--flip .feature__visual { order: 2; }
}

/* ---- Browser window mockup ---- */
.browser { background: var(--color-card-white); border: 1px solid var(--color-linen-border); border-radius: var(--r-md); overflow: hidden; box-shadow: rgba(24,25,22,.10) 0 18px 40px -18px, var(--sh-card); }
.browser__bar { display: flex; align-items: center; gap: 8px; padding: 10px 14px; border-bottom: 1px solid var(--color-linen-border); background: var(--color-pebble-gray); }
.browser__dot { width: 10px; height: 10px; border-radius: 50%; }
.browser__dot--r { background: #e06c5b; } .browser__dot--y { background: #e3b341; } .browser__dot--g { background: #7fb885; }
.browser__url { margin-left: 10px; flex: 1; font-family: var(--font-mono); font-size: 11px; color: var(--color-slate); background: var(--color-card-white); border: 1px solid var(--color-linen-border); border-radius: var(--r-sm); padding: 4px 10px; }
.browser__body { padding: 0; }

/* Mini dashboard inside the browser */
.dash { display: grid; grid-template-columns: 128px 1fr; min-height: 300px; }
.dash__side { background: var(--color-ink); padding: 16px 14px; }
.dash__brand { color: #fff; font-weight: 600; font-size: 13px; display: flex; align-items: center; gap: 7px; margin-bottom: 18px; }
.dash__brand span { width: 14px; height: 14px; border-radius: 4px; background: var(--color-signal-orange); display: inline-block; }
.dash__nav { display: flex; flex-direction: column; gap: 4px; }
.dash__nav i { height: 9px; border-radius: 3px; background: #3a3a38; }
.dash__nav i.on { background: var(--color-signal-orange); opacity: .9; width: 70%; }
.dash__nav i:nth-child(2){width:85%} .dash__nav i:nth-child(3){width:60%} .dash__nav i:nth-child(4){width:75%} .dash__nav i:nth-child(5){width:55%}
.dash__main { padding: 18px; background: var(--color-cream-paper); }
.dash__cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-bottom: 14px; }
.dash__stat { background: #fff; border: 1px solid var(--color-linen-border); border-radius: 8px; padding: 10px; }
.dash__stat b { display: block; font-size: 18px; color: var(--color-ink); letter-spacing: -.02em; }
.dash__stat em { font-family: var(--font-mono); font-style: normal; font-size: 9px; letter-spacing: .5px; text-transform: uppercase; color: var(--color-stone); }
.dash__stat.up b { color: var(--color-signal-orange); }
.dash__chart { background: #fff; border: 1px solid var(--color-linen-border); border-radius: 8px; padding: 14px; display: flex; align-items: flex-end; gap: 7px; height: 120px; }
.dash__chart i { flex: 1; background: var(--color-linen-border); border-radius: 3px 3px 0 0; }
.dash__chart i.hot { background: var(--color-signal-orange); }

/* ---- API / code panel body (reuse .terminal) ---- */
.terminal--tall .terminal__body { min-height: 300px; }

/* ---- Device / data card cluster (e-commerce/product mock) ---- */
.mockcluster { position: relative; min-height: 320px; }
.mock-card { background: #fff; border: 1px solid var(--color-linen-border); border-radius: var(--r-md); box-shadow: var(--sh-card); }
.mock-product { padding: 16px; }
.mock-product__img { height: 120px; border-radius: 8px; background: linear-gradient(135deg, var(--color-pebble-gray), #e9e9e7); border: 1px solid var(--color-linen-border); display:flex; align-items:center; justify-content:center; color: var(--color-fog); }
.mock-product__img svg { width: 40px; height: 40px; }
.mock-product h5 { font-size: 14px; margin-top: 12px; }
.mock-product .price { color: var(--color-signal-orange); font-weight: 600; margin-top: 4px; }
.mock-product .buy { margin-top: 12px; background: var(--color-signal-orange); color:#fff; text-align:center; font-size:12px; font-weight:500; padding:8px; border-radius: var(--r-sm); }
.mock-float { position: absolute; right: -6px; bottom: 6px; width: 210px; padding: 14px; }
.mock-float .row { display: flex; justify-content: space-between; align-items: center; padding: 5px 0; }
.mock-float .row + .row { border-top: 1px solid var(--color-linen-border); }
.mock-float .k { font-size: 11px; color: var(--color-slate); font-weight: 500; }
.mock-float .v { font-family: var(--font-mono); font-size: 12px; color: var(--color-ink); }
.mock-float .v.ok { color: var(--color-forest); }
@media (max-width: 520px) { .mock-float { position: static; width: auto; margin-top: 12px; } }

/* ---- Signals / site-health card (device-detection card pattern) ---- */
.signalcard { background: var(--color-card-white); border: 1px solid var(--color-linen-border); border-radius: var(--r-md); padding: var(--s-20) var(--s-24); box-shadow: var(--sh-card); max-width: 380px; }
.signalcard__head { display: flex; align-items: center; justify-content: space-between; padding-bottom: var(--s-12); border-bottom: 1px solid var(--color-linen-border); margin-bottom: var(--s-4); }
.signalcard__title { font-family: var(--font-mono); font-size: 11px; letter-spacing: .88px; text-transform: uppercase; color: var(--color-slate); }
.signalcard__badge { font-family: var(--font-mono); font-size: 11px; padding: 3px 9px; border-radius: var(--r-sm); background: rgba(98,176,109,.15); color: var(--color-forest); }
.signalrow { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--color-linen-border); }
.signalrow:last-child { border-bottom: 0; }
.signalrow .k { font-size: 12px; font-weight: 500; color: var(--color-slate); }
.signalrow .v { font-family: var(--font-mono); font-size: 13px; color: var(--color-ink); }
.signalrow .v.ok  { color: var(--color-forest); }
.signalrow .v.hot { color: var(--color-signal-orange); }

/* ---- Score gauge (Lighthouse-style) ---- */
.gauge { display: flex; align-items: center; gap: var(--s-20); }
.gauge__ring { width: 96px; height: 96px; border-radius: 50%; flex: none; display: grid; place-items: center; background:
   conic-gradient(var(--color-signal-orange) calc(var(--v,98) * 1%), var(--color-linen-border) 0); }
.gauge__ring b { width: 74px; height: 74px; border-radius: 50%; background: var(--color-card-white); display: grid; place-items: center; font-size: 24px; font-weight: 600; letter-spacing: -.02em; color: var(--color-ink); }
.gauge__meta .k { font-family: var(--font-mono); font-size: 11px; letter-spacing: .6px; text-transform: uppercase; color: var(--color-stone); }
.gauge__meta .t { font-size: 15px; font-weight: 600; margin-top: 2px; }

/* ---- Use-case / problem cards ---- */
.usecase { display: flex; flex-direction: column; height: 100%; }
.usecase .tag { font-family: var(--font-mono); font-size: 11px; letter-spacing: .5px; text-transform: uppercase; color: var(--color-persimmon); }
.usecase h3 { font-size: 17px; margin-top: 8px; }
.usecase p { margin-top: 8px; }

/* =========================================================================
   ACCORDION + RADAR/SIGNALS SECTION  +  MOBILE TYPE TUNING
   ========================================================================= */

/* Two-column: accordion | radar panel */
.solve-grid { display: grid; grid-template-columns: 1fr 1.15fr; gap: var(--s-48); align-items: stretch; }
@media (max-width: 900px) { .solve-grid { grid-template-columns: 1fr; gap: var(--s-32); } }

/* ---- Accordion (Use Case Item pattern) ---- */
.accordion { display: flex; flex-direction: column; gap: var(--s-8); }
.acc-item { background: var(--color-card-white); border: 1px solid var(--color-linen-border); border-radius: var(--r-sm); box-shadow: var(--sh-card); overflow: hidden; }
.acc-item > summary { list-style: none; cursor: pointer; display: flex; align-items: center; gap: var(--s-12); padding: 16px 20px; font-size: 16px; font-weight: 600; color: var(--color-ink); }
.acc-item > summary::-webkit-details-marker { display: none; }
.acc-item summary .acc-ico { color: var(--color-signal-orange); flex: none; display: inline-flex; }
.acc-item summary .acc-ico svg { width: 20px; height: 20px; }
.acc-item summary .acc-chev { margin-left: auto; color: var(--color-stone); transition: transform .2s ease; flex: none; }
.acc-item[open] summary .acc-chev { transform: rotate(180deg); }
.acc-item[open] > summary { color: var(--color-ink); }
.acc-body { padding: 0 20px 18px 52px; font-size: 14px; line-height: 1.6; color: var(--color-carbon); }
.acc-body .acc-link { display: inline-block; margin-top: 10px; font-family: var(--font-mono); font-size: 12px; letter-spacing: .3px; color: var(--color-persimmon); }
.acc-item[open] { border-color: var(--color-ash); }

/* ---- Radar + signals composite card ---- */
.radarpanel { background: var(--color-card-white); border: 1px solid var(--color-linen-border); border-radius: var(--r-md); box-shadow: var(--sh-card); display: grid; grid-template-columns: 1.25fr 1fr; overflow: hidden; }
@media (max-width: 560px) { .radarpanel { grid-template-columns: 1fr; } }
.radar { position: relative; padding: var(--s-20); display: flex; align-items: center; justify-content: center; min-height: 300px; background:
   radial-gradient(circle at 30% 75%, rgba(243,91,34,.04), transparent 60%); }
.radar svg { width: 100%; height: auto; max-width: 300px; }
.radar__ring { fill: none; stroke: var(--color-linen-border); }
.radar__sweep { stroke: var(--color-ash); stroke-dasharray: 3 4; }
.radar__dot { transform-box: fill-box; transform-origin: center; }
.radar__pulse { animation: pulse 2.4s ease-out infinite; transform-origin: center; }
@keyframes pulse { 0% { r: 4; opacity: .9; } 70% { r: 13; opacity: 0; } 100% { opacity: 0; } }

/* Signals panel (right of radar) */
.radar__signals { border-left: 1px solid var(--color-linen-border); padding: var(--s-20) var(--s-24); display: flex; flex-direction: column; justify-content: center; gap: 2px; }
@media (max-width: 560px) { .radar__signals { border-left: 0; border-top: 1px solid var(--color-linen-border); } }
.sig { padding: 9px 0; }
.sig + .sig { border-top: 1px solid var(--color-linen-border); }
.sig .lab { font-family: var(--font-mono); font-size: 11px; letter-spacing: .6px; color: var(--color-stone); text-transform: none; }
.sig .lab::after { content: "_"; color: var(--color-fog); }
.sig .val { font-size: 14px; font-weight: 500; color: var(--color-ink); margin-top: 3px; }
.sig .val.mono { font-family: var(--font-mono); font-weight: 470; }
.sig .val.hot { color: var(--color-signal-orange); }
.sig .val.ok  { color: var(--color-forest); }
.sig .val .warn { color: var(--color-signal-orange); }

/* ---- Mobile type tuning (readable, not oversized) ---- */
@media (max-width: 600px) {
  body { font-size: 15px; }
  .wrap { padding-inline: 18px; }
  .section { padding-block: var(--s-48); }
  .section-head { margin-bottom: var(--s-32); }
  .heading-sm { font-size: 22px; line-height: 1.2; }
  .lead { font-size: 15px; }
  .stat__num { font-size: 30px; }
  .stats { gap: var(--s-24) var(--s-16); }
  .terminal__body { font-size: 12px; padding: var(--s-16); line-height: 1.55; }
  .cta-band { padding: var(--s-32) var(--s-20); }
  .feature + .feature { margin-top: var(--s-56); }
  .btn { width: auto; }
  .btn-row .btn { flex: 1 1 auto; justify-content: center; }
}
@media (max-width: 380px) {
  .display { font-size: 30px; letter-spacing: -.02em; }
}

/* =========================================================================
   INTERACTIVE "WHAT WE BUILD" — click a row, the visual swaps.
   ========================================================================= */
.build { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: var(--s-56); align-items: start; }
@media (max-width: 900px) { .build { grid-template-columns: 1fr; gap: var(--s-28); } }

.build__list { display: flex; flex-direction: column; }
.build__item { width: 100%; text-align: left; background: none; border: 0; border-top: 1px solid var(--color-linen-border); padding: 20px 4px; cursor: pointer; display: block; }
.build__list .build__item:last-child { border-bottom: 1px solid var(--color-linen-border); }
.build__head { display: flex; align-items: center; gap: 14px; }
.build__ico { color: var(--color-fog); display: inline-flex; transition: color .2s ease; }
.build__ico svg { width: 20px; height: 20px; }
.build__title { font-size: 18px; font-weight: 600; letter-spacing: -.01em; color: var(--color-stone); transition: color .2s ease; }
.build__plus { margin-left: auto; color: var(--color-fog); font-size: 18px; line-height: 1; transition: transform .25s ease, color .2s ease; }
.build__item[aria-expanded="true"] .build__title { color: var(--color-ink); }
.build__item[aria-expanded="true"] .build__ico  { color: var(--color-signal-orange); }
.build__item[aria-expanded="true"] .build__plus { transform: rotate(45deg); color: var(--color-signal-orange); }
.build__body { display: block; max-height: 0; overflow: hidden; opacity: 0; transition: max-height .3s ease, opacity .25s ease, margin .3s ease; }
.build__item[aria-expanded="true"] .build__body { max-height: 320px; opacity: 1; margin-top: 12px; }
.build__body p { font-size: 15px; line-height: 1.6; color: var(--color-carbon); padding-left: 34px; }
.build__mobile-visual { display: none; }

/* Stage that swaps visuals */
.build__stage { position: relative; min-height: 360px; }
@media (max-width: 900px) { .build__stage { display: none; } }   /* on mobile we inline each visual */
.build__slide { position: absolute; inset: 0; opacity: 0; visibility: hidden; transform: translateY(10px); transition: opacity .35s ease, transform .35s ease, visibility .35s; }
.build__slide.is-active { position: relative; opacity: 1; visibility: visible; transform: none; }
@media (prefers-reduced-motion: reduce) { .build__slide { transition: none; } }

/* On mobile, show the active item's visual inline under its text */
@media (max-width: 900px) {
  .build__mobile-visual { display: none; margin-top: 16px; }
  .build__item[aria-expanded="true"] .build__mobile-visual { display: block; }
}

/* keep the swap visuals from stretching oddly */
.build__slide .browser, .build__slide .terminal, .build__slide .radarpanel, .build__slide .card, .build__mobile-visual .browser, .build__mobile-visual .terminal, .build__mobile-visual .radarpanel, .build__mobile-visual .card,
.build2__slide .browser, .build2__slide .terminal, .build2__slide .radarpanel, .build2__slide .card, .build2__slide .mockcluster { width: 100%; max-width: 100%; }

/* ---- Mobile overflow safety ---- */
html, body { overflow-x: hidden; max-width: 100%; }
@media (max-width: 600px) {
  .terminal__body { white-space: pre-wrap; word-break: break-word; }
  .browser__url { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .hero__grid, .build, .build2 { min-width: 0; }
  .terminal, .browser, .card, .radarpanel, .mockcluster { max-width: 100%; }
  /* Dashboard visual: shrink sidebar, keep stat cards inside the screen */
  .dash { grid-template-columns: 92px 1fr; min-height: 0; }
  .dash__side { padding: 12px 10px; }
  .dash__main { padding: 12px; min-width: 0; }
  .dash__cards { gap: 6px; }
  .dash__stat { padding: 7px; min-width: 0; }
  .dash__stat b { font-size: 14px; }
  .dash__stat em { font-size: 8px; }
  .dash__chart { height: 90px; padding: 10px; gap: 4px; }
  /* Hero demo grid stacks on mobile */
  .herodemo__grid { grid-template-columns: 1fr; }
  .mockcluster { flex-wrap: wrap; }
}

/* ---- Logo strip: single inline scrolling row on mobile ---- */
@media (max-width: 760px) {
  .logostrip__row { flex-direction: column; align-items: flex-start; gap: 10px; padding-block: 14px; }
  .logostrip__logos { flex-wrap: nowrap; overflow-x: auto; gap: 22px; width: 100%; scrollbar-width: none; -ms-overflow-style: none; padding-bottom: 2px; }
  .logostrip__logos::-webkit-scrollbar { display: none; }
  .logostrip__logos span { white-space: nowrap; flex: none; font-size: 14px; }
}

/* =========================================================================
   CENTERED HERO + PRODUCT DEMO CARD + CENTERED TRUSTED ROW
   ========================================================================= */
.hero--center { text-align: center; padding-block: 56px 8px; }
.hero--center .lead { margin-left: auto; margin-right: auto; }
.display--xl { font-size: clamp(36px, 5.8vw, 58px); font-weight: 700; letter-spacing: -.035em; line-height: 1.08; }
.hero__btns { justify-content: center; margin-top: 28px; }
.hero__btns .btn { padding: 11px 22px; font-size: 14px; }
.btn--line { background: var(--color-card-white); color: var(--color-ink); border: 1px solid var(--color-linen-border); }
.btn--line:hover { background: var(--color-pebble-gray); border-color: var(--color-linen-border); }

.herodemo { max-width: 940px; margin: 48px auto 0; background: var(--color-card-white); border: 1px solid var(--color-linen-border); border-radius: var(--r-lg); box-shadow: rgba(24,25,22,.10) 0 24px 60px -24px, var(--sh-card); overflow: hidden; text-align: left; }
.herodemo__bar { display: flex; align-items: center; justify-content: flex-end; padding: 12px 20px; border-bottom: 1px solid var(--color-linen-border); }
.herodemo__toggle { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .6px; text-transform: uppercase; color: var(--color-stone); }
.herodemo__toggle i { width: 30px; height: 16px; border-radius: 20px; background: var(--color-signal-orange); position: relative; }
.herodemo__toggle i::after { content: ""; position: absolute; top: 2px; right: 2px; width: 12px; height: 12px; border-radius: 50%; background: #fff; }
.herodemo__grid { display: grid; grid-template-columns: 1.7fr 1fr; }
@media (max-width: 720px) { .herodemo__grid { grid-template-columns: 1fr; } }
.herodemo__left { padding: 20px 24px; min-width: 0; }
.herodemo__right { padding: 24px; border-left: 1px solid var(--color-linen-border); display: flex; flex-direction: column; align-items: center; text-align: center; justify-content: center; gap: 5px; }
@media (max-width: 720px) { .herodemo__right { border-left: 0; border-top: 1px solid var(--color-linen-border); } }
.herodemo__hello { font-size: 15px; font-weight: 500; color: var(--color-ink); }
.herodemo__hello b { font-family: var(--font-mono); font-weight: 500; color: var(--color-signal-orange); }
.demotiles { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin: 16px 0; }
@media (max-width: 520px) { .demotiles { grid-template-columns: repeat(2,1fr); } }
.demotile .k { font-family: var(--font-mono); font-size: 10px; letter-spacing: .4px; text-transform: uppercase; color: var(--color-stone); }
.demotile .v { font-size: 14px; font-weight: 600; color: var(--color-ink); margin-top: 3px; }
.demolabel { font-family: var(--font-mono); font-size: 10px; letter-spacing: .6px; text-transform: uppercase; color: var(--color-stone); margin: 4px 0 10px; }
.demorecent { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 520px) { .demorecent { grid-template-columns: 1fr; } }
.demorow { display: flex; justify-content: space-between; padding: 8px 0; border-top: 1px solid var(--color-linen-border); font-size: 13px; }
.demorow .lab { color: var(--color-slate); } .demorow .val { font-family: var(--font-mono); color: var(--color-ink); } .demorow .val.ok { color: var(--color-forest); }
.demomap { border: 1px solid var(--color-linen-border); border-radius: 10px; min-height: 118px; position: relative; overflow: hidden; background:
   linear-gradient(0deg, rgba(243,91,34,.03), rgba(243,91,34,.03)),
   repeating-linear-gradient(0deg, transparent 0 15px, rgba(0,0,0,.028) 15px 16px),
   repeating-linear-gradient(90deg, transparent 0 15px, rgba(0,0,0,.028) 15px 16px),
   var(--color-cream-paper); }
.demomap .place { position: absolute; top: 8px; left: 10px; font-size: 11px; color: var(--color-slate); font-weight: 500; }
.demomap .pin { position: absolute; left: 52%; top: 55%; width: 12px; height: 12px; border-radius: 50%; background: var(--color-signal-orange); box-shadow: 0 0 0 5px rgba(243,91,34,.18); }
.herodemo__note { padding: 12px 24px; border-top: 1px solid var(--color-linen-border); font-family: var(--font-mono); font-size: 10px; letter-spacing: .4px; text-transform: uppercase; color: var(--color-fog); display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; }

.semi { width: 178px; }
.semi svg { width: 100%; height: auto; display: block; }
.semi__num { font-size: 34px; font-weight: 700; letter-spacing: -.02em; color: var(--color-ink); margin-top: -26px; text-align: center; }
.herodemo__verdict { font-size: 16px; font-weight: 600; color: var(--color-ink); margin-top: 4px; }
.herodemo__verdict .tag { font-family: var(--font-mono); background: rgba(98,176,109,.16); color: var(--color-forest); padding: 1px 8px; border-radius: 5px; font-size: 14px; }
.herodemo__sub2 { font-size: 13px; color: var(--color-slate); }
.herodemo__link { font-size: 12px; color: var(--color-persimmon); text-decoration: underline; text-underline-offset: 3px; }
.herodemo__devs { display: flex; gap: 16px; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--color-linen-border); width: 100%; justify-content: center; font-size: 12px; }
.herodemo__devs span.on { color: var(--color-ink); font-weight: 600; border-bottom: 2px solid var(--color-signal-orange); padding-bottom: 3px; }
.herodemo__devs span { color: var(--color-stone); }

.trusted { text-align: center; padding-block: 44px 8px; }
.trusted__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .88px; text-transform: uppercase; color: var(--color-stone); }
.trusted__logos { display: flex; align-items: center; justify-content: center; gap: 36px; flex-wrap: wrap; margin-top: 20px; }
.trusted__logos span { color: var(--color-fog); font-weight: 600; font-size: 16px; letter-spacing: -.01em; }
@media (max-width: 760px) {
  .trusted__logos { flex-wrap: nowrap; overflow-x: auto; gap: 26px; justify-content: flex-start; scrollbar-width: none; }
  .trusted__logos::-webkit-scrollbar { display: none; }
  .trusted__logos span { white-space: nowrap; flex: none; font-size: 14px; }
}

/* =========================================================================
   COLORFUL TECH LOGOS · BIG STAT COUNTERS · WHY SECTION + CHART
   ========================================================================= */

/* Colorful trusted logos */
.trusted__logos .tlogo { display: inline-flex; align-items: center; gap: 8px; color: var(--color-carbon); font-weight: 600; font-size: 15px; letter-spacing: -.01em; }
.trusted__logos .tlogo svg { display: block; flex: none; }
@media (max-width: 760px) { .trusted__logos .tlogo { white-space: nowrap; flex: none; font-size: 14px; } }

/* Big stat counters (image 3 style) */
.statbig { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-32); }
@media (max-width: 820px) { .statbig { grid-template-columns: repeat(2, 1fr); gap: 32px 24px; } }
@media (max-width: 460px) { .statbig { grid-template-columns: 1fr; } }
.statbig__item { padding-left: 20px; border-left: 2px solid var(--color-signal-orange); }
.statbig__num { font-size: clamp(30px, 3.6vw, 44px); font-weight: 700; color: var(--color-signal-orange); letter-spacing: -.02em; line-height: 1; }
.statbig__cap { font-family: var(--font-mono); font-size: 12px; line-height: 1.55; color: var(--color-slate); margin-top: 12px; }
.statbig__cap::after { content: "_"; color: var(--color-fog); }

/* Why section (image 2 style) */
.why { display: grid; grid-template-columns: 1.15fr 1fr; gap: var(--s-40, 40px); align-items: stretch; }
@media (max-width: 900px) { .why { grid-template-columns: 1fr; gap: var(--s-24); } }
.why__panel { background: var(--color-pebble-gray); border: 1px solid var(--color-linen-border); border-radius: var(--r-lg); padding: 36px; }
.why__panel .heading-sm { max-width: 16ch; margin-top: 12px; }
.why__panel .lead { margin-top: 14px; max-width: 42ch; }
.why__cards { display: flex; flex-direction: column; gap: 16px; }
.whycard { background: var(--color-card-white); border: 1px solid var(--color-linen-border); border-radius: var(--r-md); padding: 22px 24px; box-shadow: var(--sh-card); }
.whycard h3 { display: flex; align-items: center; gap: 10px; font-size: 16px; }
.whycard h3 svg { width: 18px; height: 18px; color: var(--color-signal-orange); flex: none; }
.whycard p { font-size: 14px; color: var(--color-slate); margin-top: 8px; line-height: 1.6; }
.whycard--dots { background-image: radial-gradient(var(--color-linen-border) 1.3px, transparent 1.3px); background-size: 15px 15px; }

/* Line chart */
.chart { margin-top: 28px; }
.chart svg { width: 100%; height: auto; display: block; }
.chart__legend { display: flex; gap: 20px; margin-top: 12px; font-family: var(--font-mono); font-size: 11px; color: var(--color-slate); }
.chart__legend b { display: inline-flex; align-items: center; gap: 6px; font-weight: 400; }
.chart__legend i { width: 14px; height: 2px; display: inline-block; }
.chart__x { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3px; color: var(--color-stone); margin-top: 6px; }

/* =========================================================================
   HERO DEMO — PROJECTS BOARD + PHONE MOCKUP (show full range)
   ========================================================================= */
.herodemo__grid--proj { grid-template-columns: 1.6fr 1fr; }
@media (max-width: 720px) { .herodemo__grid--proj { grid-template-columns: 1fr; } }

.projlist { margin-top: 16px; }
.projrow { display: grid; grid-template-columns: 1.1fr 1.3fr auto; align-items: center; gap: 12px; padding: 11px 0; border-top: 1px solid var(--color-linen-border); font-size: 13px; }
.projrow .pt { font-weight: 600; color: var(--color-ink); }
.projrow .ps { font-family: var(--font-mono); font-size: 12px; color: var(--color-slate); }
.pbadge { font-family: var(--font-mono); font-size: 10px; letter-spacing: .4px; text-transform: uppercase; padding: 3px 8px; border-radius: 5px; justify-self: end; white-space: nowrap; }
.pbadge.ok { background: rgba(98,176,109,.15); color: var(--color-forest); }
.pbadge.warn { background: rgba(243,91,34,.12); color: var(--color-persimmon); }
@media (max-width: 520px) { .projrow { grid-template-columns: 1fr auto; } .projrow .ps { display: none; } }

.herodemo__right--phone { padding: 22px 20px; }
.phone { width: 140px; margin: 0 auto; background: #141415; border-radius: 22px; padding: 8px; box-shadow: rgba(24,25,22,.22) 0 14px 34px -12px; }
.phone__screen { background: var(--color-cream-paper); border-radius: 15px; padding: 12px; min-height: 208px; display: flex; flex-direction: column; }
.phone__hdr { display: flex; align-items: center; gap: 7px; font-size: 11px; font-weight: 700; color: var(--color-ink); }
.phone__dot { width: 16px; height: 16px; border-radius: 5px; background: var(--color-signal-orange); }
.phone__card { height: 50px; border-radius: 8px; background: linear-gradient(135deg,#fff,var(--color-pebble-gray)); border: 1px solid var(--color-linen-border); margin-top: 12px; }
.phone__line { height: 8px; border-radius: 4px; background: var(--color-linen-border); margin-top: 10px; }
.phone__line.short { width: 62%; }
.phone__btn { margin-top: auto; background: var(--color-signal-orange); color: #fff; font-size: 11px; font-weight: 600; text-align: center; padding: 8px; border-radius: 8px; }
.phone__nav { display: flex; justify-content: space-around; margin-top: 12px; }
.phone__nav i { width: 22px; height: 4px; border-radius: 2px; background: var(--color-linen-border); }
.phone__nav i.on { background: var(--color-signal-orange); }
.phone__cap { text-align: center; font-family: var(--font-mono); font-size: 10px; letter-spacing: .5px; text-transform: uppercase; color: var(--color-stone); margin-top: 14px; }

/* ---------- Glyph feature bands (inner pages) ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:820px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:24px;background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:14px}
.step__n{font-family:var(--font-mono);font-size:12px;letter-spacing:.5px;color:var(--color-stone)}
.step__ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:rgba(243,91,34,.10);color:var(--color-persimmon);margin:14px 0 12px}
.step__ic svg{width:23px;height:23px}
.step h3{font-size:16px;margin-bottom:6px}
.step p{font-size:14px;line-height:1.6;color:var(--color-slate)}

.contact-list{display:flex;flex-direction:column;gap:12px}
.contact-item{display:flex;align-items:center;gap:14px;padding:15px 16px;background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:12px;color:inherit}
.contact-item__ic{width:44px;height:44px;flex:none;border-radius:11px;display:grid;place-items:center;background:rgba(243,91,34,.10);color:var(--color-persimmon)}
.contact-item__ic svg{width:22px;height:22px}
.contact-item b{font-size:14px;display:block}
.contact-item .sub{color:var(--color-slate);font-size:14px}
/* Contact page layout */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:32px;align-items:stretch}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:24px}}
.contact-form-card{background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:var(--r-lg);padding:36px}
@media(max-width:520px){.contact-form-card{padding:24px}}
.contact-form-card__head{margin-bottom:24px}
.contact-form-card__head h2{font-size:22px;color:var(--color-ink);letter-spacing:-.02em}
.contact-form-card__head p{font-size:14px;color:var(--color-slate);margin-top:6px}
.contact-form-card__note{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--color-stone);margin-top:16px}
.contact-form-card__note svg{width:15px;height:15px;color:var(--color-success-green);flex:none}
.contact-list{display:flex;flex-direction:column;gap:12px}
.field__err{color:var(--color-persimmon);font-size:13px;margin-top:6px}
.field .muted{color:var(--color-stone);font-weight:400}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:520px){.field-row{grid-template-columns:1fr;gap:0}}
.field input::placeholder,.field textarea::placeholder{color:var(--color-fog)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--color-signal-orange);box-shadow:0 0 0 3px rgba(243,91,34,.12)}
.field--captcha input{max-width:150px}
.contact-submit{width:100%;margin-top:4px;gap:8px}
.contact-submit svg{width:16px;height:16px}

/* Dark contact panel (right side) */
.contact-side{display:flex}
.contact-panel{background:var(--color-ink);border-radius:var(--r-lg);padding:36px;color:#fff;width:100%;position:relative;overflow:hidden;
  background-image:radial-gradient(circle at 90% 8%,rgba(243,91,34,.22),transparent 42%),radial-gradient(circle at 10% 100%,rgba(243,91,34,.12),transparent 45%),radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:auto,auto,20px 20px}
@media(max-width:520px){.contact-panel{padding:26px}}
.eyebrow--onDark{color:rgba(255,255,255,.45)}
.contact-panel__title{font-size:24px;font-weight:700;letter-spacing:-.02em;margin-top:8px}
.contact-panel__lead{font-size:14px;line-height:1.65;color:rgba(255,255,255,.6);margin:12px 0 24px}
.contact-item--dark{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.10);color:#fff}
.contact-item--dark:hover{background:rgba(255,255,255,.09)}
.contact-item--dark .contact-item__ic{background:rgba(243,91,34,.18);color:var(--color-apricot)}
.contact-item--dark b{color:#fff}
.contact-item--dark .sub{color:rgba(255,255,255,.6)}
.contact-panel__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:26px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12)}
.contact-panel__stats b{display:block;font-size:22px;font-weight:700;color:var(--color-apricot);letter-spacing:-.02em}
.contact-panel__stats em{font-style:normal;font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:rgba(255,255,255,.5);line-height:1.4;display:block;margin-top:5px}
.contact-panel__social{display:flex;gap:16px;margin-top:26px}
.contact-panel__social a{color:rgba(255,255,255,.5);transition:color .15s}
.contact-panel__social a svg{width:18px;height:18px}
.contact-panel__social a:hover{color:#fff}
/* Work / portfolio cards */
.work-card{display:flex;flex-direction:column}
.work-card__top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.work-card__result{font-family:var(--font-mono);font-size:11px;color:var(--color-success-green);background:rgba(98,176,109,.12);padding:3px 8px;border-radius:20px;white-space:nowrap}
.work-card__stack{display:inline-block;margin-top:16px;align-self:flex-start}
/* Legal pages (privacy, terms) */
.legal{max-width:760px}
.legal p{font-size:16px;line-height:1.75;color:var(--color-slate);margin-bottom:18px}
.legal h2{font-size:20px;color:var(--color-ink);margin:36px 0 14px;letter-spacing:-.01em}
.legal ul{margin:0 0 18px;padding-left:22px;display:flex;flex-direction:column;gap:8px}
.legal li{font-size:16px;line-height:1.7;color:var(--color-slate)}
.legal strong{color:var(--color-ink);font-weight:600}
.legal a{color:var(--color-persimmon)}
.legal a:hover{text-decoration:underline}
.legal__updated{font-family:var(--font-mono);font-size:13px;color:var(--color-stone);margin-top:14px}
.legal__contact{background:var(--color-cream-paper);border:1px solid var(--color-linen-border);border-radius:12px;padding:20px 22px;line-height:1.8}
/* Location pages — taluk tags */
.taluk-strip{margin-top:36px;padding-top:28px;border-top:1px solid var(--color-linen-border)}
.taluk-strip__label{font-family:var(--font-mono);font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--color-stone);margin-bottom:14px}
.taluk-strip__tags{display:flex;flex-wrap:wrap;gap:10px}
.taluk-tag{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--color-slate);background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:22px;padding:7px 14px;transition:all .15s}
.taluk-tag svg{width:14px;height:14px;color:var(--color-persimmon)}
a.taluk-tag:hover{border-color:var(--color-signal-orange);color:var(--color-ink)}
/* Location — landmarks line (inline icon + text, both mobile & desktop) */
.loc-landmarks{display:flex;align-items:flex-start;gap:8px;margin-top:14px;font-size:14px;line-height:1.6;color:var(--color-stone)}
.loc-landmarks__ic{flex:none;display:inline-flex;margin-top:2px}
.loc-landmarks__ic svg{width:16px;height:16px;color:var(--color-persimmon)}
/* ===== 404 page ===== */
.notfound{text-align:center}
.notfound__inner{max-width:640px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.notfound__glyph{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:18px;line-height:1}
.notfound__digit{font-size:clamp(90px,18vw,160px);font-weight:800;letter-spacing:-.05em;color:var(--color-ink);line-height:.9}
.notfound__orb{display:inline-flex;align-items:center;justify-content:center;width:clamp(78px,15vw,140px);height:clamp(78px,15vw,140px);border-radius:50%;background:var(--color-ink);color:var(--color-signal-orange);position:relative;box-shadow:0 20px 50px -18px rgba(243,91,34,.6)}
.notfound__orb svg{width:56%;height:56%}
.notfound__lead{max-width:460px}
.notfound__btns{justify-content:center;margin-top:28px}
.notfound__links{margin-top:52px;width:100%}
.notfound__links-label{font-family:var(--font-mono);font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--color-stone);margin-bottom:16px}
.notfound__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:720px){.notfound__grid{grid-template-columns:repeat(2,1fr)}}
.notfound__card{display:flex;align-items:center;gap:12px;text-align:left;background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:12px;padding:14px;transition:border-color .15s,transform .15s,box-shadow .15s}
.notfound__card:hover{border-color:var(--color-signal-orange);transform:translateY(-2px);box-shadow:0 12px 28px -16px rgba(20,20,21,.25)}
.notfound__card-ic{flex:none;width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:rgba(243,91,34,.10);color:var(--color-persimmon)}
.notfound__card-ic svg{width:20px;height:20px}
.notfound__card b{display:block;font-size:14px;color:var(--color-ink)}
.notfound__card em{font-style:normal;font-size:12px;color:var(--color-slate)}
a.contact-item{transition:border-color .15s,transform .15s}
a.contact-item:hover{border-color:var(--color-ink);transform:translateY(-1px)}

.feat{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:820px){.feat{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.feat{grid-template-columns:1fr}}
.feat__item{display:flex;gap:13px;align-items:flex-start}
.feat__ic{width:40px;height:40px;flex:none;border-radius:10px;display:grid;place-items:center;background:rgba(22,84,36,.10);color:var(--color-forest)}
.feat__ic svg{width:21px;height:21px}
.feat__item h3{font-size:15px;margin-bottom:3px}
.feat__item p{font-size:13.5px;line-height:1.55;color:var(--color-slate)}
.section-label{display:flex;align-items:center;gap:10px;justify-content:center;text-align:center;margin-bottom:32px;flex-direction:column}

/* ---------- Service detail page ---------- */
.svc-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center}
@media(max-width:920px){.svc-hero{grid-template-columns:1fr;gap:32px}}
.svc-hero__visual{filter:drop-shadow(0 24px 48px rgba(24,25,22,.10))}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip2{font-family:var(--font-mono);font-size:12px;color:var(--color-slate);background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:20px;padding:6px 12px;white-space:nowrap}
.eyebrow .svc-eyebrow-ic{display:inline-flex;align-items:center;vertical-align:-3px;margin-right:7px;color:var(--color-persimmon)}
.eyebrow .svc-eyebrow-ic svg{width:16px;height:16px}

.svc-overview{display:grid;grid-template-columns:.72fr 1.28fr;gap:48px;align-items:start}
@media(max-width:820px){.svc-overview{grid-template-columns:1fr;gap:20px}}
.svc-overview h2{font-size:clamp(24px,3vw,32px);letter-spacing:-.02em;line-height:1.15}
.svc-overview p{font-size:17px;line-height:1.8;color:var(--color-carbon)}
.svc-overview p+p{margin-top:18px}

.faq{max-width:840px;margin:0 auto}
.faq__item{border-bottom:1px solid var(--color-linen-border)}
.faq__item summary{list-style:none;cursor:pointer;padding:22px 0;font-size:17px;font-weight:600;color:var(--color-ink);display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";color:var(--color-persimmon);font-size:24px;font-weight:400;line-height:1;flex:none;transition:transform .2s}
.faq__item[open] summary::after{content:"\2013"}
.faq__a{padding:0 0 22px;color:var(--color-slate);line-height:1.75;font-size:15.5px;max-width:72ch}
.section--band .faq__item{border-color:var(--color-ash)}

/* ---------- Fingerprint-style service page ---------- */
.hero__badge{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:500;color:var(--color-slate);background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:22px;padding:6px 8px 6px 14px;margin-bottom:8px;white-space:nowrap;max-width:100%}
.hero__badge b{color:var(--color-persimmon);font-weight:600}
.hero__badge-sub{color:var(--color-slate)}
.hero__badge .pillarrow{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--color-cream-paper)}
.hero__badge .pillarrow svg{width:13px;height:13px}
.hero--center .chips{justify-content:center;margin-top:24px}

.section-head--left{max-width:620px;margin-bottom:44px}
.section-head--left .heading{margin-top:12px}
.section-head--left .lead{margin-top:16px}

.feat4{display:grid;grid-template-columns:repeat(4,1fr);gap:34px}
@media(max-width:900px){.feat4{grid-template-columns:repeat(2,1fr);gap:28px}}
@media(max-width:520px){.feat4{grid-template-columns:1fr}}
.feat4__item{border-top:1.5px solid var(--color-ash);padding-top:22px}
.feat4__ic{color:var(--color-persimmon);margin-bottom:16px;height:26px}
.feat4__ic svg{width:26px;height:26px}
.feat4__item h3{font-size:16px;margin-bottom:8px}
.feat4__item p{font-size:14px;line-height:1.62;color:var(--color-slate)}

.acc{display:grid;grid-template-columns:1.02fr .98fr;gap:52px;align-items:center}
@media(max-width:920px){.acc{grid-template-columns:1fr;gap:32px}}
.acc__visual{filter:drop-shadow(0 24px 48px rgba(24,25,22,.10))}
.acc__list{display:flex;flex-direction:column;gap:26px}
.acc__item{display:flex;gap:15px;align-items:flex-start}
.acc__ic{width:42px;height:42px;flex:none;border-radius:11px;display:grid;place-items:center;background:var(--color-wash,rgba(243,91,34,.10));color:var(--color-persimmon)}
.acc__ic svg{width:22px;height:22px}
.acc__item h3{font-size:16.5px;margin-bottom:5px}
.acc__item p{font-size:14.5px;line-height:1.65;color:var(--color-slate)}

.sigrow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:960px){.sigrow{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.sigrow{grid-template-columns:1fr}}
.sigcard{background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:14px;padding:22px}
.sigcard__t{font-family:var(--font-mono);font-size:14px;color:var(--color-ink);font-weight:500;letter-spacing:-.01em}
.sigcard__t b{color:var(--color-persimmon);font-weight:500}
.sigcard p{font-size:13px;color:var(--color-slate);line-height:1.6;margin-top:10px}
.sigcard__v{margin-top:16px;font-family:var(--font-mono);font-size:11.5px;color:var(--color-stone);background:var(--color-cream-paper);border:1px solid var(--color-linen-border);border-radius:8px;padding:8px 11px}

.devsec{display:grid;grid-template-columns:1fr 1.05fr;gap:44px;align-items:center}
@media(max-width:920px){.devsec{grid-template-columns:1fr;gap:28px}}
.devsec__logos{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.devsec__logos .chip2{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#cfcfcc}
.section--dark .terminal{box-shadow:0 20px 50px rgba(0,0,0,.35)}

/* ---------- Fingerprint split sections (heading left, content right) ---------- */
.hero--center .crumb{display:none}         /* Fingerprint has no breadcrumb in hero */
.hero__badge{margin-top:4px}
.fp-split{display:grid;grid-template-columns:.82fr 1.18fr;gap:56px;align-items:start}
@media(max-width:860px){.fp-split{grid-template-columns:1fr;gap:28px}}
.fp-split__head{position:sticky;top:96px}
@media(max-width:860px){.fp-split__head{position:static}}
.fp-split__head .heading{margin-top:12px}
.fp-split__head .lead{margin-top:16px}

.statlist{display:flex;flex-direction:column;gap:26px}
.statlist__item{border-top:1px solid var(--color-ash);padding-top:16px}
.stat-xl{font-size:clamp(30px,4vw,42px);font-weight:700;letter-spacing:-.02em;color:var(--color-persimmon);line-height:1}
.statlist__cap{font-family:var(--font-mono);font-size:12.5px;color:var(--color-stone);margin-top:8px;letter-spacing:.02em}

.sigrow--2{grid-template-columns:1fr 1fr}
@media(max-width:520px){.sigrow--2{grid-template-columns:1fr}}

/* accuracy bordered panel (Fingerprint "Industry-leading accuracy") */
.fp-panel{display:grid;grid-template-columns:1.05fr .95fr;border:1px solid var(--color-linen-border);border-radius:16px;overflow:hidden;background:var(--color-card-white)}
@media(max-width:820px){.fp-panel{grid-template-columns:1fr}}
.fp-panel__main{padding:26px 28px;border-right:1px solid var(--color-linen-border)}
@media(max-width:820px){.fp-panel__main{border-right:0;border-bottom:1px solid var(--color-linen-border)}}
.fp-panel__cap{margin-top:20px}
.fp-panel__cap h3{font-size:16px;margin-bottom:6px}
.fp-panel__cap p{font-size:13.5px;color:var(--color-slate);line-height:1.62}
.fp-panel__side{display:flex;flex-direction:column}
.fp-panel__cell{padding:24px 28px;flex:1;display:flex;align-items:center}
.fp-panel__cell+.fp-panel__cell{border-top:1px solid var(--color-linen-border)}
/* star pill for dark developer section */
.starpill{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;color:#cfcfcc;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:6px 12px}
.starpill b{color:var(--color-persimmon)}
/* keep the 4-up features single-column on phones */
@media(max-width:600px){.feat4{grid-template-columns:1fr}}

/* ===== Match Fingerprint MOBILE: left-aligned, 2-up features, tight ===== */
@media (max-width: 860px){
  .hero--center{ text-align:left; padding-block:34px 8px; }
  .hero--center .lead{ margin-left:0; margin-right:0; }
  .hero--center .hero__btns{ justify-content:flex-start; }
  .hero--center .chips{ justify-content:flex-start; }
  .hero__badge{ margin-left:0; }
  .trusted{ text-align:left; }
  .trusted__logos{ justify-content:flex-start; gap:22px; }
  .section-head--left{ margin-bottom:26px; }
}
/* features stay 2-up on phones (like Fingerprint), not one-per-row */
@media (max-width: 900px){ .feat4{ grid-template-columns:repeat(2,1fr); gap:26px 22px; } }
@media (max-width: 600px){ .feat4{ grid-template-columns:repeat(2,1fr); gap:22px 16px; } }
@media (max-width: 600px){ .feat4__ic{ margin-bottom:12px; } .feat4__item h3{ font-size:15px; } .feat4__item p{ font-size:13px; } }
/* signal cards stay 2-up on phones */
@media (max-width: 520px){ .sigrow--2{ grid-template-columns:1fr 1fr; gap:12px; } .sigcard{ padding:16px; } .sigcard p{ font-size:12px; } }
/* stat numbers a touch smaller so captions fit on phones */
@media (max-width: 520px){ .stat-xl{ font-size:30px; } .statlist__cap{ font-size:11.5px; } }

/* keep buttons on one line; tidy the mobile header CTA */
.btn{white-space:nowrap}
@media (max-width:560px){ .nav__actions .btn--primary{ padding:9px 14px; font-size:13px; } }
@media (max-width:400px){ .nav__actions .btn--primary{ display:none; } }

/* ===== Scrolling logo marquee (Fingerprint-style) ===== */
.logomarquee{overflow:hidden;position:relative;margin-top:20px;
  -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.logomarquee__track{display:flex;align-items:center;gap:46px;width:max-content;animation:logoscroll 34s linear infinite}
.logomarquee:hover .logomarquee__track{animation-play-state:paused}
.logomarquee .tlogo{white-space:nowrap;flex:none;display:inline-flex;align-items:center;gap:9px;color:var(--color-carbon);font-weight:600;font-size:15px;letter-spacing:-.01em}
.logomarquee .tlogo img{width:24px;height:24px;object-fit:contain;display:block}
@keyframes logoscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.logomarquee__track{animation:none;flex-wrap:wrap;justify-content:center}}

/* ===== Horizontal card scroller (Fingerprint "Smart Signals" carousel) ===== */
.scroller{position:relative}
.scroller__head{display:flex;justify-content:flex-end;gap:8px;margin-bottom:14px}
.scroller__btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--color-linen-border);background:var(--color-card-white);color:var(--color-ink);display:grid;place-items:center;cursor:pointer;transition:border-color .15s,color .15s}
.scroller__btn:hover{border-color:var(--color-persimmon);color:var(--color-persimmon)}
.scroller__btn svg{width:16px;height:16px}
.scroller__track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:2px 2px 12px;-webkit-overflow-scrolling:touch}
.scroller__track > *{flex:0 0 240px;scroll-snap-align:start}
@media(max-width:520px){.scroller__track > *{flex:0 0 82%}}
.scroller__track::-webkit-scrollbar{height:6px}
.scroller__track::-webkit-scrollbar-thumb{background:var(--color-fog);border-radius:3px}
.scroller__track::-webkit-scrollbar-track{background:transparent}

/* dark-section tech chips as an inline scrolling marquee */
.section--dark .logomarquee{-webkit-mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.section--dark .logomarquee .chip2{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#cfcfcc}
.logomarquee--chips .logomarquee__track{gap:12px;animation-duration:20s}

/* text-only tech chip (for tools without a brand mark) */
.tlogo--text{color:var(--color-carbon);font-weight:600;font-size:14px}
.tlogo--text::before{content:"";width:8px;height:8px;border-radius:2px;background:var(--color-persimmon);opacity:.55;display:inline-block}
.section--dark .tlogo--text{color:#cfcfcc}

/* prevent wide content (marquees, code) from blowing out grid/flex columns */
.devsec > *, .fp-split > *, .acc > *, .fp-panel > *, .fp-panel__side > *{ min-width: 0; }
.logomarquee{ max-width: 100%; }
/* ===== Live chat widget ===== */
.wchat{position:fixed;right:20px;bottom:20px;z-index:1000;font-family:var(--font-inter);display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.wchat__fab{position:relative;width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;background:var(--color-signal-orange);color:#fff;display:grid;place-items:center;box-shadow:0 10px 30px -8px rgba(243,91,34,.6);transition:transform .18s ease,background .18s;align-self:flex-end}
.wchat__fab:hover{transform:scale(1.05)}
.wchat__fab svg{position:absolute;transition:opacity .18s,transform .18s}
.wchat__fab-open{width:30px;height:30px}
.wchat__fab-close{width:24px;height:24px;opacity:0;transform:rotate(-90deg)}
.wchat.is-open .wchat__fab{background:var(--color-ink)}
.wchat.is-open .wchat__fab-open{opacity:0;transform:rotate(90deg)}
.wchat.is-open .wchat__fab-close{opacity:1;transform:rotate(0)}
.wchat__fab-badge{position:absolute;top:-3px;right:-3px;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:#fff;color:var(--color-signal-orange);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(0,0,0,.2)}

/* Greeting bubble (Fingerprint-style) */
.wchat__greeting{display:none;position:relative;max-width:270px;background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:16px;box-shadow:0 14px 40px -14px rgba(20,20,21,.28);padding:2px;animation:wchatIn .25s ease}
.wchat__greeting.show{display:block}
.wchat.is-open .wchat__greeting{display:none}
.wchat__greeting-body{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:14px 16px;border-radius:14px}
.wchat__greeting-body:hover{background:var(--color-cream-paper)}
.wchat__greeting-title{display:block;font-size:14px;font-weight:600;color:var(--color-ink)}
.wchat__greeting-sub{display:block;font-size:12.5px;color:var(--color-slate);margin-top:3px;line-height:1.45}
.wchat__greeting-x{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:var(--color-ink);color:#fff;border:none;cursor:pointer;font-size:15px;line-height:1;display:grid;place-items:center;box-shadow:0 2px 6px rgba(0,0,0,.2)}

/* Panel — hidden by default, shown only when .is-open */
.wchat__panel{display:none;position:absolute;right:0;bottom:72px;width:min(370px,calc(100vw - 40px));height:min(540px,calc(100vh - 120px));background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:16px;box-shadow:0 24px 60px -16px rgba(20,20,21,.32);flex-direction:column;overflow:hidden}
.wchat.is-open .wchat__panel{display:flex;animation:wchatIn .2s ease}
@keyframes wchatIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.wchat__head{background:var(--color-ink);color:#fff;padding:15px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.wchat__head-brand{display:flex;align-items:center;gap:11px}
.wchat__orb{width:38px;height:38px;flex:none;border-radius:50%;background:rgba(243,91,34,.16);color:var(--color-apricot);display:grid;place-items:center}
.wchat__orb svg{width:22px;height:22px}
.wchat__head-brand b{display:block;font-size:15px;font-weight:600}
.wchat__head-brand span{display:block;font-size:12px;color:rgba(255,255,255,.55);margin-top:1px}
.wchat__head-x{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;padding:4px;display:grid;place-items:center}
.wchat__head-x:hover{color:#fff}
.wchat__head-x svg{width:18px;height:18px}
.wchat__body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px;background:var(--color-cream-paper)}
.wchat__intro{font-size:13.5px;color:var(--color-slate);background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:12px;padding:12px 14px;align-self:flex-start;max-width:88%;line-height:1.5}
.wchat__msg{display:flex;max-width:85%}
.wchat__msg span{font-size:14px;line-height:1.5;padding:9px 13px;border-radius:14px;word-break:break-word}
.wchat__msg--user{align-self:flex-end}
.wchat__msg--user span{background:var(--color-signal-orange);color:#fff;border-bottom-right-radius:4px}
.wchat__msg--admin{align-self:flex-start}
.wchat__msg--admin span{background:var(--color-card-white);border:1px solid var(--color-linen-border);color:var(--color-ink);border-bottom-left-radius:4px}
.wchat__note{align-self:center;font-size:12px;color:var(--color-slate);background:rgba(243,91,34,.08);border:1px solid rgba(243,91,34,.2);border-radius:10px;padding:8px 12px;max-width:90%;text-align:center;line-height:1.45}
/* Pre-chat form */
.wchat__prechat{display:flex;flex-direction:column;gap:12px}
.wchat__prechat[hidden]{display:none}
.wchat__pc-field{display:flex;flex-direction:column;gap:5px}
.wchat__pc-field label{font-size:12px;font-weight:600;color:var(--color-slate)}
.wchat__pc-field input{border:1px solid var(--color-linen-border);border-radius:10px;padding:10px 12px;font-family:var(--font-inter);font-size:14px;outline:none;background:var(--color-card-white)}
.wchat__pc-field input:focus{border-color:var(--color-signal-orange);box-shadow:0 0 0 3px rgba(243,91,34,.12)}
.wchat__pc-err{font-size:12.5px;color:var(--color-persimmon);background:rgba(243,91,34,.08);border-radius:8px;padding:8px 10px}
.wchat__pc-start{margin-top:2px;border:none;border-radius:10px;background:var(--color-signal-orange);color:#fff;font-family:var(--font-inter);font-size:14px;font-weight:600;padding:11px;cursor:pointer;transition:background .15s}
.wchat__pc-start:hover{background:var(--color-persimmon)}
.wchat__pc-start:disabled{opacity:.6;cursor:default}
/* Conversation area */
.wchat__convo{display:flex;flex-direction:column;gap:10px}
.wchat__convo[hidden]{display:none}
/* Typing indicator */
.wchat__typing{display:flex;align-items:center;gap:8px;align-self:flex-start;color:var(--color-stone);font-size:12px}
.wchat__typing em{font-style:normal}
.wchat__typing-dots{display:inline-flex;gap:3px;background:var(--color-card-white);border:1px solid var(--color-linen-border);border-radius:12px;padding:9px 11px}
.wchat__typing-dots i{width:6px;height:6px;border-radius:50%;background:var(--color-fog);animation:wchatDot 1.2s infinite ease-in-out}
.wchat__typing-dots i:nth-child(2){animation-delay:.2s}
.wchat__typing-dots i:nth-child(3){animation-delay:.4s}
@keyframes wchatDot{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.wchat__form{display:flex;gap:8px;padding:12px;border-top:1px solid var(--color-linen-border);background:var(--color-card-white)}
.wchat__form[hidden]{display:none}
.wchat__form input{flex:1;border:1px solid var(--color-linen-border);border-radius:10px;padding:10px 12px;font-family:var(--font-inter);font-size:14px;outline:none}
.wchat__form input:focus{border-color:var(--color-signal-orange);box-shadow:0 0 0 3px rgba(243,91,34,.12)}
.wchat__form button{flex:none;width:42px;border:none;border-radius:10px;background:var(--color-signal-orange);color:#fff;cursor:pointer;display:grid;place-items:center}
.wchat__form button:hover{background:var(--color-persimmon)}
.wchat__form button svg{width:18px;height:18px}
@media(max-width:480px){.wchat{right:14px;bottom:14px}.wchat__panel{bottom:70px}.wchat__greeting{max-width:240px}}