/*
 * flextracker3 — app.css
 *
 * Seeded from flextracker2's globals.css design tokens ("Editorial Dark /
 * Ink"). FT2 used Tailwind v4 @theme; here the tokens are plain CSS custom
 * properties so the Go binary serves one static stylesheet with no build step.
 * Carry over: serif display intent, dark theme, fade-up motion, the day-type
 * color + icon palette (SPEC §7). P4 elevates this further.
 */

:root {
  /* Editorial Dark / Ink */
  color-scheme: dark; /* native controls (date picker, time, scrollbars) render dark, not white */
  --color-bg: #0d0c0a;
  --color-surface: #161410;
  --color-surface-2: #1f1c17;
  --color-surface-3: #2a2620;
  --color-border: #2c2823;
  --color-border-strong: #4a4339;
  --color-text: #e8e2d6;
  --color-text-muted: #b3aa9b;
  --color-text-faint: #938a7c;

  --color-accent: #ff8845;
  --color-accent-soft: #ff8845cc;
  --color-positive: #5fd49c;
  --color-negative: #ff7a7a;

  /* Day-type backgrounds (subtle tints over dark) */
  --color-day-workday-met:     rgba(95, 212, 156, 0.10);
  --color-day-workday-deficit: rgba(255, 122, 122, 0.10);
  --color-day-weekend:         rgba(255, 255, 255, 0.018);
  --color-day-holiday:         rgba(255, 92, 99, 0.28);
  --color-day-klamdag:         rgba(255, 184, 95, 0.30);
  --color-day-vacation:        rgba(45, 212, 191, 0.24);
  --color-day-sick:            rgba(178, 126, 255, 0.28);
  --color-day-parental:        rgba(255, 118, 185, 0.28);
  --color-day-paid-leave:      rgba(34, 197, 94, 0.24);
  --color-day-unpaid:          rgba(185, 176, 158, 0.16);
  --color-day-manual:          rgba(196, 202, 255, 0.24);

  /* FT2 used a serif display face for headings; system serif fallback here,
     swapped for a webfont during the P4 design pass. */
  --font-display: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, "Times New Roman", serif;
  --font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "Cascadia Mono", monospace;
}

html, body {
  margin: 0;
  padding: 0;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  background-image:
    radial-gradient(circle at 20% 0%, rgba(255, 136, 69, 0.04), transparent 40%),
    radial-gradient(circle at 80% 100%, rgba(95, 212, 156, 0.03), transparent 50%);
  min-height: 100vh;
}

h1, h2, h3, .display {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.01em;
}

::selection {
  background: var(--color-accent);
  color: var(--color-bg);
}

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--color-bg); }
::-webkit-scrollbar-thumb {
  background: var(--color-border-strong);
  border-radius: 5px;
  border: 2px solid var(--color-bg);
}
::-webkit-scrollbar-thumb:hover { background: var(--color-text-faint); }

button, input, select, textarea {
  font-family: inherit;
  color: inherit;
}

input[type="text"], input[type="number"], input[type="date"], select, textarea {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 14px;
  line-height: 1.35;
  transition: border-color 120ms ease, background 120ms ease;
}
input[type="text"]:focus, input[type="number"]:focus, input[type="date"]:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  background: var(--color-surface-2);
}

input[type="checkbox"] { accent-color: var(--color-accent); }

input[type="color"] {
  background: transparent;
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  width: 28px;
  height: 28px;
  cursor: pointer;
}
input[type="color"]::-webkit-color-swatch-wrapper { padding: 2px; }
input[type="color"]::-webkit-color-swatch { border: none; border-radius: 3px; }

.mono {
  font-family: var(--font-mono);
  font-feature-settings: "tnum", "zero";
}

button:focus-visible, [role="button"]:focus-visible, a:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.fade-up { animation: fadeUp 320ms cubic-bezier(0.22, 1, 0.36, 1) both; }
.fade-up-1 { animation-delay: 40ms; }
.fade-up-2 { animation-delay: 80ms; }
.fade-up-3 { animation-delay: 120ms; }
.fade-up-4 { animation-delay: 160ms; }

/* Subtle hover-lift used on interactive chips. */
.hover-lift {
  transition:
    transform 140ms cubic-bezier(0.22, 1, 0.36, 1),
    border-color 140ms ease,
    background-color 140ms ease,
    color 140ms ease,
    box-shadow 140ms ease;
}
.hover-lift:hover { transform: translateY(-1px); }
.hover-lift:active { transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
  .fade-up, .hover-lift { animation: none; transition: none; }
  .hover-lift:hover { transform: none; }
}

/* ════════════════════════════════════════════════════════════════════════
 * Year-summary strip (P4) — progress ring, allocation bars, week summary.
 * Lives in the calendar layout's .summary-aside; uses only .ys-* class names
 * so it composes with the calendar grid / day-panel styles without collision.
 * ════════════════════════════════════════════════════════════════════════ */

.ys-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 0.6rem;
  padding: 1.25rem;
}
.ys-card + .ys-card { margin-top: 1rem; }

/* Faint editorial wash on every card (carries FT2's .grain feel). */
.ys-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.6;
  background-image:
    radial-gradient(circle at 28% 18%, rgba(255, 136, 69, 0.045), transparent 46%),
    radial-gradient(circle at 78% 92%, rgba(95, 212, 156, 0.035), transparent 56%);
}
.ys-card > * { position: relative; z-index: 1; }

.ys-card-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
}
.ys-card-title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1rem;
  margin: 0;
  color: var(--color-text-muted);
  letter-spacing: 0;
}
.ys-card-goal {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-faint);
  white-space: nowrap;
}

/* Progress card. */
.ys-progress {
  display: flex;
  align-items: center;
  gap: 1.1rem;
  margin-top: 1rem;
}
.ys-ring {
  position: relative;
  flex-shrink: 0;
  width: 100px;
  height: 100px;
}
.ys-ring svg { width: 100px; height: 100px; display: block; }
.ys-ring-track { stroke: var(--color-surface-3); }
.ys-ring-value {
  stroke: var(--color-accent);
  transition: stroke-dashoffset 700ms cubic-bezier(0.22, 1, 0.36, 1);
  filter: drop-shadow(0 0 4px rgba(255, 136, 69, 0.35));
}
.ys-ring-label {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  color: var(--color-text);
}
.ys-progress-figures { min-width: 0; }
.ys-progress-total {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.ys-progress-hours {
  font-size: 2rem;
  line-height: 1;
  color: var(--color-text);
}
.ys-progress-pct { font-size: 0.75rem; color: var(--color-text-muted); }
.ys-progress-balance {
  margin-top: 0.4rem;
  font-size: 0.75rem;
  color: var(--color-text-muted);
}

/* Balance / delta color classes (shared with the calendar's BalanceClass). */
.balance--positive { color: var(--color-positive); }
.balance--negative { color: var(--color-negative); }
.balance--neutral  { color: var(--color-text-muted); }

.ys-stats {
  margin: 1.25rem 0 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem 1rem;
}
.ys-stat-label {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-text-faint);
}
.ys-stat-value {
  font-size: 0.875rem;
  color: var(--color-text);
  margin: 0.15rem 0 0;
}

/* Allocation card. */
.ys-alloc { margin-top: 1rem; display: flex; flex-direction: column; gap: 0.6rem; }
.ys-alloc-empty {
  margin: 0.5rem 0 0;
  font-size: 0.75rem;
  color: var(--color-text-faint);
}
.ys-alloc-row {
  display: block;
  text-decoration: none;
  color: inherit;
  border: 1px solid transparent;
  border-radius: 0.375rem;
  padding: 0.25rem 0.5rem;
  transition: border-color 140ms ease, background-color 140ms ease;
  cursor: pointer;
}
.ys-alloc-row:hover {
  border-color: var(--color-border);
  background: var(--color-surface-2);
}
.ys-alloc-row.is-active {
  border-color: var(--color-accent);
  background: rgba(255, 136, 69, 0.10);
}
.ys-alloc-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  font-size: 0.75rem;
}
.ys-alloc-name {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  color: var(--color-text);
}
.ys-alloc-dot {
  display: inline-block;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 9999px;
  flex-shrink: 0;
}
.ys-alloc-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ys-alloc-pct { flex-shrink: 0; color: var(--color-text-muted); }
.ys-alloc-target-pct { color: var(--color-text-faint); }
.ys-alloc-track {
  position: relative;
  margin-top: 0.375rem;
  height: 0.25rem;
  width: 100%;
  border-radius: 9999px;
  background: var(--color-surface-3);
}
.ys-alloc-fill {
  height: 100%;
  border-radius: 9999px;
  transition: width 500ms cubic-bezier(0.22, 1, 0.36, 1);
}
.ys-alloc-marker {
  position: absolute;
  top: -1px;
  width: 1px;
  height: calc(0.25rem + 2px);
  background: var(--color-text);
  transform: translateX(-0.5px);
}

/* Week-summary card. */
.ys-week-figures { margin-top: 1rem; }
.ys-week-total {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.ys-week-hours { font-size: 1.6rem; line-height: 1; color: var(--color-text); }
.ys-week-expected { font-size: 0.75rem; color: var(--color-text-muted); }
.ys-week-balance {
  margin-top: 0.4rem;
  font-size: 0.75rem;
  color: var(--color-text-muted);
}
.ys-week-track {
  margin-top: 0.9rem;
  height: 0.25rem;
  width: 100%;
  border-radius: 9999px;
  background: var(--color-surface-3);
  overflow: hidden;
}
.ys-week-fill {
  height: 100%;
  border-radius: 9999px;
  background: var(--color-accent);
  transition: width 700ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* Strip container + card grid. In the calendar aside the cards stack; on a wide
 * standalone render the grid could go multi-column, but the aside is the primary
 * home so a single column is the default. */
.year-summary { display: block; }
.ys-grid { display: flex; flex-direction: column; gap: 1rem; }
.ys-grid > .ys-card + .ys-card { margin-top: 0; } /* gap handles spacing here */

/* Strip span-filter bar (the strip's own all/unclassified/doctor/project row). */
.span-filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 0.6rem;
  padding: 0.625rem;
}
.span-filter-bar__lead {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-right: 0.25rem;
}
.span-filter-bar__chip {
  display: inline-block;
  text-decoration: none;
  font-size: 0.75rem;
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  border-radius: 0.375rem;
  padding: 0.25rem 0.6rem;
  transition: border-color 140ms ease, color 140ms ease, background-color 140ms ease;
}
.span-filter-bar__chip:hover {
  border-color: var(--color-border-strong);
  color: var(--color-text);
}
.span-filter-bar__chip.is-active {
  border-color: var(--color-accent);
  background: rgba(255, 136, 69, 0.10);
  color: var(--color-accent);
}
.span-filter-bar__select-wrap { display: inline-flex; align-items: center; }
.span-filter-bar__select {
  height: 28px;
  min-width: 140px;
  max-width: 220px;
  font-size: 0.75rem;
  padding: 0.15rem 0.5rem;
  border-radius: 0.375rem;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
}
.span-filter-bar__select.is-active {
  border-color: var(--color-accent);
  background: rgba(255, 136, 69, 0.10);
  color: var(--color-accent);
}
.span-filter-bar__clear {
  font-size: 0.75rem;
  text-decoration: none;
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  border-radius: 0.375rem;
  padding: 0.25rem 0.5rem;
  transition: border-color 140ms ease, color 140ms ease;
}
.span-filter-bar__clear:hover {
  border-color: var(--color-border-strong);
  color: var(--color-text);
}
.span-filter-bar__active {
  margin-left: auto;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  border-radius: 0.375rem;
  padding: 0.25rem 0.5rem;
}

/* Screen-reader-only utility (used by the strip's filter <label>); guarded so a
 * duplicate definition elsewhere is harmless (identical rule). */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ════════════════════════════════════════════════════════════════════════
 * Day panel (P4) — the selected-day breakdown: header (worked/expected/
 * balance + lunch/clear chips), the timeline mount + static fallback bar, the
 * per-entry span list, and the leave/override controls form. All selectors are
 * day-panel-scoped (.day-panel*, .span-*, .override-*, .timeline-*, .chip*,
 * .cat-badge*) so they compose with the calendar grid + year-summary strip
 * without collision. Ports + elevates FT2 components/day/day-details.tsx +
 * span-row.tsx (serif display date, dark surfaces, fade-up, balance color cues).
 * ════════════════════════════════════════════════════════════════════════ */

.day-panel {
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 0.6rem;
  padding: 1.25rem;
}
.day-panel--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 7rem;
  text-align: center;
}

