*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg-primary: #ffffff; --bg-secondary: #f5f5f3;
  --bg-overlay: rgba(0,0,0,0.45);
  --text-primary: #1a1a18; --text-secondary: #555; --text-tertiary: #999;
  --border: rgba(0,0,0,0.10); --border-md: rgba(0,0,0,0.20);
  --radius-md: 8px; --radius-lg: 14px;
  --accent-work: #E24B4A; --accent-short: #378ADD; --accent-long: #1D9E75;
}
[data-theme="dark"] {
  --bg-primary: #111110; --bg-secondary: #1c1c1a;
  --bg-overlay: rgba(0,0,0,0.7);
  --text-primary: #e8e8e4; --text-secondary: #888880; --text-tertiary: #555550;
  --border: rgba(255,255,255,0.07); --border-md: rgba(255,255,255,0.15);
  --accent-work: #e05050; --accent-short: #4080cc; --accent-long: #30a870;
}

html, body {
  min-height: 100%;
  background: var(--bg-primary);
  font-family: 'DM Mono', monospace;
  color: var(--text-primary);
  transition: background 0.3s, color 0.3s;
  font-size: 15px;
}
.page-wrap { display: flex; flex-direction: column; min-height: 100vh; }

/* ── TIMER GRID ── */
.timer-section {
  flex: 1;
  display: grid;
  grid-template-columns: 243px 1fr clamp(320px, calc(29px + 29.76vw), 600px);
  grid-template-rows: auto 1fr auto;
  transition: grid-template-columns 0.3s cubic-bezier(.4,0,.2,1);
}
.timer-section.task-panel-collapsed {
  grid-template-columns: 243px 1fr 36px;
}
.timer-section.left-panel-collapsed {
  grid-template-columns: 36px 1fr clamp(320px, calc(29px + 29.76vw), 600px);
}
.timer-section.task-panel-collapsed.left-panel-collapsed {
  grid-template-columns: 36px 1fr 36px;
}
@media (min-width: 979px) {
  .timer-section { min-height: 100vh; }
}
@media (max-width: 978px) {
  .timer-section { grid-template-columns: 1fr !important; transition: none; }
  .side-panel { display: none !important; }
}

/* ── TOP BAR ── */
.top-bar {
  grid-column: 1/-1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 2rem;
  border-bottom: 0.5px solid var(--border);
  gap: 14px;
  position: relative;
}
.brand-link {
  font-family: 'Fraunces', serif;
  font-weight: 700;
  font-size: 24px;
  letter-spacing: -0.01em;
  color: var(--text-primary);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}
.brand-link:hover { color: var(--accent-work); }

/* Desktop: tabs centered, gear right */
@media (min-width: 979px) {
  .mode-tabs { position: absolute; left: 50%; transform: translateX(-50%); }
  .top-right { margin-left: auto; }
}

/* Mobile: brand + gear on row 1, tabs on row 2 */
@media (max-width: 978px) {
  .top-bar { flex-wrap: wrap; padding: 0.9rem 1rem; gap: 10px; width: 100%; box-sizing: border-box; overflow: hidden; }
  .brand-link { flex: 1; font-size: 22px; }
  .top-right { flex-shrink: 0; }
  .mode-tabs { width: 100%; order: 3; max-width: 100%; box-sizing: border-box; }
}

/* ── MODE TABS ── */
.mode-tabs {
  display: flex;
  border: 0.5px solid var(--border-md);
  border-radius: var(--radius-md);
  overflow: hidden;
  flex-shrink: 0;
}
.mode-tab {
  flex: 0 0 auto;
  padding: 9px 20px;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-family: 'DM Mono', monospace;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
  border-right: 0.5px solid var(--border-md);
  text-align: center;
  white-space: nowrap;
}
.mode-tab:last-child { border-right: none; }
#tab-work.active  { background: var(--accent-work);  color: #fff; }
#tab-short.active { background: var(--accent-short); color: #fff; }
#tab-long.active  { background: var(--accent-long);  color: #fff; }

/* Mobile tabs: equal width, wrap text */
/* When cycles=0: only 2 tabs, make them 50% wider on desktop */
@media (min-width: 979px) {
  .mode-tabs.cycles-zero .mode-tab { padding: 9px 50px; }
}

