/* components.css — extracted from index.html (Phase: CSS modularization).
   Load order theme -> layout -> components -> mobile is load-bearing (cascade). */
/* ---------- Astra ---------- */
.astra-wrap{display:grid;grid-template-columns:1fr 280px;gap:18px;margin-top:22px}
.chatcard{padding:0;overflow:hidden;display:flex;flex-direction:column;min-height:520px}
.chathead{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line)}
.chathead .av{width:38px;height:38px;border-radius:11px;background:var(--grad);display:grid;place-items:center}
.chathead .av svg{width:19px;height:19px}
.chathead .meta b{font-family:'Bricolage Grotesque';font-weight:800;font-size:15px}
.chathead .meta span{display:block;font-size:11.5px;color:var(--muted)}
.chathead .route{margin-left:auto;font-family:'JetBrains Mono';font-size:10px;letter-spacing:.5px;padding:5px 10px;border-radius:20px;border:1px solid var(--line);color:var(--faint);transition:.3s}
.route.cache{color:var(--lime);border-color:rgba(134,255,107,.4);box-shadow:0 0 16px rgba(134,255,107,.15)}
.route.fresh{color:var(--cyan);border-color:rgba(34,211,238,.4)}
.stream{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}
.stream::-webkit-scrollbar{width:7px}.stream::-webkit-scrollbar-thumb{background:var(--scroll-thumb);border-radius:8px}
.msg{max-width:86%;font-size:14.2px;line-height:1.6;overflow-wrap:anywhere;min-width:0}
/* let the flex/grid chain shrink so wide code/tables/math scroll inside the bubble
   instead of widening the page (mobile horizontal-scroll fix) */
