:root{
  --paper:#f3f0e9; --paper2:#eae6dd; --ink:#0d0d0d; --ink-soft:#6f6b63; --line-l:rgba(0,0,0,.16);
  --void:#0b0b0c; --void2:#141416; --chalk:#ece9e3; --chalk-soft:#8d8a84; --line-d:rgba(236,233,227,.14);
  --mono:'Space Mono',ui-monospace,monospace; --serif:'Newsreader',Georgia,serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{background:var(--void);color:var(--chalk);font-family:var(--serif);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}

/* film grain over everything */
.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.13;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='150' height='150'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.65'/%3E%3C/svg%3E")}

.screen{position:fixed;inset:0;display:flex;flex-direction:column;z-index:1}
.hidden{display:none!important}
.light{background:var(--paper);color:var(--ink)}
.dark{background:var(--void);color:var(--chalk)}

.mono-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;line-height:1.6;color:#2b2822;font-weight:700}
.dark .mono-label{color:var(--chalk-soft)}

/* ---------- ORB ---------- */
.orb-wrap{display:flex;justify-content:center;margin-bottom:38px}
.orb-wrap.sm .orb{width:128px;height:128px}
.orb{width:188px;height:188px;display:block}
.orb.spin{animation:spin 36s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- ONBOARDING (light) ---------- */
#onboard{align-items:center;justify-content:center;padding:32px;text-align:center;overflow:hidden}
.grid{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.1;pointer-events:none}
.ob-stage{position:relative;z-index:2;width:100%;max-width:460px}
.ob-step{display:flex;flex-direction:column;align-items:center;gap:22px}
.wordmark{font-family:var(--serif);font-weight:400;font-size:4.4rem;letter-spacing:-.02em;line-height:1}
.q{font-family:var(--mono)}
.line-input{width:100%;max-width:340px;background:transparent;border:none;border-bottom:1.5px solid var(--ink);
  text-align:center;font-family:var(--serif);font-size:1.9rem;color:var(--ink);padding:8px 4px;outline:none}
.line-input::placeholder{color:rgba(13,13,13,.32)}
.fine{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;color:#574f44;max-width:300px;line-height:1.6}
.footnote{position:absolute;bottom:26px;left:0;right:0;z-index:2;text-align:center;
  font-family:var(--mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(13,13,13,.6)}
.row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:6px}
.err{font-family:var(--mono);font-size:.74rem;color:#b23b2e;min-height:1em;letter-spacing:.04em}

/* ---------- BUTTONS ---------- */
button{cursor:pointer;font-family:var(--mono);border:none;background:none;color:inherit}
.primary{background:var(--ink);color:var(--paper);text-transform:uppercase;letter-spacing:.18em;
  font-size:.8rem;font-weight:700;padding:17px 38px;border-radius:0}
.primary:hover{opacity:.85}
.ghost{background:transparent;color:var(--ink);text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;
  padding:17px 18px;border:1px solid var(--line-l)}
.ghost:hover{background:rgba(0,0,0,.05)}
.dark .primary{background:var(--chalk);color:var(--void)}
.dark .ghost{color:var(--chalk);border-color:var(--line-d)}

/* ---------- CHAT (dark) ---------- */
.bar{padding:14px 18px 12px;border-bottom:1px solid var(--line-d);background:rgba(11,11,12,.86);
  backdrop-filter:blur(8px);position:relative;z-index:3}
.bar-row{display:flex;align-items:center;justify-content:space-between}
.bar-id{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:.86rem;letter-spacing:.22em;font-weight:700}
.bar-actions{display:flex;gap:2px}
.bar-btn{width:40px;height:40px;border-radius:0;display:grid;place-items:center;color:var(--chalk-soft);font-size:1.2rem;line-height:1}
.bar-btn:hover{color:var(--chalk)}
.placements{margin-top:9px;font-family:var(--mono);font-size:.82rem;letter-spacing:.14em;color:var(--chalk-soft);min-height:1em}
.placements .gl{color:var(--chalk);margin:0 5px 0 0}
.streak{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:.74rem;font-weight:700;
  letter-spacing:.06em;color:var(--chalk);border:1px solid var(--line-d);padding:2px 8px;border-radius:0}

.thread{flex:1;overflow-y:auto;padding:24px 18px 30px;display:flex;flex-direction:column;gap:22px;scroll-behavior:smooth}

/* ---------- GLANCE WIDGET (Co-Star "day at a glance") ---------- */
.glance{background:var(--paper);color:var(--ink);padding:22px 22px 24px;position:relative;align-self:stretch}
.glance::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='0.5'/%3E%3C/svg%3E");
  opacity:.18;mix-blend-mode:multiply}
.glance-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.2em;font-size:.66rem;color:var(--ink-soft);text-align:center}
.glance-head{font-family:var(--serif);font-weight:400;font-size:1.7rem;line-height:1.18;text-align:center;margin:14px 4px 20px;letter-spacing:-.01em}
.glance-cols{display:flex;gap:18px;border-top:1px solid var(--line-l);padding-top:16px}
.glance-col{flex:1}
.glance-col:first-child{border-right:1px solid var(--line-l);padding-right:16px}
.col-h{font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;font-size:.64rem;color:var(--ink-soft);text-align:center;margin-bottom:9px}
.glance-col ul{list-style:none;text-align:center}
.glance-col li{font-family:var(--serif);font-size:1.12rem;line-height:1.6;color:var(--ink)}
.glance-refresh{position:absolute;top:14px;right:14px;font-family:var(--mono);font-size:1rem;color:var(--ink-soft);z-index:2}

/* ---------- MESSAGES ---------- */
.msg{max-width:90%;animation:rise .4s ease both}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.msg.stella{align-self:flex-start;font-family:var(--serif);font-size:1.22rem;line-height:1.5;color:var(--chalk);letter-spacing:-.005em}
.msg.stella p{margin-bottom:.7em}.msg.stella p:last-child{margin-bottom:0}
.msg.stella strong{font-weight:500}
.msg.me{align-self:flex-end;max-width:80%;font-family:var(--mono);font-size:.92rem;line-height:1.5;
  color:var(--chalk);border:1px solid var(--line-d);padding:11px 14px;letter-spacing:.01em}
.msg.me.has-img{padding:5px;border-color:var(--line-d)}
.msg-img{display:block;max-width:230px;width:100%}
.msg-cap{padding:8px 6px 3px;font-family:var(--mono);font-size:.82rem}
.caret{display:inline-block;width:8px;height:1.05em;vertical-align:-2px;margin-left:1px;background:var(--chalk);animation:caret 1s steps(2) infinite}
@keyframes caret{0%,50%{opacity:1}51%,100%{opacity:0}}

/* ---------- COMPOSER ---------- */
.attach-preview{padding:10px 18px 0;display:flex;align-items:center}
.attach-preview img{height:60px;border:1px solid var(--line-d)}
.attach-preview button{margin-left:10px;color:var(--chalk-soft);border:1px solid var(--line-d);width:28px;height:28px;font-size:1.05rem}
.composer{display:flex;align-items:flex-end;gap:8px;padding:12px 14px calc(12px + env(safe-area-inset-bottom));
  border-top:1px solid var(--line-d);background:rgba(11,11,12,.92)}
.attach-btn{width:48px;height:48px;flex:none;box-sizing:border-box;display:grid;place-items:center;color:var(--chalk-soft);border:1px solid var(--line-d)}
.attach-btn:hover{color:var(--chalk)}
#input{flex:1;background:transparent;border:1px solid var(--line-d);color:var(--chalk);font-family:var(--serif);
  font-size:1.05rem;line-height:1.3;padding:12px 14px;resize:none;outline:none;box-sizing:border-box;min-height:48px;max-height:140px}
#input::placeholder{color:var(--chalk-soft)}
.send{width:48px;height:48px;flex:none;box-sizing:border-box;background:var(--chalk);color:var(--void);font-size:1.2rem;display:grid;place-items:center}
.send:hover{opacity:.85}
.send:disabled{opacity:.4}

/* ---------- PANELS ---------- */
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:40}
.panel{position:fixed;top:0;right:0;bottom:0;width:min(420px,90vw);background:var(--void);z-index:50;
  border-left:1px solid var(--line-d);display:flex;flex-direction:column;animation:slide .28s ease both}