@media (max-width: 978px) {
  .mode-tabs { width: 100%; flex: none; flex-shrink: 1; min-width: 0; }
  .mode-tab { flex: 1; min-width: 0; white-space: normal; line-height: 1.3; padding: 8px 4px; font-size: 11px; }
}
@media (max-width: 600px) { .mode-tab { padding: 8px 4px; } }

/* ── GEAR / SETTINGS BUTTON ── */
.top-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.gear-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px 7px 11px;
  border-radius: 20px;
  border: 0.5px solid var(--border-md);
  background: transparent;
  color: var(--text-secondary);
  font-size: 13px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  font-family: 'DM Mono', monospace;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.gear-btn i { font-size: 17px; transition: transform 0.4s; }
.gear-btn:hover { background: var(--bg-secondary); color: var(--text-primary); }
.gear-btn.open i { transform: rotate(60deg); }
.gear-btn.open { background: var(--bg-secondary); color: var(--text-primary); }

/* ── SETTINGS OVERLAY ── */
.settings-overlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  padding-top: 70px;
  padding-right: 2rem;
  pointer-events: none;
}
.settings-overlay.open { pointer-events: all; }
.settings-backdrop {
  position: fixed;
  inset: 0;
  background: var(--bg-overlay);
  opacity: 0;
  transition: opacity 0.25s;
  z-index: 0;
}
.settings-overlay.open .settings-backdrop { opacity: 1; }
.settings-panel {
  position: relative;
  z-index: 1;
  background: var(--bg-primary);
  border: 0.5px solid var(--border-md);
  border-radius: var(--radius-lg);
  width: 360px;
  max-height: calc(100vh - 84px);
  overflow-y: auto;
  box-shadow: 0 8px 40px rgba(0,0,0,0.18);
  transform: translateY(-12px) scale(0.97);
  opacity: 0;
  transition: transform 0.25s cubic-bezier(.34,1.26,.64,1), opacity 0.2s;
}
@media (max-width: 978px) {
  .settings-overlay { padding-top: 0; padding-right: 0; align-items: flex-end; justify-content: center; }
  .settings-panel { width: 100%; max-width: 100%; max-height: 88vh; border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
}
.settings-overlay.open .settings-panel { transform: translateY(0) scale(1); opacity: 1; }

.settings-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 1.4rem 0.85rem;
  border-bottom: 0.5px solid var(--border);
  position: sticky;
  top: 0;
  background: var(--bg-primary);
  z-index: 1;
}
.settings-title { font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-tertiary); }
.settings-close {
  border: none;
  background: none;
  cursor: pointer;
  color: var(--text-tertiary);
  font-size: 20px;
  display: flex;
  align-items: center;
  padding: 3px;
  border-radius: 4px;
  transition: color 0.15s;
}
.settings-close:hover { color: var(--text-primary); }
.settings-body { padding: 1.1rem 1.4rem; display: flex; flex-direction: column; gap: 1.4rem; }

/* Settings form elements */
.set-group { display: flex; flex-direction: column; gap: 10px; }
.set-group-label {
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding-bottom: 6px;
  border-bottom: 0.5px solid var(--border);
}
.srow { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.slabel { font-size: 13px; color: var(--text-secondary); letter-spacing: 0.02em; line-height: 1.5; }
.adj-wrap { display: flex; align-items: center; gap: 6px; }
.adj-btn {
  border: 0.5px solid var(--border-md);
  background: transparent;
  color: var(--text-secondary);
  width: 30px;
  height: 30px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 17px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
  flex-shrink: 0;
}
.adj-btn:hover { background: var(--bg-secondary); }
.val-num {
  font-family: 'Fraunces', serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--text-primary);
  min-width: 30px;
  text-align: center;
}
.toggle-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.toggle-label { font-size: 13px; color: var(--text-secondary); letter-spacing: 0.02em; }
.toggle { position: relative; width: 40px; height: 22px; flex-shrink: 0; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute;
  inset: 0;
  cursor: pointer;
  background: var(--border-md);
  border-radius: 22px;
  transition: background 0.2s;
}
.toggle-slider:before {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  left: 3px;
  top: 3px;
  background: white;
  border-radius: 50%;
  transition: transform 0.2s;
}
.toggle input:checked + .toggle-slider { background: var(--text-primary); }
.toggle input:checked + .toggle-slider:before { transform: translateX(18px); }

