/* ═══════════════════════════════════════════════════════════════════
   Playtypus UI  — single source of truth
   Replaces (fully — verified against current Components/*.razor markup,
   2026-06): app.css, v2-additions.css, v5-additions.css, gui-fixes.css,
   logbook.css, login.css.
   Historiskt hade den här filen samma "Replaces"-rad, men sex regler
   som fortfarande används av Components/*.razor hade aldrig flyttats
   över (se "Räddat från äldre filer"-sektionen längst ner). De äldre
   filerna har tagits bort från repot — leta inte efter dem igen.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Reset ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { margin: 0; background: var(--color-background, #F4F6FB); overflow-x: hidden; font-family: var(--font-family-body, system-ui); }
button { -webkit-tap-highlight-color: transparent; cursor: pointer; font-family: inherit; }
a      { -webkit-tap-highlight-color: transparent; }
img, svg { display: block; max-width: 100%; }
input, textarea, select { font-family: inherit; }

/* ── App shell ──────────────────────────────────────────────────── */
#app { min-height: 100dvh; background: var(--color-background); }

.app-shell {
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
  max-width: var(--app-max-width, 480px);
  margin: 0 auto;
  background: var(--color-background);
  position: relative;
}

/* ── Header ─────────────────────────────────────────────────────── */
.app-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--header-background, var(--color-surface));
  padding: 0 var(--spacing-lg, 24px);
  padding-top: env(safe-area-inset-top);
  min-height: var(--header-min-height, 60px);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm, 8px);
  border-bottom: var(--header-border, 1.5px solid var(--color-border));
  box-shadow: var(--card-shadow);
  transition: background-color 200ms ease, border-color 200ms ease;
}

.app-header__brand {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}

.app-header__logo,
.app-header__mark { width: 28px; height: 28px; flex-shrink: 0; }

.app-header__name {
  font-family: var(--font-family-heading, system-ui);
  font-size: var(--font-size-lg, 1.125rem);
  font-weight: var(--font-weight-heading, 900);
  color: var(--color-text);
  letter-spacing: var(--letter-spacing-heading, -0.02em);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app-header__accent {
  color: var(--color-primary);
}

.app-header__actions {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

/* ── Icon button ─────────────────────────────────────────────────── */
.icon-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: transparent;
  font-size: 1.1rem;
  color: var(--color-text-muted);
  transition: background var(--transition-fast, 150ms ease), color var(--transition-fast, 150ms ease);
  flex-shrink: 0;
}
.icon-btn:hover   { background: var(--color-surface-alt); color: var(--color-text); }
.icon-btn--active { background: var(--color-primary-light); color: var(--color-primary); }

/* ── Overflow menu ──────────────────────────────────────────────── */
.header-overflow { position: relative; }

.header-overflow__trigger {
  background: transparent;
  border: none;
  cursor: pointer;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  transition: background var(--transition-fast, 150ms ease);
}
.header-overflow__trigger:hover { background: var(--color-surface-alt); }

.header-overflow__backdrop { position: fixed; inset: 0; z-index: 40; }

.header-overflow__menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  /* Prevent clipping outside the app shell on very narrow viewports */
  max-width: min(260px, calc(100vw - 32px));
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--border-radius-lg, 18px);
  min-width: 200px;
  list-style: none;
  z-index: 50;
  box-shadow: var(--card-shadow-hover);
  overflow: hidden;
  padding: 4px;
  animation: menuSlideIn 0.15s cubic-bezier(0.34,1.4,0.64,1);
}

@keyframes menuSlideIn {
  from { opacity: 0; transform: translateY(-6px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.overflow-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm, 8px);
  width: 100%;
  padding: 11px var(--spacing-md, 16px);
  background: transparent;
  border: none;
  border-radius: var(--border-radius-md, 12px);
  cursor: pointer;
  font-family: var(--font-family-body, system-ui);
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 600;
  color: var(--color-text);
  transition: background var(--transition-fast, 150ms ease);
  text-align: left;
  min-height: 44px;
}
.overflow-item:hover { background: var(--color-surface-alt); }
.overflow-item__icon { display: flex; align-items: center; justify-content: center; width: 22px; flex-shrink: 0; }

/* Font-scale slider row: explicit column layout, not overrideable */
li.overflow-item--slider { list-style: none; }
.overflow-item.overflow-item--slider {
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 6px;
  padding-bottom: 12px;
  min-height: auto;
}
.font-scale-slider { width: 100%; accent-color: var(--color-primary); cursor: pointer; margin-top: 2px; }

/* ── Category tabs ───────────────────────────────────────────────── */
.category-tabs {
  display: flex;
  gap: 6px;
  padding: var(--spacing-md, 16px) var(--spacing-lg, 24px) 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.category-tabs::-webkit-scrollbar { display: none; }

.category-tab {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 14px;
  border-radius: var(--border-radius-pill, 999px);
  border: 1.5px solid var(--color-border);
  background: var(--color-surface);
  font-family: var(--font-family-body, system-ui);
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 700;
  color: var(--color-text-muted);
  white-space: nowrap;
  transition: all var(--transition-fast, 150ms ease);
}
.category-tab--active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-text-on-primary);
  box-shadow: 0 2px 8px var(--color-panic-glow, rgba(91,141,239,0.22));
}
.category-tab:hover:not(.category-tab--active) {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

/* ── Panic section ───────────────────────────────────────────────── */
.panic-section { padding: var(--spacing-md, 16px) var(--spacing-lg, 24px) 0; }

.panic-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  min-height: 76px;
  border-radius: var(--border-radius-lg, 18px);
  border: none;
  background: var(--color-primary);
  color: var(--color-text-on-primary);
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease;
  box-shadow: 0 4px 20px var(--color-panic-glow, rgba(91,141,239,0.28));
  position: relative;
  overflow: hidden;
}
.panic-btn::after {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  border: 2px solid var(--color-primary);
  opacity: 0;
  animation: panicPulse 2s ease-out infinite;
}
@keyframes panicPulse {
  0%   { inset: 0;   opacity: 0.5; }
  100% { inset: -8px; opacity: 0; }
}
.panic-btn:active { transform: scale(0.97); }
.panic-btn__icon  { font-size: 1.75rem; line-height: 1; }
.panic-btn__label {
  font-family: var(--font-family-heading, system-ui);
  font-size: var(--font-size-md, 1rem);
  font-weight: 900;
  letter-spacing: -0.01em;
}
.panic-subtitle {
  text-align: center;
  font-size: var(--font-size-xs, 0.75rem);
  color: var(--color-text-muted);
  margin-top: 6px;
}

/* ── Filter trigger bar ─────────────────────────────────────────── */
.filter-trigger-bar {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm, 8px);
  padding: var(--spacing-md, 16px) var(--spacing-lg, 24px) 0;
}

.filter-trigger-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: var(--border-radius-pill, 999px);
  border: 1.5px solid var(--color-border);
  background: var(--color-surface);
  font-family: var(--font-family-body, system-ui);
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 700;
  color: var(--color-text-muted);
  transition: all var(--transition-fast, 150ms ease);
}
.filter-trigger-btn--active { border-color: var(--color-primary); color: var(--color-primary); background: var(--color-primary-light); }
.filter-trigger-btn__icon   { display: inline-flex; }
.filter-trigger-btn__badge  { color: var(--color-primary); font-size: 0.6rem; }
.filter-count { font-size: var(--font-size-xs, 0.75rem); color: var(--color-text-muted); font-weight: 700; margin-left: auto; }

/* ── Activity grid ───────────────────────────────────────────────── */
.activity-grid-section {
  flex: 1;
  padding: var(--spacing-md, 16px) var(--spacing-lg, 24px);
}

.activity-grid {
  display: grid;
  grid-template-columns: var(--grid-columns, 1fr);
  gap: var(--grid-gap, var(--spacing-sm, 8px));
}

/* ── Activity card ───────────────────────────────────────────────── */
.activity-card {
  position: relative; /* positioning context for .activity-card__fav overlay */
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-md, 16px);
  width: 100%;
  padding: var(--spacing-md, 16px);
  border-radius: var(--border-radius-lg, 18px);
  border: var(--card-border-width, 1.5px) solid var(--color-border);
  background: var(--color-surface);
  text-align: left;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: box-shadow 180ms ease, transform 120ms ease,
              border-color 180ms ease, background-color 200ms ease;
  box-shadow: var(--card-shadow);
  animation: cardIn 0.3s cubic-bezier(0.34, 1.1, 0.64, 1) both;
  border-left: var(--card-border-left-width, 3px) solid transparent;
}
.activity-card:hover {
  box-shadow: var(--card-shadow-hover);
  transform: translateY(var(--card-hover-translate-y, -2px));
  border-color: var(--color-primary);
  border-left-color: var(--color-primary);
}
.activity-card:active  { transform: scale(0.98); box-shadow: var(--card-shadow); }
.activity-card--done   { opacity: 0.5; }
.activity-card--quiz   { border-left-color: var(--color-cat-calm, #8B5CF6); }

@keyframes cardIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.activity-card__emoji {
  font-size: var(--card-emoji-size, 2rem);
  line-height: 1;
  flex-shrink: 0;
  width: 44px;
  text-align: center;
  position: relative;
}

.done-badge, .quiz-badge {
  position: absolute;
  bottom: -4px;
  right: -4px;
  font-size: 0.7rem;
  background: var(--color-surface);
  border-radius: 50%;
  line-height: 1;
  padding: 1px;
}

.activity-card__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.activity-card__header {
  display: flex;
  flex-wrap: wrap; /* safety net: if content still can't fit, it wraps instead of overflowing the card */
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-sm, 8px);
  margin-bottom: 2px;
  padding-right: 40px; /* reserve room for the .activity-card__fav corner overlay */
}

.activity-card__header-right {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.activity-card__title {
  font-family: var(--font-family-heading, system-ui);
  font-size: var(--font-size-md, 1rem);
  font-weight: var(--font-weight-card-title, 800);
  color: var(--color-text);
  line-height: 1.25;
  letter-spacing: -0.01em;
}

.activity-card__description {
  font-size: var(--font-size-sm, 0.875rem);
  color: var(--color-text-muted);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.activity-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 6px;
}

.activity-card__expand-hint {
  font-size: 0.7rem;
  color: var(--color-primary);
  font-weight: 700;
  opacity: 0;
  transition: opacity var(--transition-fast, 150ms ease);
  margin-top: 4px;
}
.activity-card:hover .activity-card__expand-hint { opacity: 1; }

/* ── Meta chip ───────────────────────────────────────────────────── */
.meta-chip {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 8px;
  border-radius: var(--border-radius-pill, 999px);
  border: 1px solid var(--color-border);
  background: var(--color-surface-alt);
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--color-text-muted);
  white-space: nowrap;
}
.meta-chip--green { background: rgba(34,197,94,0.1); border-color: rgba(34,197,94,0.3); color: #15803d; }
.meta-chip--gold  { background: rgba(217,164,65,0.12); border-color: rgba(217,164,65,0.35); color: #a3711c; }

/* ── Category chip ───────────────────────────────────────────────── */
.category-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: var(--border-radius-pill, 999px);
  border: 1.5px solid var(--color-border);
  font-size: var(--font-size-xs, 0.75rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--color-surface-alt);
  color: var(--color-text-muted);
}

/* Category chip tints */
.category-chip--movement { background: rgba(59,130,246,0.1); border-color: rgba(59,130,246,0.25); color: #1d4ed8; }
.category-chip--creative  { background: rgba(236,72,153,0.1); border-color: rgba(236,72,153,0.25); color: #be185d; }
.category-chip--calm      { background: rgba(139,92,246,0.1); border-color: rgba(139,92,246,0.25); color: #6d28d9; }
.category-chip--social    { background: rgba(245,158,11,0.1); border-color: rgba(245,158,11,0.25); color: #b45309; }

/* ── Level badges ────────────────────────────────────────────────── */
.level-badge {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 2px 8px;
  border-radius: var(--border-radius-pill, 999px);
  background: var(--color-surface-alt);
  border: 1.5px solid var(--color-border);
  color: var(--color-text-muted);
  white-space: nowrap;
}
.level-badge--1 { color: #15803d; border-color: rgba(34,197,94,0.35); background: rgba(34,197,94,0.1); }
.level-badge--2 { color: #b45309; border-color: rgba(245,158,11,0.35); background: rgba(245,158,11,0.1); }
.level-badge--3 { color: #be185d; border-color: rgba(236,72,153,0.35); background: rgba(236,72,153,0.1); }

/* ── Favourite button ────────────────────────────────────────────── */
.favorite-btn {
  background: none;
  border: 1.5px solid var(--color-border);
  border-radius: 50%;
  width: 34px;
  height: 34px;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--color-text-muted);
  transition: all var(--transition-fast, 150ms ease);
  flex-shrink: 0;
}
.favorite-btn--active { color: #e04a6a; border-color: #e04a6a; background: rgba(224,74,106,0.08); }
.favorite-btn--lg     { width: 40px; height: 40px; font-size: 1.25rem; }

/* ── Card corner-overlay favourite (ActivityCard) ────────────────────
   Anchored to .activity-card (position:relative) rather than living in
   the header flex row — it can never be squeezed out by the category
   chip / level badge on narrow cards. z-index above card content;
   stopPropagation on click keeps it from also opening the card. */
.activity-card__fav {
  position: absolute;
  top: var(--spacing-sm, 10px);
  right: var(--spacing-sm, 10px);
  z-index: 2;
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--color-text-muted);
  box-shadow: 0 1px 4px rgba(0,0,0,0.08);
  transition: all var(--transition-fast, 150ms ease);
}
.activity-card__fav--active { color: #e04a6a; border-color: #e04a6a; background: rgba(224,74,106,0.08); }
.activity-card__fav:hover   { transform: scale(1.06); }
.activity-card__fav:active  { transform: scale(0.92); }

/* ── Buttons ─────────────────────────────────────────────────────── */
.btn-primary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  min-height: 52px;
  border-radius: var(--border-radius-md, 12px);
  border: none;
  background: var(--color-primary);
  color: var(--color-text-on-primary);
  font-family: var(--font-family-heading, system-ui);
  font-size: var(--font-size-md, 1rem);
  font-weight: 800;
  letter-spacing: -0.01em;
  cursor: pointer;
  transition: opacity 150ms ease, transform 100ms ease;
}
.btn-primary:hover   { opacity: 0.9; }
.btn-primary:active  { transform: scale(0.97); }
.btn-primary:disabled { opacity: 0.4; cursor: not-allowed; }

.btn-secondary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  min-height: 48px;
  border-radius: var(--border-radius-md, 12px);
  border: 1.5px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text);
  font-family: var(--font-family-heading, system-ui);
  font-size: var(--font-size-md, 1rem);
  font-weight: 700;
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
}
.btn-secondary:hover  { border-color: var(--color-primary); color: var(--color-primary); background: var(--color-primary-light); }
.btn-secondary:active { transform: scale(0.97); }
.btn-secondary--inline { width: auto; padding: 0 var(--spacing-lg, 24px); min-height: 44px; }

.btn-done {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex: 1;
  min-height: 48px;
  border-radius: var(--border-radius-md, 12px);
  border: 1.5px solid var(--color-border);
  background: var(--color-surface-alt);
  color: var(--color-text-muted);
  font-family: var(--font-family-heading, system-ui);
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 700;
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
}
.btn-done--active {
  background: rgba(34,197,94,0.1);
  border-color: rgba(34,197,94,0.4);
  color: #15803d;
}

/* ── Empty state ─────────────────────────────────────────────────── */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-md, 16px);
  padding: var(--spacing-2xl, 48px) var(--spacing-lg, 24px);
  text-align: center;
}
.empty-state__emoji { font-size: 3.5rem; }
.empty-state__mark  { width: 64px; opacity: 0.15; }
.empty-state__title { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-xl, 1.375rem); font-weight: 900; color: var(--color-text); }
.empty-state__body  { font-size: var(--font-size-sm, 0.875rem); color: var(--color-text-muted); line-height: 1.6; }

/* ── Error state ─────────────────────────────────────────────────── */
.error-state { display: flex; flex-direction: column; align-items: center; gap: var(--spacing-md, 16px); padding: var(--spacing-2xl, 48px) var(--spacing-lg, 24px); text-align: center; }
.error-state__emoji { font-size: 3rem; }
.error-state__title { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-xl, 1.375rem); font-weight: 900; color: var(--color-text); }
.error-state__body  { font-size: var(--font-size-sm, 0.875rem); color: var(--color-text-muted); }
.error-screen__inner { display: flex; flex-direction: column; align-items: center; gap: var(--spacing-md, 16px); text-align: center; }
.error-screen__mark  { width: 80px; opacity: 0.25; }

/* ── Detail panel ────────────────────────────────────────────────── */
.detail-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: var(--overlay-backdrop, rgba(0,0,0,0.5));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
}

.detail-panel {
  background: var(--color-surface);
  border-radius: var(--detail-panel-radius, var(--border-radius-xl, 28px) var(--border-radius-xl, 28px) 0 0);
  width: 100%;
  max-width: var(--app-max-width, 480px);
  max-height: 92dvh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  animation: var(--detail-animation, slideUp 0.38s cubic-bezier(0.32, 0.72, 0, 1));
  position: relative;
  padding-bottom: max(var(--spacing-2xl, 48px), calc(env(safe-area-inset-bottom) + var(--spacing-lg, 24px)));
}

.detail-panel__handle {
  width: 36px;
  height: 4px;
  background: var(--color-border);
  border-radius: 2px;
  margin: 12px auto 0;
}

.detail-panel__hero {
  width: 100%;
  min-height: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-md, 16px);
  position: relative;
  background: var(--color-surface-alt);
  border-radius: 0;
}
.detail-panel__hero--image { min-height: 220px; background: var(--color-surface-warm); }

