/* TailorTimeTracker — atelier-warm palette w/ playful accents */
:root {
  --bg: #FBF3E7;
  --bg-warm: #FFF7EF;
  --surface: #FFFFFF;
  --surface-2: #FFFBF5;
  --ink: #1E1A18;
  --ink-2: #4A413B;
  --muted: #8A7C72;
  --line: #EBE0D1;
  --line-soft: #F3EADC;

  --peach: #D08A66;
  --peach-deep: #A85F3F;
  --peach-soft: #F4DBC9;

  --mint: #7FCFC0;
  --mint-deep: #3C9B8A;
  --mint-soft: #DBF1EC;

  --lavender: #A9C5A0;
  --lavender-deep: #6A9961;
  --lavender-soft: #E3F0DD;

  --pink: #FF7FB6;
  --pink-soft: #FFE0EE;

  --yellow: #F4C84B;
  --yellow-soft: #FFF1C8;

  --sky: #7AC6F2;
  --sky-soft: #DCF0FB;

  --r-sm: 10px;
  --r: 16px;
  --r-lg: 22px;
  --r-xl: 30px;

  --shadow-sm: 0 1px 0 rgba(30,26,24,.04), 0 2px 8px -2px rgba(120,80,40,.06);
  --shadow: 0 1px 0 rgba(30,26,24,.04), 0 12px 30px -14px rgba(120,80,40,.18), 0 4px 14px -6px rgba(120,80,40,.10);
  --shadow-lg: 0 1px 0 rgba(30,26,24,.04), 0 30px 60px -30px rgba(120,80,40,.30), 0 10px 30px -12px rgba(120,80,40,.18);

  --font-display: "Cormorant Garamond", Georgia, serif;
  --font-ui: "Inter", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --font-data: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --ease-spring: cubic-bezier(.34, 1.56, .64, 1);
  --ease-smooth: cubic-bezier(.22, 1, .36, 1);
  --ease-snap: cubic-bezier(.5, 0, .15, 1.4);
  --anim: 1;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-ui);
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  letter-spacing: -0.005em;
  min-height: 100vh;
  background-image:
    radial-gradient(circle at 0% 0%, rgba(208,138,102,.10), transparent 45%),
    radial-gradient(circle at 100% 10%, rgba(169,197,160,.12), transparent 40%),
    radial-gradient(circle at 50% 100%, rgba(127,207,192,.10), transparent 45%);
  background-attachment: fixed;
}

.mono { font-family: var(--font-mono); }
button { font: inherit; color: inherit; cursor: pointer; }
em { font-style: normal; }
input, select, textarea { font: inherit; color: inherit; }
input[type="text"], input[type="number"], textarea, select {
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--peach);
  box-shadow: 0 0 0 4px rgba(208,138,102,.15);
}

.app { max-width: 1440px; margin: 0 auto; padding: 24px 28px 80px; }

/* Top bar */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 8px; margin-bottom: 22px;
}
.brand { display: flex; align-items: center; gap: 12px; font-family: var(--font-display); font-size: 32px; letter-spacing: -0.01em; line-height: 1.1; }
.brand-mark { width: 192px; height: 192px; object-fit: contain; background: transparent; padding: 0; }
.brand em { color: var(--peach-deep); }

.view-switch {
  display: inline-flex; background: var(--surface); border: 1px solid var(--line);
  border-radius: 999px; padding: 4px; position: relative; box-shadow: var(--shadow-sm);
}
.view-switch button {
  position: relative; border: 0; background: transparent; padding: 9px 18px;
  font-weight: 600; font-size: 14px; color: var(--muted); border-radius: 999px;
  transition: color .25s var(--ease-smooth); z-index: 1;
}
.view-switch button.is-active { color: white; }
.view-switch button svg { vertical-align: -3px; margin-right: 6px; }
.view-switch .pill {
  position: absolute; top: 4px; bottom: 4px; border-radius: 999px;
  background: linear-gradient(135deg, var(--peach), var(--peach-deep));
  transition: left calc(.45s * var(--anim)) var(--ease-spring), width calc(.45s * var(--anim)) var(--ease-spring);
  box-shadow: 0 6px 14px -6px rgba(168,95,63,.6);
}
.view-switch.admin .pill {
  background: linear-gradient(135deg, var(--lavender), var(--lavender-deep));
  box-shadow: 0 6px 14px -6px rgba(106,153,97,.6);
}