.astra-wrap,.chatcard,.stream{min-width:0}
.msg.user{align-self:flex-end;background:var(--grad);color:#fff;padding:11px 15px;border-radius:15px 15px 4px 15px}
.msg.bot{align-self:flex-start;background:var(--panel2);border:1px solid var(--line);padding:15px 17px;border-radius:15px 15px 15px 4px}
.msg.bot h4{font-family:'Bricolage Grotesque';color:var(--lime);font-size:14.5px;margin:10px 0 4px}
.msg.bot h4:first-child{margin-top:0}
.msg.bot ul{margin:6px 0 2px 4px;list-style:none}
.msg.bot li{padding-left:18px;position:relative;margin:5px 0;color:var(--muted)}
.msg.bot li::before{content:"›";position:absolute;left:2px;color:var(--cyan)}
.msg.bot b,.msg.bot strong{color:var(--text)}

/* ============================================================
   RENDERED MARKDOWN — shared by Astra chat (.msg.bot) + team chat
   (.tmsg.bot). Makes Gemini's markdown read like a learning
   platform: paragraph rhythm, ordered lists, code blocks, tables,
   links, quotes. KaTeX-ready (.katex sizing reserved for later).
   ============================================================ */
.msg.bot p,.tmsg.bot p{margin:0 0 10px;line-height:1.62}
.msg.bot p:last-child,.tmsg.bot p:last-child{margin-bottom:0}
.msg.bot h1,.msg.bot h2,.msg.bot h3,.msg.bot h5,.msg.bot h6,
.tmsg.bot h1,.tmsg.bot h2,.tmsg.bot h3,.tmsg.bot h4{
  font-family:'Bricolage Grotesque';color:var(--lime);font-weight:800;
  font-size:14.5px;margin:14px 0 5px;line-height:1.3}
.msg.bot h1:first-child,.msg.bot h2:first-child,.msg.bot h3:first-child,
.tmsg.bot h1:first-child,.tmsg.bot h2:first-child,.tmsg.bot h3:first-child{margin-top:0}
/* ordered lists — numbered, styled to match the bulleted list */
.msg.bot ol,.tmsg.bot ol{margin:6px 0 2px 2px;padding:0;list-style:none;counter-reset:astra-ol}
.msg.bot ol>li,.tmsg.bot ol>li{counter-increment:astra-ol;padding-left:26px;position:relative;margin:6px 0;color:var(--muted)}
.msg.bot ol>li::before,.tmsg.bot ol>li::before{
  content:counter(astra-ol);position:absolute;left:0;top:0;color:var(--cyan);
  font-family:'JetBrains Mono';font-size:11px;font-weight:600}
.tmsg.bot ul{margin:6px 0 2px 4px;list-style:none}
.tmsg.bot li{padding-left:18px;position:relative;margin:5px 0;color:var(--muted)}
.tmsg.bot li::before{content:"›";position:absolute;left:2px;color:var(--cyan)}
/* inline code + fenced code blocks */
.msg.bot code,.tmsg.bot code{
  font-family:'JetBrains Mono',monospace;font-size:12.5px;
  background:var(--code-inline-bg);color:var(--code-inline-text);border:1px solid var(--line);
  border-radius:6px;padding:1px 6px}
.msg.bot pre,.tmsg.bot pre{
  background:var(--code-bg);border:1px solid var(--line2);border-radius:12px;
  padding:13px 15px;margin:10px 0;overflow-x:auto;-webkit-overflow-scrolling:touch}
.msg.bot pre code,.tmsg.bot pre code{
  background:none;border:none;padding:0;color:var(--code-text);font-size:12.5px;line-height:1.6;display:block;white-space:pre}
/* links, quotes, rules, tables */
.msg.bot a,.tmsg.bot a{color:var(--cyan);text-decoration:none;border-bottom:1px solid rgba(34,211,238,.35)}
.msg.bot a:hover,.tmsg.bot a:hover{border-bottom-color:var(--cyan)}
.msg.bot blockquote,.tmsg.bot blockquote{
  margin:10px 0;padding:8px 14px;border-left:3px solid var(--violet);
  background:rgba(124,92,255,.07);border-radius:0 10px 10px 0;color:var(--muted)}
.msg.bot hr,.tmsg.bot hr{border:none;border-top:1px solid var(--line);margin:14px 0}
.msg.bot table,.tmsg.bot table{width:100%;border-collapse:collapse;margin:10px 0;font-size:13px;display:block;overflow-x:auto}
.msg.bot th,.msg.bot td,.tmsg.bot th,.tmsg.bot td{border:1px solid var(--line);padding:7px 11px;text-align:left}
.msg.bot th,.tmsg.bot th{background:var(--panel2);color:var(--text);font-weight:700}
/* KaTeX block math: scroll wide equations instead of forcing page overflow (mobile) */
.msg.bot .katex-display,.tmsg.bot .katex-display{overflow-x:auto;overflow-y:hidden;padding:4px 2px;margin:10px 0}
.suggest{display:flex;flex-wrap:wrap;gap:8px;padding:0 20px 14px}
.suggest button{font-family:inherit;font-size:12.5px;color:var(--muted);background:var(--panel2);border:1px solid var(--line);padding:8px 13px;border-radius:20px;cursor:pointer;transition:.16s}
.suggest button:hover{border-color:var(--violet);color:#fff}
.composer{display:flex;gap:10px;padding:16px 20px;border-top:1px solid var(--line)}
.composer input{flex:1;background:var(--ink2);border:1px solid var(--line);border-radius:12px;padding:13px 15px;color:var(--text);font-family:inherit;font-size:14px;outline:none}
.composer input:focus{border-color:var(--violet)}
.composer .mic{width:46px;border-radius:12px;background:var(--panel2);border:1px solid var(--line);display:grid;place-items:center;cursor:pointer;color:var(--muted)}
.composer .mic:hover{color:var(--cyan);border-color:var(--cyan)}
.composer .send{border-radius:12px;background:var(--grad);border:none;padding:0 18px;cursor:pointer;display:grid;place-items:center}
.composer .send svg{width:18px;height:18px;color:#fff}

.side .card{padding:18px;margin-bottom:16px}
.side .card .k{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:1.5px;color:var(--faint);text-transform:uppercase;margin-bottom:12px}
.pchip{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.pchip:last-child{border:none}.pchip span{color:var(--muted)}.pchip b{font-weight:600}
.pchip .pill{font-size:11px;font-family:'JetBrains Mono';padding:3px 9px;border-radius:20px;background:rgba(124,92,255,.16);color:#c3b6ff;border:1px solid rgba(124,92,255,.3)}

/* ---------- Quests ---------- */
.q-controls{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.sel{position:relative}
.sel label{display:block;font-family:'JetBrains Mono';font-size:10px;letter-spacing:1.5px;color:var(--faint);text-transform:uppercase;margin-bottom:7px}
.sel select{appearance:none;background:var(--panel);border:1px solid var(--line);color:var(--text);font-family:inherit;font-size:14px;padding:12px 40px 12px 15px;border-radius:12px;cursor:pointer;outline:none;min-width:190px}
.sel select:focus{border-color:var(--violet)}
.sel::after{content:"▾";position:absolute;right:15px;bottom:13px;color:var(--faint);pointer-events:none}
.mission{padding:26px;margin-top:20px;overflow:hidden;position:relative}
.mission .badge{font-family:'JetBrains Mono';font-size:11px;letter-spacing:1px;color:var(--rose);display:inline-flex;align-items:center;gap:7px}
.mission .badge::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--rose);box-shadow:0 0 12px var(--rose);animation:pulse 1.4s infinite}
.mission .story{font-size:15.5px;line-height:1.65;margin:14px 0;max-width:640px}
.mission .puzzle{padding:16px 18px;border-radius:14px;background:rgba(245,181,68,.08);border:1px solid rgba(245,181,68,.3);font-size:14.5px}
.mission .puzzle b{color:var(--amber)}
.solverow{display:flex;gap:10px;margin-top:18px}
.solverow input{flex:1;background:var(--ink2);border:1px solid var(--line);border-radius:12px;padding:13px 15px;color:var(--text);font-family:inherit;outline:none}
.solverow input:focus{border-color:var(--amber)}
.feedback{margin-top:16px;padding:15px 17px;border-radius:13px;font-size:14px;display:none}
.feedback.win{display:block;background:rgba(134,255,107,.1);border:1px solid rgba(134,255,107,.3)}
.feedback.win b{color:var(--lime);font-family:'Bricolage Grotesque';font-size:16px}
.feedback.fail{display:block;background:rgba(255,107,139,.08);border:1px solid rgba(255,107,139,.25)}
.feedback.fail b{color:var(--rose);font-family:'Bricolage Grotesque';font-size:16px}

/* ---------- Paths ---------- */
/* Ecosystem journey strip — communicates that the roadmap is step 1, not the end. */
.journey{margin-top:22px;overflow:visible} /* visible so the "YOU START HERE" badge isn't clipped */
.journey-h{font-family:'JetBrains Mono';font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--violet);margin-bottom:5px}
.journey-sub{color:var(--muted);font-size:13.5px;margin-bottom:18px}
.journey-sub b{color:var(--text)}
.journey-rail{display:flex;align-items:stretch;gap:6px;padding-top:9px} /* room for the badge */
.journey-step{flex:1;min-width:0;position:relative;padding:16px 12px 14px;border-radius:14px;border:1px solid var(--line);background:var(--panel2);text-align:center;transition:.18s}
.journey-step.here{border-color:transparent;background:linear-gradient(160deg,rgba(124,92,255,.24),rgba(34,211,238,.05));box-shadow:0 0 0 1px var(--violet),0 12px 30px rgba(124,92,255,.22)}
.journey-step .ji{font-size:23px;line-height:1}
.journey-step .jt{font-family:'Bricolage Grotesque';font-weight:800;font-size:13.5px;margin-top:9px}
.journey-step .jd{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.4}
.journey-step .jhere{position:absolute;top:-9px;left:50%;transform:translateX(-50%);font-family:'JetBrains Mono';font-size:8.5px;letter-spacing:.5px;color:#fff;background:var(--grad);padding:2px 9px;border-radius:20px;white-space:nowrap;box-shadow:0 4px 14px rgba(124,92,255,.5)}
.journey-arrow{display:flex;align-items:center;color:var(--faint);font-size:15px;flex:none}
@media(max-width:720px){
  .journey-rail{overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:2px}
  .journey-rail::-webkit-scrollbar{display:none}
  .journey-step{flex:0 0 134px}
}
.path-tabs{display:flex;gap:10px;margin-top:22px}
.path-tabs button{font-family:inherit;font-size:13.5px;color:var(--muted);background:var(--panel);border:1px solid var(--line);padding:10px 16px;border-radius:11px;cursor:pointer}
.path-tabs button.on{color:#fff;border-color:var(--violet);background:linear-gradient(90deg,rgba(124,92,255,.2),transparent)}
.roadmap{margin-top:24px;position:relative;padding-left:34px}
.roadmap::before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--violet),var(--cyan),var(--lime))}
.node{position:relative;padding:0 0 26px}
.node::before{content:"";position:absolute;left:-28px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--ink);border:3px solid var(--violet);box-shadow:0 0 12px rgba(124,92,255,.6)}
.node.done::before{background:var(--lime);border-color:var(--lime);box-shadow:0 0 10px rgba(134,255,107,.4)}
.node.now::before{border-color:var(--cyan);background:var(--cyan);animation:pulse 1.8s infinite;box-shadow:0 0 14px rgba(34,211,238,.6)}
.node.future{opacity:.55}
.node.future::before{border-color:var(--line2);background:var(--ink);box-shadow:none}
.node .mtitle{font-family:'Bricolage Grotesque';font-weight:700;font-size:16px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.node .mtitle .tf{font-family:'JetBrains Mono';font-size:10.5px;color:var(--faint)}
.node .mtitle .pace-chip{font-family:'JetBrains Mono';font-size:10px;padding:2px 8px;border-radius:20px;font-weight:500}
.node .mdesc{color:var(--muted);font-size:13.5px;margin-top:6px;line-height:1.55}
.node ul{margin:10px 0 2px 2px;list-style:none;display:flex;flex-direction:column;gap:5px}
.node li{padding:7px 11px 7px 32px;position:relative;color:var(--text);font-size:13px;background:var(--panel2);border-radius:9px;border:1px solid var(--line)}
.node li.task-done{opacity:.5;text-decoration:line-through}
.node li::before{content:"›";position:absolute;left:12px;color:var(--cyan)}
.node .res{font-family:'JetBrains Mono';font-size:11px;color:var(--faint);margin-top:9px;padding-top:9px;border-top:1px solid var(--line)}
/* goal composer + cards */
.gc-label{display:block;font-family:'JetBrains Mono';font-size:10px;letter-spacing:1.5px;color:var(--faint);text-transform:uppercase;margin-bottom:7px}
.gc-input,.gc-select{width:100%;background:var(--ink2);border:1px solid var(--line);border-radius:12px;padding:12px 14px;color:var(--text);font-family:inherit;font-size:14px;outline:none}
.gc-input:focus,.gc-select:focus{border-color:var(--violet)}
.goal-card{padding:24px;margin-bottom:20px}
.goal-card .ghead{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:6px}
.goal-card .gtitle{font-family:'Bricolage Grotesque';font-weight:800;font-size:19px;flex:1;min-width:160px}
.goal-badge{font-family:'JetBrains Mono';font-size:10px;letter-spacing:1px;padding:4px 10px;border-radius:20px;border:1px solid var(--line);color:var(--muted);text-transform:uppercase}
.goal-badge.long{color:#c3b6ff;border-color:rgba(124,92,255,.4)}
.goal-badge.short{color:var(--cyan);border-color:rgba(34,211,238,.4)}
.goal-badge.done{color:var(--lime);border-color:rgba(134,255,107,.4)}
.goal-badge.paused{color:var(--amber);border-color:rgba(245,181,68,.4)}
.goal-summary{color:var(--muted);font-size:13.5px;margin:10px 0 14px}
.goal-summary b{color:var(--lime);font-family:'JetBrains Mono';font-size:12px}
.goal-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.goal-actions .btn{padding:10px 15px;font-size:13px}
.goals-empty{padding:40px;text-align:center;color:var(--muted)}
/* consistency loop: tasks + xp */
.task-row{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:12px;border:1px solid var(--line);background:var(--panel2);cursor:pointer;margin-bottom:8px;transition:.15s}
.task-row:hover{border-color:var(--violet)}
.task-check{width:22px;height:22px;border-radius:7px;border:2px solid var(--line2);display:grid;place-items:center;font-size:13px;color:var(--lime);flex:0 0 auto}
.task-row.done{opacity:.65}
.task-row.done .task-check{background:rgba(134,255,107,.15);border-color:var(--lime)}
.task-row.done .task-title{text-decoration:line-through;color:var(--faint)}
.task-title{font-size:14px;line-height:1.4}
.tasks-empty{color:var(--muted);font-size:13.5px;padding:8px 2px;line-height:1.5}
.xp-opp{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:8px}
.xp-opp .pt{font-family:'JetBrains Mono';color:var(--cyan);font-size:11px;border:1px solid rgba(34,211,238,.3);border-radius:20px;padding:2px 8px;flex:0 0 auto}
.xp-toast{position:fixed;right:26px;bottom:26px;z-index:300;display:flex;flex-direction:column;gap:10px;align-items:flex-end;pointer-events:none}
.xp-pop{font-family:'Bricolage Grotesque';font-weight:800;font-size:15px;background:var(--grad);color:#fff;padding:11px 17px;border-radius:13px;box-shadow:0 10px 30px rgba(124,92,255,.5);animation:xpRise .45s cubic-bezier(.2,.7,.2,1),xpFade .5s ease 1.9s forwards}
@keyframes xpRise{from{opacity:0;transform:translateY(18px) scale(.92)}to{opacity:1;transform:none}}
@keyframes xpFade{to{opacity:0;transform:translateY(-12px)}}

/* ---------- Spark / profile ---------- */
.arch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px}
.arch{padding:22px;cursor:pointer;transition:.2s;position:relative;overflow:hidden}
.arch:hover{transform:translateY(-3px)}
.arch .emo{font-size:30px}
.arch h3{font-family:'Bricolage Grotesque';font-weight:800;font-size:19px;margin-top:12px}
.arch p{color:var(--muted);font-size:13px;margin-top:6px;line-height:1.5}
.arch .for{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:1px;color:var(--faint);margin-top:12px;text-transform:uppercase}
.arch.sel-on{border-color:transparent;background:linear-gradient(160deg,rgba(124,92,255,.22),rgba(34,211,238,.06));box-shadow:0 0 0 1px var(--violet),0 14px 40px rgba(124,92,255,.3)}
.arch.sel-on::after{content:"✓ ACTIVE";position:absolute;top:14px;right:14px;font-family:'JetBrains Mono';font-size:10px;color:var(--lime)}
.opt-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-top:22px}
.opt-row .sel select{width:100%}

.locked{padding:40px;text-align:center;margin-top:22px}
.locked .lk{font-size:34px;opacity:.5}
.locked h3{font-family:'Bricolage Grotesque';font-size:20px;margin-top:14px}
.locked p{color:var(--muted);font-size:14px;margin-top:8px;max-width:440px;margin-inline:auto}
.locked .ph{display:inline-flex;gap:8px;margin-top:18px;flex-wrap:wrap;justify-content:center}
.locked .ph span{font-size:12px;color:var(--faint);border:1px solid var(--line);padding:6px 12px;border-radius:20px}

@media(max-width:900px){.app{grid-template-columns:1fr}.g-hero,.astra-wrap,.stat-row,.arch-grid,.consist-grid{grid-template-columns:1fr}}

/* ============================================================
   UI POLISH PASS — all additive (hover/active/focus/motion only)
   ============================================================ */
/* accessible focus rings */
*:focus-visible{outline:2px solid var(--violet);outline-offset:2px;border-radius:10px}
.btn:focus-visible,.nav button:focus-visible{outline-offset:3px}

/* button feedback + primary sheen sweep on hover */
.btn{position:relative;overflow:hidden}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-p::after{content:"";position:absolute;top:0;left:-130%;width:75%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.28),transparent);
  transform:skewX(-18deg);transition:left .6s ease;pointer-events:none}