.detail-panel__emoji {
  font-size: 5rem;
  line-height: 1;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.1));
  animation: emojiPop 0.45s cubic-bezier(0.34, 1.4, 0.64, 1);
}

.detail-panel__emoji-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.28);
  border-radius: 0;
}
.detail-panel__emoji--on-image {
  position: absolute;
  bottom: -28px;
  left: var(--spacing-lg, 24px);
  font-size: 3.5rem;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.25));
}

.detail-panel__hero-actions {
  position: absolute;
  top: 0; right: 0; left: 0;
  display: flex;
  justify-content: flex-end;
  padding: var(--spacing-md, 16px);
}

.detail-close-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1.5px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
  font-size: 0.9rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background var(--transition-fast, 150ms ease);
}
.detail-close-btn:hover { background: var(--color-surface-alt); }

.detail-panel__content {
  padding: var(--spacing-md, 16px) var(--spacing-lg, 24px) 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md, 16px);
}

.detail-panel__meta-row { display: flex; align-items: center; gap: var(--spacing-sm, 8px); flex-wrap: wrap; }

.detail-panel__title {
  font-family: var(--font-family-heading, system-ui);
  font-size: var(--font-size-2xl, 1.75rem);
  font-weight: 900;
  color: var(--color-text);
  line-height: 1.15;
  letter-spacing: -0.025em;
}

.detail-panel__desc-row { display: flex; align-items: flex-start; gap: var(--spacing-sm, 8px); }
.detail-panel__description { font-size: var(--font-size-md, 1rem); color: var(--color-text-muted); line-height: 1.6; flex: 1; }
.detail-panel__chips { display: flex; flex-wrap: wrap; gap: 6px; }

.detail-section { display: flex; flex-direction: column; gap: var(--spacing-sm, 8px); }
.detail-section__title {
  font-size: var(--font-size-xs, 0.75rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--color-text-muted);
}
.detail-section__title-row { display: flex; align-items: center; justify-content: space-between; }
.detail-section__title-actions { display: flex; gap: 6px; align-items: center; }

/* ── Steps list ──────────────────────────────────────────────────── */
.steps-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm, 8px);
  counter-reset: step-counter;
}
.steps-list__item {
  display: flex;
  gap: var(--spacing-sm, 8px);
  align-items: flex-start;
  font-size: var(--font-size-md, 1rem);
  color: var(--color-text);
  line-height: 1.5;
  counter-increment: step-counter;
  padding: var(--spacing-sm, 8px) 0;
  border-bottom: 1px solid var(--color-border);
}
.steps-list__item:last-child { border-bottom: none; }
.steps-list__item::before {
  content: counter(step-counter);
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--color-primary);
  color: var(--color-text-on-primary);
  font-size: 0.7rem;
  font-weight: 900;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── Props list ──────────────────────────────────────────────────── */
.props-list { list-style: none; display: flex; flex-direction: column; gap: 6px; }
.props-list__item { display: flex; align-items: center; gap: 8px; font-size: var(--font-size-sm, 0.875rem); color: var(--color-text); }
.props-list__item::before { content: "•"; color: var(--color-primary); font-weight: 900; }

/* ── Safety note ─────────────────────────────────────────────────── */
.safety-note {
  display: flex;
  gap: var(--spacing-sm, 8px);
  background: rgba(245,158,11,0.08);
  border: 1.5px solid rgba(245,158,11,0.3);
  border-radius: var(--border-radius-md, 12px);
  padding: var(--spacing-md, 16px);
}
.safety-note__icon { flex-shrink: 0; display: flex; }
.safety-note__text { font-size: var(--font-size-sm, 0.875rem); font-weight: 600; color: #92400e; line-height: 1.5; }

/* ── Detail action row ───────────────────────────────────────────── */
.detail-action-row { display: flex; gap: var(--spacing-sm, 8px); }

/* ── Share row ───────────────────────────────────────────────────── */
.detail-share-row {
  display: flex;
  gap: var(--spacing-sm, 8px);
  flex-wrap: wrap;
  padding-top: var(--spacing-sm, 8px);
  border-top: 1px solid var(--color-border);
}
.share-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: transparent;
  border: 1.5px solid var(--color-border);
  border-radius: var(--border-radius-pill, 999px);
  padding: 6px 14px;
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 700;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
}
.share-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* ── Next in series ──────────────────────────────────────────────── */
.next-series-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-md, 16px);
  width: 100%;
  background: var(--color-surface-warm);
  border: 2px solid var(--color-primary);
  border-radius: var(--border-radius-lg, 18px);
  padding: var(--spacing-md, 16px);
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
  text-align: left;
}
.next-series-btn:hover { transform: translateX(4px); }
.next-series-btn__label { font-size: var(--font-size-xs, 0.75rem); font-weight: 800; color: var(--color-primary); text-transform: uppercase; letter-spacing: 0.06em; display: block; }
.next-series-btn__title { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-md, 1rem); font-weight: 800; color: var(--color-text); display: block; }
.next-series-btn__arrow { margin-left: auto; color: var(--color-primary); flex-shrink: 0; display: flex; }

/* ── Filter drawer ───────────────────────────────────────────────── */
.drawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 249;
  background: rgba(0,0,0,0.42);
  backdrop-filter: blur(4px);
  animation: fadeIn 0.2s ease;
}

.filter-drawer {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) translateY(100%);
  z-index: 250;
  background: var(--color-surface);
  border-radius: var(--border-radius-xl, 28px) var(--border-radius-xl, 28px) 0 0;
  width: 100%;
  max-width: var(--app-max-width, 480px);
  max-height: 88dvh;
  display: flex;
  flex-direction: column;
  transition: transform 0.36s cubic-bezier(0.32, 0.72, 0, 1);
  padding-bottom: max(var(--spacing-xl, 32px), env(safe-area-inset-bottom));
}
.filter-drawer--open { transform: translateX(-50%) translateY(0); }

.filter-drawer__handle { width: 36px; height: 4px; background: var(--color-border); border-radius: 2px; margin: 12px auto 0; flex-shrink: 0; }
.filter-drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md, 16px) var(--spacing-lg, 24px);
  flex-shrink: 0;
  border-bottom: 1px solid var(--color-border);
}
.filter-drawer__title { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-lg, 1.125rem); font-weight: 900; color: var(--color-text); }
.filter-drawer__body { flex: 1; overflow-y: auto; padding: var(--spacing-md, 16px) var(--spacing-lg, 24px); display: flex; flex-direction: column; gap: var(--spacing-lg, 24px); }
.filter-drawer__footer {
  flex-shrink: 0;
  border-top: 1px solid var(--color-border);
  padding: var(--spacing-md, 16px) var(--spacing-lg, 24px);
  padding-bottom: max(var(--spacing-md, 16px), env(safe-area-inset-bottom));
}

/* ── Filter sections ─────────────────────────────────────────────── */
.filter-section { display: flex; flex-direction: column; gap: var(--spacing-sm, 8px); }
.filter-section--row { flex-direction: row; align-items: center; justify-content: space-between; }
.filter-section__label { font-size: var(--font-size-xs, 0.75rem); font-weight: 800; text-transform: uppercase; letter-spacing: 0.07em; color: var(--color-text-muted); }

.filter-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 7px 14px;
  border-radius: var(--border-radius-pill, 999px);
  border: 1.5px solid var(--color-border);
  background: var(--color-surface-alt);
  font-family: var(--font-family-body, system-ui);
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 700;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
  white-space: nowrap;
}
.filter-chip--active { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-text-on-primary); }
.filter-chip:hover:not(.filter-chip--active) { border-color: var(--color-primary); color: var(--color-primary); }

/* ── Toggle ──────────────────────────────────────────────────────── */
.toggle-btn { display: flex; align-items: center; gap: var(--spacing-sm, 8px); background: none; border: none; cursor: pointer; font-family: var(--font-family-body, system-ui); font-size: var(--font-size-sm, 0.875rem); font-weight: 700; color: var(--color-text-muted); padding: 0; }
.toggle-btn__track { width: 44px; height: 26px; border-radius: var(--border-radius-pill, 999px); background: var(--color-border); position: relative; transition: background 200ms ease; flex-shrink: 0; }
.toggle-btn__thumb { position: absolute; top: 3px; left: 3px; width: 20px; height: 20px; border-radius: 50%; background: #fff; box-shadow: 0 1px 4px rgba(0,0,0,0.18); transition: transform 200ms ease; }
.toggle-btn--active .toggle-btn__track { background: var(--color-primary); }
.toggle-btn--active .toggle-btn__thumb { transform: translateX(18px); }

/* ── Search bar ──────────────────────────────────────────────────── */
.search-bar { position: relative; display: flex; align-items: center; }
.search-bar__inner { position: relative; flex: 1; display: flex; align-items: center; }
.search-bar__input {
  width: 100%;
  padding: 11px 40px 11px var(--spacing-md, 16px);
  border: 1.5px solid var(--color-border);
  border-radius: var(--border-radius-md, 12px);
  font-family: var(--font-family-body, system-ui);
  font-size: var(--font-size-md, 1rem);
  background: var(--color-surface-alt);
  color: var(--color-text);
  outline: none;
  transition: border-color var(--transition-fast, 150ms ease);
}
.search-bar__input:focus { border-color: var(--color-primary); background: var(--color-surface); }
.search-bar__icon, .search-bar__clear { position: absolute; right: 12px; background: none; border: none; display: flex; align-items: center; justify-content: center; color: var(--color-text-muted); cursor: pointer; }

/* ── Pack switcher ───────────────────────────────────────────────── */
.pack-switcher { min-height: 100dvh; display: flex; align-items: flex-start; justify-content: center; background: var(--color-background); padding: var(--spacing-xl, 32px) var(--spacing-lg, 24px); padding-top: max(var(--spacing-2xl, 48px), env(safe-area-inset-top)); }
.pack-switcher__inner { width: 100%; max-width: 440px; display: flex; flex-direction: column; gap: var(--spacing-lg, 24px); }
.pack-switcher__header { text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--spacing-sm, 8px); }
.pack-switcher__logo { width: 64px; height: 64px; }
.pack-switcher__title { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-3xl, 2.25rem); font-weight: 900; color: var(--color-primary); letter-spacing: -0.03em; }
.pack-switcher__subtitle { font-size: var(--font-size-sm, 0.875rem); color: var(--color-text-muted); font-weight: 600; }
.pack-switcher__grid { display: flex; flex-direction: column; gap: var(--spacing-sm, 8px); }

.pack-card {
  display: flex;
  align-items: center;
  gap: var(--spacing-md, 16px);
  padding: var(--spacing-md, 16px) var(--spacing-lg, 24px);
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--border-radius-lg, 18px);
  cursor: pointer;
  text-align: left;
  transition: all var(--transition-fast, 150ms ease);
  box-shadow: var(--card-shadow);
}
.pack-card:hover { box-shadow: var(--card-shadow-hover); transform: translateY(-2px); border-color: var(--color-primary); }
.pack-card:active { transform: scale(0.98); }
.pack-card__emoji { font-size: 2.25rem; flex-shrink: 0; }
.pack-card__name-wrap { flex: 1; min-width: 0; }
.pack-card__name { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-md, 1rem); font-weight: 800; color: var(--color-text); letter-spacing: -0.01em; }
.pack-card__tagline { font-size: var(--font-size-sm, 0.875rem); color: var(--color-text-muted); margin-top: 2px; }
.pack-card__arrow { color: var(--color-text-muted); font-size: 1.1rem; flex-shrink: 0; }

/* ── Situation presets ───────────────────────────────────────────── */
.situation-presets { display: flex; gap: 6px; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; padding: 0 var(--spacing-lg, 24px); }
.situation-presets::-webkit-scrollbar { display: none; }
.situation-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 14px;
  border-radius: var(--border-radius-pill, 999px);
  border: 1.5px solid var(--color-border);
  background: var(--color-surface);
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 700;
  color: var(--color-text-muted);
  white-space: nowrap;
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
  flex-shrink: 0;
}
.situation-chip:hover { border-color: var(--color-primary); color: var(--color-primary); }
.situation-chip--active { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-text-on-primary); }

