:root {
  color-scheme: dark;
  --bg: #0b100d;
  --panel: rgba(22, 31, 26, .9);
  --panel-2: #1a251f;
  --line: rgba(255,255,255,.09);
  --text: #f4f7f5;
  --muted: #92a099;
  --green: #b7ef5a;
  --spotify: #1ed760;
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }

body {
  margin: 0;
  min-height: 100vh;
  overflow-x: hidden;
  overflow-y: auto;
  color: var(--text);
  background: var(--bg);
  font-family: "DM Sans", sans-serif;
}

.auth-gate { position: fixed; z-index: 3000; inset: 0; display: grid; place-items: center; padding: 1rem; background: radial-gradient(circle at 15% 10%, rgba(183,239,90,.13), transparent 28rem), var(--bg); }
.auth-gate[hidden] { display: none; }
.auth-pending .shell { visibility: hidden; }
.auth-gate-card { display: grid; gap: 1.25rem; width: min(520px, 100%); padding: clamp(1.5rem, 4vw, 2.6rem); border: 1px solid var(--line); border-radius: 24px; background: linear-gradient(145deg, rgba(28,39,33,.98), rgba(18,26,22,.98)); box-shadow: 0 30px 100px rgba(0,0,0,.45); }
.auth-gate-brand { display: flex; align-items: center; gap: 1rem; }
.auth-gate-brand img { width: 52px; height: 52px; }
.auth-gate-brand h1 { font-size: clamp(2rem, 8vw, 3.3rem); }
.auth-gate-card h2 { margin: 0; font: 600 clamp(1.45rem, 5vw, 2rem) "Space Grotesk", sans-serif; }
.auth-gate-card p { margin: .45rem 0 0; color: var(--muted); }
.auth-google-button { width: 100%; padding: .95rem 1rem; border: 1px solid var(--line); border-radius: 12px; background: rgba(255,255,255,.035); font-weight: 700; cursor: pointer; }
.auth-google-button:hover { border-color: rgba(183,239,90,.35); background: rgba(183,239,90,.06); }
.auth-divider { display: flex; align-items: center; gap: .8rem; color: var(--muted); font-size: .75rem; }
.auth-divider::before, .auth-divider::after { content: ""; height: 1px; flex: 1; background: var(--line); }
.auth-email-row { display: flex; gap: .55rem; }
.auth-email-row[hidden] { display: none; }
.auth-otp-row input { font-variant-numeric: tabular-nums; letter-spacing: .22em; text-align: center; }
.auth-email-row input { min-width: 0; flex: 1; padding: .9rem 1rem; border: 1px solid var(--line); border-radius: 10px; outline: none; color: var(--text); background: #0f1712; }
.auth-email-row input:focus { border-color: var(--green); }
.auth-gate-status { min-height: 1.2em; font-size: .82rem; }

button, input, textarea { font: inherit; }
button { color: inherit; }

.shell { width: 100%; margin: 0; padding: 3vh clamp(.85rem, 1.5vw, 2rem); }
.topbar { position: relative; display: flex; align-items: end; justify-content: space-between; margin-bottom: 3vh; }
.topbar.timer-enabled { display: flex; align-items: end; }
.topbar.timer-enabled .header-meta { justify-content: flex-end; }
.brand-block { display: flex; align-items: center; gap: 1rem; }
.brand-block .eyebrow { margin-bottom: .35rem; }
.menu-button { position: relative; display: grid; place-items: center; width: 46px; height: 46px; border: 1px solid var(--line); border-radius: 50%; color: var(--green); background: var(--panel-2); cursor: pointer; font-size: 1.15rem; }
.menu-button svg { width: 21px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; }
.menu-invitation-badge { position: absolute; top: -5px; right: -5px; display: grid; place-items: center; min-width: 20px; height: 20px; padding: 0 5px; border: 2px solid var(--bg); border-radius: 999px; color: var(--bg); background: var(--green); font: 800 .65rem "DM Sans", sans-serif; box-shadow: 0 3px 12px rgba(0,0,0,.35); }
.eyebrow, .section-label { margin: 0 0 .55rem; color: var(--green); font-size: .72rem; font-weight: 700; letter-spacing: .18em; }
h1 { margin: 0; font: 700 clamp(2rem, 4vw, 4.5rem)/.95 "Space Grotesk", sans-serif; letter-spacing: -.055em; }
.header-meta { display: flex; align-items: center; gap: 1rem; }
.sharing-invitation-notice { display: block; width: fit-content; max-width: calc(100% - 1rem); margin: -1vh 0 1.25rem; padding: .75rem 1rem; border: 1px solid color-mix(in srgb, var(--green) 38%, transparent); border-radius: 12px; color: var(--green); background: color-mix(in srgb, var(--green) 8%, var(--panel)); cursor: pointer; font-weight: 700; text-align: left; }
.sharing-invitation-notice:hover { background: color-mix(in srgb, var(--green) 13%, var(--panel)); }
.cast-button { width: 46px; height: 46px; padding: 11px; border: 1px solid var(--line); border-radius: 50%; background: var(--panel-2); cursor: pointer; }
.cast-button svg { width: 22px; fill: none; stroke: currentColor; stroke-width: 1.9; stroke-linecap: round; }
.cast-button.connected { color: var(--green); border-color: rgba(183,239,90,.4); }
.clock { display: grid; text-align: right; }
.clock strong { font: 600 clamp(1.7rem, 3vw, 3rem)/1 "Space Grotesk", sans-serif; }
.clock span { margin-top: .35rem; color: var(--muted); font-size: .82rem; text-transform: capitalize; }
.gym-timer { position: absolute; z-index: 5; top: calc(50% + 4rem); left: 50%; display: grid; grid-template-columns: auto auto auto; align-items: center; gap: 1.1rem; padding: 1rem 1.25rem; border: 1px solid var(--line); border-radius: 20px; background: var(--panel); box-shadow: 0 14px 40px rgba(0,0,0,.22); transform: translate(-50%, -50%); }
.gym-timer-config { display: grid; grid-template-columns: auto auto; gap: .25rem; }
.gym-timer-config select, .gym-timer-config label { min-height: 38px; border: 1px solid var(--line); border-radius: 9px; color: var(--muted); background: var(--panel-2); font-size: .78rem; }
.gym-timer-config select { grid-column: 1 / -1; padding: .2rem .35rem; outline: none; }
.gym-timer-config label { display: flex; align-items: center; gap: .15rem; padding: 0 .3rem; }
.gym-timer-config input[type="number"] { width: 44px; padding: 0; border: 0; outline: none; color: var(--text); background: transparent; text-align: right; font-weight: 700; }
.gym-timer-prep input { accent-color: var(--green); }
.gym-timer-readout { display: grid; min-width: 285px; text-align: center; }
.gym-timer-readout span { color: var(--green); font-size: 1rem; font-weight: 800; letter-spacing: .12em; }
.gym-timer-readout strong { font: 700 clamp(5rem, 7.4vw, 8.35rem)/1 "Space Grotesk", sans-serif; font-variant-numeric: tabular-nums; }
.gym-timer-actions { display: grid; gap: .25rem; }
.gym-timer-actions button { min-width: 82px; padding: .55rem .7rem; border: 1px solid var(--line); border-radius: 9px; color: var(--text); background: var(--panel-2); cursor: pointer; font-size: .8rem; font-weight: 700; }
.gym-timer-actions button:first-child { border-color: color-mix(in srgb, var(--green) 42%, transparent); color: var(--green); }
.gym-timer.is-prep .gym-timer-readout strong { color: var(--green); }
.gym-timer.is-rest .gym-timer-readout strong { color: var(--muted); }
.gym-timer.is-finished { border-color: color-mix(in srgb, var(--green) 55%, transparent); }

.dashboard-grid { display: grid; grid-template-columns: minmax(0, 1fr) 380px; align-items: start; gap: 1.25rem; }
.dashboard-grid.spotify-disabled { grid-template-columns: minmax(0, 1fr); }
.side-column { display: grid; align-content: start; gap: 1.25rem; }
.side-column[hidden] { display: none !important; }
.card { border: 1px solid var(--line); border-radius: 24px; background: var(--panel); box-shadow: 0 22px 70px rgba(0,0,0,.2); }
.workout-card { min-height: 66vh; padding: clamp(1.3rem, 3vw, 2.4rem); }
.workout-board { min-width: 0; }
.board-heading { display: flex; align-items: end; justify-content: space-between; gap: 1rem; margin-bottom: 1.25rem; }
.board-heading h2 { margin: 0; font: 600 clamp(1.8rem, 3vw, 3rem)/1 "Space Grotesk", sans-serif; letter-spacing: -.04em; }
.dashboard-title { display: block; width: min(680px, 70vw); border: 0; padding: 0; color: var(--text); background: transparent; outline: none; font: 600 clamp(1.8rem, 3vw, 3rem)/1 "Space Grotesk", sans-serif; letter-spacing: -.04em; }
.active-dashboard-date { margin: .35rem 0 0; color: var(--muted); font-size: .78rem; text-transform: capitalize; }
.board-actions { display: flex; align-items: center; gap: .65rem; }
.sessions-board { --exercise-font-size: clamp(.95rem, 4cqi, 1.15rem); display: grid; grid-template-columns: repeat(var(--session-count, 1), minmax(0, 1fr)); align-items: start; gap: 1.25rem; }
.sessions-board.has-verbose-content { --exercise-font-size: clamp(.86rem, 3.4cqi, 1rem); }
.sessions-board.has-extreme-content { --exercise-font-size: clamp(.78rem, 3cqi, .92rem); }
.session-card { container-type: inline-size; min-width: 0; padding: clamp(1.15rem, 2vw, 1.65rem); }
.session-heading { display: flex; align-items: center; justify-content: space-between; gap: .75rem; }
.session-heading-actions { display: flex; align-items: center; gap: .2rem; }
.session-order { display: grid; place-items: center; min-width: 28px; height: 28px; padding: 0 .45rem; border: 1px solid rgba(183,239,90,.24); border-radius: 999px; color: var(--green); background: rgba(183,239,90,.055); font: 700 .72rem "Space Grotesk", sans-serif; }
.session-heading-actions button { display: grid; place-items: center; width: 28px; height: 28px; padding: 0; border: 0; background: transparent; }
.drag-handle { border-radius: 6px !important; color: #77847d; cursor: grab; font-size: 1.05rem; touch-action: none; }
.drag-handle:hover { color: var(--green); background: rgba(183,239,90,.07) !important; }
.drag-handle:active { cursor: grabbing; }
.session-type { border: 1px solid rgba(183,239,90,.24); border-radius: 999px; padding: .45rem .75rem; color: var(--green); background: rgba(183,239,90,.06); outline: none; font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; cursor: pointer; }
.session-type option { color: var(--text); background: #17211b; }
.delete-session-button { border: 0; color: #68756e; background: transparent; font-size: 1.5rem; cursor: pointer; }
.delete-session-button:hover { color: #ff8c8c; }
.session-card.sortable-ghost { opacity: .25; }
.session-card.sortable-drag { border-color: rgba(183,239,90,.55); box-shadow: 0 28px 80px rgba(0,0,0,.45); }
.session-title { display: block; width: 100%; min-height: 1.2em; margin: 1rem 0 1.2rem; overflow: hidden; resize: none; border: 0; color: var(--text); background: transparent; outline: none; font: 600 clamp(1.7rem, 7cqi, 3.4rem)/1.02 "Space Grotesk", sans-serif; letter-spacing: -.045em; }
.session-title.text-medium { font-size: clamp(1.45rem, 5.4cqi, 2.7rem); }
.session-title.text-long { font-size: clamp(1.15rem, 4.2cqi, 2rem); line-height: 1.12; }
.emom-options { align-items: center; justify-content: space-between; gap: .75rem; margin: -.35rem 0 1rem; padding: .7rem .8rem; border: 1px solid rgba(183,239,90,.14); border-radius: 12px; background: rgba(183,239,90,.035); }
.emom-options:not([hidden]) { display: flex; }
.emom-options label { display: flex; align-items: center; gap: .55rem; color: var(--muted); font-size: .72rem; font-weight: 700; text-transform: uppercase; }
.duration-control { display: flex; align-items: center; gap: .3rem; color: var(--green); }
.emom-duration { width: 48px; border: 0; border-bottom: 1px solid rgba(183,239,90,.35); color: var(--green); background: transparent; outline: none; text-align: right; font-weight: 700; }
.emom-options p { margin: 0; color: var(--muted); font-size: .68rem; text-align: right; }
.exercise-minute { display: none; color: var(--green); font-family: "Space Grotesk", sans-serif; font-size: var(--exercise-font-size); font-weight: 600; line-height: 1.3; letter-spacing: 0; text-align: center; }
.session-card.is-emom .exercise-row { grid-template-columns: max-content minmax(0, 1fr) auto; column-gap: .35rem; }
.session-card.is-emom .exercise-minute { display: block; }
.session-card.is-emom .exercise-minute { grid-column: 1; grid-row: 1; align-self: baseline; padding: 0; text-align: right; }
.session-card.is-emom .exercise-name { grid-column: 2; }
.session-card.is-emom .exercise-row:has(.exercise-name.text-medium) .exercise-minute,
.session-card.is-emom .exercise-row:has(.exercise-name.text-long) .exercise-minute { font-size: var(--exercise-font-size); }
.session-card.is-emom .exercise-detail { grid-column: 2; }
.session-card.is-emom .exercise-actions { grid-column: 3; }
.session-exercises { display: grid; grid-template-columns: repeat(var(--exercise-columns, 1), minmax(0, 1fr)); gap: .55rem; margin-bottom: .75rem; }
.session-card.is-multi-column .session-exercises { align-items: start; column-gap: .45rem; }
.session-card.is-multi-column .emom-options { max-width: 50%; }
.session-card .exercise-row { grid-template-columns: minmax(0, 1fr) auto; min-height: 58px; gap: .2rem .65rem; padding: .45rem .55rem; }
.session-card .exercise-name,
.session-card .exercise-name.text-medium,
.session-card .exercise-name.text-long,
.session-card .exercise-detail,
.session-card .exercise-detail.text-medium,
.session-card .exercise-detail.text-long { font-size: var(--exercise-font-size); }
.session-card .exercise-detail { min-width: 0; }
.sessions-board.is-dense { gap: .75rem; }
.sessions-board.is-dense .session-card { padding: 1rem; border-radius: 18px; }
.sessions-board.is-dense .session-title { margin: .75rem 0 .9rem; font-size: clamp(1.15rem, 4.2cqi, 2rem); }
.sessions-board.is-dense .exercise-row { grid-template-columns: minmax(0, 1fr) auto; gap: .4rem; min-height: 51px; padding: .35rem .4rem; }
.sessions-board.is-dense .session-card.is-emom .exercise-row { grid-template-columns: max-content minmax(0, 1fr) auto; column-gap: .3rem; }
.sessions-board.is-dense .session-card.is-emom .exercise-detail { grid-column: 2; }
.sessions-board.is-dense .session-card.is-emom .exercise-actions { grid-column: 3; }
.sessions-board.is-dense .exercise-detail { grid-column: 1; text-align: left; min-width: 0; font-size: .72rem; }
.sessions-board.is-dense .exercise-actions { grid-column: 2; grid-row: 1 / span 2; }
.sessions-board.is-compact { gap: .5rem; }
.sessions-board.is-compact .session-card { padding: .7rem; border-radius: 15px; }
.sessions-board.is-compact .session-type { max-width: calc(100% - 24px); padding: .35rem .5rem; font-size: .6rem; }
.sessions-board.is-compact .session-title { margin: .55rem 0 .7rem; font-size: clamp(1rem, 3.6cqi, 1.55rem); }
.sessions-board.is-compact .exercise-row { min-height: 45px; }
.sessions-board.is-compact .check-button { width: 31px; height: 31px; }
.sessions-board.is-compact .add-button { padding: .7rem .35rem; font-size: .72rem; }
.session-card.has-long-list { padding-top: .75rem; padding-bottom: .75rem; }
.session-card.has-long-list .session-title { margin: .45rem 0 .55rem; }
.session-card.has-long-list .emom-options { margin: -.1rem 0 .5rem; padding: .4rem .5rem; }
.session-card.has-long-list .emom-options p { display: none; }
.session-card.has-long-list .session-exercises { gap: .28rem; margin-bottom: .45rem; }
.session-card.has-long-list .exercise-row,
.sessions-board.is-dense .session-card.has-long-list .exercise-row { min-height: 39px; padding: .18rem .3rem; border-radius: 10px; }
.session-card.has-long-list .check-button { width: 27px; height: 27px; }
.session-card.has-long-list .exercise-name { font-size: clamp(.72rem, 3.1cqi, .9rem); }
.session-card.has-long-list .exercise-detail { font-size: .62rem; }
.session-card.has-long-list .add-button { padding: .5rem; }
.session-card.has-very-long-list { padding: .55rem; }
.session-card.has-very-long-list .session-heading { min-height: 25px; }
.session-card.has-very-long-list .session-title { margin: .25rem 0 .35rem; font-size: clamp(.9rem, 3.2cqi, 1.3rem); }
.session-card.has-very-long-list .emom-options { padding: .25rem .4rem; }
.session-card.has-very-long-list .session-exercises { gap: .18rem; }
.session-card.has-very-long-list .exercise-row,
.sessions-board.is-dense .session-card.has-very-long-list .exercise-row { min-height: 32px; padding: .1rem .22rem; }
.session-card.has-very-long-list .check-button { width: 23px; height: 23px; }
.session-card.has-very-long-list .exercise-name { font-size: .68rem; }
.session-card.has-very-long-list .add-button { padding: .35rem; font-size: .62rem; }
.session-card.has-extreme-list .emom-options { margin-bottom: .25rem; }
.session-card.has-extreme-list .session-exercises { gap: .1rem; }
.session-card.has-extreme-list .exercise-row,
.sessions-board.is-dense .session-card.has-extreme-list .exercise-row { min-height: 25px; padding: .05rem .18rem; }
.session-card.has-extreme-list .check-button { width: 19px; height: 19px; }
.session-card.has-extreme-list .exercise-name { font-size: .58rem; }
.session-card.has-extreme-list .exercise-detail { font-size: .52rem; }
.session-card.has-extreme-list .add-button { padding: .22rem; }
.card-heading, .spotify-heading { display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.title-input { width: 100%; border: 0; padding: 0; color: var(--text); background: transparent; outline: none; font: 600 clamp(1.8rem, 3vw, 3rem)/1.1 "Space Grotesk", sans-serif; letter-spacing: -.04em; }
.title-input:focus { box-shadow: 0 2px var(--green); }
.text-button, .secondary-button { border: 0; background: transparent; color: var(--muted); cursor: pointer; }
.text-button:hover { color: var(--text); }

.exercise-list { display: grid; gap: .7rem; margin: 2rem 0 1rem; }
.exercise-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: .25rem .85rem; min-height: 68px; padding: .55rem .7rem; border: 1px solid var(--line); border-radius: 16px; background: rgba(255,255,255,.025); transition: opacity .2s, border .2s, transform .2s; }
.exercise-row:focus-within { border-color: rgba(183,239,90,.35); }
.exercise-row.completed { opacity: .5; }
.exercise-row.completed .exercise-name { text-decoration: line-through; }
.exercise-row.removing { opacity: 0; transform: translateX(12px); }
.exercise-row [contenteditable] { width: 100%; min-width: 0; overflow-wrap: anywhere; border: 0; outline: none; background: transparent; color: var(--text); font-family: "Space Grotesk", sans-serif; font-style: normal; font-variant: normal; font-synthesis: none; line-height: 1.25; white-space: pre-wrap; }
.exercise-row [contenteditable] * { font-family: inherit !important; font-size: inherit !important; font-style: inherit !important; letter-spacing: inherit !important; }
.exercise-row [contenteditable] [data-accent="true"],
.exercise-row [contenteditable] .accent-text-inline,
.exercise-row [contenteditable] span[style*="rgb(1, 2, 3)"],
.exercise-row [contenteditable] font[color="#010203"] { color: var(--green) !important; }
.exercise-row [contenteditable] span[style*="rgb(2, 3, 4)"],
.exercise-row [contenteditable] font[color="#020304"] { color: var(--text) !important; }
.exercise-row [contenteditable][data-placeholder]:empty::before { content: attr(data-placeholder); color: #68756e; pointer-events: none; }
.exercise-name { font-family: "Space Grotesk", sans-serif; font-weight: 600; font-size: clamp(1rem, 1.5vw, 1.25rem); }
.exercise-detail { display: none; }
.exercise-detail.text-medium { font-size: .74rem; }
.exercise-detail.text-long { font-size: .68rem; }
.exercise-actions { grid-column: 2; grid-row: 1; display: grid; align-content: center; gap: .15rem; }
.exercise-actions button { width: 25px; height: 25px; padding: 0; border: 0; color: #68756e; background: transparent; cursor: pointer; }
.exercise-actions .bold-button { border-radius: 5px; font-family: serif; font-size: .75rem; }
.exercise-actions .bold-button:hover, .exercise-actions .bold-button.active { color: var(--green); background: rgba(183,239,90,.08); }
.exercise-actions .color-button { border-radius: 5px; font-size: .72rem; }
.exercise-actions .color-button:hover, .exercise-actions .color-button.active { color: var(--green); background: color-mix(in srgb, var(--green) 10%, transparent); }
.exercise-actions .delete-button { grid-column: auto; grid-row: auto; }
.check-button { width: 39px; height: 39px; border: 1px solid rgba(255,255,255,.18); border-radius: 50%; background: transparent; cursor: pointer; }
.check-button span { opacity: 0; }
.completed .check-button { border-color: var(--green); color: #13200e; background: var(--green); }
.completed .check-button span { opacity: 1; }
.delete-button { border: 0; background: transparent; color: #68756e; font-size: 1.6rem; cursor: pointer; }
.delete-button:hover { color: #ff8c8c; }
.add-button { width: 100%; padding: 1rem; border: 1px dashed rgba(183,239,90,.26); border-radius: 15px; color: var(--green); background: rgba(183,239,90,.035); font-weight: 600; cursor: pointer; }
.add-button span { margin-right: .4rem; font-size: 1.25rem; }

.origin-transfer-notice { position: fixed; z-index: 1000; left: 50%; bottom: 1.25rem; display: flex; align-items: center; gap: 1rem; width: min(760px, calc(100vw - 2rem)); padding: .9rem 1rem; border: 1px solid rgba(183,239,90,.35); border-radius: 14px; background: #17231c; box-shadow: 0 18px 55px rgba(0,0,0,.5); transform: translateX(-50%); }
.origin-transfer-notice span { flex: 1; color: var(--muted); font-size: .88rem; }
.origin-transfer-notice strong { color: var(--text); }
.origin-transfer-notice.success { justify-content: center; border-color: rgba(30,215,96,.45); }
.app-version { position: fixed; z-index: 1200; left: 50%; bottom: .55rem; color: rgba(146,160,153,.65); font: 600 .68rem "Space Grotesk", sans-serif; letter-spacing: .08em; pointer-events: none; transform: translateX(-50%); }

.spotify-card { padding: 1.4rem; }
.spotify-logo { display: flex; align-items: center; gap: .6rem; font: 700 1.15rem "Space Grotesk", sans-serif; }
.spotify-logo svg { width: 28px; fill: var(--spotify); }
.icon-button { display: grid; place-items: center; width: 46px; height: 46px; border: 1px solid var(--line); border-radius: 50%; background: var(--panel-2); cursor: pointer; }
.icon-button.small { width: 34px; height: 34px; }
.icon-button svg { width: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; }
.spotify-frame-wrap { margin-top: 1.2rem; overflow: hidden; border-radius: 14px; background: #121212; }
.spotify-frame-wrap iframe { display: block; width: 100%; height: 152px; border: 0; }
.queue-preview { margin-top: .9rem; padding: .85rem; border-radius: 13px; background: rgba(255,255,255,.025); }
.queue-preview .section-label { margin-bottom: .55rem; font-size: .58rem; }
.queue-items { display: grid; gap: .45rem; }
.queue-item { display: grid; grid-template-columns: 42px minmax(0, 1fr); align-items: center; gap: .65rem; min-width: 0; }
.queue-item img { width: 42px; height: 42px; border-radius: 6px; object-fit: cover; }
.queue-item-copy { min-width: 0; }
.queue-item strong, .queue-item span { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.queue-item strong { font-size: .78rem; }
.queue-item span { margin-top: .15rem; color: var(--muted); font-size: .68rem; }
.queue-empty { margin: 0; color: var(--muted); font-size: .75rem; }
.now-playing { margin-top: 1.2rem; min-height: 132px; overflow: hidden; border-radius: 16px; background: #101713; }
.now-playing-placeholder { display: grid; place-items: center; align-content: center; gap: .8rem; min-height: 132px; padding: 1rem; text-align: center; }
.now-playing-placeholder p { margin: 0; color: var(--muted); font-size: .86rem; }
.now-playing-placeholder .primary-button { padding: .65rem .9rem; font-size: .8rem; }
.now-playing-content { grid-template-columns: 132px minmax(0, 1fr); min-height: 132px; }
.now-playing-content:not([hidden]) { display: grid; }
.now-playing-content img { width: 132px; height: 132px; object-fit: cover; }
.now-playing-copy { min-width: 0; padding: 1rem; align-self: center; }
.playing-state { margin: 0 0 .35rem; color: var(--spotify); font-size: .65rem; font-weight: 700; letter-spacing: .13em; }
.now-playing-copy h2 { overflow: hidden; margin: 0; font: 600 1.18rem/1.2 "Space Grotesk", sans-serif; text-overflow: ellipsis; white-space: nowrap; }
.now-playing-copy > p:not(.playing-state) { overflow: hidden; margin: .3rem 0 0; color: var(--muted); font-size: .8rem; text-overflow: ellipsis; white-space: nowrap; }
.now-playing-copy .playing-device { color: #6f7e76 !important; font-size: .7rem !important; }
.track-progress { height: 4px; margin-top: .7rem; overflow: hidden; border-radius: 99px; background: rgba(255,255,255,.1); }
.track-progress div { width: 0; height: 100%; border-radius: inherit; background: var(--spotify); transition: width 1s linear; }
.playback-controls { display: flex; align-items: center; justify-content: center; gap: .55rem; margin-top: .7rem; }
.playback-controls button { display: grid; place-items: center; width: 31px; height: 31px; border: 1px solid var(--line); border-radius: 50%; color: var(--text); background: rgba(255,255,255,.04); cursor: pointer; }
.playback-controls button:hover { border-color: rgba(30,215,96,.5); }
.playback-controls .playback-primary { width: 38px; height: 38px; border: 0; color: #0b100d; background: var(--spotify); }
.playback-controls button:disabled { opacity: .4; cursor: wait; }
.connect-tip { display: flex; align-items: center; gap: .7rem; margin-top: 1rem; color: var(--muted); font-size: .8rem; }
.connect-tip p { margin: 0; }
.dashboard-playback-button { margin-left: auto; padding: .5rem .65rem; border: 1px solid rgba(30,215,96,.3); border-radius: 8px; color: var(--spotify); background: rgba(30,215,96,.06); cursor: pointer; font-size: .7rem; font-weight: 700; white-space: nowrap; }
.pulse-dot { width: 8px; height: 8px; flex: 0 0 auto; border-radius: 50%; background: var(--spotify); box-shadow: 0 0 0 5px rgba(30,215,96,.1); }
.progress-card { padding: 1.4rem; }
.progress-copy { margin: 0; color: var(--muted); }
.progress-copy strong { color: var(--text); font-size: 1.4rem; }
.progress-track { height: 8px; margin-top: 1.2rem; overflow: hidden; border-radius: 99px; background: rgba(255,255,255,.08); }
.progress-bar { height: 100%; width: 0; border-radius: inherit; background: var(--green); transition: width .35s ease; }
.jam-card { display: grid; grid-template-columns: minmax(0, 1fr) 132px; align-items: center; gap: 1.2rem; padding: 1.4rem; }
.jam-copy h2 { margin: 0; font: 600 1.55rem "Space Grotesk", sans-serif; }
.jam-copy > p:not(.section-label) { margin: .55rem 0 1rem; color: var(--muted); font-size: .83rem; line-height: 1.45; }
.jam-copy .primary-button { padding: .65rem .8rem; font-size: .78rem; }
.jam-actions { display: flex; flex-wrap: wrap; gap: .45rem; }
.jam-actions .secondary-button { padding: .65rem .8rem; border: 1px solid var(--line); font-size: .78rem; }
.jam-qr { display: grid; place-items: center; width: 132px; height: 132px; padding: 9px; border-radius: 13px; color: #65726b; background: rgba(255,255,255,.05); font: 700 1.2rem "Space Grotesk", sans-serif; }
.jam-qr.active { background: #fff; }
.jam-qr img, .jam-qr canvas { width: 114px !important; height: 114px !important; }
.optional { color: #647169; font-weight: 400; }

dialog { width: min(500px, 90vw); border: 1px solid var(--line); border-radius: 22px; color: var(--text); background: #17211b; box-shadow: 0 30px 100px #000; }
dialog::backdrop { background: rgba(3,7,5,.75); backdrop-filter: blur(5px); }
.dialog-content { display: grid; gap: 1.4rem; padding: .8rem; }
.dialog-content h2 { margin: 0; font: 600 1.8rem "Space Grotesk", sans-serif; }
.dialog-help { margin: .5rem 0 0; color: var(--muted); }
.dialog-content label { display: grid; gap: .5rem; color: var(--muted); font-size: .85rem; font-weight: 600; }
.dialog-content input, .dialog-content select { padding: .9rem 1rem; border: 1px solid var(--line); border-radius: 10px; outline: none; color: var(--text); background: #0f1712; }
.dialog-content label > small { color: var(--muted); font-weight: 400; }
.dialog-content input:focus, .dialog-content select:focus { border-color: var(--green); }
.dialog-content .toggle-setting { display: flex; grid-template-columns: none; align-items: center; justify-content: space-between; gap: 1rem; padding: .9rem 1rem; border: 1px solid var(--line); border-radius: 12px; background: #0f1712; }
.toggle-setting span { display: grid; gap: .2rem; }
.toggle-setting strong { color: var(--text); font-size: .9rem; }
.toggle-setting small { color: var(--muted); font-weight: 400; }
.dialog-content .toggle-setting input { width: 42px; height: 23px; flex: 0 0 auto; accent-color: var(--green); cursor: pointer; }
.account-setting { display: grid; gap: .9rem; padding: 1rem; border: 1px solid var(--line); border-radius: 13px; background: rgba(255,255,255,.025); }
.account-setting > div:first-child { display: grid; gap: .2rem; }
.account-setting strong { color: var(--text); }
.account-setting small { color: var(--muted); }
.account-actions { display: flex; align-items: center; gap: .5rem; }
.account-actions input { min-width: 0; flex: 1; }
.account-actions button { white-space: nowrap; }
.share-list { display: grid; gap: .35rem; color: var(--muted); font-size: .76rem; }
.recipient-quick-list { display: flex; flex-wrap: wrap; gap: .35rem; }
.recipient-quick-list:empty { display: none; }
.recipient-quick-list button { max-width: 100%; overflow: hidden; padding: .35rem .55rem; border: 1px solid var(--line); border-radius: 999px; color: var(--muted); background: var(--panel-2); cursor: pointer; font-size: .7rem; text-overflow: ellipsis; white-space: nowrap; }
.recipient-quick-list button:hover { border-color: color-mix(in srgb, var(--green) 40%, transparent); color: var(--green); }
.share-item { display: flex; align-items: center; justify-content: space-between; gap: .5rem; padding: .45rem .55rem; border-radius: 8px; background: var(--panel-2); }
.share-item button { border: 0; color: var(--muted); background: transparent; cursor: pointer; }
.calendar-invitation { align-items: center; }
.share-invitation-actions { display: flex; gap: .35rem; }
.share-invitation-actions button { min-height: 34px; padding: .35rem .55rem; border: 1px solid var(--line); border-radius: 7px; color: var(--text); background: var(--panel-2); }
.share-invitation-actions button:first-child { border-color: color-mix(in srgb, var(--green) 45%, transparent); color: var(--green); }
.social-logins { display: grid; gap: .5rem; }
.social-logins > span { color: var(--muted); font-size: .7rem; text-align: center; }
.social-logins > div { display: grid; grid-template-columns: 1fr; gap: .45rem; }
.social-logins button { padding: .65rem; border: 1px solid var(--line); border-radius: 9px; color: var(--text); background: var(--panel-2); cursor: pointer; font-weight: 600; }
.social-logins button:hover { border-color: rgba(183,239,90,.4); }
.social-logins button:disabled { opacity: .4; cursor: not-allowed; }
.dialog-actions { display: flex; justify-content: flex-end; gap: .6rem; }
.theme-setting { padding: .9rem 1rem; border: 1px solid var(--line); border-radius: 12px; background: var(--panel-2); }
.template-toolbar { display: flex; justify-content: space-between; gap: .6rem; margin-bottom: .9rem; }
.secondary-button, .primary-button { padding: .8rem 1rem; border-radius: 10px; cursor: pointer; }
.danger-button { border-color: rgba(255,110,110,.35); color: #ff9a9a; }
.choice-dialog { width: min(470px, 90vw); }
.legal-consent-dialog::backdrop { background: rgba(3,7,5,.84); backdrop-filter: blur(5px); }
.legal-consent-dialog a { color: var(--green); }
.template-date-dialog { width: min(620px, 94vw); }
.template-date-heading { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; }
.template-date-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: .45rem; }
.template-date-day { position: relative; display: grid; place-items: center; min-height: 54px; padding: .5rem; border: 1px solid var(--line); border-radius: 11px; color: var(--text); background: rgba(255,255,255,.025); cursor: pointer; font-weight: 700; }
.template-date-day:hover { border-color: color-mix(in srgb, var(--green) 55%, transparent); background: color-mix(in srgb, var(--green) 10%, transparent); }
.template-date-day.outside { opacity: .35; }
.template-date-day.today { border-color: var(--green); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--green) 45%, transparent); }
.template-date-day.has-dashboard::after { content: ""; position: absolute; bottom: 6px; width: 5px; height: 5px; border-radius: 50%; background: var(--green); }
.primary-button { border: 0; color: #14200f; background: var(--green); font-weight: 700; }
.error { min-height: 1.2em; margin: -1rem 0 0; color: #ff8c8c; font-size: .8rem; }
.menu-backdrop { position: fixed; inset: 0; z-index: 20; background: rgba(3,7,5,.65); backdrop-filter: blur(3px); }
.app-menu { position: fixed; inset: 0 auto 0 0; z-index: 21; display: flex; flex-direction: column; width: min(390px, 90vw); padding: 2rem; border-right: 1px solid var(--line); background: var(--panel); box-shadow: 25px 0 80px rgba(0,0,0,.45); transform: translateX(-105%); transition: transform .25s ease; }
.app-menu.open { transform: translateX(0); }
.app-menu-heading { display: flex; align-items: center; justify-content: space-between; margin-bottom: 2.2rem; }
.app-menu-heading h2 { margin: 0; font: 600 2rem "Space Grotesk", sans-serif; }
.app-menu nav { display: grid; gap: .55rem; }
.app-menu nav button { display: flex; align-items: center; gap: 1rem; width: 100%; padding: 1rem; border: 1px solid transparent; border-radius: 13px; color: var(--text); background: transparent; cursor: pointer; text-align: left; font-weight: 600; }
.app-menu nav button b { flex: 1; }
.menu-row-badge { display: grid; place-items: center; min-width: 22px; height: 22px; padding: 0 6px; border-radius: 999px; color: var(--bg); background: var(--green); font: 800 .68rem "DM Sans", sans-serif; }
.menu-row-badge[hidden] { display: none; }
.inbox-list { display: grid; gap: .75rem; }
.inbox-message { padding: 1rem; border: 1px solid var(--line); border-radius: 14px; background: var(--panel-2); }
.inbox-message.unread { border-color: color-mix(in srgb, var(--green) 55%, var(--line)); box-shadow: inset 4px 0 var(--green); }
.inbox-message h3 { margin: 0 0 .4rem; font: 600 1.05rem "Space Grotesk", sans-serif; }
.inbox-message p { margin: 0; color: var(--muted); white-space: pre-wrap; }
.inbox-message small { display: block; margin-top: .65rem; color: var(--muted); }
.inbox-actions { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .75rem; }
.admin-message-compose { display: grid; gap: .65rem; margin-bottom: 1rem; padding: 1rem; border: 1px solid color-mix(in srgb, var(--green) 35%, var(--line)); border-radius: 14px; }
.admin-message-compose input, .admin-message-compose textarea { width: 100%; padding: .75rem; border: 1px solid var(--line); border-radius: 9px; outline: none; color: var(--text); background: var(--panel-2); }
.admin-message-compose textarea { min-height: 110px; resize: vertical; }
.app-menu nav button:hover { border-color: rgba(183,239,90,.25); background: rgba(183,239,90,.05); }
.app-menu nav span { color: var(--green); font-size: .65rem; letter-spacing: .12em; }
.menu-footer { display: grid; gap: .8rem; margin-top: auto; }
.menu-language-options { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .5rem; }
.menu-language-options button { display: flex; align-items: center; gap: .55rem; min-width: 0; padding: .75rem .8rem; border: 1px solid var(--line); border-radius: 11px; color: var(--text); background: var(--panel-2); cursor: pointer; text-align: left; }
.menu-language-options button:hover { border-color: color-mix(in srgb, var(--green) 42%, var(--line)); }
.menu-language-options button.active { border-color: var(--green); color: var(--green); background: color-mix(in srgb, var(--green) 9%, var(--panel-2)); }
.menu-language-options .language-flag { position: relative; display: inline-block; flex: 0 0 auto; width: 25px; height: 17px; overflow: hidden; border: 1px solid rgba(255,255,255,.32); border-radius: 3px; box-shadow: 0 1px 3px rgba(0,0,0,.25); }
.flag-da { background: #c8102e; }
.flag-da::before { content: ""; position: absolute; inset: 0; background: linear-gradient(to right, transparent 0 31%, #fff 31% 43%, transparent 43%), linear-gradient(to bottom, transparent 0 42%, #fff 42% 58%, transparent 58%); }
.flag-de { background: linear-gradient(to bottom, #181818 0 33.333%, #dd0000 33.333% 66.666%, #ffce00 66.666%); }
.flag-fr { background: linear-gradient(to right, #0055a4 0 33.333%, #fff 33.333% 66.666%, #ef4135 66.666%); }
.flag-gb { background: #21468b; }
.flag-gb::before { content: ""; position: absolute; inset: -3px; background: linear-gradient(32deg, transparent 42%, #fff 42% 48%, #cf142b 48% 52%, #fff 52% 58%, transparent 58%), linear-gradient(-32deg, transparent 42%, #fff 42% 48%, #cf142b 48% 52%, #fff 52% 58%, transparent 58%); }
.flag-gb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to right, transparent 0 39%, #fff 39% 61%, transparent 61%), linear-gradient(to bottom, transparent 0 34%, #fff 34% 66%, transparent 66%), linear-gradient(to right, transparent 0 44%, #cf142b 44% 56%, transparent 56%), linear-gradient(to bottom, transparent 0 41%, #cf142b 41% 59%, transparent 59%); }
.menu-language-options button b { overflow: hidden; font-size: .8rem; text-overflow: ellipsis; white-space: nowrap; }
.menu-note { margin: 0; color: var(--muted); font-size: .75rem; }
.manager-dialog { width: min(1050px, 94vw); max-height: 88vh; overflow: auto; }
.manager-content { padding: .8rem; }
.manager-heading { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.4rem; }
.manager-heading h2 { margin: 0; font: 600 2rem "Space Grotesk", sans-serif; }
.week-grid { display: grid; grid-template-columns: repeat(7, minmax(110px, 1fr)); gap: .65rem; }
.day-card, .saved-card, .template-card { border: 1px solid var(--line); border-radius: 14px; color: var(--text); background: rgba(255,255,255,.025); }
.day-card { min-height: 150px; padding: .8rem; cursor: pointer; text-align: left; }
.day-card:hover, .day-card.active { border-color: rgba(183,239,90,.45); }
.day-card .day-name { color: var(--green); font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.day-card strong { display: block; margin: .55rem 0; font: 600 1.35rem "Space Grotesk", sans-serif; }
.day-card small { color: var(--muted); }
.manager-list, .template-grid { display: grid; gap: .7rem; }
.template-grid { grid-template-columns: repeat(3, 1fr); }
.saved-card, .template-card { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1rem; }
.saved-card h3, .template-card h3 { margin: 0; font: 600 1.1rem "Space Grotesk", sans-serif; }
.saved-card p, .template-card p { margin: .3rem 0 0; color: var(--muted); font-size: .78rem; }
.card-actions { display: flex; gap: .45rem; }
.card-actions button { padding: .55rem .7rem; border: 1px solid var(--line); border-radius: 9px; color: var(--text); background: var(--panel-2); cursor: pointer; }
.planner-actions { display: flex; justify-content: flex-end; gap: .5rem; margin-top: 1rem; }
.calendar-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: .8rem; }
.calendar-header { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: start; gap: .75rem; }
.calendar-header .calendar-toolbar { margin-bottom: .8rem; }
.calendar-header-actions { display: flex; align-items: center; gap: .6rem; }
.calendar-only-mine { display: flex; align-items: center; gap: .35rem; color: var(--muted); font-size: .7rem; white-space: nowrap; }
.calendar-only-mine input { accent-color: var(--green); }
.calendar-share-button { min-height: 36px; padding: .55rem .8rem; border: 1px solid color-mix(in srgb, var(--green) 35%, transparent); border-radius: 9px; color: var(--green); background: color-mix(in srgb, var(--green) 7%, transparent); }
.calendar-toolbar h3 { margin: 0; font: 600 1.2rem "Space Grotesk", sans-serif; text-transform: capitalize; }
.calendar-toolbar button { width: 36px; height: 36px; border: 1px solid var(--line); border-radius: 50%; color: var(--text); background: var(--panel-2); cursor: pointer; }
.calendar-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: .45rem; }
.calendar-weekday { padding: .35rem; color: var(--muted); font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-align: center; text-transform: uppercase; }
.calendar-day { min-height: 120px; padding: .5rem; border: 1px solid var(--line); border-radius: 11px; background: rgba(255,255,255,.02); }
.calendar-day.outside { opacity: .35; }
.calendar-day.today { border-color: rgba(183,239,90,.5); }
.calendar-day-number { display: flex; align-items: center; justify-content: space-between; margin-bottom: .4rem; color: var(--muted); font-size: .72rem; font-weight: 700; }
.calendar-day-select { padding: 0; border: 0; color: inherit; background: transparent; cursor: pointer; font: inherit; }
.calendar-add { border: 0; color: var(--green); background: transparent; cursor: pointer; font-size: 1rem; }
.calendar-items { display: grid; gap: .25rem; }
.calendar-item { display: grid; grid-template-columns: minmax(0,1fr) auto; overflow: hidden; width: 100%; border-radius: 7px; color: var(--text); background: var(--panel-2); font-size: .67rem; }
.calendar-item.shared { box-shadow: inset 3px 0 var(--green); }
.calendar-item-open { overflow: hidden; padding: .35rem .4rem; border: 0; color: inherit; background: transparent; cursor: pointer; text-align: left; text-overflow: ellipsis; white-space: nowrap; }
.calendar-item-delete { padding: .2rem .4rem; border: 0; color: var(--muted); background: transparent; cursor: pointer; }
.mobile-calendar-agenda { display: none; }
.dashboard-navigator { display: inline-flex; align-items: center; gap: .35rem; margin-top: .35rem; }
.dashboard-navigator button { width: 28px; height: 28px; padding: 0; border: 1px solid var(--line); border-radius: 50%; color: var(--text); background: var(--panel-2); cursor: pointer; }
.dashboard-navigator span { min-width: 34px; color: var(--muted); font-size: .72rem; text-align: center; }

/* Theme surfaces */
dialog, .auth-gate-card, .origin-transfer-notice { background: var(--panel); }
.dialog-content input, .dialog-content select, .dialog-content .toggle-setting, .auth-email-row input, .session-type option, .now-playing { background: var(--panel-2); }
.primary-button { color: var(--bg); }

@media (max-width: 800px) {
  body { overflow: auto; }
  .shell { width: min(94vw, 680px); padding: 1.5rem 0; }
  .dashboard-grid { grid-template-columns: 1fr; }
  .workout-card { min-height: auto; }
  .board-heading { align-items: flex-start; }
  .week-grid { grid-template-columns: repeat(2, 1fr); }
  .template-grid { grid-template-columns: 1fr; }
  .manager-dialog { width: min(96vw, 680px); max-height: 92vh; }
  .manager-content { padding: .35rem; }
  .manager-heading { margin-bottom: 1rem; }
  .manager-heading h2 { font-size: 1.55rem; }
  .calendar-grid { gap: .28rem; }
  .calendar-header { grid-template-columns: minmax(0, 1fr); }
  .calendar-header-actions { align-items: stretch; flex-direction: column; }
  .calendar-share-button { width: 100%; margin-bottom: .6rem; }
  .calendar-day { position: relative; min-height: 48px; padding: .3rem; border-radius: 9px; }
  .calendar-day-number { justify-content: center; margin: 0; }
  .calendar-day-select { display: grid; place-items: center; width: 100%; min-height: 38px; border-radius: 7px; }
  .calendar-day.selected { border-color: var(--green); background: color-mix(in srgb, var(--green) 9%, transparent); }
  .calendar-day.has-dashboard::after { content: ""; position: absolute; bottom: 5px; left: 50%; width: 5px; height: 5px; border-radius: 50%; background: var(--green); transform: translateX(-50%); pointer-events: none; }
  .calendar-day .calendar-add, .calendar-day .calendar-items { display: none; }
  .mobile-calendar-agenda { display: grid; gap: .75rem; margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--line); }
  .mobile-calendar-agenda-heading { display: flex; align-items: center; justify-content: space-between; gap: .75rem; }
  .mobile-calendar-agenda-heading h3 { margin: 0; font: 600 1.05rem "Space Grotesk", sans-serif; text-transform: capitalize; }
  .mobile-calendar-agenda-heading button { padding: .65rem .8rem; }
  .mobile-calendar-agenda-items { display: grid; gap: .5rem; }
  .mobile-calendar-agenda-item { display: grid; grid-template-columns: minmax(0, 1fr) 48px; overflow: hidden; min-height: 58px; border: 1px solid var(--line); border-radius: 11px; background: var(--panel-2); }
  .mobile-calendar-agenda-item.shared { box-shadow: inset 3px 0 var(--green); }
  .mobile-calendar-agenda-open { display: grid; align-content: center; gap: .15rem; min-width: 0; padding: .7rem .8rem; border: 0; color: var(--text); background: transparent; cursor: pointer; text-align: left; }
  .mobile-calendar-agenda-open strong { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .mobile-calendar-agenda-open small { overflow: hidden; color: var(--muted); text-overflow: ellipsis; white-space: nowrap; }
  .mobile-calendar-agenda-delete { min-width: 48px; border: 0; border-left: 1px solid var(--line); color: #ff9a9a; background: transparent; cursor: pointer; font-size: 1.25rem; }
  .saved-card, .template-card { align-items: stretch; flex-direction: column; }
  .card-actions { justify-content: stretch; }
  .card-actions button { flex: 1; min-height: 44px; }
  .spotify-frame-wrap iframe { height: 152px; }
}

@media (min-width: 801px) and (max-width: 1100px) {
  .dashboard-grid { grid-template-columns: 1fr; }
  .side-column { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 520px) {
  .template-date-dialog { width: 96vw; }
  .template-date-grid { gap: .25rem; }
  .template-date-day { min-height: 42px; padding: .3rem; border-radius: 8px; }
  .auth-email-row { display: grid; }
  .shell { width: calc(100% - 1.25rem); padding: 1rem 0 2.5rem; overflow: hidden; }
  .topbar { display: grid; grid-template-columns: minmax(0, 1fr); align-items: start; gap: .85rem; margin-bottom: 2rem; }
  .topbar.timer-enabled { display: grid; grid-template-columns: minmax(0, 1fr); }
  .brand-block { min-width: 0; gap: .65rem; }
  .brand-block > div { min-width: 0; }
  .brand-block h1 { font-size: clamp(2.2rem, 12vw, 3.1rem); line-height: .95; }
  .brand-block .eyebrow { overflow-wrap: anywhere; font-size: .62rem; }
  .menu-button { flex: 0 0 auto; width: 40px; height: 40px; }
  .header-meta { justify-content: flex-end; gap: .5rem; }
  .gym-timer { position: static; grid-column: 1; grid-template-columns: minmax(0, 1fr); width: 100%; margin-top: .65rem; padding: .8rem; transform: none; }
  .topbar.timer-enabled .header-meta { grid-column: 1; justify-content: flex-end; }
  .gym-timer-config { grid-row: 3; grid-column: 1; grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .gym-timer-config select { grid-column: auto; }
  .gym-timer-readout { grid-row: 1; grid-column: 1; min-width: 0; text-align: center; }
  .gym-timer-readout strong { font-size: clamp(4rem, 22vw, 6.5rem); }
  .gym-timer-actions { grid-row: 2; grid-column: 1; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gym-timer-actions button { width: 100%; }
  .header-meta .icon-button, .header-meta .cast-button { width: 40px; height: 40px; padding: 9px; }
  .clock strong { font-size: 1.65rem; }
  .board-heading { display: grid; gap: 1rem; }
  .dashboard-title { width: 100%; font-size: clamp(2rem, 10vw, 2.7rem); }
  .board-actions { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .5rem; }
  .board-actions button { min-height: 46px; padding: .7rem .55rem; border: 1px solid var(--line); border-radius: 10px; background: var(--panel-2); text-align: center; }
  .board-actions #addSessionButton { grid-column: 1 / -1; }
  .board-actions #deleteDashboardButton { color: #ff9a9a; }
  .sessions-board,
  .sessions-board.is-dense,
  .sessions-board.is-compact { display: grid; grid-template-columns: minmax(0, 1fr) !important; gap: 1rem; overflow: visible; }
  .sessions-board .session-card { grid-column: 1 !important; width: 100%; min-width: 0; padding: 1rem; border-radius: 18px; }
  .sessions-board .session-title,
  .sessions-board.is-dense .session-title,
  .sessions-board.is-compact .session-title { margin: .8rem 0 1rem; font-size: clamp(1.65rem, 9vw, 2.4rem); }
  .session-card.is-multi-column .session-exercises { grid-template-columns: minmax(0, 1fr); }
  .session-card.is-multi-column .emom-options { max-width: none; }
  .session-heading { gap: .4rem; }
  .session-type { max-width: min(190px, 55vw); }
  .clock span { display: none; }
  .exercise-row { grid-template-columns: minmax(0, 1fr) auto; }
  .exercise-detail { grid-column: 1; text-align: left; font-size: .85rem; }
  .exercise-actions { grid-column: 2; grid-row: 1; }
  .side-column { grid-template-columns: minmax(0, 1fr); }
  .jam-card { grid-template-columns: 1fr 112px; }
  .jam-qr { width: 112px; height: 112px; }
  .jam-qr img, .jam-qr canvas { width: 94px !important; height: 94px !important; }
  .now-playing-content { grid-template-columns: 112px minmax(0, 1fr); }
  .now-playing-content img { width: 112px; height: 132px; }
}

/* 16:9 TV / cast layout */
@media (min-width: 1200px) and (min-aspect-ratio: 16/10) {
  .shell { padding: 2vh 1.35vw; }
  .topbar { margin-bottom: 1.6vh; }
  h1 { font-size: clamp(2.6rem, 3.35vw, 4rem); }
  .menu-button, .icon-button { width: 42px; height: 42px; }
  .dashboard-grid { grid-template-columns: minmax(0, 1fr) 350px; gap: .85rem; }
  .board-heading { margin-bottom: .75rem; }
  .dashboard-title { font-size: clamp(1.65rem, 2.25vw, 2.6rem); }
  .active-dashboard-date { margin-top: .2rem; }
  .sessions-board { gap: .7rem; }
  .session-card { padding: 1rem; border-radius: 18px; }
  .session-title { margin: .65rem 0 .8rem; }
  .side-column { gap: .75rem; }
  .spotify-card, .jam-card { padding: 1rem; border-radius: 18px; }
  .now-playing { min-height: 112px; }
  .now-playing-content { grid-template-columns: 112px minmax(0, 1fr); min-height: 112px; }
  .now-playing-content img { width: 112px; height: 112px; }
  .now-playing-copy { padding: .75rem; }
  .queue-preview { margin-top: .65rem; padding: .65rem; }
  .queue-item img { width: 34px; height: 34px; }
  .queue-item { grid-template-columns: 34px minmax(0, 1fr); }
  .connect-tip { margin-top: .65rem; }
  .jam-card { grid-template-columns: minmax(0, 1fr) 110px; }
  .jam-qr { width: 110px; height: 110px; }
  .jam-qr img, .jam-qr canvas { width: 92px !important; height: 92px !important; }
}

html:fullscreen, html:fullscreen body { width: 100%; height: 100%; overflow: hidden; }
html:fullscreen .shell { min-height: 100vh; padding: 4vh 4vw; }
html:fullscreen .menu-button,
html:fullscreen .board-actions,
html:fullscreen .delete-session-button,
html:fullscreen .drag-handle,
html:fullscreen .delete-button,
html:fullscreen .bold-button,
html:fullscreen .color-button,
html:fullscreen .add-button,
html:fullscreen .spotify-heading .icon-button { display: none !important; }
html:fullscreen .brand-block { gap: 0; }
html:fullscreen h1 { font-size: clamp(3.4rem, 4.2vw, 5.4rem); }
html:fullscreen .dashboard-title { width: min(1400px, 90vw); max-width: 100%; font-size: clamp(2.2rem, 2.8vw, 3.5rem); }
html:fullscreen .dashboard-grid { grid-template-columns: minmax(0, 1fr) 360px; gap: 1.2rem; }
html:fullscreen .dashboard-grid.spotify-disabled { grid-template-columns: minmax(0, 1fr); }
html:fullscreen .sessions-board { gap: 1rem; }
html:fullscreen .session-card { padding: 1.35rem; }
html:fullscreen .session-title { font-size: clamp(1.65rem, 5.2cqi, 2.8rem); margin: .9rem 0 1.1rem; }
html:fullscreen .exercise-row { min-height: 64px; padding: .65rem .75rem; }
html:fullscreen .exercise-name { font-size: clamp(1.25rem, 4.4cqi, 1.6rem); line-height: 1.3; }
html:fullscreen .session-card .exercise-name.text-medium { font-size: clamp(1.15rem, 4cqi, 1.45rem); }
html:fullscreen .session-card .exercise-name.text-long { font-size: clamp(1.02rem, 3.5cqi, 1.25rem); line-height: 1.3; }
html:fullscreen .exercise-detail { font-size: 1rem; line-height: 1.3; }
html:fullscreen .exercise-detail.text-medium { font-size: .92rem; }
html:fullscreen .exercise-detail.text-long { font-size: .85rem; }
html:fullscreen .session-type { font-size: .8rem; }
html:fullscreen .exercise-minute { font-size: clamp(1.25rem, 4.4cqi, 1.6rem); }
html:fullscreen .session-card.is-emom .exercise-row:has(.exercise-name.text-medium) .exercise-minute { font-size: clamp(1.15rem, 4cqi, 1.45rem); }
html:fullscreen .session-card.is-emom .exercise-row:has(.exercise-name.text-long) .exercise-minute { font-size: clamp(1.02rem, 3.5cqi, 1.25rem); }
html:fullscreen .sessions-board { --exercise-font-size: clamp(1.15rem, 4cqi, 1.4rem); }
html:fullscreen .sessions-board.has-verbose-content { --exercise-font-size: clamp(1.05rem, 3.6cqi, 1.25rem); }
html:fullscreen .sessions-board.has-extreme-content { --exercise-font-size: clamp(.95rem, 3.2cqi, 1.12rem); }
html:fullscreen .session-card .exercise-name,
html:fullscreen .session-card .exercise-name.text-medium,
html:fullscreen .session-card .exercise-name.text-long,
html:fullscreen .session-card .exercise-detail,
html:fullscreen .session-card .exercise-detail.text-medium,
html:fullscreen .session-card .exercise-detail.text-long,
html:fullscreen .session-card .exercise-minute { font-size: var(--exercise-font-size); }
html:fullscreen .duration-help { display: none; }
html:fullscreen .emom-options { display: none !important; }
html.tv-mode .emom-options { display: none !important; }
html:fullscreen .topbar { margin-bottom: 2.5vh; }
html:fullscreen .board-heading { margin-bottom: 1.15rem; }

/* Keep individual long sessions inside the 16:9 fullscreen canvas. */
html:fullscreen .session-card.flow-columns .exercise-name,
html:fullscreen .session-card.flow-columns .exercise-detail {
  column-count: 2;
  column-gap: 1.1rem;
  column-rule: 1px solid rgba(255,255,255,.08);
}
html:fullscreen .session-card.auto-fit > * { zoom: var(--session-fit); }
