/* =========================================================================
   site3 — "Scroll Through the Product"
   Faithful replica of the Synopsis app shell. Tokens verbatim from the app.

   SCROLL MODEL: full-viewport scroll-snap pages (one page per gesture; never
   rest between two). Animations are 100% time-based (rAF clock), decoupled
   from scroll — see app.js. No pinned tracks, no scroll scrubbing.
   ========================================================================= */

/* ---------- Aspekta @font-face (self-hosted) ---------- */
@font-face { font-family:"Aspekta"; src:url("assets/fonts/Aspekta-100.woff2") format("woff2"); font-weight:100; font-style:normal; font-display:swap; }
@font-face { font-family:"Aspekta"; src:url("assets/fonts/Aspekta-200.woff2") format("woff2"); font-weight:200; font-style:normal; font-display:swap; }
@font-face { font-family:"Aspekta"; src:url("assets/fonts/Aspekta-300.woff2") format("woff2"); font-weight:300; font-style:normal; font-display:swap; }
@font-face { font-family:"Aspekta"; src:url("assets/fonts/Aspekta-400.woff2") format("woff2"); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:"Aspekta"; src:url("assets/fonts/Aspekta-500.woff2") format("woff2"); font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:"Aspekta"; src:url("assets/fonts/Aspekta-600.woff2") format("woff2"); font-weight:600; font-style:normal; font-display:swap; }
@font-face { font-family:"Aspekta"; src:url("assets/fonts/Aspekta-700.woff2") format("woff2"); font-weight:700; font-style:normal; font-display:swap; }

:root{
  /* Side-nav rail (dark) */
  --rail-bg:#212121; --rail-border:#424242; --rail-text:#bdbdbd; --rail-text-hover:#ffffff;
  --rail-hover-bg:rgba(255,255,255,0.08);
  --rail-active-fg:#6663FD; --rail-active-bg:rgba(102,99,253,0.12); --rail-icon-dim:#9e9e9e;

  /* Canvas (light) */
  --canvas-bg:#F8F9FA; --paper:#FFFFFF; --divider:rgba(0,0,0,0.12);

  /* Brand */
  --purple:#6663FD; --purple-08:rgba(102,99,253,0.08);

  /* Text ramp */
  --text-primary:#0A0A0A; --text-secondary:#6B7280; --text-disabled:#9CA3AF;
  --greeting-grey:#484848;

  /* Semantic */
  --success:#2e7d32; --warning:#ed6c02; --error:#d32f2f; --info:#0288d1;

  /* Chat bubbles */
  --user-bubble-bg:#eeeeee;

  /* synopsis categorical palette (OKLCH, verbatim) */
  --syn-0:oklch(0.5916 0.2223 278.02); --syn-1:oklch(0.70 0.15 50); --syn-2:oklch(0.65 0.20 160);
  --syn-3:oklch(0.60 0.18 140); --syn-4:oklch(0.75 0.15 90); --syn-5:oklch(0.55 0.18 15);

  --rail-w:84px;  /* narrow icon-over-label rail (gives the docked chat room) */
  --font:"Aspekta","Inter",system-ui,-apple-system,sans-serif;
  --mono:"IBM Plex Mono","Fira Code",monospace;
  /* Caveat: hand-style annotation font for the hero deck labels ONLY */
  --annot:"Caveat",ui-rounded,"Segoe Print",cursive;
}