@keyframes slide{from{transform:translateX(100%)}to{transform:none}}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 12px;border-bottom:1px solid var(--line-d)}
.panel-head h2{font-family:var(--mono);font-size:.82rem;font-weight:700;letter-spacing:.2em;color:var(--chalk)}
.panel-head-actions{display:flex;gap:2px}
.panel-intro{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;color:var(--chalk-soft);padding:12px 18px 0}
.panel-body{flex:1;overflow-y:auto;padding:16px 18px 24px}
.mem-empty{font-family:var(--serif);color:var(--chalk-soft);font-size:1.06rem;line-height:1.5}
.mem-item{font-family:var(--serif);font-size:1.06rem;line-height:1.45;color:var(--chalk);padding:13px 0;border-bottom:1px solid var(--line-d)}
.notif-card{border:1px solid var(--line-d);padding:14px 15px;margin-bottom:12px}
.notif-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:9px}
.notif-badge{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--void);background:var(--chalk);padding:3px 8px;white-space:nowrap}
.notif-when{font-family:var(--mono);font-size:.7rem;color:var(--chalk-soft);text-align:right}
.notif-title{font-family:var(--serif);font-size:1.16rem;color:var(--chalk);margin-bottom:5px}
.notif-msg{font-family:var(--serif);font-size:1.04rem;line-height:1.5;color:#d9d6cf}
.notif-why{margin-top:9px;font-family:var(--mono);font-size:.68rem;letter-spacing:.04em;color:var(--chalk-soft);line-height:1.5;border-top:1px solid var(--line-d);padding-top:8px}

.thread::-webkit-scrollbar,.panel-body::-webkit-scrollbar{width:0}

/* onboarding progress + intent */
.ob-progress{position:absolute;top:26px;left:0;right:0;z-index:3;display:flex;gap:7px;justify-content:center}
.ob-progress .dot{width:7px;height:7px;border-radius:50%;background:rgba(0,0,0,.16)}
.ob-progress .dot.on{background:var(--ink)}
.choices{display:flex;flex-direction:column;gap:11px;width:100%;max-width:360px}
.choice{font-family:var(--serif);font-size:1.18rem;color:var(--ink);background:transparent;border:1px solid var(--line-l);
  padding:16px 18px;text-align:left;transition:background .15s}
.choice:hover{background:rgba(0,0,0,.05)}

/* ---------- TAB SHELL ---------- */
.topbar{display:flex;align-items:center;padding:12px 14px;border-bottom:1px solid var(--line-d);min-height:50px}
.topbar-spacer{flex:1}
.tabwrap{flex:1;position:relative;overflow:hidden}
.tab{position:absolute;inset:0;overflow-y:auto;display:none;-webkit-overflow-scrolling:touch}
.tab.active{display:block}
#tab-chat{flex-direction:column}
#tab-chat.active{display:flex}
.tab::-webkit-scrollbar{width:0}

.tabbar{display:flex;border-top:1px solid var(--line-d);background:rgba(11,11,12,.95);padding-bottom:env(safe-area-inset-bottom)}
.tabbtn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 0 10px;color:var(--chalk-soft);
  font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase}