.select-sm {
  font-family: 'DM Mono', monospace;
  font-size: 13px;
  color: var(--text-primary);
  background: var(--bg-secondary);
  border: 0.5px solid var(--border-md);
  border-radius: var(--radius-md);
  padding: 5px 10px;
  cursor: pointer;
  outline: none;
}
.btn-action {
  border: 0.5px solid var(--border-md);
  background: transparent;
  color: var(--text-secondary);
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 9px 14px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.btn-action:hover { background: var(--bg-secondary); color: var(--text-primary); }
.btn-action.save { border-color: var(--accent-work); color: var(--accent-work); }
.btn-action.save:hover { background: var(--accent-work); color: #fff; }
.btn-action.danger { border-color: #aaa; }
.btn-action.danger:hover { background: var(--bg-secondary); color: var(--text-primary); }

/* Color scheme toggle */
.scheme-toggle {
  display: flex;
  border: 0.5px solid var(--border-md);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.scheme-opt {
  flex: 1;
  padding: 9px 12px;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: 'DM Mono', monospace;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.18s, color 0.18s;
  border-right: 0.5px solid var(--border-md);
}
.scheme-opt:last-child { border-right: none; }
.scheme-opt.active { background: var(--text-primary); color: var(--bg-primary); }

/* Character theme pills */
.char-theme-row { display: flex; gap: 7px; flex-wrap: wrap; }
.char-pill {
  padding: 6px 13px;
  border-radius: 20px;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: 'DM Mono', monospace;
  border: 0.5px solid var(--border-md);
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.18s, color 0.18s;
}
.char-pill:hover { background: var(--bg-secondary); color: var(--text-primary); }
.char-pill.active { background: var(--text-primary); color: var(--bg-primary); }

/* Notification help box */
.notif-help {
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.7;
  display: none;
}
.notif-help.visible { display: block; }
.notif-help strong { color: var(--text-primary); }

/* ── SIDE PANELS (desktop only) ── */
.side-panel {
  position: relative;
  padding: 1.75rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  border-right: 0.5px solid var(--border);
  overflow-y: auto;
  overflow-x: hidden;
  transition: padding 0.3s cubic-bezier(.4,0,.2,1);
}
.side-panel:not(.right) { grid-column: 1; grid-row: 2; }
.side-panel.right { border-right: none; border-left: 0.5px solid var(--border); grid-column: 3; grid-row: 2; }

/* Left panel collapsed state */
.left-panel-collapsed .side-panel:not(.right) {
  padding: 1.75rem 0;
  overflow: hidden;
  cursor: pointer;
}
.left-panel-collapsed .side-panel:not(.right) > *:not(.side-panel-collapsed-labels) {
  display: none;
}

/* Inline row: "Cycle Progress" label + collapse toggle button */
.side-panel-label-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 5px;
  margin-bottom: 2px;
}
.panel-label.side-panel-label-row {
  border-bottom: none;
  padding-bottom: 0;
}
.side-panel-label-text {
  flex: 1;
  padding-bottom: 7px;
  border-bottom: 0.5px solid var(--border);
}

/* Stacked vertical labels when collapsed */
.side-panel-collapsed-labels {
  display: none;
}
.left-panel-collapsed .side-panel-collapsed-labels {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}
.side-panel-expand-btn {
  border: none;
  background: none;
  color: var(--text-tertiary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 4px;
  font-size: 20px;
  flex-shrink: 0;
  margin-bottom: 6px;
  transition: color 0.15s;
}
.side-panel-expand-btn:hover { color: var(--text-primary); }
.side-panel-collapsed-label {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  border-right: 0.5px solid var(--border);
  padding-right: 7px;
  padding-top: 10px;
  padding-bottom: 10px;
  white-space: nowrap;
}
.side-panel-collapsed-label:last-child {
  border-right: none;
  padding-right: 0;
}

/* Toggle button — left panel */
.side-panel-toggle {
  border: none;
  background: none;
  color: var(--text-tertiary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 4px;
  font-size: 20px;
  flex-shrink: 0;
  transition: color 0.15s, transform 0.3s cubic-bezier(.4,0,.2,1);
}
.side-panel-toggle:hover { color: var(--text-primary); }
.left-panel-collapsed .side-panel-toggle {
  transform: rotate(180deg);
}
.stat-card { background: var(--bg-secondary); border-radius: var(--radius-md); padding: 12px 16px; }
.stat-val { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 700; color: var(--text-primary); line-height: 1; }
.stat-sub { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-tertiary); margin-top: 4px; }
.panel-label {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding-bottom: 7px;
  border-bottom: 0.5px solid var(--border);
  margin-bottom: 2px;
}

/* ── MOBILE STATS ── */
.mobile-stats {
  display: none;
  flex-direction: column;
  padding: 1.25rem 1.5rem;
  border-top: 0.5px solid var(--border);
  gap: 10px;
}
@media (max-width: 978px) { .mobile-stats { display: flex; } }
.mobile-stats-cards { display: flex; gap: 10px; }
.mobile-stats-cards .stat-card { flex: 1; }

/* ── CENTER PANEL ── */
.center-panel {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  padding: 2.5rem 1.36rem;
}
.clock-wrap {
  position: relative;
  width: min(44vw, 360px);
  height: min(44vw, 360px);
}
@media (max-width: 978px) { .clock-wrap { width: min(80vw, 300px); height: min(80vw, 300px); } }

.clock-svg { width: 100%; height: 100%; }
.track { fill: none; stroke: var(--border); stroke-width: 8; }
.progress-arc {
  fill: none;
  stroke-width: 8;
  stroke-linecap: round;
  transition: stroke-dashoffset 1s linear, stroke 0.4s ease;
}
.clock-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.time-display {
  font-family: 'Fraunces', serif;
  font-weight: 700;
  font-size: clamp(46px, 7.5vw, 88px);
  letter-spacing: -0.02em;
  color: var(--text-primary);
  line-height: 1;
}
.phase-label { font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-tertiary); }
.char-svg { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; overflow: visible; }

/* Controls */
.controls { display: flex; gap: 16px; align-items: center; }
.btn-main {
  width: 66px; height: 66px;
  border-radius: 50%;
  border: 0.5px solid var(--border-md);
  background: var(--text-primary);
  color: var(--bg-primary);
  font-size: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.1s;
}
.btn-main:active { transform: scale(0.93); }
.btn-sec {
  width: 46px; height: 46px;
  border-radius: 50%;
  border: 0.5px solid var(--border-md);
  background: transparent;
  color: var(--text-secondary);
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, transform 0.1s;
}
.btn-sec:hover { background: var(--bg-secondary); }
.btn-sec:active { transform: scale(0.93); }

/* ── DESCRIPTION SECTION ── */
.desc-section {
  border-top: 0.5px solid var(--border);
  background: var(--bg-secondary);
  padding: 3rem 2rem;
}
.desc-inner {
  max-width: 860px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem 3rem;
}
@media (max-width: 680px) { .desc-inner { grid-template-columns: 1fr; gap: 2rem 0; } }
.desc-block h1 {
  font-family: 'Fraunces', serif;
  font-weight: 700;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--text-primary);
  margin-bottom: 0.65rem;
}
.desc-block h2 {
  font-family: 'Fraunces', serif;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: -0.01em;
  color: var(--text-primary);
  margin-bottom: 0.65rem;
}
.desc-block h3 {
  font-family: 'Fraunces', serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: -0.01em;
  color: var(--text-primary);
  margin-top: 1.2rem;
  margin-bottom: 0.4rem;
}
.desc-block p, .desc-block li { font-size: 14px; line-height: 1.85; color: var(--text-secondary); letter-spacing: 0.01em; }
.desc-block ul { padding-left: 1.2em; display: flex; flex-direction: column; gap: 5px; }
.desc-block li::marker { color: var(--text-tertiary); }
.desc-tag {
  display: inline-block;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin-bottom: 6px;
}
.desc-full { grid-column: 1/-1; }
@media (max-width: 680px) { .desc-full { grid-column: 1; } }

.site-footer {
  border-top: 0.5px solid var(--border);
  padding: 1.1rem 2rem;
  text-align: center;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}
.site-footer a {
  color: inherit;
  text-decoration: none;
  transition: color 0.15s;
}
.site-footer a:hover { color: var(--text-primary); }

/* ── TOAST ── */
.toast {
  position: fixed;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--text-primary);
  color: var(--bg-primary);
  padding: 10px 24px;
  border-radius: var(--radius-md);
  font-size: 13px;
  letter-spacing: 0.06em;
  opacity: 0;
  transition: opacity 0.3s, transform 0.3s;
  white-space: nowrap;
  pointer-events: none;
  z-index: 200;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* Privacy policy page */
.policy-page { min-height: 100vh; background: var(--bg-primary); }
.policy-top-bar { justify-content: space-between; }
.policy-back-link {
  display: flex;
  align-items: center;
  gap: 7px;
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 0.5px solid var(--border-md);
  border-radius: 20px;
  padding: 7px 14px 7px 11px;
  transition: background 0.15s, color 0.15s;
}
.policy-back-link:hover { background: var(--bg-secondary); color: var(--text-primary); }
.policy-main {
  width: min(100%, 860px);
  margin: 0 auto;
  padding: 4rem 2rem 5rem;
}
.policy-main h1 {
  font-family: 'Fraunces', serif;
  font-size: clamp(42px, 8vw, 76px);
  line-height: 1;
  color: var(--text-primary);
  margin-bottom: 0.7rem;
}
.policy-updated {
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin-bottom: 3rem;
}
.policy-main section {
  border-top: 0.5px solid var(--border);
  padding: 1.6rem 0;
}
.policy-main h2 {
  font-family: 'Fraunces', serif;
  font-size: 22px;
  line-height: 1.25;
  margin-bottom: 0.75rem;
}
.policy-main p {
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.85;
  letter-spacing: 0.01em;
  margin-bottom: 0.85rem;
}
.policy-main p:last-child { margin-bottom: 0; }
.policy-main a {
  color: var(--accent-long);
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
@media (max-width: 680px) {
  .policy-main { padding: 3rem 1.2rem 4rem; }
  .policy-back-link { padding-right: 11px; }
}
/* ════════════════════════════════════════════
   TASK LIST  (append to styles.css)
   ════════════════════════════════════════════ */

/* ── Task panel (right side, desktop) ── */
.task-panel {
  position: relative;
  padding: 1.75rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  border-left: 0.5px solid var(--border);
  grid-column: 3;
  grid-row: 2;
  overflow-y: auto;
  overflow-x: hidden;
  min-height: 0;
  transition: padding 0.3s cubic-bezier(.4,0,.2,1);
}

/* Collapsed state — narrow tab, content hidden */
.task-panel-collapsed .task-panel {
  padding: 1.75rem 0;
  overflow: hidden;
  cursor: pointer;
}
.task-panel-collapsed .task-panel > *:not(.task-panel-header) {
  display: none;
}
/* task-empty gets display:block via inline style from tasks.js — need !important to override */
.task-panel-collapsed .task-panel #taskEmpty {
  display: none !important;
}
.task-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}
.task-panel-collapsed .task-panel-header {
  flex-direction: column-reverse;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  width: 36px;
  padding: 0;
}
.task-panel-toggle {
  border: none;
  background: none;
  color: var(--text-tertiary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3px;
  border-radius: 4px;
  font-size: 20px;
  flex-shrink: 0;
  transition: color 0.15s, transform 0.3s cubic-bezier(.4,0,.2,1);
}
.task-panel-toggle:hover { color: var(--text-primary); }
.task-panel-collapsed .task-panel-toggle {
  transform: rotate(180deg);
}

/* "Tasks" label — rotated when collapsed */
.task-panel .panel-label {
  flex: 1;
  transition: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border-bottom: 0.5px solid var(--border);
  padding-bottom: 7px;
  margin-bottom: 2px;
}
.task-panel-collapsed .task-panel .panel-label {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  border-bottom: none;
  border-right: 0.5px solid var(--border);
  padding-bottom: 0;
  padding-right: 7px;
  margin-bottom: 0;
  margin-right: 2px;
  flex: none;
  letter-spacing: 0.2em;
}

/* On mobile the task panel is hidden from the grid; shown in .mobile-tasks instead */
@media (max-width: 978px) {
  .task-panel { display: none !important; }
}

/* ── Mobile task section (below controls / mobile-stats) ── */
.mobile-tasks {
  display: none;
  flex-direction: column;
  padding: 1.25rem 1.5rem;
  border-top: 0.5px solid var(--border);
  gap: 1rem;
}
@media (max-width: 978px) { .mobile-tasks { display: flex; } }

/* ── Shared inner task UI (used in both panels) ── */
.task-input-row {
  display: flex;
  gap: 7px;
  align-items: center;
}

.task-input {
  flex: 1;
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  color: var(--text-primary);
  background: var(--bg-secondary);
  border: 0.5px solid var(--border-md);
  border-radius: var(--radius-md);
  padding: 8px 11px;
  outline: none;
  transition: border-color 0.15s;
  letter-spacing: 0.02em;
}
.task-input::placeholder { color: var(--text-tertiary); }
.task-input:focus { border-color: var(--accent-work); }

.task-add-btn {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 0.5px solid var(--border-md);
  background: var(--text-primary);
  color: var(--bg-primary);
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform 0.1s, background 0.15s;
}
.task-add-btn:hover { background: var(--accent-work); border-color: var(--accent-work); }
.task-add-btn:active { transform: scale(0.9); }

/* ── Task list ── */
.task-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 0;
  margin: 0;
}

.task-item {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 10px 8px 6px;
  border-radius: var(--radius-md);
  border: 0.5px solid var(--border);
  background: var(--bg-secondary);
  cursor: default;
  transition: background 0.15s, opacity 0.2s, border-color 0.2s;
  user-select: none;
  min-width: 0;
}
.task-item:hover { background: var(--bg-secondary); border-color: var(--border-md); }

/* Active (top unchecked) task gets a subtle accent left-border */
.task-item.task-active {
  border-left: 2.5px solid var(--accent-work);
  padding-left: 5px;
}

/* Done tasks fade */
.task-item.task-done {
  opacity: 0.45;
}
.task-item.task-done .task-text {
  text-decoration: line-through;
  color: var(--text-tertiary);
}

/* Drag states */
.task-item.task-dragging {
  opacity: 0.35;
}
.task-item.task-drag-over {
  border-color: var(--accent-work);
  background: var(--bg-primary);
}

/* ── Drag handle ── */
.task-drag-handle {
  color: var(--text-tertiary);
  font-size: 14px;
  cursor: grab;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  opacity: 0.5;
  transition: opacity 0.15s;
}
.task-item:hover .task-drag-handle { opacity: 1; }
.task-drag-handle:active { cursor: grabbing; }

/* ── Custom checkbox ── */
.task-check-wrap {
  position: relative;
  width: 17px;
  height: 17px;
  flex-shrink: 0;
  cursor: pointer;
}
.task-checkbox {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.task-checkmark {
  position: absolute;
  inset: 0;
  border: 0.5px solid var(--border-md);
  border-radius: 4px;
  background: transparent;
  transition: background 0.15s, border-color 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.task-checkmark::after {
  content: '';
  display: none;
  width: 4px;
  height: 8px;
  border: 1.5px solid var(--bg-primary);
  border-top: none;
  border-left: none;
  transform: rotate(45deg) translate(-1px, -1px);
}
.task-checkbox:checked + .task-checkmark {
  background: var(--text-primary);
  border-color: var(--text-primary);
}
.task-checkbox:checked + .task-checkmark::after { display: block; }

/* ── Task text ── */
.task-text {
  flex: 1;
  font-size: 12px;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
  line-height: 1.4;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  cursor: text;
}
.task-text:hover {
  color: var(--text-primary);
}

/* ── Inline edit input ── */
.task-edit-input {
  flex: 1;
  min-width: 0;
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  color: var(--text-primary);
  background: var(--bg-primary);
  border: none;
  border-bottom: 1px solid var(--accent-work);
  outline: none;
  padding: 0 2px;
  letter-spacing: 0.02em;
  line-height: 1.4;
}
.task-item.task-editing {
  background: var(--bg-primary);
  border-color: var(--accent-work);
}

/* ── Session badge ── */
.task-session-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  min-width: 20px;
  font-family: 'Fraunces', serif;
  font-weight: 700;
  font-size: 11px;
  line-height: 1;
  color: var(--accent-work);
  background: transparent;
  border: 0.5px solid var(--accent-work);
  border-radius: 20px;
  padding: 2px 6px;
  opacity: 1;
  white-space: nowrap;
  letter-spacing: 0;
  pointer-events: none;
}
.task-done .task-session-badge {
  color: var(--text-secondary);
  border-color: var(--text-secondary);
  opacity: 1;
}
.task-done-divider {
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 6px 0 2px;
  border-top: 0.5px solid var(--border);
  margin-top: 4px;
  list-style: none;
}

/* ── Completed section (below input) ── */
.task-done-section {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-top: 10px;
  border-top: 0.5px solid var(--border);
  margin-top: 4px;
}
.task-done-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.task-done-label {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}
.task-clear-btn {
  border: none;
  background: none;
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 4px;
  transition: color 0.15s, background 0.15s;
}
.task-clear-btn:hover {
  color: var(--accent-work);
  background: var(--bg-secondary);
}

/* ── Delete button ── */
.task-delete {
  border: none;
  background: none;
  color: var(--text-tertiary);
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2px;
  border-radius: 3px;
  opacity: 0;
  transition: opacity 0.15s, color 0.15s;
  flex-shrink: 0;
}
.task-item:hover .task-delete { opacity: 1; font-size: 15px; font-weight: 700; }
.task-item.task-selected .task-delete { opacity: 1; font-size: 15px; font-weight: 700; }
.task-delete:hover { color: var(--accent-work); }

/* ── Empty state ── */
.task-empty {
  font-size: 11px;
  color: var(--text-tertiary);
  letter-spacing: 0.08em;
  text-align: center;
  padding: 10px 0 4px;
  text-transform: uppercase;
  line-height: 1.6;
}

/* ── Active task callout (tiny label above list) ── */
.task-active-row {
  display: flex;
  align-items: baseline;
  gap: 6px;
  font-size: 11px;
  color: var(--text-tertiary);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  min-height: 16px;
}
.task-active-name {
  color: var(--accent-work);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: none;
  font-family: 'DM Mono', monospace;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 160px;
}

/* ── Panel button group (pop-out + mute, desktop left panel) ── */
.panel-btn-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* ── Pop-out mini timer button ── */
.popout-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 7px 12px 7px 10px;
  border-radius: var(--radius-md);
  border: 0.5px solid var(--border-md);
  background: transparent;
  color: var(--text-tertiary);
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.2s;
  white-space: nowrap;
  width: 100%;
  margin-top: 6px;
}
.popout-btn i { font-size: 14px; flex-shrink: 0; }
.popout-btn:hover {
  background: var(--bg-secondary);
  color: var(--text-primary);
}
.popout-btn.active {
  border-color: var(--accent-work);
  color: var(--accent-work);
  background: transparent;
}
.popout-btn.active:hover {
  background: var(--bg-secondary);
}
/* Hidden on mobile/tablet — the side panel itself is already hidden there */
@media (max-width: 978px) {
  .popout-btn { display: none; }
}


/* Inherits .popout-btn base styles; overrides for muted (red) state */
.mute-ambient-btn.muted {
  border-color: var(--accent-work);
  color: var(--accent-work);
  background: transparent;
}
.mute-ambient-btn.muted:hover {
  background: var(--bg-secondary);
}
/* Mobile version is always shown (not hidden at ≤978px like .popout-btn) */
.mute-ambient-mobile {
  display: none; /* shown via .mute-ambient-visible class set by JS */
}
@media (max-width: 978px) {
  .mute-ambient-mobile.mute-ambient-visible {
    /* Only show when JS has confirmed ambient sounds are enabled */
    display: flex;
    margin-top: 10px;
    width: 100%;
  }
}