.identity {
  display: flex; align-items: center; gap: 10px; background: var(--surface);
  border: 1px solid var(--line); padding: 6px 12px 6px 6px;
  border-radius: 999px; box-shadow: var(--shadow-sm);
}
.avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: linear-gradient(135deg, var(--peach-soft), var(--peach));
  color: white; font-weight: 700; display: grid; place-items: center;
  font-size: 13px; letter-spacing: 0; flex-shrink: 0;
}
.identity .name { font-weight: 600; font-size: 14px; }
.identity .role { color: var(--muted); font-size: 12px; }

/* Cards */
.card {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: 22px; box-shadow: var(--shadow-sm);
}
.card-title { font-family: var(--font-display); font-weight: 600; font-size: 26px; line-height: 1.15; margin: 0 0 4px; letter-spacing: -0.01em; }
.card-sub { font-size: 13px; color: var(--muted); margin: 0; }
.section-eyebrow { text-transform: uppercase; letter-spacing: .18em; font-size: 11px; color: var(--muted); font-weight: 700; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: 0; border-radius: 12px; padding: 10px 16px; font-weight: 600; font-size: 14px;
  background: var(--surface); color: var(--ink); border: 1px solid var(--line);
  transition: transform .18s var(--ease-spring), box-shadow .2s, background .2s, color .2s, border-color .2s;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.btn:active { transform: translateY(0) scale(.98); }
.btn.primary { background: linear-gradient(135deg, var(--peach), var(--peach-deep)); color: white; border-color: transparent; box-shadow: 0 8px 20px -10px rgba(168,95,63,.7); }
.btn.primary:hover { box-shadow: 0 12px 24px -10px rgba(168,95,63,.7); }
.btn.mint { background: linear-gradient(135deg, var(--mint), var(--mint-deep)); color: white; border-color: transparent; box-shadow: 0 8px 20px -10px rgba(60,155,138,.6); }
.btn.ghost { background: transparent; border-color: var(--line); color: var(--ink-2); }
.btn.ghost:hover { background: var(--surface); }
.btn.danger { color: #C44; background: white; border-color: var(--pink-soft); }
.btn.pill { border-radius: 999px; padding: 8px 14px; }
.btn.sm { padding: 7px 11px; font-size: 13px; border-radius: 10px; }
.btn.icon { padding: 8px; width: 36px; height: 36px; }
.btn:disabled { opacity: .5; pointer-events: none; }

/* Chips */
.chip {
  display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px;
  border-radius: 999px; background: var(--surface-2); border: 1px solid var(--line);
  font-size: 12px; font-weight: 600; color: var(--ink-2); white-space: nowrap;
}
.chip .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--muted); }
.chip.assigned { background: var(--lavender-soft); border-color: transparent; color: var(--lavender-deep); }
.chip.assigned .dot { background: var(--lavender-deep); }
.chip.accepted { background: var(--sky-soft); border-color: transparent; color: #2A7FB2; }
.chip.accepted .dot { background: #2A7FB2; }
.chip.running { background: var(--mint-soft); border-color: transparent; color: var(--mint-deep); }
.chip.running .dot { background: var(--mint-deep); animation: livedot 1.2s ease-in-out infinite; }
.chip.paused { background: var(--yellow-soft); border-color: transparent; color: #8C7008; }
.chip.paused .dot { background: #C99908; }
.chip.done { background: #E7F6E5; border-color: transparent; color: #2C7A2C; }
.chip.done .dot { background: #2C7A2C; }
.chip.archived { background: #EEE; border-color: transparent; color: #777; }
.chip.archived .dot { background: #999; }

@keyframes livedot {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(60,155,138,.6); }
  50% { transform: scale(1.25); box-shadow: 0 0 0 5px rgba(60,155,138,0); }
}

/* Layout helpers */
.row { display: flex; gap: 12px; align-items: center; }
.col { display: flex; flex-direction: column; gap: 12px; }
.spread { display: flex; justify-content: space-between; align-items: center; }
.grow { flex: 1; }
.hr { height: 1px; background: var(--line); margin: 14px 0; border: 0; }

/* Tailor view grid */
.tailor-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 20px; }
@media (max-width: 1000px) { .tailor-grid { grid-template-columns: 1fr; } }

/* Timer hero */
.timer-hero {
  position: relative; overflow: hidden;
  background: radial-gradient(circle at 80% 0%, rgba(208,138,102,.10), transparent 50%),
              radial-gradient(circle at 0% 100%, rgba(127,207,192,.10), transparent 55%),
              var(--surface);
  padding: 28px; border-radius: var(--r-xl); border: 1px solid var(--line); box-shadow: var(--shadow);
}
.timer-hero .product-eyebrow { display: flex; align-items: baseline; gap: 10px; font-family: var(--font-display); font-size: 14px; color: var(--muted); }
.timer-hero h1 { font-family: var(--font-display); font-size: clamp(36px, 5vw, 56px); line-height: 1.05; margin: 6px 0 0; letter-spacing: -0.025em; }
.timer-hero h1 em { color: var(--peach-deep); }

.timer-ring-wrap { position: relative; display: grid; place-items: center; width: 280px; height: 280px; margin: 20px auto 8px; }
.timer-ring-wrap svg { width: 100%; height: auto; max-width: 280px; }
.timer-digits { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; pointer-events: none; text-align: center; }
.timer-digits .big { font-family: var(--font-mono); font-size: 52px; font-weight: 600; line-height: 1; letter-spacing: -0.02em; color: var(--ink); font-variant-numeric: tabular-nums; }
.timer-digits .pace { margin-top: 8px; font-size: 12px; color: var(--muted); font-weight: 600; text-transform: uppercase; letter-spacing: .12em; }
.timer-digits .pace b { font-family: var(--font-mono); color: var(--ink-2); text-transform: none; letter-spacing: -0.01em; font-weight: 600; }

.ring-pulse { position: absolute; inset: -8px; border-radius: 50%; border: 2px solid var(--mint); opacity: 0; animation: ringpulse calc(2.2s * var(--anim)) ease-out infinite; }
@keyframes ringpulse { 0% { transform: scale(.92); opacity: 0.5; } 100% { transform: scale(1.04); opacity: 0; } }

/* Timer controls */
.timer-controls { display: flex; gap: 10px; justify-content: center; margin-top: 14px; }
.play-btn {
  width: 64px; height: 64px; border-radius: 50%; border: 0;
  background: linear-gradient(135deg, var(--mint), var(--mint-deep)); color: white;
  display: grid; place-items: center;
  box-shadow: 0 12px 28px -10px rgba(60,155,138,.6);
  transition: transform .25s var(--ease-spring), box-shadow .2s;
}
.play-btn:hover { transform: translateY(-2px) scale(1.04); }
.play-btn:active { transform: scale(.96); }
.play-btn.running { background: linear-gradient(135deg, var(--peach), var(--peach-deep)); box-shadow: 0 12px 28px -10px rgba(168,95,63,.6); }
.play-btn svg { width: 24px; height: 24px; }

/* Subtask list */
.subtasks { margin-top: 10px; display: flex; flex-direction: column; gap: 6px; }
.subtask {
  display: grid; grid-template-columns: 18px 1fr auto auto; gap: 10px; align-items: center;
  padding: 8px 10px; border-radius: 10px; font-size: 13px; transition: background .2s;
}
.subtask:hover { background: var(--surface-2); }
.subtask.done { color: var(--muted); }
.subtask.done .subtask-label { text-decoration: line-through; }
.checkbox {
  width: 18px; height: 18px; border-radius: 6px; border: 1.5px solid var(--line);
  background: var(--surface); display: grid; place-items: center;
  padding: 0; margin: 0; line-height: 0; appearance: none; -webkit-appearance: none;
  transition: background .2s var(--ease-spring), border-color .2s, transform .2s var(--ease-spring); flex-shrink: 0;
}
.checkbox.is-checked { background: var(--mint); border-color: var(--mint); }
.checkbox svg { opacity: 0; transform: scale(.5); transition: opacity .2s, transform .25s var(--ease-spring); color: white; display: block; }
.checkbox.is-checked svg { opacity: 1; transform: scale(1); }
.subtask-label { font-weight: 500; }
.subtask-time { font-family: var(--font-mono); font-size: 12px; color: var(--muted); }
.subtask.is-active { background: var(--mint-soft); }
.subtask.is-active .subtask-label { color: var(--mint-deep); font-weight: 600; }
.subtask-play {
  width: 24px; height: 24px; border-radius: 50%; border: 0;
  background: var(--peach-soft); color: var(--peach-deep); display: grid; place-items: center;
  transition: background .2s, transform .2s var(--ease-spring);
}
.subtask-play:hover { background: var(--peach); color: white; transform: scale(1.1); }
.subtask.is-active .subtask-play { background: var(--mint); color: white; animation: pulse-bg 1.6s ease-in-out infinite; }
@keyframes pulse-bg { 50% { background: var(--mint-deep); } }
.subtask-actions { display: inline-flex; gap: 4px; align-items: center; }

/* Progress bars */
.bar { height: 6px; background: var(--line-soft); border-radius: 999px; overflow: hidden; position: relative; }
.bar > span { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--peach), var(--peach-deep)); border-radius: 999px; transition: width .6s var(--ease-smooth); }
.bar.mint > span { background: linear-gradient(90deg, var(--mint), var(--mint-deep)); }
.bar.over > span { background: linear-gradient(90deg, var(--pink), #E0457E); }

/* Queue card */
.queue-card .head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 14px; }
.queue-list { display: flex; flex-direction: column; gap: 10px; }
.queue-item {
  display: grid; grid-template-columns: 36px 1fr auto; gap: 12px; align-items: center;
  padding: 10px 12px; border: 1px solid var(--line); background: var(--surface);
  border-radius: 14px; transition: transform .2s var(--ease-spring), border-color .2s; cursor: pointer;
}
.queue-item:hover { transform: translateY(-1px); border-color: var(--peach-soft); }
.queue-thumb {
  width: 36px; height: 36px; border-radius: 10px; background: var(--lavender-soft);
  display: grid; place-items: center; font-family: var(--font-display); color: var(--lavender-deep); font-size: 16px;
}

/* Stat grid */
.stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.stat-box { padding: 16px; border-radius: var(--r); border: 1px solid var(--line); background: var(--surface); }
.stat-label { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .14em; font-weight: 700; }
.stat-value { font-family: var(--font-data); font-size: 28px; font-weight: 600; margin-top: 6px; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; line-height: 1.1; }
.stat-delta { font-size: 12px; color: var(--mint-deep); font-weight: 600; margin-top: 4px; }
.stat-delta.over { color: var(--peach-deep); }

/* Sparkline */
.spark { display: block; width: 100%; height: 28px; margin-top: 8px; }

/* Admin tabs */
.admin-tabs {
  display: inline-flex; gap: 4px; background: var(--surface); border: 1px solid var(--line);
  padding: 4px; border-radius: 14px; box-shadow: var(--shadow-sm);
}
.admin-tabs button {
  border: 0; background: transparent; padding: 9px 14px; font-weight: 600; font-size: 13px;
  color: var(--muted); border-radius: 10px; display: flex; align-items: center; gap: 7px;
  transition: background .2s, color .2s; position: relative;
}
.admin-tabs button .count { font-size: 11px; padding: 1px 7px; border-radius: 999px; background: var(--peach-soft); color: var(--peach-deep); font-weight: 700; }
.admin-tabs button.is-active { background: var(--ink); color: white; }
.admin-tabs button.is-active .count { background: rgba(255,255,255,.18); color: white; }
.admin-tabs button:not(.is-active):hover { color: var(--ink); }

/* Dashboard */
.dashboard-toolbar { display: flex; justify-content: space-between; align-items: center; margin: 18px 0 14px; gap: 12px; flex-wrap: wrap; }
.dash-grid { display: grid; gap: 18px; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }
.dash-grid.cozy { grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); gap: 22px; }
.dash-grid.compact { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; }

.tailor-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 18px; position: relative; overflow: hidden;
  transition: transform .25s var(--ease-spring), box-shadow .25s, border-color .25s;
}
.tailor-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.tailor-card.running { border-color: var(--mint); }
.tailor-card.running::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--mint), var(--mint-deep), var(--mint));
  background-size: 200% 100%; animation: slide-bg 2.5s linear infinite;
}
@keyframes slide-bg { to { background-position: -200% 0; } }
.tailor-card.paused { border-color: var(--yellow); }
.tailor-card.idle { opacity: .92; }

