:root {
  --tlt-bg: #f6f4ee;
  --tlt-surface: #fbfaf6;
  --tlt-surface2: #fff;
  --tlt-line: rgba(40, 38, 32, 0.1);
  --tlt-line2: rgba(40, 38, 32, 0.06);
  --tlt-ink: #1d1c19;
  --tlt-ink2: #3a3a35;
  --tlt-ink3: #6b6a62;
  --tlt-muted: #9a978c;
  --tlt-primary: oklch(0.42 0.09 155);
  --tlt-primary-fg: #fff;
  --tlt-primary-soft: oklch(0.95 0.03 155);
  --tlt-accent: oklch(0.62 0.13 45);
  --tlt-accent-soft: oklch(0.94 0.04 45);
  --tlt-yellow: oklch(0.86 0.16 100);
  --tlt-ok: oklch(0.55 0.12 155);
  --tlt-warn: oklch(0.72 0.14 75);
  --tlt-danger: oklch(0.55 0.18 25);
  --tlt-chip-bg: rgba(40, 38, 32, 0.05);
  --font-display: "Instrument Serif", "Times New Roman", serif;
  --font-sans: "Inter Tight", "Helvetica Neue", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", "SF Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; }
html { background: var(--tlt-bg); color: var(--tlt-ink); font-family: var(--font-sans); }
body { margin: 0; min-width: 320px; }
button, input, select, textarea { font: inherit; }
button { -webkit-tap-highlight-color: transparent; }