.day-panel-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  padding-bottom: 0.85rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}
.day-panel-title { margin: 0; min-width: 0; font-size: 0.875rem; }
.day-panel-date { font-size: 1.25rem; color: var(--color-text); }
.day-panel-type { margin-left: 0.5rem; font-size: 0.875rem; color: var(--color-text-muted); }
.day-panel-holiday { margin-left: 0.5rem; font-size: 0.75rem; color: var(--color-text-muted); }

.day-panel-stats {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.35rem 0.85rem;
  font-size: 0.875rem;
}
.day-panel-balance { font-weight: 600; }

/* Header chips: "+ lunch" / "clear day" (FT2's small outline buttons). */
.chip {
  border: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-text-muted);
  border-radius: 0.375rem;
  padding: 0.1rem 0.55rem;
  font-size: 0.75rem;
  cursor: pointer;
  transition: border-color 140ms ease, color 140ms ease, background-color 140ms ease;
}
.chip:hover { border-color: var(--color-border-strong); color: var(--color-text); }
.chip--lunch:hover { border-color: rgba(255, 184, 95, 0.6); color: #ffce88; }
.chip--holiday:hover { border-color: rgba(255, 105, 117, 0.62); color: #ff9da7; }
.chip--paid-leave {
  border-color: rgba(34, 197, 94, 0.42);
  color: #a7f3d0;
  background: rgba(34, 197, 94, 0.08);
}
.chip--paid-leave:hover { border-color: rgba(34, 197, 94, 0.7); color: #c8facc; }
.chip--static {
  cursor: default;
  pointer-events: none;
}
.chip--danger:hover { border-color: var(--color-negative); color: var(--color-negative); }
.chip:disabled { opacity: 0.4; cursor: default; }

/* Timeline mount — the P5 island hydrates this; until then a static, color-coded
 * 06:00–20:00 fallback bar reads the day at a glance. */
.day-panel__timeline { margin-top: 0.25rem; }
.timeline-mount {
  position: relative;
  margin-top: 1rem;
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  background: var(--color-surface-2);
  padding: 0.5rem;
  min-height: 3.25rem;
}
.timeline-fallback {
  position: relative;
  height: 2.25rem;
  border-radius: 0.375rem;
  background:
    repeating-linear-gradient(
      to right,
      var(--color-surface-3) 0,
      var(--color-surface-3) 1px,
      transparent 1px,
      transparent calc(100% / 14)
    );
  overflow: hidden;
}
.timeline-seg {
  position: absolute;
  top: 0.3rem;
  bottom: 0.3rem;
  min-width: 2px;
  border-radius: 0.2rem;
  opacity: 0.9;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.25);
}
/* A filtered-out segment stays in place on the (no-JS) static timeline but is
   dimmed, mirroring the breakdown-list dimming so the filter narrows focus
   rather than dropping blocks out of the day. */
.timeline-seg--dimmed {
  opacity: 0.22;
  filter: saturate(0.5);
}
/* interactive timeline track span dimmed by the active quick-filter (parity with
   the day-panel list + v2's filtered timeline); un-dims on hover/focus so a
   filtered-out entry is still inspectable/right-clickable. */
.tl-span--dimmed {
  opacity: 0.26;
  filter: saturate(0.5);
}
.tl-span--dimmed:hover,
.tl-span--dimmed:focus,
.tl-span--dimmed:focus-within {
  opacity: 1;
  filter: none;
}
.timeline-hint {
  margin: 0.6rem 0 0;
  font-size: 0.75rem;
  color: var(--color-text-muted);
}

/* ════════════════════════════════════════════════════════════════════════
 * Timeline editor island (P5) — the interactive day editor the Alpine island
 * (Alpine.data("timeline")) binds to inside #timeline-mount. Ports + elevates
 * FT2 timeline-track.tsx / tool-palette.tsx / span-action-popover.tsx using the
 * Editorial Dark tokens. All selectors are .tl-* / .week-* scoped so they
 * compose with the day panel + calendar without collision. The static
 * .timeline-fallback above is the no-JS view; this is shown once Alpine hydrates.
 * ════════════════════════════════════════════════════════════════════════ */

.timeline-editor { margin-top: 0.85rem; }

/* Toolbar: tool palette (left) + armed hint & window-mode buttons (right). */
.tl-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 0.75rem;
  margin-bottom: 0.65rem;
}
.tl-palette {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
}
.tl-palette__hint {
  margin-right: 0.15rem;
  font-size: 0.75rem;
  color: var(--color-text-muted);
}
.tl-tool {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  border: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-text-muted);
  border-radius: 0.4rem;
  padding: 0.2rem 0.55rem;
  font-size: 0.75rem;
  cursor: pointer;
}
.tl-tool:hover {
  border-color: var(--color-border-strong);
  background: var(--color-surface-2);
  color: var(--color-text);
}
.tl-tool[draggable="true"] { cursor: grab; }
.tl-tool[draggable="true"]:active { cursor: grabbing; }
.tl-tool:disabled { opacity: 0.45; cursor: default; }
.tl-tool__dot {
  display: inline-block;
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.25);
}
.tl-tool__mins { font-size: 0.65rem; color: var(--color-text-faint); }
/* Armed tool: tinted with its own color (the --tl-tool-color custom prop) and a
 * gentle pulse — the FT2 armed-pulse affordance. */
.tl-tool--armed {
  color: var(--color-text);
  border-color: color-mix(in srgb, var(--tl-tool-color, var(--color-accent)) 55%, transparent);
  background: color-mix(in srgb, var(--tl-tool-color, var(--color-accent)) 18%, transparent);
  animation: tlArmedPulse 1.8s ease-in-out infinite;
}
@keyframes tlArmedPulse {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--tl-tool-color, var(--color-accent)) 40%, transparent); }
  50% { box-shadow: 0 0 0 3px color-mix(in srgb, var(--tl-tool-color, var(--color-accent)) 12%, transparent); }
}
@media (prefers-reduced-motion: reduce) {
  .tl-tool--armed { animation: none; }
}

.tl-toolbar__aside {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin-left: auto;
}
.tl-history {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
}
.tl-history__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.65rem;
  height: 1.55rem;
  border: 1px solid var(--color-border);
  border-radius: 0.35rem;
  background: transparent;
  color: var(--color-text-muted);
  font-size: 0.95rem;
  line-height: 1;
  cursor: pointer;
  transition: border-color 140ms ease, color 140ms ease, background-color 140ms ease;
}
.tl-history__btn:hover:not(:disabled) {
  border-color: var(--color-border-strong);
  background: var(--color-surface-2);
  color: var(--color-text);
}
.tl-history__btn:disabled {
  opacity: 0.35;
  cursor: default;
}
.tl-armed {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border: 1px solid color-mix(in srgb, var(--color-accent) 40%, transparent);
  background: color-mix(in srgb, var(--color-accent) 10%, transparent);
  color: var(--color-accent);
  border-radius: 0.4rem;
  padding: 0.1rem 0.5rem;
  font-size: 0.7rem;
}
.tl-armed__nudge { animation: tlNudge 1.4s ease-in-out infinite; }
@keyframes tlNudge { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(2px); } }
@media (prefers-reduced-motion: reduce) { .tl-armed__nudge { animation: none; } }
.tl-armed__esc {
  border: 1px solid color-mix(in srgb, var(--color-accent) 30%, transparent);
  border-radius: 0.25rem;
  padding: 0 0.25rem;
  font-size: 0.6rem;
  opacity: 0.85;
}
.tl-modes { display: inline-flex; gap: 0.2rem; }
.tl-mode {
  border: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-text-muted);
  border-radius: 0.35rem;
  padding: 0.15rem 0.55rem;
  font-size: 0.7rem;
  cursor: pointer;
  transition: border-color 140ms ease, color 140ms ease, background-color 140ms ease;
}
.tl-mode:hover { border-color: var(--color-border-strong); color: var(--color-text); }
.tl-mode--active {
  border-color: var(--color-accent);
  background: rgba(255, 136, 69, 0.12);
  color: var(--color-accent);
}

/* The hour scale + the interactive track. */
.tl-scalewrap { position: relative; }
.tl-scale {
  position: relative;
  height: 1rem;
  margin-bottom: 0.15rem;
}
.tl-scale__hour {
  position: absolute;
  transform: translateX(-50%);
  font-size: 0.65rem;
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
}
.tl-track {
  position: relative;
  height: 2.6rem;
  border-radius: 0.45rem;
  background: var(--color-surface-3);
  border: 1px solid var(--color-border);
  touch-action: none; /* so pointer-drag works on touch without scrolling */
  cursor: default;
  user-select: none;
  -webkit-user-select: none;
  overflow: visible;
}
.tl-track--split { cursor: crosshair; }
.tl-track--busy { opacity: 0.7; }

.tl-tick {
  position: absolute;
  top: 0;
  height: 100%;
  width: 1px;
}
.tl-tick--q { background: var(--color-border); opacity: 0.18; }
.tl-tick--h { background: var(--color-border-strong); opacity: 0.5; }
.tl-tick--hr { background: var(--color-border-strong); width: 2px; opacity: 0.7; }