.tcard-head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.tcard-avatar { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(135deg, var(--peach), var(--peach-deep)); color: white; font-weight: 700; display: grid; place-items: center; font-size: 15px; flex-shrink: 0; }
.tcard-name { font-weight: 700; font-size: 15px; }
.tcard-loc { font-size: 12px; color: var(--muted); }
.tcard-task { font-family: var(--font-display); font-size: 22px; line-height: 1.15; letter-spacing: -.01em; }
.tcard-sub { color: var(--muted); font-size: 13px; margin-top: 3px; }
.tcard-timer-row { display: flex; align-items: center; gap: 12px; margin: 14px 0 10px; }
.tcard-time { font-family: var(--font-mono); font-size: 28px; font-weight: 600; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.tcard-time.running { color: var(--mint-deep); }
.tcard-time.paused { color: #8C7008; }
.tcard-time.idle { color: var(--muted); }
.tcard-actions { display: flex; gap: 6px; margin-top: 12px; flex-wrap: wrap; }

/* Mini open-ended */
.mini-openended { position: relative; display: grid; place-items: center; flex-shrink: 0; }
.mini-openended .mini-core { width: 60%; height: 60%; border-radius: 50%; background: radial-gradient(circle, rgba(127,207,192,0.7) 0%, rgba(127,207,192,0) 70%); }
.mini-openended[data-state="running"] .mini-core { animation: oe-breathe 2.4s ease-in-out infinite; }
.mini-openended[data-state="paused"] .mini-core { background: radial-gradient(circle, rgba(196,153,8,0.5) 0%, rgba(196,153,8,0) 70%); }
.mini-openended .mini-ripple { position: absolute; width: 100%; height: 100%; border-radius: 50%; border: 1.5px solid var(--mint-deep); opacity: 0; animation: mini-ripple 2.4s ease-out infinite; }
@keyframes mini-ripple { 0% { transform: scale(0.4); opacity: 0.7; } 100% { transform: scale(1.0); opacity: 0; } }

/* Catalog */
.catalog-grid { display: grid; gap: 18px; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); margin-top: 14px; }
.product-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 18px; transition: transform .25s var(--ease-spring), box-shadow .25s; }
.product-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.product-card h3 { font-family: var(--font-display); font-size: 26px; margin: 0; letter-spacing: -.01em; line-height: 1.1; }
.product-card .sku { color: var(--muted); font-size: 12px; font-family: var(--font-mono); }
.product-thumb { width: 100%; height: 110px; border-radius: var(--r); margin-bottom: 12px; position: relative; overflow: hidden; }
.product-thumb svg { position: absolute; inset: 0; width: 100%; height: 100%; }