/* ── Ready Now ───────────────────────────────────────────────────── */
.ready-now-section { padding: 0 var(--spacing-lg, 24px) var(--spacing-md, 16px); }
.ready-now-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--spacing-sm, 8px); }
.ready-now-title { font-size: var(--font-size-xs, 0.75rem); font-weight: 800; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.07em; }
.ready-now-sub   { font-size: var(--font-size-xs, 0.75rem); color: var(--color-text-muted); }
.ready-now-refresh { background: transparent; border: none; font-size: 1rem; color: var(--color-text-muted); cursor: pointer; padding: 0 4px; transition: transform 300ms ease; }
.ready-now-refresh:active { transform: rotate(180deg); }
.ready-now-cards { display: flex; gap: var(--spacing-sm, 8px); overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 4px; scrollbar-width: none; }
.ready-now-cards::-webkit-scrollbar { display: none; }
.ready-now-card {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--border-radius-md, 12px);
  padding: 9px 14px;
  white-space: nowrap;
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 700;
  color: var(--color-text);
  flex-shrink: 0;
}
.ready-now-card:hover { border-color: var(--color-primary); color: var(--color-primary); transform: translateY(-1px); box-shadow: var(--card-shadow); }
.ready-now-card__emoji { font-size: 1.1rem; }
.ready-now-card__title { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 120px; }
.ready-now-card__arrow { color: var(--color-text-muted); font-size: 0.85rem; }

/* ── Recent history ──────────────────────────────────────────────── */
.recent-history { padding: 0 var(--spacing-lg, 24px) var(--spacing-md, 16px); }
.recent-history__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--spacing-sm, 8px); }
.recent-history__title { font-size: var(--font-size-xs, 0.75rem); font-weight: 800; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.07em; }
.recent-history__clear { background: transparent; border: none; font-size: var(--font-size-xs, 0.75rem); font-weight: 700; color: var(--color-text-muted); cursor: pointer; padding: 0; }
.recent-chips { display: flex; gap: 6px; overflow-x: auto; scrollbar-width: none; }
.recent-chips::-webkit-scrollbar { display: none; }
.recent-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--border-radius-pill, 999px);
  padding: 5px 12px;
  white-space: nowrap;
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 600;
  color: var(--color-text-muted);
  flex-shrink: 0;
}
.recent-chip:hover { border-color: var(--color-primary); color: var(--color-primary); }
.recent-chip__emoji { font-size: 1rem; }

/* ── Timer ───────────────────────────────────────────────────────── */
.timer-widget { display: flex; flex-direction: column; align-items: center; gap: var(--spacing-md, 16px); }
.timer-presets { display: flex; flex-direction: column; gap: var(--spacing-sm, 8px); align-items: center; width: 100%; }
.timer-presets__label { font-size: var(--font-size-xs, 0.75rem); font-weight: 800; text-transform: uppercase; letter-spacing: 0.07em; color: var(--color-text-muted); }
.timer-presets__row { display: flex; gap: 6px; flex-wrap: wrap; justify-content: center; }
.timer-preset-btn { padding: 7px 14px; border-radius: var(--border-radius-pill, 999px); border: 1.5px solid var(--color-border); background: var(--color-surface-alt); font-weight: 700; font-size: var(--font-size-sm, 0.875rem); cursor: pointer; transition: all var(--transition-fast, 150ms ease); color: var(--color-text-muted); }
.timer-preset-btn--active { border-color: var(--color-primary); color: var(--color-primary); background: var(--color-primary-light); }
.timer-btn { padding: 10px 20px; border-radius: var(--border-radius-md, 12px); border: 1.5px solid var(--color-border); background: var(--color-surface-alt); font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-sm, 0.875rem); font-weight: 700; cursor: pointer; transition: all var(--transition-fast, 150ms ease); }
.timer-btn--start { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-text-on-primary); min-width: 120px; min-height: 48px; }
.timer-btn--ghost { color: var(--color-text-muted); }
.timer-btn--ghost:hover { border-color: var(--color-primary); color: var(--color-primary); }
.timer-btn--danger { color: var(--color-error); border-color: var(--color-error); }
.timer-controls { display: flex; gap: var(--spacing-sm, 8px); }
.timer-ring-wrap { position: relative; width: 140px; height: 140px; display: flex; align-items: center; justify-content: center; }
.timer-ring { width: 100%; height: 100%; }
.timer-ring__track { stroke: var(--color-border); }
.timer-ring__fill { stroke: var(--color-primary); transition: stroke-dashoffset 1s linear; }
.timer-ring__label { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.timer-ring__time { font-family: var(--font-family-heading, system-ui); font-size: 1.75rem; font-weight: 900; color: var(--color-text); }
.timer-ring__done { font-size: 2.5rem; animation: emojiPop 0.5s cubic-bezier(0.34,1.4,0.64,1); }

/* ── Guided steps ────────────────────────────────────────────────── */
.guided-toggle { background: var(--color-surface-alt); border: 1.5px solid var(--color-border); border-radius: var(--border-radius-pill, 999px); padding: 4px 12px; font-size: var(--font-size-xs, 0.75rem); font-weight: 700; cursor: pointer; color: var(--color-text-muted); transition: all var(--transition-fast, 150ms ease); white-space: nowrap; }
.guided-toggle--active { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-text-on-primary); }
.guided-steps { display: flex; flex-direction: column; gap: var(--spacing-md, 16px); }
.guided-steps__progress { display: flex; flex-direction: column; gap: 6px; }
.guided-steps__counter { font-size: var(--font-size-xs, 0.75rem); font-weight: 800; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.06em; }
.guided-steps__bar { height: 5px; background: var(--color-border); border-radius: var(--border-radius-pill, 999px); overflow: hidden; }
.guided-steps__fill { height: 100%; background: var(--color-primary); border-radius: var(--border-radius-pill, 999px); transition: width 400ms cubic-bezier(0.34,1.2,0.64,1); }
.guided-steps__step { background: var(--color-surface-alt); border-radius: var(--border-radius-md, 12px); padding: var(--spacing-md, 16px) var(--spacing-lg, 24px); display: flex; gap: var(--spacing-sm, 8px); align-items: flex-start; }
.guided-steps__text { flex: 1; font-size: var(--font-size-lg, 1.125rem); line-height: 1.5; font-weight: 600; }
.guided-steps__controls { display: flex; gap: var(--spacing-sm, 8px); }
.guided-steps__back { flex: 1; }
.guided-steps__next, .guided-steps__done { flex: 2; }

/* ── Quiz ────────────────────────────────────────────────────────── */
.quiz-block { display: flex; flex-direction: column; gap: var(--spacing-md, 16px); }
.quiz-progress { display: flex; flex-direction: column; gap: 6px; }
.quiz-progress__bar { display: flex; gap: 4px; }
.quiz-progress__dot { flex: 1; height: 4px; border-radius: var(--border-radius-pill, 999px); background: var(--color-border); transition: background 300ms ease; }
.quiz-progress__dot--done   { background: var(--color-primary); opacity: 0.5; }
.quiz-progress__dot--active { background: var(--color-primary); }
.quiz-progress__label { font-size: var(--font-size-xs, 0.75rem); font-weight: 800; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.06em; }
.quiz-question { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--spacing-sm, 8px); }
.quiz-question__emoji { font-size: 2.5rem; }
.quiz-question__text  { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-xl, 1.375rem); font-weight: 800; line-height: 1.3; }
.quiz-options { display: flex; flex-direction: column; gap: var(--spacing-sm, 8px); }
.quiz-option {
  text-align: left;
  padding: var(--spacing-md, 16px);
  background: var(--color-surface-alt);
  border: 1.5px solid var(--color-border);
  border-radius: var(--border-radius-md, 12px);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
  font-size: var(--font-size-md, 1rem);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm, 8px);
}
.quiz-option:hover:not(:disabled) { border-color: var(--color-primary); background: var(--color-primary-light); }
.quiz-option:disabled { cursor: default; }
.quiz-option--correct { background: rgba(34,197,94,0.1) !important; border-color: rgba(34,197,94,0.4) !important; color: #15803d; }
.quiz-option--wrong   { background: rgba(239,68,68,0.1) !important; border-color: rgba(239,68,68,0.4) !important; color: #b91c1c; }
.quiz-option--muted   { opacity: 0.5; }
.quiz-option__letter  { display: flex; align-items: center; justify-content: center; min-width: 24px; height: 24px; border-radius: 50%; background: var(--color-border); font-size: 0.75rem; font-weight: 900; flex-shrink: 0; }
.quiz-option__text    { flex: 1; }
.quiz-option__icon    { display: flex; flex-shrink: 0; margin-left: auto; }
.quiz-feedback {
  border-radius: var(--border-radius-md, 12px);
  padding: var(--spacing-md, 16px);
  display: flex;
  gap: var(--spacing-sm, 8px);
  align-items: flex-start;
}
.quiz-feedback--correct { background: rgba(34,197,94,0.08); border: 1.5px solid rgba(34,197,94,0.3); }
.quiz-feedback--wrong   { background: rgba(239,68,68,0.08); border: 1.5px solid rgba(239,68,68,0.3); }
.quiz-feedback__icon    { font-size: 1.25rem; flex-shrink: 0; }
.quiz-feedback__body    { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.quiz-feedback__verdict { font-weight: 800; color: var(--color-text); font-size: var(--font-size-sm, 0.875rem); }
.quiz-feedback__explanation { font-size: var(--font-size-sm, 0.875rem); color: var(--color-text-muted); line-height: 1.5; }
.quiz-next { width: auto; align-self: flex-end; min-height: 44px; padding: 10px 24px; }
.quiz-result { text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--spacing-sm, 8px); padding: var(--spacing-lg, 24px) 0; }
.quiz-result__hero    { color: var(--color-primary); animation: emojiPop 0.5s cubic-bezier(0.34,1.4,0.64,1); }
.quiz-result__title   { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-2xl, 1.75rem); font-weight: 900; color: var(--color-text); }
.quiz-result__score   { display: flex; align-items: baseline; gap: 6px; }
.quiz-result__score-num { font-size: var(--font-size-3xl, 2.25rem); font-weight: 900; color: var(--color-primary); font-family: var(--font-family-heading, system-ui); }
.quiz-result__score-of, .quiz-result__score-label { color: var(--color-text-muted); font-size: var(--font-size-md, 1rem); }
.quiz-result__score-total { font-size: var(--font-size-2xl, 1.75rem); font-weight: 900; color: var(--color-text); font-family: var(--font-family-heading, system-ui); }
.quiz-result__new-best {
  display: flex; align-items: center; gap: 5px;
  color: #a3711c; background: rgba(217,164,65,0.12); border: 1px solid rgba(217,164,65,0.35);
  border-radius: var(--border-radius-pill, 999px); padding: 3px 12px;
  font-size: var(--font-size-xs, 0.75rem); font-weight: 800;
}
html.dark .quiz-result__new-best { color: #eab308; background: rgba(234,179,8,0.14); border-color: rgba(234,179,8,0.3); }
.quiz-result__message { color: var(--color-text-muted); font-weight: 600; }
.quiz-result__summary { width: 100%; display: flex; flex-direction: column; gap: 6px; text-align: left; }
.quiz-result__row { display: flex; gap: var(--spacing-sm, 8px); padding: var(--spacing-sm, 8px) var(--spacing-md, 16px); border-radius: var(--border-radius-md, 12px); }
.quiz-result__row--correct { background: rgba(34,197,94,0.06); }
.quiz-result__row--wrong   { background: rgba(239,68,68,0.06); }
.quiz-result__row-icon { flex-shrink: 0; font-weight: 800; }
.quiz-result__row-body { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.quiz-result__row-q      { font-weight: 700; font-size: var(--font-size-sm, 0.875rem); color: var(--color-text); }
.quiz-result__row-yours  { font-size: var(--font-size-xs, 0.75rem); color: var(--color-error); }
.quiz-result__row-correct { font-size: var(--font-size-xs, 0.75rem); color: #15803d; font-weight: 700; }
.quiz-result__actions { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--spacing-sm, 8px); margin-top: var(--spacing-sm, 8px); width: 100%; }
.quiz-retry, .quiz-share { flex: 1 1 160px; max-width: 220px; display: inline-flex; align-items: center; justify-content: center; }

/* ── Panic detail ────────────────────────────────────────────────── */
.panic-detail-overlay { position: fixed; inset: 0; z-index: 200; background: rgba(0,0,0,0.5); backdrop-filter: blur(8px); display: flex; align-items: flex-end; justify-content: center; }
.panic-detail-panel { background: var(--color-surface); border-radius: var(--border-radius-xl, 28px) var(--border-radius-xl, 28px) 0 0; width: 100%; max-width: var(--app-max-width, 480px); max-height: 90dvh; overflow-y: auto; animation: slideUp 0.38s cubic-bezier(0.32,0.72,0,1); padding-bottom: max(var(--spacing-2xl, 48px), env(safe-area-inset-bottom)); }
.panic-detail__hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 140px;
  padding: max(var(--spacing-2xl, 48px), calc(env(safe-area-inset-top) + var(--spacing-lg, 24px))) var(--spacing-md, 16px) var(--spacing-md, 16px);
  position: relative;
  background: var(--color-surface-alt);
}
.panic-detail__hero--primary { background: var(--color-primary); }
.panic-detail__emoji { font-size: 4rem; }
.panic-detail__badge { font-size: var(--font-size-xs, 0.75rem); font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-muted); margin-top: 6px; }
.panic-detail__hero--primary .panic-detail__badge { color: rgba(255,255,255,0.7); }
.panic-detail__content { padding: var(--spacing-md, 16px) var(--spacing-lg, 24px); display: flex; flex-direction: column; gap: var(--spacing-md, 16px); }
.panic-detail__title { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-2xl, 1.75rem); font-weight: 900; letter-spacing: -0.025em; color: var(--color-text); }
.panic-detail__description { color: var(--color-text-muted); line-height: 1.6; }
.panic-steps { display: flex; flex-direction: column; gap: 8px; }
.panic-step { display: flex; gap: var(--spacing-sm, 8px); align-items: flex-start; }
.panic-step__num { min-width: 22px; height: 22px; border-radius: 50%; background: var(--color-primary); color: var(--color-text-on-primary); font-size: 0.7rem; font-weight: 900; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.panic-step__text { font-size: var(--font-size-md, 1rem); line-height: 1.5; color: var(--color-text); }
.panic-detail__actions { display: flex; gap: var(--spacing-sm, 8px); }
.panic-close-btn { position: absolute; top: var(--spacing-md, 16px); right: var(--spacing-md, 16px); }
.panic-try-another { background: transparent; border: 1.5px solid var(--color-border); border-radius: var(--border-radius-md, 12px); padding: 10px 16px; font-weight: 700; font-size: var(--font-size-sm, 0.875rem); cursor: pointer; color: var(--color-text-muted); transition: all var(--transition-fast, 150ms ease); }
.panic-try-another:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* ── Content blocks ──────────────────────────────────────────────── */
.content-blocks { display: flex; flex-direction: column; gap: var(--spacing-md, 16px); }
.content-block { display: block; }
.content-block__caption { font-size: var(--font-size-xs, 0.75rem); color: var(--color-text-muted); margin-top: 6px; font-style: italic; text-align: center; padding: 0 var(--spacing-sm, 8px); }
.content-block--youtube { display: flex; flex-direction: column; gap: var(--spacing-xs, 4px); }
.youtube-embed { position: relative; padding-bottom: 56.25%; height: 0; border-radius: var(--border-radius-md, 12px); overflow: hidden; background: #000; }
.youtube-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }
.youtube-consent { cursor: pointer; border-radius: var(--border-radius-md, 12px); overflow: hidden; border: 1.5px solid var(--color-border); }
.youtube-consent__thumb { position: relative; padding-bottom: 56.25%; background-size: cover; background-position: center; background-color: var(--color-surface-alt); }
.youtube-consent__play { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.42); border: none; cursor: pointer; font-size: 2.5rem; color: #fff; transition: background var(--transition-fast, 150ms ease); }
.youtube-consent__play:hover { background: rgba(0,0,0,0.58); }
.youtube-consent__notice { padding: var(--spacing-sm, 8px) var(--spacing-md, 16px); font-size: var(--font-size-xs, 0.75rem); color: var(--color-text-muted); background: var(--color-surface-alt); text-align: center; }
.content-block--image { display: flex; flex-direction: column; gap: var(--spacing-xs, 4px); }
.content-block__img { width: 100%; border-radius: var(--border-radius-md, 12px); object-fit: cover; max-height: 280px; border: 1px solid var(--color-border); }
.content-block--link { display: flex; align-items: center; gap: var(--spacing-sm, 8px); background: var(--color-surface-alt); border: 1.5px solid var(--color-border); border-radius: var(--border-radius-md, 12px); padding: var(--spacing-md, 16px); text-decoration: none; color: var(--color-text); transition: all var(--transition-fast, 150ms ease); font-weight: 600; font-size: var(--font-size-sm, 0.875rem); }
.content-block--link:hover { border-color: var(--color-primary); color: var(--color-primary); }
.content-block-link__icon { display: flex; flex-shrink: 0; }
.content-block-link__label { flex: 1; }
.content-block-link__arrow { color: var(--color-primary); font-weight: 800; flex-shrink: 0; }
.content-block--audio { display: flex; flex-direction: column; gap: 6px; }
.content-block__audio { width: 100%; border-radius: var(--border-radius-sm, 8px); accent-color: var(--color-primary); }
.content-block--pdf { border-color: var(--color-primary-light); }

/* Webembed (sandboxed iframe with consent gate) */
.content-block--webembed { display: flex; flex-direction: column; gap: var(--spacing-xs, 4px); }
.webembed-frame { position: relative; padding-bottom: 56.25%; height: 0; border-radius: var(--border-radius-md, 12px); overflow: hidden; background: var(--color-surface-alt); border: 1.5px solid var(--color-border); }
.webembed-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }
.webembed-consent { cursor: pointer; border-radius: var(--border-radius-md, 12px); border: 1.5px dashed var(--color-border); overflow: hidden; transition: border-color var(--transition-fast, 150ms ease); }
.webembed-consent:hover { border-color: var(--color-primary); }
.webembed-consent__inner { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: var(--spacing-lg, 24px) var(--spacing-md, 16px); background: var(--color-surface-alt); text-align: center; }
.webembed-consent__icon { display: flex; align-items: center; justify-content: center; }
.webembed-consent__title { font-weight: 700; font-size: var(--font-size-sm, 0.875rem); color: var(--color-text); }
.webembed-consent__notice { font-size: var(--font-size-xs, 0.75rem); color: var(--color-text-muted); }
.webembed-consent__btn { display: inline-block; padding: 6px 18px; border-radius: var(--border-radius-pill, 999px); background: var(--color-primary); color: var(--color-text-on-primary); font-size: var(--font-size-xs, 0.75rem); font-weight: 700; margin-top: 4px; }

