/* ============================================================
   Toolhouse agent animations — shared webmail UI
   Used by: Marketing, Support, Social, Executive Assistant
   Accent: #08f · 1080×1080 · light theme
   ============================================================ */
:root{
  --accent:#08f;
  --accent-ink:#0070d6;
  --accent-soft:rgba(0,136,255,.10);
  --ink:#1b1f24;
  --ink-2:#3c434c;
  --muted:#7a838e;
  --faint:#aab2bb;
  --line:#e8ebef;
  --line-2:#eef1f4;
  --surface:#ffffff;
  --rail:#f6f8fa;
  --page:#e9edf2;
  --ok:#1aa06d;
  --ok-soft:rgba(26,160,109,.10);
  --warn:#d98324;
  --warn-soft:rgba(217,131,36,.12);
  --shadow:0 1px 2px rgba(20,30,45,.04),0 12px 34px rgba(20,30,45,.10);
  --shadow-lg:0 24px 70px rgba(20,30,45,.22);
  --ui:"Figtree",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  --serif:"Newsreader",Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;}
body{
  background:#dde2e8;font-family:var(--ui);color:var(--ink);
  overflow:hidden;-webkit-font-smoothing:antialiased;
}

/* ---------- stage / scaling ---------- */
.stage{position:fixed;inset:0;display:grid;place-items:center;background:#dde2e8;overflow:hidden;}
.canvas{
  position:absolute;left:50%;top:50%;width:1080px;height:1080px;
  transform-origin:center center;background:var(--page);transition:opacity .45s ease;
}
.canvas.fading{opacity:0;}

/* ---------- app window ---------- */
.app{
  position:absolute;inset:28px;background:var(--surface);border-radius:24px;
  box-shadow:var(--shadow-lg);overflow:hidden;display:grid;
  grid-template-columns:78px 1fr;grid-template-rows:64px 1fr;
  grid-template-areas:"rail top" "rail main";
}

/* rail */
.rail{
  grid-area:rail;background:var(--rail);border-right:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;padding:18px 0;gap:10px;
}
.rail .compose-btn{
  width:50px;height:50px;border-radius:16px;border:none;background:var(--accent);
  color:#fff;cursor:pointer;display:grid;place-items:center;margin-bottom:14px;
  box-shadow:0 6px 16px rgba(0,136,255,.34);
}
.rail .compose-btn svg{width:24px;height:24px;}
.nav-ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:var(--muted);position:relative;}
.nav-ic svg{width:23px;height:23px;}
.nav-ic.active{background:var(--accent-soft);color:var(--accent-ink);}
.nav-ic .badge{
  position:absolute;top:6px;right:6px;min-width:18px;height:18px;padding:0 5px;
  background:var(--accent);color:#fff;border-radius:9px;font-size:11px;font-weight:700;
  display:grid;place-items:center;border:2px solid var(--rail);
}

/* topbar */
.top{grid-area:top;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 24px;}
.search{
  flex:1;max-width:560px;height:42px;border-radius:21px;background:#f1f3f6;
  display:flex;align-items:center;gap:12px;padding:0 18px;color:var(--faint);font-size:18px;
}
.search svg{width:20px;height:20px;color:var(--faint);}
.top-spacer{flex:1;}
.user-av{
  width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#5b6470,#3c434c);
  color:#fff;display:grid;place-items:center;font-weight:600;font-size:17px;
}

/* main */
.main{grid-area:main;position:relative;overflow:hidden;}
.folder-head{display:flex;align-items:center;gap:12px;padding:22px 30px 10px;}
.folder-head h1{font-size:25px;font-weight:700;letter-spacing:-.01em;}
.folder-head .fcount{font-size:16px;color:var(--muted);font-weight:500;}