.tabbtn .ti{font-size:1.2rem;line-height:1;width:34px;height:34px;display:grid;place-items:center;border-radius:50%}
.tabbtn.active{color:var(--chalk)}
.tabbtn.active .ti{background:rgba(236,233,227,.08)}
.tabbtn.accent .ti{background:var(--chalk);color:var(--void)}
.tabbtn.accent.active .ti{background:var(--chalk);color:var(--void)}

/* TODAY */
.today-inner{padding:26px 20px 30px;display:flex;flex-direction:column;gap:18px}
.hello{font-family:var(--serif);font-weight:300;font-size:2.6rem;letter-spacing:-.02em;line-height:1.05}
.placements{font-family:var(--mono);font-size:.84rem;letter-spacing:.14em;color:var(--chalk-soft)}
.placements .gl{color:var(--chalk);margin-right:5px}
.placements.big{font-size:1rem;margin:6px 0 18px}
.ask-cta{margin-top:4px;text-align:left;font-family:var(--serif);font-size:1.12rem;color:var(--chalk-soft);
  border:1px solid var(--line-d);border-radius:999px;padding:15px 20px}
.ask-cta:hover{color:var(--chalk);border-color:var(--chalk-soft)}

/* PAIR */
.pair-inner,.me-inner{padding:24px 20px 34px}
.tab-title{font-family:var(--serif);font-weight:300;font-size:2.1rem;letter-spacing:-.02em;margin-bottom:8px}
.tab-sub{font-family:var(--serif);font-size:1.05rem;line-height:1.5;color:var(--chalk-soft);margin-bottom:20px}
.pair-form{display:flex;flex-direction:column;gap:10px}
.field{background:transparent;border:1px solid var(--line-d);color:var(--chalk);font-family:var(--serif);font-size:1.05rem;padding:13px 14px;outline:none}
.field::placeholder{color:var(--chalk-soft)}
.primary.wide{width:100%;margin-top:4px}
.compat-card{margin-top:22px;border:1px solid var(--line-d);padding:20px}
.compat-score{display:flex;flex-direction:column;align-items:center;margin-bottom:14px}
.compat-score .num{font-family:var(--serif);font-size:3.6rem;line-height:1;color:var(--chalk)}
.compat-score .pct{font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--chalk-soft);margin-top:4px}
.compat-head{font-family:var(--serif);font-size:1.4rem;text-align:center;line-height:1.25;margin-bottom:18px}
.compat-dims{display:flex;flex-direction:column;gap:14px;border-top:1px solid var(--line-d);padding-top:16px}
.dim-n{font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--chalk-soft);margin-bottom:3px}
.dim-t{font-family:var(--serif);font-size:1.06rem;line-height:1.45}
.compat-sum{font-family:var(--serif);font-size:1.08rem;line-height:1.5;margin:18px 0;color:#d9d6cf}
.compat-share-line{font-family:var(--serif);font-style:italic;font-size:1.18rem;text-align:center;line-height:1.35;margin-bottom:18px}
.friend-row{display:flex;justify-content:space-between;align-items:center;width:100%;padding:14px 2px;border-bottom:1px solid var(--line-d);color:var(--chalk)}
.friend-name{font-family:var(--serif);font-size:1.12rem}
.friend-score{font-family:var(--mono);font-size:.9rem;color:var(--chalk-soft)}

/* ME */
.me-h{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--chalk-soft);margin:24px 0 10px}
.me-chart{display:flex;flex-direction:column}
.cr{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line-d);font-family:var(--serif);font-size:1.08rem}
.cr span{color:var(--chalk-soft)}.cr b{font-weight:500}
.me-memory .mem-item{font-family:var(--serif);font-size:1.06rem;line-height:1.45;padding:12px 0;border-bottom:1px solid var(--line-d)}