.tl-lunch {
  position: absolute;
  top: 0;
  height: 100%;
  background: var(--color-day-klamdag);
  pointer-events: none;
}
.tl-split-marker {
  position: absolute;
  top: -0.25rem;
  bottom: -0.25rem;
  z-index: 35;
  width: 0;
  border-left: 2px solid var(--color-accent);
  pointer-events: none;
  filter: drop-shadow(0 0 3px rgba(255, 136, 69, 0.45));
}
.tl-split-marker__label {
  position: absolute;
  top: -1.35rem;
  left: 0;
  transform: translateX(-50%);
  border-radius: 0.25rem;
  background: var(--color-accent);
  color: #000;
  padding: 0.05rem 0.35rem;
  font-size: 0.63rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

/* Span blocks: each carries data-span-id for the hit-test. */
.tl-span {
  position: absolute;
  top: 0.25rem;
  bottom: 0.25rem;
  overflow: hidden;
  border-radius: 0.25rem;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.4), inset 0 0 0 1px rgba(0, 0, 0, 0.2);
  cursor: pointer;
  -webkit-touch-callout: none;
  transition: box-shadow 120ms ease;
}
.tl-span:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 1px;
}
.tl-span--split { cursor: crosshair; box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 80%, transparent); }
.tl-span--open { box-shadow: 0 0 0 2px var(--color-accent); }
.tl-span--drop-target {
  box-shadow:
    0 0 0 2px var(--color-accent),
    0 0 0 5px color-mix(in srgb, var(--color-accent) 18%, transparent);
}
.tl-span__label {
  display: flex;
  align-items: center;
  gap: 0.15rem;
  height: 100%;
  min-width: 0;
  padding: 0 0.4rem;
  font-size: 0.7rem;
  font-weight: 500;
  line-height: 1.1;
  color: rgba(0, 0, 0, 0.85);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tl-span__icon { flex: none; }
.tl-span__scissor { margin-left: 0.25rem; color: rgba(0, 0, 0, 0.85); }

/* Drag-create preview (only while dragging past the threshold). */
.tl-preview {
  position: absolute;
  top: 0.15rem;
  bottom: 0.15rem;
  border-radius: 0.25rem;
  border: 2px solid var(--color-accent-soft);
  background: rgba(255, 136, 69, 0.15);
  pointer-events: none;
}
.tl-preview__label {
  position: absolute;
  top: -1.35rem;
  left: 0;
  white-space: nowrap;
  border-radius: 0.25rem;
  background: var(--color-accent);
  color: #000;
  padding: 0.05rem 0.35rem;
  font-size: 0.65rem;
  font-weight: 500;
}

/* Action popover / context menu (two views: actions | projects). */
.tl-menu-layer { position: absolute; inset: 0; z-index: 40; }
.tl-menu-backdrop { position: fixed; inset: 0; z-index: 0; background: transparent; }
.tl-menu {
  position: absolute;
  top: 100%;
  z-index: 1;
  margin-top: 0.35rem;
  width: 15rem;
  max-width: 80vw;
  border: 1px solid var(--color-border);
  border-radius: 0.45rem;
  background: var(--color-surface);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
  padding: 0.4rem;
}
.tl-menu__head {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding-bottom: 0.35rem;
  margin-bottom: 0.35rem;
  border-bottom: 1px solid var(--color-border);
  font-size: 0.75rem;
}
.tl-menu__dot {
  display: inline-block;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  flex: none;
}
.tl-menu__title { font-weight: 500; color: var(--color-text); }
.tl-menu__range { margin-left: auto; font-size: 0.62rem; color: var(--color-text-muted); }
.tl-menu__view { display: flex; flex-direction: column; gap: 0.1rem; }
.tl-menu__row {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  width: 100%;
  border: none;
  background: transparent;
  color: var(--color-text);
  border-radius: 0.3rem;
  padding: 0.3rem 0.4rem;
  font-size: 0.75rem;
  text-align: left;
  cursor: pointer;
}
.tl-menu__row:hover { background: var(--color-surface-2); }
.tl-menu__row:disabled { opacity: 0.4; cursor: default; }
.tl-menu__row--danger { color: var(--color-negative); }
.tl-menu__row--danger:hover { background: rgba(255, 122, 122, 0.1); }
.tl-menu__icon { flex: none; width: 1rem; text-align: center; }
.tl-menu__row-label { flex: 1; }
.tl-menu__hint { font-size: 0.6rem; color: var(--color-text-faint); }
.tl-menu__back {
  width: 100%;
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  border-radius: 0.3rem;
  padding: 0.25rem 0.4rem;
  font-size: 0.65rem;
  text-align: left;
  cursor: pointer;
}
.tl-menu__back:hover { background: var(--color-surface-2); color: var(--color-text); }
.tl-menu__projects { max-height: 14rem; overflow-y: auto; }
.tl-menu__empty { margin: 0.35rem 0.4rem 0; font-size: 0.65rem; color: var(--color-text-faint); }

@media (max-width: 700px), (pointer: coarse) {
  .tl-track {
    min-height: 3rem;
  }

  .tl-menu {
    position: fixed;
    left: 0.75rem !important;
    right: 0.75rem;
    bottom: max(0.75rem, env(safe-area-inset-bottom));
    top: auto;
    width: auto;
    max-width: none;
    margin-top: 0;
    padding: 0.55rem;
    border-radius: 0.6rem;
  }

  .tl-menu__head {
    font-size: 0.85rem;
  }

  .tl-menu__row,
  .tl-menu__back {
    min-height: 2.65rem;
    padding: 0.55rem 0.6rem;
    font-size: 0.88rem;
  }

  .tl-menu__hint {
    font-size: 0.72rem;
  }
}

.timeline-error {
  margin: 0.55rem 0 0;
  font-size: 0.75rem;
  color: var(--color-negative);
}

/* Undo bar — the timeline mutation undo affordance (FT2 undo-bar.tsx). Shown
 * for 8s after a delete/split/assign; the accent "undo" button restores the
 * snapshot / reverts the tags, the × dismisses. */
.tl-undo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0.55rem 0 0;
  padding: 0.3rem 0.55rem;
  border: 1px solid var(--color-border-strong);
  border-radius: 6px;
  background: var(--color-surface-2);
  font-size: 0.75rem;
  color: var(--color-text);
  animation: fadeUp 0.18s ease;
}
.tl-undo__msg { color: var(--color-text-muted); }
.tl-undo__btn {
  margin-left: auto;
  padding: 0.1rem 0.55rem;
  border: 1px solid color-mix(in srgb, var(--color-accent) 40%, transparent);
  border-radius: 5px;
  background: color-mix(in srgb, var(--color-accent) 12%, transparent);
  color: var(--color-accent);
  font-size: 0.7rem;
  cursor: pointer;
}
.tl-undo__btn:hover { background: color-mix(in srgb, var(--color-accent) 22%, transparent); }
.tl-undo__btn:disabled { opacity: 0.5; cursor: default; }
.tl-undo__x {
  border: none;
  background: transparent;
  color: var(--color-text-faint);
  font-size: 0.9rem;
  line-height: 1;
  cursor: pointer;
}
.tl-undo__x:hover { color: var(--color-text-muted); }

/* Day-clear undo bar — the "Restore N cleared entries" affordance shown after a
 * "clear day" mutation (FT2 day-details.tsx pendingDayUndo, 8s window). It mirrors
 * the timeline undo bar but lives in the day-panel header region; the "undo"
 * button is an htmx submit that re-creates the cleared spans via /day/restore. */
.day-undo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0.5rem 0 0;
  padding: 0.3rem 0.55rem;
  border: 1px solid var(--color-border-strong);
  border-radius: 6px;
  background: var(--color-surface-2);
  font-size: 0.75rem;
  color: var(--color-text);
  animation: fadeUp 0.18s ease;
}
.day-undo__msg { color: var(--color-text-muted); }
.day-undo__btn {
  margin-left: auto;
  padding: 0.1rem 0.55rem;
  border: 1px solid color-mix(in srgb, var(--color-accent) 40%, transparent);
  border-radius: 5px;
  background: color-mix(in srgb, var(--color-accent) 12%, transparent);
  color: var(--color-accent);
  font-size: 0.7rem;
  cursor: pointer;
}
.day-undo__btn:hover { background: color-mix(in srgb, var(--color-accent) 22%, transparent); }
.day-undo__btn:disabled { opacity: 0.5; cursor: default; }
.day-undo__x {
  border: none;
  background: transparent;
  color: var(--color-text-faint);
  font-size: 0.9rem;
  line-height: 1;
  cursor: pointer;
}
.day-undo__x:hover { color: var(--color-text-muted); }

/* Week strip — the week-timeline expand/collapse (FT2 week-timeline.tsx). The
 * rows are server-rendered compact day mounts; the open day panel is the editing
 * surface, so these are read-only context with a fast day-switch. */
.week-strip { margin-top: 1.1rem; }
.week-strip__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}
.week-strip__label { font-size: 0.75rem; color: var(--color-text-muted); }
.week-strip__toggle {
  border: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-text-muted);
  border-radius: 0.4rem;
  padding: 0.15rem 0.6rem;
  font-size: 0.72rem;
  cursor: pointer;
}
.week-strip__toggle:hover { border-color: var(--color-border-strong); color: var(--color-text); }
.week-strip__rows {
  margin-top: 0.7rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.week-row {
  display: grid;
  grid-template-columns: 5.5rem minmax(0, 1fr);
  gap: 0.65rem;
  align-items: start;
}
.week-row--selected .week-row__day { color: var(--color-text); }
.week-row__day {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.05rem;
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  padding: 0;
  text-align: left;
}
.week-row__day:hover { color: var(--color-text); }
.week-row__day--gap { cursor: default; color: var(--color-text-faint); }
.week-row__dow { font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.12em; }
.week-row__num { font-size: 1.05rem; }
.week-row__worked { font-size: 0.65rem; color: var(--color-text-muted); }
.week-row__track { min-width: 0; }
.week-row__track--gap {
  height: 2.25rem;
  border-radius: 0.375rem;
  background: var(--color-surface-2);
  opacity: 0.4;
}
.week-row__holiday {
  display: block;
  margin-top: 0.3rem;
  font-size: 0.72rem;
  color: var(--color-text-muted);
}

/* Week-strip nav (prev/next week) + the "drag on any row to create" armed hint,
 * mirroring FT2 week-timeline.tsx onPrevWeek/onNextWeek + the armed affordance. */
.week-strip__nav {
  display: flex;
  align-items: center;
  gap: 0.45rem;
}
.week-strip__arrow {
  border: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-text-muted);
  border-radius: 0.35rem;
  padding: 0.05rem 0.4rem;
  font-size: 0.65rem;
  line-height: 1.2;
  cursor: pointer;
}
.week-strip__arrow:hover { border-color: var(--color-border-strong); color: var(--color-text); }
.week-strip__hint {
  font-size: 0.72rem;
  color: var(--color-accent);
}

/* Compact timeline mount used by each week row: a real interactive editor, but
 * trimmed of the day timeline's outer chrome (no card border/padding, shorter
 * track, no per-row window-mode buttons — those live on the day timeline and
 * drive every row via the shared armed tool). */
.timeline-mount--compact {
  margin-top: 0;
  border: none;
  background: transparent;
  padding: 0;
  min-height: 0;
}
.timeline-mount--compact .timeline-editor { margin-top: 0; }
.tl-scalewrap--compact { margin-top: 0; }
.tl-track--compact { height: 2.1rem; }

/* Per-entry span list (FT2 SpanRow read view). */
.span-list { list-style: none; margin: 1.4rem 0 0; padding: 0; display: flex; flex-direction: column; gap: 0.3rem; }
.span-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  padding: 0.15rem 0;
}
/* Filter dimming (FT2 parity / better): a non-matching entry stays VISIBLE in
   the breakdown list but is dimmed in place, so the active filter narrows focus
   without hiding the rest of the day. Presentation only — the row still carries
   its real actions (edit/delete) and the engine math is unchanged. */
.span-row--dimmed {
  opacity: 0.32;
  filter: saturate(0.6);
  transition: opacity 140ms ease, filter 140ms ease;
}
.span-row--dimmed:hover,
.span-row--dimmed:focus-within {
  opacity: 0.7;
  filter: none;
}
/* The "showing <filter> · other entries dimmed" hint above the breakdown list. */
.span-filter-note {
  margin-top: 1.25rem;
  margin-bottom: -0.25rem;
  font-size: 0.6875rem;
  color: var(--color-text-muted);
}
.span-swatch { display: inline-block; width: 0.5rem; height: 0.5rem; border-radius: 9999px; flex-shrink: 0; }
.span-id { font-size: 0.625rem; color: var(--color-text-faint); }
.span-time { color: var(--color-text-muted); }
.span-label { color: var(--color-text); }
.span-note { max-width: 28ch; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--color-text-muted); }
.span-mins { margin-left: auto; color: var(--color-text-muted); font-variant-numeric: tabular-nums; }
.span-del {
  border: 1px solid transparent;
  background: transparent;
  color: var(--color-text-faint);
  border-radius: 0.3rem;
  padding: 0 0.35rem;
  line-height: 1.4;
  cursor: pointer;
  transition: color 140ms ease, border-color 140ms ease;
}
.span-del:hover { color: var(--color-negative); border-color: var(--color-negative); }

/* Click-to-edit time + "+ note" affordance (FT2 SpanRow read view). */
.span-time--edit {
  border: 0;
  background: transparent;
  font: inherit;
  color: var(--color-text-muted);
  cursor: pointer;
  padding: 0;
  text-decoration: underline dotted;
  text-underline-offset: 2px;
  transition: color 140ms ease;
}
.span-time--edit:hover { color: var(--color-text); }
.span-addnote {
  border: 0;
  background: transparent;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  cursor: pointer;
  padding: 0;
  transition: color 140ms ease;
}
.span-addnote:hover { color: var(--color-text); }

/* Inline breakdown-row editor (FT2 SpanRow editing branch). */
.span-row--editing { align-items: flex-start; }
.span-edit {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
  flex: 1 1 auto;
}
.span-edit__time {
  width: 6.5rem;
  border: 1px solid var(--color-border-strong);
  background: var(--color-surface-2);
  color: var(--color-text);
  border-radius: 0.3rem;
  padding: 0.1rem 0.3rem;
  font-size: 0.75rem;
}
.span-edit__sep { color: var(--color-text-faint); }
.span-edit__note {
  flex: 1 1 10ch;
  min-width: 9ch;
  border: 1px solid var(--color-border-strong);
  background: var(--color-surface-2);
  color: var(--color-text);
  border-radius: 0.3rem;
  padding: 0.1rem 0.4rem;
  font-size: 0.75rem;
}
.span-edit__note::placeholder { color: var(--color-text-faint); }
.span-edit__actions { margin-left: auto; display: flex; align-items: center; gap: 0.35rem; }
.span-edit__save {
  border: 1px solid color-mix(in srgb, var(--color-accent) 40%, transparent);
  background: color-mix(in srgb, var(--color-accent) 12%, transparent);
  color: var(--color-accent);
  border-radius: 0.3rem;
  padding: 0.1rem 0.55rem;
  font-size: 0.6875rem;
  cursor: pointer;
  transition: background-color 140ms ease;
}
.span-edit__save:hover { background: color-mix(in srgb, var(--color-accent) 22%, transparent); }
.span-edit__save:disabled { opacity: 0.4; cursor: default; }
.span-edit__cancel {
  border: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-text-muted);
  border-radius: 0.3rem;
  padding: 0.1rem 0.5rem;
  font-size: 0.6875rem;
  cursor: pointer;
  transition: border-color 140ms ease, color 140ms ease;
}
.span-edit__cancel:hover { border-color: var(--color-border-strong); color: var(--color-text); }

/* Category badges (doctor / lunch), color-blind-safe (text label + tint). */
.cat-badge {
  border-radius: 0.25rem;
  padding: 0.05rem 0.35rem;
  font-size: 0.6875rem;
}
/* doctor badge uses FT2's sky family (span-row.tsx bg-sky-500/15 text-sky-300),
   distinct from the periwinkle vacation day-type (--color-day-vacation). */
