/* ============================================================
   Ember — editorial base. Warm stone neutrals (oklch, near-zero chroma),
   light serif display, one restrained ember accent, flat hairline cards,
   no gradients, no chunky bezel. Direction deltas live in themes.css.
   ============================================================ */
:root{
  /* cool neutral scale, hue-driven so a scheme can re-tint everything */
  --n-hue:255;            /* cool slate (default) */
  --paper:oklch(98.2% .004 var(--n-hue));
  --paper-2:oklch(95.6% .006 var(--n-hue));
  --paper-3:oklch(92.5% .008 var(--n-hue));
  --paper-4:oklch(88% .010 var(--n-hue));
  --rule:oklch(89.5% .008 var(--n-hue));
  --rule-2:oklch(80% .013 var(--n-hue));
  --ink:oklch(25% .020 var(--n-hue));
  --ink-2:oklch(41% .018 var(--n-hue));
  --ink-3:oklch(57% .015 var(--n-hue));
  --ink-4:oklch(71% .012 var(--n-hue));

  /* one accent — default Daybreak; [data-scheme] swaps the full combination */
  --accent:#0b66d8;
  --accent-2:#0a55b4;
  --accent-soft:#e4eefb;
  --accent-line:#b6d2f4;
  --accent-b:#15a6c4;
  --accent-b-soft:#def2f5;

  --serif:"Source Serif 4","Songti SC","Source Han Serif SC",ui-serif,Georgia,serif;
  --ui:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"PingFang SC","Helvetica Neue",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;

  --font-display:var(--serif);--font-ui:var(--ui);--brandfont:var(--serif);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;color:var(--ink);font-family:var(--ui);line-height:1.5;letter-spacing:-.005em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
  background:oklch(95.8% .006 var(--n-hue));
  background-image:
    linear-gradient(oklch(89% .008 var(--n-hue)/.55) 1px,transparent 1px),
    linear-gradient(90deg,oklch(89% .008 var(--n-hue)/.55) 1px,transparent 1px);
  background-size:34px 34px;background-position:-1px -1px}
em{font-style:normal}

/* ---- scenario color combinations (iOS Liquid Glass family) ----
   each is a designed pairing: primary + secondary + cool neutral cast */
body[data-scheme="daybreak"]{--n-hue:250;--accent:#0b66d8;--accent-2:#0a55b4;--accent-soft:#e4eefb;--accent-line:#b6d2f4;--accent-b:#15a6c4;--accent-b-soft:#def2f5}
body[data-scheme="dusk"]{--n-hue:286;--accent:#5852db;--accent-2:#4740c2;--accent-soft:#eae8fb;--accent-line:#c8c4f1;--accent-b:#8f70f2;--accent-b-soft:#ece6fd}
body[data-scheme="tide"]{--n-hue:200;--accent:#0e8f9e;--accent-2:#0b7583;--accent-soft:#ddeff1;--accent-line:#a9dee4;--accent-b:#2f9e6f;--accent-b-soft:#ddf0e7}
body[data-scheme="slate"]{--n-hue:258;--accent:#5a6473;--accent-2:#454e5d;--accent-soft:#e9ebef;--accent-line:#ccd2db;--accent-b:#7d8ba1;--accent-b-soft:#e9edf2}
body[data-scheme="iris"]{--n-hue:292;--accent:#6a4fd6;--accent-2:#5640bf;--accent-soft:#ece7fb;--accent-line:#cdc3f1;--accent-b:#3a9fd8;--accent-b-soft:#dfeefb}
/* warm options */
body[data-scheme="grove"]{--n-hue:95;--accent:#2e7556;--accent-2:#245d44;--accent-soft:#dcebe0;--accent-line:#9bbda6;--accent-b:#5f9f7a;--accent-b-soft:#e3efe7}
body[data-scheme="amber"]{--n-hue:64;--accent:#b5652a;--accent-2:#97501d;--accent-soft:#f3e6d5;--accent-line:#ddbf98;--accent-b:#d98a3f;--accent-b-soft:#f6ecd9}
.wrap{max-width:1320px;margin:0 auto;padding:0 44px}

/* ---------- page head ---------- */
.pagehead{padding:70px 0 30px;display:flex;flex-direction:column;gap:16px}
.ph-eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);font-weight:500;display:flex;align-items:center;gap:9px}
.ph-eyebrow::before{content:"";width:6px;height:6px;border-radius:999px;background:var(--accent)}
.ph-title{font-family:var(--serif);font-weight:300;font-size:42px;letter-spacing:-.03em;line-height:1.14;margin:0;max-width:820px;color:var(--ink)}
.ph-title em{color:var(--accent)}
.ph-sub{font-size:15px;color:var(--ink-2);max-width:700px;line-height:1.65;letter-spacing:-.003em}
.ph-sub b{color:var(--ink);font-weight:600}
.ph-jump{display:flex;gap:9px;margin-top:6px;flex-wrap:wrap}
.ph-jump a{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;color:var(--ink-2);
  border:1px solid var(--rule);border-radius:999px;padding:8px 15px;background:var(--paper);transition:border-color .15s,color .15s}
.ph-jump a:hover{border-color:var(--accent-line);color:var(--accent-2)}
.ph-jump a i{font-style:normal;color:var(--accent);margin-right:8px;font-weight:600}

/* ---------- direction section ---------- */
.direction{padding:26px 0 14px}
.dir-rule{height:1px;background:var(--rule);margin:18px 0}
.dir-tab{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:13px;padding:16px 0 14px;
  background:linear-gradient(180deg,oklch(95.8% .006 var(--n-hue)) 65%,oklch(95.8% .006 var(--n-hue)/0));margin-bottom:4px}
.dir-tab .dt-n{font-family:var(--mono);font-size:11px;color:var(--paper);background:var(--ink);width:26px;height:26px;border-radius:7px;display:grid;place-items:center;font-weight:500;flex-shrink:0}
.dir-tab b{font-family:var(--serif);font-size:21px;font-weight:400;letter-spacing:-.02em}
.dir-tab span{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}

/* ---------- brand zone ---------- */
.brandzone{display:grid;grid-template-columns:1.2fr .8fr;gap:46px;align-items:center;padding:42px 44px;border-radius:22px;margin:6px 0 16px;position:relative;
  background:var(--paper);border:1px solid var(--rule)}
.bz-mk{display:flex;align-items:center;gap:15px}
.bz-mk .embermark{color:var(--accent)}
.bz-word{font-family:var(--serif);font-size:60px;font-weight:300;letter-spacing:-.04em;line-height:.9;color:var(--ink)}
.bz-slogan{font-family:var(--serif);font-weight:300;font-size:28px;letter-spacing:-.025em;margin-top:26px;line-height:1.2;color:var(--ink)}
.bz-slogan em{color:var(--accent)}
.bz-en{font-family:var(--serif);font-style:italic;font-size:14.5px;margin-top:10px;color:var(--ink-3);max-width:440px;line-height:1.5}
.bz-kw{display:flex;flex-wrap:wrap;gap:7px;margin-top:24px}
.bz-kw span{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px;border:1px solid var(--rule);color:var(--ink-3);background:var(--paper-2)}
.bz-tokens{display:flex;align-items:center;gap:13px;flex-wrap:wrap;margin-top:26px}
.bz-sw{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10.5px;color:var(--ink-3)}
.bz-sw i{width:13px;height:13px;border-radius:4px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.07)}
.bz-tdiv{width:1px;height:15px;background:var(--rule-2)}
.bz-font{font-family:var(--serif);font-size:13px;font-weight:400;color:var(--ink-2)}
.bz-font.sub{font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.bz-right{display:flex;flex-direction:column;align-items:center;gap:16px}

/* app icon */
.appicon{width:118px;height:118px;border-radius:27px;display:grid;place-items:center;position:relative;overflow:hidden}
.appicon .embermark{position:relative;z-index:2}
.appicon-cap{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-4)}

/* ---------- canvas of phones ---------- */
.canvas{display:grid;grid-template-columns:repeat(3,1fr);gap:54px 28px;padding:30px 0 26px}
.scell{display:flex;flex-direction:column}
.plabel{display:flex;align-items:baseline;gap:10px;margin:0 0 16px 2px;white-space:nowrap}
.plabel b{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.1em;color:var(--accent-2)}
.plabel span{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.cgroup-title{grid-column:1/-1;display:flex;align-items:baseline;gap:11px;margin:16px 0 -14px;padding-left:2px}
.cgroup-title b{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);display:flex;align-items:center;gap:9px}
.cgroup-title b::before{content:"";width:6px;height:6px;border-radius:999px;background:var(--accent)}
.cgroup-title span{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--ink-4)}

/* ---------- cold-start feature ---------- */
.cs-feature{display:flex;gap:48px;align-items:center;flex-wrap:wrap;padding:14px 0 30px}
.cs-caption{max-width:330px}
.cs-tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2);font-weight:500}
.cs-caption h3{font-family:var(--serif);font-weight:300;font-size:24px;line-height:1.28;letter-spacing:-.025em;margin:12px 0 0;color:var(--ink)}
.cs-caption p{font-size:13.5px;color:var(--ink-2);line-height:1.65;margin:14px 0 0}
.cs-caption p b{color:var(--ink);font-weight:600}
.cs-flowdots{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px}
.cs-flowdots span{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--ink-3);background:var(--paper-2);border:1px solid var(--rule);border-radius:999px;padding:4px 10px}
.cs-src{font-family:var(--mono);font-size:9.5px;color:var(--ink-4);margin-top:16px;letter-spacing:.06em}
.cs-phonewrap{flex-shrink:0;width:300px}

/* ============================================================
   PHONE — clean, bezel-free
   ============================================================ */
.phone{width:100%;max-width:300px}
.phone-screen{position:relative;border-radius:42px;overflow:hidden;height:624px;
  background:var(--screen-bg,var(--paper));color:var(--screen-ink,var(--ink));font-family:var(--font-ui);
  border:1px solid var(--rule-2);
  box-shadow:0 1px 0 oklch(100% 0 0/.6) inset,0 40px 70px -36px oklch(32% .04 var(--n-hue)/.42),0 12px 26px -18px oklch(32% .04 var(--n-hue)/.26)}
.screen-mesh{position:absolute;inset:0;z-index:0;pointer-events:none}
.di{display:none}
.statusbar{position:absolute;top:0;left:0;right:0;height:50px;display:flex;align-items:flex-end;justify-content:space-between;padding:0 26px 9px;z-index:11;color:var(--screen-ink,var(--ink))}
.sb-time{font-size:14px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:0}
.sb-right{display:flex;align-items:center;gap:6px}
.sb-cell{display:flex;align-items:flex-end;gap:1.5px;height:10px}
.sb-cell i{width:3px;background:currentColor;border-radius:1px}
.sb-cell i:nth-child(1){height:4px}.sb-cell i:nth-child(2){height:6px}.sb-cell i:nth-child(3){height:8px}.sb-cell i:nth-child(4){height:10px}
.sb-wifi{width:15px;height:10px;background:currentColor;-webkit-clip-path:path('M8 11L0.6 4.2A9.8 9.8 0 0 1 15.4 4.2Z');clip-path:path('M8 11L0.6 4.2A9.8 9.8 0 0 1 15.4 4.2Z')}
.sb-bat{width:23px;height:11px;border:1.3px solid currentColor;border-radius:3px;opacity:.9;position:relative}
.sb-bat::after{content:"";position:absolute;right:-3px;top:3.2px;width:1.6px;height:4px;background:currentColor;border-radius:0 1px 1px 0;opacity:.5}
.sb-bat b{position:absolute;inset:1.5px;width:66%;background:currentColor;border-radius:1px;display:block}
.home-ind{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);width:120px;height:5px;border-radius:3px;background:var(--screen-ink,var(--ink));opacity:.22;z-index:12}
.screen-body{position:absolute;inset:0;z-index:1;padding-top:50px;padding-bottom:22px;display:flex;flex-direction:column;height:100%}