/* PLAN PANEL */
.plan-day{margin-bottom:18px}
.plan-date{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;color:var(--chalk-soft);margin-bottom:8px}
.plan-item{border:1px solid var(--line-d);border-left:3px solid var(--chalk-soft);padding:11px 13px;margin-bottom:9px}
.plan-item.prio-high{border-left-color:#e8a563}
.plan-item.prio-medium{border-left-color:var(--chalk-soft)}
.plan-item.prio-low{border-left-color:rgba(236,233,227,.25)}
.plan-top{display:flex;justify-content:space-between;gap:8px;margin-bottom:6px}
.plan-prio{font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--void);background:var(--chalk-soft);padding:2px 7px}
.plan-item.prio-high .plan-prio{background:#e8a563}
.plan-meta{font-family:var(--mono);font-size:.64rem;color:var(--chalk-soft)}
.plan-text{font-family:var(--serif);font-size:1.05rem;line-height:1.45;color:var(--chalk)}
.plan-reason{font-family:var(--mono);font-size:.64rem;color:var(--chalk-soft);margin-top:6px;line-height:1.4}

.friends-empty{font-family:var(--serif);color:var(--chalk-soft);font-size:1.06rem;line-height:1.5;margin-top:18px}
.friend-go{font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;color:var(--chalk-soft)}
.friend-card{margin-top:20px;border:1px solid var(--line-d);padding:18px}
.friend-card-h{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--chalk-soft);margin-bottom:12px}
.friend-card .glance{margin-bottom:16px}
.friend-card .compat-card{margin-top:16px;border:none;padding:16px 0 0}
.toast{position:fixed;left:50%;bottom:86px;transform:translateX(-50%);z-index:80;background:var(--chalk);color:var(--void);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;padding:10px 16px;animation:rise .3s ease}

/* place autocomplete */
.place-wrap{position:relative;width:100%;max-width:340px;margin:0 auto}
.place-suggest{display:none;position:absolute;top:100%;left:0;right:0;z-index:5;background:var(--paper);border:1px solid var(--line-l);max-height:230px;overflow-y:auto;text-align:left}
.place-suggest.on{display:block}
.place-opt{display:block;width:100%;text-align:left;font-family:var(--serif);font-size:1.02rem;color:var(--ink);padding:11px 13px;border-bottom:1px solid rgba(0,0,0,.07)}
.place-opt:hover{background:rgba(0,0,0,.05)}
/* dark variant inside edit form */
.dark .place-suggest{background:var(--void2);border-color:var(--line-d)}
.dark .place-opt{color:var(--chalk);border-bottom:1px solid var(--line-d)}
.dark .place-opt:hover{background:rgba(255,255,255,.05)}