/* Requests */
.req-list { display: flex; flex-direction: column; gap: 12px; margin-top: 14px; }
.req-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 18px;
  display: grid; grid-template-columns: auto 1fr auto; gap: 18px; align-items: center;
  transition: opacity .35s, transform .35s var(--ease-smooth);
}
.req-card.dismissing { opacity: 0; transform: translateX(20px); }
.req-delta { font-family: var(--font-mono); font-size: 22px; font-weight: 600; letter-spacing: -.02em; padding: 12px 14px; border-radius: var(--r); }
.req-delta.add { background: var(--mint-soft); color: var(--mint-deep); }
.req-delta.sub { background: var(--pink-soft); color: #C44A82; }
.req-meta .who { font-weight: 600; }
.req-meta .what { color: var(--muted); font-size: 13px; margin-top: 2px; }
.req-meta .reason { background: var(--surface-2); padding: 10px 12px; border-radius: 10px; margin-top: 8px; border-left: 3px solid var(--peach); font-size: 13px; color: var(--ink-2); }

/* Assign */
.assign-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 14px; }
@media (max-width: 1000px) { .assign-layout { grid-template-columns: 1fr; } }
.tailor-pick { display: flex; gap: 10px; flex-wrap: wrap; }
.tailor-chip {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px 8px 8px;
  background: var(--surface); border: 1px solid var(--line); border-radius: 999px;
  cursor: pointer; transition: transform .2s var(--ease-spring), border-color .2s, background .2s;
}
.tailor-chip:hover { transform: translateY(-1px); border-color: var(--peach); }
.tailor-chip.is-selected { background: var(--peach-soft); border-color: var(--peach); }
.tailor-chip .avatar { width: 24px; height: 24px; font-size: 11px; }
.tailor-chip .load { font-size: 11px; color: var(--muted); }
.product-pick { display: flex; flex-direction: column; gap: 8px; max-height: 420px; overflow: auto; padding-right: 6px; }
.product-pick::-webkit-scrollbar { width: 8px; }
.product-pick::-webkit-scrollbar-thumb { background: var(--line); border-radius: 999px; }
.product-pick-item {
  display: grid; grid-template-columns: 36px 1fr auto; gap: 12px; align-items: center;
  padding: 10px; border: 1px solid var(--line); border-radius: var(--r); background: var(--surface);
  transition: border-color .2s, background .2s, transform .2s var(--ease-spring); cursor: pointer;
}
.product-pick-item:hover { transform: translateY(-1px); border-color: var(--peach); }
.product-pick-item.is-selected { border-color: var(--peach); background: var(--peach-soft); }