*{box-sizing:border-box;}
body{
  margin:0; font-family:var(--font); color:var(--text-primary);
  background:#0c0c10; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
img{display:block;}
button{font-family:inherit;cursor:pointer;border:0;background:none;}
svg.icon{display:block;}
[data-icon]{display:inline-flex;align-items:center;justify-content:center;}
[data-icon] svg{width:1em;height:1em;stroke:currentColor;}

/* ============================ SCROLL-SNAP ENGINE ============================
   The scroller is the snap ROOT. Each .page is exactly one viewport tall and
   snaps to start with snap-stop:always, so a single gesture always lands
   cleanly on one page — the user can never rest between two pages.
   ============================================================================ */
html,body{height:100%;}
.scroller{
  height:100dvh;overflow-y:auto;overflow-x:hidden;
  scroll-snap-type:y mandatory;scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  margin-left:0;transition:margin-left .5s cubic-bezier(.4,0,.2,1);
  background:var(--canvas-bg);
}
body.app-booted .scroller{margin-left:var(--rail-w);}

.page{
  position:relative;height:100dvh;width:100%;overflow:hidden;
  scroll-snap-align:start;scroll-snap-stop:always;
  contain:layout paint;
}

/* ============================ SIDE-NAV RAIL (expanded 240px) ============================ */
.rail{
  position:fixed;left:0;top:0;height:100vh;width:var(--rail-w);
  background:var(--rail-bg);z-index:1000;
  display:flex;flex-direction:column;align-items:stretch;
  transform:translateX(-100%);transition:transform .5s cubic-bezier(.4,0,.2,1);
  border-right:1px solid var(--rail-border);
}
body.app-booted .rail{transform:translateX(0);}
.rail__logo{display:flex;align-items:center;justify-content:center;padding:18px 0;border-bottom:1px solid var(--rail-border);flex-shrink:0;}
.rail__logo img{display:block;}
.rail__group{display:flex;flex-direction:column;padding:12px 0 6px;}
.rail__spacer{flex:1;}
.rail__item{
  position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  min-height:56px;padding:11px 4px;color:var(--rail-text);text-align:center;
  font-size:0.625rem;line-height:1;transition:background .12s ease,color .12s ease;
}
.rail__icon{font-size:20px;display:flex;flex-shrink:0;color:inherit;}
.rail__label{font-size:0.625rem;white-space:nowrap;font-weight:500;color:inherit;letter-spacing:.005em;}
.rail__item:hover{background:var(--rail-hover-bg);color:var(--rail-text-hover);}
.rail__item[aria-current="true"]{
  color:var(--rail-active-fg);background:var(--rail-active-bg);
  box-shadow:inset 3px 0 0 currentColor;
}
.rail__item[aria-current="true"] .rail__label{font-weight:600;}
.rail__divider{height:1px;background:var(--rail-border);margin:8px 16px;}
.rail__item--engine .rail__label{color:var(--rail-text);}
.rail__item--engine:hover .rail__label{color:var(--rail-text-hover);}

/* footer cluster: profile row + upward dropdown */
.rail__group--footer{border-top:1px solid var(--rail-border);padding:0;position:relative;}
.rail__profile{
  width:100%;display:flex;align-items:center;justify-content:center;gap:12px;
  padding:14px 4px;min-height:56px;color:var(--rail-text);
  transition:background .12s ease,color .12s ease;text-align:left;
}
/* narrow rail: avatar only (name + chevron hidden); dropdown still opens */
.rail__name,.rail__chev{display:none;}
.rail__profile:hover{background:var(--rail-hover-bg);color:var(--rail-text-hover);}
.rail__avatar{
  width:30px;height:30px;border-radius:50%;background:#ec407a;color:#fff;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:0.6875rem;font-weight:600;letter-spacing:.02em;
}
.rail__name{flex:1;font-size:0.8125rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rail__chev{font-size:16px;color:var(--rail-icon-dim);display:flex;flex-shrink:0;transition:transform .18s ease;}
.rail__profile[aria-expanded="true"] .rail__chev{transform:rotate(180deg);}

.profile-pop{
  position:absolute;left:8px;right:auto;width:232px;bottom:calc(100% + 6px);
  background:#2b2b2b;border:1px solid var(--rail-border);border-radius:8px;
  box-shadow:0 -8px 28px rgba(0,0,0,.45);
  padding:6px;display:flex;flex-direction:column;z-index:20;
  transform-origin:bottom center;
  opacity:0;transform:translateY(8px) scale(.98);pointer-events:none;
  transition:opacity .16s ease,transform .16s ease;
}
.profile-pop.is-open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;}
.profile-pop[hidden]{display:none;}
.profile-pop__item{
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:6px;
  color:#e7e7ee;font-size:0.8125rem;font-weight:500;transition:background .12s,color .12s;
}
.profile-pop__item [data-icon]{font-size:16px;color:var(--rail-icon-dim);display:flex;}
.profile-pop__item:hover{background:var(--rail-hover-bg);color:#fff;}
.profile-pop__item--cta{background:var(--purple);color:#fff;}
.profile-pop__item--cta [data-icon]{color:#fff;}
.profile-pop__item--cta:hover{filter:brightness(1.08);background:var(--purple);color:#fff;}
.profile-pop__divider{height:1px;background:var(--rail-border);margin:6px 4px;}
.profile-pop__link{
  padding:7px 12px;border-radius:6px;color:var(--rail-text);font-size:0.78rem;transition:background .12s,color .12s;
}
.profile-pop__link:hover{background:var(--rail-hover-bg);color:#fff;}

/* ============================ BUTTONS (shared) ============================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:4px;
  font-weight:500;font-size:0.9rem;padding:8px 16px;text-transform:none;transition:filter .12s,background .12s,border-color .12s;}
.btn--lg{padding:11px 22px;font-size:1rem;}
.btn--solid{background:var(--purple);color:#fff;}
.btn--solid:hover{filter:brightness(1.08);}
.btn--ghost-dark{color:#e7e7ee;border:1px solid rgba(255,255,255,.28);}
.btn--ghost-dark:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5);}

/* ============================ SECTION 1 — LANDING ============================ */
.landing{background:transparent;
  display:flex;flex-direction:column;align-items:center;justify-content:center;}
.landing__bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(1100px 620px at 78% -10%, rgba(102,99,253,.30), transparent 60%),
    radial-gradient(900px 720px at 6% 112%, rgba(102,99,253,.16), transparent 55%),
    linear-gradient(180deg,#0c0c12 0%,#15131f 55%,#0c0c12 100%);
}
.landing__nav{
  position:absolute;top:0;left:0;right:0;z-index:6;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(24px,5vw,72px);
}
.landing__nav-cta{display:flex;gap:12px;}

/* vertically centered hero column that fills tall viewports gracefully */
.landing__hero{
  position:relative;z-index:2;width:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:clamp(26px,4.5vh,62px);
  padding:clamp(78px,9vh,104px) 24px 56px;will-change:transform,opacity;
}
.landing__copy{text-align:center;max-width:760px;}
.landing__h1{
  margin:0 auto 16px;max-width:17ch;color:#fff;font-weight:300;
  font-size:clamp(2.2rem,5vw,3.9rem);line-height:1.04;letter-spacing:-.025em;
}
.landing__sub{
  margin:0 auto 24px;max-width:60ch;color:rgba(255,255,255,.74);
  font-size:clamp(1rem,1.5vw,1.16rem);font-weight:300;line-height:1.55;
}
.landing__cta{display:flex;gap:14px;justify-content:center;}

/* ---- THREE staggered live demo cards — Deepnote-style horizontal fan ---- */
.herodecks{
  position:relative;
  width:min(1260px,95vw);
  height:clamp(300px,44vh,484px);
  flex-shrink:0;
}
.deck{
  position:absolute;left:50%;top:54%;margin:0;
  width:min(476px,32vw);min-width:348px;
  transition:transform .46s cubic-bezier(.22,.61,.36,1),opacity .46s ease;
  will-change:transform,opacity;
}
.deck__card{
  border-radius:13px;overflow:hidden;border:1px solid rgba(255,255,255,.12);
  background:#1c1c22;
  box-shadow:0 34px 90px -30px rgba(0,0,0,.78);
  transition:box-shadow .46s ease;
}
/* default diagonal fan — wide horizontal spread, light overlap; chat front+center */
.deck--wf   { transform:translate(-50%,-50%) translate(-360px,-26px) rotate(-5deg) scale(.86); z-index:1; opacity:.9; }
.deck--dash { transform:translate(-50%,-50%) translate(360px,-12px)  rotate(5deg)  scale(.88); z-index:2; opacity:.92; }
.deck--chat { transform:translate(-50%,-50%) translate(0,42px) scale(1.02); z-index:3; opacity:1; }

/* hovered deck raises to top + slides up; others recede slightly */
.herodecks.has-hover .deck{opacity:.62;}
.herodecks .deck.is-hover{z-index:9 !important;opacity:1 !important;}
.herodecks .deck.is-hover .deck__card{box-shadow:0 48px 120px -32px rgba(0,0,0,.88);}
.deck--wf.is-hover   { transform:translate(-50%,-50%) translate(-360px,-58px) rotate(-3deg) scale(.92); }
.deck--dash.is-hover { transform:translate(-50%,-50%) translate(360px,-46px)  rotate(3deg)  scale(.92); }
.deck--chat.is-hover { transform:translate(-50%,-50%) translate(0,18px) scale(1.07); }

/* entrance: decks rise+fade on load (driven by .is-shown toggle) */
.deck{opacity:0;}
.herodecks.is-shown .deck{opacity:var(--deck-op,1);}

/* hand-style annotation above each card */
.deck__annot{
  position:absolute;bottom:calc(100% + 6px);
  display:flex;flex-direction:column;align-items:center;gap:0;
  font-family:var(--annot);color:rgba(255,255,255,.9);
  pointer-events:none;white-space:nowrap;
  opacity:0;transform:translateY(6px);transition:opacity .5s ease,transform .5s ease;
}
.herodecks.is-shown .deck__annot{opacity:1;transform:none;}
.deck__annot-text{
  font-size:1.55rem;font-weight:600;line-height:1;letter-spacing:.01em;
  text-shadow:0 1px 14px rgba(102,99,253,.35);
}
.deck__annot--left{left:8%;transform:translateY(6px) rotate(-3deg);}
.herodecks.is-shown .deck__annot--left{transform:rotate(-3deg);}
.deck__annot--right{right:6%;transform:translateY(6px) rotate(3deg);}
.herodecks.is-shown .deck__annot--right{transform:rotate(3deg);}
.deck__annot--center{left:50%;transform:translate(-50%,6px);}
.herodecks.is-shown .deck__annot--center{transform:translateX(-50%);}
/* little hand-drawn arrow that points down to the card */
.deck__annot-arrow{position:relative;width:42px;height:26px;margin-top:1px;}
.deck__annot-arrow::before{
  content:"";position:absolute;inset:0;
  background:no-repeat center/contain;
}
.deck__annot-arrow[data-arrow="center"]::before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 42 26'%3E%3Cpath d='M21 1 C19 9 22 15 21 22' fill='none' stroke='%23b9b7ff' stroke-width='2' stroke-linecap='round'/%3E%3Cpath d='M16 17 L21 24 L26 17' fill='none' stroke='%23b9b7ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
.deck__annot-arrow[data-arrow="left"]::before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 42 26'%3E%3Cpath d='M30 1 C20 6 14 12 13 21' fill='none' stroke='%23b9b7ff' stroke-width='2' stroke-linecap='round'/%3E%3Cpath d='M9 14 L12 23 L20 19' fill='none' stroke='%23b9b7ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
.deck__annot-arrow[data-arrow="right"]::before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 42 26'%3E%3Cpath d='M12 1 C22 6 28 12 29 21' fill='none' stroke='%23b9b7ff' stroke-width='2' stroke-linecap='round'/%3E%3Cpath d='M22 19 L30 23 L33 14' fill='none' stroke='%23b9b7ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.deck__bar{
  display:flex;align-items:center;gap:7px;padding:10px 13px;background:#26262e;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.dot{width:10px;height:10px;border-radius:50%;}
.dot--r{background:#ff5f57;}.dot--y{background:#febc2e;}.dot--g{background:#28c840;}
.deck__app{
  margin-left:10px;display:inline-flex;align-items:center;gap:7px;
  font-size:.72rem;font-weight:500;color:rgba(255,255,255,.66);
}
.deck__app-icon{font-size:14px;display:flex;color:rgba(255,255,255,.5);}
.deck__body{background:var(--canvas-bg);overflow:hidden;}

/* mini chat demo (front card) */
.mini-chat{padding:18px 18px 6px;display:flex;flex-direction:column;gap:11px;min-height:236px;}
.mini-chat__user{
  align-self:flex-end;background:var(--user-bubble-bg);color:var(--text-primary);
  border-radius:12px;padding:9px 13px;font-size:.84rem;line-height:1.42;max-width:88%;
}
.mini-chat__assistant{
  align-self:flex-start;color:var(--text-primary);font-size:.86rem;line-height:1.5;max-width:98%;min-height:1.2em;
}
.mini-chat__assistant strong{font-weight:600;}
.mini-chat__caret{display:inline-block;width:2px;height:1em;background:var(--purple);margin-left:1px;vertical-align:-2px;border-radius:1px;animation:blink 1s step-end infinite;}
.mini-chat__chart{
  align-self:stretch;background:#fff;border:1px solid var(--divider);border-radius:8px;
  padding:9px 11px 8px;margin-top:1px;
}
.mini-chat__chart[hidden]{display:none;}
.mini-chat__chart-title{font-size:.6rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;}
.mini-chat__bars{display:flex;align-items:flex-end;gap:8px;height:54px;margin-top:7px;}
.mini-cbar{flex:1;height:var(--h);background:var(--c);border-radius:3px 3px 0 0;transform:scaleY(0);transform-origin:bottom;}
.mini-chat__source{font-size:.66rem;color:var(--text-disabled);margin-top:-2px;}
.mini-chat__source[hidden]{display:none;}
/* L1: the input row sits on the same light canvas as the rest of the chat card,
   not on the dark card shell — so it never reads as a separate black footer box. */
.mini-chat__inputwrap{background:var(--canvas-bg);padding:4px 14px 14px;}
.mini-chat__input{
  display:flex;align-items:center;gap:8px;padding:9px 10px 9px 13px;
  background:#fff;border:1px solid var(--divider);border-radius:9px;
}
.mini-chat__ph{flex:1;font-size:.78rem;color:var(--text-disabled);}
.mini-chat__send{font-size:17px;color:var(--purple);display:flex;}

/* mini dashboard demo (right card) */
.mini-dash{display:flex;flex-direction:column;gap:9px;padding:14px;min-height:268px;}
.mini-dash__row{display:flex;gap:9px;}
.mini-card{
  background:#fff;border:1px solid var(--divider);border-radius:8px;padding:11px 13px;
  display:flex;flex-direction:column;gap:5px;
}
.mini-card--kpi{flex:1;}
.mini-card--chart{flex:1;gap:8px;}
.mini-card--list{gap:7px;}
.mini-list{display:flex;flex-direction:column;gap:6px;}
.mini-list__row{display:flex;align-items:center;justify-content:space-between;font-size:.72rem;}
.mini-list__name{color:var(--text-primary);font-weight:500;}
.mini-list__val{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-weight:600;}
.mini-card__label{font-size:.58rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;}
.mini-card__val{font-size:1.5rem;font-weight:600;letter-spacing:-.02em;line-height:1;}
.mini-card__delta{display:inline-flex;align-items:center;gap:4px;font-size:.74rem;font-weight:500;color:var(--success);}
.mini-card__delta [data-icon]{font-size:13px;}
.mini-bars{display:flex;align-items:flex-end;gap:14px;height:78px;}
.mini-barcol{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:5px;}
.mini-barcol span{font-size:.58rem;color:var(--text-secondary);}
/* L4: bars must vary by their --h (West 100 / SE 64 / MW 46 / EMEA 30);
   the bar wrapper owns the height, the fill scales in on top of it. */
.mini-bar{width:100%;height:var(--h);background:var(--c);border-radius:3px 3px 0 0;transform:scaleY(0);transform-origin:bottom;}

/* mini workflow demo (left card) */
.deck__body--wf{padding:10px 8px;min-height:222px;display:flex;}
.mini-wf{width:100%;height:100%;}
.mini-node rect:first-of-type{fill:#fff;stroke:#e0e0e0;stroke-width:2;}  /* node body only */
.mini-node__strip{stroke:none;}
.mini-node__ico{stroke:none;}  /* colored icon tiles keep their inline fill */
.mini-node text{font-family:var(--font);font-size:12px;font-weight:600;fill:var(--text-primary);}
.mini-node--trigger rect:first-of-type{stroke:#5cb85c;}
.mini-wf__edge{stroke-dasharray:120;stroke-dashoffset:0;}

.landing__scrollhint{
  position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:5;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  color:rgba(255,255,255,.6);font-size:.82rem;font-weight:300;cursor:pointer;
}
.landing__scrollhint:hover{color:rgba(255,255,255,.85);}
.landing__scrollhint .chev{font-size:18px;animation:bob 1.8s ease-in-out infinite;}
@keyframes bob{0%,100%{transform:translateY(0);}50%{transform:translateY(6px);}}

/* ===== SHARED: callout annotation (distinct from the product UI — surfaces a key marketing point) ===== */
.s3-callout{
  display:flex;gap:11px;align-items:flex-start;max-width:560px;
  padding:13px 16px;border-radius:11px;
  background:linear-gradient(rgba(102,99,253,.06),rgba(102,99,253,.06)),var(--paper);
  border:1px solid rgba(102,99,253,.28);box-shadow:inset 3px 0 0 var(--purple);
  color:var(--text-secondary);font-size:.9rem;line-height:1.5;
}
.s3-callout__icon{color:var(--purple);flex:0 0 auto;margin-top:1px;display:flex;}
.s3-callout__icon svg{width:17px;height:17px;}
.s3-callout strong,.s3-callout b{color:var(--text-primary);font-weight:600;}
.s3-callout--dark{
  background:linear-gradient(rgba(124,124,255,.10),rgba(124,124,255,.10));
  border-color:rgba(124,124,255,.3);color:rgba(255,255,255,.78);
}
.s3-callout--dark strong{color:#fff;}

/* ===== SHARED: reusable bobbing scroll hint (matches the landing hero hint) ===== */
.s3-scrollhint{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  color:var(--text-disabled);font-size:.82rem;font-weight:400;cursor:pointer;
  background:none;border:0;transition:color .15s ease;
}
.s3-scrollhint:hover{color:var(--text-secondary);}
.s3-scrollhint .chev{display:flex;animation:bob 1.8s ease-in-out infinite;}
.s3-scrollhint .chev svg{width:18px;height:18px;}
@media (prefers-reduced-motion:reduce){ .s3-scrollhint .chev{animation:none;} }

/* bobbing scroll caret for the dark engine pages (injected per-section) */
.s3-caret{
  position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:6;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.42);pointer-events:auto;
}
.s3-caret:hover{color:rgba(255,255,255,.8);}
.s3-caret svg{width:26px;height:26px;animation:bob 1.8s ease-in-out infinite;}
body.is-stacked .s3-caret{display:none;}
@media (prefers-reduced-motion:reduce){ .s3-caret svg{animation:none;} }

/* ============================ SECTION 2 — CHAT ============================ */
.chat{background:var(--canvas-bg);}
.chat__toprail{
  position:absolute;top:0;right:0;z-index:5;padding:16px 32px 0 0;
  display:flex;flex-direction:column;gap:8px;
}
.iconbtn{
  width:40px;height:40px;padding:8px;border-radius:8px;border:1px solid rgba(0,0,0,.12);
  background:#fff;color:#374151;font-size:20px;display:flex;align-items:center;justify-content:center;
  transition:background .12s;
}
.iconbtn:hover{background:#f3f4f6;}
.iconbtn--sm{width:28px;height:28px;padding:5px;font-size:16px;border:0;color:#9e9e9e;}
.chat__center{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:0 24px;
}
.chat__greeting{
  margin:0 0 32px;font-weight:100;font-size:2.6rem;color:var(--greeting-grey);text-align:center;
  letter-spacing:-.01em;overflow:hidden;will-change:transform,opacity,max-height,margin;
}
.chat__thread{width:100%;max-width:768px;display:flex;flex-direction:column;gap:14px;margin-bottom:32px;}
.chat__thread:empty{margin-bottom:0;}

/* prompt box (flat, outlined) */
.promptbox{
  width:100%;max-width:804px;background:#fff;border:1px solid var(--divider);border-radius:8px;
  padding:8px 8px 8px 16px;display:flex;align-items:center;gap:8px;min-height:56px;
}
.promptbox__text{flex:1;min-width:0;display:block;font-size:1rem;line-height:1.45;color:var(--text-primary);}
.promptbox__ph{color:var(--text-disabled);}
.promptbox__caret{display:inline-block;width:3px;height:1.15em;background:var(--purple);margin-left:2px;vertical-align:-2px;border-radius:1px;animation:blink 1.05s step-end infinite;}
@keyframes blink{50%{opacity:0;}}
.promptbox__controls{display:flex;align-items:center;gap:2px;}
.promptbox__icon{width:36px;height:36px;border-radius:6px;color:#6B7280;font-size:20px;display:flex;align-items:center;justify-content:center;}
.promptbox__icon:hover{background:#f3f4f6;}
.promptbox__send{width:40px;height:40px;border-radius:8px;color:var(--purple);font-size:20px;display:flex;align-items:center;justify-content:center;transition:transform .18s ease,background .18s ease,box-shadow .18s ease;}
.promptbox__send:hover{background:var(--purple-08);}
.promptbox__send.is-sending{background:var(--purple);color:#fff;transform:scale(.86);box-shadow:0 0 0 4px var(--purple-08);transition:transform .12s ease,background .12s ease,box-shadow .12s ease;}
.promptbox__timer{font-family:var(--mono);font-size:.85rem;color:var(--text-secondary);padding:0 8px;}

.chat__foreshadow{
  position:absolute;bottom:30px;left:0;right:0;margin:0;opacity:0;
  display:flex;justify-content:center;
}

/* chat messages */
.msg{display:flex;width:100%;}
.msg--user{justify-content:flex-end;}
.msg--assistant{justify-content:flex-start;}
.msg__user-bubble{
  background:var(--user-bubble-bg);color:var(--text-primary);border-radius:12px;
  padding:10px 15px;max-width:80%;white-space:pre-wrap;font-size:1rem;line-height:1.5;
}
.msg__assistant{
  background:transparent;border-radius:0;padding:5px;max-width:100%;width:100%;
  font-size:1rem;line-height:1.62;color:var(--text-primary);
}
.msg__assistant p{margin:0 0 .6em;}
.msg__assistant strong{font-weight:600;}
.msg__source{display:block;margin-top:8px;color:var(--text-disabled);font-size:.8rem;}
.msg__chip{
  display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:7px 14px;border-radius:18px;
  background:var(--purple);color:#fff;font-size:.85rem;font-weight:500;
}

/* inline chart inside a chat answer */
.msg__chart{
  margin-top:14px;background:#fff;border:1px solid var(--divider);border-radius:8px;
  padding:12px 14px 10px;max-width:420px;
}
.msg__chart-title{font-size:.74rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px;}
.msg__chart-bars{display:flex;align-items:flex-end;gap:14px;height:140px;padding-bottom:22px;}
.msg__chart-bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative;}
.msg__chart-fill{width:100%;max-width:44px;height:var(--h);background:var(--c);border-radius:4px 4px 0 0;transform:scaleY(0);transform-origin:bottom;transition:transform .5s cubic-bezier(.22,.61,.36,1);}
.msg__chart-lbl{position:absolute;bottom:-18px;font-size:.68rem;color:var(--text-secondary);white-space:nowrap;}

/* SynopsisProgressBar — branded breathing bar (clip-path notch verbatim) */
.synbar{
  height:20px;width:100%;max-width:768px;border-radius:0;overflow:hidden;position:relative;
  background:rgba(102,99,253,.12);
  clip-path:polygon(0 0,0 100%,100% 100%,100% 0,calc(100% - 10px) 0,calc(100% - 10px) 10px,10px 10px,10px 0);
}
.synbar::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,var(--purple),transparent);
  background-size:50% 100%;background-repeat:no-repeat;
  animation:synsweep 1.4s ease-in-out infinite;
}
@keyframes synsweep{0%{background-position:-60% 0;}100%{background-position:160% 0;}}

/* ============================ SECTION 3 — DASHBOARDS ============================ */
.dash{background:var(--canvas-bg);}
.dock{
  position:absolute;left:0;top:0;bottom:0;width:360px;background:#fff;border-right:1px solid var(--divider);
  display:flex;flex-direction:column;z-index:4;
  transform:translateX(-12px);opacity:0;will-change:transform,opacity;
}
.dock__head{display:flex;align-items:center;gap:8px;padding:14px 16px;border-bottom:1px solid var(--divider);flex-shrink:0;}
.dock__logo{display:none;}
.dock__title{font-weight:600;font-size:.95rem;flex:1;}
.dock__thread{flex:1 1 auto;overflow:hidden;padding:18px 16px;display:flex;flex-direction:column;gap:12px;min-height:0;}
.dock__thread .msg__assistant{font-size:.92rem;line-height:1.55;}
.dock__thread .msg__user-bubble{font-size:.92rem;}
.dock__thread .synbar{max-width:100%;}
.dock__inputwrap{flex-shrink:0;padding:0 16px 16px;background:#fff;}
.promptbox--dock{margin:0;min-height:48px;max-width:none;width:100%;}

.board{
  position:absolute;left:360px;top:0;right:0;bottom:0;display:flex;flex-direction:column;
  overflow:hidden;will-change:transform;
}
.page-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 28px;background:var(--canvas-bg);flex-shrink:0;
  opacity:0;will-change:opacity,transform;
}
.page-header__title{display:flex;align-items:center;gap:12px;}
.page-header__icon{font-size:24px;color:var(--text-primary);display:flex;}
.page-header__title h3{margin:0;font-size:1.8rem;font-weight:500;letter-spacing:-.01em;}
.page-header__actions{display:flex;gap:8px;}
.hbtn{
  display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:4px;
  border:1px solid var(--divider);background:#fff;color:var(--text-primary);font-size:.85rem;font-weight:500;
}
.hbtn [data-icon]{font-size:16px;}
.hbtn:hover{background:#f3f4f6;}
.hbtn--solid{background:var(--purple);color:#fff;border-color:var(--purple);}
.hbtn--solid:hover{background:var(--purple);filter:brightness(1.06);}

.board__filterbar{
  display:flex;gap:8px;padding:0 28px 10px;opacity:0;will-change:opacity,transform;flex-shrink:0;
}
.filter-chip{
  display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:18px;
  border:1px solid var(--divider);background:#fff;font-size:.82rem;color:var(--text-secondary);
}
.filter-chip [data-icon]{font-size:14px;}

/* D2: the grid hugs its content (4 widgets) and centers vertically — so removing
   the markdown widget leaves no large empty dotted band reserving its old slot. */
.board__gridwrap{flex:1;overflow:hidden;min-height:0;padding:0 24px 24px;display:flex;flex-direction:column;justify-content:center;}
.board__grid{
  max-height:100%;padding:18px;
  max-width:1600px;
  display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:64px;gap:8px;
  background-color:var(--paper);
  background-image:radial-gradient(circle, rgba(0,0,0,0.15) 1px, transparent 1px);
  background-size:calc((100% - 0px)/12) 64px;background-position:0 0;
  border-radius:8px;border:1px solid var(--divider);
}
.widget{
  background:#fff;border:1px solid var(--divider);border-radius:8px;overflow:hidden;
  display:flex;flex-direction:column;
  opacity:0;transform:scale(.92);transform-origin:center;will-change:transform,opacity;
}
.widget__head{padding:10px 14px;border-bottom:1px solid var(--divider);}
.widget__title{font-size:.85rem;font-weight:600;color:var(--text-primary);}
.widget__body{flex:1;padding:14px;position:relative;min-height:0;}

/* KPI */
.kpi{display:flex;flex-direction:column;justify-content:center;gap:6px;}
.kpi__value{font-size:2.6rem;font-weight:600;letter-spacing:-.02em;line-height:1;}
.kpi__delta{display:inline-flex;align-items:center;gap:5px;font-size:.95rem;font-weight:500;width:fit-content;}
.kpi__delta [data-icon]{font-size:16px;}
.kpi__delta--up{color:var(--success);}
.kpi__spark{width:100%;height:32px;margin-top:6px;}

/* LINE */
.linechart{width:100%;height:calc(100% - 22px);}
.linechart__path{stroke-dasharray:1000;stroke-dashoffset:1000;}
.linechart__area{opacity:0;}
.linechart__axis{display:flex;justify-content:space-between;font-size:.72rem;color:var(--text-disabled);margin-top:2px;}

/* BAR */
.barchart{display:flex;align-items:flex-end;gap:18px;height:100%;padding-bottom:22px;}
.bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative;}
.bar__fill{width:100%;max-width:64px;height:var(--h);background:var(--c);border-radius:4px 4px 0 0;
  transform:scaleY(0);transform-origin:bottom;}
.bar__lbl{position:absolute;bottom:-20px;font-size:.74rem;color:var(--text-secondary);white-space:nowrap;}

/* TABLE */
.dtable{width:100%;border-collapse:collapse;font-size:.84rem;}
.dtable thead th{
  position:sticky;top:0;background:#f3f4f6;text-align:left;padding:8px 10px;font-weight:600;
  color:var(--text-secondary);border-bottom:1px solid var(--divider);font-size:.78rem;
}
.dtable td{padding:8px 10px;border-bottom:1px solid var(--divider);}
.dtable .num{text-align:right;font-variant-numeric:tabular-nums;}
.dtable .pos{color:var(--success);}

/* ============================ FOOTER ============================ */
.page--footer{height:auto;min-height:100dvh;overflow:visible;background:#08080B;
  display:flex;align-items:stretch;}
.footer{background:#08080B;color:#fff;padding:64px clamp(24px,5vw,72px) 28px;
  width:100%;display:flex;flex-direction:column;justify-content:center;}
.footer__inner{display:flex;flex-wrap:wrap;gap:48px;justify-content:space-between;max-width:1200px;margin:0 auto;width:100%;}
.footer__brand{max-width:300px;}
.footer__tag{color:rgba(255,255,255,.6);font-weight:300;margin:16px 0 22px;font-size:.95rem;}
.footer__cta{display:flex;gap:10px;}
.footer__cols{display:flex;gap:56px;flex-wrap:wrap;}
.footer__col{display:flex;flex-direction:column;gap:10px;}
.footer__col h4{margin:0 0 6px;font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.5);}
.footer__col a{color:var(--text-disabled);font-size:.9rem;transition:color .12s;}
.footer__col a:hover{color:#fff;}
.footer__bottom{
  display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center;
  max-width:1200px;margin:44px auto 0;width:100%;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);
  color:var(--text-disabled);font-size:.82rem;
}
.footer__bottom a{color:var(--text-disabled);}
.footer__bottom a:hover{color:#fff;}

/* ============================ MOBILE SHELL — TOP BAR ============================
   Sticky translucent top bar; desktop hides it entirely, is-stacked shows it as
   fixed chrome above all content. Mirrors the in-hero landing nav (which we hide
   on mobile) but persists across every section.
   ============================================================================ */
.mtopbar{display:none;}
body.is-stacked .mtopbar{
  display:flex;align-items:center;justify-content:space-between;
  position:fixed;top:0;left:0;right:0;z-index:1200;height:52px;
  padding:0 14px 0 16px;
  background:rgba(11,11,15,.82);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:transform .32s ease,opacity .26s ease;
}
/* App zone: the marketing top bar slides away — you're now "in the app" */
body.is-stacked.app-booted .mtopbar{transform:translateY(-100%);opacity:0;pointer-events:none;}
.mtopbar__logo{
  display:flex;align-items:center;height:44px;min-width:44px;flex-shrink:0;
}
.mtopbar__logo img{height:24px;width:auto;}
.mtopbar__actions{display:flex;align-items:center;gap:8px;}
.mtopbar__signin{
  display:inline-flex;align-items:center;height:36px;padding:0 12px;border-radius:8px;
  color:rgba(255,255,255,.86);font-size:.86rem;font-weight:500;white-space:nowrap;
  transition:background .12s ease,color .12s ease;
}
.mtopbar__signin:hover,.mtopbar__signin:active{background:rgba(255,255,255,.1);color:#fff;}
.mtopbar__demo{
  display:inline-flex;align-items:center;height:36px;padding:0 14px;border-radius:9px;
  background:var(--purple);color:#fff;font-size:.86rem;font-weight:600;white-space:nowrap;
  transition:filter .12s ease;
}
.mtopbar__demo:active{filter:brightness(1.08);}

/* ============================ MOBILE SHELL — TAB BAR ============================ */
.tabbar[hidden]{display:none;}
.tabbar{
  position:fixed;left:0;right:0;bottom:0;z-index:1100;
  display:none;background:rgba(20,20,24,.94);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-top:1px solid var(--rail-border);
  padding:4px 4px env(safe-area-inset-bottom,6px);
}
.tabbar__item{
  flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:7px 1px 6px;color:var(--rail-text);
  font-size:.58rem;font-weight:500;line-height:1;letter-spacing:-.02em;text-align:center;
  border-radius:10px;transition:color .12s ease,background .12s ease;
}
.tabbar__item span:last-child{
  max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.tabbar__item [data-icon]{font-size:20px;display:flex;}
.tabbar__item:active{background:rgba(255,255,255,.06);}
.tabbar__item[aria-current="true"]{color:var(--purple);}
.tabbar__item[aria-current="true"] [data-icon]{transform:translateY(-1px);}

/* ============================ TOUCH / SMALL — robust fallback ============================
   If a page's content can't fit 100dvh on a small screen, that page relaxes to
   height:auto / min-height:100dvh and snap relaxes to proximity so content is
   never trapped. Animations still trigger time-based on enter.
   ============================================================================ */
body.is-stacked .rail{display:none;}
/* Tab bar belongs to the app zone only: hidden (slid down) in the marketing
   hero + the under-the-hood story, slides up when you enter an app surface. */
body.is-stacked .tabbar{
  display:flex;transform:translateY(100%);opacity:0;pointer-events:none;
  transition:transform .32s ease,opacity .26s ease;
}
body.is-stacked.app-booted .tabbar{transform:translateY(0);opacity:1;pointer-events:auto;}
/* content sits between the fixed top bar (52px) and bottom tab bar (~60px) */
body.is-stacked .scroller{
  margin-left:0;scroll-snap-type:y proximity;
  padding-top:52px;
  padding-bottom:calc(60px + env(safe-area-inset-bottom,0px));
}
body.is-stacked .page{height:auto;min-height:auto;overflow:visible;scroll-snap-stop:normal;contain:none;}
/* every page gets comfortable mobile gutters + vertical rhythm; sections may
   override below. min-width:0 everywhere guards against fixed-width overflow. */
body.is-stacked .page,body.is-stacked .page *{min-width:0;}

/* ---- shared mobile type + spacing ---- */
body.is-stacked .landing__h1{font-size:clamp(2.2rem,9vw,2.9rem);margin-bottom:14px;}
body.is-stacked .landing__sub{font-size:clamp(1rem,4.2vw,1.12rem);line-height:1.55;}
body.is-stacked .page-header__title h3{font-size:clamp(1.4rem,5.4vw,1.7rem);}

/* ---- LANDING ---- */
body.is-stacked .landing{padding:clamp(40px,7vh,64px) 18px clamp(48px,8vh,64px);justify-content:flex-start;}
body.is-stacked .landing__nav{display:none;}
body.is-stacked .landing__hero{position:static;padding:0;gap:clamp(36px,6vh,52px);}
body.is-stacked .landing__copy{max-width:100%;}
body.is-stacked .landing__cta{flex-wrap:wrap;gap:12px;}
body.is-stacked .landing__cta .btn{flex:1 1 auto;min-width:140px;}
/* HERO VISUAL: the three product decks become a single CONTAINED, decorative
   "stack" — the dashboard in front with the chat + workflow peeking behind — so
   it reads as a graphic, NOT three full cards you're forced to scroll past. */
body.is-stacked .herodecks{
  position:relative;display:block;width:100%;
  height:clamp(330px,50vh,400px);margin-top:8px;overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,#000 78%,transparent 100%);
  mask-image:linear-gradient(180deg,#000 78%,transparent 100%);
}
body.is-stacked .deck{
  position:absolute;left:50%;top:0;width:90%;max-width:330px;min-width:0;
  margin:0;opacity:1 !important;will-change:transform;
}
body.is-stacked .deck__card{box-shadow:0 26px 60px -28px rgba(0,0,0,.8);}
body.is-stacked .deck--dash{z-index:3;transform:translate(-50%,58px) !important;}
body.is-stacked .deck--chat{z-index:2;transform:translate(-66%,6px) rotate(-5deg) scale(.95) !important;}
body.is-stacked .deck--wf{z-index:1;transform:translate(-34%,14px) rotate(5deg) scale(.95) !important;}
body.is-stacked .deck__annot{display:none !important;}
body.is-stacked .landing__scrollhint{display:none;}
/* keep the mini-content inside each deck legible at 360px */
body.is-stacked .mini-chat{min-height:0;padding:16px 16px 4px;}
body.is-stacked .mini-dash{min-height:0;}
body.is-stacked .deck__body--wf{min-height:0;}
body.is-stacked .mini-dash__row{flex-wrap:nowrap;}

/* ---- CHAT ---- */
body.is-stacked .chat{padding:clamp(40px,7vh,64px) 18px;display:block;}
body.is-stacked .chat__toprail{display:none;}
body.is-stacked .chat__center{position:static;padding:0;align-items:center;}
body.is-stacked .chat__greeting{font-size:clamp(1.6rem,7vw,2.1rem);margin-bottom:22px;}
body.is-stacked .chat__thread{max-width:100%;margin-bottom:16px;}
body.is-stacked .chat__thread .msg__user-bubble{max-width:86%;}
body.is-stacked .msg__chart{max-width:100%;}
body.is-stacked .promptbox{max-width:100%;}
body.is-stacked .chat__foreshadow{position:static;margin-top:20px;}

/* ---- DASHBOARDS ---- */
body.is-stacked .dash{padding:clamp(40px,7vh,64px) 18px;display:block;}
/* the dock becomes a compact "the chat built this" context strip at the top;
   the input row is dropped on mobile so the artifact below is the star. */
body.is-stacked .dock{
  position:static;width:100%;height:auto;
  background:var(--paper);border:1px solid var(--divider);border-radius:12px;
  border-right:1px solid var(--divider);overflow:hidden;margin-bottom:22px;
}
body.is-stacked .dock__head{padding:11px 14px;}
body.is-stacked .dock__thread{overflow:visible;padding:14px 14px 16px;gap:10px;}
body.is-stacked .dock__thread .msg__user-bubble{max-width:88%;}
body.is-stacked .dock__inputwrap{display:none;}
body.is-stacked .dock .s3-callout{max-width:100%;}

body.is-stacked .board{position:static;height:auto;}
body.is-stacked .page-header{padding:0 0 14px;flex-wrap:nowrap;gap:10px;}
body.is-stacked .page-header__title{gap:9px;min-width:0;}
body.is-stacked .page-header__title h3{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
body.is-stacked .page-header__icon{font-size:21px;flex-shrink:0;}
body.is-stacked .page-header__actions{flex-shrink:0;}
body.is-stacked .board__filterbar{padding:0 0 12px;flex-wrap:wrap;}
body.is-stacked .board__gridwrap{padding:0;overflow:visible;}
body.is-stacked .board__grid{
  height:auto;padding:0;gap:12px;background-image:none;background-color:transparent;
  border:0;border-radius:0;display:flex;flex-direction:column;
}
/* widgets become clean stacked cards — drop the absolute 12-col grid placement */
body.is-stacked .widget{
  grid-column:auto !important;grid-row:auto !important;
  min-height:0;box-shadow:0 1px 2px rgba(0,0,0,.04);
}
/* charts use height:100% internally — give the bodies a DEFINITE height on
   mobile (the desktop grid-row height is gone). flex:none so the explicit
   height wins over the inherited flex-basis:0% (which would collapse them). */
body.is-stacked .widget--kpi .widget__body{min-height:120px;}
body.is-stacked .widget--line .widget__body{flex:none;height:180px;}
body.is-stacked .widget--bar .widget__body{flex:none;height:200px;}
body.is-stacked .kpi__value{font-size:clamp(2rem,9vw,2.6rem);}
body.is-stacked .barchart{gap:14px;}
/* the data table scrolls horizontally inside its card rather than overflowing the page */
body.is-stacked .widget--table .widget__body{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0;}
body.is-stacked .widget--table .dtable{min-width:392px;font-size:.82rem;}
body.is-stacked .widget--table .dtable th,body.is-stacked .widget--table .dtable td{padding:9px 11px;}
body.is-stacked .dash__foot{display:flex;justify-content:center;padding-top:22px;}

body.is-stacked .page--footer{min-height:auto;}

/* fade-in-on-enter for stacked */
body.is-stacked [data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease;}
body.is-stacked [data-reveal].in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  body.is-stacked [data-reveal]{opacity:1;transform:none;transition:none;}
}

/* ---- shared mobile callout + scroll hint tuning ---- */
@media (max-width:768px){
  .s3-callout{max-width:100%;padding:12px 14px;font-size:.88rem;line-height:1.5;}
  .s3-callout__icon svg{width:16px;height:16px;}
  .s3-scrollhint{font-size:.8rem;}
}

/* ============================ REDUCED MOTION ============================ */
@media (prefers-reduced-motion:reduce){
  .scroller{scroll-snap-type:none;scroll-behavior:auto;}
  .page{height:auto;min-height:100dvh;overflow:visible;scroll-snap-stop:normal;contain:none;}
  .landing__scrollhint .chev,.synbar::before,.mini-chat__caret,.promptbox__caret{animation:none;}
  .promptbox__send,.promptbox__send.is-sending{transition:none;}
  .landing{justify-content:flex-start;padding:96px 20px 60px;}
  .landing__nav{position:static;padding:0 0 32px;}
  .landing__hero{position:static;padding:0;gap:56px;}
  .herodecks{position:static;width:100%;height:auto;display:flex;flex-direction:column;gap:48px;}
  .deck{position:static;width:100%;min-width:0;transform:none !important;opacity:1 !important;}
  .deck__annot{position:static;transform:none !important;align-items:flex-start;opacity:1;margin-bottom:2px;}
  .deck__annot-arrow{display:none;}
  .chat,.dash{display:block;padding:40px 24px;}
  .chat__toprail{position:static;flex-direction:row;justify-content:flex-end;padding-bottom:16px;}
  .chat__center{position:static;padding:0;}
  .dock{position:static;width:100%;height:auto;border-right:0;border-bottom:1px solid var(--divider);margin-bottom:24px;transform:none !important;opacity:1 !important;}
  .board{position:static;}
  .board__gridwrap{padding:0;overflow:visible;}
  .board__grid{height:auto;grid-auto-rows:minmax(80px,auto);}
  .page--footer{min-height:auto;}
}

/* ============================ RESPONSIVE TWEAKS ============================ */
@media (max-width:1480px){
  .deck{width:min(400px,30vw);}
  .deck--wf{transform:translate(-50%,-50%) translate(-320px,-26px) rotate(-5deg) scale(.85);}
  .deck--dash{transform:translate(-50%,-50%) translate(320px,-12px) rotate(5deg) scale(.86);}
  .deck--wf.is-hover{transform:translate(-50%,-50%) translate(-320px,-56px) rotate(-3deg) scale(.91);}
  .deck--dash.is-hover{transform:translate(-50%,-50%) translate(320px,-44px) rotate(3deg) scale(.9);}
}
@media (max-width:1380px){
  .dock{width:340px;}
  .board{left:340px;}
}
@media (max-width:1180px){
  .dock{width:312px;}
  .board{left:312px;}
}
@media (max-width:768px){
  .chat__greeting{font-size:2rem;}
  .kpi__value{font-size:2rem;}
  .page-header__title h3{font-size:1.4rem;}
  .page-header{flex-wrap:wrap;gap:12px;}
  .deck__annot-text{font-size:1.7rem;}
}