.cat-badge--doctor { background: rgba(14, 165, 233, 0.15); color: #7dd3fc; }
.cat-badge--lunch  { background: rgba(255, 184, 95, 0.16); color: #ffce88; }

.span-empty {
  margin-top: 1.4rem;
  border: 1px dashed var(--color-border);
  border-radius: 0.45rem;
  padding: 1rem;
  text-align: center;
  font-size: 0.6875rem;
  color: var(--color-text-muted);
}

/* Override / leave / note controls. */
.override-form { margin-top: 1.4rem; padding-top: 1rem; border-top: 1px solid var(--color-border); }
.override-form-row { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 0.75rem; }
.field { display: flex; flex-direction: column; font-size: 0.75rem; }
.field-grow { flex: 1 1 12rem; }
.field-inline { display: flex; align-items: center; gap: 0.4rem; font-size: 0.75rem; color: var(--color-text-muted); }
.field-label {
  margin-bottom: 0.25rem;
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-text-muted);
}
.override-select { min-width: 11rem; }
.input-narrow { width: 6rem; }

.quick-entry {
  margin: 0.95rem 0 0.85rem;
  padding: 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--color-surface-2) 82%, transparent);
}
.quick-entry-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.55rem;
}
.quick-entry-title {
  margin: 0;
  font-size: 0.92rem;
  color: var(--color-text);
}
.quick-entry-range {
  color: var(--color-text-muted);
  font-size: 0.7rem;
  text-align: right;
}
.quick-entry-form {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.65rem;
}
.quick-entry-project { min-width: 10rem; }
.quick-entry-error {
  flex-basis: 100%;
  margin: 0;
}
.quick-entry.htmx-request { opacity: 0.75; }

.btn-accent {
  --btn-accent-bg: color-mix(in srgb, var(--color-surface-2) 86%, var(--color-accent) 14%);
  --btn-accent-bg-hover: color-mix(in srgb, var(--color-surface-3) 78%, var(--color-accent) 22%);
  --btn-accent-border: color-mix(in srgb, var(--color-border-strong) 70%, var(--color-accent) 30%);
  --btn-accent-border-hover: color-mix(in srgb, var(--color-border-strong) 50%, var(--color-accent) 50%);
  border: 1px solid var(--btn-accent-border);
  background-color: var(--btn-accent-bg);
  color: var(--color-text);
  font-weight: 500;
  border-radius: 0.4rem;
  padding: 0.4rem 1rem;
  font-size: 0.75rem;
  cursor: pointer;
  transition: background-color 140ms ease, border-color 140ms ease, color 140ms ease, box-shadow 140ms ease, opacity 140ms ease, transform 140ms ease;
}
.btn-accent:hover {
  border-color: var(--btn-accent-border-hover);
  background-color: var(--btn-accent-bg-hover);
  color: var(--color-text);
}
.btn-accent:disabled, .btn-ghost:disabled { opacity: 0.4; cursor: default; }
.btn-ghost {
  border: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-text-muted);
  border-radius: 0.4rem;
  padding: 0.4rem 0.85rem;
  font-size: 0.75rem;
  cursor: pointer;
  transition: border-color 140ms ease, color 140ms ease;
}
.btn-ghost:hover { border-color: var(--color-border-strong); color: var(--color-text); }
.btn-danger {
  border-color: color-mix(in srgb, var(--color-negative) 45%, var(--color-border));
  color: var(--color-negative);
}
.btn-danger:hover {
  border-color: var(--color-negative);
  color: var(--color-negative);
}

/* Day-panel text utilities (scoped, neutral; safe if also defined elsewhere). */
.muted { color: var(--color-text-muted); }
.muted-italic { font-family: var(--font-display); font-style: italic; color: var(--color-text-muted); }
.faint { color: var(--color-text-faint); font-size: 0.625rem; margin-top: 0.25rem; }
.error-text { color: var(--color-negative); font-size: 0.75rem; margin: 0 0 0.6rem; }

/* Alpine x-cloak: hide elements until Alpine initializes (override reveal). */
[x-cloak] { display: none !important; }

/* ════════════════════════════════════════════════════════════════════════
 * Calendar page (P4) — page shell, layout, month nav, the span-filter bar, and
 * the month grid + day cells (day-type palette SPEC §7, color-blind safe: every
 * tint is paired with the cell icon + a left edge strip on non-workday types).
 * Ported + elevated from flextracker2 app/home-client.tsx + month-calendar.tsx +
 * day-cell.tsx; shares the editorial dark tokens, fade-up motion and the
 * .balance--* / .mono helpers defined above. Day-panel + strip selectors are
 * elsewhere; these are page/grid-scoped so nothing collides.
 * ════════════════════════════════════════════════════════════════════════ */

.serif-italic { font-family: var(--font-display); font-style: italic; }

/* --- Page shell ----------------------------------------------------------- */
.page { max-width: 72rem; margin: 0 auto; padding: 2.5rem 1.5rem 4rem; }
.page__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 2rem;
}
.page__title {
  font-family: var(--font-display);
  font-size: 2.5rem;
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--color-text);
}
.page__dot { color: var(--color-accent); }
.page__tagline {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.875rem;
  color: var(--color-text-muted);
  margin: 0.35rem 0 0;
}
.page__nav {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  font-size: 0.75rem;
  color: var(--color-text-muted);
}
.page__synced { color: var(--color-text-faint); }
.page__nav-link {
  color: var(--color-text-muted);
  text-decoration: none;
  border-bottom: 1px dotted var(--color-text-faint);
  transition: color 140ms ease;
}
.page__nav-link:hover { color: var(--color-text); }

/* The day panel sits above the calendar (FT2 puts the day view first). */
#day-panel { display: block; margin-bottom: 1.5rem; }

/* --- Calendar layout: grid (left) + summary aside (right) ----------------- */
.calendar-layout {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}
@media (min-width: 60rem) {
  .calendar-layout { grid-template-columns: 2fr 1fr; align-items: start; }
}
.calendar-col { min-width: 0; }

/* --- Month nav ------------------------------------------------------------ */
.month-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}
.month-nav-title { display: flex; align-items: center; gap: 0.75rem; }
.month-heading {
  font-family: var(--font-display);
  font-size: 1.5rem;
  margin: 0;
  color: var(--color-text);
  letter-spacing: -0.01em;
}
.month-year { font-style: italic; color: var(--color-text-muted); }
.month-nav-actions { display: flex; align-items: center; gap: 0.5rem; }
.iconbtn {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: 0.375rem;
  padding: 0.25rem 0.55rem;
  cursor: pointer;
  transition: border-color 140ms ease, color 140ms ease;
}
.iconbtn:hover { border-color: var(--color-border-strong); color: var(--color-text); }

/* --- Span-filter bar (calendar grid + day panel) -------------------------- */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 0.6rem;
  padding: 0.625rem;
}
.filter-label {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-right: 0.25rem;
}
.filter-btn {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: 0.375rem;
  padding: 0.25rem 0.6rem;
  cursor: pointer;
  transition: border-color 140ms ease, color 140ms ease, background-color 140ms ease;
}
.filter-btn:hover { border-color: var(--color-border-strong); color: var(--color-text); }
.filter-btn.is-active {
  border-color: var(--color-accent);
  background: rgba(255, 136, 69, 0.12);
  color: var(--color-accent);
}
.filter-project { display: inline-flex; align-items: center; }
.filter-select {
  height: 28px;
  min-width: 140px;
  max-width: 220px;
  font-size: 0.75rem;
  padding: 0.15rem 0.5rem;
  border-radius: 0.375rem;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
}
.filter-select.is-active {
  border-color: var(--color-accent);
  background: rgba(255, 136, 69, 0.10);
  color: var(--color-accent);
}
.btn-clear { font-size: 0.75rem; }
.filter-active {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  border-radius: 0.375rem;
  padding: 0.25rem 0.5rem;
  cursor: pointer;
  transition: color 140ms ease, border-color 140ms ease, background-color 140ms ease;
}
.filter-active:hover,
.filter-active:focus-visible {
  color: var(--color-text);
  border-color: var(--color-border-strong);
}
/* When a filter is active the badge lights up (accent) so it visibly names the
   active filter instead of reading like a static "ALL ENTRIES" chip. */
.filter-active--on {
  color: var(--color-accent);
  border-color: var(--color-accent);
  background: rgba(255, 136, 69, 0.12);
}

/* --- Month grid + weekday header ------------------------------------------ */
.calendar-grid-wrap { position: relative; }
.weekday-row {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.5rem;
  margin-bottom: 0.75rem;
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-text-faint);
}
.weekday-cell { padding: 0 0.25rem; }
.month-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.5rem;
}
/* The per-cell OOB slot wrapper must not break the grid: it lays its single
 * cell out as a grid item itself. */
.day-cell-slot { display: contents; }

.cal-context-menu {
  position: fixed;
  z-index: 70;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  width: min(14rem, calc(100vw - 1rem));
  padding: 0.45rem;
  border: 1px solid var(--color-border-strong);
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--color-surface) 94%, black);
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.48);
  outline: none;
}
.cal-context-menu__date {
  padding: 0.25rem 0.45rem 0.35rem;
  font-size: 0.625rem;
  color: var(--color-text-faint);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 0.2rem;
}
.cal-context-menu button {
  display: flex;
  align-items: center;
  min-height: 2rem;
  width: 100%;
  padding: 0.35rem 0.5rem;
  border: 1px solid transparent;
  border-radius: 0.375rem;
  background: transparent;
  color: var(--color-text-muted);
  font-size: 0.75rem;
  text-align: left;
  cursor: pointer;
  transition: color 140ms ease, background-color 140ms ease, border-color 140ms ease;
}
.cal-context-menu button:hover,
.cal-context-menu button:focus-visible {
  color: var(--color-text);
  border-color: var(--color-border);
  background: var(--color-surface-2);
}
.cal-context-menu__muted {
  color: var(--color-text-faint) !important;
  margin-top: 0.15rem;
}

@media (max-width: 700px), (pointer: coarse) {
  .cal-context-menu {
    left: 0.75rem !important;
    right: 0.75rem;
    top: auto !important;
    bottom: max(0.75rem, env(safe-area-inset-bottom));
    width: auto;
    max-height: min(70vh, 32rem);
    overflow-y: auto;
    padding: 0.55rem;
  }

  .cal-context-menu button {
    min-height: 2.65rem;
    padding: 0.55rem 0.65rem;
    font-size: 0.88rem;
  }
}

/* Day cell: a square, tinted, ring-bordered button. */
.day-cell {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  min-height: 4.75rem;
  overflow: hidden;
  text-align: left;
  border: none;
  border-radius: 0.375rem;
  padding: 0.5rem;
  background: var(--color-surface);
  box-shadow: inset 0 0 0 1px var(--color-border);
  cursor: pointer;
  transition: box-shadow 140ms ease, transform 140ms ease, background-color 140ms ease;
}
.day-cell:hover { box-shadow: inset 0 0 0 1px var(--color-border-strong); transform: translateY(-1px); }
.day-cell.is-selected { box-shadow: inset 0 0 0 2px var(--color-accent); }
.day-cell--pad { background: transparent; box-shadow: none; cursor: default; pointer-events: none; }

/* Day-type tints (SPEC §7). Each is paired with the cell's icon glyph. */
.day--workday  { background: var(--color-day-workday-met); }
.day-cell--empty { background: var(--color-surface); }
.day-cell--deficit { background: var(--color-day-workday-deficit); }
.day--weekend  { background: var(--color-day-weekend); }
.day-cell--positive { background: var(--color-day-workday-met); }
.day--holiday  { background: linear-gradient(135deg, var(--color-day-holiday), rgba(255, 92, 99, 0.12)); }
.day--klamdag  { background: linear-gradient(135deg, var(--color-day-klamdag), rgba(255, 184, 95, 0.12)); }
.day--vacation {
  background:
    repeating-linear-gradient(
      135deg,
      rgba(92, 240, 211, 0.16) 0,
      rgba(92, 240, 211, 0.16) 1px,
      transparent 1px,
      transparent 8px
    ),
    linear-gradient(135deg, var(--color-day-vacation), rgba(45, 212, 191, 0.08));
}
.day--sick     { background: linear-gradient(135deg, var(--color-day-sick), rgba(178, 126, 255, 0.12)); }
.day--parental { background: linear-gradient(135deg, var(--color-day-parental), rgba(255, 118, 185, 0.12)); }
.day--paid-leave {
  background:
    repeating-linear-gradient(
      45deg,
      rgba(134, 239, 172, 0.16) 0,
      rgba(134, 239, 172, 0.16) 1px,
      transparent 1px,
      transparent 7px
    ),
    linear-gradient(135deg, var(--color-day-paid-leave), rgba(34, 197, 94, 0.08));
}
.day--unpaid   { background: linear-gradient(135deg, var(--color-day-unpaid), rgba(185, 176, 158, 0.06)); }
.day--manual   { background: linear-gradient(135deg, var(--color-day-manual), rgba(196, 202, 255, 0.10)); }