/* Dialog */
.dialog-back {
  position: fixed; inset: 0; background: rgba(30,26,24,.30); backdrop-filter: blur(3px);
  z-index: 50; display: grid; place-items: center; animation: fadeIn calc(.25s * var(--anim)) var(--ease-smooth);
}
.dialog {
  background: var(--surface); border-radius: var(--r-xl); padding: 28px; max-width: 480px; width: 92%;
  border: 1px solid var(--line); box-shadow: var(--shadow-lg); animation: popIn calc(.4s * var(--anim)) var(--ease-spring);
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes popIn { from { opacity: 0; transform: scale(.92) translateY(8px); } to { opacity: 1; transform: scale(1) translateY(0); } }

/* Entrance animation */
@keyframes fadeUp { from { transform: translateY(10px); } to { transform: translateY(0); } }
.fade-in { animation: fadeUp calc(.4s * var(--anim)) var(--ease-smooth); }

/* Toasts */
.toasts { position: fixed; bottom: 26px; right: 26px; display: flex; flex-direction: column; gap: 10px; z-index: 80; pointer-events: none; }
.toast {
  background: var(--ink); color: white; padding: 12px 16px; border-radius: 14px;
  font-size: 13px; font-weight: 500; display: flex; align-items: center; gap: 10px;
  box-shadow: var(--shadow-lg); animation: toastIn .4s var(--ease-spring), toastOut .35s var(--ease-smooth) 3.5s forwards;
  max-width: 340px;
}
.toast.mint { background: var(--mint-deep); }
.toast.peach { background: var(--peach-deep); }
@keyframes toastIn { from { opacity: 0; transform: translateY(10px) scale(.96); } }
@keyframes toastOut { to { opacity: 0; transform: translateY(8px); } }

/* Confetti */
.confetti { position: absolute; pointer-events: none; inset: 0; overflow: hidden; }
.confetti span { position: absolute; width: 8px; height: 12px; border-radius: 2px; animation: confettiFall 1.5s ease-out forwards; }
@keyframes confettiFall { 0% { transform: translate(0, 0) rotate(0deg); opacity: 1; } 100% { transform: translate(var(--dx, 0), var(--dy, 200px)) rotate(var(--rot, 360deg)); opacity: 0; } }

/* Stepper */
.stepper { display: inline-flex; align-items: center; gap: 4px; }
.stepper button { width: 28px; height: 28px; padding: 0; }
.stepper input { width: 56px; text-align: center; padding: 6px 4px; font-family: var(--font-mono); }

/* Live marker */
.live-marker { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 700; color: var(--mint-deep); text-transform: uppercase; letter-spacing: .14em; }
.live-marker .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--mint-deep); animation: livedot 1.2s ease-in-out infinite; }

