/* team.css — /team workspace shell layout (skeleton).
   Reuses design tokens from theme.css + components (.panel/.btn/.empty-state).
   Only the workspace chrome (sidebar + content frame) lives here. */
.tw { display: grid; grid-template-columns: 244px 1fr; min-height: 100dvh; }

/* ── Sidebar ── */
.tw-side {
  border-right: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(18,18,31,.7), rgba(10,10,18,.55));
  backdrop-filter: blur(8px);
  display: flex; flex-direction: column; padding: 20px 14px; gap: 4px;
}
:root[data-theme="light"] .tw-side { background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(244,246,251,.72)); }
.tw-brand { display: flex; align-items: center; gap: 11px; padding: 4px 8px 18px; }
.tw-brand img { width: 32px; height: 32px; border-radius: 9px; }
.tw-brand b { font-family: 'Bricolage Grotesque', sans-serif; font-size: 15px; font-weight: 800; letter-spacing: -.3px; display: block; }
.tw-brand span { display: block; font-family: 'JetBrains Mono', monospace; font-size: 9.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--faint); margin-top: 2px; }
.tw-nav { display: flex; flex-direction: column; gap: 3px; }
.tw-nav a {
  display: flex; align-items: center; gap: 11px; padding: 11px 12px; border-radius: 11px;
  color: var(--muted); text-decoration: none; font-size: 14.5px; font-weight: 500; transition: .15s; cursor: pointer;
}
.tw-nav a .i { width: 20px; text-align: center; font-size: 15px; }
.tw-nav a:hover { background: rgba(124,92,255,.06); color: var(--text); }
.tw-nav a.on { color: #fff; background: linear-gradient(90deg, rgba(124,92,255,.22), rgba(34,211,238,.06)); box-shadow: inset 0 0 0 1px var(--line2); }
.tw-side-foot { margin-top: auto; padding-top: 12px; border-top: 1px solid var(--line); }
.tw-back { display: flex; align-items: center; gap: 8px; color: var(--faint); text-decoration: none; font-size: 13px; padding: 9px 12px; border-radius: 10px; }
.tw-back:hover { color: var(--text); background: rgba(255,255,255,.04); }

/* ── Content frame ── */
.tw-main { overflow-y: auto; height: 100dvh; padding: 30px 34px 60px; max-width: 1100px; }
.tw-top { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.tw-top h1 { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 26px; letter-spacing: -.5px; }
.tw-section { display: none; }
.tw-section.on { display: block; animation: rise .45s cubic-bezier(.2,.7,.2,1); }

/* Placeholder card (skeleton — features migrate here later) */
.tw-ph { padding: 40px 30px; text-align: center; }
.tw-ph .emo { font-size: 34px; }
.tw-ph h3 { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 19px; margin-top: 12px; }
.tw-ph p { color: var(--muted); font-size: 14px; margin-top: 8px; max-width: 460px; margin-inline: auto; line-height: 1.55; }
.tw-ph .tag { display: inline-block; margin-top: 16px; font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: .5px; color: var(--faint); border: 1px solid var(--line); border-radius: 20px; padding: 5px 12px; }

/* ── Overview (workspace home) ── */
.tw-ov-head { margin-bottom: 22px; }
.tw-ov-head h2 { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 28px; letter-spacing: -.6px; }
.tw-ov-meta { display: block; margin-top: 5px; color: var(--muted); font-size: 13.5px; }
.tw-ov-doors { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 22px; }
.tw-door {
  text-align: left; cursor: pointer; color: var(--text); font: inherit;
  border: 1px solid var(--line); border-radius: 16px; padding: 20px 20px 22px;
  background: linear-gradient(160deg, rgba(124,92,255,.08), rgba(34,211,238,.03));
  display: flex; flex-direction: column; gap: 6px; transition: .16s;
}
.tw-door:hover { border-color: var(--line2); transform: translateY(-2px); box-shadow: 0 12px 30px -18px rgba(124,92,255,.6); }
.tw-door-i { font-size: 26px; }
.tw-door b { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 17px; }
.tw-door .d { color: var(--muted); font-size: 13px; line-height: 1.5; }
.tw-ov-members { padding: 16px 18px; }
.tw-ov-members-h { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.tw-ov-members-h b { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 15px; }
.tw-ov-members-h span { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--faint); }
.tw-ov-member-list { display: flex; flex-wrap: wrap; gap: 10px; }
.tw-ov-member { display: flex; align-items: center; gap: 8px; background: rgba(255,255,255,.04); border: 1px solid var(--line); border-radius: 30px; padding: 5px 12px 5px 5px; }
.tw-ov-member .av { width: 26px; height: 26px; border-radius: 50%; overflow: hidden; display: grid; place-items: center; background: linear-gradient(135deg, #7c5cff, #22d3ee); flex: 0 0 auto; }
.tw-ov-member .av img { width: 100%; height: 100%; object-fit: cover; }
.tw-ov-member .av .ini { color: #fff; font-weight: 700; font-size: 12px; }
.tw-ov-member .nm { font-size: 13.5px; }
.tw-ov-member .lead { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: .5px; color: var(--brand, #9d8cff); border: 1px solid var(--line2); border-radius: 20px; padding: 2px 6px; }

/* ── Team Room (human-first chat) ── */
.tw-room { display: flex; flex-direction: column; height: calc(100dvh - 140px); min-height: 340px; }
.tw-room-log {
  flex: 1 1 auto; overflow-y: auto; display: flex; flex-direction: column; gap: 9px;
  padding: 4px 2px 14px;
}
.tw-room-log .skel-row { height: 46px; border-radius: 14px; }
.tw-room-empty { margin: auto; text-align: center; color: var(--muted); max-width: 360px; }
.tw-room-empty .emo { font-size: 30px; }
.tw-room-empty .d { margin-top: 8px; font-size: 14px; line-height: 1.55; }
.tw-rmsg { max-width: 76%; align-self: flex-start; padding: 9px 13px; border-radius: 14px;
  background: rgba(255,255,255,.045); border: 1px solid var(--line); }
.tw-rmsg .who { font-size: 11px; font-weight: 600; color: var(--faint); margin-bottom: 3px; }
.tw-rmsg .txt { font-size: 14px; line-height: 1.5; white-space: pre-wrap; word-break: break-word; }
.tw-rmsg .at { font-size: 10px; color: var(--faint); margin-top: 4px; opacity: .7; }
.tw-rmsg.me { align-self: flex-end; background: linear-gradient(90deg, rgba(124,92,255,.22), rgba(34,211,238,.08)); border-color: var(--line2); }
.tw-rmsg.me .who { color: var(--text); }
.tw-room-form { display: flex; gap: 8px; padding-top: 11px; border-top: 1px solid var(--line); }
.tw-room-input {
  flex: 1; background: rgba(255,255,255,.04); border: 1px solid var(--line); color: var(--text);
  border-radius: 12px; padding: 12px 14px; font: inherit; font-size: 14px; outline: none;
}
.tw-room-input:focus { border-color: var(--line2); }
.tw-room-send {
  flex: 0 0 auto; width: 46px; border: none; border-radius: 12px; color: #fff; cursor: pointer;
  background: linear-gradient(90deg, var(--brand, #7c5cff), #22d3ee); display: grid; place-items: center;
}
.tw-room-send:disabled { opacity: .5; cursor: default; }

/* ── Team Astra (explicitly-invoked study assistant · Personal mode) ── */
.tw-astra { display: flex; flex-direction: column; height: calc(100dvh - 140px); min-height: 360px; }
.tw-astra-note {
  font-size: 12.5px; color: var(--muted); background: rgba(124,92,255,.07);
  border: 1px solid var(--line); border-radius: 11px; padding: 9px 13px; margin-bottom: 12px;
}
.tw-astra-note b { color: var(--text); font-weight: 700; }
.tw-astra-log { flex: 1 1 auto; overflow-y: auto; display: flex; flex-direction: column; gap: 12px; padding: 2px 2px 14px; }
.tw-astra-empty { margin: auto; text-align: center; color: var(--muted); max-width: 400px; }
.tw-astra-empty .emo { font-size: 32px; }
.tw-astra-empty .d { margin-top: 8px; font-size: 14px; line-height: 1.55; }
.tw-amsg { max-width: 84%; padding: 11px 14px; border-radius: 14px; }
.tw-amsg.q { align-self: flex-end; background: linear-gradient(90deg, rgba(124,92,255,.22), rgba(34,211,238,.08)); border: 1px solid var(--line2); }
.tw-amsg.a { align-self: flex-start; background: rgba(255,255,255,.045); border: 1px solid var(--line); }
.tw-amsg .who { font-size: 11px; font-weight: 700; color: var(--brand, #9d8cff); margin-bottom: 5px; }
.tw-amsg .txt { font-size: 14px; line-height: 1.6; word-break: break-word; }
.tw-amsg .txt p { margin: 0 0 8px; } .tw-amsg .txt p:last-child { margin-bottom: 0; }
.tw-amsg .txt ul, .tw-amsg .txt ol { margin: 4px 0 8px; padding-left: 20px; }
.tw-amsg .txt li { margin: 3px 0; }
.tw-amsg .txt code { background: rgba(255,255,255,.08); padding: 1px 5px; border-radius: 5px; font-family: 'JetBrains Mono', monospace; font-size: 12.5px; }
.tw-amsg.thinking .txt { color: var(--faint); }
.tw-amsg-actions { margin-top: 9px; }
.tw-share-btn {
  border: 1px solid var(--line2); background: rgba(124,92,255,.08); color: var(--text);
  font: inherit; font-size: 12px; font-weight: 600; padding: 5px 11px; border-radius: 9px; cursor: pointer;
}
.tw-share-btn:hover { background: rgba(124,92,255,.16); }
.tw-share-btn.shared { color: var(--faint); background: transparent; border-color: var(--line); cursor: default; }
.tw-astra-form { display: flex; gap: 8px; align-items: flex-end; padding-top: 11px; border-top: 1px solid var(--line); }
.tw-astra-input {
  flex: 1; background: rgba(255,255,255,.04); border: 1px solid var(--line); color: var(--text);
  border-radius: 12px; padding: 12px 14px; font: inherit; font-size: 14px; outline: none;
  resize: none; max-height: 140px; line-height: 1.45;
}
.tw-astra-input:focus { border-color: var(--line2); }
.tw-astra-send {
  flex: 0 0 auto; border: none; border-radius: 12px; color: #fff; cursor: pointer; font-weight: 700;
  font-size: 14px; padding: 12px 20px; background: linear-gradient(90deg, var(--brand, #7c5cff), #22d3ee);
}
.tw-astra-send:disabled { opacity: .55; cursor: default; }

/* ── Team Astra (Global / shared chat) ── */
.tw-tc { display: flex; flex-direction: column; height: calc(100dvh - 140px); min-height: 360px; }
.tw-tc-note {
  font-size: 12.5px; color: var(--muted); background: rgba(124,92,255,.07);
  border: 1px solid var(--line); border-radius: 11px; padding: 9px 13px; margin-bottom: 12px;
}
.tw-tc-note b { color: var(--text); font-weight: 700; }
.tw-tc-log { flex: 1 1 auto; overflow-y: auto; display: flex; flex-direction: column; gap: 11px; padding: 2px 2px 14px; }
.tw-tc-log .skel-row { height: 46px; border-radius: 14px; }
.tw-tc-empty { margin: auto; text-align: center; color: var(--muted); max-width: 420px; }
.tw-tc-empty .emo { font-size: 32px; }
.tw-tc-empty .d { margin-top: 8px; font-size: 14px; line-height: 1.55; }
.tw-tmsg { max-width: 84%; padding: 10px 14px; border-radius: 14px; }
.tw-tmsg.u { align-self: flex-end; background: linear-gradient(90deg, rgba(124,92,255,.22), rgba(34,211,238,.08)); border: 1px solid var(--line2); }
.tw-tmsg.u:not(.me) { align-self: flex-start; background: rgba(255,255,255,.045); border-color: var(--line); }
.tw-tmsg.a { align-self: flex-start; background: rgba(255,255,255,.045); border: 1px solid var(--line); }
.tw-tmsg .who { font-size: 11px; font-weight: 700; color: var(--faint); margin-bottom: 4px; }
.tw-tmsg.u.me .who { color: var(--text); }
.tw-tmsg.a .who { color: var(--brand, #9d8cff); }
.tw-tmsg .txt { font-size: 14px; line-height: 1.6; word-break: break-word; }
.tw-tmsg.u .txt { white-space: pre-wrap; }
.tw-tmsg.a .txt p { margin: 0 0 8px; } .tw-tmsg.a .txt p:last-child { margin-bottom: 0; }
.tw-tmsg.a .txt ul, .tw-tmsg.a .txt ol { margin: 4px 0 8px; padding-left: 20px; }
.tw-tmsg.a .txt li { margin: 3px 0; }
.tw-tmsg.a .txt code { background: rgba(255,255,255,.08); padding: 1px 5px; border-radius: 5px; font-family: 'JetBrains Mono', monospace; font-size: 12.5px; }
.tw-tmsg.thinking .txt { color: var(--faint); }
.tw-tc-form { display: flex; gap: 8px; align-items: flex-end; padding-top: 11px; border-top: 1px solid var(--line); }
.tw-tc-input {
  flex: 1; background: rgba(255,255,255,.04); border: 1px solid var(--line); color: var(--text);
  border-radius: 12px; padding: 12px 14px; font: inherit; font-size: 14px; outline: none;
  resize: none; max-height: 140px; line-height: 1.45;
}
.tw-tc-input:focus { border-color: var(--line2); }
.tw-tc-send {
  flex: 0 0 auto; border: none; border-radius: 12px; color: #fff; cursor: pointer; font-weight: 700;
  font-size: 14px; padding: 12px 20px; background: linear-gradient(90deg, var(--brand, #7c5cff), #22d3ee);
}
.tw-tc-send:disabled { opacity: .55; cursor: default; }

/* ── Materials (shared shelf + per-note "Let Astra see it") ── */
.tw-mat { display: flex; flex-direction: column; gap: 16px; }
.tw-mat-add { display: flex; flex-direction: column; gap: 8px; padding: 14px; border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,.025); }
.tw-mat-title, .tw-mat-body {
  background: rgba(255,255,255,.04); border: 1px solid var(--line); color: var(--text);
  border-radius: 11px; padding: 11px 13px; font: inherit; font-size: 14px; outline: none;
}
.tw-mat-title:focus, .tw-mat-body:focus { border-color: var(--line2); }
.tw-mat-body { resize: vertical; min-height: 64px; line-height: 1.5; }
.tw-mat-save {
  align-self: flex-start; border: none; border-radius: 11px; color: #fff; cursor: pointer; font-weight: 700;
  font-size: 13.5px; padding: 10px 18px; background: linear-gradient(90deg, var(--brand, #7c5cff), #22d3ee);
}
.tw-mat-save:disabled { opacity: .55; cursor: default; }
.tw-mat-list { display: flex; flex-direction: column; gap: 10px; }
.tw-mat-list .skel-row { height: 70px; border-radius: 14px; }
.tw-mat-empty { text-align: center; color: var(--muted); padding: 28px 12px; }
.tw-mat-empty .emo { font-size: 30px; }
.tw-mat-empty .d { margin-top: 8px; font-size: 14px; line-height: 1.55; max-width: 380px; margin-inline: auto; }
.tw-mat-item { border: 1px solid var(--line); border-radius: 14px; padding: 13px 15px; background: rgba(255,255,255,.03); }
.tw-mat-item.seen { border-color: var(--line2); background: rgba(124,92,255,.06); }
.tw-mat-head { display: flex; align-items: center; gap: 10px; }
.tw-mat-name { flex: 1; font-size: 14.5px; color: var(--text); word-break: break-word; }
.tw-mat-del { flex: 0 0 auto; border: none; background: transparent; color: var(--faint); cursor: pointer; font-size: 14px; padding: 2px 6px; border-radius: 8px; }
.tw-mat-del:hover { color: #ff6b6b; background: rgba(255,107,107,.1); }
.tw-mat-note { margin: 7px 0 0; font-size: 13.5px; line-height: 1.55; color: var(--muted); white-space: pre-wrap; word-break: break-word; }
.tw-mat-link { display: inline-block; margin-top: 6px; font-size: 13px; color: var(--brand, #9d8cff); word-break: break-all; }
.tw-mat-toggle { display: inline-flex; align-items: center; gap: 8px; margin-top: 11px; cursor: pointer; font-size: 12.5px; color: var(--muted); user-select: none; }
.tw-mat-toggle input { width: 15px; height: 15px; accent-color: var(--brand, #7c5cff); cursor: pointer; }
.tw-mat-item.seen .tw-mat-toggle span { color: var(--brand, #9d8cff); font-weight: 600; }

/* ── Generic empty state (used by Tasks / Members / Leaderboard / Settings) ── */
.tw-empty-state { text-align: center; padding: 40px 12px; color: var(--muted); }
.tw-empty-state .emo { font-size: 32px; }
.tw-empty-state .d { margin-top: 8px; font-size: 14px; line-height: 1.55; max-width: 380px; margin-inline: auto; }

/* ── Tasks (Projects + Tasks) ── */
.tw-tasks { display: flex; flex-direction: column; gap: 16px; }
.tw-tasks-head { display: flex; justify-content: flex-end; }
.tw-proj-new-btn {
  border: 1px dashed var(--line2); background: rgba(124,92,255,.06); color: var(--text);
  font: inherit; font-size: 13.5px; font-weight: 600; padding: 9px 18px; border-radius: 11px; cursor: pointer;
}
.tw-proj-new-btn:hover { background: rgba(124,92,255,.14); }
.tw-proj-form {
  border: 1px solid var(--line); border-radius: 14px; padding: 16px;
  background: rgba(255,255,255,.025); display: flex; flex-direction: column; gap: 8px;
}
.tw-proj-title, .tw-proj-detail {
  background: rgba(255,255,255,.04); border: 1px solid var(--line); color: var(--text);
  border-radius: 11px; padding: 11px 13px; font: inherit; font-size: 14px; outline: none;
}
.tw-proj-title:focus, .tw-proj-detail:focus { border-color: var(--line2); }
.tw-proj-detail { resize: vertical; min-height: 48px; line-height: 1.5; }
.tw-proj-form-btns { display: flex; gap: 8px; }
.tw-proj-save {
  border: none; border-radius: 10px; color: #fff; cursor: pointer; font-weight: 700;
  font-size: 13.5px; padding: 10px 20px; background: linear-gradient(90deg, var(--brand, #7c5cff), #22d3ee);
}
.tw-proj-save:disabled { opacity: .55; cursor: default; }
.tw-proj-cancel {
  border: 1px solid var(--line); background: transparent; color: var(--muted);
  font: inherit; font-size: 13.5px; padding: 10px 16px; border-radius: 10px; cursor: pointer;
}
.tw-proj-cancel:hover { color: var(--text); }
.tw-proj-list { display: flex; flex-direction: column; gap: 14px; }
.tw-proj-list .skel-row { height: 100px; border-radius: 14px; }
.tw-proj-empty { text-align: center; padding: 40px 12px; color: var(--muted); }
.tw-proj-empty .emo { font-size: 32px; }
.tw-proj-empty .d { margin-top: 8px; font-size: 14px; line-height: 1.55; max-width: 380px; margin-inline: auto; }
.tw-proj {
  border: 1px solid var(--line); border-radius: 16px; padding: 18px 18px 14px;
  background: rgba(255,255,255,.03);
}
.tw-proj-head { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; }
.tw-proj-name { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 16px; flex: 1; }
.tw-proj-stats { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--faint); flex: 0 0 auto; }
.tw-proj-desc { font-size: 13px; color: var(--muted); margin-bottom: 8px; line-height: 1.5; }
.tw-proj-bar { height: 4px; border-radius: 999px; background: var(--ring-track, #1e1e30); margin-bottom: 14px; overflow: hidden; }
.tw-proj-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--violet), var(--cyan)); transition: width .3s ease; }
.tw-task-list { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; }
.tw-task-empty { font-size: 13px; color: var(--faint); padding: 6px 2px; }
.tw-task-item {
  display: flex; align-items: center; gap: 9px; padding: 8px 10px;
  border-radius: 10px; background: rgba(255,255,255,.025); border: 1px solid transparent;
  transition: opacity .2s;
}
.tw-task-item:hover { border-color: var(--line); }
.tw-task-item.done { opacity: .6; }
.tw-task-check { display: flex; flex: 0 0 auto; }
.tw-task-check input { width: 16px; height: 16px; accent-color: var(--brand, #7c5cff); cursor: pointer; }
.tw-task-title { flex: 1; font-size: 13.5px; line-height: 1.45; word-break: break-word; }
.tw-task-item.done .tw-task-title { text-decoration: line-through; color: var(--faint); }
.tw-task-who {
  flex: 0 0 auto; font-size: 11px; color: var(--faint);
  background: rgba(255,255,255,.06); border-radius: 20px; padding: 2px 8px;
}
.tw-task-del {
  flex: 0 0 auto; border: none; background: transparent; color: var(--faint);
  cursor: pointer; font-size: 13px; padding: 2px 6px; border-radius: 8px; opacity: 0; transition: opacity .15s;
}
.tw-task-item:hover .tw-task-del { opacity: 1; }
.tw-task-del:hover { color: #ff6b6b; background: rgba(255,107,107,.1); }
.tw-task-form { display: flex; gap: 7px; margin-top: 4px; }
.tw-task-inp {
  flex: 1; background: rgba(255,255,255,.03); border: 1px dashed var(--line); color: var(--text);
  border-radius: 10px; padding: 9px 12px; font: inherit; font-size: 13px; outline: none;
}
.tw-task-inp:focus { border-color: var(--violet); border-style: solid; background: rgba(255,255,255,.04); }
.tw-task-add {
  flex: 0 0 auto; border: 1px solid var(--line); background: rgba(124,92,255,.08); color: var(--text);
  font: inherit; font-size: 13px; font-weight: 600; padding: 9px 14px; border-radius: 10px; cursor: pointer;
}
.tw-task-add:hover { background: rgba(124,92,255,.16); }

/* ── Members ── */
.tw-members { display: flex; flex-direction: column; gap: 18px; }
.tw-mem-list { display: flex; flex-direction: column; gap: 9px; }
.tw-mem-list .skel-row { height: 66px; border-radius: 14px; }
.tw-mem-card {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  border: 1px solid var(--line); border-radius: 14px; padding: 12px 16px;
  background: rgba(255,255,255,.03);
}
.tw-mem-card .av {
  width: 40px; height: 40px; border-radius: 50%; overflow: hidden; display: grid; place-items: center;
  background: linear-gradient(135deg, #7c5cff, #22d3ee); flex: 0 0 auto;
}
.tw-mem-card .av img { width: 100%; height: 100%; object-fit: cover; }
.tw-mem-card .av .ini { color: #fff; font-weight: 700; font-size: 16px; }
.tw-mem-info { flex: 1; min-width: 0; }
.tw-mem-name { display: block; font-size: 14.5px; font-weight: 700; }
.tw-mem-user { display: block; font-size: 12px; color: var(--faint); margin-top: 2px; }
.tw-mem-tags { display: flex; align-items: center; gap: 7px; flex: 0 0 auto; }
.tw-mem-role {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: .4px;
  color: var(--faint); border: 1px solid var(--line); border-radius: 20px; padding: 3px 8px;
}
.tw-mem-role.lead { color: var(--brand, #9d8cff); border-color: var(--line2); }
.tw-mem-me {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--cyan);
  border: 1px solid rgba(34,211,238,.3); border-radius: 20px; padding: 3px 8px;
}
.tw-mem-actions { display: flex; gap: 7px; flex: 0 0 auto; }
.tw-mem-transfer, .tw-mem-remove {
  border: 1px solid var(--line); background: transparent; color: var(--muted);
  font: inherit; font-size: 12px; padding: 5px 11px; border-radius: 9px; cursor: pointer;
}
.tw-mem-transfer:hover { color: var(--brand, #9d8cff); border-color: var(--brand, #9d8cff); }
.tw-mem-remove:hover { color: #ff6b6b; border-color: rgba(255,107,107,.5); background: rgba(255,107,107,.06); }
.tw-mem-foot { padding-top: 4px; }
.tw-leave-btn {
  border: 1px solid rgba(255,107,107,.3); background: rgba(255,107,107,.05); color: #ff8a8a;
  font: inherit; font-size: 14px; font-weight: 600; padding: 11px 22px; border-radius: 12px; cursor: pointer;
}
.tw-leave-btn:hover { background: rgba(255,107,107,.12); }

/* ── Leaderboard ── */
.tw-lb { display: flex; flex-direction: column; gap: 10px; }
.tw-lb-list { display: flex; flex-direction: column; gap: 8px; }
.tw-lb-list .skel-row { height: 62px; border-radius: 14px; }
.tw-lb-row {
  display: flex; align-items: center; gap: 13px;
  border: 1px solid var(--line); border-radius: 14px; padding: 12px 16px;
  background: rgba(255,255,255,.03);
}
.tw-lb-row.me { border-color: var(--line2); background: rgba(124,92,255,.07); }
.tw-lb-rank { width: 28px; text-align: center; font-size: 20px; flex: 0 0 auto; }
.tw-lb-row .av {
  width: 36px; height: 36px; border-radius: 50%; overflow: hidden; display: grid; place-items: center;
  background: linear-gradient(135deg, #7c5cff, #22d3ee); flex: 0 0 auto;
}
.tw-lb-row .av img { width: 100%; height: 100%; object-fit: cover; }
.tw-lb-row .av .ini { color: #fff; font-weight: 700; font-size: 14px; }
.tw-lb-info { flex: 1; min-width: 0; }
.tw-lb-info b { display: block; font-size: 14.5px; font-weight: 700; }
.tw-lb-bar { height: 3px; border-radius: 999px; background: var(--ring-track, #1e1e30); margin-top: 6px; overflow: hidden; }
.tw-lb-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--violet), var(--cyan)); }
.tw-lb-xp { flex: 0 0 auto; font-family: 'JetBrains Mono', monospace; font-size: 13px; font-weight: 700; color: var(--brand, #9d8cff); }

/* ── Settings ── */
.tw-settings { display: flex; flex-direction: column; gap: 18px; }
.tw-settings .skel-row { height: 110px; border-radius: 14px; }
.tw-set-card { padding: 20px 22px; display: flex; flex-direction: column; gap: 16px; }
.tw-set-row { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.tw-set-label { font-size: 13px; font-weight: 600; color: var(--faint); min-width: 90px; flex: 0 0 auto; }
.tw-set-val { font-size: 15px; font-weight: 600; }
.tw-set-code-row { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.tw-set-code {
  font-family: 'JetBrains Mono', monospace; font-size: 20px; font-weight: 700;
  letter-spacing: 2px; background: rgba(124,92,255,.1); padding: 7px 14px;
  border-radius: 10px; color: var(--brand, #9d8cff);
}
.tw-set-copy, .tw-set-btn {
  border: 1px solid var(--line); background: rgba(255,255,255,.04); color: var(--text);
  font: inherit; font-size: 13px; font-weight: 600; padding: 8px 14px; border-radius: 10px; cursor: pointer;
}
.tw-set-copy:hover, .tw-set-btn:hover { background: rgba(255,255,255,.08); }
.tw-set-btn:disabled { opacity: .5; cursor: default; }
.tw-set-leave { display: flex; }
.tw-set-danger {
  border: 1px solid rgba(255,107,107,.2); border-radius: 14px; padding: 18px 20px;
  background: rgba(255,107,107,.03); display: flex; flex-direction: column; gap: 10px;
}
.tw-set-danger h3 { font-family: 'Bricolage Grotesque', sans-serif; font-size: 15px; font-weight: 800; color: #ff8a8a; }
.tw-set-danger p { font-size: 13px; color: var(--muted); line-height: 1.5; }
.tw-set-del-btn {
  align-self: flex-start; border: 1px solid rgba(255,107,107,.4); background: rgba(255,107,107,.07);
  color: #ff8a8a; font: inherit; font-size: 13.5px; font-weight: 600; padding: 10px 20px;
  border-radius: 11px; cursor: pointer;
}
.tw-set-del-btn:hover { background: rgba(255,107,107,.16); }

/* ── Landing page (no teamId: pick / create / join) ── */
.tw-landing-wrap {
  min-height: 100dvh; display: flex; align-items: center; justify-content: center;
  padding: 30px 16px;
}
.tw-landing {
  width: 100%; max-width: 520px; display: flex; flex-direction: column; align-items: center; gap: 24px;
}
.tw-land-brand {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 17px; letter-spacing: -.3px;
  color: var(--text);
}
.tw-land-brand img { width: 34px; height: 34px; border-radius: 10px; }
.tw-land-title {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 32px;
  letter-spacing: -.6px; text-align: center; margin: 0;
}
.tw-land-teams {
  width: 100%; display: flex; flex-direction: column; gap: 8px;
}
.tw-lc {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-radius: 14px; cursor: pointer; font: inherit; color: var(--text);
  background: rgba(255,255,255,.04); border: 1px solid var(--line);
  transition: background .15s, border-color .15s; text-align: left;
}
.tw-lc:hover { background: rgba(124,92,255,.09); border-color: rgba(124,92,255,.3); }
.tw-lc-name { font-size: 15px; font-weight: 700; }
.tw-lc-meta { font-size: 12.5px; color: var(--muted); display: flex; align-items: center; gap: 8px; }
.tw-lc-role {
  font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 1px; text-transform: uppercase;
  padding: 2px 7px; border-radius: 20px; border: 1px solid var(--line); color: var(--faint);
}
.tw-lc-role.lead { border-color: rgba(124,92,255,.4); color: #9d8cff; }
.tw-lc-empty { text-align: center; color: var(--muted); font-size: 13.5px; padding: 8px 0; line-height: 1.5; }
.tw-land-or {
  display: flex; align-items: center; gap: 12px; width: 100%; color: var(--faint); font-size: 13px;
}
.tw-land-or::before, .tw-land-or::after {
  content: ''; flex: 1; height: 1px; background: var(--line);
}
.tw-land-actions { display: flex; flex-direction: column; gap: 10px; width: 100%; }
.tw-land-card {
  border: 1px solid var(--line); border-radius: 14px; overflow: hidden;
  background: rgba(255,255,255,.03);
}
.tw-land-card-head {
  display: flex; align-items: center; gap: 10px; padding: 14px 18px; cursor: pointer;
  font-size: 15px; font-weight: 600; transition: background .15s;
}
.tw-land-card-head:hover { background: rgba(255,255,255,.04); }
.tw-land-icon { font-size: 16px; width: 22px; text-align: center; }
.tw-land-form {
  display: flex; flex-direction: column; gap: 10px; padding: 4px 18px 18px;
}
.tw-land-inp {
  width: 100%; padding: 11px 14px; border-radius: 11px; font: inherit; font-size: 14.5px;
  background: rgba(255,255,255,.05); border: 1px solid var(--line); color: var(--text);
  outline: none; transition: border-color .15s;
}
.tw-land-inp:focus { border-color: rgba(124,92,255,.5); }
.tw-land-submit {
  align-self: flex-start; padding: 10px 22px; border-radius: 11px; font: inherit; font-size: 14px; font-weight: 700;
  background: linear-gradient(90deg, #7c5cff, #5ea8ff); border: none; color: #fff; cursor: pointer;
  transition: opacity .15s;
}
.tw-land-submit:hover { opacity: .88; }
.tw-land-submit:disabled { opacity: .5; cursor: default; }
.tw-land-back {
  color: var(--faint); text-decoration: none; font-size: 13.5px; margin-top: 4px;
}
.tw-land-back:hover { color: var(--text); }

/* ── Overview hub (no team selected: team picker + create / join) ── */
.tw-hub { max-width: 560px; }
.tw-hub-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 18px; }
.tw-hub-head h2 { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 26px; letter-spacing: -.5px; margin: 0; }
.tw-hub-back { color: var(--faint); text-decoration: none; font-size: 13.5px; }
.tw-hub-back:hover { color: var(--text); }
.tw-hub-teams { display: flex; flex-direction: column; gap: 8px; margin-bottom: 6px; }
.tw-hub-empty { color: var(--muted); font-size: 14px; padding: 16px 0; }
.tw-hc {
  display: flex; align-items: center; gap: 12px; padding: 14px 18px; border-radius: 14px;
  background: rgba(255,255,255,.04); border: 1px solid var(--line);
  cursor: pointer; text-align: left; font: inherit; color: var(--text); width: 100%;
  transition: background .15s, border-color .15s;
}
.tw-hc:hover { background: rgba(124,92,255,.1); border-color: rgba(124,92,255,.35); }
.tw-hc-name { font-size: 15px; font-weight: 700; flex: 1; }
.tw-hc-meta { font-size: 12.5px; color: var(--muted); flex: 0 0 auto; }
.tw-hc-role { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: .5px; padding: 2px 7px; border-radius: 20px; border: 1px solid var(--line2); color: var(--faint); flex: 0 0 auto; }
.tw-hc-role.lead { color: var(--brand, #9d8cff); border-color: rgba(124,92,255,.3); }
.tw-hc.sm { padding: 10px 14px; border-radius: 11px; }
.tw-hub-or { display: flex; align-items: center; gap: 10px; margin: 18px 0; color: var(--faint); font-size: 13px; }
.tw-hub-or::before, .tw-hub-or::after { content: ''; flex: 1; height: 1px; background: var(--line); }
.tw-hub-actions { display: flex; flex-direction: column; gap: 10px; }
.tw-hub-card { border-radius: 14px; background: rgba(255,255,255,.03); border: 1px solid var(--line); overflow: hidden; }
.tw-hub-card-head {
  display: flex; align-items: center; gap: 10px; padding: 13px 18px; cursor: pointer;
  font-size: 15px; font-weight: 600; transition: background .15s;
}
.tw-hub-card-head:hover { background: rgba(255,255,255,.04); }
.tw-hub-form { display: flex; gap: 10px; padding: 4px 18px 16px; }
.tw-hub-inp {
  flex: 1; padding: 10px 14px; border-radius: 10px; font: inherit; font-size: 14px;
  background: rgba(255,255,255,.05); border: 1px solid var(--line); color: var(--text);
  outline: none; transition: border-color .15s;
}
.tw-hub-inp:focus { border-color: rgba(124,92,255,.5); }
.tw-hub-submit {
  padding: 10px 20px; border-radius: 10px; font: inherit; font-size: 14px; font-weight: 700;
  background: linear-gradient(90deg, #7c5cff, #5ea8ff); border: none; color: #fff; cursor: pointer;
  white-space: nowrap; transition: opacity .15s;
}
.tw-hub-submit:hover { opacity: .88; }
.tw-hub-submit:disabled { opacity: .5; cursor: default; }

/* ── Overview: copy invite button + team switcher ── */
.tw-ov-head { align-items: flex-start; }
.tw-ov-copy-invite {
  margin-top: 8px; padding: 6px 14px; border-radius: 8px; font: inherit; font-size: 13px;
  background: rgba(255,255,255,.06); border: 1px solid var(--line); color: var(--muted);
  cursor: pointer; transition: background .15s, color .15s;
}
.tw-ov-copy-invite:hover { background: rgba(124,92,255,.15); color: var(--text); }
.tw-ov-switch { margin-top: 22px; }
.tw-ov-switch-h { font-size: 12px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; color: var(--faint); margin-bottom: 10px; }

/* ── Leaderboard tabs ── */
.tw-lb-tabs { display: flex; gap: 6px; margin-bottom: 18px; }
.tw-lb-tab {
  padding: 8px 18px; border-radius: 20px; font: inherit; font-size: 13.5px; font-weight: 600;
  background: rgba(255,255,255,.05); border: 1px solid var(--line); color: var(--muted);
  cursor: pointer; transition: background .15s, color .15s, border-color .15s;
}
.tw-lb-tab:hover { color: var(--text); background: rgba(255,255,255,.08); }
.tw-lb-tab.on { background: rgba(124,92,255,.15); border-color: rgba(124,92,255,.4); color: var(--text); }
.tw-lb-sub { display: block; font-size: 11.5px; color: var(--faint); margin-top: 1px; }

/* ── Mobile: sidebar becomes a horizontal top strip ── */
@media (max-width: 820px) {
  .tw { grid-template-columns: 1fr; }
  .tw-side {
    flex-direction: row; align-items: center; gap: 6px; padding: 10px 12px;
    border-right: none; border-bottom: 1px solid var(--line);
    overflow-x: auto; scrollbar-width: none; position: sticky; top: 0; z-index: 20;
  }
  .tw-side::-webkit-scrollbar { display: none; }
  .tw-brand { display: none; }
  .tw-nav { flex-direction: row; gap: 6px; }
  .tw-nav a { flex: 0 0 auto; white-space: nowrap; padding: 9px 13px; font-size: 13.5px; }
  .tw-side-foot { margin: 0 0 0 auto; padding: 0; border: none; flex: 0 0 auto; }
  .tw-main { height: auto; padding: 18px 16px 40px; }
  .tw-top h1 { font-size: 22px; }
  .tw-room { height: calc(100dvh - 170px); }
  .tw-rmsg { max-width: 88%; }
  .tw-astra { height: calc(100dvh - 200px); }
  .tw-amsg { max-width: 92%; }
  .tw-tc { height: calc(100dvh - 200px); }
  .tw-tmsg { max-width: 92%; }
  .tw-ov-doors { grid-template-columns: 1fr; }
  .tw-ov-head h2 { font-size: 24px; }
}