/* me: edit */
.me-edit-btn{width:100%;margin-top:22px}
.ghost.wide{width:100%;display:block;text-align:center}
.edit-form{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.edit-form .place-wrap{max-width:none}

/* chat starter chips */
.chips{display:flex;flex-wrap:wrap;gap:8px;align-self:flex-start;margin-top:4px}
.chip{font-family:var(--mono);font-size:.74rem;letter-spacing:.02em;color:var(--chalk);border:1px solid var(--line-d);padding:9px 13px;border-radius:999px}
.chip:hover{border-color:var(--chalk-soft)}

/* ---------- animations & effects ---------- */
@keyframes fadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes pop { 0% { opacity: 0; transform: scale(.7); } 60% { transform: scale(1.08); } 100% { opacity: 1; transform: scale(1); } }
@keyframes floaty { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-7px); } }
@keyframes glowPulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(236,233,227,0); } 50% { box-shadow: 0 0 14px 1px rgba(236,233,227,.18); } }
@keyframes shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }

.msg { animation: fadeUp .34s cubic-bezier(.2,.7,.2,1) both; }
.tab.active { animation: fadeIn .3s ease both; }
.ob-step:not(.hidden) { animation: fadeUp .42s cubic-bezier(.2,.7,.2,1) both; }
.glance, .compat-card, .friend-card { animation: fadeUp .5s cubic-bezier(.2,.7,.2,1) both; }
.compat-score .num { animation: pop .55s cubic-bezier(.2,.8,.2,1) both; }
.ob-step[data-step="intro"] .orb-wrap, .ob-step[data-step="drawing"] .orb-wrap { animation: floaty 5s ease-in-out infinite; }
.tabbtn.accent .ti { animation: glowPulse 3.2s ease-in-out infinite; }
.chip { animation: fadeUp .4s ease both; }
.chips .chip:nth-child(2){animation-delay:.05s}.chips .chip:nth-child(3){animation-delay:.1s}.chips .chip:nth-child(4){animation-delay:.15s}

/* tactile press feedback */
.primary, .ghost, .choice, .chip, .tabbtn, .friend-row, .place-opt, .ask-cta, .glance-refresh, .bar-btn { transition: transform .12s ease, background .15s ease, border-color .15s ease, color .15s ease, opacity .15s ease; }
.primary:active, .ghost:active, .choice:active, .chip:active, .friend-row:active, .ask-cta:active, .tabbtn:active { transform: scale(.97); }
.tabbtn .ti { transition: background .2s ease, transform .15s ease; }
.tabbtn:active .ti { transform: scale(.9); }

/* shimmer for streaming caret line / loading heads */
.glance-head:empty::after, .glance-head { }
.caret { display:inline-block; width:7px; height:1.1em; background:var(--chalk); margin-left:2px; vertical-align:text-bottom; animation: blink 1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }

/* ---------- Me: bell + streak chip ---------- */
.me-bell { display:flex; align-items:center; justify-content:center; gap:9px; margin-top:11px }
.streak { display:inline-flex; align-items:center; gap:5px; align-self:flex-start; font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; color:#e8a563; border:1px solid rgba(232,165,99,.4); padding:5px 11px; border-radius:999px; margin-bottom:4px; animation: fadeUp .4s ease both }
.streak.hidden { display:none }

/* onboarding readability boost */
.ob-step { gap:20px }
.line-input { font-size:1.5rem }
.choice { font-size:1.16rem; border-color:rgba(0,0,0,.22) }
.footnote { letter-spacing:.04em }

@media (prefers-reduced-motion: reduce) {
  .msg, .tab.active, .ob-step:not(.hidden), .glance, .compat-card, .friend-card, .compat-score .num, .chip { animation: none !important; }
  .ob-step .orb-wrap, .tabbtn.accent .ti { animation: none !important; }
}

/* safe-area top (Telegram header) */
:root{--safe-top:0px}
.today-inner{padding-top:calc(28px + var(--safe-top))}
.pair-inner,.me-inner{padding-top:calc(26px + var(--safe-top))}
.ob-progress{top:calc(26px + var(--safe-top))}

/* avatars */
.ava{display:inline-block;border-radius:50%;background-size:cover;background-position:center;background-color:#26241f;flex:none}
.ava-i{display:grid;place-items:center;color:var(--chalk);font-family:var(--serif)}
.friend-l{display:flex;align-items:center;gap:12px;min-width:0}
.friend-row .friend-name{font-family:var(--serif);font-size:1.12rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* full-screen overlays */
.screen-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:200;background:var(--void);overflow-y:auto;-webkit-overflow-scrolling:touch;display:none}
.screen-overlay.open{display:block;animation:ovIn .32s cubic-bezier(.2,.7,.2,1)}
@keyframes ovIn{from{opacity:0;transform:translateX(26px)}to{opacity:1;transform:none}}
.ov-bar{position:sticky;top:0;z-index:2;background:rgba(11,11,12,.96);padding:calc(11px + var(--safe-top)) 16px 11px}
.ov-back{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--chalk-soft)}
.ov-back:active{color:var(--chalk);transform:scale(.97)}
.ov-body{padding:6px 20px 44px}

/* friend screen */
.fr-hero{display:flex;flex-direction:column;align-items:center;gap:9px;padding:10px 0 22px;animation:fadeUp .42s cubic-bezier(.2,.7,.2,1) both}
.fr-name{font-family:var(--serif);font-weight:300;font-size:2rem;letter-spacing:-.02em}
.fr-sub{font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--chalk-soft)}
#friend-screen .glance{margin-bottom:20px}
#friend-screen .primary{margin-top:6px}