/* embermark — quiet pulse */
.embermark .em-glow{animation:emGlow 3.6s ease-in-out infinite}
.embermark .em-dot{animation:emDot 3.6s ease-in-out infinite}
@keyframes emGlow{0%,100%{opacity:.1;transform:scale(.92);transform-box:fill-box;transform-origin:center}50%{opacity:.2;transform:scale(1.08);transform-box:fill-box;transform-origin:center}}
@keyframes emDot{0%,100%{opacity:.9}50%{opacity:1}}

/* ---------- app chrome (flat base; glass variant in themes) ---------- */
.apptop{display:flex;align-items:center;justify-content:space-between;padding:6px 20px 14px;flex-shrink:0}
.brandrow{display:flex;align-items:center;gap:9px;min-width:0}
.brandrow .bm{color:var(--accent);display:grid;place-items:center}
.brandrow b{font-family:var(--brandfont);font-size:20px;font-weight:400;letter-spacing:-.03em;color:var(--screen-ink,var(--ink))}
.apptop.back .brandrow b{font-size:16px}
.apptop b{white-space:nowrap}
.back-arrow{font-size:20px;line-height:1;color:var(--ink-2);width:34px;height:34px;border:1px solid var(--rule);border-radius:999px;display:grid;place-items:center;background:var(--paper);font-family:inherit;cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent}
.apptop-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.watch-ind{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap}
.breath{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:breath 2.8s ease-in-out infinite}
@keyframes breath{0%,100%{opacity:.35;transform:scale(.8)}50%{opacity:1;transform:scale(1.15)}}
.avatar{position:relative;width:30px;height:30px;border-radius:8px;background:var(--ink);border:none;display:grid;place-items:center;font-family:var(--serif);font-size:15px;font-weight:400;color:var(--paper)}
.avatar-dot{position:absolute;top:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:var(--accent);border:1.5px solid var(--screen-bg,var(--paper))}

/* ---------- home ---------- */
.home-lead{padding:2px 20px 14px;font-family:var(--serif);font-weight:300;font-size:19px;letter-spacing:-.02em;color:var(--ink-2);line-height:1.35;flex-shrink:0}
.home-lead b{font-family:var(--serif);color:var(--ink);font-weight:400}
.home-scroll{flex:1;overflow-y:auto;padding:0 16px 10px;display:flex;flex-direction:column;gap:22px}
.home-scroll::-webkit-scrollbar{width:0}
.agroup{display:flex;flex-direction:column;gap:10px}
.group-label{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);display:flex;align-items:center;gap:8px;padding:0 4px}
.group-label::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent)}
.agroup.watch .group-label{color:var(--accent-b)}
.agroup.watch .group-label::before{background:var(--accent-b)}
.home-src{font-family:var(--mono);font-size:9px;color:var(--ink-4);letter-spacing:.08em;padding:4px 4px 0;text-transform:uppercase}

.acard{background:var(--paper);border:1px solid var(--rule);border-radius:16px;padding:16px;transition:border-color .15s}
.acard-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.acard-title{font-family:var(--serif);font-size:17px;font-weight:400;line-height:1.3;color:var(--ink);letter-spacing:-.018em}
.acard .chev{color:var(--ink-4);font-size:17px;line-height:1.2;flex-shrink:0}
.acard-sub{margin-top:8px;font-size:12px;color:var(--ink-3);line-height:1.5;letter-spacing:-.003em}
.acard-foot{margin-top:14px;padding-top:12px;border-top:1px dashed var(--rule);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.chip{font-family:var(--mono);font-size:9.5px;font-weight:500;letter-spacing:.04em;padding:3px 9px;border-radius:999px;background:var(--paper-2);color:var(--ink-3);border:1px solid var(--rule);white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.chip::before{content:"";width:4px;height:4px;border-radius:999px;background:var(--ink-4)}
.chip.now{background:var(--accent-soft);color:var(--accent-2);border-color:var(--accent-line)}
.chip.now::before{background:var(--accent)}
.chip.mute,.chip.ghost{background:transparent}
.hold-hint{margin-left:auto;font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-2);display:flex;align-items:center;gap:6px}
.hold-hint.mute{color:var(--ink-4);font-weight:500}
.dotpulse{width:6px;height:6px;border-radius:50%;background:var(--ink-4);animation:breath 2.8s ease-in-out infinite}

.quickbar{flex-shrink:0;margin:10px 16px 2px;display:flex;align-items:center;gap:10px;padding:9px 9px 9px 16px;border-radius:999px;
  background:var(--paper);border:1px solid var(--rule-2)}
.qb-field{flex:1;font-size:12.5px;color:var(--ink-3)}
.qb-mic{display:flex;align-items:center;gap:2px;height:18px;padding:0 4px}
.qb-mic i{width:2px;height:8px;background:var(--ink-3);border-radius:2px}
.qb-mic i:nth-child(2){height:13px}.qb-mic i:nth-child(3){height:6px}
.qb-send{width:32px;height:32px;border-radius:999px;background:var(--accent);color:var(--paper);display:grid;place-items:center;font-size:15px;font-weight:700;flex-shrink:0}

/* ---------- detail / approve ---------- */
.screen-pad{padding:6px 20px 8px;overflow-y:auto;flex:1}
.screen-pad::-webkit-scrollbar{width:0}
.kicker{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2);margin:6px 0 10px}
.prep-card{background:var(--paper-2);border:1px solid var(--rule);border-radius:16px;padding:16px;font-family:var(--serif);font-size:16px;font-weight:300;line-height:1.55;color:var(--ink);letter-spacing:-.012em}
.hold{position:relative;width:100%;margin-top:16px;height:50px;border:1px solid var(--accent);border-radius:999px;
  background:var(--accent);color:var(--paper);font-size:13.5px;font-weight:500;letter-spacing:-.005em;overflow:hidden;cursor:pointer;font-family:var(--ui);-webkit-tap-highlight-color:transparent}
.hold-fill{position:absolute;inset:0;background:oklch(100% 0 0/.25);width:0}
.hold.is-holding .hold-fill{width:100%;transition:width .9s linear}
.hold-label{position:relative;z-index:1}
.dualbtn{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:9px}
.btn{height:44px;border-radius:999px;font-size:13px;font-weight:500;letter-spacing:-.005em;cursor:pointer;font-family:var(--ui);border:1px solid var(--rule-2);background:var(--paper);color:var(--ink)}
.btn.ghost{background:transparent;border-color:var(--rule)}
.btn.wide{width:100%;margin-top:12px}
.why-head,.src-head{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin:24px 0 12px}
.why{margin:0;padding:0;list-style:none;display:grid;gap:13px;counter-reset:w}
.why li{counter-increment:w;position:relative;padding-left:26px;font-size:13px;line-height:1.55;color:var(--ink);letter-spacing:-.005em}
.why li::before{content:counter(w);position:absolute;left:0;top:1px;width:18px;height:18px;border-radius:999px;background:var(--accent-soft);color:var(--accent-2);font-family:var(--mono);font-size:9.5px;font-weight:600;display:grid;place-items:center}
.src-list{display:grid;gap:8px}
.srcq{background:var(--accent-soft);border-left:2px solid var(--accent);border-radius:0 10px 10px 0;padding:11px 13px;font-family:var(--serif);font-weight:300;font-size:13px;line-height:1.55;color:var(--ink);letter-spacing:-.008em}
.srcq-from{display:block;font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);margin-bottom:5px}

.approve-action{font-family:var(--serif);font-size:22px;font-weight:300;color:var(--ink);line-height:1.25;letter-spacing:-.025em;margin-bottom:12px}
.draft-card{background:var(--paper);border:1px solid var(--rule);border-radius:16px;padding:15px;font-family:var(--serif);font-weight:300;font-size:13.5px;line-height:1.6;color:var(--ink);letter-spacing:-.008em}
.draft-tag{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--accent-2);margin-bottom:9px;font-weight:500;text-transform:uppercase}
.approve-zone{margin-top:4px}
.approve-note{font-size:11.5px;color:var(--ink-3);text-align:center;margin-top:12px;line-height:1.5}
.exec-card,.done-card{margin-top:16px;background:var(--paper);border:1px solid var(--rule);border-radius:16px;padding:16px}
.exec-row,.done-row{display:flex;gap:12px;align-items:center}
.exec-row b,.done-row b{font-family:var(--serif);font-size:15px;font-weight:400;color:var(--ink);display:block;letter-spacing:-.01em}
.exec-row span,.done-row span{font-size:11.5px;color:var(--ink-3);display:block;margin-top:3px}
.exec-spin{width:22px;height:22px;border-radius:50%;border:2.2px solid var(--accent-soft);border-top-color:var(--accent);animation:spin .8s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.undo{width:100%;margin-top:14px;height:42px;border-radius:999px;border:1px solid var(--accent);background:transparent;color:var(--accent-2);font-weight:500;font-size:13px;cursor:pointer;font-family:var(--ui);display:flex;align-items:center;justify-content:center;gap:9px}
.undo-ring{width:16px;height:16px;border-radius:50%;border:2px solid var(--accent-soft);position:relative}
.undo-ring::after{content:"";position:absolute;inset:-2px;border-radius:50%;border:2px solid var(--accent);clip-path:inset(0 0 calc((1 - var(--p))*100%) 0)}
.done-tick{width:30px;height:30px;border-radius:8px;background:var(--accent);display:grid;place-items:center;color:var(--paper);flex-shrink:0}
.done-next{margin-top:14px;font-family:var(--serif);font-weight:300;font-size:13px;line-height:1.6;color:var(--ink-2);padding-top:13px;border-top:1px dashed var(--rule);letter-spacing:-.008em}
.done-next b{font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);display:block;margin-bottom:5px}

/* ---------- memory ---------- */
.mem-lead{font-family:var(--serif);font-size:21px;font-weight:300;color:var(--ink);margin:6px 0 16px;line-height:1.25;letter-spacing:-.025em}
.mem-lead span{display:block;font-family:var(--ui);font-size:12px;font-weight:400;color:var(--ink-3);margin-top:7px;letter-spacing:-.003em;line-height:1.5}
.mem-card{background:var(--paper);border:1px solid var(--rule);border-radius:16px;padding:14px 15px;margin-bottom:10px}
.mem-k{display:flex;align-items:center;gap:8px;color:var(--ink)}
.mem-k .embermark{color:var(--accent);flex-shrink:0}
.mem-k b{font-family:var(--serif);font-size:14.5px;font-weight:400;flex:1;letter-spacing:-.012em}
.mem-edit{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--rule);border-radius:6px;padding:3px 7px}
.mem-v{margin-top:8px;font-size:12.5px;line-height:1.55;color:var(--ink-2);letter-spacing:-.003em}
.mem-src{margin-top:9px;font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;color:var(--ink-4);text-transform:uppercase}
.mem-rule{background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:16px;padding:14px}
.rule-k{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-2)}
.rule-v{margin-top:7px;font-family:var(--serif);font-weight:300;font-size:13px;line-height:1.55;color:var(--ink);letter-spacing:-.008em}

/* ---------- settings ---------- */
.set-block{margin-bottom:20px}
.set-h{display:flex;align-items:center;gap:9px;font-family:var(--serif);font-size:15px;font-weight:400;color:var(--ink);margin-bottom:11px;letter-spacing:-.012em}
.set-badge{font-family:var(--mono);font-size:8.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:6px;flex-shrink:0}
.set-badge.auto{background:var(--accent-soft);color:var(--accent-2)}
.set-badge.must{background:var(--ink);color:var(--paper)}
.set-badge.plain{background:var(--paper-3);color:var(--ink-3)}
.set-list{background:var(--paper);border:1px solid var(--rule);border-radius:16px;overflow:hidden}
.set-row{display:flex;align-items:center;gap:12px;padding:12px 15px;border-bottom:1px solid var(--rule);font-size:13px;color:var(--ink);letter-spacing:-.005em}
.set-row:last-child{border-bottom:none}
.set-row .tick{width:18px;height:18px;border-radius:6px;background:var(--accent);color:var(--paper);display:grid;place-items:center;font-size:10px;font-style:normal;flex-shrink:0;font-weight:700}
.set-row .lock{color:var(--ink-3);font-style:normal;font-size:9px;flex-shrink:0;width:18px;text-align:center}
.set-toggles{background:var(--paper);border:1px solid var(--rule);border-radius:16px;overflow:hidden}
.trow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 15px;border-bottom:1px solid var(--rule)}
.trow:last-child{border-bottom:none}
.trow-k{font-size:12.5px;font-weight:500;color:var(--ink);letter-spacing:-.005em}
.trow-v{font-size:10.5px;color:var(--ink-3);margin-top:3px}
.toggle{width:38px;height:22px;border-radius:999px;background:var(--paper-3);position:relative;flex-shrink:0;border:1px solid var(--rule);transition:background .2s}
.toggle::after{content:"";position:absolute;width:17px;height:17px;border-radius:50%;background:var(--paper);top:2px;left:2px;transition:left .2s;box-shadow:0 1px 2px rgba(0,0,0,.18)}
.toggle.on{background:var(--accent);border-color:transparent}
.toggle.on::after{left:18px}