.btn-p:hover::after{left:140%}

/* nav: active accent bar + nudge on hover */
.nav button{position:relative}
.nav button.on::before{content:"";position:absolute;left:-16px;top:50%;transform:translateY(-50%);
  width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--grad)}
.nav button:hover{transform:translateX(2px)}

/* interactive cards lift on hover */
.stat,.goal-card,.day,.task-row{transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.stat:hover,.goal-card:hover{transform:translateY(-3px);border-color:var(--line2);box-shadow:0 16px 36px rgba(0,0,0,.38)}
.day:not(.today):hover{transform:translateY(-2px);border-color:var(--line2)}
.task-row:hover{transform:translateX(2px);border-color:var(--line2)}
.suggest button:hover{border-color:var(--cyan);color:var(--text);transform:translateY(-1px)}

.beta-chip{display:inline-block;vertical-align:middle;margin-left:6px;font-family:'JetBrains Mono';font-size:8.5px;letter-spacing:.6px;color:#34d399;border:1px solid rgba(52,211,153,.4);background:rgba(52,211,153,.1);border-radius:20px;padding:2px 6px;cursor:help}
/* topbar chips + avatar */
.chip{transition:border-color .18s ease,transform .18s ease}
.chip:hover{border-color:var(--line2)}
.avatar{transition:transform .18s ease,box-shadow .18s ease}
.avatar:hover{transform:scale(1.07);box-shadow:0 0 18px rgba(34,211,238,.5)}

/* pulse XP / streak chips when their number changes */
@keyframes chipPulse{0%{transform:none}28%{transform:scale(1.15)}100%{transform:none}}
.chip.bump{animation:chipPulse .6s cubic-bezier(.2,.7,.2,1)}
.chip.bump .dot{box-shadow:0 0 16px currentColor}

/* hamburger press feedback */
.menu-btn:active{transform:scale(.94)}

/* ---------- general toasts (errors / confirmations) ---------- */
.toast-host{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:400;
  display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none;max-width:92vw}
.toast{pointer-events:auto;display:flex;align-items:center;gap:11px;font-size:13.5px;font-weight:500;
  padding:12px 16px;border-radius:13px;background:rgba(23,23,40,.92);border:1px solid var(--line2);
  color:var(--text);box-shadow:0 16px 44px rgba(0,0,0,.5);backdrop-filter:blur(12px);
  animation:toastIn .35s cubic-bezier(.2,.7,.2,1)}
.toast .ic{width:20px;height:20px;flex:0 0 auto;display:grid;place-items:center;border-radius:50%;
  font-weight:800;font-size:12px;font-family:'JetBrains Mono'}
.toast.ok{border-color:rgba(134,255,107,.45)}.toast.ok .ic{color:var(--lime);background:rgba(134,255,107,.12)}
.toast.err{border-color:rgba(255,107,139,.5)}.toast.err .ic{color:var(--rose);background:rgba(255,107,139,.12)}
.toast.info .ic{color:var(--cyan);background:rgba(34,211,238,.12)}
.toast.out{animation:toastOut .35s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateY(-14px) scale(.96)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(-14px) scale(.96)}}

/* respect reduced-motion preference */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important}
  .btn-p::after{display:none}
}

