/* SquadBear marketing subpages — hand-authored stylesheet that mirrors the
 * landing page's brand language (src/client/pages/landing.tsx). Plain CSS so
 * the pages are fully static and crawlable; copied verbatim to
 * dist/client/marketing/site.css by scripts/build-marketing.mjs.
 *
 * Per-page accent comes from --pillar / --pillar-soft, set on <body>. */

:root {
  --ink: #0f172a;
  --slate-700: #334155;
  --slate-600: #475569;
  --slate-500: #64748b;
  --slate-400: #94a3b8;
  --slate-300: #cbd5e1;
  --slate-200: #e2e8f0;
  --slate-100: #f1f5f9;
  --slate-50: #f8fafc;
  --sky-500: #0ea5e9;
  --sky-600: #0284c7;
  --sky-700: #0369a1;
  --brand-from: #38bdf8;
  --brand-via: #6366f1;
  --brand-to: #8b5cf6;
  --pillar: #6366f1;
  --pillar-soft: #e0e7ff;
  --maxw: 80rem;
  color-scheme: light;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: #fff;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}

a { color: inherit; }
img { max-width: 100%; display: block; }

.container {
  width: 100%;
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: 1rem;
}
@media (min-width: 1024px) { .container { padding-inline: 2rem; } }

/* ---- decorative glow blobs (match landing) ---- */
.glow-wrap { position: fixed; inset: 0; overflow: hidden; pointer-events: none; z-index: 0; }
.glow { position: absolute; border-radius: 9999px; filter: blur(130px); }
.glow-1 { top: -10rem; left: 50%; width: 60rem; height: 34rem; transform: translateX(-50%); background: rgba(186, 230, 253, 0.4); }
.glow-2 { top: 30%; left: -10rem; width: 24rem; height: 24rem; background: rgba(221, 214, 254, 0.34); }
main, .site-header, .site-footer { position: relative; z-index: 1; }

/* ---- buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  border-radius: 0.75rem; padding: 0.7rem 1.15rem;
  font-size: 0.9rem; font-weight: 600; text-decoration: none;
  border: 1px solid transparent; cursor: pointer; transition: all 0.15s ease;
  white-space: nowrap;
}
.btn-primary {
  background-image: linear-gradient(to right, #06b6d4, #8b5cf6);
  color: #fff; box-shadow: 0 10px 22px -8px rgba(139, 92, 246, 0.5);
}
.btn-primary:hover { transform: translateY(-2px); }
.btn-ghost { border-color: var(--slate-300); color: var(--slate-700); background: #fff; }
.btn-ghost:hover { border-color: var(--slate-400); color: var(--ink); }
.btn-sm { padding: 0.5rem 0.9rem; font-size: 0.85rem; }

/* ---- header ---- */
.site-header {
  position: sticky; top: 0; z-index: 40;
  border-bottom: 1px solid var(--slate-200);
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(14px);
}
.site-header .bar { display: flex; height: 4rem; align-items: center; justify-content: space-between; }
.site-header .logo img { height: 1.75rem; width: auto; }
.site-nav { display: none; align-items: center; gap: 1.5rem; font-size: 0.875rem; color: var(--slate-600); }
.site-nav a { text-decoration: none; transition: color 0.15s; }
.site-nav a:hover, .site-nav a[aria-current="page"] { color: var(--ink); }
.site-nav a[aria-current="page"] { font-weight: 600; }
@media (min-width: 880px) { .site-nav { display: flex; } }
/* Modules dropdown (desktop nav) */
.nav-dd { position: relative; }
.nav-dd-btn { display: inline-flex; align-items: center; gap: 0.25rem; padding: 0; margin: 0; border: 0; background: none; font: inherit; color: inherit; cursor: pointer; }
.nav-dd-btn:hover { color: var(--ink); }
.nav-dd-btn svg { transition: transform 0.15s; }
.nav-dd:hover .nav-dd-btn svg, .nav-dd.open .nav-dd-btn svg { transform: rotate(180deg); }
.nav-dd-pop { position: absolute; left: 50%; top: 100%; transform: translateX(-50%); padding-top: 0.65rem; width: 17rem; opacity: 0; visibility: hidden; transition: opacity 0.15s; z-index: 50; }
.nav-dd:hover .nav-dd-pop, .nav-dd:focus-within .nav-dd-pop, .nav-dd.open .nav-dd-pop { opacity: 1; visibility: visible; }
.nav-dd-card { background: #fff; border: 1px solid var(--slate-200); border-radius: 0.85rem; box-shadow: 0 16px 36px -16px rgba(15, 23, 42, 0.28); padding: 0.4rem; }
.nav-dd-card a { display: flex; gap: 0.6rem; align-items: flex-start; padding: 0.55rem 0.65rem; border-radius: 0.6rem; text-decoration: none; color: inherit; }
.nav-dd-card a:hover { background: var(--slate-50); }
.nav-dd-card .dd-dot { margin-top: 0.35rem; width: 0.55rem; height: 0.55rem; border-radius: 9999px; flex: none; }
.nav-dd-card .dd-name { display: block; font-size: 0.85rem; font-weight: 600; color: var(--slate-700); }
.nav-dd-card .dd-blurb { display: block; font-size: 0.72rem; color: var(--slate-500); }
.header-cta { display: flex; align-items: center; gap: 0.5rem; }
.header-cta .signin { display: none; font-size: 0.875rem; color: var(--slate-600); text-decoration: none; padding: 0.5rem 0.75rem; }
.header-cta .signin:hover { color: var(--ink); }
@media (min-width: 640px) { .header-cta .signin { display: block; } }
.menu-btn { display: inline-flex; align-items: center; justify-content: center; width: 2.25rem; height: 2.25rem; border: 0; background: transparent; color: var(--slate-600); cursor: pointer; }
@media (min-width: 880px) { .menu-btn { display: none; } }
.mobile-nav { display: flex; flex-direction: column; gap: 0.15rem; border-top: 1px solid var(--slate-200); background: #fff; padding: 0.65rem 1rem; font-size: 0.9rem; color: var(--slate-600); }
.mobile-nav a { text-decoration: none; border-radius: 0.5rem; padding: 0.55rem 0.75rem; }
.mobile-nav a:hover { background: var(--slate-50); color: var(--ink); }
.mobile-nav-label { margin: 0.5rem 0.75rem 0.1rem; font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--slate-400); }
@media (min-width: 880px) { .mobile-nav { display: none; } }

/* ---- eyebrow pill ---- */
.eyebrow {
  display: inline-flex; align-items: center; gap: 0.5rem;
  border-radius: 9999px; padding: 0.35rem 0.85rem;
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.02em;
  border: 1px solid color-mix(in oklab, var(--pillar) 35%, transparent);
  background: color-mix(in oklab, var(--pillar) 12%, #fff);
  color: color-mix(in oklab, var(--pillar) 75%, #000);
}
.eyebrow .dot { width: 0.5rem; height: 0.5rem; border-radius: 9999px; background: var(--pillar); }

/* ---- hero ---- */
.hero { position: relative; isolation: isolate; overflow: hidden; }
.hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(to bottom, color-mix(in oklab, var(--pillar-soft) 60%, #fff), #fff 60%);
}
.hero-grid {
  display: grid; gap: 2.5rem; align-items: center;
  padding-block: 3.5rem 2rem;
}
@media (min-width: 1024px) { .hero-grid { grid-template-columns: 1fr 1fr; gap: 3rem; padding-block: 5rem 3rem; } }
.hero h1 {
  font-size: clamp(2.2rem, 5vw, 3.5rem); line-height: 1.05; letter-spacing: -0.02em;
  font-weight: 800; margin: 1.1rem 0 0;
}
.hero-sub { margin-top: 1.25rem; max-width: 36rem; font-size: 1.05rem; color: var(--slate-600); }
.hero-cta { margin-top: 1.75rem; display: flex; flex-wrap: wrap; gap: 0.75rem; }
.hero-trust { margin-top: 1rem; font-size: 0.8rem; color: var(--slate-500); display: flex; align-items: center; gap: 0.4rem; }
.hero-trust .dot { width: 0.4rem; height: 0.4rem; border-radius: 9999px; background: #22c55e; }
.hero-media { position: relative; display: flex; justify-content: center; }
/* Height-based so every pose (whatever its aspect ratio) is the same height and
   rests on the frame's top edge instead of dipping over the widget's content. */
.hero-mascot {
  position: absolute; top: -4rem; right: 0.5rem; height: 4.5rem; width: auto; z-index: 3;
  filter: drop-shadow(0 14px 24px rgba(99, 102, 241, 0.28));
  pointer-events: none;
}
@media (max-width: 520px) { .hero-mascot { height: 3.25rem; top: -2.9rem; } }

.gradient-text {
  background-image: linear-gradient(to right, var(--brand-from), var(--brand-via), var(--brand-to));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* ---- generic section ---- */
.section { padding-block: 4rem; }
@media (min-width: 1024px) { .section { padding-block: 5.5rem; } }
.section-head { max-width: 44rem; margin-inline: auto; text-align: center; }
.section-head h2 { font-size: clamp(1.7rem, 3.5vw, 2.25rem); font-weight: 700; letter-spacing: -0.02em; margin: 0; }
.section-head p { margin-top: 1rem; color: var(--slate-600); }
.section-eyebrow { color: var(--pillar); font-weight: 600; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.08em; }

/* ---- feature rows ---- */
.feature {
  display: grid; gap: 2rem; align-items: center; padding-block: 2.5rem;
  border-top: 1px solid var(--slate-100);
}
@media (min-width: 900px) { .feature { grid-template-columns: 1fr 1fr; gap: 3.5rem; } .feature.flip .feature-copy { order: 2; } }
.feature h3 { font-size: 1.35rem; font-weight: 700; letter-spacing: -0.01em; margin: 0.75rem 0 0; }
.feature p { margin-top: 0.75rem; color: var(--slate-600); font-size: 1rem; }
.feature-tag {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em;
  color: color-mix(in oklab, var(--pillar) 70%, #000);
}
.feature-media { display: flex; justify-content: center; }
.shot {
  width: 100%; height: auto; border-radius: 1rem; border: 1px solid var(--slate-200);
  box-shadow: 0 24px 50px -24px rgba(15, 23, 42, 0.35);
}
.feature-iconbox {
  width: 100%; max-width: 22rem; aspect-ratio: 4 / 3;
  border-radius: 1.25rem; border: 1px solid var(--slate-200);
  background:
    radial-gradient(120% 120% at 30% 20%, color-mix(in oklab, var(--pillar) 14%, #fff), #fff 70%);
  display: grid; place-items: center; box-shadow: 0 24px 50px -28px rgba(15, 23, 42, 0.3);
}
.feature-iconbox img { width: 46%; height: auto; filter: drop-shadow(0 12px 22px rgba(15, 23, 42, 0.18)); }

/* ---- cards / benefits ---- */
.cards { display: grid; gap: 1rem; margin-top: 3rem; }
@media (min-width: 640px) { .cards.cols-2 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .cards.cols-3 { grid-template-columns: repeat(3, 1fr); } .cards.cols-4 { grid-template-columns: repeat(4, 1fr); } }
.card {
  border-radius: 1rem; border: 1px solid var(--slate-200); background: #fff;
  padding: 1.4rem; box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  transition: transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
.card.hoverable:hover { transform: translateY(-4px); border-color: color-mix(in oklab, var(--pillar) 45%, var(--slate-200)); box-shadow: 0 16px 30px -18px rgba(15, 23, 42, 0.28); }
.card h3 { margin: 0; font-size: 1.02rem; font-weight: 650; }
.card p { margin: 0.4rem 0 0; font-size: 0.9rem; color: var(--slate-600); }
.card .card-icon {
  width: 2.5rem; height: 2.5rem; border-radius: 0.75rem; margin-bottom: 0.9rem;
  display: grid; place-items: center;
  background: color-mix(in oklab, var(--pillar) 14%, #fff);
}
.card .card-icon img { width: 1.5rem; height: 1.5rem; }

/* ---- benefit strip background ---- */
.band { background: linear-gradient(to bottom, var(--slate-50), transparent); border-block: 1px solid var(--slate-200); }

/* ---- FAQ ---- */
.faq { max-width: 48rem; margin-inline: auto; margin-top: 2.5rem; }
.faq details {
  border: 1px solid var(--slate-200); border-radius: 0.85rem; background: #fff;
  padding: 0 1.15rem; margin-bottom: 0.75rem;
}
.faq summary {
  cursor: pointer; list-style: none; padding: 1rem 0; font-weight: 600; font-size: 1rem;
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: var(--pillar); font-size: 1.4rem; font-weight: 400; line-height: 1; transition: transform 0.2s; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq p { margin: 0 0 1.1rem; color: var(--slate-600); font-size: 0.95rem; }

/* ---- crosslinks ---- */
.crosslink {
  display: block; text-decoration: none; border-radius: 1rem; border: 1px solid var(--slate-200);
  background: #fff; padding: 1.25rem; transition: transform 0.15s, border-color 0.15s, box-shadow 0.15s;
}
.crosslink:hover { transform: translateY(-4px); border-color: var(--sky-500); box-shadow: 0 16px 30px -18px rgba(15, 23, 42, 0.25); }
.crosslink .cl-eyebrow { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; }
.crosslink h3 { margin: 0.5rem 0 0; font-size: 1.1rem; }
.crosslink p { margin: 0.35rem 0 0; font-size: 0.88rem; color: var(--slate-600); }
.crosslink .go { margin-top: 0.75rem; font-size: 0.85rem; font-weight: 600; color: var(--sky-600); }

/* ---- final CTA ---- */
.cta-final { border-top: 1px solid var(--slate-200); text-align: center; }
.cta-final h2 { font-size: clamp(1.6rem, 3vw, 2rem); font-weight: 700; }
.cta-final code { background: var(--slate-100); color: var(--sky-600); padding: 0.15rem 0.55rem; border-radius: 0.5rem; }

/* ---- footer ---- */
.site-footer { border-top: 1px solid var(--slate-200); text-align: center; color: var(--slate-400); padding: 2.5rem 1rem; font-size: 0.875rem; }
.site-footer img { height: 2rem; width: auto; margin-inline: auto; }
.site-footer nav { margin-top: 1.25rem; display: flex; flex-wrap: wrap; justify-content: center; gap: 0.5rem 1.5rem; color: var(--slate-500); }
.site-footer nav a { text-decoration: none; }
.site-footer nav a:hover { color: var(--ink); }

/* ================= interactive widgets ================= */
.widget-frame {
  position: relative; width: 100%; border-radius: 1.25rem; border: 1px solid var(--slate-200);
  background: #fff; box-shadow: 0 30px 60px -30px rgba(15, 23, 42, 0.35); padding: 1.1rem;
}
.widget-caption { margin-top: 0.9rem; font-size: 0.8rem; color: var(--slate-500); text-align: center; }

/* coverage calendar */
.cal { display: grid; grid-template-columns: 8.5rem repeat(5, 1fr); gap: 0.35rem; font-size: 0.78rem; }
.cal .cal-h { text-align: center; font-weight: 600; color: var(--slate-500); padding-bottom: 0.2rem; }
.cal .cal-name { display: flex; align-items: center; gap: 0.5rem; font-weight: 500; }
.cal .cal-av { width: 1.6rem; height: 1.6rem; border-radius: 9999px; display: grid; place-items: center; font-size: 0.7rem; font-weight: 700; color: #fff; }
.cal .cal-cell { height: 1.9rem; border-radius: 0.4rem; background: var(--slate-100); position: relative; }
.cal .cal-chip { position: absolute; inset: 0; border-radius: 0.4rem; display: grid; place-items: center; font-size: 0.62rem; font-weight: 700; color: #fff; opacity: 0; transform: scale(0.7); transition: all 0.35s ease; }
.cal .cal-chip.show { opacity: 1; transform: scale(1); }
.cal-chip.pto { background: #22c55e; }
.cal-chip.sick { background: #f59e0b; }
.cal-chip.hol { background: #94a3b8; }
.coverage {
  margin-top: 0.9rem; border-radius: 0.7rem; padding: 0.65rem 0.9rem; font-size: 0.82rem; font-weight: 600;
  display: flex; align-items: center; gap: 0.5rem; transition: all 0.4s ease;
}
.coverage.risk { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }
.coverage.ok { background: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }

/* timesheet */
.ts { font-size: 0.82rem; }
.ts-row { display: grid; grid-template-columns: 6rem 1fr 4.5rem; gap: 0.5rem; align-items: center; padding: 0.4rem 0; border-bottom: 1px solid var(--slate-100); }
.ts-row .ts-day { font-weight: 600; color: var(--slate-600); }
.ts-row.holiday .ts-day { color: var(--slate-400); }
.ts-bar-track { height: 0.55rem; border-radius: 9999px; background: var(--slate-100); overflow: hidden; }
.ts-bar-fill { height: 100%; width: 0; border-radius: 9999px; background: linear-gradient(to right, #2dd4bf, #14b8a6); transition: width 0.6s ease; }
.ts-row.holiday .ts-bar-fill { background: var(--slate-300); }
.ts-hrs { text-align: right; font-variant-numeric: tabular-nums; font-weight: 600; }
.ts-chip { font-size: 0.62rem; font-weight: 700; color: var(--slate-500); background: var(--slate-100); border-radius: 9999px; padding: 0.05rem 0.45rem; margin-left: 0.4rem; }
.ts-summary { margin-top: 0.9rem; border-radius: 0.7rem; background: var(--slate-50); border: 1px solid var(--slate-200); padding: 0.8rem 0.95rem; }
.ts-summary .ts-line { display: flex; justify-content: space-between; font-size: 0.82rem; }
.ts-summary .big { font-size: 1.25rem; font-weight: 800; font-variant-numeric: tabular-nums; }
.ts-summary .ts-prog { height: 0.5rem; border-radius: 9999px; background: var(--slate-200); margin-top: 0.55rem; overflow: hidden; }
.ts-summary .ts-prog > span { display: block; height: 100%; width: 0; background: linear-gradient(to right, #2dd4bf, #14b8a6); transition: width 0.8s ease; }
.leave-aware { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.7rem; font-weight: 700; color: #0f766e; background: #ccfbf1; border-radius: 9999px; padding: 0.15rem 0.55rem; }

/* radar */
.radar-wrap { display: flex; flex-direction: column; align-items: center; }
.radar { width: 100%; max-width: 22rem; height: auto; }
.radar .grid-line { fill: none; stroke: var(--slate-200); }
.radar .axis { stroke: var(--slate-200); }
.radar .blob { fill: color-mix(in oklab, #ec4899 22%, transparent); stroke: #ec4899; stroke-width: 2; stroke-linejoin: round; transition: all 1s ease; }
.radar .pt { fill: #ec4899; }
.radar .lbl { font-size: 9px; fill: var(--slate-500); font-weight: 600; }
.radar-meta { margin-top: 0.6rem; display: flex; align-items: center; gap: 0.6rem; flex-wrap: wrap; justify-content: center; }
.priv-chip { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.72rem; font-weight: 700; color: #9d174d; background: #fce7f3; border-radius: 9999px; padding: 0.2rem 0.6rem; }
.resp-chip { font-size: 0.72rem; color: var(--slate-500); font-variant-numeric: tabular-nums; }

/* ================= agent chat demo ================= */
.demo { width: 100%; max-width: 38rem; margin-inline: auto; }
.demo-switch { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 0.75rem; }
.demo-tab {
  white-space: nowrap; border-radius: 9999px; border: 1px solid var(--slate-200);
  padding: 0.35rem 0.95rem; font-size: 0.82rem; color: var(--slate-500); background: #fff; cursor: pointer; transition: all 0.15s;
}
.demo-tab:hover { border-color: var(--slate-300); color: var(--slate-700); }
.demo-tab.is-active { border-color: var(--sky-500); background: #eff6ff; color: var(--sky-700); }
.demo-window {
  overflow: hidden; border-radius: 1rem; border: 1px solid var(--slate-200);
  background-image: linear-gradient(135deg, #0c1a2e, #0e2233 55%, #10283a);
  box-shadow: 0 30px 60px -25px rgba(8, 47, 73, 0.55); color: #fff;
}
.demo-chrome { display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid rgba(255,255,255,0.1); padding: 0.6rem 1rem; }
.demo-dots { display: flex; gap: 0.35rem; }
.demo-dots span { width: 0.6rem; height: 0.6rem; border-radius: 9999px; }
.demo-dots .r { background: rgba(248,113,113,0.7); } .demo-dots .y { background: rgba(251,191,36,0.7); } .demo-dots .g { background: rgba(52,211,153,0.7); }
.demo-persona { font-size: 0.69rem; color: rgba(255,255,255,0.4); }
.demo-servers { display: flex; align-items: center; gap: 0.35rem; font-size: 0.69rem; color: rgba(110,231,183,0.85); }
.demo-servers .live { width: 0.4rem; height: 0.4rem; border-radius: 9999px; background: #34d399; }
.demo-prompt { border-bottom: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.02); padding: 0.75rem 1rem; }
.demo-prompt .lbl { display: flex; align-items: center; gap: 0.35rem; font-size: 0.62rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: rgba(125,211,252,0.7); margin-bottom: 0.3rem; }
.demo-prompt .lbl span { width: 0.35rem; height: 0.35rem; border-radius: 9999px; background: #38bdf8; }
.demo-prompt p { margin: 0; font-size: 0.875rem; color: rgba(255,255,255,0.9); line-height: 1.5; }
.demo-thread { height: 21rem; overflow-y: auto; padding: 1rem; display: flex; flex-direction: column; gap: 0.75rem; }
.tool { border-radius: 0.75rem; border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.03); padding: 0.75rem; }
.tool-top { display: flex; align-items: center; gap: 0.5rem; }
.mcp { border-radius: 0.4rem; border: 1px solid; padding: 0.1rem 0.45rem; font-size: 0.62rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; }
.sb-mcp-orbit { background: rgba(14,165,233,0.15); color: #7dd3fc; border-color: rgba(14,165,233,0.3); }
.sb-mcp-jira { background: rgba(59,130,246,0.15); color: #93c5fd; border-color: rgba(59,130,246,0.3); }
.sb-mcp-github { background: rgba(161,161,170,0.15); color: #e4e4e7; border-color: rgba(161,161,170,0.3); }
.sb-mcp-slack { background: rgba(217,70,239,0.15); color: #f0abfc; border-color: rgba(217,70,239,0.3); }
.tool code.tname { font-size: 0.75rem; font-weight: 600; color: rgba(255,255,255,0.85); }
.tool .args { margin-top: 0.4rem; display: block; word-break: break-all; font-size: 0.69rem; line-height: 1.5; color: rgba(255,255,255,0.4); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.tool .res { margin-top: 0.5rem; border-radius: 0.5rem; background: rgba(8,47,73,0.4); padding: 0.4rem 0.6rem; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 0.69rem; line-height: 1.5; color: rgba(110,231,183,0.9); }
.tool .tick { margin-left: auto; color: #34d399; font-weight: 700; }
.tool .typing { margin-left: auto; display: inline-flex; gap: 0.15rem; }
.tool .typing i { width: 0.25rem; height: 0.25rem; border-radius: 9999px; background: rgba(255,255,255,0.5); animation: sb-bounce 1s infinite; }
.tool .typing i:nth-child(2) { animation-delay: 0.12s; } .tool .typing i:nth-child(3) { animation-delay: 0.24s; }
.msg-ai { display: flex; gap: 0.6rem; }
.msg-ai .av { margin-top: 0.1rem; flex: none; width: 1.75rem; height: 1.75rem; border-radius: 9999px; display: grid; place-items: center; font-size: 0.62rem; font-weight: 700; color: #fff; background: linear-gradient(135deg, #8b5cf6, #0ea5e9); }
.msg-ai .bubble { max-width: 85%; border-radius: 1rem; border-bottom-left-radius: 0.25rem; border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.05); padding: 0.6rem 0.9rem; font-size: 0.85rem; color: rgba(255,255,255,0.9); line-height: 1.55; }
.demo-foot { display: flex; align-items: center; justify-content: space-between; border-top: 1px solid rgba(255,255,255,0.1); padding: 0.5rem 1rem; }
.demo-foot .note { font-size: 0.69rem; color: rgba(255,255,255,0.35); }
.demo-foot .replay { display: inline-flex; align-items: center; gap: 0.3rem; border: 0; background: transparent; color: rgba(255,255,255,0.6); font-size: 0.75rem; cursor: pointer; padding: 0.25rem 0.5rem; border-radius: 0.5rem; }
.demo-foot .replay:hover { background: rgba(255,255,255,0.1); color: #fff; }

@keyframes sb-bounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-0.2rem); } }
@keyframes sb-fade { from { opacity: 0; transform: translateY(0.4rem); } to { opacity: 1; transform: none; } }
.tool, .msg-ai { animation: sb-fade 0.3s ease both; }

/* reduced motion: show final state, no animation */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .cal .cal-chip { opacity: 1; transform: none; }
}