/* Section header */
.section-header { display: flex; align-items: end; justify-content: space-between; margin: 6px 0 14px; flex-wrap: wrap; gap: 12px; }
.section-header h2 { font-family: var(--font-display); font-size: 36px; line-height: 1.1; margin: 0; letter-spacing: -.02em; }
.section-header h2 em { color: var(--peach-deep); }
.section-header .sub { color: var(--muted); font-size: 13px; margin-top: 4px; }

/* Open-ended timer */
.timer-openended { position: relative; }
.timer-openended .oe-halo { position: absolute; width: 78%; height: 78%; border-radius: 50%; border: 1.5px dashed var(--lavender); opacity: .45; }
.timer-openended[data-state="running"] .oe-halo { animation: oe-rotate 18s linear infinite; opacity: .55; }
.timer-openended[data-state="paused"] .oe-halo { border-color: #C99908; opacity: .65; animation: none; }
@keyframes oe-rotate { to { transform: rotate(360deg); } }
.timer-openended .oe-core { position: absolute; width: 57%; height: 57%; border-radius: 50%; background: radial-gradient(circle, rgba(127,207,192,0.55) 0%, rgba(127,207,192,0.18) 45%, rgba(127,207,192,0) 75%); filter: blur(1px); }
.timer-openended[data-state="running"] .oe-core { animation: oe-breathe 3.2s ease-in-out infinite; }
.timer-openended[data-state="paused"] .oe-core { background: radial-gradient(circle, rgba(196,153,8,0.30) 0%, rgba(196,153,8,0.10) 50%, rgba(196,153,8,0) 75%); opacity: .7; }
@keyframes oe-breathe { 0%, 100% { transform: scale(0.85); opacity: 0.55; } 50% { transform: scale(1.12); opacity: 1; } }
.timer-openended .oe-ripple { position: absolute; border-radius: 50%; border: 1.5px solid var(--mint-deep); width: 80px; height: 80px; opacity: 0; animation: oe-ripple-anim 3.6s cubic-bezier(0.2, 0.8, 0.2, 1) infinite; }
.timer-openended .oe-ripple-1 { animation-delay: 0s; }
.timer-openended .oe-ripple-2 { animation-delay: 1.2s; }
.timer-openended .oe-ripple-3 { animation-delay: 2.4s; }
@keyframes oe-ripple-anim { 0% { width: 80px; height: 80px; opacity: 0.55; border-width: 2px; } 100% { width: 260px; height: 260px; opacity: 0; border-width: 0.5px; } }
.timer-openended .timer-digits .big { font-family: var(--font-display); font-weight: 400; font-variant-numeric: tabular-nums lining-nums; letter-spacing: -0.02em; font-size: 62px; }
.timer-openended .timer-digits .pace.oe-pace { display: inline-flex; align-items: center; gap: 8px; background: var(--mint-soft); color: var(--mint-deep); padding: 5px 12px; border-radius: 999px; margin-top: 12px; letter-spacing: 0.16em; font-size: 11px; font-weight: 700; }
.timer-openended[data-state="paused"] .oe-pace { background: var(--yellow-soft); color: #8C7008; }
.oe-dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.timer-openended[data-state="running"] .oe-dot { animation: livedot 1.2s ease-in-out infinite; }

/* Open-ended tag in subtask */
.openended-tag { margin-top: 5px; display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 600; color: var(--lavender-deep); background: var(--lavender-soft); padding: 2px 10px; border-radius: 999px; letter-spacing: 0.04em; }
.oe-mini-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--lavender-deep); }
.oe-mini-dot[data-running="1"] { animation: livedot 1.2s ease-in-out infinite; }