/* ── Audio player ────────────────────────────────────────────────── */
.audio-player { display: flex; align-items: center; gap: var(--spacing-sm, 8px); background: var(--color-surface-alt); border: 1.5px solid var(--color-border); border-radius: var(--border-radius-lg, 18px); padding: var(--spacing-sm, 8px) var(--spacing-md, 16px); }
.audio-player__btn { width: 40px; height: 40px; border-radius: 50%; border: none; background: var(--color-primary); color: var(--color-text-on-primary); font-size: 1rem; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: transform 150ms ease; flex-shrink: 0; }
.audio-player__btn:active { transform: scale(0.92); }
.audio-player__label { flex: 1; font-weight: 700; font-size: var(--font-size-sm, 0.875rem); color: var(--color-text-muted); }
.audio-player__credit { font-size: 0.7rem; color: var(--color-text-muted); opacity: 0.6; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 140px; }

/* ── Action bar ──────────────────────────────────────────────────── */
.action-bar { display: flex; flex-direction: column; gap: var(--spacing-sm, 8px); }
.action-bar__label { font-size: var(--font-size-xs, 0.75rem); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text-muted); }
.action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm, 8px);
  border: 1.5px solid var(--color-border);
  border-radius: var(--border-radius-md, 12px);
  padding: var(--spacing-sm, 8px) var(--spacing-lg, 24px);
  font-family: var(--font-family-heading, system-ui);
  font-size: var(--font-size-md, 1rem);
  font-weight: 700;
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
  min-height: 48px;
  width: 100%;
  text-decoration: none;
  background: var(--color-surface-alt);
  color: var(--color-text);
}
.action-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* ── Speech button ───────────────────────────────────────────────── */
.speech-btn { background: transparent; border: 1.5px solid var(--color-border); border-radius: 50%; width: 34px; height: 34px; cursor: pointer; font-size: 0.9rem; display: flex; align-items: center; justify-content: center; transition: all var(--transition-fast, 150ms ease); color: var(--color-text-muted); flex-shrink: 0; }
.speech-btn--active { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-text-on-primary); }

/* ── Language dropdown ───────────────────────────────────────────── */
.lang-dropdown { position: relative; }
.lang-dropdown__trigger { display: inline-flex; align-items: center; gap: 4px; background: transparent; border: 1.5px solid var(--color-border); border-radius: var(--border-radius-pill, 999px); padding: 4px 10px; font-size: 1rem; cursor: pointer; transition: all var(--transition-fast, 150ms ease); min-height: 36px; color: var(--color-text-muted); }
.lang-dropdown__trigger:hover { border-color: var(--color-primary); }
.lang-dropdown__flag { font-size: 1.1rem; }
.lang-dropdown__chevron { font-size: 0.55rem; color: var(--color-text-muted); }
.lang-dropdown__list { position: absolute; top: calc(100% + 6px); right: 0; background: var(--color-surface); border: 1.5px solid var(--color-border); border-radius: var(--border-radius-lg, 18px); min-width: 160px; z-index: 50; list-style: none; overflow: hidden; box-shadow: var(--card-shadow-hover); animation: fadeIn 0.15s ease; padding: 4px; }
.lang-dropdown__option { display: flex; align-items: center; gap: var(--spacing-sm, 8px); width: 100%; padding: 10px var(--spacing-md, 16px); background: transparent; border: none; border-radius: var(--border-radius-md, 12px); cursor: pointer; font-size: var(--font-size-sm, 0.875rem); font-weight: 600; color: var(--color-text-muted); transition: all var(--transition-fast, 150ms ease); text-align: left; }
.lang-dropdown__option:hover { background: var(--color-surface-alt); color: var(--color-text); }
.lang-dropdown__option--active { color: var(--color-primary); }
.lang-dropdown__option-flag { font-size: 1.1rem; flex-shrink: 0; }
.lang-dropdown__option-label { flex: 1; }
.lang-dropdown__check { margin-left: auto; color: var(--color-primary); font-weight: 800; }

/* ── Badge system ────────────────────────────────────────────────── */
.badge-toast {
  position: fixed;
  bottom: 80px;
  left: 50%;
  transform: translateX(-50%) translateY(12px);
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--color-surface);
  border: 1.5px solid var(--color-primary);
  border-radius: var(--border-radius-lg, 18px);
  padding: 12px 20px;
  box-shadow: var(--card-shadow-hover);
  z-index: 1200;
  opacity: 0;
  pointer-events: none;
  max-width: 320px;
  width: calc(100vw - 48px);
  transition: opacity 0.25s ease, transform 0.25s ease;
}
.badge-toast--in  { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: auto; }
.badge-toast--out { opacity: 0; transform: translateX(-50%) translateY(12px); }
.badge-toast__emoji { font-size: 2rem; line-height: 1; flex-shrink: 0; }
.badge-toast__text  { display: flex; flex-direction: column; gap: 2px; }
.badge-toast__label { font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-primary); }
.badge-toast__name  { font-size: 0.95rem; font-weight: 700; color: var(--color-text); }
.badges-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 16px; padding: 20px; }
.badge-item { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: var(--spacing-md, 16px) 12px; border-radius: var(--border-radius-lg, 18px); text-align: center; border: 1.5px solid var(--color-border); background: var(--color-surface); transition: transform 0.15s ease; }
.badge-item--earned { border-color: var(--color-primary); background: var(--color-primary-light); }
.badge-item--locked { opacity: 0.5; filter: grayscale(0.6); }
.badge-item__emoji { font-size: 2.2rem; line-height: 1; }
.badge-item__name  { font-size: var(--font-size-sm, 0.875rem); font-weight: 700; color: var(--color-text); }
.badge-item__desc  { font-size: 0.72rem; color: var(--color-text-muted); }
.streak-counter { display: inline-flex; align-items: center; gap: 4px; font-size: 0.9rem; font-weight: 700; color: var(--color-accent); background: rgba(244,132,95,0.12); padding: 4px 10px; border-radius: var(--border-radius-pill, 999px); }
.streak-counter__icon { flex-shrink: 0; color: var(--color-accent); }
.activity-updated-banner { display: flex; align-items: center; gap: 8px; background: var(--color-primary-light); border-left: 3px solid var(--color-primary); border-radius: 0 var(--border-radius-sm, 8px) var(--border-radius-sm, 8px) 0; padding: 8px 12px; font-size: var(--font-size-sm, 0.875rem); font-weight: 600; color: var(--color-primary); }

/* ── Onboarding ──────────────────────────────────────────────────── */
.onboarding-overlay {
  position: fixed;
  inset: 0;
  background: var(--color-background);
  z-index: 300;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(var(--spacing-lg, 24px), env(safe-area-inset-top)) var(--spacing-lg, 24px) max(var(--spacing-lg, 24px), env(safe-area-inset-bottom));
  animation: fadeIn 0.25s ease;
}
.onboarding-panel { width: 100%; max-width: 480px; display: flex; flex-direction: column; gap: var(--spacing-xl, 32px); }
.onboarding-panel--completing { opacity: 0; transform: scale(0.95); transition: all 0.3s ease; }
.onboarding-progress { display: flex; gap: 10px; justify-content: center; align-items: center; }
.onboarding-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--color-border); border: none; cursor: pointer; transition: all var(--transition-base, 250ms ease); padding: 0; }
.onboarding-dot--active { background: var(--color-primary); transform: scale(1.4); box-shadow: 0 0 0 3px var(--color-primary-light); }
.onboarding-dot--done { background: var(--color-primary); opacity: 0.45; }
.onboarding-slides { min-height: 320px; display: flex; align-items: flex-start; }
.onboarding-slide { width: 100%; display: flex; flex-direction: column; align-items: center; gap: var(--spacing-md, 16px); text-align: center; animation: slideEntrance 0.3s cubic-bezier(0.34,1.2,0.64,1); }
@keyframes slideEntrance { from{opacity:0;transform:translateX(24px)} to{opacity:1;transform:translateX(0)} }
.onboarding-emoji-wrap { width: 96px; height: 96px; background: var(--color-surface-alt); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.onboarding-emoji { font-size: 3.2rem; line-height: 1; }
.onboarding-title { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-2xl, 1.75rem); font-weight: 900; line-height: 1.2; color: var(--color-text); }
.onboarding-body  { font-size: var(--font-size-lg, 1.125rem); color: var(--color-text-muted); line-height: 1.6; max-width: 36ch; }
.onboarding-options { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: var(--spacing-sm, 8px); width: 100%; }
.onboarding-option { position: relative; padding: var(--spacing-sm, 8px) var(--spacing-md, 16px); border: 2px solid var(--color-border); border-radius: var(--border-radius-md, 12px); background: var(--color-surface); font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-md, 1rem); font-weight: 700; cursor: pointer; transition: all var(--transition-base, 250ms ease); min-height: 52px; display: flex; align-items: center; justify-content: center; gap: 6px; color: var(--color-text); }
.onboarding-option:hover { border-color: var(--color-primary); background: var(--color-primary-light); }
.onboarding-option--selected { border-color: var(--color-primary); background: var(--color-primary-light); color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-light); }
.onboarding-toggles { display: flex; flex-wrap: wrap; gap: var(--spacing-sm, 8px); justify-content: center; width: 100%; }
.onboarding-toggle { padding: var(--spacing-sm, 8px) var(--spacing-lg, 24px); border: 2px solid var(--color-border); border-radius: var(--border-radius-lg, 18px); background: var(--color-surface); font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-sm, 0.875rem); font-weight: 700; cursor: pointer; transition: all var(--transition-fast, 150ms ease); min-height: 48px; color: var(--color-text-muted); }
.onboarding-toggle--selected { border-color: var(--color-primary); background: var(--color-primary-light); color: var(--color-primary); }
.onboarding-actions { display: flex; flex-direction: column; align-items: stretch; gap: var(--spacing-sm, 8px); }
.onboarding-skip { background: transparent; border: none; cursor: pointer; color: var(--color-text-muted); font-size: var(--font-size-sm, 0.875rem); font-weight: 600; padding: var(--spacing-md, 16px); min-height: 48px; border-radius: var(--border-radius-md, 12px); align-self: center; }
.onboarding-skip:hover { color: var(--color-text); }