/* ---------- onboarding ---------- */
.cs-root{flex:1;display:flex;flex-direction:column;min-height:0}
.cs-nav{flex-shrink:0;display:flex;align-items:center;gap:10px;height:30px;padding:0 18px;position:relative;z-index:2}
.cs-replay{width:28px;height:28px;border-radius:8px;border:1px solid var(--rule);background:var(--paper);color:var(--ink-3);font-size:13px;line-height:1;cursor:pointer;display:grid;place-items:center;font-family:inherit;flex-shrink:0;transition:opacity .2s}
.cs-replay.hidden{opacity:0;pointer-events:none}
.cs-prog{flex:1;display:flex;gap:6px;justify-content:center}
.cs-prog i{width:24px;height:4px;border-radius:2px;background:var(--paper-3);transition:all .35s}
.cs-prog i.on{background:var(--ink)}
.cs-prog i.done{background:var(--ink-3)}
.cs-nav-sp{width:28px;flex-shrink:0}
.cs-step{flex:1;display:flex;flex-direction:column;min-height:0}
@media (prefers-reduced-motion: no-preference){
  .cs-step{animation:csIn .42s ease both}
}
@keyframes csIn{from{opacity:0}to{opacity:1}}

/* 3-step stepper (登录 → 连接邮箱 → 进入首页) */
.cs-stepper{flex:1;display:flex;align-items:center;justify-content:center;gap:0}
.csx-node{display:flex;align-items:center;gap:6px}
.csx-dot{width:18px;height:18px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;
  font-family:var(--ui);font-size:10px;font-weight:600;color:var(--ink-4);background:var(--paper-3);transition:all .3s}
.csx-lb{font-family:var(--ui);font-size:11px;letter-spacing:-.01em;color:var(--ink-4);white-space:nowrap;transition:color .3s}
.csx-node.on .csx-dot{background:var(--accent);color:#fff}
.csx-node.on .csx-lb{color:var(--ink);font-weight:600}
.csx-node.done .csx-dot{background:color-mix(in oklab,var(--accent) 22%,transparent);color:var(--accent-2)}
.csx-node.done .csx-lb{color:var(--ink-3)}
.csx-bar{width:18px;height:2px;border-radius:2px;background:var(--paper-3);margin:0 8px;flex-shrink:0;transition:background .3s}
.csx-bar.done{background:color-mix(in oklab,var(--accent) 40%,transparent)}

/* login legal footnote (replaces the hold-edu line on launch) */
.ob-legal{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);text-align:center;margin-top:16px}
.aauth-btn.shown{display:flex}

/* connect step */
.ob-connect{padding-top:4px}
.ob-lede{font-size:13px;line-height:1.6;color:var(--ink-2);letter-spacing:-.004em;margin:12px 0 18px}
.cn-card{background:var(--paper);border:1px solid var(--rule-2);border-radius:18px;padding:15px 15px 16px;
  box-shadow:0 12px 30px -18px oklch(40% .05 var(--n-hue)/.4)}