/* compat screen */
.cs-loading{display:flex;flex-direction:column;align-items:center;gap:20px;padding-top:74px;animation:fadeIn .3s ease}
.cs-loading-t{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--chalk-soft)}
.cs-heads{display:flex;align-items:center;justify-content:center;gap:16px;padding-top:6px;animation:fadeUp .42s ease both}
.cs-heart{color:#e8a563;font-size:1.4rem;animation:pop .6s ease both}
.cs-names{text-align:center;font-family:var(--serif);font-size:1.3rem;margin-top:11px}
.cs-names span{color:var(--chalk-soft);margin:0 4px}
.cs-ring{position:relative;width:168px;height:168px;margin:16px auto 4px;animation:fadeIn .5s ease both}
.cs-ring svg{width:100%;height:100%}
#cs-arc{transition:stroke-dashoffset 1.25s cubic-bezier(.2,.7,.2,1)}
.cs-ring-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.cs-num{font-family:var(--serif);font-size:3.1rem;line-height:1;color:var(--chalk)}
.cs-pct{font-family:var(--mono);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--chalk-soft);margin-top:4px}
.cs-bond{text-align:center;font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#e8a563;margin-bottom:4px}
.cs-head{text-align:center;font-family:var(--serif);font-size:1.55rem;line-height:1.22;margin:6px 12px 24px}
.cs-dims{display:flex;flex-direction:column;gap:17px;border-top:1px solid var(--line-d);padding-top:20px}
.cs-dim{animation:fadeUp .5s ease both}
.cs-dim-top{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--chalk-soft);margin-bottom:7px}
.cs-dim-top b{color:var(--chalk);font-size:.95rem}
.cs-bar{height:4px;background:rgba(236,233,227,.1)}
.cs-bar i{display:block;height:100%;width:0;background:#e8a563;transition:width 1s cubic-bezier(.2,.7,.2,1)}
.cs-dim-t{font-family:var(--serif);font-size:1.05rem;line-height:1.45;margin-top:9px}
.cs-sum{font-family:var(--serif);font-size:1.1rem;line-height:1.5;margin:24px 0;color:#d9d6cf}
.cs-share-line{font-family:var(--serif);font-style:italic;font-size:1.22rem;text-align:center;line-height:1.35;margin-bottom:22px}

@media (max-width:420px){
  .wordmark{font-size:3.6rem}.glance-head{font-size:1.5rem}.msg.stella{font-size:1.14rem}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
}

.danger-link{display:block;width:100%;text-align:center;margin-top:20px;padding:11px;background:none;border:none;color:#b06a6a;font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;opacity:.7;cursor:pointer;transition:opacity .15s}
.danger-link:active{opacity:1;transform:scale(.98)}

/* typing indicator */
.typing{display:inline-flex;gap:6px;padding:6px 0}
.typing i{width:7px;height:7px;border-radius:50%;background:var(--chalk-soft);animation:typingBounce 1.25s infinite ease-in-out}
.typing i:nth-child(2){animation-delay:.16s}
.typing i:nth-child(3){animation-delay:.32s}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0);opacity:.35}30%{transform:translateY(-5px);opacity:1}}