/* inbox list */
.inbox{list-style:none;padding:0 16px;}
.row{display:flex;align-items:center;gap:16px;padding:16px 18px;border-radius:14px;position:relative;}
.row + .row{margin-top:2px;}
.r-av{
  width:46px;height:46px;border-radius:50%;flex:none;display:grid;place-items:center;
  font-size:19px;font-weight:600;color:#fff;background:#c2cad3;
}
.r-av.gradient-1{background:linear-gradient(135deg,#8a93a0,#666f7a);}
.r-av.gradient-2{background:linear-gradient(135deg,#9aa3ad,#737c87);}
.r-av.gradient-3{background:linear-gradient(135deg,#b3bac2,#8e96a0);}
.r-main{flex:1;min-width:0;}
.r-top{display:flex;align-items:baseline;gap:10px;}
.r-from{font-size:21px;font-weight:600;color:var(--ink-2);white-space:nowrap;}
.r-time{margin-left:auto;font-size:15px;color:var(--faint);font-weight:500;flex:none;}
.r-sub{font-size:18px;color:var(--muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.r-sub b{color:var(--ink-2);font-weight:600;}
.row.muted{opacity:.92;}
.row.muted .r-from{font-weight:500;color:var(--ink-2);}

/* ---- agent row states ---- */
.agentRow{
  overflow:hidden;max-height:0;opacity:0;transform:translateY(-6px);
  padding-top:0;padding-bottom:0;margin-top:0;
  transition:max-height .5s ease,opacity .4s ease,transform .45s ease,padding .4s ease,background .4s ease,box-shadow .4s ease;
  background:var(--surface);
}
.agentRow .r-av{background:var(--accent);}
.agentRow .r-from{color:var(--ink);font-weight:700;}
.agent-working,.agent-reply{display:none;}
.agent-working{align-items:center;}
.agent-reply b{color:var(--ink);}
.agent-reply .r-prev{color:var(--muted);font-weight:400;}
.unread-dot{
  width:11px;height:11px;border-radius:50%;background:var(--accent);flex:none;
  opacity:0;transform:scale(0);transition:transform .4s ease,opacity .3s ease;
}
.work-line{display:flex;align-items:center;gap:10px;margin-top:5px;}
.work-text{font-size:18px;color:var(--accent-ink);font-weight:600;}
.dots{display:inline-flex;gap:4px;}
.dots i{width:6px;height:6px;border-radius:50%;background:var(--accent);display:block;opacity:.35;}
.shimmer-bar{
  height:9px;border-radius:5px;margin-top:9px;width:62%;
  background:linear-gradient(90deg,#e9edf2 25%,#dbe6f5 37%,#e9edf2 63%);background-size:280px 100%;
}
.slide[data-step="working"] .agentRow,.slide[data-step="reply"] .agentRow,.slide[data-step="reading"] .agentRow{
  max-height:96px;opacity:1;transform:none;padding-top:16px;padding-bottom:16px;margin-top:2px;
  box-shadow:inset 0 0 0 1px var(--line-2);
}
.slide[data-step="working"] .agent-working{display:block;}
.slide[data-step="reply"] .agent-reply,.slide[data-step="reading"] .agent-reply{display:block;}
.slide[data-step="reply"] .agentRow,.slide[data-step="reading"] .agentRow{background:#f3f8ff;box-shadow:inset 0 0 0 1px rgba(0,136,255,.16);}
.slide[data-step="reply"] .unread-dot,.slide[data-step="reading"] .unread-dot{opacity:1;transform:scale(1);}
.slide[data-step="working"] .dots i{animation:dotPulse 1.1s infinite ease-in-out;}
.slide[data-step="working"] .dots i:nth-child(2){animation-delay:.16s;}
.slide[data-step="working"] .dots i:nth-child(3){animation-delay:.32s;}
.slide[data-step="working"] .shimmer-bar{animation:shimmer 1.2s infinite linear;}
@keyframes dotPulse{0%,100%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}
@keyframes shimmer{0%{background-position:-180px 0}100%{background-position:240px 0}}

/* ---------- compose card ---------- */
.compose-card{
  position:absolute;right:26px;bottom:0;width:486px;background:var(--surface);
  border-radius:16px 16px 0 0;box-shadow:0 -2px 8px rgba(20,30,45,.04),0 22px 60px rgba(20,30,45,.26);
  z-index:30;overflow:hidden;opacity:0;transform:translateY(60px) scale(.97);
  transition:opacity .5s cubic-bezier(.2,.7,.2,1),transform .55s cubic-bezier(.2,.7,.2,1);
}
.slide[data-step="compose"] .compose-card,.slide[data-step="attaching"] .compose-card,.slide[data-step="attached"] .compose-card{opacity:1;transform:none;}
.slide[data-step="sending"] .compose-card{opacity:0;transform:translateY(-30px) scale(.95);}
.cc-head{background:#222a32;color:#fff;height:46px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;font-size:16px;font-weight:600;}
.cc-head .cc-x{color:#cdd4db;font-size:22px;line-height:1;background:none;border:none;cursor:pointer;}
.cc-field{display:flex;align-items:center;gap:10px;padding:13px 20px;border-bottom:1px solid var(--line-2);}
.cc-label{color:var(--muted);font-size:17px;width:34px;}
.recip{display:inline-flex;align-items:center;gap:9px;background:#eef4ff;border:1px solid rgba(0,136,255,.22);padding:5px 12px 5px 6px;border-radius:18px;font-size:17px;color:var(--ink-2);font-weight:500;}
.recip .recip-av{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:13px;}
.cc-subj{font-size:18px;font-weight:600;color:var(--ink);}
.cc-body{padding:16px 20px;font-size:18px;line-height:1.5;color:var(--ink-2);min-height:84px;}
.cc-body .sig{color:var(--ink-2);}

/* attachment chip */
.chip{
  margin:0 20px 12px;border:1px solid var(--line);border-radius:12px;background:#fafbfc;
  padding:12px 14px;display:flex;align-items:center;gap:13px;position:relative;
  opacity:0;transform:translateY(-12px) scale(.98);pointer-events:none;
}
.slide[data-step="attaching"] .chip,.slide[data-step="attached"] .chip,.slide[data-step="sending"] .chip{opacity:1;transform:none;}
.slide[data-step="attaching"] .chip{animation:dropIn .6s cubic-bezier(.2,.8,.2,1);}
@keyframes dropIn{0%{opacity:0;transform:translateY(-72px) scale(.96) rotate(-3deg)}45%{opacity:1}100%{opacity:1;transform:none}}
.chip .doc-ic{width:40px;height:46px;flex:none;}
.chip .c-meta{flex:1;min-width:0;}
.chip .c-name{font-size:17px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chip .c-size{font-size:14px;color:var(--muted);margin-top:2px;}
.chip .c-prog{height:5px;border-radius:3px;background:#e6eaee;margin-top:8px;overflow:hidden;}
.chip .c-prog i{display:block;height:100%;width:0;background:var(--accent);border-radius:3px;}
.slide[data-step="attaching"] .chip .c-prog i{animation:fillBar 1.05s .25s cubic-bezier(.4,0,.2,1) forwards;}
@keyframes fillBar{from{width:0}to{width:100%}}
.chip .c-check{width:26px;height:26px;border-radius:50%;background:var(--ok);color:#fff;flex:none;display:grid;place-items:center;opacity:0;transform:scale(.4);transition:.3s ease;}
.chip .c-check svg{width:15px;height:15px;}
.slide[data-step="attached"] .chip .c-check,.slide[data-step="sending"] .chip .c-check{opacity:1;transform:scale(1);}
.slide[data-step="attached"] .chip .c-meta .c-prog,.slide[data-step="sending"] .chip .c-meta .c-prog{display:none;}

.cc-foot{display:flex;align-items:center;gap:14px;padding:14px 20px 18px;}
.send{
  background:var(--accent);color:#fff;border:none;border-radius:22px;padding:11px 24px;
  font-size:17px;font-weight:600;font-family:var(--ui);display:inline-flex;align-items:center;gap:9px;
  cursor:pointer;box-shadow:0 6px 16px rgba(0,136,255,.30);transition:transform .12s ease;
}
.send svg{width:18px;height:18px;}
.slide[data-step="sending"] .send{transform:scale(.94);}
.cc-tools{display:flex;gap:6px;color:var(--faint);}
.cc-tools svg{width:21px;height:21px;}

/* flying chip on send */
.fly{
  position:absolute;z-index:40;right:60px;bottom:120px;display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1px solid var(--line);border-radius:20px;padding:7px 14px 7px 8px;
  box-shadow:var(--shadow);opacity:0;font-size:15px;font-weight:600;color:var(--ink-2);
}
.fly .recip-av{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:12px;}
.slide[data-step="sending"] .fly{animation:flyOff 1s cubic-bezier(.4,0,.2,1) forwards;}
@keyframes flyOff{0%{opacity:0;transform:translate(0,0) scale(1);}18%{opacity:1;transform:translate(-10px,-30px) scale(1);}100%{opacity:0;transform:translate(-340px,-560px) scale(.5);}}

/* toast */
.toast{
  position:absolute;left:50%;bottom:34px;transform:translateX(-50%) translateY(30px);
  background:#222a32;color:#fff;padding:13px 22px;border-radius:12px;font-size:16px;font-weight:500;
  z-index:45;opacity:0;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow);
  transition:opacity .3s ease,transform .4s cubic-bezier(.2,.8,.2,1);
}
.toast .t-ic{color:#5ad29a;}
.slide[data-step="sending"] .toast,.slide[data-step="working"] .toast{opacity:1;transform:translateX(-50%) translateY(0);}

/* cursor */
.cursor{
  position:absolute;left:0;top:0;width:26px;height:26px;z-index:60;pointer-events:none;
  opacity:0;transform:translate(760px,760px);
  transition:transform .7s cubic-bezier(.4,0,.2,1),opacity .3s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.32));
}
.cursor svg{width:100%;height:100%;}
.slide[data-step="compose"] .cursor{opacity:1;transform:translate(820px,840px);}
.slide[data-step="attaching"] .cursor{opacity:1;transform:translate(800px,880px);}
.slide[data-step="attached"] .cursor{opacity:1;transform:translate(635px,978px);}
.slide[data-step="sending"] .cursor{opacity:1;transform:translate(635px,978px) scale(.86);}
/* no-attach: glide straight to Send */
.slide.no-attach[data-step="compose"] .cursor{opacity:1;transform:translate(720px,900px);}
.cursor .ring{position:absolute;inset:-8px;border:2px solid var(--accent);border-radius:50%;opacity:0;}
.slide[data-step="sending"] .cursor .ring{animation:clickRing .5s ease-out;}
@keyframes clickRing{0%{opacity:.7;transform:scale(.4)}100%{opacity:0;transform:scale(1.5)}}

/* ============================================================
   READER (result panel) — shared chrome + reusable components
   ============================================================ */
.reader{
  position:absolute;inset:0;background:var(--surface);z-index:20;padding:24px 34px 30px;overflow:hidden;
  opacity:0;transform:translateY(22px);pointer-events:none;
  transition:opacity .45s ease,transform .5s cubic-bezier(.2,.7,.2,1);
}
.slide[data-step="reading"] .reader{opacity:1;transform:none;}
.rd-head{display:flex;align-items:flex-start;gap:14px;}
.rd-back{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;color:var(--muted);flex:none;}
.rd-back svg{width:22px;height:22px;}
.rd-title{font-size:27px;font-weight:700;letter-spacing:-.01em;line-height:1.2;padding-top:4px;}
.rd-meta{display:flex;align-items:center;gap:13px;margin:18px 0 8px;padding-left:54px;}
.rd-meta .r-av{width:44px;height:44px;background:var(--accent);}
.rd-from{font-size:19px;font-weight:700;color:var(--ink);white-space:nowrap;}
.rd-addr{font-size:15px;color:var(--muted);margin-top:1px;}
.rd-to{font-size:15px;color:var(--muted);margin-top:1px;}
.rd-time{margin-left:auto;font-size:15px;color:var(--faint);align-self:flex-start;}
.rd-note{margin:14px 0 18px;padding-left:54px;font-size:18px;line-height:1.5;color:var(--ink-2);}
.rd-note b{color:var(--ink);font-weight:600;}
.rd-grid{display:grid;grid-template-columns:1fr 286px;gap:24px;padding-left:54px;}

/* generic result card */
.result-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:0 10px 30px rgba(20,30,45,.07);padding:22px 24px;
}
.rc-kicker{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-ink);font-weight:700;}
.rc-h{font-size:24px;font-weight:700;letter-spacing:-.01em;margin:5px 0 2px;color:#15191e;}
.rc-sub{font-size:14px;color:var(--muted);}

/* pills */
.pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;font-size:13.5px;font-weight:600;padding:4px 11px;white-space:nowrap;}
.pill svg{width:13px;height:13px;}
.pill.ok{background:var(--ok-soft);color:var(--ok);}
.pill.accent{background:var(--accent-soft);color:var(--accent-ink);}
.pill.warn{background:var(--warn-soft);color:var(--warn);}
.pill.ghost{background:#f1f3f6;color:var(--ink-2);}

/* schedule / timeline list (marketing) */
.creative{
  border-radius:11px;overflow:hidden;border:1px solid var(--line);margin-bottom:16px;
}
.creative .hero{
  background:linear-gradient(120deg,#08f,#3aa0ff);color:#fff;padding:18px 20px;
}
.creative .hero .eyebrow{font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.85;font-weight:600;}
.creative .hero .head{font-family:var(--serif);font-size:25px;font-weight:600;line-height:1.15;margin-top:3px;}
.creative .body{padding:13px 20px;font-size:15.5px;line-height:1.5;color:var(--ink-2);background:#fff;}
.sched{list-style:none;position:relative;margin-top:4px;}
.sched::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line);}
.sched li{display:flex;align-items:center;gap:13px;padding:9px 0;position:relative;padding-left:26px;}
.sched li::before{content:"";position:absolute;left:3px;top:50%;transform:translateY(-50%);width:10px;height:10px;border-radius:50%;background:#fff;border:2px solid var(--accent);}
.sched .day{font-size:14px;font-weight:700;color:var(--ink);width:62px;flex:none;}
.sched .ch{font-size:14.5px;color:var(--ink-2);flex:1;}
.sched .ch b{font-weight:600;color:var(--ink);}

/* status strip (support) */
.statusline{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}
.emailish{border:1px solid var(--line);border-radius:11px;background:#fbfcfd;padding:16px 18px;}
.emailish .to{font-size:14px;color:var(--muted);margin-bottom:9px;}
.emailish .to b{color:var(--ink-2);font-weight:600;}
.emailish p{font-size:16px;line-height:1.55;color:#2a2f36;margin-bottom:10px;text-wrap:pretty;}
.src{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--accent-ink);background:var(--accent-soft);border-radius:8px;padding:6px 10px;}
.src svg{width:14px;height:14px;}

/* social post cards */
.post{border:1px solid var(--line);border-radius:13px;background:#fff;padding:15px 17px;margin-bottom:13px;}
.post:last-child{margin-bottom:0;}
.post-head{display:flex;align-items:center;gap:10px;margin-bottom:9px;}
.post-head .p-av{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:15px;flex:none;}
.post-head .p-name{font-size:15px;font-weight:700;color:var(--ink);line-height:1.1;}
.post-head .p-handle{font-size:13px;color:var(--muted);}
.platform{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;padding:4px 10px;border-radius:999px;}
.platform svg{width:13px;height:13px;}
.platform.li{background:#e8f1fb;color:#0a66c2;}
.platform.x{background:#eceef0;color:#1a1d21;}
.platform.ig{background:#fdecf3;color:#c1358a;}
.post-text{font-size:15.5px;line-height:1.5;color:#2a2f36;text-wrap:pretty;}
.post-foot{display:flex;align-items:center;gap:10px;margin-top:11px;}

/* triage list (exec assistant) */
.tlist{list-style:none;}
.tlist li{display:flex;align-items:flex-start;gap:13px;padding:12px 0;border-bottom:1px solid var(--line-2);}
.tlist li:last-child{border-bottom:none;}
.tmark{width:26px;height:26px;border-radius:8px;flex:none;display:grid;place-items:center;margin-top:1px;}
.tmark svg{width:15px;height:15px;}
.tmark.ok{background:var(--ok-soft);color:var(--ok);}
.tmark.star{background:var(--accent-soft);color:var(--accent-ink);}
.tbody{flex:1;min-width:0;}
.tbody .tt{font-size:16.5px;font-weight:600;color:var(--ink);line-height:1.25;}
.tbody .ts{font-size:14.5px;color:var(--muted);margin-top:2px;line-height:1.4;}

/* ---------- side column ---------- */
.side{display:flex;flex-direction:column;gap:18px;}
.card{border:1px solid var(--line);border-radius:14px;background:#fff;padding:18px 18px;opacity:0;transform:translateY(12px);}
.slide[data-step="reading"] .card{animation:rise .5s ease forwards;}
.slide[data-step="reading"] .card.c1{animation-delay:1.0s;}
.slide[data-step="reading"] .card.c2{animation-delay:1.35s;}
@keyframes rise{to{opacity:1;transform:none}}
.comment{background:#f3f8ff;border-color:rgba(0,136,255,.2);}
.warncard{background:var(--warn-soft);border-color:rgba(217,131,36,.28);}
.cm-head{display:flex;align-items:center;gap:10px;margin-bottom:9px;}
.cm-av{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:14px;}
.cm-av.warn{background:var(--warn);}
.cm-name{font-size:16px;font-weight:700;color:var(--ink);}
.cm-name small{display:block;font-weight:500;color:var(--accent-ink);font-size:12px;letter-spacing:.04em;}
.cm-name small.warn{color:var(--warn);}
.cm-body{font-size:16px;line-height:1.5;color:var(--ink-2);}
.sum-title{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:13px;display:flex;align-items:center;gap:8px;}
.sum-title svg{width:18px;height:18px;color:var(--accent-ink);}
.sum-item{display:flex;gap:11px;font-size:15.5px;line-height:1.4;color:var(--ink-2);margin-bottom:12px;}
.sum-item b{color:var(--ink);font-weight:600;}
.sum-item .mk{width:9px;height:9px;border-radius:3px;flex:none;margin-top:5px;}
.sum-item .mk.a{background:var(--accent);}
.sum-item .mk.b{background:var(--ok);}
.sum-item .mk.c{background:var(--warn);}
.sum-foot{border-top:1px solid var(--line-2);margin-top:4px;padding-top:13px;display:flex;gap:9px;}
.btn{flex:1;text-align:center;padding:10px 0;border-radius:10px;font-size:15px;font-weight:600;font-family:var(--ui);}
.btn.primary{background:var(--accent);color:#fff;}
.btn.ghost{background:#f1f3f6;color:var(--ink-2);}

.credit{position:absolute;left:0;right:0;bottom:6px;text-align:center;font-size:11px;color:#c2c9d0;letter-spacing:.04em;}


/* ============================================================
   CAROUSEL layout, controls + scene overrides
   ============================================================ */
:root{--del:#cf3a2e;--del-soft:rgba(207,58,46,.08);}

.cstage{position:fixed;inset:0;display:grid;place-items:center;background:#dde2e8;overflow:hidden;}
.ccanvas{
  position:absolute;left:50%;top:50%;width:1080px;height:1080px;
  transform-origin:center center;background:var(--page);overflow:hidden;
}
.track{position:absolute;top:0;left:0;height:1080px;display:flex;transition:transform .62s cubic-bezier(.7,0,.2,1);}
.slide{position:relative;width:1080px;height:1080px;flex:0 0 1080px;}

/* leave a control strip below the app card */
.app{inset:28px 28px 92px;}

/* cursor depth fix for the shorter app */
.slide[data-step="attached"] .cursor{opacity:1;transform:translate(635px,905px);}
.slide[data-step="sending"] .cursor{opacity:1;transform:translate(635px,905px) scale(.86);}

/* control dock */
.cdock{position:absolute;left:0;right:0;bottom:0;height:92px;display:flex;align-items:center;justify-content:center;gap:26px;z-index:90;}
.cbtn{
  width:50px;height:50px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink-2);
  display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow);
  transition:transform .15s ease,background .15s ease,color .15s ease,border-color .15s ease;
}
.cbtn:hover{background:var(--accent);color:#fff;border-color:var(--accent);}
.cbtn:active{transform:scale(.92);}
.cbtn svg{width:22px;height:22px;}
.cdots{display:flex;align-items:center;gap:11px;}
.cdot{width:9px;height:9px;border-radius:50%;background:#c3ccd5;border:none;padding:0;cursor:pointer;transition:width .3s ease,background .3s ease,border-radius .3s ease;}
.cdot.active{width:26px;border-radius:5px;background:var(--accent);}

/* ---- legal scene: document + tracked changes ---- */
.doc{background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 10px 30px rgba(20,30,45,.07);padding:30px 34px;font-family:var(--serif);}
.doc-kicker{font-family:var(--ui);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-ink);font-weight:700;}
.doc-h{font-size:26px;font-weight:600;letter-spacing:.01em;margin:6px 0 3px;color:#15191e;}
.doc-sub{font-family:var(--ui);font-size:14px;color:var(--muted);margin-bottom:18px;}
.doc p{font-size:18px;line-height:1.6;color:#2a2f36;margin-bottom:13px;text-wrap:pretty;}
.doc .clause-n{font-weight:600;color:#15191e;}
del{text-decoration:none;color:var(--del);position:relative;background:var(--del-soft);border-radius:3px;padding:0 2px;white-space:nowrap;}
del::after{content:"";position:absolute;left:2px;right:2px;top:54%;height:2px;background:var(--del);transform:scaleX(0);transform-origin:left;border-radius:2px;}
ins{text-decoration:none;color:var(--accent-ink);background:var(--accent-soft);border-radius:3px;padding:0 2px;position:relative;opacity:0;}
ins::after{content:"";position:absolute;left:2px;right:2px;bottom:1px;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;border-radius:2px;}
.slide[data-step="reading"] .ed del::after{animation:draw .4s ease forwards;animation-delay:calc(.5s + var(--i)*.5s);}
.slide[data-step="reading"] .ed ins{animation:insIn .4s ease forwards;animation-delay:calc(.7s + var(--i)*.5s);}
.slide[data-step="reading"] .ed ins::after{animation:draw .34s ease forwards;animation-delay:calc(.82s + var(--i)*.5s);}
@keyframes draw{to{transform:scaleX(1)}}
@keyframes insIn{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}