/* ── Tutorial ────────────────────────────────────────────────────── */
.tutorial-overlay { position: fixed; inset: 0; z-index: 300; display: flex; flex-direction: column; align-items: center; justify-content: flex-end; }
.tutorial-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.55); backdrop-filter: blur(4px); }
.tutorial-panel { position: relative; z-index: 1; background: var(--color-surface); border-radius: var(--border-radius-xl, 28px) var(--border-radius-xl, 28px) 0 0; width: 100%; max-width: 600px; padding: var(--spacing-lg, 24px) var(--spacing-lg, 24px) max(var(--spacing-2xl, 48px), calc(env(safe-area-inset-bottom)+24px)); display: flex; flex-direction: column; gap: var(--spacing-md, 16px); animation: slideUp 0.4s cubic-bezier(0.32,0.72,0,1); }
.tutorial-panel__handle { width: 36px; height: 4px; background: var(--color-border); border-radius: 2px; margin: 0 auto; }
.tutorial-dots { display: flex; gap: 6px; justify-content: center; }
.tutorial-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-border); border: none; cursor: pointer; transition: all 200ms ease; padding: 0; }
.tutorial-dot--active { width: 24px; border-radius: 4px; background: var(--color-primary); }
.tutorial-slides { min-height: 220px; position: relative; overflow: hidden; }
.tutorial-slide { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--spacing-sm, 8px); }
.tutorial-slide--active { opacity: 1; }
.tutorial-slide--future, .tutorial-slide--past { opacity: 0; position: absolute; top: 0; width: 100%; pointer-events: none; }
.tutorial-emoji { font-size: 3.5rem; }
.tutorial-title { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-2xl, 1.75rem); font-weight: 900; letter-spacing: -0.025em; color: var(--color-text); }
.tutorial-body { font-size: var(--font-size-md, 1rem); color: var(--color-text-muted); line-height: 1.6; }
.tutorial-actions { display: flex; flex-direction: column; gap: var(--spacing-sm, 8px); }
.tutorial-skip { background: none; border: none; font-size: var(--font-size-sm, 0.875rem); color: var(--color-text-muted); cursor: pointer; font-weight: 600; padding: var(--spacing-sm, 8px); }

/* ── Slideshow ───────────────────────────────────────────────────── */
.slideshow-overlay { position: fixed; inset: 0; z-index: 500; display: flex; align-items: center; justify-content: center; }
.slideshow-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.88); backdrop-filter: blur(10px); }
.slideshow-panel { position: relative; z-index: 1; width: min(580px,94vw); background: var(--color-surface); border-radius: var(--border-radius-xl, 28px); padding: var(--spacing-2xl, 48px) var(--spacing-xl, 32px); display: flex; flex-direction: column; gap: var(--spacing-lg, 24px); align-items: center; animation: slideUp 0.4s cubic-bezier(0.32,0.72,0,1); }
.slideshow-close { position: absolute; top: var(--spacing-md, 16px); right: var(--spacing-md, 16px); }
.slideshow-card { text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--spacing-md, 16px); animation: emojiPop 0.4s cubic-bezier(0.34,1.4,0.64,1); }
.slideshow-card__emoji { font-size: 5rem; }
.slideshow-card__title { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-3xl, 2.25rem); font-weight: 900; letter-spacing: -0.03em; line-height: 1.1; color: var(--color-text); }
.slideshow-card__description { font-size: var(--font-size-md, 1rem); color: var(--color-text-muted); line-height: 1.6; max-width: 420px; }
.slideshow-controls { display: flex; align-items: center; gap: var(--spacing-md, 16px); width: 100%; }
.slideshow-btn { width: 44px; height: 44px; border-radius: 50%; background: var(--color-surface-alt); border: 1.5px solid var(--color-border); display: flex; align-items: center; justify-content: center; cursor: pointer; flex-shrink: 0; transition: all var(--transition-fast, 150ms ease); }
.slideshow-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }
.slideshow-timer-bar { flex: 1; height: 4px; background: var(--color-border); border-radius: var(--border-radius-pill, 999px); overflow: hidden; }
.slideshow-timer-fill { height: 100%; background: var(--color-primary); border-radius: var(--border-radius-pill, 999px); animation: slideshowProgress linear forwards; }
@keyframes slideshowProgress { from{width:0%} to{width:100%} }

/* ── Logbook ─────────────────────────────────────────────────────── */
.logbook { padding: 0 var(--spacing-lg, 24px) 80px; flex: 1; }
.logbook__header { padding: var(--spacing-lg, 24px) 0 var(--spacing-md, 16px); border-bottom: 1px solid var(--color-border); margin-bottom: var(--spacing-md, 16px); }
.logbook__header-top { display: flex; align-items: center; justify-content: space-between; }
.logbook__title { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-xl, 1.375rem); font-weight: 900; color: var(--color-text); margin-bottom: 4px; }
.logbook__subtitle { font-size: var(--font-size-sm, 0.875rem); color: var(--color-text-muted); margin-bottom: var(--spacing-sm, 8px); }
.logbook__count { display: inline-block; background: var(--color-primary); color: var(--color-text-on-primary); font-size: var(--font-size-xs, 0.75rem); font-weight: 700; padding: 2px 10px; border-radius: var(--border-radius-pill, 999px); }
.logbook__empty { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 60px var(--spacing-lg, 24px); text-align: center; color: var(--color-text-muted); }
.logbook__empty-icon { font-size: 3rem; }
.logbook__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }

.lb-card { border: 1.5px solid var(--color-border); border-radius: var(--border-radius-lg, 18px); background: var(--color-surface); box-shadow: var(--card-shadow); overflow: hidden; cursor: pointer; text-align: left; padding: 0; transition: transform 0.15s ease, box-shadow 0.15s ease; display: flex; flex-direction: column; }
.lb-card:hover { transform: translateY(-2px); box-shadow: var(--card-shadow-hover); border-color: var(--color-primary); }
.lb-card:active { transform: scale(0.97); }
.lb-card__photo { width: 100%; aspect-ratio: 4/3; overflow: hidden; }
.lb-card__img { width: 100%; height: 100%; object-fit: cover; display: block; }
.lb-card__emoji-bg { width: 100%; aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; background: var(--color-surface-alt); font-size: 2.5rem; }
.lb-card__body { padding: 8px 10px; display: flex; flex-direction: column; gap: 2px; flex: 1; }
.lb-card__title { font-size: 0.8rem; font-weight: 700; color: var(--color-text); line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.lb-card__date { font-size: 0.7rem; color: var(--color-text-muted); }
.lb-card__note-icon { display: flex; margin-top: 2px; }

.lb-detail-overlay { position: fixed; inset: 0; z-index: 300; background: rgba(0,0,0,0.45); display: flex; align-items: flex-end; justify-content: center; }
.lb-detail-sheet { background: var(--color-surface); border-radius: var(--border-radius-xl, 28px) var(--border-radius-xl, 28px) 0 0; width: 100%; max-width: 600px; max-height: 90dvh; overflow-y: auto; position: relative; padding-bottom: max(var(--spacing-md, 16px), env(safe-area-inset-bottom)); animation: slideUp 0.35s cubic-bezier(0.32,0.72,0,1); }
.lb-detail-sheet__close { position: absolute; top: 14px; right: 14px; background: var(--color-surface-alt); border: 1.5px solid var(--color-border); border-radius: 50%; width: 34px; height: 34px; cursor: pointer; z-index: 10; color: var(--color-text-muted); display: flex; align-items: center; justify-content: center; }
.lb-detail-sheet__photo { width: 100%; max-height: 280px; object-fit: cover; display: block; border-radius: var(--border-radius-xl, 28px) var(--border-radius-xl, 28px) 0 0; }
.lb-detail-sheet__emoji-hero { width: 100%; height: 160px; display: flex; align-items: center; justify-content: center; font-size: 4rem; border-radius: var(--border-radius-xl, 28px) var(--border-radius-xl, 28px) 0 0; background: var(--color-surface-alt); }
.lb-detail-sheet__body { padding: var(--spacing-lg, 24px); display: flex; flex-direction: column; gap: var(--spacing-md, 16px); }
.lb-detail-sheet__title { font-size: var(--font-size-xl, 1.375rem); font-weight: 900; color: var(--color-text); letter-spacing: -0.02em; }
.lb-detail-sheet__date { font-size: var(--font-size-sm, 0.875rem); color: var(--color-text-muted); margin-top: -8px; }
.lb-detail-sheet__actions { display: flex; gap: 10px; flex-wrap: wrap; }
.lb-detail-sheet__note-section { display: flex; flex-direction: column; gap: 8px; }
.lb-detail-sheet__note-label { font-size: var(--font-size-sm, 0.875rem); font-weight: 700; color: var(--color-text-muted); }
.lb-detail-sheet__note-input { border: 1.5px solid var(--color-border); border-radius: var(--border-radius-md, 12px); padding: 10px 12px; font-size: var(--font-size-md, 1rem); font-family: var(--font-family-body, system-ui); background: var(--color-surface-alt); color: var(--color-text); resize: none; width: 100%; transition: border-color var(--transition-fast, 150ms ease); }
.lb-detail-sheet__note-input:focus { outline: none; border-color: var(--color-primary); background: var(--color-surface); }
.lb-btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 16px; border-radius: var(--border-radius-md, 12px); font-size: var(--font-size-sm, 0.875rem); font-weight: 700; font-family: var(--font-family-body, system-ui); border: none; cursor: pointer; transition: opacity 0.15s ease; min-height: 44px; }
.lb-btn:disabled { opacity: 0.45; cursor: default; }
.lb-btn--primary   { background: var(--color-primary); color: var(--color-text-on-primary); }
.lb-btn--secondary { background: var(--color-surface-alt); color: var(--color-text); border: 1.5px solid var(--color-border); }
.lb-btn--danger    { background: transparent; color: var(--color-error); border: 1.5px solid var(--color-error); width: 100%; }
.lb-photo-input-hidden { position: absolute; width: 1px; height: 1px; opacity: 0; overflow: hidden; clip: rect(0,0,0,0); }

/* ── Login ───────────────────────────────────────────────────────── */
.login-page { min-height: 100dvh; display: flex; align-items: center; justify-content: center; padding: var(--spacing-lg, 24px); background: var(--color-background); }
.login-card { width: 100%; max-width: 380px; background: var(--color-surface); border: 1.5px solid var(--color-border); border-radius: var(--border-radius-xl, 28px); box-shadow: var(--card-shadow-hover); padding: 40px 32px 36px; display: flex; flex-direction: column; gap: 28px; }
.login-card__identity { display: flex; flex-direction: column; align-items: center; gap: 8px; text-align: center; }
.login-card__emoji { font-size: 3rem; line-height: 1; }
.login-card__app-name { font-size: 1.5rem; font-weight: 900; color: var(--color-text); margin: 0; font-family: var(--font-family-heading, system-ui); letter-spacing: -0.02em; }
.login-card__tagline { font-size: var(--font-size-sm, 0.875rem); color: var(--color-text-muted); margin: 0; }
.login-card__form { display: flex; flex-direction: column; gap: 10px; }
.login-card__label { font-size: var(--font-size-sm, 0.875rem); font-weight: 600; color: var(--color-text-muted); }
.login-card__input-row { display: flex; gap: 8px; }
.login-card__input { flex: 1; padding: 12px 14px; border: 1.5px solid var(--color-border); border-radius: var(--border-radius-md, 12px); font-size: var(--font-size-md, 1rem); font-family: var(--font-family-body, system-ui); background: var(--color-surface-alt); color: var(--color-text); outline: none; transition: border-color var(--transition-fast, 150ms ease); }
.login-card__input:focus { border-color: var(--color-primary); background: var(--color-surface); }
.login-card__input--error { border-color: var(--color-error); }
.login-card__input:disabled { opacity: 0.5; cursor: not-allowed; }
.login-card__show-btn { padding: 0 12px; border: 1.5px solid var(--color-border); border-radius: var(--border-radius-md, 12px); background: var(--color-surface-alt); font-size: 1rem; cursor: pointer; flex-shrink: 0; min-height: 48px; }
.login-card__error { font-size: var(--font-size-sm, 0.875rem); color: var(--color-error); margin: 0; padding: 8px 12px; background: rgba(239,68,68,0.08); border-radius: var(--border-radius-sm, 8px); }
.login-card__hint { font-size: 0.82rem; color: var(--color-text-muted); margin: 0; text-align: center; }
.login-card__submit { margin-top: 6px; padding: 14px; background: var(--color-primary); color: var(--color-text-on-primary); border: none; border-radius: var(--border-radius-md, 12px); font-size: var(--font-size-md, 1rem); font-weight: 800; font-family: var(--font-family-heading, system-ui); cursor: pointer; transition: opacity 0.15s ease, transform 0.1s ease; min-height: 52px; }
.login-card__submit:hover:not(:disabled) { opacity: 0.9; }
.login-card__submit:active:not(:disabled) { transform: scale(0.98); }
.login-card__submit:disabled { opacity: 0.45; cursor: not-allowed; }

/* ── Print ───────────────────────────────────────────────────────── */
.print-footer { display: none; }
@media print, html.is-printing {
  .app-header, .filter-trigger-bar, .activity-grid-section,
  .panic-section, .ready-now-section, .filter-drawer,
  .detail-share-row, .detail-close-btn, .badge-toast,
  .onboarding-overlay { display: none !important; }
  .detail-panel { position: static !important; box-shadow: none !important; border-radius: 0 !important; max-height: none; padding-bottom: 0; }
  .print-footer { display: block !important; font-size: 9pt; color: #999; margin-top: 24pt; border-top: 1px solid #eee; padding-top: 6pt; }
  img { max-width: 100%; print-color-adjust: exact; -webkit-print-color-adjust: exact; }
}

/* ── Misc ────────────────────────────────────────────────────────── */
.fav-view-header { display: flex; align-items: center; gap: var(--spacing-md, 16px); padding: var(--spacing-md, 16px) var(--spacing-lg, 24px); }
.fav-view-title  { font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-2xl, 1.75rem); font-weight: 900; letter-spacing: -0.025em; color: var(--color-text); }
.back-btn { background: transparent; border: none; font-size: var(--font-size-md, 1rem); font-weight: 700; color: var(--color-primary); cursor: pointer; padding: 0; }
.results-bar { display: flex; align-items: center; padding: 0 var(--spacing-lg, 24px) var(--spacing-sm, 8px); }
.results-bar__count { font-size: var(--font-size-xs, 0.75rem); color: var(--color-text-muted); font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; }
.loading-shimmer { display: flex; flex-direction: column; gap: var(--spacing-sm, 8px); padding: var(--spacing-md, 16px) var(--spacing-lg, 24px); }
.skeleton { background: linear-gradient(90deg, var(--color-surface-alt) 25%, var(--color-surface) 50%, var(--color-surface-alt) 75%); background-size: 800px 100%; animation: shimmer 1.4s ease infinite; border-radius: var(--border-radius-md, 12px); }
.skeleton--text { height: 16px; border-radius: 4px; }
.skeleton--chip { height: 28px; width: 72px; border-radius: var(--border-radius-pill, 999px); }
@keyframes shimmer { 0%{background-position:-800px 0} 100%{background-position:800px 0} }
.help-btn { font-weight: 900; font-family: var(--font-family-heading, system-ui); font-size: var(--font-size-sm, 0.875rem); }
.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; }