/* Add subtask */
.add-subtask-btn { margin-top: 8px; display: inline-flex; align-items: center; gap: 10px; padding: 10px 14px; border: 1.5px dashed var(--lavender); background: transparent; color: var(--lavender-deep); border-radius: 12px; font-weight: 600; font-size: 13px; cursor: pointer; transition: transform .2s var(--ease-spring), background .2s; }
.add-subtask-btn:hover { transform: translateY(-1px); background: var(--lavender-soft); border-style: solid; }
.add-subtask-form { margin-top: 8px; display: flex; gap: 6px; align-items: center; padding: 6px 6px 6px 12px; border: 1.5px solid var(--lavender); background: var(--surface); border-radius: 14px; box-shadow: 0 8px 20px -12px rgba(106,153,97,.4); }
.add-subtask-form input { flex: 1; border: 0; background: transparent; outline: none; padding: 8px 4px; font-size: 14px; min-width: 0; }

/* Tailor-added subtask */
.subtask.is-custom { background: linear-gradient(180deg, transparent, var(--lavender-soft) 220%); }
.subtask.is-custom .subtask-label { color: var(--lavender-deep); }
.custom-chip { display: inline-block; margin-left: 8px; font-size: 10px; font-weight: 700; color: var(--lavender-deep); background: var(--lavender-soft); padding: 1px 7px; border-radius: 999px; letter-spacing: 0.06em; text-transform: uppercase; vertical-align: 2px; }
.subtask-remove { width: 24px; height: 24px; border-radius: 50%; border: 0; background: transparent; color: var(--muted); display: grid; place-items: center; opacity: 0; transition: opacity .2s, background .2s; }
.subtask:hover .subtask-remove { opacity: 1; }
.subtask-remove:hover { background: var(--pink-soft); color: #C44A82; }

/* Queue rows (admin) */
.queue-row { display: flex; gap: 10px; align-items: center; padding: 8px 10px; border: 1px solid var(--line); border-radius: 12px; background: var(--surface); transition: border-color .2s, background .2s; }
.queue-row:hover { border-color: var(--peach-soft); }
.queue-row[data-confirming="1"] { border-color: #E0457E; background: var(--pink-soft); }
.queue-remove { width: 28px; height: 28px; border-radius: 50%; border: 0; background: transparent; color: var(--muted); display: grid; place-items: center; cursor: pointer; transition: background .2s, color .2s; flex-shrink: 0; }
.queue-remove:hover { background: var(--pink-soft); color: #C44A82; }

/* Tab panels */
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* Responsive */
@media (max-width: 980px) {
  .app { padding: 18px 18px 80px; }
  .section-header h2 { font-size: 30px; }
  .admin-tabs { width: 100%; overflow-x: auto; flex-wrap: nowrap; }
  .admin-tabs::-webkit-scrollbar { display: none; }
  .dash-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
  .catalog-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
  .timer-hero { padding: 22px; }
  .timer-hero h1 { font-size: clamp(30px, 5vw, 44px); }
  .timer-ring-wrap { width: 240px; height: 240px; }
}

@media (max-width: 640px) {
  .app { padding: 14px 12px 100px; }
  .topbar { flex-direction: column; align-items: stretch; gap: 10px; padding: 6px 2px; margin-bottom: 14px; }
  .brand { font-size: 26px; }
  .brand-mark { width: 140px; height: 140px; }
  .view-switch { align-self: center; width: 100%; justify-content: center; }
  .view-switch button { flex: 1; padding: 9px 10px; font-size: 13px; }
  .identity { align-self: stretch; justify-content: flex-start; }
  .section-header h2 { font-size: 26px; }
  .card { padding: 16px; border-radius: 18px; }
  .card-title { font-size: 22px; }
  .timer-hero { padding: 18px; border-radius: 22px; }
  .timer-hero h1 { font-size: clamp(28px, 9vw, 36px); }
  .timer-ring-wrap { width: 220px; height: 220px; margin: 16px auto 4px; }
  .timer-digits .big { font-size: 38px; }
  .timer-openended .timer-digits .big { font-size: 42px; }
  .play-btn { width: 56px; height: 56px; }
  .timer-controls { flex-wrap: wrap; }
  .timer-controls .btn.primary { width: 100%; }
  .stat-value { font-size: 22px; }
  .stat-box { padding: 12px; }
  .dash-grid, .dash-grid.cozy, .dash-grid.compact { grid-template-columns: 1fr; gap: 12px; }
  .tailor-card { padding: 16px; }
  .tcard-task { font-size: 19px; }
  .tcard-time { font-size: 24px; }
  .tcard-actions .btn { flex: 1; min-width: 80px; }
  .catalog-grid { grid-template-columns: 1fr; gap: 12px; }
  .req-card { grid-template-columns: auto 1fr; grid-template-areas: "delta meta" "actions actions"; gap: 12px; padding: 14px; }
  .req-card > .req-delta { grid-area: delta; font-size: 18px; padding: 10px 12px; }
  .req-card > .req-meta { grid-area: meta; }
  .req-card > .col { grid-area: actions; flex-direction: row; }
  .req-card > .col .btn { flex: 1; }
  .assign-layout { grid-template-columns: 1fr; }
  .dialog { padding: 20px; border-radius: 22px; }
  .toasts { left: 12px; right: 12px; bottom: 14px; align-items: stretch; }
  .toast { max-width: none; }
}

/* Logout button */
.btn-logout {
  width: 32px; height: 32px; border-radius: 50%; border: 0; background: transparent;
  color: var(--muted); display: grid; place-items: center; cursor: pointer; margin-left: 4px;
  transition: background .2s, color .2s, transform .2s var(--ease-spring);
}
.btn-logout:hover { background: var(--pink-soft); color: #C44A82; transform: scale(1.1); }

/* Login field helper (reused in user dialogs) */
.login-field { margin-bottom: 12px; }
.login-field label { display: block; font-size: 12px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.14em; margin-bottom: 6px; }
.login-field input, .login-field select { width: 100%; }

/* Color picker */
.color-picks { display: flex; gap: 8px; flex-wrap: wrap; }
.color-pick {
  width: 36px; height: 36px; border-radius: 50%; border: 2.5px solid transparent;
  cursor: pointer; transition: transform .2s var(--ease-spring), border-color .2s;
}
.color-pick:hover { transform: scale(1.15); }
.color-pick.is-active { border-color: var(--ink); transform: scale(1.15); }