/* ---------- skeleton loaders ---------- */
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skel{background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.10) 37%,rgba(255,255,255,.04) 63%);background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:10px}
.skel-row{height:36px;margin-bottom:7px}
.skel-line{height:12px;margin:9px 0}
.skel-card{height:128px;border-radius:var(--radius);margin-bottom:14px}

/* ---------- chat: message entrance · typing dots · copy ---------- */
.msg{position:relative;animation:msgIn .35s cubic-bezier(.2,.7,.2,1)}
@keyframes msgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.typing{display:inline-flex;gap:5px;align-items:center;padding:3px 2px}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:typedot 1.2s infinite ease-in-out}
.typing span:nth-child(2){animation-delay:.18s}.typing span:nth-child(3){animation-delay:.36s}
@keyframes typedot{0%,60%,100%{opacity:.25;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.copy-btn{position:absolute;top:8px;right:8px;width:26px;height:26px;display:grid;place-items:center;
  border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--faint);cursor:pointer;opacity:0;transition:.15s}
.msg.bot:hover .copy-btn{opacity:1}
.copy-btn:hover{color:var(--cyan);border-color:var(--line2)}
.copy-btn.done{color:var(--lime);border-color:rgba(134,255,107,.4);opacity:1}

/* ---------- friendlier empty states ---------- */
.empty-state{text-align:center;padding:28px 20px;color:var(--muted)}
.empty-state .emo{font-size:30px;opacity:.9}
.empty-state .t{font-family:'Bricolage Grotesque';font-weight:800;font-size:16px;color:var(--text);margin-top:10px}
.empty-state .d{font-size:13px;margin-top:5px;max-width:400px;margin-inline:auto;line-height:1.5}

/* ---------- confetti (streak milestone) ---------- */
.confetti-host{position:fixed;inset:0;z-index:500;pointer-events:none;overflow:hidden}
.confetti-host i{position:absolute;top:-16px;width:9px;height:14px;border-radius:2px;opacity:.95;animation:confFall 2.2s cubic-bezier(.35,.1,.3,1) forwards}
@keyframes confFall{to{transform:translateY(106vh) rotate(560deg);opacity:.12}}

/* ---------- command palette (Cmd/Ctrl-K) ---------- */
.cmdk-scrim{position:fixed;inset:0;z-index:600;background:rgba(4,4,10,.6);backdrop-filter:blur(4px);display:none}
.cmdk-scrim.on{display:block}
.cmdk{position:fixed;z-index:601;top:14vh;left:50%;transform:translateX(-50%);width:min(560px,92vw);
  background:linear-gradient(180deg,var(--panel),var(--ink2));border:1px solid var(--line2);border-radius:16px;
  box-shadow:0 30px 80px rgba(0,0,0,.6);overflow:hidden;display:none}
.cmdk.on{display:block;animation:msgIn .2s ease}
.cmdk input{width:100%;background:none;border:none;border-bottom:1px solid var(--line);color:var(--text);font-family:inherit;font-size:16px;padding:18px 20px;outline:none}
.cmdk .list{max-height:50vh;overflow-y:auto;padding:8px}
.cmdk .item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:11px;cursor:pointer;color:var(--muted);font-size:14px}
.cmdk .item .i{width:20px;height:20px;display:grid;place-items:center;opacity:.85}
.cmdk .item .i svg{width:18px;height:18px}
.cmdk .item.sel,.cmdk .item:hover{background:rgba(124,92,255,.16);color:#fff}
.cmdk .item .kbd{margin-left:auto;font-family:'JetBrains Mono';font-size:10px;color:var(--faint);border:1px solid var(--line);border-radius:6px;padding:2px 6px}
.cmdk .empty{padding:18px;color:var(--faint);font-size:13.5px;text-align:center}

/* ---------- feedback board ---------- */
.fb-stars{display:inline-flex;gap:3px}
.fb-stars .s{cursor:pointer;font-size:22px;color:#39394d;transition:.12s;line-height:1}
.fb-stars .s.on{color:var(--amber);text-shadow:0 0 10px rgba(245,181,68,.5)}
.fb-stars.ro .s{cursor:default;font-size:14px}
.fb-card{padding:18px 20px;margin-bottom:14px}
.fb-head{display:flex;align-items:center;gap:11px;flex-wrap:wrap}
.fb-ava{width:32px;height:32px;border-radius:9px;background:var(--grad2);display:grid;place-items:center;font-weight:800;color:#04121a;font-family:'Bricolage Grotesque';font-size:14px;flex:none}
.fb-name{font-weight:700;font-size:14px;color:var(--text)}
.fb-date{font-family:'JetBrains Mono';font-size:10.5px;color:var(--faint)}
.fb-type{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.5px;text-transform:uppercase;border:1px solid var(--line);border-radius:20px;padding:3px 9px;color:var(--muted)}
.fb-type.request{color:var(--cyan);border-color:rgba(34,211,238,.35)}
.fb-type.bug{color:var(--rose);border-color:rgba(255,107,139,.35)}
.fb-type.praise{color:var(--lime);border-color:rgba(134,255,107,.35)}
.fb-status{margin-left:auto;font-family:'JetBrains Mono';font-size:10px;letter-spacing:.5px;text-transform:uppercase;padding:3px 10px;border-radius:20px;border:1px solid var(--line);color:var(--faint)}
.fb-status.planned{color:var(--cyan);border-color:rgba(34,211,238,.4)}
.fb-status.done{color:var(--lime);border-color:rgba(134,255,107,.45);box-shadow:0 0 14px rgba(134,255,107,.12)}
.fb-msg{color:var(--text);font-size:14px;line-height:1.55;margin-top:11px}
.fb-reply{margin-top:12px;padding:12px 14px;border-radius:12px;background:rgba(124,92,255,.10);border:1px solid rgba(124,92,255,.3)}
.fb-reply .who{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.5px;color:var(--violet);text-transform:uppercase}
.fb-reply .txt{color:var(--text);font-size:13.5px;line-height:1.5;margin-top:4px}
.fb-userreply{margin-top:10px;padding:10px 14px;border-radius:12px;background:var(--panel2);border:1px solid var(--line)}
.fb-userreply .who{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.5px;color:var(--cyan)}
.fb-userreply .txt{color:var(--muted);font-size:13.5px;line-height:1.5;margin-top:3px}
.fb-del{color:var(--faint);cursor:pointer;font-size:17px;line-height:1;margin-left:4px}
.fb-del:hover{color:var(--rose)}
.fb-replyrow{display:flex;gap:8px;margin-top:10px}
.fb-adminbox{margin-top:12px;padding:12px 14px;border-radius:12px;background:rgba(245,181,68,.07);border:1px dashed rgba(245,181,68,.4)}
.fb-adminbox .lbl{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.5px;color:var(--amber);text-transform:uppercase;margin-bottom:6px}
.fb-adminbox textarea{min-height:60px;resize:vertical}
.fb-adminrow{display:flex;gap:8px;margin-top:8px;align-items:center}
.fb-adminrow .gc-select{width:auto;flex:0 0 auto;padding:9px 12px}
.fb-adminrow .btn{margin-left:auto;padding:9px 16px}
/* ── Achievements (Core Memory) ── */
.ach-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ach-h{font-size:17px;font-weight:700;margin:0}
.ach-count{font-size:12.5px;color:var(--muted);font-weight:600}
.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:12px}
.ach{position:relative;border:1px solid var(--line);border-radius:16px;padding:14px 10px;text-align:center;background:var(--panel2);transition:.18s}
.ach.locked{opacity:.5;filter:grayscale(.7)}
.ach.unlocked{border-color:var(--violet);background:linear-gradient(180deg,rgba(124,92,255,.10),transparent)}
.ach.unlocked.t-gold{border-color:#f4c54a;background:linear-gradient(180deg,rgba(244,197,74,.12),transparent)}
.ach.unlocked.t-silver{border-color:#cdd3df}
.ach-ico{font-size:30px;line-height:1;margin-bottom:7px}
.ach-name{font-size:12.5px;font-weight:700;color:var(--text)}
.ach-desc{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.35}
.ach-bar{height:5px;border-radius:5px;background:var(--line);margin-top:9px;overflow:hidden}
.ach-bar > i{display:block;height:100%;background:var(--violet);border-radius:5px}
.ach-new{position:absolute;top:-6px;right:-6px;background:var(--rose);color:#fff;font-size:9px;font-weight:800;letter-spacing:.4px;padding:3px 6px;border-radius:8px}
/* Activity timeline */
.act{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.act:last-child{border-bottom:none}
.act-dot{flex:none;width:9px;height:9px;border-radius:50%;background:var(--violet)}
.act-body{flex:1;min-width:0}
.act-label{font-size:13.5px;font-weight:600;color:var(--text)}
.act-sub{font-size:11.5px;color:var(--muted);margin-top:1px}
.act-xp{flex:none;font-size:12px;font-weight:700;color:var(--cyan)}
/* ── Team Projects (Astra Team) ── */
.proj{border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:12px;background:var(--panel2)}
.proj-head{display:flex;align-items:flex-start;gap:10px}
.proj-title{font-weight:700;font-size:14.5px;color:var(--text)}
.proj-detail{font-size:12px;color:var(--muted);margin-top:2px}
.proj-pct{flex:none;font-size:12px;font-weight:700;color:var(--cyan)}
.proj-bar{height:6px;border-radius:6px;background:var(--line);margin:10px 0;overflow:hidden}
.proj-bar > i{display:block;height:100%;background:var(--grad);border-radius:6px;transition:width .25s}
.proj-tasks{display:flex;flex-direction:column;gap:2px}
.tt{display:flex;align-items:center;gap:9px;padding:7px 2px;border-bottom:1px solid var(--line)}
.tt:last-child{border-bottom:none}
.tt-check{flex:none;width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line);background:var(--panel);color:#fff;font-size:12px;line-height:1;cursor:pointer;display:grid;place-items:center;font-family:inherit}
.tt.done .tt-check{background:var(--violet);border-color:var(--violet)}
.tt.done .tt-title{text-decoration:line-through;color:var(--muted)}
.tt-title{flex:1;min-width:0;font-size:13.5px;color:var(--text)}
.tt-chip{flex:none;font-size:10.5px;font-weight:600;color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:2px 7px}
.tt-by{flex:none;font-size:10.5px;font-weight:600;color:var(--mint,var(--cyan))}
.proj-add{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
@media (max-width:560px){ .proj-add{flex-direction:column} .proj-add .gc-select{max-width:none!important} }
/* ── Profile dashboard ── */
.pf-card{padding:0;overflow:hidden;margin-top:18px}
.pf-banner{position:relative;height:150px;background:linear-gradient(120deg,var(--violet),var(--cyan));background-size:cover;background-position:center}
.pf-cam{position:absolute;border:1px solid rgba(255,255,255,.25);background:rgba(7,7,13,.55);color:#fff;font-family:inherit;font-size:12px;border-radius:10px;padding:7px 11px;cursor:pointer;backdrop-filter:blur(6px);transition:.15s}
.pf-cam:hover{background:rgba(7,7,13,.8);border-color:#fff}
.pf-cam-banner{right:14px;top:14px}
.pf-head{position:relative;display:flex;align-items:flex-end;justify-content:space-between;padding:0 22px}
.pf-avatar-wrap{position:relative;margin-top:-52px}
.pf-avatar{width:104px;height:104px;border-radius:50%;border:4px solid var(--panel);object-fit:cover;background:var(--ink2);display:block}
.pf-cam-ava{right:-2px;bottom:0;padding:6px 8px;border-radius:50%}
/* ── Image cropper (avatar + banner) ───────────────────────────── */
.crop-scrim{position:fixed;inset:0;background:rgba(7,7,13,.82);backdrop-filter:blur(4px);z-index:200;display:none;align-items:center;justify-content:center;padding:18px}
.crop-scrim.open{display:flex}
.crop-modal{background:var(--panel);border:1px solid var(--line2);border-radius:18px;padding:20px;width:min(460px,94vw);max-height:92vh;overflow:auto;box-shadow:0 24px 70px rgba(0,0,0,.6)}
.crop-modal h3{margin:0 0 4px;font-size:16px;color:var(--text)}
.crop-modal .crop-sub{color:var(--muted);font-size:12.5px;margin-bottom:14px}
.crop-stage{position:relative;overflow:hidden;margin:0 auto;background:#000;touch-action:none;cursor:grab;user-select:none;border:1px solid var(--line2)}
.crop-stage.grabbing{cursor:grabbing}
.crop-stage.round{border-radius:50%}
.crop-stage img{position:absolute;top:0;left:0;will-change:left,top,width;pointer-events:none;-webkit-user-drag:none;max-width:none}
.crop-zoom{display:flex;align-items:center;gap:10px;margin-top:16px;color:var(--muted);font-size:14px}
.crop-zoom input[type=range]{flex:1;accent-color:var(--violet)}
.crop-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
/* ── Teams ─────────────────────────────────────────────────────── */
.team-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border:1px solid var(--line);border-radius:14px;background:var(--panel2);cursor:pointer;margin-bottom:12px;transition:.15s}
.team-card:hover{border-color:var(--violet);transform:translateY(-1px)}
.tc-ico{width:44px;height:44px;border-radius:12px;background:var(--grad);display:grid;place-items:center;font-weight:800;color:#fff;flex:none}
.team-mem{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.team-mem:last-child{border-bottom:none}
.tm-ava{width:34px;height:34px;border-radius:50%;background:var(--panel);background-size:cover;background-position:center;display:grid;place-items:center;font-size:13px;font-weight:700;flex:none}
.lead-badge{font-family:'JetBrains Mono';font-size:9px;letter-spacing:.5px;color:var(--amber);border:1px solid rgba(245,181,68,.4);border-radius:20px;padding:2px 7px;white-space:nowrap}
.mat-item{display:flex;align-items:flex-start;gap:10px;padding:11px 12px;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;background:var(--panel2)}
.mat-item .mi-k{font-size:17px;flex:none;line-height:1.4}
.tchat{height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:6px 4px}
.tmsg{max-width:86%;padding:10px 13px;border-radius:14px;font-size:14px;line-height:1.55;overflow-wrap:anywhere}
.tmsg.user{align-self:flex-end;background:var(--grad);color:#fff;border-bottom-right-radius:4px}
.tmsg.bot{align-self:flex-start;background:var(--panel2);border:1px solid var(--line);border-bottom-left-radius:4px}
.tmsg.bot p{margin:0 0 6px}.tmsg.bot p:last-child{margin:0}
.tmsg .who{font-size:10px;opacity:.8;margin-bottom:3px;font-family:'JetBrains Mono';letter-spacing:.4px}
/* ── Arcade ────────────────────────────────────────────────────── */
.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;margin-top:24px}
.game-card{border:1px solid var(--line);border-radius:16px;padding:18px;background:var(--panel2);cursor:pointer;transition:.15s;display:flex;flex-direction:column;gap:8px}
.game-card:hover{border-color:var(--violet);transform:translateY(-2px);box-shadow:0 12px 30px rgba(124,92,255,.18)}
.game-card .gc-emoji{font-size:30px}
.game-card .gc-name{font-weight:700;font-size:15.5px}
.game-card .gc-desc{font-size:12.5px;color:var(--muted);line-height:1.45;flex:1}
.game-card .gc-skill{font-family:'JetBrains Mono';font-size:9.5px;letter-spacing:.5px;color:var(--cyan);text-transform:uppercase}
.gm-scrim{position:fixed;inset:0;background:rgba(7,7,13,.85);backdrop-filter:blur(5px);z-index:210;display:none;align-items:center;justify-content:center;padding:18px}
.gm-scrim.open{display:flex}
.gm-modal{background:var(--panel);border:1px solid var(--line2);border-radius:20px;padding:20px;width:min(560px,96vw);max-height:94vh;overflow:auto;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.gm-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.gm-head .gm-title{font-weight:800;font-size:18px;flex:1}
.gm-close{background:var(--panel2);border:1px solid var(--line2);color:var(--text);border-radius:10px;width:34px;height:34px;cursor:pointer;font-size:20px;line-height:1}
.gm-hud{display:flex;gap:16px;font-family:'JetBrains Mono';font-size:13px;margin-bottom:6px;color:var(--muted)}
.gm-hud b{color:var(--lime)}
.sm-prob{font-size:34px;font-weight:800;text-align:center;margin:18px 0}
.sm-input{width:100%;font-size:22px;text-align:center;padding:12px;border-radius:12px;background:var(--ink2);border:1px solid var(--line2);color:var(--text);outline:none}
.sm-input.bad{border-color:var(--rose);animation:gshake .3s}
@keyframes gshake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
.mm-grid{display:grid;gap:8px;margin:18px auto;justify-content:center}
.mm-cell{width:60px;height:60px;border-radius:12px;background:var(--panel2);border:1px solid var(--line2);cursor:pointer;transition:.12s}
.mm-cell.lit{background:var(--grad);border-color:transparent}
.mm-cell.good{background:var(--lime);border-color:transparent}
.mm-cell.bad{background:var(--rose);border-color:transparent}
.ty-target{font-size:16px;line-height:1.8;background:var(--ink2);border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:12px;font-family:'JetBrains Mono'}
.ty-target .done{color:var(--lime)}.ty-target .wrong{color:#fff;background:var(--rose);border-radius:3px}
.ty-input{width:100%;min-height:84px;font-size:15px;padding:12px;border-radius:12px;background:var(--ink2);border:1px solid var(--line2);color:var(--text);outline:none;resize:none;font-family:'JetBrains Mono'}
.gm-result{text-align:center;padding:10px}
.gm-result .big{font-size:42px;font-weight:800;color:var(--lime)}
.gm-btn-row{display:flex;gap:10px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.chess-frame{width:100%;height:460px;border:0;border-radius:12px;background:var(--ink2);display:block}
/* ── Your Spark (interactive) ──────────────────────────────────── */
.spark-preview{padding:20px;margin-top:20px}
.sp-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.sp-orb{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:var(--grad);color:#fff;font-size:18px;flex:none;box-shadow:0 0 18px rgba(124,92,255,.4)}
.sp-sub{font-size:12px;color:var(--muted)}
.sp-body{font-size:15px;line-height:1.6;color:var(--text);background:var(--ink2);border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.sp-body.flash{animation:spFlash .6s ease}
@keyframes spFlash{0%{box-shadow:0 0 0 0 rgba(124,92,255,.45)}100%{box-shadow:0 0 0 16px rgba(124,92,255,0)}}
.sp-meta{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.5px;color:var(--faint);margin-top:10px;text-transform:uppercase}
/* appearance / theme segmented control */
.theme-seg{display:inline-flex;gap:4px;padding:4px;border:1px solid var(--line);border-radius:14px;background:var(--panel2)}
.theme-opt{display:flex;align-items:center;gap:7px;font-family:inherit;font-size:13.5px;font-weight:600;color:var(--muted);background:none;border:none;padding:9px 16px;border-radius:10px;cursor:pointer;transition:.15s}
.theme-opt:hover{color:var(--text)}
.theme-opt.on{color:#fff;background:var(--grad);box-shadow:0 6px 18px rgba(124,92,255,.3)}
.theme-opt svg{width:16px;height:16px}
@media(max-width:560px){.theme-seg{display:flex;width:100%}.theme-opt{flex:1;justify-content:center;padding:11px 8px}}
.spark-block{margin-top:22px}
.spark-h{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;font-family:'JetBrains Mono';font-size:12px;letter-spacing:.5px;color:var(--muted);text-transform:uppercase;margin-bottom:12px}
.spark-hint{text-transform:none;color:var(--faint);font-size:11px}
.linklike{background:none;border:none;color:var(--cyan);cursor:pointer;font-family:inherit;font-size:12px;padding:0}
.linklike:hover{text-decoration:underline}
.chip-row{display:flex;flex-wrap:wrap;gap:8px}
.goal-chip{font-size:13px;color:#cbd5e1;border:1px solid var(--line2);background:var(--panel2);padding:9px 14px;border-radius:30px;cursor:pointer;transition:.15s;font-family:inherit}
.goal-chip:hover{border-color:var(--violet)}
.goal-chip.on{background:rgba(124,92,255,.18);border-color:var(--violet);color:#fff}
.arch-quote{font-size:12px;color:var(--cyan);margin-top:10px;font-style:italic;line-height:1.45}
.sm2-scrim{position:fixed;inset:0;background:rgba(7,7,13,.85);backdrop-filter:blur(5px);z-index:210;display:none;align-items:center;justify-content:center;padding:18px}
.sm2-scrim.open{display:flex}
.sm2-modal{background:var(--panel);border:1px solid var(--line2);border-radius:20px;padding:22px;width:min(480px,96vw);max-height:92vh;overflow:auto;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.sm2-prog{font-family:'JetBrains Mono';font-size:11px;color:var(--faint);margin-bottom:12px}
.sm2-q{display:flex;gap:10px;margin-bottom:6px}
.sm2-q .av{flex:none;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--grad);color:#fff}
.sm2-q .bd{background:var(--panel2);border:1px solid var(--line);border-radius:14px;border-top-left-radius:4px;padding:11px 14px;color:var(--text);font-size:14.5px;line-height:1.5}
.sm2-opt{display:block;width:100%;text-align:left;padding:11px 14px;border:1px solid var(--line2);border-radius:12px;background:var(--panel2);color:#e5e7eb;margin-top:8px;cursor:pointer;transition:.15s;font-size:14px;font-family:inherit}
.sm2-opt:hover{border-color:var(--violet);transform:translateX(3px)}
/* ── Calendar ──────────────────────────────────────────────────── */
.cal-wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;margin-top:22px;align-items:start}
@media(max-width:820px){.cal-wrap{grid-template-columns:1fr}}
.cal-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.cal-title{font-weight:700;font-size:16px;color:var(--text);min-width:150px}
.cal-nav{width:32px;height:32px;border-radius:9px;border:1px solid var(--line2);background:var(--panel2);color:var(--text);cursor:pointer;font-size:18px;line-height:1}
.cal-nav:hover{border-color:var(--violet)}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal-dow span{text-align:center;font-family:'JetBrains Mono';font-size:10px;letter-spacing:.5px;color:var(--faint)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-cell{aspect-ratio:1;border:1px solid var(--line);border-radius:10px;background:var(--panel2);cursor:pointer;padding:6px;display:flex;flex-direction:column;gap:3px;transition:.12s;position:relative;overflow:hidden}
.cal-cell:hover{border-color:var(--violet)}
.cal-cell.blank{background:transparent;border:none;cursor:default}
.cal-cell.today{border-color:var(--cyan)}
.cal-cell.sel{border-color:var(--violet);background:rgba(124,92,255,.14)}
.cal-cell .dnum{font-size:12.5px;color:var(--muted);font-weight:600}
.cal-cell.today .dnum{color:var(--cyan)}
.cal-dots{display:flex;gap:3px;flex-wrap:wrap;margin-top:auto}
.dot{width:6px;height:6px;border-radius:50%;display:inline-block}
.dot.task{background:var(--cyan)}.dot.ev{background:var(--violet)}.dot.goal{background:var(--amber)}
.cal-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:14px;font-size:11.5px;color:var(--muted)}
.cal-legend i{margin-right:5px;vertical-align:middle}
.cal-day-h{font-weight:700;font-size:15px;color:var(--text)}
.cal-ev{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:var(--panel2);margin-bottom:8px}
.cal-ev.done .cal-ev-t{text-decoration:line-through;color:var(--faint)}
.cal-ev-box{width:18px;height:18px;border-radius:6px;border:1.5px solid var(--faint);flex:none;display:grid;place-items:center;font-size:12px;color:transparent;cursor:pointer}
.cal-ev.done .cal-ev-box{background:var(--lime);border-color:var(--lime);color:#053}
.cal-ev-t{flex:1;font-size:13.5px;color:var(--text)}
.cal-ev-time{font-size:11px;color:var(--faint);font-family:'JetBrains Mono'}
.cal-gcal{color:var(--cyan);font-size:11px;text-decoration:none;border:1px solid var(--line2);border-radius:8px;padding:3px 7px;white-space:nowrap}
.cal-gcal:hover{border-color:var(--cyan)}
.cal-task{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);padding:5px 0}
.cal-x{color:var(--faint);cursor:pointer;font-size:14px;padding:0 4px}.cal-x:hover{color:var(--rose)}
.pf-xp{font-family:'JetBrains Mono';font-size:13px;font-weight:700;color:var(--lime);background:rgba(134,255,107,.1);border:1px solid rgba(134,255,107,.35);border-radius:999px;padding:7px 14px;margin-bottom:8px}
.pf-form{padding:18px 22px 24px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pf-toggle{display:flex;align-items:center;gap:10px;margin-top:18px;font-size:14px;color:var(--text);cursor:pointer;user-select:none}
.pf-toggle input{width:18px;height:18px;accent-color:var(--violet);cursor:pointer}
.pf-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.pf-actions .btn svg{width:16px;height:16px}
.pf-account{margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
.pf-acc-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.pf-acc-label{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.6px;text-transform:uppercase;color:var(--faint)}
.pf-acc-val{font-size:14.5px;color:var(--text);margin-top:3px;word-break:break-all}
.pf-account .btn{margin-left:auto}.pf-account .btn svg{width:16px;height:16px}
/* ── Leaderboard ── */
.lb-me{margin-top:16px;display:flex;align-items:center;gap:14px;padding:16px 18px;border:1px solid rgba(124,92,255,.4);background:rgba(124,92,255,.08)}
.lb-row{display:flex;align-items:center;gap:14px;padding:13px 16px;border:1px solid var(--line);border-radius:14px;background:var(--panel);margin-bottom:10px;transition:.15s}
.lb-row:hover{border-color:var(--line2);transform:translateX(2px)}
.lb-row.me{border-color:var(--violet);box-shadow:0 0 0 1px rgba(124,92,255,.35)}
.lb-rank{font-family:'JetBrains Mono';font-weight:700;font-size:15px;width:34px;text-align:center;color:var(--muted)}
.lb-rank.top{color:var(--amber)}
.lb-ava{width:42px;height:42px;border-radius:50%;object-fit:cover;background:var(--ink2);border:1px solid var(--line2);flex:none}
.lb-name{font-weight:600;font-size:14.5px}
.lb-name a{color:inherit;text-decoration:none}.lb-name a:hover{color:var(--cyan)}
.lb-arch{font-size:11px;color:var(--faint);font-family:'JetBrains Mono';text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.lb-xp{margin-left:auto;font-family:'JetBrains Mono';font-weight:700;font-size:15px;color:var(--lime)}
@media(max-width:560px){.grid2{grid-template-columns:1fr}}