/* ── Dark mode overrides ─────────────────────────────────────────── */
html.dark .meta-chip--green { background: rgba(52,211,153,0.12); border-color: rgba(52,211,153,0.25); color: #34d399; }
html.dark .meta-chip--gold  { background: rgba(234,179,8,0.14);  border-color: rgba(234,179,8,0.3);   color: #eab308; }
html.dark .category-chip--movement { background: rgba(96,165,250,0.12); border-color: rgba(96,165,250,0.25); color: #60a5fa; }
html.dark .category-chip--creative { background: rgba(244,114,182,0.12); border-color: rgba(244,114,182,0.25); color: #f472b6; }
html.dark .category-chip--calm     { background: rgba(167,139,250,0.12); border-color: rgba(167,139,250,0.25); color: #a78bfa; }
html.dark .category-chip--social   { background: rgba(252,211,77,0.12);  border-color: rgba(252,211,77,0.25);  color: #fcd34d; }
html.dark .safety-note { background: rgba(245,158,11,0.08); border-color: rgba(245,158,11,0.2); }
html.dark .safety-note__text { color: #fbbf24; }
html.dark .level-badge--1 { color: #34d399; border-color: rgba(52,211,153,0.3); background: rgba(52,211,153,0.1); }
html.dark .level-badge--2 { color: #fbbf24; border-color: rgba(251,191,36,0.3); background: rgba(251,191,36,0.1); }
html.dark .level-badge--3 { color: #f472b6; border-color: rgba(244,114,182,0.3); background: rgba(244,114,182,0.1); }

/* ── Animations ──────────────────────────────────────────────────── */
@keyframes fadeIn   { from{opacity:0} to{opacity:1} }
@keyframes slideUp  { from{transform:translateY(100%)} to{transform:translateY(0)} }
@keyframes emojiPop { 0%{transform:scale(0.5);opacity:0} 70%{transform:scale(1.12)} 100%{transform:scale(1);opacity:1} }

/* ── Reduced motion ──────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ── Pack landing (PackSwitcher) ────────────────────────────────── */
.pack-landing {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: max(var(--spacing-2xl, 48px), env(safe-area-inset-top))
           var(--spacing-lg, 24px)
           max(80px, calc(env(safe-area-inset-bottom) + 56px));
  background: var(--color-background);
  gap: var(--spacing-xl, 32px);
  overflow: hidden;
}

/* Subtle radial spotlight behind the header */
.pack-landing::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: min(600px, 140vw);
  height: 380px;
  background: radial-gradient(ellipse at 50% 30%,
    var(--color-primary-light, rgba(91,141,239,0.12)) 0%,
    transparent 72%);
  pointer-events: none;
  z-index: 0;
}

.pack-landing__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center;
  position: relative;
  z-index: 1;
}

/* Mark: intentionally small (24px) — identity element, not hero */
.pack-landing__mark {
  width: 24px;
  height: 24px;
  opacity: 0.9;
}

.pack-landing__wordmark {
  font-family: var(--font-family-heading, system-ui);
  font-size: clamp(2rem, 8vw, 2.75rem);
  font-weight: 900;
  color: var(--color-text);
  letter-spacing: -0.04em;
  margin: 0;
  line-height: 1;
}

.pack-landing__wordmark span {
  color: var(--color-primary);
}

.pack-landing__tagline {
  font-size: var(--font-size-sm, 0.875rem);
  color: var(--color-text-muted);
  font-weight: 500;
  margin: 0;
  letter-spacing: 0.01em;
}

.pack-landing__grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  max-width: 440px;
  position: relative;
  z-index: 1;
}

/* Staggered card entrance animation */
.pack-landing__grid .pack-card:nth-child(1) { animation: cardReveal 0.35s cubic-bezier(0.22,1,0.36,1) both; }
.pack-landing__grid .pack-card:nth-child(2) { animation: cardReveal 0.35s cubic-bezier(0.22,1,0.36,1) 60ms both; }
.pack-landing__grid .pack-card:nth-child(3) { animation: cardReveal 0.35s cubic-bezier(0.22,1,0.36,1) 120ms both; }
.pack-landing__grid .pack-card:nth-child(4) { animation: cardReveal 0.35s cubic-bezier(0.22,1,0.36,1) 180ms both; }
.pack-landing__grid .pack-card:nth-child(n+5) { animation: cardReveal 0.35s cubic-bezier(0.22,1,0.36,1) 220ms both; }

@keyframes cardReveal {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Enhanced pack card for the landing page */
.pack-landing .pack-card {
  padding: var(--spacing-md, 16px) var(--spacing-lg, 24px);
  border-left: 3px solid var(--pack-accent, var(--color-primary));
  border-radius: var(--border-radius-lg, 18px);
  gap: var(--spacing-md, 16px);
}

.pack-landing .pack-card:hover {
  border-left-color: var(--pack-accent, var(--color-primary));
  transform: translateX(3px) translateY(-1px);
}

.pack-landing .pack-card__emoji {
  font-size: 2rem;
}

.pack-landing__footer {
  font-size: var(--font-size-xs, 0.75rem);
  color: var(--color-text-muted);
  font-weight: 500;
  text-align: center;
  margin: 0;
  opacity: 0.55;
  position: relative;
  z-index: 1;
}

/* ── Maker credit — always small and subtle ──────────────────────── */
.maker-credit {
  position: absolute;
  bottom: max(12px, env(safe-area-inset-bottom));
  right: 16px;
  display: flex;
  align-items: center;
  gap: 5px;
  opacity: 0.28;
  transition: opacity var(--transition-fast, 150ms ease);
  z-index: 2;
  text-decoration: none;
}
.maker-credit:hover { opacity: 0.5; }

.maker-credit__mark {
  width: 14px;
  height: 14px;
  object-fit: contain;
  filter: grayscale(1);
}

.maker-credit__text {
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  text-transform: lowercase;
  white-space: nowrap;
}

/* ── ab-overlay (full-screen overlay panel, e.g. Logbook, Badges) ─
   Bugfix: this was `overflow: hidden` with no scrollable child, so any
   content taller than the viewport (e.g. a Logbook with more than a
   screenful of entries) was simply clipped — there was nothing to scroll.
   The header is made sticky and the overlay itself becomes the scroll
   container, so content scrolls under a header that stays put. ── */
.ab-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: var(--color-background);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  animation: fadeIn 0.2s ease;
}

.ab-overlay__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: max(var(--spacing-md, 16px), calc(env(safe-area-inset-top) + var(--spacing-sm, 8px)))
           var(--spacing-lg, 24px)
           var(--spacing-md, 16px);
  border-bottom: 1.5px solid var(--color-border);
  background: var(--color-surface);
  flex-shrink: 0;
  position: sticky;
  top: 0;
  z-index: 1;
  gap: var(--spacing-sm, 8px);
}

/* ── modal-backdrop + modal-sheet (DataSync, Reminders) ─────────── */
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 190;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  animation: fadeIn 0.2s ease;
}

.modal-sheet {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 195;
  background: var(--color-surface);
  border-radius: var(--border-radius-xl, 28px) var(--border-radius-xl, 28px) 0 0;
  width: 100%;
  max-width: var(--app-max-width, 480px);
  max-height: 88dvh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  padding: 0 var(--spacing-lg, 24px) max(var(--spacing-xl, 32px), env(safe-area-inset-bottom));
  animation: slideUp 0.35s cubic-bezier(0.32, 0.72, 0, 1);
}

.modal-sheet__handle {
  width: 36px;
  height: 4px;
  background: var(--color-border);
  border-radius: 2px;
  margin: 12px auto var(--spacing-md, 16px);
}

.modal-sheet__footer {
  padding-top: var(--spacing-md, 16px);
  border-top: 1px solid var(--color-border);
  margin-top: var(--spacing-md, 16px);
}

/* ── btn ghost variant (used in modal-sheet footer) ─────────────── */
.btn.btn--ghost {
  background: transparent;
  border: 1.5px solid var(--color-border);
  color: var(--color-text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border-radius: var(--border-radius-md, 12px);
  font-family: var(--font-family-heading, system-ui);
  font-size: var(--font-size-md, 1rem);
  font-weight: 700;
  cursor: pointer;
  transition: all var(--transition-fast, 150ms ease);
  padding: 0 var(--spacing-lg, 24px);
}
.btn.btn--ghost:hover { border-color: var(--color-primary); color: var(--color-primary); }
.btn.btn--full { width: 100%; }

/* ── overflow-item active state ─────────────────────────────────── */
.overflow-item--active {
  background: var(--color-primary-light);
  color: var(--color-primary);
}
.overflow-item--active .overflow-item__icon { color: var(--color-primary); }

/* ── Skeleton variants for loading state ────────────────────────── */
.skeleton-mark {
  width: 28px;
  height: 28px;
  border-radius: 50%;
}
.skeleton--title  { height: 20px; width: 120px; border-radius: 4px; }
.skeleton--line-short  { height: 14px; width: 60%;  border-radius: 4px; }
.skeleton--line-medium { height: 14px; width: 80%;  border-radius: 4px; }
.skeleton--line-long   { height: 14px; width: 95%;  border-radius: 4px; }
.skeleton--emoji  { width: 44px; height: 44px; border-radius: var(--border-radius-md, 12px); flex-shrink: 0; }
.skeleton-panic   { margin: var(--spacing-md, 16px) var(--spacing-lg, 24px) 0; height: 76px; border-radius: var(--border-radius-lg, 18px); background: linear-gradient(90deg, var(--color-surface-alt) 25%, var(--color-surface) 50%, var(--color-surface-alt) 75%); background-size: 800px 100%; animation: shimmer 1.4s ease infinite; }
.skeleton-card    { display: flex; align-items: flex-start; gap: var(--spacing-md, 16px); padding: var(--spacing-md, 16px); border-radius: var(--border-radius-lg, 18px); background: var(--color-surface); border: 1.5px solid var(--color-border); }
.skeleton-card__lines { flex: 1; display: flex; flex-direction: column; gap: 8px; padding-top: 4px; }

/* ═══════════════════════════════════════════════════════════════════
   Pack-specific UI overrides
   Scoped via data-pack attribute set by AppShell
   ═══════════════════════════════════════════════════════════════════ */

/* ── Enterprise: sharp, structured, table-density ────────────────── */
[data-pack="enterprise"] .app-header {
  border-bottom: 2px solid var(--color-primary);
  background: var(--color-surface);
}

[data-pack="enterprise"] .app-header__name {
  font-size: var(--font-size-md, 1rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

[data-pack="enterprise"] .activity-card,
[data-pack="enterprise"] .activity-row {
  border-radius: var(--border-radius-md, 4px);
  border-left: 3px solid var(--color-primary);
}

[data-pack="enterprise"] .activity-card:hover,
[data-pack="enterprise"] .activity-row:hover {
  border-left-color: var(--color-accent);
}

/* List mode default: table-like row density */
[data-pack="enterprise"] .activity-list {
  border: 1.5px solid var(--color-border);
  border-radius: var(--border-radius-md, 4px);
  overflow: hidden;
}

[data-pack="enterprise"] .activity-row {
  border-bottom: 1px solid var(--color-border);
  border-radius: 0;
  border-left: 3px solid transparent;
}

[data-pack="enterprise"] .activity-row:last-child {
  border-bottom: none;
}

[data-pack="enterprise"] .header-overflow__menu {
  border-radius: var(--border-radius-md, 4px);
}

[data-pack="enterprise"] .overflow-item {
  border-radius: var(--border-radius-sm, 2px);
}

[data-pack="enterprise"] .category-tab {
  border-radius: var(--border-radius-sm, 2px);
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  font-size: 0.75rem;
}

/* ── Clinical: serif headings, teal stripe header ────────────────── */
[data-pack="clinical"] .app-header {
  border-top: 3px solid var(--color-primary);
  border-bottom: 1px solid var(--color-border);
}

[data-pack="clinical"] .app-header__name {
  font-family: var(--font-family-heading, serif);
  font-weight: 600;
  font-style: italic;
  letter-spacing: 0;
}

[data-pack="clinical"] .detail-panel__title {
  font-family: var(--font-family-heading, serif);
  font-weight: 600;
}

[data-pack="clinical"] .activity-card {
  border-top: 2px solid var(--color-primary-light);
}

[data-pack="clinical"] .activity-card:hover {
  border-top-color: var(--color-primary);
}

/* Safety note gets clinical emphasis */
[data-pack="clinical"] .safety-note {
  border-left: 3px solid var(--color-danger);
  background: color-mix(in srgb, var(--color-danger) 8%, var(--color-surface));
}

[data-pack="clinical"] .category-tab {
  font-family: var(--font-family-body, sans-serif);
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════════
   Räddat från äldre filer vid versionsstädning (2026-06)
   Dessa regler styr klasser som fortfarande renderas av
   Components/*.razor men som aldrig flyttades över när ui.css
   ursprungligen konsoliderades. app.css, v2-additions.css,
   gui-fixes.css och v5-additions.css är borttagna — allt de
   bidrog med som faktiskt används finns nedan.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Från app.css / v2-additions.css ──────────────────────────────── */

/* ActivityActionBar.razor */
.action-bar__timer { display: flex; flex-direction: column; gap: var(--spacing-sm, 8px); }

/* ActivityCard.razor — fortfarande live: action-bar__timer (övriga
   .activity-card__thumb-regler i den gamla app.css matchade en
   div+background-image-variant av kortet som inte längre finns;
   nuvarande <img class="activity-card__thumb"> får sin styling från
   v6-additions-sektionen nedan, som redan matchar dagens <img>-markup). */

/* AudioPlayer.razor — ljudvågsindikator */
.audio-player__indicator { display: flex; align-items: flex-end; gap: 3px; height: 20px; }
.audio-player__indicator span { width: 4px; background: var(--color-primary); border-radius: 2px; animation: soundWave 0.8s ease-in-out infinite; }
.audio-player__indicator span:nth-child(2) { animation-delay: 0.15s; height: 14px; }
.audio-player__indicator span:nth-child(3) { animation-delay: 0.3s; height: 10px; }
@keyframes soundWave { 0%,100%{height:6px} 50%{height:20px} }

/* ── Från gui-fixes.css / v5-additions.css ────────────────────────── */

/* OnboardingFlow.razor */
.onboarding-actions__next,
.onboarding-actions__finish {
  width: 100%;
}

.onboarding-option__check {
  font-size: 0.9rem;
  font-weight: 900;
}

.onboarding-burst {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 301;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-lg);
}
.onboarding-burst span {
  font-size: 3rem;
  animation: burstPop 0.6s cubic-bezier(0.34,1.56,0.64,1) both;
}
.onboarding-burst span:nth-child(1) { animation-delay: 0ms;   }
.onboarding-burst span:nth-child(2) { animation-delay: 60ms;  }
.onboarding-burst span:nth-child(3) { animation-delay: 120ms; }
.onboarding-burst span:nth-child(4) { animation-delay: 180ms; }
.onboarding-burst span:nth-child(5) { animation-delay: 240ms; }
.onboarding-burst span:nth-child(6) { animation-delay: 300ms; }

@keyframes burstPop {
  0%   { transform: scale(0) translateY(20px); opacity: 0; }
  60%  { transform: scale(1.3) translateY(-30px); opacity: 1; }
  100% { transform: scale(0.8) translateY(-60px); opacity: 0; }
}

/* ═══════════════════════════════════════════════════════════════════
   v6 / v9 / v10 feature-tillägg — sammanslagna 2026-06
   Tidigare tre separata <link>-taggar i index.html (v6-additions.css,
   v9-additions.css, v10-additions.css). Innehållet är oförändrat och
   ligger i samma inbördes ordning som tidigare, så cascade-beteendet
   är identiskt — bara antalet HTTP-requests och filer är färre.
   ═══════════════════════════════════════════════════════════════════ */

/* ============================================================
   Playtypus v6 — feature additions
   List view, card actions, lock state, user activities,
   activity notes, data sync panel, user activity editor.
   ============================================================ */

/* ── Layout toggle: removed — now a single .icon-btn (see header icon-btn
   rules above), reused as-is so the control never grows past one button's
   footprint regardless of how many modes a pack enables. ── */

/* ── Activity list (row layout) ──────────────────────────────────────────── */

.activity-list {
  display: flex;
  flex-direction: column;
  gap: var(--row-gap, 6px);
  padding: 0 12px 24px;
}

.activity-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: var(--row-padding, 12px 14px);
  background: var(--color-card, #fff);
  border-radius: var(--row-border-radius, 12px);
  box-shadow: var(--row-shadow, 0 1px 4px rgba(0,0,0,0.07));
  cursor: pointer;
  transition: transform 0.12s, box-shadow 0.12s, background-color 200ms ease;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.activity-row:hover  { transform: translateY(-1px); box-shadow: var(--row-shadow-hover, 0 3px 8px rgba(0,0,0,0.11)); }
.activity-row:active { transform: scale(0.99); }

.activity-row--done  { opacity: 0.6; }
.activity-row--locked {
  opacity: 0.5;
  cursor: not-allowed;
  filter: grayscale(0.4);
}

.activity-row__emoji {
  font-size: var(--row-emoji-size, 1.6rem);
  flex-shrink: 0;
  position: relative;
  width: 2.4rem;
  text-align: center;
}

.activity-row__body {
  flex: 1;
  min-width: 0;
}

.activity-row__title-line {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.activity-row__title {
  font-size: var(--row-title-size, 0.975rem);
  font-weight: var(--font-weight-row-title, 600);
  color: var(--color-text, #222);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.activity-row__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}

.activity-row__actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

/* ── Small badge / chip variants ─────────────────────────────────────────── */

.meta-chip--sm       { font-size: 0.7rem; padding: 2px 6px; }
.category-chip--sm   { font-size: 0.7rem; padding: 2px 7px; }
.level-badge--sm     { gap: 1px; }
.done-badge--sm      { top: -4px; right: -4px; }
.favorite-btn--sm    { padding: 2px 4px; min-width: unset; }

/* ── Card quick-actions ──────────────────────────────────────────────────── */

.activity-card__card-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.card-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px;
  border-radius: 8px;
  font-size: 0.8rem;
  font-weight: 600;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: opacity 0.15s, transform 0.1s;
  line-height: 1.2;
}
.card-action-btn:active { transform: scale(0.96); }

.card-action-btn--timer {
  background: var(--color-accent, #e8845a);
  color: #fff;
}
.card-action-btn--link {
  background: var(--color-surface-alt, #f0ece8);
  color: var(--color-text, #222);
}

/* ── Lock state ──────────────────────────────────────────────────────────── */

.activity-card--locked {
  opacity: 0.5;
  cursor: not-allowed;
  filter: grayscale(0.35);
}

.lock-icon {
  position: absolute;
  top: -4px;
  right: -6px;
  display: flex;
}

/* ── User activity badge ─────────────────────────────────────────────────── */

.user-badge {
  display: inline-flex;
  vertical-align: middle;
  opacity: 0.7;
}

/* ── Activity note ───────────────────────────────────────────────────────── */

.activity-note {
  background: var(--color-surface-alt, #faf8f5);
  border: 1.5px dashed var(--color-border, #ddd);
  border-radius: 12px;
  padding: 12px 14px;
  margin: 16px 0;
}

.activity-note__header {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
}

.activity-note__label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-text-muted, #888);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.activity-note__saving {
  font-size: 0.75rem;
  color: var(--color-text-muted, #aaa);
  margin-left: auto;
}

.activity-note__textarea {
  width: 100%;
  border: 1.5px solid var(--color-border, #ddd);
  border-radius: 8px;
  padding: 8px 10px;
  font-size: 0.9rem;
  font-family: inherit;
  resize: vertical;
  background: var(--color-card, #fff);
  color: var(--color-text, #222);
  box-sizing: border-box;
  transition: border-color 0.15s;
}
.activity-note__textarea:focus {
  outline: none;
  border-color: var(--color-accent, #e8845a);
}

.activity-note__clear {
  margin-top: 6px;
  font-size: 0.78rem;
  opacity: 0.65;
}

/* ── User activity editor (modal sheet) ──────────────────────────────────── */

.user-activity-editor {
  max-height: 90dvh;
  overflow-y: auto;
}

.user-activity-editor__form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 0 0 4px;
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.form-field__label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-text-muted, #888);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.form-field__label .required {
  color: var(--color-accent, #e8845a);
}

.form-field__input,
.form-field__textarea,
.form-field__select {
  border: 1.5px solid var(--color-border, #ddd);
  border-radius: 8px;
  padding: 9px 11px;
  font-size: 0.95rem;
  font-family: inherit;
  background: var(--color-card, #fff);
  color: var(--color-text, #222);
  box-sizing: border-box;
  width: 100%;
  transition: border-color 0.15s;
}

.form-field__input:focus,
.form-field__textarea:focus,
.form-field__select:focus {
  outline: none;
  border-color: var(--color-accent, #e8845a);
}

.form-field__input--emoji {
  font-size: 1.4rem;
  width: 4rem;
  text-align: center;
}

.form-field__textarea { resize: vertical; min-height: 70px; }

.form-error {
  color: #c0392b;
  font-size: 0.85rem;
  padding: 6px 10px;
  background: #fdecea;
  border-radius: 8px;
  margin: 0;
}

/* ── Data sync panel ─────────────────────────────────────────────────────── */

.data-sync-panel {
  padding: 16px 0;
}

.data-sync-panel__title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 6px;
}

.data-sync-panel__desc {
  font-size: 0.875rem;
  color: var(--color-text-muted, #666);
  margin: 0 0 14px;
  line-height: 1.5;
}

.data-sync-panel__section {
  margin-bottom: 10px;
}

.btn--full { width: 100%; justify-content: center; }

.data-sync-panel__feedback {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 0.875rem;
  line-height: 1.4;
}

.data-sync-panel__feedback--ok    { background: #eafaf1; color: #1e7e34; }
.data-sync-panel__feedback--error { background: #fdecea; color: #c0392b; }

/* ── Add activity FAB ────────────────────────────────────────────────────── */

.fab-add-activity {
  position: fixed;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 80px);
  right: 20px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--color-accent, #e8845a);
  color: #fff;
  border: none;
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(0,0,0,0.22);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.15s, box-shadow 0.15s;
  z-index: 200;
}
.fab-add-activity:hover  { transform: scale(1.07); }
.fab-add-activity:active { transform: scale(0.95); }

/* ── Reminder panel ──────────────────────────────────────────────────────── */

.reminder-panel {
  padding: 16px 0;
}

.reminder-panel__title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 14px;
}

.reminder-panel__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
}

.reminder-panel__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.reminder-panel__time {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-text, #222);
}

.reminder-panel__freq {
  font-size: 0.8rem;
  color: var(--color-text-muted, #888);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.reminder-panel__ics {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--color-border, #eee);
}

.reminder-panel__ics-note {
  font-size: 0.85rem;
  color: var(--color-text-muted, #666);
  margin: 0 0 10px;
  line-height: 1.5;
}

.reminder-panel__feedback {
  font-size: 0.85rem;
  color: var(--color-text-muted, #666);
  margin: 10px 0 0;
  font-style: italic;
}

/* ── Toggle switch ───────────────────────────────────────────────────────── */

.toggle-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  flex-shrink: 0;
}

.toggle-switch input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-switch__track {
  display: block;
  width: 46px;
  height: 26px;
  background: var(--color-surface-alt, #ddd);
  border-radius: 13px;
  transition: background 0.2s;
  position: relative;
}

.toggle-switch__track::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
  transition: transform 0.2s;
}

.toggle-switch input:checked ~ .toggle-switch__track {
  background: var(--color-accent, #e8845a);
}

.toggle-switch input:checked ~ .toggle-switch__track::after {
  transform: translateX(20px);
}

.toggle-switch input:focus-visible ~ .toggle-switch__track {
  outline: 2px solid var(--color-accent, #e8845a);
  outline-offset: 2px;
}


/* ── Thumbnail support on cards / rows (v8) ───────────────────────────────── */

.activity-card__emoji--thumbnail,
.activity-row__emoji--thumbnail {
  padding: 0;
  overflow: hidden;
  border-radius: var(--radius-sm, 6px);
  background: var(--color-surface-alt, #f3f4f6);
}

.activity-card__thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-sm, 6px);
  display: block;
}

.activity-row__thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-sm, 6px);
  display: block;
}

/* ── Audio recorder (v8) ──────────────────────────────────────────────────── */

.voice-recorder {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 0 16px 16px;
}

.voice-recorder__controls {
  display: flex;
  align-items: center;
  gap: 12px;
}

.voice-recorder__btn {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
  flex-shrink: 0;
}

.voice-recorder__btn--record {
  background: var(--color-danger, #ef4444);
  color: #fff;
  box-shadow: 0 0 0 0 rgba(239,68,68,0.4);
}

.voice-recorder__btn--record.is-recording {
  animation: rec-pulse 1.4s ease-in-out infinite;
}

@keyframes rec-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239,68,68,0.4); }
  50%       { box-shadow: 0 0 0 10px rgba(239,68,68,0); }
}

.voice-recorder__btn--stop {
  background: var(--color-surface-alt, #e5e7eb);
  color: var(--color-text, #111);
}

.voice-recorder__timer {
  font-variant-numeric: tabular-nums;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-text, #111);
  min-width: 48px;
}

.voice-recorder__status {
  font-size: 0.8rem;
  color: var(--color-text-muted, #6b7280);
}

.voice-recorder__list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 340px;
  overflow-y: auto;
}

.voice-recorder__empty {
  font-size: 0.85rem;
  color: var(--color-text-muted, #6b7280);
  text-align: center;
  padding: 24px 0;
}

.voice-recording {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--color-surface, #fff);
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: var(--radius-md, 10px);
}

.voice-recording__name {
  flex: 1;
  font-size: 0.85rem;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.voice-recording__dur {
  font-size: 0.75rem;
  color: var(--color-text-muted, #6b7280);
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}

.voice-recording__btn {
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  border-radius: 4px;
  color: var(--color-text-muted, #6b7280);
  flex-shrink: 0;
}

.voice-recording__btn:hover {
  color: var(--color-primary, #5b8def);
  background: var(--color-primary-ghost, #eff4ff);
}

.voice-recording__btn--delete:hover {
  color: var(--color-danger, #ef4444);
  background: #fef2f2;
}

.voice-recording__waveform {
  display: flex;
  align-items: center;
  gap: 2px;
  height: 20px;
  flex-shrink: 0;
}

.voice-recording__waveform span {
  display: block;
  width: 3px;
  border-radius: 2px;
  background: var(--color-primary, #5b8def);
  animation: waveform-bar 1s ease-in-out infinite;
}

.voice-recording__waveform span:nth-child(2) { animation-delay: 0.15s; }
.voice-recording__waveform span:nth-child(3) { animation-delay: 0.3s; }
.voice-recording__waveform span:nth-child(4) { animation-delay: 0.45s; }

@keyframes waveform-bar {
  0%, 100% { height: 4px; }
  50%       { height: 16px; }
}

/*
 * v9-additions.css
 * Styles for Playtypus v9 features.
 * All selectors follow the BEM conventions used elsewhere in the codebase.
 */


/* ── WeeklyGoalBar ─────────────────────────────────────────────────────────
 * Compact ring + text indicator shown in .app-header__actions next to
 * the streak counter. Sized to match .streak-counter height (≈30px).
 * ─────────────────────────────────────────────────────────────────────────── */

.weekly-goal {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px 4px 6px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-primary, #E8845A) 10%, transparent);
    user-select: none;
    line-height: 1;
}

.weekly-goal__ring {
    width: 26px;
    height: 26px;
    flex-shrink: 0;
}

.weekly-goal__ring-track {
    stroke: color-mix(in srgb, var(--color-primary, #E8845A) 20%, transparent);
}

.weekly-goal__ring-fill {
    stroke: var(--color-primary, #E8845A);
    stroke-linecap: round;
    transition: stroke-dashoffset 400ms ease;
}

.weekly-goal__label {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--color-primary, #E8845A);
    white-space: nowrap;
}

.weekly-goal__sep {
    opacity: 0.5;
    font-weight: 400;
    margin: 0 1px;
}


/* ── FavoritesShelf ────────────────────────────────────────────────────────
 * Horizontal scrollable strip of favourite activity cards, rendered
 * above the main activity grid when Features.FavoritesShelf == true.
 * ─────────────────────────────────────────────────────────────────────────── */

.favorites-shelf {
    padding: 0 var(--spacing-md, 16px) var(--spacing-sm, 8px);
    border-bottom: 1.5px solid var(--color-border, #e8e0d8);
}

.favorites-shelf__scroll {
    display: flex;
    gap: var(--spacing-sm, 8px);
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: none;          /* Firefox */
    -ms-overflow-style: none;       /* IE/Edge */
    scroll-snap-type: x mandatory;
}

.favorites-shelf__scroll::-webkit-scrollbar {
    display: none;                  /* Chrome/Safari */
}

.favorites-shelf__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    min-width: 72px;
    max-width: 88px;
    padding: 8px 6px;
    border: 1.5px solid var(--color-border, #e8e0d8);
    border-radius: var(--border-radius-md, 12px);
    background: var(--color-surface, #fff);
    cursor: pointer;
    scroll-snap-align: start;
    flex-shrink: 0;
    text-align: center;
    transition: border-color 150ms ease, box-shadow 150ms ease;
}

.favorites-shelf__item:hover,
.favorites-shelf__item:focus-visible {
    border-color: var(--color-primary, #E8845A);
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    outline: none;
}

.favorites-shelf__thumb {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.favorites-shelf__thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--color-primary, #E8845A) 12%, transparent);
    color: var(--color-primary, #E8845A);
    font-size: 1.4rem;
    border-radius: 50%;
    width: 48px;
    height: 48px;
}

.favorites-shelf__label {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--color-text, #1a1a1a);
    line-height: 1.2;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
}


/* ── PackVersioning update banner ──────────────────────────────────────────
 * Info banner shown in ActivityDetail when the activity has been updated
 * since the user last marked it done and Features.PackVersioning == true.
 * ─────────────────────────────────────────────────────────────────────────── */

.update-banner {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm, 8px);
    padding: var(--spacing-sm, 8px) var(--spacing-md, 16px);
    border-radius: var(--border-radius-md, 12px);
    background: color-mix(in srgb, var(--color-primary, #E8845A) 8%, transparent);
    border: 1.5px solid color-mix(in srgb, var(--color-primary, #E8845A) 25%, transparent);
    margin-bottom: var(--spacing-md, 16px);
}

.update-banner__icon {
    flex-shrink: 0;
    display: flex;
}

.update-banner__text {
    font-size: var(--font-size-sm, 0.875rem);
    color: var(--color-text, #1a1a1a);
    line-height: 1.4;
}


/* ── YouTube consent — placeholder (no external request) ───────────────────
 * Replaces the old background-image thumbnail that leaked to YouTube.
 * Uses an inline SVG play button on a dark background instead.
 * ─────────────────────────────────────────────────────────────────────────── */

.youtube-consent__thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #111;
    /* Keep the existing 16:9 padding-bottom trick from .youtube-consent__thumb */
}

.youtube-consent__play-svg {
    width: 64px;
    height: 64px;
    opacity: 0.9;
    transition: opacity 150ms ease, transform 150ms ease;
}

.youtube-consent:hover .youtube-consent__play-svg {
    opacity: 1;
    transform: scale(1.08);
}


/* ── Broken image fallback ─────────────────────────────────────────────────
 * Applied via onerror on <img> elements in ContentBlockRenderer.
 * Shows a muted placeholder instead of the browser's broken-image icon.
 * ─────────────────────────────────────────────────────────────────────────── */

.img--broken {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 80px;
    width: 100%;
    background: var(--color-surface-alt, #f7f3ef);
    border: 1.5px dashed var(--color-border, #e8e0d8);
    border-radius: var(--border-radius-md, 12px);
    color: var(--color-text-muted, #999);
    font-size: var(--font-size-sm, 0.875rem);
}

/* onerror sets alt text — we hide the broken-icon via overflow */
.img--broken::before {
    content: "🖼 " attr(alt);
}

.img--broken[alt="Image unavailable"]::before {
    content: "🖼  Image unavailable";
}


/* ── ActivityNoteEditor: saved confirmation ────────────────────────────────── */

.activity-note__saved {
    font-size: 0.75rem;
    color: var(--color-success, #4a9b6f);
    margin-left: auto;
    opacity: 0.8;
}

 * New block types added in v9: "text" renders a paragraph, "divider" an <hr>.
 * ─────────────────────────────────────────────────────────────────────────── */

.content-block--text .content-block__text {
    font-size: var(--font-size-body, 1rem);
    color: var(--color-text, #1a1a1a);
    line-height: 1.6;
    margin: 0;
}

.content-block--divider {
    border: none;
    border-top: 1.5px solid var(--color-border, #e8e0d8);
    margin: var(--spacing-md, 16px) 0;
}

/*
 * v10-additions.css
 * Styles for Playtypus v10 features.
 * All selectors follow the BEM conventions used elsewhere in the codebase.
 */


/* ══════════════════════════════════════════════════════════════════════════
 * DENSITY LEVELS
 * Applied via data-density on .app-shell (set by AppShell.razor).
 * "comfortable" = default (~64 px rows, unchanged from v6 baseline)
 * "compact"     = ~44 px rows – meta chips collapsed
 * "minimal"     = ~34 px rows – no meta row
 * Only affects .activity-row (list view). Grid cards are untouched.
 * ══════════════════════════════════════════════════════════════════════════ */

.app-shell[data-density="compact"] .activity-row {
    --row-padding: 7px 14px;
}

.app-shell[data-density="compact"] .activity-row__meta {
    flex-wrap: nowrap;
    overflow: hidden;
    gap: 3px;
    margin-top: 2px;
}

.app-shell[data-density="compact"] .activity-row__meta > *:nth-child(n+3) {
    display: none;
}

.app-shell[data-density="compact"] .activity-row__title {
    font-size: 0.9rem;
}

.app-shell[data-density="compact"] .activity-row__emoji {
    font-size: 1.3rem;
    width: 2rem;
}

.app-shell[data-density="minimal"] .activity-row {
    --row-padding: 5px 14px;
    align-items: center;
}

.app-shell[data-density="minimal"] .activity-row__meta {
    display: none;
}

.app-shell[data-density="minimal"] .activity-row__title {
    font-size: 0.875rem;
}

.app-shell[data-density="minimal"] .activity-row__emoji {
    font-size: 1.1rem;
    width: 1.75rem;
}

.app-shell[data-density="minimal"] .activity-row__actions .card-action-btn {
    display: none;
}


/* ══════════════════════════════════════════════════════════════════════════
 * MAP CONTENT BLOCK
 * Consent gate follows the webembed-consent pattern from v6-additions.css.
 * ══════════════════════════════════════════════════════════════════════════ */

.content-block--map {
    border-radius: var(--border-radius-md, 12px);
    overflow: hidden;
}

.map-consent {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 160px;
    background: var(--color-surface-alt, #f7f3ef);
    border: 1.5px dashed var(--color-border, #e8e0d8);
    border-radius: var(--border-radius-md, 12px);
    cursor: pointer;
    transition: border-color 150ms ease, background 150ms ease;
}

.map-consent:hover,
.map-consent:focus-visible {
    border-color: var(--color-primary, #E8845A);
    background: color-mix(in srgb, var(--color-primary, #E8845A) 5%, var(--color-surface-alt, #f7f3ef));
    outline: none;
}

.map-consent__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 24px 16px;
    text-align: center;
}

.map-consent__icon { display: flex; align-items: center; justify-content: center; }

.map-consent__title {
    font-size: var(--font-size-body, 1rem);
    font-weight: 600;
    color: var(--color-text, #1a1a1a);
    margin: 0;
}

.map-consent__notice {
    font-size: var(--font-size-sm, 0.875rem);
    color: var(--color-text-muted, #888);
    margin: 0;
}

.map-consent__btn {
    display: inline-block;
    margin-top: 6px;
    padding: 6px 18px;
    background: var(--color-primary, #E8845A);
    color: #fff;
    border-radius: 999px;
    font-size: var(--font-size-sm, 0.875rem);
    font-weight: 600;
    pointer-events: none;
}

.map-frame { width: 100%; }

.map-frame .leaflet-control-attribution {
    font-size: 10px;
    opacity: 0.8;
}


/* ══════════════════════════════════════════════════════════════════════════
 * TIMELINE VIEW
 * ══════════════════════════════════════════════════════════════════════════ */

.activity-timeline {
    display: flex;
    flex-direction: column;
    gap: 32px;
    padding: 8px 0 24px;
}

.timeline-group__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}

.timeline-group__line {
    flex: 1;
    height: 1.5px;
    background: var(--color-border, #e8e0d8);
}

.timeline-group__label {
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-text-muted, #888);
    white-space: nowrap;
    margin: 0;
}

.timeline-group__count {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--color-text-muted, #aaa);
    background: var(--color-surface-alt, #f3ede8);
    border-radius: 999px;
    padding: 1px 7px;
}

.timeline-group__items {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.timeline-item {
    display: grid;
    grid-template-columns: 36px 1fr;
    gap: 8px;
    align-items: flex-start;
}

.timeline-item__pip {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 10px;
}

.timeline-item__day {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--color-primary, #E8845A);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    flex-shrink: 0;
}

.timeline-item__day--none {
    background: var(--color-surface-alt, #e8e0d8);
    color: var(--color-text-muted, #aaa);
}

.timeline-item__card { min-width: 0; }

.timeline-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 48px 16px;
    text-align: center;
}

.timeline-empty__icon { display: flex; align-items: center; justify-content: center; }
.timeline-empty__text {
    font-size: 0.9rem;
    color: var(--color-text-muted, #888);
    margin: 0;
}


/* ══════════════════════════════════════════════════════════════════════════
 * TABLE VIEW
 * ══════════════════════════════════════════════════════════════════════════ */

.activity-table-wrapper {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.activity-table {
    width: 100%;
    min-width: 420px;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.875rem;
}

.activity-table__head-row {
    position: sticky;
    top: 0;
    z-index: 1;
    background: var(--color-surface, #fff);
}

.activity-table__th {
    padding: 8px 10px;
    text-align: left;
    white-space: nowrap;
    border-bottom: 2px solid var(--color-border, #e8e0d8);
    color: var(--color-text-muted, #888);
    font-size: 0.75rem;
    font-weight: 600;
}

.activity-table__th--icon   { width: 36px; padding: 8px 4px; }
.activity-table__th--prep   { width: 52px; text-align: center; }
.activity-table__th--level  { width: 52px; text-align: center; }
.activity-table__th--done   { width: 40px; text-align: center; }
.activity-table__th--fav    { width: 40px; text-align: center; }

.table-sort-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
    white-space: nowrap;
}

.table-sort-btn--active { color: var(--color-primary, #E8845A); }
.table-sort-btn__icon   { display: flex; opacity: 0.6; }

.activity-table__row {
    cursor: pointer;
    transition: background 120ms ease;
}

.activity-table__row:hover {
    background: color-mix(in srgb, var(--color-primary, #E8845A) 5%, transparent);
}

.activity-table__row:focus-visible {
    outline: 2px solid var(--color-primary, #E8845A);
    outline-offset: -2px;
}

.activity-table__row--done   { opacity: 0.55; }
.activity-table__row--locked { cursor: not-allowed; opacity: 0.45; filter: grayscale(0.4); }

.activity-table__td {
    padding: 9px 10px;
    border-bottom: 1px solid var(--color-border, #f0eae4);
    vertical-align: middle;
}

.activity-table__td--icon   { padding: 9px 4px; width: 36px; }
.activity-table__td--prep   { text-align: center; }
.activity-table__td--level  { text-align: center; }
.activity-table__td--done   { text-align: center; }
.activity-table__td--fav    { text-align: center; }

.activity-table__emoji { font-size: 1.25rem; line-height: 1; }
.activity-table__thumb { width: 28px; height: 28px; object-fit: cover; border-radius: 6px; }
.activity-table__title { font-weight: 600; color: var(--color-text, #1a1a1a); }

.table-done-btn {
    background: none;
    border: 1.5px solid var(--color-border, #ccc);
    border-radius: 50%;
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 0.75rem;
    color: var(--color-text-muted, #aaa);
    transition: border-color 120ms, background 120ms, color 120ms;
}

.table-done-btn--active {
    background: var(--color-primary, #E8845A);
    border-color: var(--color-primary, #E8845A);
    color: #fff;
}

.table-empty { padding: 32px 16px; text-align: center; }
.table-empty__text { font-size: 0.9rem; color: var(--color-text-muted, #888); margin: 0; }


/* ══════════════════════════════════════════════════════════════════════════
 * ADMIN MODE
 * ══════════════════════════════════════════════════════════════════════════ */

/* Admin mode stripe — full-width bar directly below the sticky header */
.admin-mode-stripe {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 5px 16px;
    background: #f59e0b;
    color: #fff;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    user-select: none;
    position: sticky;
    top: var(--header-min-height, 60px);
    z-index: 99;
}

.overflow-divider {
    border: none;
    border-top: 1px solid var(--color-border, #eee);
    margin: 4px 12px;
}

.overflow-item--admin  { color: #f59e0b; font-weight: 600; }
.overflow-item--danger { color: var(--color-danger, #e53e3e); }

/* Admin login modal */
.admin-login-modal { max-width: 400px; }

.admin-login-modal__desc {
    font-size: 0.875rem;
    color: var(--color-text-muted, #888);
    margin: 0 0 16px;
    text-align: center;
}

.admin-login-modal__form {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 0 4px;
}

/* Admin activity editor */
.admin-activity-editor {
    max-height: 90dvh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.admin-activity-editor .modal-sheet__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding-bottom: 4px;
}

.admin-activity-editor__form {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0 4px;
}

.form-section {
    padding: 12px 0;
    border-bottom: 1px solid var(--color-border, #f0eae4);
}

.form-section:last-child { border-bottom: none; }

.form-section__title {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-text-muted, #aaa);
    margin: 0 0 10px;
}

.form-section--publish {
    background: color-mix(in srgb, #f59e0b 6%, transparent);
    border-radius: var(--border-radius-md, 10px);
    padding: 12px;
    margin-top: 4px;
}

.form-row { display: grid; gap: 8px; margin-bottom: 8px; }
.form-row--2col { grid-template-columns: 1fr 1fr; }
.form-row--3col { grid-template-columns: 1fr 1fr 1fr; }

@media (max-width: 360px) {
    .form-row--3col { grid-template-columns: 1fr 1fr; }
}

.form-field--checkbox {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    padding-top: 4px;
}

.form-field--checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--color-primary, #E8845A);
}

.form-field__hint {
    font-size: 0.75rem;
    color: var(--color-text-muted, #aaa);
    margin: 2px 0 0;
}

.modal-sheet__footer--wrap { flex-wrap: wrap; gap: 8px; }

.form-success {
    font-size: 0.875rem;
    color: #16a34a;
    background: color-mix(in srgb, #16a34a 8%, transparent);
    border-radius: 8px;
    padding: 8px 12px;
    margin: 4px 0 0;
}

.btn--danger-ghost {
    background: transparent;
    border: 1.5px solid var(--color-danger, #e53e3e);
    color: var(--color-danger, #e53e3e);
}

.btn--danger-ghost:hover {
    background: color-mix(in srgb, var(--color-danger, #e53e3e) 8%, transparent);
}

.btn--danger { background: var(--color-danger, #e53e3e); color: #fff; border: none; }
.btn--sm { padding: 4px 10px; font-size: 0.8rem; }

.admin-confirm-delete {
    background: color-mix(in srgb, var(--color-danger, #e53e3e) 8%, transparent);
    border: 1.5px solid var(--color-danger, #e53e3e);
    border-radius: var(--border-radius-md, 10px);
    padding: 12px 14px;
    margin: 0 4px 12px;
}

.admin-confirm-delete p {
    font-weight: 600;
    color: var(--color-danger, #e53e3e);
    margin: 0 0 10px;
    font-size: 0.9rem;
}

.admin-confirm-delete__actions { display: flex; gap: 8px; justify-content: flex-end; }