/* Non-color left edge strip → day type legible without relying on the tint. */
.day-edge {
  position: absolute;
  left: 0; top: 0;
  width: 4px; height: 100%;
  background: color-mix(in srgb, var(--color-text-faint) 60%, transparent);
}
.day-edge--deficit { background: var(--color-negative); }
.day--holiday .day-edge { background: #ff5c63; }
.day--klamdag .day-edge { background: #ffb85f; }
.day--vacation .day-edge {
  width: 6px;
  background: linear-gradient(180deg, #2dd4bf, #8ff8df);
}
.day--sick .day-edge { background: #b27eff; }
.day--parental .day-edge { background: #ff76b9; }
.day--paid-leave .day-edge {
  width: 6px;
  background: linear-gradient(180deg, #22c55e, #86efac);
}
.day--unpaid .day-edge { background: #b9b09e; }
.day--manual .day-edge { background: #c4caff; }

.day-top { display: flex; align-items: flex-start; justify-content: space-between; }
.day-num {
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
}
.day-icon { font-size: 0.75rem; color: var(--color-text-muted); }
.day--holiday .day-icon { color: #ff858b; }
.day--klamdag .day-icon { color: #ffc982; }
.day--vacation .day-icon { color: #8ff8df; }
.day--sick .day-icon { color: #c6a2ff; }
.day--parental .day-icon { color: #ff9dcd; }
.day--paid-leave .day-icon { color: #86efac; }
.day--unpaid .day-icon { color: #d0c8b9; }
.day--manual .day-icon { color: #d4d8ff; }
.day-doctor-dot {
  position: absolute;
  right: 0.55rem; top: 1.75rem;
  width: 0.375rem; height: 0.375rem;
  border-radius: 9999px;
  background: #6ea8ff;
}
.day-body { display: flex; flex-direction: column; gap: 0.1rem; margin-top: 0.15rem; font-size: 0.75rem; line-height: 1.15; }
.day-holiday {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.6875rem;
  color: var(--color-text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.day-kind {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.6875rem;
  color: var(--color-text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.day--vacation .day-kind { color: #c5fff1; }
.day--sick .day-kind { color: #dccbff; }
.day--parental .day-kind { color: #ffd1e8; }
.day--paid-leave .day-kind { color: #c8facc; }
.day--unpaid .day-kind { color: #d8d1c2; }
.day--manual .day-kind { color: #e0e3ff; }
.day--klamdag .day-kind { color: #ffe0aa; }
.day-worked { color: var(--color-text); }
.day-balance { font-variant-numeric: tabular-nums; white-space: nowrap; }
.day-balance.balance--negative { color: var(--color-negative); }
.day-balance.balance--positive { color: var(--color-positive); }
.day-balance.balance--neutral  { color: var(--color-text-muted); }

.grid-hint { margin: 0.85rem 0 0; font-size: 0.6875rem; color: var(--color-text-faint); }

/* --- "Filtered: X" grid banner -------------------------------------------- */
/* Shown on the grid surface when a span filter is active, so the filter's
 * scope is obvious without scanning the filter control. Lives inside
 * #calendar-col so it swaps with the grid; hidden when the filter is all/none. */
.filtered-banner {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.85rem;
  padding: 0.45rem 0.7rem;
  font-size: 0.75rem;
  color: var(--color-text);
  border: 1px solid var(--color-accent);
  border-left-width: 3px;
  background: rgba(255, 136, 69, 0.10);
  border-radius: 0.5rem;
}
.filtered-banner__icon { color: var(--color-accent); font-size: 0.7rem; line-height: 1; }
.filtered-banner__text { color: var(--color-text-muted); }
.filtered-banner__name {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 600;
  color: var(--color-text);
}
.filtered-banner__clear {
  margin-left: auto;
  font-size: 0.6875rem;
  color: var(--color-accent);
  background: transparent;
  border: 1px solid var(--color-accent);
  border-radius: 0.375rem;
  padding: 0.15rem 0.5rem;
  cursor: pointer;
  transition: background-color 140ms ease, color 140ms ease;
}
.filtered-banner__clear:hover { background: var(--color-accent); color: var(--color-bg); }

/* --- Calendar legend (collapsible footer key) ----------------------------- */
/* Subtle, on-theme key for the cell balance markers + the day-type palette.
 * Color-blind safe: every row carries glyph + label, and the day-type swatch
 * uses the same tint as the cell. Native <details> → no JS, stays folded. */
.cal-legend { margin: 0.85rem 0 0; }
.cal-legend__summary {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.6875rem;
  letter-spacing: 0.04em;
  color: var(--color-text-faint);
  cursor: pointer;
  list-style: none;
  user-select: none;
  transition: color 140ms ease;
}
.cal-legend__summary:hover { color: var(--color-text-muted); }
.cal-legend__summary::-webkit-details-marker { display: none; }
.cal-legend__summary::before {
  content: "▸";
  display: inline-block;
  font-size: 0.6rem;
  transition: transform 140ms ease;
}
.cal-legend[open] .cal-legend__summary::before { transform: rotate(90deg); }
.cal-legend__body {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  margin-top: 0.6rem;
  padding: 0.75rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 0.5rem;
  animation: fadeUp 220ms ease both;
}
.cal-legend__group {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 9rem;
}
.cal-legend__title {
  font-size: 0.5625rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-text-faint);
  margin-bottom: 0.1rem;
}
.cal-legend__item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.6875rem;
  color: var(--color-text-muted);
}
.cal-legend__glyph {
  width: 1.1rem;
  text-align: center;
  font-size: 0.7rem;
  line-height: 1;
  color: var(--color-text-muted);
}
.cal-legend__swatch {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 0.25rem;
  font-size: 0.65rem;
  line-height: 1;
  color: var(--color-text);
  box-shadow: inset 0 0 0 1px var(--color-border);
}

/* htmx in-flight feedback: dim the element issuing the request. */
.htmx-request.chip,
.htmx-request.btn-accent,
.htmx-request.span-del,
.htmx-request.iconbtn,
.htmx-request.filter-btn { opacity: 0.5; pointer-events: none; }

/* ════════════════════════════════════════════════════════════════════════
 * Settings page (P4) — projects / schedule / config / holiday refresh.
 * Scoped under .settings-* so it composes with the calendar + day-panel styles
 * without collision; reuses the shared .btn-accent / .btn-ghost / .field-* /
 * .balance--* utilities defined above.
 * ════════════════════════════════════════════════════════════════════════ */

.settings-page {
  max-width: 56rem;
  margin: 0 auto;
  padding: 2.5rem 1.5rem 4rem;
}

.settings-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.75rem;
  padding-bottom: 1.1rem;
  border-bottom: 1px solid var(--color-border);
}
.settings-title {
  font-family: var(--font-display);
  font-size: 2.4rem;
  line-height: 1;
  margin: 0;
  color: var(--color-text);
}
.settings-dot { color: var(--color-accent); }
.settings-tagline {
  margin: 0.5rem 0 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.875rem;
  color: var(--color-text-muted);
}
.settings-back {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  text-decoration: none;
  border-bottom: 1px dotted var(--color-text-faint);
  transition: color 140ms ease, border-color 140ms ease;
  white-space: nowrap;
}
.settings-back:hover { color: var(--color-text); border-color: var(--color-text); }

/* Cards — one per settings section. */
.settings-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 0.6rem;
  padding: 1.4rem;
}
.settings-card + .settings-card { margin-top: 1.25rem; }
.settings-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.55;
  background-image:
    radial-gradient(circle at 24% 14%, rgba(255, 136, 69, 0.04), transparent 46%),
    radial-gradient(circle at 82% 96%, rgba(95, 212, 156, 0.03), transparent 56%);
}
.settings-card > * { position: relative; z-index: 1; }

.settings-card-head { margin-bottom: 1.1rem; }
.settings-card-title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.15rem;
  margin: 0;
  color: var(--color-text);
  letter-spacing: 0;
}
.settings-card-hint {
  margin: 0.4rem 0 0;
  font-size: 0.75rem;
  line-height: 1.5;
  color: var(--color-text-faint);
}
.settings-card-hint code {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  background: var(--color-surface-3);
  border-radius: 0.25rem;
  padding: 0.05rem 0.35rem;
  color: var(--color-text-muted);
}

.settings-empty {
  border: 1px dashed var(--color-border);
  border-radius: 0.5rem;
  padding: 1.1rem;
  text-align: center;
}
.settings-empty .faint { font-size: 0.6875rem; line-height: 1.5; }
.settings-empty code {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  background: var(--color-surface-3);
  border-radius: 0.25rem;
  padding: 0.05rem 0.3rem;
}

.settings-project-create {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-bottom: 0.9rem;
}
.settings-project-create-field {
  flex: 1 1 16rem;
  min-width: 12rem;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.settings-project-create input {
  width: 100%;
  box-sizing: border-box;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  color: var(--color-text);
  padding: 0.45rem 0.55rem;
  font-size: 0.85rem;
}
.settings-project-create input:focus {
  outline: none;
  border-color: var(--color-accent);
}

/* Shared inline label/value cluster (target %, active, year, hours). */
.settings-inline {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.75rem;
  color: var(--color-text-muted);
}
.settings-inline-label { font-size: 0.75rem; color: var(--color-text-muted); }
.settings-num {
  width: 4.5rem;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.settings-date {
  width: 8.75rem;
  font-variant-numeric: tabular-nums;
}

/* Active-target sum chip. */
.settings-targets {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.9rem;
  font-size: 0.75rem;
}
.settings-targets .mono { font-variant-numeric: tabular-nums; }

/* Project / schedule / config rows. */
.settings-project-list,
.settings-schedule-list,
.settings-config-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.settings-project,
.settings-schedule,
.settings-config,
.settings-setup-form,
.settings-holiday {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  border-radius: 0.45rem;
  padding: 0.6rem 0.75rem;
}

.settings-project-name { flex: 1 1 9rem; min-width: 8rem; }
.settings-project-tag {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-faint);
}

.settings-schedule-day {
  flex: 1 1 7rem;
  min-width: 6rem;
  font-size: 0.875rem;
  color: var(--color-text);
}

.settings-semester {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}
.settings-semester-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.6rem;
}
.settings-semester-stats > div {
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  border-radius: 0.45rem;
  padding: 0.65rem 0.75rem;
}
.settings-semester-stats strong {
  display: block;
  margin-top: 0.2rem;
  font-size: 1rem;
  font-variant-numeric: tabular-nums;
}
.settings-semester-chip {
  display: inline-flex;
  margin-top: 0.3rem;
  padding: 0.1rem 0.35rem;
  border: 1px solid var(--color-border);
  border-radius: 0.3rem;
  color: var(--color-text-muted);
  font-size: 0.65rem;
}
.settings-semester-start { margin-top: -0.2rem; }
.settings-semester-form {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  border-radius: 0.45rem;
  padding: 0.6rem 0.75rem;
}
@media (max-width: 680px) {
  .settings-semester-stats {
    grid-template-columns: 1fr;
  }
}
.settings-schedule-mins { margin-left: auto; }

.settings-config { align-items: center; }
.settings-project .btn-accent,
.settings-project .btn-ghost,
.settings-schedule .btn-accent,
.settings-config .btn-accent,
.settings-holiday .btn-accent,
.settings-setup-form .btn-ghost {
  flex: 0 0 auto;
  min-height: 2rem;
  padding: 0.35rem 0.75rem;
  line-height: 1;
}
.settings-config-meta {
  flex: 1 1 14rem;
  min-width: 11rem;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.settings-config-label { font-size: 0.8125rem; color: var(--color-text); }
.settings-config-help { font-size: 0.625rem; line-height: 1.4; margin: 0; }
.settings-config-input { flex: 0 1 12rem; min-width: 8rem; }
.settings-config-hours {
  flex: 0 1 12rem;
  min-width: 8rem;
}
.settings-config-hours .settings-config-input {
  min-width: 0;
  width: 100%;
}
input[type="time"] {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 14px;
  color: inherit;
}
input[type="time"]:focus { outline: none; border-color: var(--color-accent); background: var(--color-surface-2); }

/* Holiday refresh + counts. */
.settings-holiday { align-items: center; }
.settings-holiday-counts {
  display: flex;
  gap: 1.5rem;
  margin: 0.9rem 0 0;
  font-size: 0.75rem;
}
.settings-holiday-counts dt {
  font-size: 0.5625rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
}
.settings-holiday-counts dd {
  margin: 0.1rem 0 0;
  font-size: 1.1rem;
  color: var(--color-text);
}

/* Source badge. */
.settings-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.6875rem;
  border-radius: 9999px;
  padding: 0.2rem 0.6rem;
  border: 1px solid var(--color-border);
}
.settings-badge-dot {
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 9999px;
  flex-shrink: 0;
}
.settings-badge--cached {
  color: var(--color-positive);
  border-color: rgba(95, 212, 156, 0.4);
  background: rgba(95, 212, 156, 0.08);
}
.settings-badge--cached .settings-badge-dot {
  background: var(--color-positive);
  box-shadow: 0 0 5px rgba(95, 212, 156, 0.6);
}
.settings-badge--empty { color: var(--color-text-faint); }
.settings-badge--empty .settings-badge-dot { background: var(--color-text-faint); }
.settings-badge-when { font-size: 0.625rem; }

/* Backup / restore. */
.settings-backup-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}
.settings-backup-form {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  border-radius: 0.45rem;
  padding: 0.75rem;
}
.settings-backup-meta {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  color: var(--color-text);
}
.settings-backup-file {
  align-items: flex-start;
  flex-direction: column;
}
.settings-backup-file input[type="file"] {
  width: 100%;
  color: var(--color-text-muted);
  font-size: 0.75rem;
}
@media (max-width: 760px) {
  .settings-backup-grid {
    grid-template-columns: 1fr;
  }
}

/* Inline saved / error status pills. */
.settings-saved,
.settings-error {
  font-size: 0.6875rem;
  border-radius: 9999px;
  padding: 0.15rem 0.55rem;
}
.settings-saved {
  color: var(--color-positive);
  background: rgba(95, 212, 156, 0.1);
}
.settings-error {
  color: var(--color-negative);
  background: rgba(255, 122, 122, 0.1);
}

/* htmx in-flight: dim the submitting form's button. */
.settings-project.htmx-request,
.settings-project-create.htmx-request,
.settings-schedule.htmx-request,
.settings-config.htmx-request,
.settings-semester-form.htmx-request,
.settings-setup-form.htmx-request,
.settings-holiday.htmx-request,
.settings-backup-form.htmx-request { opacity: 0.75; }

/* Design-export card: the four Copy/Download buttons + the transient status. */
.settings-design-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}
.settings-design-msg { display: inline-block; margin-top: 0.75rem; }

/* ════════════════════════════════════════════════════════════════════════
 * Google-Timeline import flow (P4, SPEC §7) — the upload page, the review
 * workspace (day-list rail + the open day's proposal panel), the classify and
 * edit forms, and the status badges. All selectors are import-scoped
 * (.import-*) so they compose with the calendar / day-panel / settings styles
 * without collision. Shares the editorial dark tokens, fade-up motion, the
 * .btn-accent / .btn-ghost / .field* / .mono helpers, and the day-type color
 * vocabulary (approved → positive, pending → accent, skipped → faint).
 * ════════════════════════════════════════════════════════════════════════ */

.import-page { max-width: 64rem; }

/* --- Upload page ---------------------------------------------------------- */
.import-upload { display: flex; justify-content: center; }
.import-upload-card {
  width: 100%;
  max-width: 36rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 0.75rem;
  padding: 2rem;
}
.import-upload-title { margin: 0 0 0.5rem; font-size: 1.75rem; color: var(--color-text); }
.import-upload-lede { margin: 0 0 1.5rem; font-size: 0.95rem; line-height: 1.5; color: var(--color-text-muted); }
.import-upload-form { display: flex; flex-direction: column; gap: 1.1rem; }
.import-file-field { display: flex; flex-direction: column; gap: 0.4rem; }
.import-file-field input[type="file"] {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  border: 1px dashed var(--color-border-strong);
  border-radius: 0.5rem;
  padding: 0.9rem;
  background: var(--color-surface-2);
  cursor: pointer;
}
.import-file-field input[type="file"]::file-selector-button {
  font-family: inherit;
  font-size: 0.75rem;
  color: var(--color-text);
  background: var(--color-surface-3);
  border: 1px solid var(--color-border);
  border-radius: 0.35rem;
  padding: 0.3rem 0.7rem;
  margin-right: 0.75rem;
  cursor: pointer;
}
.import-tz-field,
.import-start-field { display: flex; flex-direction: column; gap: 0.25rem; }
.import-upload-form .btn-accent { align-self: flex-start; padding: 0.5rem 1.25rem; font-size: 0.85rem; }
.import-help { margin-top: 1.5rem; font-size: 0.8rem; }
.import-help summary {
  cursor: pointer;
  color: var(--color-text-muted);
  font-family: var(--font-display);
  font-style: italic;
}
.import-help summary:hover { color: var(--color-text); }
.import-help p { margin: 0.6rem 0 0; line-height: 1.5; }

/* --- Summary header ------------------------------------------------------- */
.import-summary {
  margin-bottom: 1.5rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 0.6rem;
  padding: 0.9rem 1.1rem;
}
.import-summary-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}
.import-summary-progress { display: flex; flex-wrap: wrap; gap: 0.4rem 1.1rem; font-size: 0.8rem; }
.import-summary-title { margin: 0; font-size: 1.2rem; color: var(--color-text); }
.import-summary-meta,
.import-summary-counts {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.65rem;
  color: var(--color-text-muted);
  font-size: 0.78rem;
}
.import-summary-counts { margin-top: 0.55rem; }
.import-stat { color: var(--color-text-muted); }
.import-stat strong { color: var(--color-text); font-weight: 600; }
.import-stat--ok strong { color: var(--color-positive); }
.import-complete {
  font-size: 0.85rem;
  color: var(--color-positive);
}
.import-warnings { margin-top: 0.75rem; font-size: 0.75rem; }
.import-warnings summary { cursor: pointer; color: var(--color-text-muted); }
.import-warnings summary:hover { color: var(--color-text); }
.import-warnings ul { margin: 0.5rem 0 0; padding-left: 1.1rem; }
.import-warnings li { margin: 0.15rem 0; }

/* --- Workspace: rail + open day ------------------------------------------- */
.import-workspace {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
  align-items: start;
}
@media (min-width: 56rem) {
  .import-workspace { grid-template-columns: 16rem 1fr; }
}
.import-daylist {
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 0.6rem;
  padding: 0.5rem;
  max-height: 36rem;
  overflow-y: auto;
}
.import-daylist-items { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.2rem; }
.import-dl-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  text-align: left;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 0.4rem;
  padding: 0.4rem 0.55rem;
  cursor: pointer;
  font-size: 0.8rem;
  color: var(--color-text);
  transition: border-color 140ms ease, background-color 140ms ease;
}
.import-dl-row:hover { border-color: var(--color-border); background: var(--color-surface-2); }
.import-dl-row.is-selected { border-color: var(--color-accent); background: rgba(255, 136, 69, 0.1); }
.import-dl-date { flex: 1 1 auto; }
.import-dl-meta {
  flex-basis: 100%;
  color: var(--color-text-faint);
  font-size: 0.7rem;
}
.import-dl-count { color: var(--color-text-muted); font-size: 0.75rem; display: inline-flex; align-items: center; gap: 0.3rem; }
.import-dl-unknown { color: var(--color-accent); font-size: 0.7rem; }

/* --- Status badge --------------------------------------------------------- */
.import-badge {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-radius: 9999px;
  padding: 0.1rem 0.5rem;
  border: 1px solid transparent;
}
.import-badge--pending { color: var(--color-accent); background: rgba(255, 136, 69, 0.12); }
.import-badge--approved { color: var(--color-positive); background: rgba(95, 212, 156, 0.12); }
.import-badge--skipped { color: var(--color-text-faint); background: rgba(255, 255, 255, 0.04); }

/* --- Open day panel ------------------------------------------------------- */
.import-day-panel-slot { min-width: 0; }
.import-day-panel {
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 0.6rem;
  padding: 1.25rem;
}
.import-day-panel--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 8rem;
  text-align: center;
}
.import-day-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  padding-bottom: 0.85rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}
.import-day-title { margin: 0; min-width: 0; }
.import-day-date { font-size: 1.25rem; color: var(--color-text); }
.import-day-tz { margin-left: 0.5rem; font-size: 0.75rem; color: var(--color-text-faint); }

/* Raw Google Timeline sequence. */
.import-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.55rem;
}
.import-section-title {
  margin: 0;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1rem;
  color: var(--color-text);
  letter-spacing: 0;
}
.import-section-meta { font-size: 0.7rem; color: var(--color-text-faint); }
.import-timeline {
  margin-bottom: 1.15rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}
.import-timeline-scale {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  margin: 0 0 0.35rem 13rem;
  font-size: 0.62rem;
  color: var(--color-text-faint);
}
.import-timeline-scale span:not(:last-child) { text-align: left; }
.import-timeline-scale span:last-child { text-align: right; }
.import-timeline-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.import-timeline-visit {
  display: grid;
  grid-template-columns: minmax(10rem, 13rem) 1fr;
  gap: 0.6rem;
  align-items: center;
}
.import-timeline-rail {
  position: relative;
  height: 0.7rem;
  border-radius: 999px;
  background:
    linear-gradient(to right,
      transparent 0,
      transparent calc(25% - 1px),
      rgba(255, 255, 255, 0.08) calc(25% - 1px),
      rgba(255, 255, 255, 0.08) 25%,
      transparent 25%,
      transparent calc(50% - 1px),
      rgba(255, 255, 255, 0.08) calc(50% - 1px),
      rgba(255, 255, 255, 0.08) 50%,
      transparent 50%,
      transparent calc(75% - 1px),
      rgba(255, 255, 255, 0.08) calc(75% - 1px),
      rgba(255, 255, 255, 0.08) 75%,
      transparent 75%),
    var(--color-surface-2);
  overflow: hidden;
}
.import-timeline-bar {
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--visit-left);
  width: var(--visit-width);
  min-width: 3px;
  border-radius: inherit;
  background: var(--visit-color, var(--color-accent));
}
.import-timeline-copy {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.78rem;
}
.import-timeline-time {
  color: var(--color-text-muted);
  white-space: nowrap;
}
.import-timeline-label {
  color: var(--color-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.import-timeline-semantic {
  color: var(--color-text-faint);
  font-size: 0.65rem;
  white-space: nowrap;
}
.import-timeline-mins {
  margin-left: auto;
  color: var(--color-text-muted);
  font-size: 0.7rem;
  white-space: nowrap;
}
.import-timeline-visit--home { --visit-color: rgba(110, 168, 255, 0.78); }
.import-timeline-visit--work { --visit-color: rgba(95, 212, 156, 0.82); }
.import-timeline-visit--move { --visit-color: rgba(255, 184, 95, 0.82); }
.import-timeline-visit--split { --visit-color: rgba(180, 130, 255, 0.82); }
.import-timeline-visit--unknown { --visit-color: rgba(255, 136, 69, 0.82); }
@media (max-width: 44rem) {
  .import-timeline-scale { margin-left: 0; }
  .import-timeline-visit { grid-template-columns: 1fr; gap: 0.25rem; }
}

/* Proposed lines list. */
.import-lines { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.25rem; }
.import-line {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.8rem;
  padding: 0.25rem 0.4rem;
  border-radius: 0.35rem;
}
.import-line:nth-child(odd) { background: var(--color-surface-2); }
.import-line-time { color: var(--color-text-muted); }
.import-line-label { color: var(--color-text); }
.import-line-tags { color: var(--color-accent); font-size: 0.7rem; }
.import-line-mins { margin-left: auto; color: var(--color-text-muted); font-variant-numeric: tabular-nums; }
.import-line-total { margin: 0.75rem 0 0; font-size: 0.8rem; color: var(--color-text); }
.import-no-lines { margin: 0.5rem 0; font-size: 0.85rem; }
.import-notes { display: flex; flex-wrap: wrap; gap: 0.25rem 1rem; margin-top: 0.5rem; }

.outlook-item-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}
.outlook-item-table th,
.outlook-item-table td {
  padding: 0.45rem 0.5rem;
  border-top: 1px solid var(--color-border);
  vertical-align: top;
}
.outlook-item-table th {
  width: 7rem;
  color: var(--color-text-faint);
  font-weight: 500;
  text-align: left;
}
.outlook-item-table td { color: var(--color-text); }

/* Approve outcome banner. */
.import-outcome {
  margin: 0 0 1rem;
  font-size: 0.8rem;
  border-radius: 0.4rem;
  padding: 0.5rem 0.75rem;
}
.import-outcome--dry { color: var(--color-text-muted); background: var(--color-surface-2); border: 1px solid var(--color-border); }
.import-outcome--ok { color: var(--color-positive); background: rgba(95, 212, 156, 0.1); }
.import-outcome--warn { color: var(--color-negative); background: rgba(255, 122, 122, 0.1); }

/* Control rows. */
.import-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-border);
}
.import-skip { margin-left: auto; }

/* Classify form. */
.import-classify {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-border);
}
.import-classify-title { margin: 0 0 0.75rem; font-family: var(--font-display); font-style: italic; font-weight: 500; color: var(--color-text); }
.import-classify-hints {
  margin: 0 0 1rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: 0.5rem 1rem;
}
.import-classify-hints div { display: flex; flex-direction: column; gap: 0.1rem; min-width: 0; }
.import-classify-hints dt {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-faint);
}
.import-classify-hints dd { margin: 0; font-size: 0.8rem; color: var(--color-text-muted); }
.import-placeid { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.import-classify-map {
  margin: 0 0 1rem;
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  overflow: hidden;
  background: var(--color-surface-2);
}
.import-classify-map iframe {
  display: block;
  width: 100%;
  height: 14rem;
  border: 0;
}
.import-map-link {
  display: inline-flex;
  margin: 0.55rem 0.7rem 0.65rem;
  font-size: 0.72rem;
  color: var(--color-accent);
  text-decoration: none;
}
.import-map-link:hover { text-decoration: underline; }
.import-classify-quick {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin: -0.25rem 0 1rem;
}
.import-classify-quick .field-label { margin: 0 0.25rem 0 0; }
.import-classify-row { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 0.75rem; margin-bottom: 0.75rem; }

/* Visual proposal editor. */
.import-proposal-editor {
  margin: 0 0 1.15rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}
.import-editor-scale {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  margin-bottom: 0.35rem;
  font-size: 0.62rem;
  color: var(--color-text-faint);
}
.import-editor-scale span:last-child { text-align: right; }
.import-editor-track {
  position: relative;
  height: 2.35rem;
  border: 1px solid var(--color-border);
  border-radius: 0.45rem;
  background:
    linear-gradient(to right,
      transparent 0,
      transparent calc(25% - 1px),
      rgba(255,255,255,0.08) calc(25% - 1px),
      rgba(255,255,255,0.08) 25%,
      transparent 25%,
      transparent calc(50% - 1px),
      rgba(255,255,255,0.08) calc(50% - 1px),
      rgba(255,255,255,0.08) 50%,
      transparent 50%,
      transparent calc(75% - 1px),
      rgba(255,255,255,0.08) calc(75% - 1px),
      rgba(255,255,255,0.08) 75%,
      transparent 75%),
    var(--color-surface-2);
  overflow: hidden;
}
.import-editor-bar {
  position: absolute;
  top: 0.45rem;
  height: 1.4rem;
  min-width: 0.7rem;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 0.35rem;
  background: rgba(95, 212, 156, 0.8);
  color: var(--color-bg);
  cursor: grab;
  padding: 0;
  overflow: hidden;
  display: flex;
  align-items: center;
  z-index: 1;
}
.import-editor-bar:active { cursor: grabbing; }
.import-editor-bar--dragging {
  overflow: visible;
  z-index: 2;
  box-shadow: 0 0 0 2px var(--color-accent);
}
.import-editor-lunch {
  position: absolute;
  top: 0.35rem;
  height: 1.6rem;
  border: 1px dashed rgba(245, 168, 94, 0.85);
  border-radius: 0.35rem;
  background: rgba(245, 168, 94, 0.18);
  color: var(--color-text);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.62rem;
  pointer-events: none;
  z-index: 0;
}
.import-editor-bar-label {
  min-width: 0;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.68rem;
  padding: 0 0.25rem;
  pointer-events: none;
}
.import-editor-duration {
  position: absolute;
  left: 50%;
  top: -1.5rem;
  transform: translateX(-50%);
  border-radius: 0.25rem;
  background: var(--color-accent);
  color: #000;
  padding: 0.05rem 0.35rem;
  font-size: 0.64rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
  pointer-events: none;
  display: none;
}
.import-editor-bar--dragging .import-editor-duration { display: inline-flex; }
.import-editor-handle {
  width: 0.36rem;
  height: 100%;
  flex: 0 0 auto;
  background: rgba(13, 12, 10, 0.28);
  cursor: ew-resize;
}
.import-editor-rows {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-top: 0.65rem;
}
.import-editor-row {
  display: grid;
  grid-template-columns: 6.8rem minmax(8rem, 1fr) minmax(8rem, 12rem) minmax(5rem, 8rem);
  gap: 0.45rem;
  align-items: center;
}
.import-editor-row-time { color: var(--color-text-muted); font-size: 0.76rem; }
.import-editor-label-input,
.import-editor-type-input,
.import-editor-project { width: 100%; box-sizing: border-box; }
.import-editor-controls {
  border-top: 0;
  margin-top: 0.75rem;
  padding-top: 0;
}
@media (max-width: 48rem) {
  .import-editor-row { grid-template-columns: 1fr; }
}

/* Edit form. */
.import-edit { margin-top: 1.25rem; padding-top: 1rem; border-top: 1px solid var(--color-border); }
.import-edit-title { margin: 0 0 0.75rem; font-family: var(--font-display); font-style: italic; font-weight: 500; color: var(--color-text); }
.import-edit-text {
  width: 100%;
  box-sizing: border-box;
  resize: vertical;
  font-size: 0.85rem;
  line-height: 1.6;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  padding: 0.75rem;
  color: var(--color-text);
}
.import-edit-text:focus { outline: none; border-color: var(--color-accent); }
.import-edit .import-controls { border-top: none; padding-top: 0; margin-top: 0.75rem; }

.import-empty {
  text-align: center;
  border: 1px dashed var(--color-border);
  border-radius: 0.6rem;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

/* htmx in-flight: dim a submitting import form. */
.import-classify.htmx-request,
.import-edit.htmx-request,
.import-upload-form.htmx-request { opacity: 0.75; }

/* =========================================================================
 * P4 integration — surfaces the BUILD agents added without their own CSS:
 * the home toolbar, the Traggo-offline banner, the manual-entry form, the
 * Ctrl/Cmd+K command composer, the time-report panel, and the data-quality
 * panel. (The shortcuts overlay, first-run hint and toast region ship their
 * own scoped <style> blocks.) All reference the Editorial Dark / Ink tokens.
 * ========================================================================= */

/* --- Home toolbar (filter summary + command button) ----------------------- */
.page__toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-bottom: 1.25rem;
  padding: 0.55rem 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 0.6rem;
  background: var(--color-surface);
}
.page__toolbar-hint { font-size: 0.75rem; color: var(--color-text-muted); }
.page__toolbar-active {
  margin-right: auto;
  max-width: 18rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.625rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  border-radius: 0.375rem;
  padding: 0.2rem 0.5rem;
}
.composer-trigger {
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  color: var(--color-text-muted);
  border-radius: 0.375rem;
  padding: 0.3rem 0.6rem;
  font-size: 0.7rem;
  cursor: pointer;
  transition: border-color 140ms ease, color 140ms ease;
}
.composer-trigger:hover { border-color: var(--color-border-strong); color: var(--color-text); }
.composer-trigger-key { margin-left: 0.35rem; font-size: 0.625rem; color: var(--color-text-faint); }

/* --- Traggo-offline banner (graceful degradation) ------------------------- */
.traggo-banner {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
  padding: 0.85rem 1rem;
  border: 1px solid color-mix(in srgb, var(--color-accent) 45%, transparent);
  background: rgba(255, 136, 69, 0.08);
  border-radius: 0.6rem;
}
.traggo-banner__icon { font-size: 1.1rem; line-height: 1.3; flex-shrink: 0; color: var(--color-accent); }
.traggo-banner__body { min-width: 0; }
.traggo-banner__title { margin: 0; font-weight: 500; color: var(--color-text); }
.traggo-banner__detail { margin: 0.25rem 0 0; font-size: 0.7rem; color: var(--color-text-muted); word-break: break-word; }
.traggo-banner__hint { margin: 0.35rem 0 0; font-size: 0.7rem; color: var(--color-text-faint); }

/* --- Manual entry form ---------------------------------------------------- */
.manual-entry {
  margin-bottom: 1.5rem;
  padding: 1rem 1.1rem;
  border: 1px solid var(--color-border);
  border-radius: 0.7rem;
  background: var(--color-surface);
}
.manual-entry-head { margin-bottom: 0.75rem; }
.manual-entry-title { margin: 0; font-size: 1.05rem; color: var(--color-text); }
.manual-entry-sub { margin-left: 0.5rem; font-size: 0.8rem; color: var(--color-text-muted); }
.manual-entry-form {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.75rem;
}
.manual-entry-tool,
.manual-entry-form .field input,
.manual-entry-form .field select,
.quick-entry-form .field input,
.quick-entry-form .field select {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: 0.4rem;
  color: var(--color-text);
  padding: 0.35rem 0.5rem;
  font-size: 0.8rem;
}
.manual-entry-form .field input:focus,
.manual-entry-form .field select:focus,
.quick-entry-form .field input:focus,
.quick-entry-form .field select:focus { outline: none; border-color: var(--color-accent); }
.manual-entry-error { flex-basis: 100%; margin: 0; }
.manual-entry.htmx-request { opacity: 0.75; }

/* --- Command composer ----------------------------------------------------- */
.page__composer { margin-bottom: 1.5rem; }
.composer {
  border: 1px solid var(--color-border);
  border-radius: 0.7rem;
  background: var(--color-surface);
  padding: 0.85rem 1rem;
}
.composer-form { display: flex; flex-direction: column; gap: 0.75rem; }
.composer-row { display: flex; align-items: flex-end; gap: 0.65rem; }
.composer-field { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 0.3rem; }
.composer-label {
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.composer-help { margin-left: 0.35rem; color: var(--color-text-faint); cursor: help; }
.composer-input {
  width: 100%;
  box-sizing: border-box;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: 0.45rem;
  color: var(--color-text);
  padding: 0.5rem 0.6rem;
  font-size: 0.85rem;
}
.composer-input:focus { outline: none; border-color: var(--color-accent); }
.composer-submit { white-space: nowrap; }
.composer-evidence, .composer-proposal {
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  background: var(--color-surface-2);
  padding: 0.7rem 0.8rem;
  font-size: 0.78rem;
}
.composer-evidence-head, .composer-proposal-head {
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  margin-bottom: 0.4rem;
}
.composer-proposal-head { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }
.composer-dl { display: grid; grid-template-columns: auto 1fr; gap: 0.2rem 0.75rem; margin: 0; }
.composer-dl dt { color: var(--color-text-faint); }
.composer-dl dd { margin: 0; color: var(--color-text); }
.composer-stage {
  font-size: 0.6rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 0.05rem 0.45rem;
}
.composer-stage--on { color: var(--color-accent); border-color: var(--color-accent); }
.composer-summary { display: flex; flex-wrap: wrap; gap: 0.75rem; margin: 0.5rem 0 0; }
.composer-summary div { display: flex; flex-direction: column; }
.composer-summary dt { font-size: 0.6rem; text-transform: uppercase; color: var(--color-text-faint); }
.composer-summary dd { margin: 0; color: var(--color-text); }
.composer-textarea {
  width: 100%;
  box-sizing: border-box;
  resize: vertical;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0.4rem;
  color: var(--color-text);
  padding: 0.5rem;
  margin-top: 0.3rem;
  font-size: 0.78rem;
  line-height: 1.5;
}
.composer-textarea:focus { outline: none; border-color: var(--color-accent); }
.composer-warnings, .composer-validation { margin: 0.5rem 0 0; padding-left: 1.1rem; color: var(--color-accent); }
.composer-entries { margin: 0.5rem 0 0; padding-left: 1.1rem; }
.composer-entry { display: flex; flex-wrap: wrap; gap: 0.5rem; font-size: 0.72rem; }
.composer-tag { color: var(--color-text-muted); }
.composer-msg { margin: 0.4rem 0 0; }
.composer-success { color: var(--color-positive); font-size: 0.78rem; }
.composer .span-swatch { display: inline-block; width: 0.7rem; height: 0.7rem; border-radius: 0.2rem; vertical-align: middle; margin-right: 0.3rem; }

/* --- Time-report panel ---------------------------------------------------- */
.trp {
  border: 1px solid var(--color-border);
  border-radius: 0.7rem;
  background: var(--color-surface);
  padding: 1rem 1.1rem;
}
.trp-head { display: flex; align-items: baseline; justify-content: space-between; gap: 0.5rem; margin-bottom: 0.6rem; }
.trp-title { margin: 0; font-family: var(--font-display); font-size: 1rem; color: var(--color-text); }
.trp-period { font-size: 0.7rem; color: var(--color-text-faint); }
.trp-draft-form { display: flex; flex-direction: column; gap: 0.6rem; }
.trp-textarea {
  width: 100%;
  box-sizing: border-box;
  resize: vertical;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: 0.45rem;
  color: var(--color-text);
  padding: 0.6rem;
  font-size: 0.78rem;
  line-height: 1.55;
  font-family: var(--font-mono);
}
.trp-textarea:focus { outline: none; border-color: var(--color-accent); }
.trp-actions { display: flex; align-items: center; gap: 0.6rem; flex-wrap: wrap; }
.trp-hint { font-size: 0.68rem; color: var(--color-text-faint); }
.trp-empty { margin: 0.25rem 0 0; }
.trp-result { margin-top: 0.75rem; }
.trp-preview { display: flex; flex-direction: column; gap: 0.6rem; }
.trp-preview-head { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; }
.trp-preview-count { font-size: 0.75rem; color: var(--color-text); }
.trp-status { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-text-faint); }
.trp-status[data-ready="true"] { color: var(--color-positive); }
.trp-entries { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.35rem; }
.trp-entry { border: 1px solid var(--color-border); border-radius: 0.4rem; padding: 0.4rem 0.55rem; background: var(--color-surface-2); }
.trp-entry-top { display: flex; justify-content: space-between; gap: 0.5rem; }
.trp-entry-range { color: var(--color-text); }
.trp-entry-mins { font-size: 0.72rem; }
.trp-entry-meta { display: flex; gap: 0.5rem; font-size: 0.72rem; margin-top: 0.15rem; }
.trp-entry-project { color: var(--color-text-muted); }
.trp-entry-note { color: var(--color-text-faint); }
.trp-totals { list-style: none; margin: 0; padding: 0; font-size: 0.72rem; }
.trp-total-row { display: flex; justify-content: space-between; padding: 0.1rem 0; }
.trp-review { border: 1px solid color-mix(in srgb, var(--color-accent) 40%, transparent); border-radius: 0.45rem; padding: 0.5rem 0.6rem; background: rgba(255, 136, 69, 0.06); }
.trp-review-title { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-accent); margin-bottom: 0.3rem; }
.trp-warnings { margin: 0; padding-left: 1.1rem; font-size: 0.72rem; color: var(--color-text-muted); }
.trp-apply-form { display: flex; flex-direction: column; gap: 0.5rem; }
.trp-proposal-label { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-text-faint); }
.trp-proposal {
  width: 100%;
  box-sizing: border-box;
  resize: vertical;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0.4rem;
  color: var(--color-text);
  padding: 0.5rem;
  margin-top: 0.25rem;
  font-size: 0.76rem;
  line-height: 1.5;
}
.trp-proposal:focus { outline: none; border-color: var(--color-accent); }
.trp-apply-actions { display: flex; align-items: center; gap: 0.6rem; flex-wrap: wrap; }
.trp-dirty { font-size: 0.68rem; color: var(--color-accent); }
.trp-applied { display: flex; flex-direction: column; gap: 0.2rem; }
.trp-applied-msg { margin: 0; color: var(--color-positive); }
.trp-applied-sub { margin: 0; font-size: 0.72rem; color: var(--color-text-faint); }
.trp.htmx-request, .trp-draft-form.htmx-request, .trp-apply-form.htmx-request, .trp-proposal-form.htmx-request { opacity: 0.8; }
/* Quick-capture proposal mode: a collapsed <details> below the text draft. */
.trp-proposal-mode { margin-top: 0.7rem; border-top: 1px solid var(--color-border); padding-top: 0.6rem; }
.trp-proposal-summary { cursor: pointer; font-size: 0.72rem; color: var(--color-text-muted); list-style: none; }
.trp-proposal-summary::-webkit-details-marker { display: none; }
.trp-proposal-summary::before { content: "+ "; color: var(--color-accent); }
.trp-proposal-mode[open] .trp-proposal-summary::before { content: "− "; }
.trp-proposal-form { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.5rem; }
.trp-proposal-preview .trp-warning[data-kind="validation"] { color: var(--color-negative, var(--color-accent)); }

/* --- Data-quality panel --------------------------------------------------- */
.dq-slot { display: block; }
.dq-card { display: flex; flex-direction: column; gap: 0.4rem; }
.dq-card--clean { flex-direction: row; align-items: center; gap: 0.5rem; }
.dq-clean-check { color: var(--color-positive); font-size: 1rem; }
.dq-clean-text { font-size: 0.8rem; color: var(--color-text-muted); }
.dq-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  width: 100%;
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  color: inherit;
  text-align: left;
}
.dq-title { margin: 0; display: flex; align-items: baseline; gap: 0.4rem; }
.dq-count { color: var(--color-accent); font-size: 0.75rem; }
.dq-toggle-glyph { color: var(--color-text-faint); }
.dq-summary { margin: 0; font-size: 0.72rem; color: var(--color-text-muted); }
.dq-list { list-style: none; margin: 0.3rem 0 0; padding: 0; display: flex; flex-direction: column; gap: 0.3rem; }
.dq-row { display: flex; align-items: center; gap: 0.5rem; font-size: 0.74rem; }
.dq-icon { flex-shrink: 0; }
.dq-icon--unclassified { color: var(--color-accent); }
.dq-icon--overlap { color: var(--color-negative); }
.dq-jump {
  background: transparent;
  border: none;
  border-bottom: 1px dotted var(--color-text-faint);
  color: var(--color-text-muted);
  cursor: pointer;
  padding: 0;
  font-size: 0.72rem;
}
.dq-jump:hover { color: var(--color-text); }
.dq-row-label { color: var(--color-text-faint); }

/* ════════════════════════════════════════════════════════════════════════
 * P4 design-polish layer — additive elevations applied after the section
 * styles above (no existing rule is edited, so htmx behavior + layout are
 * untouched). Goal: more depth, tactile primary actions, a clearer accent
 * focus ring on every control (WCAG AA / visible focus), and a calmer, more
 * cohesive "Editorial Dark / Ink" surface. Faithful to flextracker2's
 * identity; crisper and a touch more dimensional.
 * ════════════════════════════════════════════════════════════════════════ */

/* Shared elevation tokens (kept local to this layer so nothing above shifts). */
:root {
  --shadow-card: 0 1px 2px rgba(0, 0, 0, 0.35), 0 8px 24px -16px rgba(0, 0, 0, 0.6);
  --shadow-card-hover: 0 2px 4px rgba(0, 0, 0, 0.4), 0 18px 40px -22px rgba(0, 0, 0, 0.7);
  --ring-focus: 0 0 0 2px var(--color-bg), 0 0 0 4px var(--color-accent);
}

/* --- Card depth ----------------------------------------------------------- */
/* The primary surfaces were flat (1px border only); a faint, downward shadow
 * lifts them off the page background for the same dimensional feel FT2 had. */
.day-panel,
.ys-card,
.settings-card,
.manual-entry,
#time-report-panel,
.import-summary,
.import-day-panel,
.import-daylist {
  box-shadow: var(--shadow-card);
}

/* --- Restrained primary action -------------------------------------------- */
/* Keep primary actions distinct without turning them into bright orange slabs. */
.btn-accent {
  background-color: var(--btn-accent-bg);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.06) inset,
              0 8px 18px -16px rgba(0, 0, 0, 0.85);
}
.btn-accent:hover {
  background-color: var(--btn-accent-bg-hover);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.08) inset,
              0 10px 22px -18px rgba(0, 0, 0, 0.9);
}
.btn-accent:active { transform: translateY(0.5px); }
.btn-accent:disabled { box-shadow: none; transform: none; }

/* --- Visible focus on form controls (a11y) -------------------------------- */
/* The global :focus-visible ring covered buttons/links/role=button; inputs and
 * selects only changed border-color (a weak, low-contrast cue). Give every
 * editable control the same crisp accent ring on keyboard focus. */
input[type="text"]:focus-visible,
input[type="number"]:focus-visible,
input[type="date"]:focus-visible,
input[type="time"]:focus-visible,
input[type="color"]:focus-visible,
input[type="checkbox"]:focus-visible,
select:focus-visible,
textarea:focus-visible,
.composer-input:focus-visible,
.trp-textarea:focus-visible,
.import-edit-text:focus-visible {
  outline: none;
  box-shadow: var(--ring-focus);
  border-color: var(--color-accent);
}

/* --- Calendar cell polish ------------------------------------------------- */
/* A soft accent halo on the selected day, and a marginally stronger hover lift,
 * so the grid feels responsive without changing its geometry. */
.day-cell.is-selected {
  box-shadow: inset 0 0 0 2px var(--color-accent),
              0 0 0 1px rgba(255, 136, 69, 0.25),
              0 6px 18px -10px rgba(255, 136, 69, 0.5);
}
.day-cell:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 2px var(--color-accent), var(--ring-focus);
}

/* --- htmx swap scroll anchoring ------------------------------------------- */
/* When a day cell or filter swaps the panel/grid, give the scrolled-to target
 * breathing room from the viewport edge. */
#day-panel,
#calendar-root,
.day-panel { scroll-margin-top: 1.25rem; }

/* --- Progress ring track depth -------------------------------------------- */
/* A faint inner ring under the track reads as an engraved gauge. */
.ys-ring::before {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: 9999px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
  pointer-events: none;
}

/* --- Selection + link affordance refinement ------------------------------- */
.page__nav-link:focus-visible,
.settings-back:focus-visible,
.shortcuts-trigger:focus-visible {
  outline: none;
  box-shadow: var(--ring-focus);
  border-radius: 0.2rem;
}

@media (prefers-reduced-motion: reduce) {
  .btn-accent:active { transform: none; }
}

/* Honor an explicit reduced-transparency / high-contrast preference: drop the
 * decorative card washes and lean on solid borders. */
@media (prefers-contrast: more) {
  .ys-card::after,
  .settings-card::after { display: none; }
  .day-cell { box-shadow: inset 0 0 0 1px var(--color-border-strong); }
}

/* ---- login (interactive Traggo sign-in, login.templ) -------------------- */
.login-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.75rem;
  padding: 2rem 1rem;
}
.login-head { text-align: center; }
.login-card {
  width: 100%;
  max-width: 30rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  box-shadow: var(--shadow-card);
  padding: 1.75rem 1.75rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.login-title { font-size: 1.25rem; margin: 0; }
.login-sub { margin: -0.35rem 0 0.4rem; font-size: 0.85rem; line-height: 1.4; }
.login-error {
  margin: 0;
  padding: 0.6rem 0.8rem;
  border-radius: 8px;
  background: rgba(255, 122, 122, 0.12);
  border: 1px solid rgba(255, 122, 122, 0.4);
  color: var(--color-negative);
  font-size: 0.85rem;
}
.login-submit { margin-top: 0.4rem; align-self: flex-start; }
.remember-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.65rem;
  align-items: start;
  margin-top: -0.15rem;
  cursor: pointer;
}
.remember-row input {
  width: 1rem;
  height: 1rem;
  margin-top: 0.12rem;
}
.remember-row__label {
  display: block;
  font-size: 0.9rem;
  color: var(--color-text);
}
.remember-row__hint {
  display: block;
  margin-top: 0.1rem;
  font-size: 0.78rem;
  line-height: 1.35;
}
/* the hardcoded Traggo server, shown read-only above the credential fields */
.login-fixed-url {
  margin: 0;
  padding: 0.55rem 0.7rem;
  border-radius: 8px;
  background: var(--color-surface-2, rgba(255, 255, 255, 0.04));
  border: 1px solid var(--color-border, rgba(255, 255, 255, 0.1));
  font-size: 0.85rem;
  word-break: break-all;
  color: var(--color-text-muted, inherit);
}

/* logout sits inline in the header nav as a bare button styled like a nav link */
.page__nav-logout { display: inline; margin: 0; }
.page__nav-logout-btn { background: none; border: none; padding: 0; cursor: pointer; font: inherit; }