.cn-head{display:flex;align-items:center;gap:8px;margin-bottom:11px}
.cn-badge{font-family:var(--ui);font-size:10px;font-weight:600;letter-spacing:.02em;color:#fff;background:var(--accent);border-radius:6px;padding:3px 7px}
.cn-title{font-family:var(--ui);font-size:14.5px;font-weight:600;letter-spacing:-.012em;color:var(--ink)}
.cn-addr{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;
  background:var(--paper-2);border:1px dashed var(--accent-line);border-radius:11px;padding:11px 13px;cursor:pointer;transition:border-color .2s,background .2s}
.cn-addr:hover{border-color:var(--accent);background:color-mix(in oklab,var(--accent-soft) 50%,var(--paper-2))}
.cn-addr.copied{border-style:solid;border-color:var(--accent)}
.cn-addr-tx{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--ink);letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cn-addr-act{font-family:var(--ui);font-size:12px;font-weight:600;color:var(--accent-2);flex-shrink:0}
.cn-note{font-size:11.5px;line-height:1.55;color:var(--ink-3);letter-spacing:-.003em;margin:9px 0 13px}
.cn-cta{width:100%;height:48px;border-radius:13px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--ui);font-size:14px;font-weight:600;letter-spacing:-.01em;color:#fff;
  background:linear-gradient(150deg,color-mix(in oklab,var(--accent) 86%,#fff),var(--accent));
  box-shadow:0 8px 20px -9px color-mix(in oklab,var(--accent) 66%,transparent);transition:transform .12s}
.cn-cta:active{transform:scale(.99)}
.cn-cta .holdcta-hint{background:oklch(100% 0 0/.22);color:#fff}
.cn-cta .hold-fill{background:oklch(100% 0 0/.26)}
/* the Google G inside the accent CTA gets a white chip so it stays legible */
.cn-cta-g .gauth-g{background:#fff;border-radius:4px;padding:2px;box-sizing:content-box;width:15px;height:15px;flex-shrink:0}
.cn-cta span{white-space:nowrap}
.cn-sub{font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:var(--ink-4);text-align:center;margin-top:9px}
.cn-or{display:flex;align-items:center;gap:12px;margin:18px 2px 14px}
.cn-or::before,.cn-or::after{content:"";flex:1;height:1px;background:var(--rule)}
.cn-or span{font-family:var(--ui);font-size:11px;color:var(--ink-4);white-space:nowrap}
/* secondary fallback — forwarding address, quieter than the Gmail card */
.cn-alt{background:var(--paper-2);border:1px solid var(--rule);border-radius:15px;padding:13px 13px 12px}
.cn-alt-h{font-family:var(--ui);font-size:12.5px;font-weight:600;letter-spacing:-.01em;color:var(--ink-2);margin-bottom:9px}
.cn-alt .cn-addr{background:var(--paper)}
.cn-alt-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px}
.cn-alt-note{font-size:11px;line-height:1.45;color:var(--ink-4);letter-spacing:-.003em}
.cn-alt-go{flex-shrink:0;font-family:var(--ui);font-size:12.5px;font-weight:600;letter-spacing:-.008em;color:var(--accent-2);
  background:none;border:none;cursor:pointer;padding:4px 0;transition:opacity .15s}
.cn-alt-go:hover{opacity:.7}
.ob-connect .ob-tiny{margin-top:11px}

/* login auth buttons — tap (not hold), clear spacing between the two */
.ob-auth{display:flex;flex-direction:column;gap:12px;width:100%;max-width:268px;margin:0 auto}
.auth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;height:50px;border-radius:14px;cursor:pointer;
  font-family:var(--ui);font-size:15px;font-weight:600;letter-spacing:-.01em;border:1px solid transparent;
  transition:transform .12s ease,box-shadow .2s,opacity .2s}
.auth-btn:active{transform:scale(.985)}
.auth-apple{background:#000;color:#fff;box-shadow:0 8px 22px -10px oklch(0% 0 0/.6)}
.auth-apple:hover{opacity:.9}
.auth-google{background:#fff;color:#3c4043;border-color:#dadce0;box-shadow:0 6px 18px -10px oklch(40% .05 var(--n-hue)/.5)}
.auth-google:hover{background:#f7faff}
.auth-btn .gauth-label{line-height:1;white-space:nowrap}

/* ===== Gmail authorization → "learning your profile" transition ===== */
.gl{position:absolute;inset:0;z-index:40;display:flex;flex-direction:column;align-items:center;padding:52px 24px 14px;overflow:hidden;
  background:linear-gradient(168deg,var(--paper) 0%,color-mix(in oklab,var(--accent-soft) 36%,var(--paper)) 56%,var(--paper) 100%)}

/* top progress strip — reassures the user they can leave anytime */
.gl-top{position:relative;z-index:2;width:100%;flex-shrink:0;margin-bottom:6px}
.gl-bar{height:4px;border-radius:3px;background:var(--paper-3);overflow:hidden}
.gl-bar-fill{display:block;height:100%;border-radius:3px;background:linear-gradient(90deg,color-mix(in oklab,var(--accent) 80%,#fff),var(--accent));
  transition:width .8s cubic-bezier(.32,.72,.3,1)}
.gl-top-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px}
.gl-top-step{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--ink-3)}
.gl-leave{font-family:var(--ui);font-size:11.5px;font-weight:600;letter-spacing:-.006em;color:var(--accent-2);background:none;border:none;cursor:pointer;padding:2px 0;transition:opacity .15s}
.gl-leave:hover{opacity:.65}
.gl-top-note{font-family:var(--ui);font-size:10px;letter-spacing:-.003em;color:var(--ink-4);margin-top:5px}
.gl-mesh{position:absolute;inset:0;z-index:0;pointer-events:none}
.gl-mesh i{position:absolute;border-radius:50%;filter:blur(40px);opacity:.4}
.gl-mesh i:nth-child(1){left:-12%;top:-8%;width:62%;height:48%;background:radial-gradient(circle,color-mix(in oklab,var(--accent) 60%,transparent),transparent 66%);animation:glFloat1 16s ease-in-out infinite}
.gl-mesh i:nth-child(2){right:-14%;top:36%;width:58%;height:50%;background:radial-gradient(circle,color-mix(in oklab,var(--accent-b) 55%,transparent),transparent 66%);animation:glFloat2 20s ease-in-out infinite}
.gl-mesh i:nth-child(3){left:20%;bottom:-12%;width:60%;height:46%;background:radial-gradient(circle,color-mix(in oklab,var(--accent) 40%,transparent),transparent 66%);animation:glFloat1 24s ease-in-out infinite reverse}
@keyframes glFloat1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(14%,10%) scale(1.18)}}
@keyframes glFloat2{0%,100%{transform:translate(0,0) scale(1.05)}50%{transform:translate(-16%,-12%) scale(1.22)}}

.gl-core{position:relative;z-index:1;width:96px;height:96px;display:grid;place-items:center;margin-top:6px;flex-shrink:0}
.gl-ring{position:absolute;border-radius:50%;border:1.5px solid color-mix(in oklab,var(--accent) 40%,transparent)}
.gl-ring.r1{width:50px;height:50px}
.gl-ring.r2{width:72px;height:72px;opacity:.6;animation:glPulse 2.6s ease-out infinite}
.gl-ring.r3{width:94px;height:94px;opacity:.32;animation:glPulse 2.6s ease-out infinite .6s}
@keyframes glPulse{0%{transform:scale(.82);opacity:.5}70%,100%{transform:scale(1.12);opacity:0}}
.gl-mk{position:relative;z-index:2;width:54px;height:54px;border-radius:50%;display:grid;place-items:center;color:#fff;
  background:linear-gradient(155deg,color-mix(in oklab,var(--accent) 84%,#fff),var(--accent));
  box-shadow:0 8px 20px -7px color-mix(in oklab,var(--accent) 64%,transparent),inset 0 1px 0 oklch(100% 0 0/.4)}
.gl-check{font-size:30px;font-weight:700;line-height:1}
@media (prefers-reduced-motion: no-preference){
  .gl-check{animation:glPop .4s cubic-bezier(.34,1.56,.64,1) both}
}
@keyframes glPop{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}
/* scanning mail dots converge into the core during the scan phase */
.gl-orbit{position:absolute;inset:0;z-index:1}
.gl-core.ph-scan .gl-dot{position:absolute;top:50%;left:50%;width:7px;height:7px;border-radius:2px;
  background:color-mix(in oklab,var(--accent) 70%,#fff);box-shadow:0 1px 3px color-mix(in oklab,var(--accent) 50%,transparent);
  animation:glConverge 1.9s ease-in calc(var(--i) * .26s) infinite}
@keyframes glConverge{
  0%{transform:rotate(calc(var(--i) * 60deg)) translateX(74px) rotate(calc(var(--i) * -60deg));opacity:0}
  22%{opacity:1}
  100%{transform:rotate(calc(var(--i) * 60deg)) translateX(6px) rotate(calc(var(--i) * -60deg));opacity:0}}
.gl-core:not(.ph-scan) .gl-dot{display:none}

.gl-cap{position:relative;z-index:1;margin-top:12px;font-family:var(--ui);font-size:14px;font-weight:500;letter-spacing:-.008em;color:var(--ink);text-align:center;min-height:20px}
@media (prefers-reduced-motion: no-preference){
  .gl-cap{animation:glCapIn .5s ease both}
}
@keyframes glCapIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
.gl-prog{position:relative;z-index:1;display:flex;gap:6px;margin-top:11px}
.gl-prog i{width:18px;height:3px;border-radius:2px;background:var(--paper-3);transition:background .4s}
.gl-prog i.on{background:var(--accent)}

.gl-stage{position:relative;z-index:1;width:100%;max-width:300px;margin-top:13px;flex:1 1 auto;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:11px}
.gl-facts{display:flex;flex-wrap:wrap;gap:7px;justify-content:center}
.gl-fact{display:flex;align-items:center;gap:6px;font-family:var(--ui);font-size:11.5px;font-weight:500;letter-spacing:-.006em;color:var(--ink-2);white-space:nowrap;
  background:var(--paper);border:1px solid var(--rule);border-radius:999px;padding:6px 11px;
  opacity:0;transform:translateY(9px) scale(.97);transition:opacity .5s ease,transform .5s cubic-bezier(.22,1,.36,1)}
.gl-facts.in .gl-fact{opacity:1;transform:none}
.gl-fact-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--accent)}
.gl-threads{display:flex;flex-direction:column;gap:6px}
.gl-threads-h{font-family:var(--ui);font-size:11px;font-weight:600;letter-spacing:.01em;color:var(--ink-3);margin-bottom:3px}
.gl-thread{display:flex;align-items:center;gap:9px;background:var(--paper);border:1px solid var(--rule);border-radius:12px;padding:7px 11px;min-width:0;
  opacity:0;transform:translateX(14px);transition:opacity .45s ease,transform .45s cubic-bezier(.22,1,.36,1)}
.gl-threads.in .gl-thread{opacity:1;transform:none}
.gl-thread-av{width:24px;height:24px;border-radius:7px;flex-shrink:0;display:grid;place-items:center;font-family:var(--ui);font-size:11px;font-weight:600;color:#fff;background:var(--accent)}
.gl-thread-n{font-family:var(--ui);font-size:13px;font-weight:600;letter-spacing:-.01em;color:var(--ink);white-space:nowrap;flex-shrink:0}
.gl-thread-k{font-family:var(--ui);font-size:11px;color:var(--ink-3);margin-left:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.gl-thread-ok{margin-left:auto;font-size:12px;font-weight:700;color:var(--accent)}

/* confirm gate — user must tap to enter the home */
.gl-foot{position:relative;z-index:2;width:100%;max-width:300px;flex-shrink:0;margin-top:0;padding-top:12px;
  opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .4s ease,transform .4s cubic-bezier(.22,1,.36,1)}
.gl-foot.in{opacity:1;transform:none;pointer-events:auto}
.gl-confirm{width:100%;height:48px;border-radius:14px;border:none;cursor:pointer;
  font-family:var(--ui);font-size:15px;font-weight:600;letter-spacing:-.01em;color:#fff;
  background:linear-gradient(150deg,color-mix(in oklab,var(--accent) 86%,#fff),var(--accent));
  box-shadow:0 10px 24px -10px color-mix(in oklab,var(--accent) 66%,transparent);transition:transform .12s}
.gl-confirm:active{transform:scale(.99)}
.gl-confirm:disabled{opacity:.5;cursor:default}

.ob{flex:1;display:flex;flex-direction:column;padding:6px 22px;overflow-y:auto;min-height:0}
.ob::-webkit-scrollbar{width:0}
.ob-launch{align-items:center;text-align:center}
.ob-mk{color:var(--accent)}
.ob-word{font-family:var(--brandfont);font-size:46px;font-weight:300;letter-spacing:-.045em;color:var(--ink);margin-top:18px}
.ob-tagline{font-family:var(--serif);font-style:italic;font-size:14.5px;color:var(--ink-3);margin-top:12px;letter-spacing:-.01em}
.ob-h1{font-family:var(--serif);font-size:25px;font-weight:300;line-height:1.22;letter-spacing:-.025em;color:var(--ink);margin:8px 0 0}
.ob-h1 em{color:var(--accent)}
.ob-sub{font-size:13px;color:var(--ink-2);line-height:1.6;margin-top:12px;letter-spacing:-.003em}
.ob-launch .ob-sub{max-width:230px}
.ob-spacer{flex:1;min-height:14px}
.ob-tiny{font-family:var(--mono);font-size:9.5px;color:var(--ink-4);text-align:center;margin-top:14px;line-height:1.6;letter-spacing:.04em}

.gauth-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;height:48px;border-radius:12px;
  background:#fff;border:1px solid #dadce0;color:#3c4043;font-weight:500;font-size:14px;
  font-family:"Roboto",var(--ui);box-shadow:0 1px 2px rgba(60,64,67,.16);cursor:pointer;transition:box-shadow .2s,background .2s}
.gauth-btn:hover{background:#f7faff;box-shadow:0 1px 3px rgba(60,64,67,.22),0 2px 6px rgba(60,64,67,.1)}
.ob-launch .gauth-btn{max-width:256px}
.gauth-g{flex-shrink:0;display:block}
.gauth-label{line-height:1;white-space:nowrap}

/* Apple sign-in — shown only when the Tweaks "登录方式" enables it */
.aauth-btn{display:none;align-items:center;justify-content:center;gap:9px;width:100%;height:48px;border-radius:12px;margin-top:10px;
  background:#000;border:1px solid #000;color:#fff;font-weight:500;font-size:14.5px;font-family:var(--ui);cursor:pointer;transition:opacity .2s}
.aauth-btn:hover{opacity:.86}
.ob-launch .aauth-btn{max-width:256px}
.aauth-g{flex-shrink:0;display:block;margin-top:-2px}
body.show-apple .aauth-btn{display:flex}
.style-notion .aauth-btn{border-radius:9px}
body.no-grid{background-image:none}

.ob-list{background:var(--paper);border:1px solid var(--rule);border-radius:16px;overflow:hidden;margin-top:20px}
.olr{display:flex;align-items:center;gap:12px;padding:13px 14px;border-bottom:1px solid var(--rule)}
.olr:last-child{border-bottom:none}
.olr-ic{width:30px;height:30px;border-radius:8px;background:var(--accent-soft);color:var(--accent-2);display:grid;place-items:center;font-family:var(--serif);font-size:14px;flex-shrink:0}
.olr-tx{flex:1;min-width:0}
.olr-tx b{font-size:12.5px;font-weight:600;color:var(--ink);display:block;letter-spacing:-.008em}
.olr-tx span{font-size:10.5px;color:var(--ink-3);display:block;margin-top:2px;line-height:1.5}

/* concept animation — open loops Reeve runs, then long-press closes */
.concept-anim-wrap{margin:14px 0 6px;display:flex;flex-direction:column;align-items:center;gap:15px}
.ca3{display:flex;gap:16px;justify-content:center}
.ca3-loop{width:50px;height:50px;overflow:visible}
.ca3-track{fill:none;stroke:var(--rule-2);stroke-width:3;opacity:.45}
.ca3-arc{fill:none;stroke:var(--accent);stroke-width:3.4;stroke-linecap:round}
.ca3-spin{transform-box:fill-box;transform-origin:28px 28px}
.ca3-run{fill:var(--accent);transform-box:fill-box;transform-origin:center}
.ca3-check{display:none}
/* A — auto-run: each loop's dot orbits on its own, staggered */
.ph-run .ca3-spin{animation:ca3spin 1.5s linear infinite;animation-delay:var(--d)}
@keyframes ca3spin{to{transform:rotate(360deg)}}
/* B — press: dots ease toward each gap while you hold */
.ph-press .ca3-spin{transform:rotate(350deg);transition:transform .6s ease}
/* B — close: dots snap into each gap (kept loop), one by one */
.ph-close .ca3-spin{transform:rotate(360deg);transition:transform .42s cubic-bezier(.3,1.6,.5,1);transition-delay:var(--d)}
.ph-close .ca3-run{animation:ca3pop .5s ease both;animation-delay:var(--d)}
@keyframes ca3pop{40%{transform:scale(1.55)}100%{transform:scale(1.2)}}
.ph-close .ca3-loop{animation:ca3keep .6s ease both;animation-delay:var(--d)}
@keyframes ca3keep{40%{transform:scale(1.12)}100%{transform:scale(1)}}
/* the long-press indicator */
.ca3-hold{position:relative;width:30px;height:30px;border-radius:50%;background:var(--accent-soft);border:1.5px solid var(--accent-line);display:grid;place-items:center}
.ca3-finger{width:11px;height:11px;border-radius:50%;background:var(--accent);transition:transform .3s}
.ph-press .ca3-finger,.ph-close .ca3-finger{transform:scale(.74)}
.ph-press .ca3-hold::after,.ph-close .ca3-hold::after{content:"";position:absolute;inset:-2px;border-radius:50%;border:2px solid var(--accent);animation:ca3ripple 1.1s ease-out infinite}
@keyframes ca3ripple{0%{transform:scale(1);opacity:.55}100%{transform:scale(1.7);opacity:0}}

/* concept animation — hand-drawn node track (Gmail-authorization screen) */
.concept-anim-old{margin:16px 0 8px;display:flex;flex-direction:column;align-items:center;gap:14px}
.ca2{width:100%;max-width:212px;height:auto;display:block;overflow:visible}
.ca2.ring{max-width:150px}
.ca2-track{fill:none;stroke:var(--rule-2);stroke-width:2.2;stroke-linecap:round}
.ca2-fill{fill:none;stroke:var(--accent);stroke-width:2.6;stroke-linecap:round;stroke-dasharray:4;transition:stroke-dashoffset .62s cubic-bezier(.45,.05,.3,1)}
.ca2-fill.noTrans{transition:none}
.ca2-hub{fill:var(--accent);opacity:.5}
.ca2-node{fill:var(--screen-bg,#fff);stroke:var(--rule-2);stroke-width:2;transition:fill .3s,stroke .3s}
.ca2-node.active{stroke:var(--accent);fill:var(--accent-soft)}
.ca2-node.done{fill:var(--accent);stroke:var(--accent)}
.ca2-mover g{transform-box:fill-box;transform-origin:center}
.ca2-mail,.ca2-think,.ca2-snap{opacity:0}
/* hand-drawn email — inked outline, lightly filled */
.ca2-env{fill:var(--accent-soft);stroke:var(--accent-2);stroke-width:1.7;stroke-linejoin:round}
.ca2-flap{fill:none;stroke:var(--accent-2);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.ca2-flap2{opacity:.5;stroke-width:1.2}
.ca2-mail{transform:rotate(-5deg)}
/* hand-drawn thinking marks */
.ca2-dot{fill:var(--accent);stroke:var(--accent);stroke-width:.8;stroke-linejoin:round}
/* hand-drawn snap — sketchy check + sparks */
.ca2-check{fill:none;stroke:var(--accent-2);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.ca2-spark line{stroke:var(--accent);stroke-width:1.7;stroke-linecap:round}

/* fly: email drops into the node, hand-placed */
.ph-fly .ca2-mail{animation:caMail .72s cubic-bezier(.3,.8,.3,1) both}
@keyframes caMail{0%{opacity:0;transform:translate(20px,-22px) rotate(8deg) scale(.5)}55%{opacity:1}80%{transform:translate(0,0) rotate(-7deg) scale(1.08)}100%{opacity:1;transform:translate(0,0) rotate(-5deg) scale(1)}}
/* think: three marks bob */
.ph-think .ca2-think{opacity:1}
.ph-think .ca2-dot{animation:caDot 1s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
.ph-think .ca2-dot:nth-child(2){animation-delay:.16s}
.ph-think .ca2-dot:nth-child(3){animation-delay:.32s}
@keyframes caDot{0%,100%{opacity:.3;transform:translateY(1.5px) scale(.85)}50%{opacity:1;transform:translateY(-1.5px) scale(1.05)}}
/* snap: spark bursts + check is drawn (the "finger snap" approval) */
.ph-snap .ca2-snap{opacity:1}
.ph-snap .ca2-spark{animation:caSpark .56s ease-out both;transform-box:fill-box;transform-origin:center}
@keyframes caSpark{0%{opacity:0;transform:scale(.3)}45%{opacity:1}100%{opacity:0;transform:scale(1.3)}}
.ph-snap .ca2-check{stroke-dasharray:19;stroke-dashoffset:19;animation:caCheck .44s ease .12s forwards}
@keyframes caCheck{to{stroke-dashoffset:0}}

.concept-cap{font-family:var(--mono);font-size:10.5px;letter-spacing:.03em;color:var(--ink-3);text-align:center;display:flex;align-items:center;gap:7px}
.concept-cap .cc-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:breath 1.6s ease-in-out infinite}

.cs-auth-ov{position:absolute;inset:0;z-index:40;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  background:oklch(97% .006 var(--n-hue)/.82);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.cs-auth-tx{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2)}

.scanlist{background:var(--paper);border:1px solid var(--rule);border-radius:16px;padding:4px 15px;margin-top:20px}
.scan-item{display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-bottom:1px solid var(--rule)}
.scan-item:last-child{border-bottom:none}
.scan-dot{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:11px;flex-shrink:0;background:var(--accent-soft);color:var(--accent-2);font-weight:700}
.scan-dot.run{background:transparent;border:2.2px solid var(--accent-soft);border-top-color:var(--accent);animation:spin .8s linear infinite}
.scan-dot.idle{background:var(--paper-2);color:var(--ink-4)}
.scan-item b{font-family:var(--serif);font-size:13.5px;font-weight:400;color:var(--ink);display:block;letter-spacing:-.01em}
.scan-item span{font-size:10.5px;color:var(--ink-3);display:block;margin-top:2px}
.cs-bar{height:4px;border-radius:999px;background:var(--paper-3);overflow:hidden;margin-top:20px}
.cs-bar i{display:block;height:100%;border-radius:999px;background:var(--ink);width:0;animation:csFill 4s linear forwards}
@keyframes csFill{to{width:100%}}

/* ---------- recommendation ---------- */
.reco{padding:40px 0 90px}
.reco-card{border-radius:22px;padding:42px;background:var(--paper);border:1px solid var(--rule)}
.reco-eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);font-weight:500}
.reco h2{font-family:var(--serif);font-size:32px;font-weight:300;letter-spacing:-.03em;margin:14px 0 0;line-height:1.15;color:var(--ink)}
.reco h2 em{color:var(--accent)}
.reco-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:30px}
.reco-col h4{font-family:var(--serif);font-size:16px;font-weight:400;margin:0 0 12px;display:flex;align-items:center;gap:9px;white-space:nowrap;letter-spacing:-.012em}
.reco-col h4 i{font-style:normal;font-family:var(--mono);font-size:10px;padding:3px 8px;border-radius:6px;background:var(--accent-soft);color:var(--accent-2);flex-shrink:0}
.reco-col ul{margin:0;padding:0;list-style:none;display:grid;gap:11px}
.reco-col li{font-size:13px;line-height:1.6;color:var(--ink-2);padding-left:18px;position:relative;letter-spacing:-.003em}
.reco-col li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;background:var(--accent)}
.reco-col li b{color:var(--ink);font-weight:600}
.reco-verdict{margin-top:30px;padding-top:26px;border-top:1px solid var(--rule);font-family:var(--serif);font-weight:300;font-size:15px;line-height:1.7;color:var(--ink);letter-spacing:-.01em}
.reco-verdict b{color:var(--accent-2);font-weight:600}

/* ---------- cold-start: triage + reflect ---------- */
.ob-cta{height:48px;border-radius:999px;border:1px solid var(--accent);background:var(--accent);color:#fff;font-family:var(--ui);font-size:14px;font-weight:500;letter-spacing:-.005em;cursor:pointer;width:100%;-webkit-tap-highlight-color:transparent}

/* long-press CTA — fill animates while held; teaches the core interaction */
.holdcta{position:relative;overflow:hidden;cursor:pointer;font-family:var(--ui);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:none}
.holdcta .hold-fill{position:absolute;left:0;top:0;bottom:0;width:0;background:oklch(100% 0 0/.26);z-index:0}
.holdcta.is-holding .hold-fill{width:100%;transition:width .82s linear}
.holdcta .holdcta-in{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:11px}
.holdcta .holdcta-hint{position:absolute;right:13px;top:50%;transform:translateY(-50%);z-index:1;font-family:var(--mono);font-size:9px;letter-spacing:.1em;padding:3px 7px;border-radius:999px;background:oklch(100% 0 0/.22);color:#fff;opacity:.85}
.holdcta.ob-cta .hold-fill{background:oklch(100% 0 0/.3)}
.holdcta.gauth-btn .hold-fill{background:oklch(60% .14 var(--n-hue)/.16)}
.holdcta.gauth-btn .holdcta-hint{background:var(--paper-3);color:var(--ink-3)}
.holdcta.aauth-btn .holdcta-hint{background:oklch(100% 0 0/.2);color:#fff}
.ob-holdedu{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:13px;font-family:var(--mono);font-size:10px;letter-spacing:.02em;color:var(--ink-3);text-align:center}
.holdedu-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:breath 2.4s ease-in-out infinite;flex-shrink:0}
.triage-list{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.triage{display:flex;gap:11px;align-items:center;width:100%;text-align:left;padding:11px 13px;border-radius:13px;border:1px solid var(--rule);background:var(--paper);cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s}
.triage .tg-check{width:22px;height:22px;border-radius:7px;border:1.6px solid var(--rule-2);display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;transition:all .15s}
.triage.on{border-color:var(--accent-line);background:var(--accent-soft)}
.triage.on .tg-check{background:var(--accent);border-color:var(--accent)}
.tg-body{flex:1;min-width:0;overflow:hidden}
.tg-top{display:flex;justify-content:space-between;gap:8px;align-items:baseline;min-width:0}
.tg-top b{font-family:var(--serif);font-size:14px;color:var(--ink);font-weight:400;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tg-top i{font-family:var(--mono);font-size:9px;letter-spacing:.06em;color:var(--ink-3);font-style:normal;flex-shrink:0}
.triage.real .tg-top i{color:var(--accent-2)}
.tg-sub{font-size:11px;color:var(--ink-3);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.reflect{margin-top:18px;display:flex;flex-direction:column;gap:10px}
.rf-row{display:flex;align-items:center;gap:11px;padding:13px;border-radius:13px;border:1px solid var(--rule);background:var(--paper);opacity:0;transform:translateY(7px);transition:opacity .42s,transform .42s}
.rf-row.in{opacity:1;transform:none}
.rf-k{font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;text-transform:uppercase;padding:4px 8px;border-radius:6px;flex-shrink:0;font-weight:500}
.rf-k.keep{background:var(--accent-soft);color:var(--accent-2)}
.rf-k.drop{background:var(--paper-3);color:var(--ink-3)}
.rf-v{font-family:var(--serif);font-size:14px;color:var(--ink);letter-spacing:-.01em}
.reflect-note{margin-top:14px;display:flex;gap:9px;align-items:flex-start;padding:12px 13px;border-radius:13px;background:var(--accent-soft);opacity:0;transition:opacity .42s}
.reflect-note.in{opacity:1}
.reflect-note .embermark{color:var(--accent);flex-shrink:0;margin-top:1px}
.reflect-note span{font-size:11.5px;color:var(--ink-2);line-height:1.55}

/* ---------- timeline home: top bar + thread cards + centered connector ---------- */
.tl-top{flex-shrink:0}
/* AI-native logo: vivid liquid-glass aura breathing behind the mark */
.tl-top .bm{position:relative;isolation:isolate}
.tl-top .bm::before{content:"";position:absolute;inset:-8px;border-radius:50%;z-index:-1;
  background:
    radial-gradient(60% 60% at 30% 26%,oklch(70% .26 var(--n-hue)/.92),transparent 68%),
    radial-gradient(58% 58% at 74% 76%,oklch(72% .25 calc(var(--n-hue) + 55)/.82),transparent 70%),
    radial-gradient(56% 56% at 82% 22%,oklch(76% .24 calc(var(--n-hue) - 55)/.78),transparent 72%);
  filter:blur(6px);animation:logoBreath 3.4s ease-in-out infinite;will-change:transform,opacity}
.tl-top .bm::after{content:"";position:absolute;inset:-3px;border-radius:50%;z-index:-1;border:1.5px solid var(--accent);
  animation:logoRing 3.4s ease-out infinite;will-change:transform,opacity}
@keyframes logoBreath{
  0%,100%{transform:scale(.78) rotate(0deg);opacity:.5}
  50%{transform:scale(1.32) rotate(36deg);opacity:1}}
@keyframes logoRing{
  0%{transform:scale(.7);opacity:.65}
  70%,100%{transform:scale(1.6);opacity:0}}
.tl-top .bm .embermark{animation:logoPulse 3.4s ease-in-out infinite}
@keyframes logoPulse{0%,100%{transform:scale(.96)}50%{transform:scale(1.08)}}
.tl-breath{display:inline-flex;align-items:center;gap:4px;height:11px;margin-left:9px;padding-left:10px;border-left:1px solid var(--rule);align-self:center}
.tl-breath i{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.4;animation:think 1.4s ease-in-out infinite}
.tl-breath i:nth-child(2){animation-delay:.18s}
.tl-breath i:nth-child(3){animation-delay:.36s}
@keyframes think{0%,100%{opacity:.28;transform:translateY(2px) scale(.78);box-shadow:0 0 0 0 transparent}42%{opacity:1;transform:translateY(-2px) scale(1.18);box-shadow:0 0 7px 1px color-mix(in oklab,var(--accent) 50%,transparent)}}
.tl-scroll{flex:1;overflow-y:auto;padding:8px 16px 12px;display:flex;flex-direction:column;gap:0}
.tl-scroll::-webkit-scrollbar{width:0}

/* the thread card — one card, status changes per state */
.thread-card{background:var(--paper);border:1px solid var(--rule);border-radius:18px;padding:14px 15px}
/* time phrases — highlighted in the scenario's secondary accent */
.t-time{font-style:normal;font-weight:600;color:var(--accent-b);background:var(--accent-b-soft);border-radius:5px;padding:.5px 5px;margin:0 1px;font-variant-numeric:tabular-nums;letter-spacing:-.01em;white-space:nowrap;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.tc-status .t-time{padding:.5px 4px;font-size:.96em}
.draft-card .t-time,.td-text .t-time{font-weight:600}
.tc-status{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tc-status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;position:relative}
.tc-status b{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.tc-status span{font-size:11px;color:var(--ink-3);letter-spacing:-.003em}
.thread-card.watch .tc-status-dot{background:var(--accent)}
.thread-card.watch .tc-status-dot::after{content:"";position:absolute;inset:-2px;border-radius:50%;border:1.5px solid var(--accent);opacity:.5;animation:thinkRing 1.9s ease-out infinite}
@keyframes thinkRing{0%{transform:scale(.7);opacity:.6}100%{transform:scale(2);opacity:0}}
.thread-card.watch .tc-status b{color:var(--ink-2)}
.thread-card.act .tc-status-dot{background:var(--accent)}
.thread-card.act .tc-status b{color:var(--accent-2)}
.tc-open{display:flex;align-items:baseline;justify-content:space-between;gap:10px;width:100%;background:none;border:none;padding:9px 0 0;cursor:pointer;font-family:inherit;text-align:left}
.tc-subj{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--ink);letter-spacing:-.02em;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tc-open .chev{color:var(--ink-4);font-size:18px;flex-shrink:0}
.tc-meta{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;color:var(--ink-4);margin-top:5px}
.tc-line{font-size:12.5px;color:var(--ink-2);line-height:1.6;margin-top:11px;letter-spacing:-.003em}
.tc-watchfoot{display:flex;align-items:center;gap:8px;margin-top:13px;padding-top:11px;border-top:1px dashed var(--rule);font-family:var(--mono);font-size:9.5px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.tc-incoming{margin-top:11px}
.tc-inq{display:block;background:var(--accent-soft);border-left:2px solid var(--accent);border-radius:0 9px 9px 0;padding:9px 11px;font-family:var(--serif);font-weight:300;font-size:12.5px;line-height:1.5;color:var(--ink);letter-spacing:-.006em}
.tc-act{margin-top:13px;padding-top:13px;border-top:1px dashed var(--rule)}
.tc-act-head{display:flex;align-items:center;gap:8px}
.tc-act-head .embermark{color:var(--accent);flex-shrink:0}
.tc-act-head span{font-family:var(--serif);font-size:15.5px;font-weight:400;color:var(--ink);letter-spacing:-.012em}
.tc-why{margin:10px 0 0;padding:0;list-style:none;display:grid;gap:7px}
.tc-why li{position:relative;padding-left:15px;font-size:11.5px;line-height:1.5;color:var(--ink-2);letter-spacing:-.003em}
.tc-why li::before{content:"";position:absolute;left:3px;top:7px;width:4px;height:4px;border-radius:50%;background:var(--accent)}
.thread-card .draft-card{margin-top:11px;font-size:12.5px}
.thread-card .hold{margin-top:13px}
.tc-advise{display:flex;align-items:flex-start;gap:9px;margin-top:12px;padding:10px 12px;border-radius:12px;background:var(--paper-2);border:1px dashed var(--rule-2);font-size:11.5px;line-height:1.55;color:var(--ink-2);letter-spacing:-.003em}
.tc-advise .dotpulse{margin-top:5px;flex-shrink:0;background:var(--accent)}
.tc-source{width:100%;margin-top:9px;height:42px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-2);display:flex;align-items:center;justify-content:center;gap:7px}
.tc-sent{display:flex;align-items:flex-start;gap:10px;margin-top:11px;padding-top:12px;border-top:1px dashed var(--rule);font-size:12.5px;color:var(--ink-2);line-height:1.55;letter-spacing:-.004em}
.tc-sent-tick{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:700;flex-shrink:0}

/* detail — the thread's own timeline */
.td-pad{padding-top:6px}
.td-head{margin:2px 0 18px}
.td-subj{font-family:var(--serif);font-size:24px;font-weight:300;color:var(--ink);letter-spacing:-.025em}
.td-sub{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;color:var(--ink-4);margin-top:6px}
.td-rail{position:relative;padding-left:26px}
.td-rail::before{content:"";position:absolute;left:10px;top:6px;bottom:14px;width:2px;background:var(--rule)}
.td-item{position:relative;margin-bottom:16px}
.td-node{position:absolute;left:-26px;top:0;width:22px;height:22px;border-radius:50%;background:var(--paper);border:1.5px solid var(--rule-2);display:grid;place-items:center;font-size:11px;color:var(--ink-3);z-index:1}
.td-item.sent .td-node{background:var(--accent);border-color:var(--accent);color:#fff}
.td-item.watch .td-node{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 14%,transparent);animation:breath 2.8s ease-in-out infinite}
.td-who{display:flex;align-items:baseline;gap:8px}
.td-who b{font-family:var(--serif);font-size:14px;font-weight:400;color:var(--ink)}
.td-who span{font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:var(--ink-4)}
.td-text{font-size:12.5px;color:var(--ink-2);line-height:1.6;margin-top:5px;letter-spacing:-.003em}
.td-tag{display:inline-block;margin-top:8px;font-family:var(--mono);font-size:8.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-2);background:var(--accent-soft);border-radius:999px;padding:3px 9px}
.td-next{margin-top:8px;font-family:var(--serif);font-weight:300;font-size:13px;color:var(--ink-2);line-height:1.65;letter-spacing:-.008em;padding-top:14px;border-top:1px dashed var(--rule)}
.td-next b{font-family:var(--mono);font-weight:500;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);display:block;margin-bottom:5px}

/* open original email button + slide-up sheet */
.td-rawbtn{display:flex;align-items:center;gap:11px;width:100%;margin-top:8px;padding:12px 14px;border-radius:14px;background:var(--paper);border:1px solid var(--rule);cursor:pointer;text-align:left;font-family:inherit;transition:border-color .15s}
.td-rawbtn:hover{border-color:var(--accent-line)}
.td-rawbtn-ic{width:32px;height:32px;border-radius:9px;background:var(--accent-soft);color:var(--accent-2);display:grid;place-items:center;font-size:15px;flex-shrink:0}
.td-rawbtn-tx{flex:1;min-width:0}
.td-rawbtn-tx b{font-size:13px;font-weight:600;color:var(--ink);display:block;letter-spacing:-.008em}
.td-rawbtn-tx span{font-size:10.5px;color:var(--ink-3);display:block;margin-top:2px;line-height:1.4}
.td-rawbtn-up{color:var(--ink-4);font-size:15px;flex-shrink:0}
.sheet-scrim{position:absolute;inset:0;z-index:30;background:oklch(25% .03 var(--n-hue)/0);backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);display:flex;align-items:flex-end;pointer-events:none;transition:background .32s,backdrop-filter .32s}
.sheet-scrim.in{background:oklch(25% .03 var(--n-hue)/.34);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);pointer-events:auto}
.mail-sheet{width:100%;max-height:82%;display:flex;flex-direction:column;background:var(--screen-bg,var(--paper));border-radius:22px 22px 0 0;transform:translateY(100%);transition:transform .36s cubic-bezier(.32,.72,0,1);box-shadow:0 -12px 30px -12px oklch(30% .04 var(--n-hue)/.4);overflow:hidden}
.sheet-scrim.in .mail-sheet{transform:translateY(0)}
.sheet-grab{width:38px;height:4px;border-radius:3px;background:var(--rule-2);margin:9px auto 4px}
.sheet-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 18px 12px;border-bottom:1px solid var(--rule)}
.sheet-h-tx b{font-family:var(--serif);font-size:17px;font-weight:500;color:var(--ink);letter-spacing:-.015em;display:block}
.sheet-h-tx span{font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:var(--ink-4);display:block;margin-top:3px}
.sheet-x{width:30px;height:30px;border-radius:999px;border:1px solid var(--rule);background:var(--paper-2);color:var(--ink-3);font-size:13px;cursor:pointer;flex-shrink:0;display:grid;place-items:center}
.sheet-scroll{flex:1;overflow-y:auto;padding:14px 18px 20px}
.sheet-scroll::-webkit-scrollbar{width:0}
.ms-hilites{background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:12px;padding:11px 13px;margin-bottom:16px}
.ms-hl-k{font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2)}
.ms-hl-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.ms-hl-chip{font-size:11px;color:var(--accent-2);background:var(--paper);border:1px solid var(--accent-line);border-radius:999px;padding:4px 10px;font-weight:500}
.ms-subj{font-family:var(--serif);font-size:18px;font-weight:400;color:var(--ink);letter-spacing:-.018em;margin-bottom:14px}
.ms-msg{padding:13px 0;border-top:1px solid var(--rule)}
.ms-msg-h{display:flex;align-items:baseline;gap:8px;margin-bottom:7px}
.ms-msg-h b{font-family:var(--serif);font-size:13.5px;font-weight:500;color:var(--ink)}
.ms-msg-h span{font-family:var(--mono);font-size:9px;color:var(--ink-4)}
.ms-body{margin:0;font-size:13px;line-height:1.7;color:var(--ink-2);letter-spacing:-.003em}
.ms-mark{background:color-mix(in oklab,var(--accent-b) 26%,transparent);color:var(--ink);border-radius:4px;padding:1px 4px;font-weight:500;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.ms-foot{font-size:10px;color:var(--ink-4);margin-top:16px;line-height:1.5;text-align:center}

/* Reeve decomposes one complex email into many action cards */
.td-actions{margin-top:4px;padding-top:14px;border-top:1px dashed var(--rule)}
.td-act-lead{display:flex;align-items:center;gap:8px;margin-bottom:11px}
.td-act-lead .embermark{color:var(--accent)}
.td-act-lead span{font-family:var(--serif);font-size:14px;color:var(--ink);letter-spacing:-.01em}
.td-act-card{display:flex;align-items:flex-start;gap:11px;background:var(--paper);border:1px solid var(--rule);border-radius:13px;padding:11px 13px;margin-bottom:8px}
.td-act-n{width:20px;height:20px;border-radius:6px;background:var(--accent-soft);color:var(--accent-2);font-family:var(--mono);font-size:10px;font-weight:600;display:grid;place-items:center;flex-shrink:0;margin-top:1px}
.td-act-tx{flex:1;min-width:0}
.td-act-tx b{font-family:var(--serif);font-size:13.5px;font-weight:400;color:var(--ink);display:block;letter-spacing:-.01em;line-height:1.3}
.td-act-tx span{font-size:11px;color:var(--ink-3);display:block;margin-top:3px;line-height:1.45}
.td-act-verb{font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:var(--accent-2);flex-shrink:0;margin-top:2px;white-space:nowrap}
/* per-node 看原文 + bottom long-press approve */
.td-src{margin-top:8px;font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:var(--ink-3);background:var(--paper-2);border:1px solid var(--rule);border-radius:7px;padding:4px 9px;cursor:pointer}
.td-src:hover{border-color:var(--accent-line);color:var(--accent-2)}
.td-approve{margin-top:14px;padding-top:14px;border-top:1px dashed var(--rule)}
.td-approve-lead{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.td-approve-lead .embermark{color:var(--accent)}
.td-approve-lead span{font-family:var(--serif);font-size:15px;color:var(--ink);letter-spacing:-.01em}
.td-approve .draft-card{margin-bottom:0}
.td-approve .hold{margin-top:12px}
.td-approve .tc-sent{display:flex;align-items:flex-start;gap:10px;font-size:12.5px;color:var(--ink-2);line-height:1.55;letter-spacing:-.004em}

/* cold-start: first thread + following-up end */
.ob-thread{padding-top:4px}
.ob-h1.sm{font-size:22px}
.ob-h1.ctr{text-align:center}
.ob-thread .thread-card{margin-top:14px}
.ob-end{align-items:center;text-align:center}
.end-ring{width:96px;height:96px;border-radius:50%;display:grid;place-items:center;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-line);margin-bottom:6px}
.ob-sub.ctr{max-width:250px;margin-left:auto;margin-right:auto}
.end-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:7px;margin-top:18px}
.end-chips span{font-family:var(--mono);font-size:10px;letter-spacing:.03em;color:var(--ink-3);background:var(--paper-2);border:1px solid var(--rule);border-radius:999px;padding:5px 11px}

/* ---------- profile 个人主页 ---------- */
.avatar-btn{background:none;border:none;padding:0;cursor:pointer;-webkit-tap-highlight-color:transparent;display:grid;place-items:center}

/* iOS push navigation: base layer parallaxes left, secondary slides in from right */
.push-base{position:absolute;inset:0;padding-top:50px;padding-bottom:22px;display:flex;flex-direction:column;transition:transform .36s cubic-bezier(.32,.72,0,1);will-change:transform}
.push-base.pushed{transform:translateX(-26%)}
.push-over{position:absolute;inset:0;z-index:9;display:flex;flex-direction:column;padding-top:50px;background:var(--screen-bg);transform:translateX(100%);transition:transform .36s cubic-bezier(.32,.72,0,1);will-change:transform;box-shadow:-12px 0 30px -12px oklch(30% .04 var(--n-hue)/.3)}
.push-over.in{transform:translateX(0)}

/* iOS nav bar (secondary pages) */
.navbar{flex-shrink:0;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:44px;padding:0 8px;position:relative;z-index:2}
.nav-back{justify-self:start;display:flex;align-items:center;gap:0;background:none;border:none;cursor:pointer;color:var(--accent);font-family:var(--ui);padding:6px 8px;border-radius:10px;-webkit-tap-highlight-color:transparent}
.nav-chev{font-size:24px;line-height:1;margin-top:-2px}
.nav-back-tx{font-family:var(--brandfont);font-size:15px;letter-spacing:-.02em;margin-left:1px}
.nav-title{justify-self:center;font-family:var(--serif);font-size:16px;font-weight:500;color:var(--ink);letter-spacing:-.015em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.nav-action{justify-self:end;padding-right:6px}
.push-over .screen-pad,.push-over .td-pad{flex:1;min-height:0}

.pf-pad{padding-top:6px}
.pf-id{display:flex;align-items:center;gap:13px;margin:2px 0 22px}
.pf-avatar{width:48px;height:48px;border-radius:13px;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-family:var(--serif);font-size:23px;font-weight:400;flex-shrink:0}
.pf-id-tx b{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--ink);letter-spacing:-.02em;display:block}
.pf-id-tx span{font-size:11.5px;color:var(--ink-3);margin-top:3px;display:block;letter-spacing:-.003em}
.pf-sec-h{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin:0 0 11px;display:flex;align-items:center;gap:8px}
.pf-sec-h::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent)}

/* insight kanban */
.pf-kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.pf-col{background:var(--paper-2);border:1px solid var(--rule);border-radius:13px;padding:9px 8px;display:flex;flex-direction:column;gap:7px}
.pf-col-h{display:flex;align-items:center;justify-content:space-between;gap:4px}
.pf-col-h span{font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:var(--ink-3);text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pf-col-h i{font-family:var(--mono);font-size:10px;font-weight:600;font-style:normal;width:16px;height:16px;border-radius:5px;display:grid;place-items:center;flex-shrink:0;background:var(--paper-3);color:var(--ink-2)}
.pf-col.watch .pf-col-h i{background:var(--accent-soft);color:var(--accent-2)}
.pf-col.act .pf-col-h i{background:var(--accent);color:#fff}
.pf-ktile{background:var(--paper);border:1px solid var(--rule);border-radius:9px;padding:7px 8px}
.pf-col.watch .pf-ktile{border-left:2px solid var(--accent)}
.pf-ktile b{font-family:var(--serif);font-size:12px;font-weight:400;color:var(--ink);display:block;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pf-ktile span{font-size:9.5px;color:var(--ink-3);display:block;margin-top:3px;line-height:1.35}
.pf-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:9px 0 22px}
.pf-stat{background:var(--paper);border:1px solid var(--rule);border-radius:13px;padding:11px 13px}
.pf-stat-v{font-family:var(--serif);font-size:21px;font-weight:300;color:var(--ink);letter-spacing:-.02em}
.pf-stat-v .t-time{font-size:.82em}
.pf-stat-k{font-size:11px;color:var(--ink-2);margin-top:3px;font-weight:500}
.pf-stat-s{font-size:9.5px;color:var(--ink-4);margin-top:3px;line-height:1.4}

/* gmail authorization */
.pf-gmail{display:flex;align-items:center;gap:11px;background:var(--paper);border:1px solid var(--rule);border-radius:13px;padding:12px 13px}
.pf-gmail-ic{width:34px;height:34px;border-radius:9px;background:var(--paper-2);border:1px solid var(--rule);display:grid;place-items:center;flex-shrink:0}
.pf-gmail-tx{flex:1;min-width:0}
.pf-gmail-tx b{font-size:13px;font-weight:600;color:var(--ink);display:block;letter-spacing:-.008em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pf-gmail-tx span{font-size:10.5px;color:var(--ink-3);display:block;margin-top:3px;line-height:1.4}
.pf-revoke{flex-shrink:0;font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;color:var(--accent-2);background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:7px;padding:6px 9px;cursor:pointer}
.pf-add{width:100%;margin:8px 0 22px;height:42px;border-radius:11px;border:1px dashed var(--rule-2);background:transparent;color:var(--ink-2);font-family:var(--ui);font-size:12.5px;font-weight:500;cursor:pointer;letter-spacing:-.005em}
.pf-add:hover{border-color:var(--accent-line);color:var(--accent-2)}

/* manage nav */
.pf-nav{background:var(--paper);border:1px solid var(--rule);border-radius:13px;overflow:hidden}
.pf-row{display:flex;align-items:center;gap:12px;width:100%;padding:13px 14px;border:none;border-bottom:1px solid var(--rule);background:none;cursor:pointer;text-align:left;font-family:inherit}
.pf-row:last-child{border-bottom:none}
.pf-row-ic{width:30px;height:30px;border-radius:8px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex-shrink:0}
.pf-row-ic.gear{color:var(--ink-3);background:var(--paper-2);font-size:14px}
.pf-row-tx{flex:1;min-width:0}
.pf-row-tx b{font-size:13px;font-weight:600;color:var(--ink);display:block;letter-spacing:-.008em}
.pf-row-tx span{font-size:10.5px;color:var(--ink-3);display:block;margin-top:2px;line-height:1.4}
.pf-row .chev{flex-shrink:0}

/* ---------- insights dashboard (bottom of profile) ---------- */
.ins-sec{margin-top:24px}
.ins-hero{background:var(--paper);border:1px solid var(--rule);border-radius:15px;padding:14px 15px 10px;overflow:hidden}
.ins-hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.ins-hero-v{font-family:var(--serif);font-size:34px;font-weight:300;color:var(--ink);letter-spacing:-.03em;line-height:1}
.ins-hero-v span{font-size:15px;margin-left:3px;color:var(--ink-3)}
.ins-hero-k{font-size:11.5px;color:var(--ink-3);margin-top:4px;font-weight:500}
.ins-hero-badge{font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);background:var(--paper-2);border:1px solid var(--rule);border-radius:999px;padding:3px 8px;flex-shrink:0}
.ins-area{width:100%;height:62px;display:block;margin-top:6px}
.ins-area-line{filter:drop-shadow(0 2px 4px color-mix(in oklab,var(--accent) 30%,transparent))}
.ins-dot{fill:var(--accent)}
.ins-dot.last{fill:var(--accent);stroke:var(--paper);stroke-width:2}
.ins-days{display:flex;justify-content:space-between;font-family:var(--mono);font-size:9px;color:var(--ink-4);padding:0 4px;margin-top:2px}
.ins-hero-note{font-size:10px;color:var(--ink-4);margin-top:8px;line-height:1.45;letter-spacing:-.003em}
.ins-tiles{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:9px}
.ins-tile{background:var(--paper);border:1px solid var(--rule);border-radius:13px;padding:11px 13px}
.ins-tile-v{font-family:var(--serif);font-size:24px;font-weight:300;color:var(--ink);letter-spacing:-.02em;line-height:1}
.ins-tile-v span{font-size:12px;margin-left:2px;color:var(--ink-3)}
.ins-tile-k{font-size:11px;color:var(--ink-2);margin-top:5px;font-weight:500}
.ins-tile-s{font-size:9.5px;color:var(--ink-4);margin-top:3px;line-height:1.4}
.ins-drafted{background:var(--paper);border:1px solid var(--rule);border-radius:13px;padding:13px 14px;margin-top:9px}
.ins-card-h{display:flex;align-items:baseline;justify-content:space-between}
.ins-card-h b{font-family:var(--serif);font-size:14px;font-weight:400;color:var(--ink);letter-spacing:-.01em}
.ins-card-h span{font-family:var(--mono);font-size:10px;color:var(--ink-3)}
.ins-seg{display:flex;gap:3px;margin-top:11px;height:10px}
.ins-seg .seg{border-radius:3px}
.ins-seg .seg.s0{background:var(--accent)}
.ins-seg .seg.s1{background:color-mix(in oklab,var(--accent) 60%,var(--paper-3))}
.ins-seg .seg.s2{background:color-mix(in oklab,var(--accent) 32%,var(--paper-3))}
.ins-legend{display:flex;gap:14px;margin-top:10px}
.ins-legend .lg{display:flex;align-items:center;gap:6px;font-size:10.5px;color:var(--ink-2)}
.ins-legend .dot{width:8px;height:8px;border-radius:3px;flex-shrink:0}
.ins-legend .dot.s0{background:var(--accent)}
.ins-legend .dot.s1{background:color-mix(in oklab,var(--accent) 60%,var(--paper-3))}
.ins-legend .dot.s2{background:color-mix(in oklab,var(--accent) 32%,var(--paper-3))}

/* ---------- email footer (agent's sent email) ---------- */
.ef-wrap{padding:14px 16px;display:flex;flex-direction:column;height:100%;overflow-y:auto}
.ef-wrap::-webkit-scrollbar{width:0}
.ef-mailbody{background:var(--paper);border:1px solid var(--rule);border-radius:14px;padding:16px}
.ef-mh{display:flex;align-items:baseline;justify-content:space-between;gap:8px;padding-bottom:11px;border-bottom:1px solid var(--rule)}
.ef-mh b{font-family:var(--serif);font-size:15px;font-weight:500;color:var(--ink)}
.ef-mh span{font-family:var(--mono);font-size:9px;color:var(--ink-4)}
.ef-mtx{font-size:12.5px;color:var(--ink-2);line-height:1.6;margin:12px 0 0;letter-spacing:-.003em}
.ef-msig{font-size:12.5px;color:var(--ink-2);margin:10px 0 0}
.ef-divider{height:1px;background:var(--rule);margin:16px 0}
.ef-foot{display:flex;align-items:center;gap:10px}
.ef-mk{width:30px;height:30px;border-radius:8px;background:var(--accent-soft);display:grid;place-items:center;color:var(--accent);flex-shrink:0}
.ef-foot-tx b{font-size:11.5px;font-weight:600;color:var(--ink);display:block;letter-spacing:-.006em}
.ef-foot-tx span{font-size:10px;color:var(--ink-3);display:block;margin-top:2px}
.ef-cta{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:13px;height:42px;border-radius:10px;background:var(--accent-soft);border:1px solid var(--accent-line);color:var(--accent-2);font-family:var(--ui);font-size:12.5px;font-weight:600;cursor:pointer;letter-spacing:-.005em}
.ef-cap{font-family:var(--mono);font-size:9px;color:var(--ink-4);text-align:center;margin-top:14px;letter-spacing:.04em}

/* ---------- H5 share landing (client side) ---------- */
.h5{display:flex;flex-direction:column;height:100%}
.h5-top{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:8px 16px;border-bottom:1px solid var(--rule);background:var(--paper)}
.h5-mk{width:30px;height:30px;border-radius:8px;background:var(--accent-soft);display:grid;place-items:center;color:var(--accent);flex-shrink:0}
.h5-top-tx{flex:1;min-width:0}
.h5-top-tx b{font-family:var(--brandfont);font-size:15px;font-weight:400;color:var(--ink);letter-spacing:-.02em;display:block;line-height:1.1}
.h5-top-tx span{font-size:9.5px;color:var(--ink-3);display:block;margin-top:1px}
.h5-secure{font-family:var(--mono);font-size:8.5px;letter-spacing:.04em;color:var(--ink-3);background:var(--paper-2);border:1px solid var(--rule);border-radius:999px;padding:3px 8px;flex-shrink:0}
.h5-scroll{flex:1;overflow-y:auto;padding:16px}
.h5-scroll::-webkit-scrollbar{width:0}
.h5-hello{font-family:var(--serif);font-size:19px;font-weight:400;color:var(--ink);letter-spacing:-.02em}
.h5-hero{font-family:var(--serif);font-size:21px;font-weight:300;color:var(--ink);letter-spacing:-.022em;line-height:1.3;margin-top:8px}
.h5-herosub{font-size:12.5px;color:var(--ink-2);line-height:1.6;margin-top:9px;letter-spacing:-.003em}
.h5-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:13px}
.h5-chips span{font-family:var(--mono);font-size:9.5px;letter-spacing:.02em;color:var(--ink-3);background:var(--paper-2);border:1px solid var(--rule);border-radius:999px;padding:5px 10px}
.h5-plans{display:flex;flex-direction:column;gap:9px;margin-top:18px}
.h5-plan{background:var(--paper);border:1px solid var(--rule);border-radius:13px;padding:13px 14px}
.h5-plan-h{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.h5-plan-h b{font-family:var(--serif);font-size:14px;font-weight:500;color:var(--ink);letter-spacing:-.012em;line-height:1.25}
.h5-plan-tag{font-family:var(--mono);font-size:8.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-2);background:var(--accent-soft);border-radius:999px;padding:3px 8px;flex-shrink:0}
.h5-plan-pts{margin:10px 0 0;padding:0;list-style:none;display:grid;gap:7px}
.h5-plan-pts li{display:flex;align-items:flex-start;gap:8px;font-size:11.5px;line-height:1.5;color:var(--ink-2);letter-spacing:-.003em}
.h5-plan-pts li i{width:15px;height:15px;border-radius:50%;display:grid;place-items:center;font-size:9px;font-style:normal;font-weight:700;flex-shrink:0;margin-top:1px}
.h5-plan-pts li.good i{background:var(--accent-soft);color:var(--accent-2)}
.h5-plan-pts li.warn i{background:var(--paper-3);color:var(--ink-3)}
.h5-analysis{background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:13px;padding:13px 14px;margin-top:14px}
.h5-an-h{display:flex;align-items:center;gap:8px;color:var(--accent-2)}
.h5-an-h .embermark{color:var(--accent)}
.h5-an-h b{font-family:var(--serif);font-size:13.5px;font-weight:500;letter-spacing:-.01em}
.h5-reco{margin:9px 0 0;font-size:12px;line-height:1.6;color:var(--ink);letter-spacing:-.004em}
.h5-next{display:flex;flex-direction:column;gap:5px;margin-top:14px;padding:12px 14px;border:1px dashed var(--rule-2);border-radius:13px}
.h5-next-k{font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2)}
.h5-next-v{font-family:var(--serif);font-weight:300;font-size:13px;color:var(--ink);line-height:1.5;letter-spacing:-.008em}
.h5-cta{width:100%;margin-top:16px;height:46px;border-radius:12px;background:var(--accent);border:none;color:#fff;font-family:var(--ui);font-size:14px;font-weight:500;cursor:pointer;letter-spacing:-.005em}
.h5-cta2{width:100%;margin-top:9px;height:44px;border-radius:12px;background:transparent;border:1px solid var(--rule-2);color:var(--ink);font-family:var(--ui);font-size:13px;font-weight:500;cursor:pointer;letter-spacing:-.005em}
.h5-promo{margin-top:20px;padding:14px;border-radius:14px;background:var(--ink);color:var(--paper);display:flex;flex-direction:column;align-items:flex-start;gap:10px;position:relative;overflow:hidden}
.h5-promo::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 90% at 88% 0%,color-mix(in oklab,var(--accent) 55%,transparent),transparent 70%);pointer-events:none}
.h5-promo-mk{position:relative;z-index:1;width:30px;height:30px;border-radius:8px;background:oklch(100% 0 0/.12);display:grid;place-items:center;color:#fff}
.h5-promo-tx{position:relative;z-index:1;font-size:12px;line-height:1.6;color:oklch(100% 0 0/.86);letter-spacing:-.004em}
.h5-promo-cta{position:relative;z-index:1;font-family:var(--ui);font-size:12.5px;font-weight:600;color:var(--ink);background:#fff;border:none;border-radius:9px;padding:9px 15px;cursor:pointer;letter-spacing:-.005em}
.h5-trust{font-size:10px;color:var(--ink-4);text-align:center;margin-top:13px;line-height:1.5;letter-spacing:-.003em}

/* home feed: multiple thread cards, grouped */
.tl-scroll.feed{gap:20px}
.feed-group{display:flex;flex-direction:column;gap:10px}
.feed-group .group-label{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);display:flex;align-items:center;gap:8px;padding:0 2px}
.feed-group .group-label::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent)}
.feed-group.watch .group-label{color:var(--ink-3)}
.feed-group.watch .group-label::before{background:var(--ink-4)}

/* H5 conversation (client inquiry → agent reply) */
.h5-convo{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.h5-msg{border-radius:13px;padding:11px 13px;border:1px solid var(--rule)}
.h5-msg.client{background:var(--paper-2);margin-right:18px}
.h5-msg.agent{background:var(--paper);margin-left:18px;border-color:var(--accent-line)}
.h5-msg-h{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:5px}
.h5-msg-h b{font-family:var(--serif);font-size:13px;font-weight:500;color:var(--ink)}
.h5-msg.agent .h5-msg-h b{color:var(--accent-2)}
.h5-msg-h span{font-family:var(--mono);font-size:9px;color:var(--ink-4)}
.h5-msg-tx{font-size:12px;line-height:1.6;color:var(--ink-2);letter-spacing:-.003em}

/* H5 analysis verdict + suggestion */
.h5-an-h{display:flex;align-items:center;gap:8px;color:var(--accent-2)}
.h5-verdict{margin-left:auto;font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.06em;color:#fff;background:var(--accent);border-radius:999px;padding:3px 9px}
.h5-suggest{margin-top:11px;padding-top:11px;border-top:1px dashed var(--accent-line);font-size:11.5px;line-height:1.55;color:var(--ink);letter-spacing:-.004em}
.h5-suggest b{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-2);display:block;margin-bottom:5px}

/* H5 drafted reply for the client */
.h5-draft{background:var(--paper);border:1px solid var(--rule);border-radius:13px;padding:13px 14px;margin-top:16px}
.h5-draft-h{display:flex;align-items:center;gap:8px;margin-bottom:9px}
.h5-draft-h .embermark{color:var(--accent)}
.h5-draft-h b{font-family:var(--serif);font-size:13.5px;font-weight:500;color:var(--ink);letter-spacing:-.01em}
.h5-draft-h span{margin-left:auto;font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--rule);border-radius:6px;padding:3px 7px}
.h5-draft-tx{font-family:var(--serif);font-weight:300;font-size:13px;line-height:1.65;color:var(--ink);letter-spacing:-.006em;margin:0}

/* H5 send → App Store conversion */
.h5-convert{display:flex;flex-direction:column;align-items:center;text-align:center;margin-top:20px;animation:h5In .4s cubic-bezier(.2,.7,.2,1) both}
@keyframes h5In{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.h5-convert-tick{width:54px;height:54px;border-radius:50%;background:var(--accent-soft);border:1px solid var(--accent-line);display:grid;place-items:center;color:var(--accent)}
.h5-convert-sent{margin-top:12px}
.h5-convert-sent b{font-family:var(--serif);font-size:17px;font-weight:400;color:var(--ink);letter-spacing:-.015em;display:block}
.h5-convert-sent span{font-size:11.5px;color:var(--ink-3);display:block;margin-top:5px;line-height:1.5}
.h5-convert-card{width:100%;margin-top:20px;padding:18px 16px;border-radius:16px;background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.h5-convert-card::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 100% at 84% 0%,color-mix(in oklab,var(--accent) 60%,transparent),transparent 70%);pointer-events:none}
.h5-gift{position:relative;z-index:1;display:inline-block;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.06em;color:var(--ink);background:#fff;border-radius:999px;padding:5px 12px}
.h5-convert-promo{position:relative;z-index:1;font-family:var(--serif);font-weight:300;font-size:16px;line-height:1.4;color:#fff;letter-spacing:-.012em;margin-top:13px}
.h5-appstore{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:15px;height:46px;border-radius:12px;background:#fff;border:none;color:var(--ink);font-family:var(--ui);font-size:14px;font-weight:600;cursor:pointer;letter-spacing:-.005em}
.h5-appstore span{font-size:16px}

@media (prefers-reduced-motion:reduce){*{animation:none!important}}

/* zoom toolbar (canvas zoom) */
#zoombar{position:fixed;right:18px;bottom:18px;z-index:9999;display:flex;align-items:center;gap:2px;padding:5px 6px;border-radius:999px;
  background:oklch(100% 0 0/.72);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid oklch(100% 0 0/.7);box-shadow:0 8px 24px -10px oklch(40% .05 255/.4),inset 0 1px 1px oklch(100% 0 0/.9);font-family:var(--mono,monospace)}
#zoombar button{width:30px;height:30px;border:none;background:transparent;border-radius:999px;cursor:pointer;font-size:16px;color:#1f2a3a;display:grid;place-items:center;line-height:1}
#zoombar button:hover{background:oklch(60% .02 255/.12)}
#zlevel{font-size:11px;color:#3a4658;min-width:38px;text-align:center;font-variant-numeric:tabular-nums}
html,body{height:100%;overflow:hidden}
body{cursor:grab}
.zoomable{transition:none;will-change:transform}
body.panning{cursor:grabbing;user-select:none}
body.panning .zoomable{pointer-events:none}

/* ---------- voice / manual capture ---------- */
.vc-scroll{justify-content:flex-start}
.vc-intro{display:flex;flex-direction:column;align-items:center;text-align:center;padding-top:46px}
.vc-orb-wrap{height:70px;display:grid;place-items:center}
.vc-orb{display:flex;align-items:center;gap:4px;height:46px}
.vc-orb i{width:5px;height:14px;border-radius:3px;background:var(--accent-line)}
.vc-orb.on i{background:var(--accent);animation:vcBar 1s ease-in-out infinite}
.vc-orb.on i:nth-child(2){animation-delay:.12s}.vc-orb.on i:nth-child(3){animation-delay:.24s}.vc-orb.on i:nth-child(4){animation-delay:.36s}.vc-orb.on i:nth-child(5){animation-delay:.48s}
@keyframes vcBar{0%,100%{height:10px}50%{height:38px}}
.vc-tip{font-family:var(--serif);font-weight:300;font-size:17px;color:var(--ink);letter-spacing:-.018em;margin-top:18px;max-width:230px;line-height:1.4}
.vc-live{font-size:13px;color:var(--ink-2);margin-top:14px;line-height:1.6;max-width:250px;background:var(--paper-2);border:1px solid var(--rule);border-radius:12px;padding:11px 13px;letter-spacing:-.003em}
.vc-parsed{padding-top:6px}
.vc-said{margin-bottom:16px}
.vc-q{display:block;font-family:var(--serif);font-weight:300;font-size:16px;line-height:1.45;color:var(--ink);letter-spacing:-.012em}
.vc-said i{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);font-style:normal;margin-top:7px;display:block}
.vc-head{display:flex;align-items:center;gap:8px;margin-bottom:11px}
.vc-head .embermark{color:var(--accent)}
.vc-head span{font-family:var(--serif);font-size:14.5px;color:var(--ink);letter-spacing:-.01em}
.vc-fields{background:var(--paper);border:1px solid var(--rule);border-radius:14px;overflow:hidden;margin-bottom:14px}
.vc-field{display:flex;gap:10px;padding:12px 14px;border-bottom:1px solid var(--rule)}
.vc-field:last-child{border-bottom:none}
.vc-k{font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);width:74px;flex-shrink:0;padding-top:2px}
.vc-v{font-size:13px;color:var(--ink);line-height:1.5;letter-spacing:-.005em}
.vc-done{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-2);line-height:1.5;margin-bottom:14px;letter-spacing:-.004em}
.vc-bar{cursor:pointer;border:none;width:auto;text-align:left;font-family:inherit}
.vc-bar.rec{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-line)}
.vc-bar.rec .qb-send{background:var(--accent)}
.vc-bar .qb-send{font-size:13px}
@media(max-width:1100px){.canvas{grid-template-columns:repeat(2,1fr)}}
@media(max-width:780px){
  .wrap{padding:0 20px}.brandzone{grid-template-columns:1fr;gap:30px}.bz-word{font-size:48px}
  .canvas{grid-template-columns:1fr}.reco-grid{grid-template-columns:1fr}.ph-title{font-size:32px}
}