.app-shell { min-height: 100svh; display: grid; grid-template-columns: 220px minmax(0, 1fr); background: var(--tlt-bg); }
.auth-page { min-height: 100svh; display: grid; place-items: center; padding: 24px; background: var(--tlt-bg); }
.auth-panel { width: min(440px, 100%); display: flex; flex-direction: column; gap: 18px; padding: 24px; border: 1px solid var(--tlt-line); border-radius: 14px; background: var(--tlt-surface); box-shadow: 0 18px 48px rgba(29, 28, 25, .08); }
.auth-brand { display: flex; align-items: center; gap: 8px; font-weight: 700; }
.auth-brand span span { opacity: .4; }
.auth-form { display: grid; gap: 12px; }
.auth-form .btn { width: 100%; }
.auth-alert { padding: 10px 12px; border: 1px solid color-mix(in oklch, var(--tlt-primary) 28%, var(--tlt-line)); border-radius: 10px; background: var(--tlt-primary-soft); color: var(--tlt-primary); font-size: 13px; font-weight: 650; }
.auth-alert.error { border-color: color-mix(in oklch, var(--tlt-danger) 28%, var(--tlt-line)); background: color-mix(in oklch, var(--tlt-danger) 9%, var(--tlt-surface2)); color: var(--tlt-danger); }
.auth-dev-link { display: inline-flex; min-height: 34px; align-items: center; justify-content: center; border-radius: 9px; background: var(--tlt-accent-soft); color: var(--tlt-accent); font-size: 13px; font-weight: 700; text-decoration: none; }
.push-actions { display: grid; gap: 10px; }
.sidebar { min-height: 100svh; position: sticky; top: 0; display: flex; flex-direction: column; gap: 4px; padding: 22px 14px; border-right: 1px solid var(--tlt-line); background: var(--tlt-surface); }
.brand { display: flex; align-items: center; gap: 8px; padding: 4px 10px 22px; font-weight: 650; letter-spacing: 0; }
.brand-mark { width: 22px; height: 22px; border-radius: 50%; background: var(--tlt-primary); position: relative; flex: 0 0 auto; overflow: hidden; }
.brand-mark::before, .brand-mark::after { content: ""; position: absolute; left: 3px; right: 3px; height: 9px; border: 1.4px solid var(--tlt-accent); border-left: 0; border-right: 0; border-radius: 50%; opacity: .9; }
.brand-mark::before { top: 5px; } .brand-mark::after { bottom: 5px; }
.brand span span { opacity: .4; }
.eyebrow { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--tlt-ink3); }
.team-label { padding: 0 10px 8px; }
.nav-row { width: 100%; display: flex; align-items: center; gap: 10px; border: 0; border-radius: 8px; padding: 8px 10px; background: transparent; color: var(--tlt-ink2); cursor: pointer; font-size: 13.5px; font-weight: 550; text-align: left; }
.nav-row.active { background: var(--tlt-primary-soft); color: var(--tlt-primary); font-weight: 650; }
.nav-row .label { flex: 1; }
.badge { min-width: 20px; border-radius: 999px; padding: 1px 6px; background: var(--tlt-accent); color: #fff; font-size: 10.5px; font-weight: 700; text-align: center; }
.user-chip { margin-top: auto; padding: 12px 10px 4px; border-top: 1px solid var(--tlt-line2); display: flex; align-items: center; gap: 10px; }
.user-bubble-wrap { margin-top: auto; position: relative; }
.user-bubble-wrap .user-chip { margin-top: 0; width: 100%; }
.user-chip-button { border: 0; background: transparent; color: var(--tlt-ink); cursor: pointer; text-align: left; border-radius: 10px; }
.user-chip-button:hover { background: var(--tlt-chip-bg); }
.avatar { display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; width: var(--size, 28px); height: var(--size, 28px); flex: 0 0 auto; background: var(--bg, var(--tlt-chip-bg)); color: var(--fg, var(--tlt-ink2)); font-size: calc(var(--size, 28px) * .4); font-weight: 650; }
.avatar.primary { --bg: var(--tlt-primary); --fg: #fff; }
.avatar.photo { overflow: hidden; background: var(--tlt-chip-bg); }
.avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.user-menu { position: absolute; left: 4px; right: 4px; bottom: calc(100% + 10px); z-index: 20; padding: 10px; border: 1px solid var(--tlt-line); border-radius: 14px; background: var(--tlt-surface); box-shadow: 0 10px 32px rgba(29, 28, 25, .12); display: flex; flex-direction: column; gap: 8px; }
.user-menu-head { display: flex; align-items: center; gap: 10px; padding: 4px 4px 8px; border-bottom: 1px solid var(--tlt-line2); }
.user-menu-row { min-height: 36px; border: 0; border-radius: 9px; background: transparent; color: var(--tlt-ink); display: flex; align-items: center; gap: 8px; padding: 0 9px; cursor: pointer; font-size: 13px; font-weight: 650; text-align: left; }
.user-menu-row:hover { background: var(--tlt-primary-soft); color: var(--tlt-primary); }
.upload-row input { display: none; }
.user-menu-info { display: flex; align-items: flex-start; gap: 8px; padding: 8px 9px 4px; color: var(--tlt-ink3); font-size: 11.5px; line-height: 1.35; }
.info-dot { width: 18px; height: 18px; border-radius: 50%; background: var(--tlt-chip-bg); color: var(--tlt-ink2); display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; font-size: 11px; font-weight: 700; position: relative; cursor: help; }
.tooltip { position: absolute; left: 24px; bottom: -6px; width: 210px; padding: 9px 10px; border-radius: 9px; border: 1px solid var(--tlt-line); background: var(--tlt-ink); color: var(--tlt-primary-fg); font-size: 11.5px; font-weight: 500; line-height: 1.35; opacity: 0; pointer-events: none; transform: translateY(4px); transition: opacity .12s, transform .12s; }
.info-dot:hover .tooltip, .info-dot:focus .tooltip { opacity: 1; transform: translateY(0); }
.main { padding: 22px 32px 32px; min-width: 0; display: flex; flex-direction: column; gap: 22px; }
.topbar { display: flex; justify-content: space-between; gap: 18px; align-items: flex-start; }
h1, h2, h3, p { margin-top: 0; }
.page-title { margin: 0; font-family: var(--font-display); font-size: 36px; font-weight: 400; letter-spacing: 0; line-height: 1.05; }
.subhead { margin-top: 4px; color: var(--tlt-ink3); font-size: 13.5px; }
.actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.btn { min-height: 34px; border: 1px solid transparent; border-radius: 9px; padding: 0 13px; display: inline-flex; align-items: center; justify-content: center; gap: 6px; cursor: pointer; font-size: 13.5px; font-weight: 600; color: var(--tlt-primary-fg); background: var(--tlt-primary); transition: transform .06s, filter .12s, opacity .12s; }
.btn:hover { filter: brightness(.98); }
.btn:active { transform: scale(.985); }
.btn.secondary { background: var(--tlt-surface2); color: var(--tlt-ink); border-color: var(--tlt-line); }
.btn.ghost { background: transparent; color: var(--tlt-ink2); }
.btn.accent { background: var(--tlt-accent); color: #fff; }
.btn:disabled { opacity: .45; cursor: default; }
.btn.small { min-height: 28px; padding: 0 10px; font-size: 12.5px; }
.icon { width: 16px; height: 16px; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.card { background: var(--tlt-surface); border: 1px solid var(--tlt-line); border-radius: 14px; overflow: hidden; }
.card-pad { padding: 16px; }
.card-head { padding: 14px 18px; border-bottom: 1px solid var(--tlt-line2); display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.card-title { font-size: 14px; font-weight: 650; }
.chip { display: inline-flex; align-items: center; gap: 5px; border-radius: 999px; padding: 3px 9px; background: var(--tlt-chip-bg); color: var(--tlt-ink2); white-space: nowrap; font-size: 11.5px; font-weight: 550; }
.chip.small { padding: 2px 7px; font-size: 10.5px; }
.dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; display: inline-block; flex: 0 0 auto; }
.hero { position: relative; padding: 26px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 26px; }
.court-backdrop { position: absolute; right: -42px; top: -20px; opacity: .06; width: 340px; height: 240px; pointer-events: none; }
.match-title { margin: 6px 0 0; font-family: var(--font-display); font-size: 44px; font-weight: 400; letter-spacing: 0; line-height: 1.02; }
.match-title span { color: var(--tlt-primary); }
.location { display: flex; align-items: center; gap: 6px; margin-top: 8px; color: var(--tlt-ink3); font-size: 13.5px; }
.stat-rail { display: flex; flex-direction: column; gap: 10px; }
.stat { padding: 11px 14px; border-radius: 10px; background: var(--tlt-surface2); border: 1px solid var(--tlt-line); }
.stat-top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.stat-value { font-size: 13px; font-weight: 550; }
.bar { height: 4px; margin-top: 7px; border-radius: 2px; background: var(--tlt-line2); overflow: hidden; }
.bar > span { display: block; height: 100%; width: var(--pct); background: var(--fill, var(--tlt-primary)); }
.grid-dashboard { display: grid; grid-template-columns: 1.55fr 1fr; gap: 22px; }
.grid-two { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.avail-row { display: grid; grid-template-columns: 1.6fr .55fr .65fr 1fr; align-items: center; gap: 12px; padding: 10px 20px; border-bottom: 1px solid var(--tlt-line2); }
.avail-row:last-child { border-bottom: 0; }
.person { display: flex; align-items: center; gap: 10px; min-width: 0; }
.person strong { display: block; font-size: 13.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.meta { display: block; font-family: var(--font-mono); font-size: 11px; color: var(--tlt-ink3); }
.status { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 650; color: var(--status); }
.segmented { justify-self: end; display: inline-flex; padding: 2px; border-radius: 8px; background: var(--tlt-chip-bg); }
.segmented button { border: 0; background: transparent; border-radius: 6px; padding: 5px 10px; color: var(--tlt-ink3); cursor: pointer; font-size: 11.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.segmented button.active { background: var(--tlt-surface2); color: var(--status); box-shadow: 0 1px 2px rgba(0, 0, 0, .06); }
.item-row { padding: 12px 18px; border-bottom: 1px solid var(--tlt-line2); display: flex; align-items: center; gap: 12px; }
.item-row:last-child { border-bottom: 0; }
.tile { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; background: var(--tlt-chip-bg); color: var(--tlt-ink2); flex: 0 0 auto; }
.date-cube { width: 52px; text-align: center; }
.date-day { font-family: var(--font-display); font-size: 22px; line-height: 1; }
.action-card { padding: 14px 18px; border-bottom: 1px solid var(--tlt-line2); }
.action-card.done { opacity: .55; }
.view { display: none; }
.view.active { display: contents; }
.lineup-grid { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(320px, 1fr); gap: 20px; align-items: start; }
.line-row { display: grid; grid-template-columns: 46px minmax(0, 1fr) auto; gap: 14px; align-items: center; padding: 12px 20px; border-bottom: 1px solid var(--tlt-line2); }
.line-row:last-child { border-bottom: 0; }
.line-row.drag-over { outline: 2px dashed var(--tlt-primary); outline-offset: -6px; background: var(--tlt-primary-soft); }
.player-pill { display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px 6px 6px; border-radius: 9px; background: var(--tlt-primary-soft); border: 1px solid color-mix(in oklch, var(--tlt-primary) 25%, transparent); cursor: grab; }
.bench-player { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: 8px; cursor: grab; }
.bench-player:hover { background: var(--tlt-chip-bg); }
.bench-player.dim { opacity: .5; }
.bench-drop-zone.drag-over { outline: 2px dashed var(--tlt-primary); outline-offset: -8px; background: var(--tlt-primary-soft); }
.sub-queue { padding: 14px 20px; border-top: 1px solid var(--tlt-line2); background: var(--tlt-bg); }
.sub-slot { display: inline-flex; align-items: center; gap: 8px; margin: 8px 8px 0 0; padding: 6px 10px 6px 6px; border-radius: 999px; background: var(--tlt-surface2); border: 1px solid var(--tlt-line); }
.sub-slot[draggable="true"] { cursor: grab; }
.sub-slot.drag-over { outline: 2px dashed var(--tlt-primary); }
.confirmation-list { display: grid; }
.confirmation-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 18px; border-bottom: 1px solid var(--tlt-line2); }
.confirmation-row:last-child { border-bottom: 0; }
.confirmation-row.confirmed { background: color-mix(in oklch, var(--tlt-primary) 6%, transparent); }
.confirmation-row.declined { background: color-mix(in oklch, var(--tlt-danger) 7%, transparent); }
.lineup-confirm-action.confirmed { background: color-mix(in oklch, var(--tlt-primary) 5%, transparent); }
.lineup-confirm-action.declined { background: color-mix(in oklch, var(--tlt-danger) 6%, transparent); }
.location-map { aspect-ratio: 16 / 7; background: var(--tlt-chip-bg); border-bottom: 1px solid var(--tlt-line2); overflow: hidden; }
.location-map iframe { width: 100%; height: 100%; border: 0; display: block; }
.location-card-body { padding: 14px 18px; display: grid; gap: 4px; }
.location-card-body strong { font-size: 14px; }
.live-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 18px; }
.score-hero { padding: 22px 26px; display: grid; grid-template-columns: 1fr auto 1fr; gap: 24px; align-items: center; position: relative; }
.score-number { font-family: var(--font-display); font-size: 64px; line-height: 1; display: flex; gap: 14px; align-items: baseline; letter-spacing: 0; }
.live-line-body { padding: 14px 18px; display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; align-items: center; }
.score-box { display: flex; gap: 14px; font-family: var(--font-mono); font-variant-numeric: tabular-nums; text-align: center; }
.score-box strong { display: block; font-size: 22px; }
.score-box span { display: block; font-size: 16px; color: var(--tlt-ink3); }
.mobile-wrap { max-width: 430px; margin: 0 auto; min-height: calc(100svh - 44px); border-radius: 28px; overflow: hidden; border: 1px solid var(--tlt-line); background: var(--tlt-surface); position: relative; }
.mobile-shell { min-height: calc(100svh - 44px); background: var(--tlt-bg); display: flex; flex-direction: column; }
.mobile-head { padding: 28px 20px 12px; display: flex; align-items: center; justify-content: space-between; background: var(--tlt-surface); border-bottom: 1px solid var(--tlt-line2); }
.mobile-body { padding: 14px 16px 92px; flex: 1; overflow: auto; display: flex; flex-direction: column; gap: 14px; }
.mobile-tabs { position: absolute; left: 0; right: 0; bottom: 0; padding: 8px 12px 24px; background: color-mix(in oklch, var(--tlt-surface) 88%, transparent); backdrop-filter: blur(20px); border-top: 1px solid var(--tlt-line2); display: flex; justify-content: space-around; }
.mobile-tab { display: flex; flex-direction: column; align-items: center; gap: 3px; color: var(--tlt-ink3); font-size: 10.5px; font-weight: 600; }
.mobile-tab.active { color: var(--tlt-primary); }
.mobile-hero { border-radius: 16px; padding: 18px; color: var(--tlt-primary-fg); background: var(--tlt-primary); overflow: hidden; position: relative; }
.mobile-hero.accent { background: var(--tlt-accent); }
.mobile-title { font-family: var(--font-display); font-size: 30px; line-height: 1.1; margin: 6px 0 0; letter-spacing: 0; }
.tap-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin-top: 14px; }
.tap-grid button { border: 1px solid var(--tlt-line); background: var(--tlt-surface2); color: var(--tlt-ink2); padding: 10px 4px; border-radius: 10px; cursor: pointer; font-size: 12.5px; font-weight: 650; }
.tap-grid button.active { border-color: transparent; background: var(--tlt-primary); color: var(--tlt-primary-fg); }
.user-shell { display: flex; flex-direction: column; gap: 18px; }
.user-tabs { display: inline-flex; align-self: flex-start; gap: 3px; padding: 3px; border-radius: 10px; background: var(--tlt-chip-bg); }
.user-tabs button { min-height: 34px; border: 0; border-radius: 8px; padding: 0 14px; background: transparent; color: var(--tlt-ink3); cursor: pointer; font-size: 13px; font-weight: 650; }
.user-tabs button.active { background: var(--tlt-surface2); color: var(--tlt-primary); box-shadow: 0 1px 2px rgba(0, 0, 0, .06); }
.user-home { display: flex; flex-direction: column; gap: 18px; }
.user-hero { position: relative; display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr); gap: 24px; padding: 24px 26px; }
.user-hero-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 18px; }
.user-next-stack { position: relative; display: grid; gap: 10px; align-content: start; }
.user-home-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: start; }
.quick-action { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; align-items: center; padding: 14px 18px; border-bottom: 1px solid var(--tlt-line2); }
.quick-action:last-child { border-bottom: 0; }
.quick-action > div:first-child { display: flex; gap: 10px; align-items: flex-start; min-width: 0; }
.team-pulse { display: grid; gap: 8px; padding: 14px 18px; }
.team-pulse > div { display: grid; grid-template-columns: 74px 1fr auto; align-items: center; gap: 10px; padding: 10px; border: 1px solid var(--tlt-line); border-radius: 10px; background: var(--tlt-surface2); }
.roster-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr); gap: 18px; align-items: start; }
.roster-table { display: grid; }
.roster-item { border-bottom: 1px solid var(--tlt-line2); }
.roster-item:last-child { border-bottom: 0; }
.roster-item.editing { background: color-mix(in oklch, var(--tlt-primary) 4%, transparent); }
.roster-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 12px 18px; border-bottom: 1px solid var(--tlt-line2); }
.roster-item:not(.editing) .roster-row { border-bottom: 0; }
.roster-row-actions { display: flex; align-items: center; justify-content: flex-end; gap: 10px; flex-wrap: wrap; }
.roster-edit-form { border-top: 1px solid var(--tlt-line2); }
.avatar-edit-row { display: grid; grid-template-columns: auto minmax(0, 1fr) auto; gap: 12px; align-items: center; padding: 14px 18px; }
.avatar-edit-row strong { display: block; font-size: 14px; }
.edit-player-fields { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.roster-side { display: flex; flex-direction: column; gap: 14px; }
.member-form { display: grid; gap: 12px; padding: 16px 18px; }
.invite-list { display: grid; }
.invite-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 18px; border-bottom: 1px solid var(--tlt-line2); }
.invite-row:last-child { border-bottom: 0; }
.empty-state { padding: 16px 18px; color: var(--tlt-ink3); font-size: 13px; }
.user-grid { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(280px, .7fr); gap: 18px; align-items: start; }
.user-form { overflow: hidden; }
.form-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; padding: 16px 18px; }
.field { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.field.wide { grid-column: 1 / -1; }
.field span { font-size: 11px; font-weight: 650; color: var(--tlt-ink3); text-transform: uppercase; letter-spacing: .08em; }
.field input, .field select, .field textarea { width: 100%; border: 1px solid var(--tlt-line); border-radius: 9px; background: var(--tlt-surface2); color: var(--tlt-ink); padding: 10px 11px; font-size: 13.5px; outline: none; }
.field input:focus, .field select:focus, .field textarea:focus { border-color: color-mix(in oklch, var(--tlt-primary) 45%, var(--tlt-line)); box-shadow: 0 0 0 3px var(--tlt-primary-soft); }
.pref-block { padding: 16px 18px; border-top: 1px solid var(--tlt-line2); display: grid; grid-template-columns: .55fr 1fr; gap: 16px; }
.schedule-builder-grid { display: grid; grid-template-columns: minmax(0, 1.45fr) minmax(280px, .55fr); gap: 18px; align-items: start; }
.team-setup-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr); gap: 18px; align-items: start; }
.team-setup-grid > .card { align-self: start; }
.metadata-list { display: grid; gap: 10px; }
.line-type-editor { display: grid; gap: 10px; padding: 14px 18px; }
.line-type-row { display: grid; grid-template-columns: minmax(0, 1fr) 120px auto; gap: 10px; align-items: end; padding: 10px; border: 1px solid var(--tlt-line); border-radius: 10px; background: var(--tlt-surface2); }
.schedule-edit-list { display: flex; flex-direction: column; gap: 10px; padding: 12px; }
.schedule-edit-row { border: 1px solid var(--tlt-line); border-radius: 12px; overflow: hidden; transition: border-color .12s, box-shadow .12s, transform .06s; }
.schedule-edit-row.home-match { background: color-mix(in oklch, var(--tlt-primary) 12%, var(--tlt-surface2)); border-color: color-mix(in oklch, var(--tlt-primary) 26%, var(--tlt-line)); }
.schedule-edit-row.away-match { background: color-mix(in oklch, var(--tlt-accent) 14%, var(--tlt-surface2)); border-color: color-mix(in oklch, var(--tlt-accent) 32%, var(--tlt-line)); }
.schedule-edit-row.open { box-shadow: 0 10px 28px rgba(29, 28, 25, .08); }
.schedule-edit-row:hover { transform: translateY(-1px); }
.schedule-edit-summary { display: grid; grid-template-columns: 62px minmax(0, 1fr) auto; gap: 14px; align-items: center; padding: 14px 18px; cursor: pointer; }
.schedule-edit-summary:focus-visible { outline: 3px solid var(--tlt-primary-soft); outline-offset: -3px; }
.schedule-edit-summary strong { font-size: 14px; }
.schedule-disclosure { color: var(--tlt-ink3); transition: transform .12s; }
.schedule-edit-row.open .schedule-disclosure { transform: rotate(90deg); }
.schedule-form { border-top: 1px solid var(--tlt-line2); background: color-mix(in oklch, var(--tlt-surface) 88%, #fff); }
.schedule-form-actions { padding: 0 18px 18px; justify-content: flex-start; }
.save-status { min-height: 28px; display: inline-flex; align-items: center; padding: 0 9px; border-radius: 999px; background: var(--tlt-chip-bg); color: var(--tlt-ink3); font-size: 12px; font-weight: 700; }
.save-status.saving { color: var(--tlt-accent); background: var(--tlt-accent-soft); }
.save-status.saved { color: var(--tlt-primary); background: var(--tlt-primary-soft); }
.save-status.error { color: var(--tlt-danger); background: color-mix(in oklch, var(--tlt-danger) 10%, var(--tlt-surface2)); }
.bring-editor { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; }
.bring-line-field { display: grid; gap: 8px; padding: 10px; border: 1px solid var(--tlt-line); border-radius: 10px; background: var(--tlt-surface2); }
.line-format-panel { display: grid; gap: 8px; }
.line-format-panel > div { display: flex; justify-content: space-between; gap: 10px; padding: 10px; border: 1px solid var(--tlt-line); border-radius: 10px; background: var(--tlt-surface2); }
.line-format-panel strong { font-family: var(--font-mono); color: var(--tlt-primary); }
.line-format-panel span { color: var(--tlt-ink3); font-size: 12px; font-weight: 600; }
.bring-category-list { display: flex; flex-wrap: wrap; gap: 7px; }
.signup-avail-list { display: flex; flex-direction: column; gap: 8px; }
.signup-avail-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: 12px; padding: 10px; border: 1px solid var(--tlt-line); border-radius: 10px; background: var(--tlt-surface2); }
.check-row { margin: 0 18px 16px; display: flex; align-items: center; gap: 10px; padding: 12px; border: 1px solid var(--tlt-line); border-radius: 10px; background: var(--tlt-bg); }
.check-row input { width: 18px; height: 18px; accent-color: var(--tlt-primary); }
.check-row span { display: flex; flex-direction: column; gap: 2px; }
.check-row small { color: var(--tlt-ink3); font-size: 12px; }
.check-row.disabled { opacity: .55; }
.user-summary { display: flex; flex-direction: column; gap: 14px; }
.user-summary > div:first-child { display: flex; align-items: center; gap: 12px; }
.summary-stat { padding: 12px; border-radius: 10px; background: var(--tlt-surface2); border: 1px solid var(--tlt-line); display: flex; flex-direction: column; gap: 5px; }
.summary-stat strong { font-size: 15px; line-height: 1.25; }
.mini-availability { display: flex; flex-wrap: wrap; gap: 6px; }
.personal-list { display: flex; flex-direction: column; }
.personal-card { display: grid; grid-template-columns: 62px 1fr; gap: 14px; padding: 16px 18px; border-bottom: 1px solid var(--tlt-line2); }
.personal-card:last-child { border-bottom: 0; }
.personal-card.playing { background: color-mix(in oklch, var(--tlt-primary) 5%, transparent); }
.personal-card.subbing { background: color-mix(in oklch, var(--tlt-accent) 5%, transparent); }
.personal-details { margin-top: 10px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.personal-details span { min-height: 34px; display: flex; align-items: center; gap: 6px; padding: 8px 10px; border-radius: 9px; background: var(--tlt-surface2); border: 1px solid var(--tlt-line); font-size: 12.5px; color: var(--tlt-ink2); }
.personal-confirm-actions { justify-content: flex-start; margin-top: 10px; }
.glance-grid { display: grid; gap: 10px; }
.team-list { display: flex; flex-direction: column; }
.team-match { padding: 16px 18px; border-bottom: 1px solid var(--tlt-line2); }
.team-match:last-child { border-bottom: 0; }
.team-match-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
.home-chip { background: var(--tlt-primary-soft); color: var(--tlt-primary); }
.away-chip { background: var(--tlt-accent-soft); color: var(--tlt-accent); }
.team-lines { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 8px; }
.team-line { min-height: 92px; display: flex; flex-direction: column; gap: 5px; padding: 10px; border: 1px solid var(--tlt-line); border-radius: 10px; background: var(--tlt-surface2); }
.team-line strong { font-family: var(--font-mono); font-size: 12px; color: var(--tlt-primary); }
.team-line span { font-size: 12.5px; font-weight: 650; line-height: 1.3; }
.team-line small { margin-top: auto; color: var(--tlt-ink3); font-size: 11px; line-height: 1.35; }
.bring-row { margin-top: 12px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.calendar-grid { padding: 18px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.calendar-day { min-height: 184px; display: flex; flex-direction: column; gap: 6px; padding: 14px; border: 1px solid var(--tlt-line); border-radius: 12px; background: var(--tlt-surface2); color: var(--tlt-ink); text-align: left; cursor: pointer; }
.calendar-day:hover { border-color: color-mix(in oklch, var(--tlt-primary) 35%, var(--tlt-line)); background: var(--tlt-primary-soft); }
.calendar-num { font-family: var(--font-display); font-size: 42px; line-height: .95; color: var(--tlt-primary); }
.match-detail-hero { padding: 18px; border-bottom: 1px solid var(--tlt-line2); background: var(--tlt-bg); }
.detail-lines { padding: 18px; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; }
.detail-line-card { min-height: 178px; display: flex; flex-direction: column; gap: 12px; border: 1px solid var(--tlt-line); border-radius: 12px; padding: 12px; background: var(--tlt-surface2); }
.detail-line-head { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.detail-line-head strong { font-family: var(--font-mono); color: var(--tlt-primary); }
.detail-player-list { display: flex; flex-direction: column; gap: 8px; }
.detail-player-list > div { display: flex; align-items: center; gap: 8px; font-size: 12.5px; font-weight: 650; }
.detail-subs { margin-top: auto; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.detail-bring { padding: 0 18px 18px; }
.desktop-only { display: initial; }
.mobile-only { display: none; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: .42; } }

@media (max-width: 980px) {
  .app-shell { display: block; padding-bottom: 70px; }
  .sidebar { display: none; }
  .main { padding: 16px; gap: 16px; }
  .topbar { flex-direction: column; }
  .actions { justify-content: flex-start; }
  .grid-dashboard, .grid-two, .hero, .lineup-grid, .live-grid, .score-hero, .user-grid, .pref-block, .user-hero, .user-home-grid, .schedule-builder-grid, .team-setup-grid, .bring-editor, .roster-grid, .edit-player-fields, .avatar-edit-row, .line-type-row { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .avail-row { grid-template-columns: 1fr; align-items: start; }
  .segmented { justify-self: start; }
  .line-row { grid-template-columns: 38px 1fr; }
  .line-row > :last-child { grid-column: 2; }
  .location-map { aspect-ratio: 4 / 3; }
  .team-lines, .calendar-grid, .personal-details, .quick-action, .team-pulse > div, .detail-lines, .schedule-edit-summary { grid-template-columns: 1fr; }
  .live-line-body { grid-template-columns: 1fr; text-align: left; }
  .mobile-only { display: flex; }
  .bottom-nav { position: fixed; left: 0; right: 0; bottom: 0; z-index: 10; padding: 8px 8px calc(8px + env(safe-area-inset-bottom)); background: var(--tlt-surface); border-top: 1px solid var(--tlt-line); justify-content: space-around; }
  .bottom-nav .nav-row { flex-direction: column; gap: 3px; width: auto; font-size: 10.5px; padding: 7px 9px; }
}
