/* ==========================================================================
   Ezra Productivity PWA - Core Design System
   Aesthetics: Vibe-coded, Minimalist, Clean, Premium Startup
   Palette: Deep Sage Green (#4A6B5D), Muted Gold (#D4B886), Off-White (#FAFAFA)
   ========================================================================== */

/* GDPR-Compliant Local Font Declarations (Round 10) */
@font-face {
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: local('Outfit Light'), local('Outfit-Light'), url('./fonts/outfit-v15-latin-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: local('Outfit Regular'), local('Outfit-Regular'), url('./fonts/outfit-v15-latin-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: local('Outfit Medium'), local('Outfit-Medium'), url('./fonts/outfit-v15-latin-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: local('Outfit Bold'), local('Outfit-Bold'), url('./fonts/outfit-v15-latin-700.woff2') format('woff2');
}

@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: local('Plus Jakarta Sans Regular'), local('PlusJakartaSans-Regular'), url('./fonts/plus-jakarta-sans-v12-latin-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: local('Plus Jakarta Sans SemiBold'), local('PlusJakartaSans-SemiBold'), url('./fonts/plus-jakarta-sans-v12-latin-600.woff2') format('woff2');
}

:root {
  /* Colors */
  --bg-color: #FAFAFA;
  --surface-color: #FFFFFF;
  --primary-accent: #4A6B5D;
  --primary-accent-rgb: 74, 107, 93;
  --primary-light: #F0F4F2;
  --secondary-accent: #D4B886;
  --secondary-light: #F9F5EE;
  --text-primary: #2D3142;
  --text-secondary: #8E93A6;
  --border-color: #ECEEF2;
  --danger-color: #E27474;
  --danger-light: #FDF1F1;
  --success-color: #5C9A6F;
  --shadow-color: rgba(45, 49, 66, 0.04);
  
  /* Fonts */
  --font-header: 'Outfit', sans-serif;
  --font-body: 'Plus Jakarta Sans', sans-serif;
  
  /* Borders & Spacing */
  --radius-lg: 24px;
  --radius-md: 16px;
  --radius-sm: 10px;
  --transition-smooth: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-bounce: all 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

/* ==========================================================================
   Base resets & layouts
   ========================================================================== */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  -webkit-tap-highlight-color: transparent;
}

body {
  font-family: var(--font-body);
  background-color: #1e2220; /* Dark premium background for margins on desktop */
  color: var(--text-primary);
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  overflow: hidden;
}

/* PWA App Frame Wrapper (Centering on wide screens like a native mobile app) */
#app-frame {
  width: 100%;
  max-width: 480px;
  height: 100vh;
  background-color: var(--bg-color);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.25);
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

@media (max-width: 480px) {
  #app-frame {
    max-width: 100%;
    height: 100vh;
    box-shadow: none;
  }
}

/* Base Content Screens styling */
.screen {
  flex: 1;
  overflow-y: auto;
  padding: 24px 20px 100px 20px; /* Generous bottom spacing for bottom navigation bar */
  display: none;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  scrollbar-width: none;
}

.screen::-webkit-scrollbar {
  display: none;
}

.screen.active {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

/* Section Headings */
h1, h2, h3, h4 {
  font-family: var(--font-header);
  color: var(--text-primary);
}

.screen-title {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 6px;
  color: var(--text-primary);
  letter-spacing: -0.5px;
}

.screen-subtitle {
  font-size: 14px;
  color: var(--text-secondary);
  margin-bottom: 24px;
  font-weight: 400;
}

/* ==========================================================================
   Navigation Bar (Bottom)
   ========================================================================== */
.bottom-nav {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 72px;
  background-color: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(20px);
  border-top: 1px solid var(--border-color);
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  align-items: center;
  z-index: 100;
  padding: 0 10px;
}

.nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  height: 100%;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 500;
  gap: 4px;
  transition: var(--transition-smooth);
}

.nav-item svg {
  width: 22px;
  height: 22px;
  transition: var(--transition-bounce);
  stroke-width: 1.75;
}

.nav-item .filled-icon {
  display: none;
  fill: var(--primary-accent);
}

.nav-item.active {
  color: var(--primary-accent);
  font-weight: 600;
}

.nav-item.active svg {
  transform: translateY(-2px);
  stroke: var(--primary-accent);
}

.nav-item.active .outline-icon {
  display: none;
}

.nav-item.active .filled-icon {
  display: block;
}

/* ==========================================================================
   Onboarding Slider Wizard
   ========================================================================== */
#onboarding-screen {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 500;
  background-color: var(--bg-color);
  display: flex;
  flex-direction: column;
  padding: 0;
}

.onboarding-slides {
  flex: 1;
  display: flex;
  width: 600%; /* 6 Slides */
  height: 100%;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.slide {
  width: 16.666%; /* 100% / 6 */
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 48px 24px 36px 24px;
  overflow-y: auto;
}

.slide-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-top: auto;
  margin-bottom: auto;
}

.slide-illustration {
  margin-bottom: 24px;
  width: 150px;
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--primary-light);
  box-shadow: inset 0 8px 24px rgba(74, 107, 93, 0.05);
}

.slide-illustration svg {
  width: 80px;
  height: 80px;
  color: var(--primary-accent);
}

.slide h2 {
  font-size: 26px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 12px;
  line-height: 1.25;
}

.slide p {
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.6;
  max-width: 320px;
}

/* Persona options grid */
.persona-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  width: 100%;
  margin-top: 10px;
}

.persona-card {
  background: var(--surface-color);
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 16px;
  cursor: pointer;
  text-align: left;
  transition: var(--transition-smooth);
}

.persona-card:hover, .persona-card.selected {
  border-color: var(--primary-accent);
  background: var(--primary-light);
  transform: translateY(-2px);
}

.persona-icon {
  font-size: 24px;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  background: var(--primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-smooth);
}

.persona-info h4 {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 2px;
}

.persona-info p {
  font-size: 11px;
  color: var(--text-secondary);
  margin: 0;
  text-align: left;
}

/* Scrollable onboarding catalog checklist style */
.onboarding-checklist-container {
  width: 100%;
  max-height: 280px;
  overflow-y: auto;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--surface-color);
  padding: 16px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 20px;
  box-shadow: inset 0 4px 12px rgba(0, 0, 0, 0.02);
}

/* Custom minimal scrollbar for onboarding checklist */
.onboarding-checklist-container::-webkit-scrollbar {
  width: 4px;
}
.onboarding-checklist-container::-webkit-scrollbar-track {
  background: transparent;
}
.onboarding-checklist-container::-webkit-scrollbar-thumb {
  background: var(--border-color);
  border-radius: 4px;
}

.onboarding-checklist-category {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.onboarding-checklist-cat-title {
  font-family: var(--font-header);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--primary-accent);
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--border-color);
  padding-bottom: 4px;
}

.onboarding-checklist-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 0;
  border-bottom: 1px dashed var(--border-color);
  cursor: pointer;
}
.onboarding-checklist-item:last-child {
  border-bottom: none;
}

.onboarding-checklist-label {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text-primary);
}

.onboarding-checklist-emoji {
  font-size: 18px;
}

/* Custom checklist rounded checkbox input representation */
.onboarding-check-round {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid var(--border-color);
  display: flex;
  align-items: center;
  justify-content: center;
  color: transparent;
  transition: var(--transition-bounce);
}

.onboarding-check-round svg {
  width: 12px;
  height: 12px;
  stroke-width: 3.5;
}

.onboarding-checklist-item.checked .onboarding-check-round {
  background: var(--primary-accent);
  border-color: var(--primary-accent);
  color: var(--surface-color);
}

/* Onboarding Controls */
.onboarding-controls {
  padding: 0 24px 36px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.slide-dots {
  display: flex;
  gap: 8px;
}

.dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border-color);
  transition: var(--transition-smooth);
}

.dot.active {
  width: 24px;
  border-radius: 4px;
  background: var(--primary-accent);
}

.btn-primary {
  width: 100%;
  background: var(--primary-accent);
  color: var(--surface-color);
  border: none;
  padding: 16px 24px;
  font-family: var(--font-header);
  font-size: 16px;
  font-weight: 600;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: var(--transition-bounce);
  box-shadow: 0 8px 24px rgba(74, 107, 93, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.btn-primary:active {
  transform: scale(0.97);
}

.btn-secondary {
  background: transparent;
  color: var(--text-secondary);
  border: none;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
}

/* ==========================================================================
   Home / Today Screen Layout
   ========================================================================== */
.header-widget {
  background: linear-gradient(135deg, #4A6B5D 0%, #3B5449 100%);
  color: var(--surface-color);
  border-radius: var(--radius-lg);
  padding: 24px;
  margin-bottom: 20px;
  box-shadow: 0 12px 32px rgba(74, 107, 93, 0.15);
  position: relative;
  overflow: hidden;
}

.header-widget::after {
  content: '';
  position: absolute;
  top: -60px;
  right: -60px;
  width: 160px;
  height: 160px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 50%;
}

.header-greeting {
  font-family: var(--font-header);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  opacity: 0.8;
  margin-bottom: 4px;
  font-weight: 500;
}

.header-motto {
  font-family: var(--font-header);
  font-size: 22px;
  font-weight: 700;
  line-height: 1.25;
  margin-bottom: 16px;
}

.scripture-box {
  background: rgba(255, 255, 255, 0.08);
  border-left: 3px solid var(--secondary-accent);
  padding: 10px 14px;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-size: 12px;
  line-height: 1.5;
  font-style: italic;
  font-weight: 400;
}

.scripture-ref {
  display: block;
  margin-top: 4px;
  font-weight: 600;
  font-size: 10px;
  text-transform: uppercase;
  color: var(--secondary-accent);
  font-style: normal;
}

.daily-progress-container {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 16px;
}

.progress-text-holder h4 {
  font-size: 14px;
  font-weight: 600;
  color: var(--surface-color);
}

.progress-text-holder p {
  font-size: 11px;
  opacity: 0.7;
}

/* Today Screen Dashed Quick-Add habit button */
.today-add-habit-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--primary-light);
  color: var(--primary-accent);
  border: 1.5px dashed var(--primary-accent);
  padding: 14px;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-family: var(--font-header);
  font-size: 14px;
  font-weight: 600;
  width: 100%;
  margin-bottom: 24px;
  transition: var(--transition-bounce);
}

.today-add-habit-btn:hover {
  background: rgba(74, 107, 93, 0.12);
}

.today-add-habit-btn:active {
  transform: scale(0.98);
}

.today-add-habit-btn span {
  font-size: 16px; /* Emoji scale */
}

/* Sabbat Banner style */
.sabbat-banner {
  background: var(--secondary-light);
  border: 1px dashed var(--secondary-accent);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  margin-bottom: 24px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  color: #927546;
}

.sabbat-banner svg {
  color: var(--secondary-accent);
  flex-shrink: 0;
  margin-top: 2px;
}

.sabbat-banner h4 {
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 3px;
  color: #795d30;
}

.sabbat-banner p {
  font-size: 11px;
  line-height: 1.4;
}

/* TimeOfDay Section headers */
.routine-section {
  margin-bottom: 28px;
}

.routine-title-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.routine-title-bar span {
  font-size: 16px; /* Emoji size */
}

.routine-title {
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
}

/* Habit List Cards styling */
.habits-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.habit-card {
  background: var(--surface-color);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-color);
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 4px 12px var(--shadow-color);
  transition: var(--transition-smooth);
}

.habit-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(45, 49, 66, 0.06);
  border-color: #dbe0e8;
}

.habit-details {
  display: flex;
  align-items: center;
  gap: 16px;
  flex: 1;
}

.habit-icon-emoji {
  font-size: 26px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.habit-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
}

.habit-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--text-secondary);
}

.habit-interval-badge {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  background: var(--border-color);
  color: var(--text-secondary);
  padding: 1px 6px;
  border-radius: 6px;
  letter-spacing: 0.5px;
}

.habit-streak-pill {
  display: flex;
  align-items: center;
  gap: 3px;
  background: var(--secondary-light);
  color: #b09156;
  padding: 1px 6px;
  border-radius: 10px;
  font-weight: 600;
}

.habit-action-box {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* Double click counter styles */
.check-btn-count-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
}

.check-btn-counter-badge {
  font-size: 9px;
  font-weight: 700;
  color: var(--primary-accent);
  background: var(--primary-light);
  padding: 1px 5px;
  border-radius: 6px;
}

/* Beautiful Interactive Custom Habit Checkbox */
.check-btn {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  border: 2px solid var(--border-color);
  background: var(--surface-color);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-bounce);
  color: transparent;
}

.check-btn svg {
  width: 16px;
  height: 16px;
  stroke-width: 3;
}

.check-btn.checked {
  background: var(--primary-accent);
  border-color: var(--primary-accent);
  color: var(--surface-color);
  transform: scale(1.05);
}

/* Special styling for half check state */
.check-btn.half-checked {
  background: var(--primary-light);
  border-color: var(--primary-accent);
  color: var(--primary-accent);
}

/* Habit Card completion states */
.habit-card.completed {
  border-color: var(--primary-light);
  background: rgba(255, 255, 255, 0.6);
}

.habit-card.completed .habit-title {
  text-decoration: line-through;
  color: var(--text-secondary);
}

.habit-card.completed .habit-icon-emoji {
  background: var(--border-color);
  opacity: 0.6;
}

/* Numeric Habit inputs */
.habit-num-input {
  width: 60px;
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 4px 6px;
  text-align: center;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  outline: none;
}

.habit-num-input:focus {
  border-color: var(--primary-accent);
}

.habit-unit-label {
  font-size: 11px;
  color: var(--text-secondary);
  font-weight: 500;
}

/* Floating Action Button (FAB) for custom To-Do addition */
.fab-btn {
  position: absolute;
  right: 20px;
  bottom: 92px; /* Floats above the bottom navigation bar */
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--primary-accent);
  color: var(--surface-color);
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(74, 107, 93, 0.3);
  z-index: 110;
  transition: var(--transition-bounce);
}

.fab-btn svg {
  width: 24px;
  height: 24px;
  transition: transform 0.3s ease;
}

.fab-btn:hover {
  transform: translateY(-4px) rotate(90deg);
}

.fab-btn:active {
  transform: translateY(-2px) scale(0.95);
}

/* Single To-Do Block beneath habits list */
.todo-block-card {
  background: var(--surface-color);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-color);
  padding: 20px;
  margin-top: 24px;
  box-shadow: 0 4px 16px var(--shadow-color);
}

.todo-block-title {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.todo-block-title div {
  display: flex;
  align-items: center;
  gap: 8px;
}

.todo-block-title span {
  font-size: 16px; /* Emoji */
}

/* Inline Add Task Button placed under list on Today screen */
.todo-inline-add-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  padding: 10px;
  margin-top: 12px;
  background: none;
  border: 1.5px dashed var(--border-color);
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition-smooth);
}

.todo-inline-add-btn:hover {
  border-color: var(--primary-accent);
  color: var(--primary-accent);
  background: var(--primary-light);
}

.todo-list-items {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.todo-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-color);
}

.todo-item:last-child {
  border-bottom: none;
}

.todo-check-label {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
}

.todo-checkbox {
  width: 20px;
  height: 20px;
  border-radius: 6px;
  border: 2px solid var(--border-color);
  display: flex;
  align-items: center;
  justify-content: center;
  color: transparent;
  transition: var(--transition-smooth);
}

.todo-checkbox svg {
  width: 12px;
  height: 12px;
  stroke-width: 4;
}

.todo-item.completed .todo-checkbox {
  background: var(--secondary-accent);
  border-color: var(--secondary-accent);
  color: var(--surface-color);
}

.todo-item.completed .todo-text {
  text-decoration: line-through;
  color: var(--text-secondary);
}

.todo-delete-btn {
  background: none;
  border: none;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 4px;
  opacity: 0;
  transition: var(--transition-smooth);
}

.todo-item:hover .todo-delete-btn {
  opacity: 1;
}

.todo-delete-btn:hover {
  color: var(--danger-color);
}

/* Empty illustrations states styles */
.empty-state {
  text-align: center;
  padding: 40px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}

.empty-illustration {
  font-size: 48px;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: var(--primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 10px;
}

.empty-state h3 {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
}

.empty-state p {
  font-size: 13px;
  color: var(--text-secondary);
  max-width: 240px;
  line-height: 1.5;
}

/* ==========================================================================
   Tab 2: Planner & Deep Work
   ========================================================================== */
.planner-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  background: var(--border-color);
  padding: 4px;
  border-radius: var(--radius-sm);
  margin-bottom: 24px;
}

.planner-tab-btn {
  background: none;
  border: none;
  padding: 8px;
  font-family: var(--font-header);
  font-size: 13px;
  font-weight: 600;
  border-radius: 8px;
  cursor: pointer;
  transition: var(--transition-smooth);
  color: var(--text-secondary);
}

.planner-tab-btn.active {
  background: var(--surface-color);
  color: var(--text-primary);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

/* Pomodoro style card */
.focus-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px 0;
}

.timer-circle-wrap {
  position: relative;
  width: 220px;
  height: 220px;
  margin-bottom: 28px;
}

.timer-ring-bg {
  stroke: var(--border-color);
}

.timer-ring-progress {
  stroke: var(--primary-accent);
  transition: stroke-dashoffset 0.1s linear;
}

.timer-text-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}

.timer-time {
  font-family: var(--font-header);
  font-size: 40px;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
  letter-spacing: -1px;
}

.timer-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-secondary);
  font-weight: 600;
  margin-top: 4px;
}

.timer-controls {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 32px;
}

.timer-btn-round {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid var(--border-color);
  background: var(--surface-color);
  color: var(--text-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 12px var(--shadow-color);
  transition: var(--transition-bounce);
}

.timer-btn-round:active {
  transform: scale(0.9);
}

.timer-btn-round.play-pause {
  width: 68px;
  height: 68px;
  background: var(--primary-accent);
  color: var(--surface-color);
  border: none;
  box-shadow: 0 8px 20px rgba(74, 107, 93, 0.25);
}

.timer-btn-round.play-pause svg {
  width: 28px;
  height: 28px;
}

/* Sound and setting pills */
.timer-options {
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 16px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: 0 4px 12px var(--shadow-color);
}

.timer-option-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.timer-option-label {
  font-size: 13px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
}

.timer-option-label span {
  font-size: 14px; /* Emoji */
}

/* Sound selectors */
.sound-toggle-group {
  display: flex;
  background: var(--bg-color);
  border-radius: 12px;
  padding: 2px;
  border: 1px solid var(--border-color);
}

.sound-btn {
  background: none;
  border: none;
  padding: 6px 12px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  border-radius: 10px;
  cursor: pointer;
  color: var(--text-secondary);
  transition: var(--transition-smooth);
}

.sound-btn.active {
  background: var(--surface-color);
  color: var(--primary-accent);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
}

/* Timer adjustments */
.time-adjust-pills {
  display: flex;
  gap: 6px;
}

.time-adjust-btn {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 4px 10px;
  font-family: var(--font-header);
  font-weight: 600;
  font-size: 12px;
  cursor: pointer;
  color: var(--text-primary);
  transition: var(--transition-smooth);
}

.time-adjust-btn:active {
  background: var(--primary-light);
}

/* ==========================================================================
   Tab 3: Insights & Growth Analytics
   ========================================================================== */
.stats-cards-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 24px;
}

.stat-pill-card {
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 4px 12px var(--shadow-color);
  position: relative;
}

.stat-icon-bg {
  position: absolute;
  right: 12px;
  top: 12px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--secondary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px; /* Emoji */
}

.stat-icon-bg.accent {
  background: var(--primary-light);
}

.stat-value {
  font-family: var(--font-header);
  font-size: 26px;
  font-weight: 800;
  color: var(--text-primary);
  margin-top: 6px;
  line-height: 1.1;
}

.stat-label {
  font-size: 11px;
  color: var(--text-secondary);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Custom SVG Heatmap styles */
.analytics-box {
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: 20px;
  margin-bottom: 24px;
  box-shadow: 0 4px 16px var(--shadow-color);
}

.analytics-title-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}

.analytics-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: 8px;
}

.analytics-title span {
  font-size: 16px; /* Emoji */
}

/* Heatmap grid rendering styles */
.heatmap-scroll {
  overflow-x: auto;
  scrollbar-width: none;
}

.heatmap-scroll::-webkit-scrollbar {
  display: none;
}

.heatmap-grid {
  display: grid;
  grid-template-columns: repeat(7, 12px); /* 7 columns or rows, will construct in app.js */
  gap: 4px;
  width: max-content;
}

.heatmap-cell {
  width: 14px;
  height: 14px;
  border-radius: 3px;
  background: #f1f2f5;
  transition: var(--transition-smooth);
  position: relative;
  cursor: pointer;
}

.heatmap-cell.level-0 { background: #f1f2f5; }
.heatmap-cell.level-1 { background: #d0ded8; }
.heatmap-cell.level-2 { background: #a2c0b3; }
.heatmap-cell.level-3 { background: #739d89; }
.heatmap-cell.level-4 { background: #4a6b5d; } /* Primary */
.heatmap-cell.sabbat-day {
  border: 1px dashed var(--secondary-accent);
  background: var(--secondary-light);
}

.heatmap-cell:hover::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--text-primary);
  color: var(--surface-color);
  font-size: 9px;
  padding: 4px 8px;
  border-radius: 4px;
  white-space: nowrap;
  z-index: 100;
}

.heatmap-legend {
  display: flex;
  justify-content: flex-end;
  gap: 4px;
  font-size: 10px;
  color: var(--text-secondary);
  align-items: center;
  margin-top: 10px;
}

.heatmap-legend-box {
  width: 10px;
  height: 10px;
  border-radius: 2px;
}

/* Stewardship Pillar donut styling */
.pillar-layout {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.donut-holder {
  width: 120px;
  height: 120px;
  position: relative;
  flex-shrink: 0;
}

.donut-label-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}

.donut-center-title {
  font-family: var(--font-header);
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
}

.donut-center-sub {
  font-size: 9px;
  color: var(--text-secondary);
  text-transform: uppercase;
  font-weight: 600;
}

.pillar-labels-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}

.pillar-label-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 11px;
}

.pillar-bullet-title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
}

.pillar-bullet-emoji {
  font-size: 12px;
}

.pillar-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.pillar-percent {
  font-weight: 700;
  color: var(--text-secondary);
}

/* ==========================================================================
   INSIGHTS EXPANSION: ROUTINE-HISTORIE (Individual Habit Charts)
   ========================================================================== */
.history-warning-box {
  background: var(--secondary-light);
  border: 1px dashed var(--secondary-accent);
  color: #795d30;
  border-radius: var(--radius-md);
  padding: 12px 16px;
  font-size: 12px;
  line-height: 1.5;
  margin-bottom: 24px;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.history-warning-box span {
  font-size: 16px;
}

.history-cards-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.history-habit-card {
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 18px 16px;
  box-shadow: 0 4px 12px var(--shadow-color);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.history-habit-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.history-habit-info {
  display: flex;
  align-items: center;
  gap: 10px;
}

.history-habit-emoji {
  font-size: 20px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
}

.history-habit-name {
  font-size: 14.5px;
  font-weight: 700;
  color: var(--text-primary);
}

.history-habit-meta {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  background: var(--bg-color);
  padding: 2px 6px;
  border-radius: 4px;
}

.history-habit-rate {
  font-size: 13px;
  font-weight: 700;
  color: var(--primary-accent);
}

/* History SVG chart layout */
.history-chart-wrapper {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  height: 70px;
  padding: 8px 0 2px 0;
  border-bottom: 1.5px solid var(--border-color);
  margin-bottom: 4px;
  gap: 6px;
  overflow-x: auto;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
}

.history-chart-wrapper::-webkit-scrollbar {
  height: 3px;
}
.history-chart-wrapper::-webkit-scrollbar-track {
  background: transparent;
}
.history-chart-wrapper::-webkit-scrollbar-thumb {
  background: var(--border-color);
  border-radius: 2px;
}

.history-chart-column {
  flex-shrink: 0;
  width: 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  height: 100%;
  justify-content: flex-end;
  cursor: pointer;
  position: relative;
}

.history-chart-bar {
  width: 100%;
  max-width: 24px;
  background: var(--border-color);
  border-radius: 4px 4px 0 0;
  transition: height 0.4s cubic-bezier(0.1, 0.8, 0.1, 1), background-color 0.3s ease;
}

.history-chart-bar.filled {
  background: var(--primary-accent);
}

.history-chart-bar.half-filled {
  background: var(--secondary-accent);
}

.history-chart-column:hover .history-chart-bar.filled {
  background: #3c584c;
}

.history-chart-date-label {
  font-size: 9px;
  color: var(--text-secondary);
  font-weight: 600;
  text-transform: uppercase;
}

.history-chart-column:hover::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: 48px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--text-primary);
  color: var(--surface-color);
  font-size: 9px;
  padding: 4px 8px;
  border-radius: 4px;
  white-space: nowrap;
  z-index: 100;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

/* Sabbath settings selector */
.sabbat-setting-card {
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: 20px;
  margin-bottom: 24px;
  box-shadow: 0 4px 16px var(--shadow-color);
}

.sabbat-setting-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.toggle-switch {
  position: relative;
  display: inline-block;
  width: 48px;
  height: 26px;
}

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

.toggle-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--border-color);
  transition: .4s;
  border-radius: 34px;
}

.toggle-slider:before {
  position: absolute;
  content: "";
  height: 18px;
  width: 18px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  transition: .4s;
  border-radius: 50%;
}

input:checked + .toggle-slider {
  background-color: var(--primary-accent);
}

input:checked + .toggle-slider:before {
  transform: translateX(22px);
}

.day-picker-row {
  display: flex;
  gap: 6px;
  width: 100%;
}

.day-picker-btn {
  flex: 1;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  padding: 8px 0;
  font-family: var(--font-header);
  font-size: 11px;
  font-weight: 600;
  border-radius: 8px;
  cursor: pointer;
  transition: var(--transition-smooth);
}

.day-picker-btn.active {
  background: var(--secondary-accent);
  color: var(--surface-color);
  border-color: var(--secondary-accent);
}

/* ==========================================================================
   Tab 4: Habit Library
   ========================================================================== */
.library-section-title {
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin-bottom: 12px;
  letter-spacing: 0.5px;
}

.library-stack-row {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 12px;
  margin-bottom: 24px;
  scrollbar-width: none;
}

.library-stack-row::-webkit-scrollbar {
  display: none;
}

.stack-pack-card {
  width: 160px;
  flex-shrink: 0;
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 16px;
  box-shadow: 0 4px 12px var(--shadow-color);
  cursor: pointer;
  transition: var(--transition-smooth);
}

.stack-pack-card:hover {
  transform: translateY(-4px);
  border-color: var(--primary-accent);
}

.stack-icon-wrap {
  font-size: 24px;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  background: var(--secondary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
}

.stack-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
}

.stack-desc {
  font-size: 10px;
  color: var(--text-secondary);
  line-height: 1.4;
  margin-bottom: 10px;
}

.stack-add-btn {
  width: 100%;
  background: var(--primary-light);
  border: none;
  color: var(--primary-accent);
  font-size: 11px;
  font-weight: 700;
  padding: 6px 0;
  border-radius: 6px;
  cursor: pointer;
  transition: var(--transition-smooth);
}

.stack-pack-card:hover .stack-add-btn {
  background: var(--primary-accent);
  color: var(--surface-color);
}

/* Category Grid Accordion items */
.category-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.category-row-bar {
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  box-shadow: 0 2px 8px var(--shadow-color);
  transition: var(--transition-smooth);
}

.category-row-bar:hover {
  border-color: #ced4de;
}

.category-row-left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.category-row-emoji {
  font-size: 20px;
}

.category-row-name {
  font-size: 14px;
  font-weight: 700;
}

.category-row-count {
  font-size: 10px;
  background: var(--border-color);
  color: var(--text-secondary);
  padding: 2px 8px;
  border-radius: 12px;
  font-weight: 600;
}

.category-chevron {
  color: var(--text-secondary);
  transition: transform 0.3s ease;
}

.category-row-bar.open .category-chevron {
  transform: rotate(180deg);
}

/* Category library items shelf */
.category-library-drawer {
  display: none;
  background: rgba(236, 238, 242, 0.3);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  margin-top: -6px;
  border: 1px solid var(--border-color);
  border-top: none;
  padding: 14px 12px;
  flex-direction: column;
  gap: 8px;
}

.category-row-bar.open + .category-library-drawer {
  display: flex;
}

.library-item-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--surface-color);
  padding: 12px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(236, 238, 242, 0.8);
}

.library-item-details {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.library-item-title {
  font-size: 13px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 6px;
}

.library-item-title-text {
  display: flex;
  align-items: center;
  gap: 8px;
}

.library-item-badge {
  font-size: 9px;
  color: var(--text-secondary);
  font-weight: 500;
  text-transform: uppercase;
}

.library-item-add-btn {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  cursor: pointer;
  transition: var(--transition-smooth);
}

.library-item-add-btn:hover {
  background: var(--primary-accent);
  color: var(--surface-color);
  border-color: var(--primary-accent);
}

.library-item-add-btn.added {
  background: var(--success-color);
  color: var(--surface-color);
  border-color: var(--success-color);
  cursor: default;
}

.library-drawer-custom-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 12px;
  background: var(--primary-light);
  border: 1.5px dashed var(--primary-accent);
  color: var(--primary-accent);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  margin-top: 12px;
  transition: var(--transition-smooth);
}

.library-drawer-custom-btn:hover {
  background: rgba(74, 107, 93, 0.15);
  transform: translateY(-1px);
}

.library-drawer-custom-btn:active {
  transform: translateY(0);
}

/* ==========================================================================
   Tab 5: Discovery & Prayer Wall
   ========================================================================== */
.prayer-widget {
  background: var(--surface-color);
  border: 1.5px dashed var(--primary-accent);
  border-radius: var(--radius-lg);
  padding: 20px;
  margin-bottom: 24px;
  text-align: center;
  cursor: pointer;
  transition: var(--transition-smooth);
  box-shadow: 0 4px 12px var(--shadow-color);
}

.prayer-widget:hover {
  background: var(--primary-light);
  transform: translateY(-2px);
}

.prayer-widget-icon {
  font-size: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 12px auto;
}

.prayer-widget h3 {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 4px;
}

.prayer-widget p {
  font-size: 11px;
  color: var(--text-secondary);
}

/* Prayer feed */
.prayer-card {
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 16px;
  margin-bottom: 12px;
  box-shadow: 0 4px 12px var(--shadow-color);
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: var(--transition-smooth);
}

.prayer-header-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.prayer-tag-pill {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 20px;
  background: var(--secondary-light);
  color: #b09156;
}

.prayer-date {
  font-size: 10px;
  color: var(--text-secondary);
}

.prayer-text {
  font-size: 13.5px;
  color: var(--text-primary);
  line-height: 1.5;
  font-weight: 500;
}

.prayer-footer-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--border-color);
  padding-top: 10px;
}

.pray-count-indicator {
  font-size: 11px;
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  gap: 4px;
}

.pray-count-indicator span {
  font-size: 12px; /* Emoji */
}

.prayer-actions {
  display: flex;
  gap: 8px;
}

.prayer-btn {
  background: var(--primary-light);
  color: var(--primary-accent);
  border: none;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: var(--transition-smooth);
}

.prayer-btn:hover {
  background: var(--primary-accent);
  color: var(--surface-color);
}

.prayer-btn.answered {
  background: var(--secondary-light);
  color: #a78749;
}

.prayer-btn.answered:hover {
  background: var(--secondary-accent);
  color: var(--surface-color);
}

/* Resources library cards */
.resources-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 12px;
}

.resource-card {
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 16px;
  box-shadow: 0 4px 12px var(--shadow-color);
  display: flex;
  gap: 16px;
  cursor: pointer;
  transition: var(--transition-smooth);
}

.resource-card:hover {
  border-color: var(--primary-accent);
  transform: translateY(-2px);
}

.resource-image-fallback {
  font-size: 26px;
  width: 72px;
  height: 72px;
  background: var(--secondary-light);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.resource-info {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.resource-pillar {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--secondary-accent);
  margin-bottom: 2px;
  letter-spacing: 0.5px;
}

.resource-title {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
}

.resource-desc {
  font-size: 11px;
  color: var(--text-secondary);
  line-height: 1.4;
}

/* Smart recommendations styling */
.smart-rec-banner {
  background: #f0f5f2;
  border-left: 4px solid var(--primary-accent);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: 16px;
  margin-bottom: 24px;
  display: flex;
  gap: 14px;
}

.smart-rec-icon {
  font-size: 18px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--surface-color);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.04);
}

.smart-rec-info h4 {
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 3px;
  color: var(--primary-accent);
}

.smart-rec-info p {
  font-size: 11px;
  line-height: 1.4;
  color: var(--text-primary);
}

.smart-rec-link {
  display: inline-block;
  margin-top: 6px;
  font-size: 10px;
  font-weight: 700;
  color: var(--secondary-accent);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-decoration: none;
}

/* ==========================================================================
   Modals (BottomSheet style like iOS)
   ========================================================================== */
.modal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(45, 49, 66, 0.4);
  backdrop-filter: blur(4px);
  z-index: 200;
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.modal-overlay.active {
  display: block;
  opacity: 1;
}

.modal-sheet {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  max-height: 80%;
  background: var(--surface-color);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  z-index: 210;
  transform: translateY(100%);
  transition: transform 0.4s cubic-bezier(0.1, 0.7, 0.1, 1);
  padding: 28px 24px 36px 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  overflow-y: auto;
}

.modal-overlay.active .modal-sheet {
  transform: translateY(0);
}

/* Modal header handle */
.modal-handle {
  width: 40px;
  height: 4px;
  background: var(--border-color);
  border-radius: 2px;
  margin: -14px auto 10px auto;
  flex-shrink: 0;
}

.modal-title-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.modal-close-btn {
  background: var(--bg-color);
  border: none;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}

.form-group label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text-secondary);
}

.form-input {
  width: 100%;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 14px;
  outline: none;
  background: var(--bg-color);
  transition: var(--transition-smooth);
}

.form-input:focus {
  border-color: var(--primary-accent);
  background: var(--surface-color);
}

.form-select {
  width: 100%;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 14px;
  outline: none;
  background: var(--bg-color) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%238E93A6'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E") no-repeat right 16px center;
  background-size: 16px;
  appearance: none;
  transition: var(--transition-smooth);
}

.form-select:focus {
  border-color: var(--primary-accent);
  background-color: var(--surface-color);
}

/* Modal flex buttons */
.modal-btn-row {
  display: flex;
  gap: 12px;
  margin-top: 12px;
}

/* Language selection flag styles in Header */
.header-lang-selector {
  display: flex;
  gap: 8px;
  background: rgba(255, 255, 255, 0.1);
  padding: 4px;
  border-radius: 20px;
  position: absolute;
  top: 24px;
  right: 24px;
}

.lang-btn {
  background: none;
  border: none;
  font-size: 12px;
  cursor: pointer;
  opacity: 0.5;
  filter: grayscale(100%);
  transition: var(--transition-smooth);
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lang-btn.active {
  opacity: 1;
  filter: grayscale(0%);
  background: rgba(255, 255, 255, 0.2);
}

/* ==========================================================================
   Animations & Particles
   ========================================================================== */
#celebration-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1000;
}

@keyframes bounce {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.15); }
}

.check-bounce {
  animation: bounce 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.info-tooltip-trigger {
  font-size: 8px;
  cursor: pointer;
  color: var(--text-secondary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin-left: 4px;
  background: var(--border-color);
  width: 13px;
  height: 13px;
  border-radius: 50%;
  font-weight: 700;
}

.info-tooltip-trigger:hover::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--text-primary);
  color: var(--surface-color);
  font-size: 10px;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  white-space: normal;
  width: 180px;
  text-align: center;
  z-index: 1000;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  font-weight: 500;
  text-transform: none;
  line-height: 1.4;
}

/* ==========================================================================
   PWA Installation Overlay & App Store Aesthetics (Round 8)
   ========================================================================== */
#pwa-install-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: 100000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  box-sizing: border-box;
}

.pwa-install-card {
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  border-radius: 28px;
  width: 100%;
  max-width: 380px;
  padding: 24px;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.22);
  position: relative;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  animation: pwaSlideUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  transition: opacity 0.3s ease;
}

@keyframes pwaSlideUp {
  from {
    opacity: 0;
    transform: translateY(40px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.pwa-install-close-row {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 8px;
}

.pwa-install-close-btn {
  background: var(--secondary-light);
  border: none;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-smooth);
}

.pwa-install-close-btn:hover {
  background: rgba(0, 0, 0, 0.08);
  color: var(--text-primary);
}

.pwa-store-header {
  display: flex;
  gap: 16px;
  margin-bottom: 20px;
  align-items: center;
}

.pwa-store-logo {
  width: 72px;
  height: 72px;
  background: var(--secondary-light);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
  flex-shrink: 0;
  overflow: hidden;
}

.pwa-store-logo img {
  width: 46px;
  height: 46px;
  object-fit: contain;
}

.pwa-store-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.pwa-store-info h3 {
  font-size: 18px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
  font-family: var(--font-header);
}

.pwa-store-info .pwa-store-subtitle {
  font-size: 12px;
  color: var(--text-secondary);
  font-weight: 600;
  margin: 0;
}

.pwa-store-rating {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
}

.pwa-store-rating span:first-child {
  color: #D4B886;
  font-size: 12px;
  letter-spacing: 1px;
}

.pwa-store-rating-label {
  font-size: 9px;
  font-weight: 800;
  color: #795d30;
  background: #f7eedb;
  padding: 2px 6px;
  border-radius: 4px;
  text-transform: uppercase;
}

.pwa-store-gallery {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.pwa-store-pill {
  font-size: 11px;
  font-weight: 700;
  color: var(--primary-accent);
  background: var(--secondary-light);
  padding: 6px 12px;
  border-radius: 12px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.02);
}

.pwa-store-body {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 24px;
}

.pwa-store-install-btn {
  background: var(--primary-accent);
  color: #FAFAFA;
  border: none;
  border-radius: 16px;
  padding: 14px 20px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(74, 107, 93, 0.3);
  transition: var(--transition-smooth);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.pwa-store-install-btn:hover {
  background: #3c564a;
  transform: translateY(-1px);
}

.pwa-store-dont-show-row {
  display: flex;
  justify-content: center;
  margin-top: 18px;
  border-top: 1px dashed var(--border-color);
  padding-top: 12px;
}

.pwa-dont-show-checkbox-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text-secondary);
  cursor: pointer;
  user-select: none;
  font-weight: 500;
}

.pwa-dont-show-checkbox-label input {
  cursor: pointer;
  accent-color: var(--primary-accent);
  width: 15px;
  height: 15px;
}

/* Coachmark Arrows */
.pwa-coachmark-arrow {
  position: absolute;
  z-index: 100001;
  display: flex;
  justify-content: center;
  width: 100%;
  pointer-events: none;
  box-sizing: border-box;
  padding: 0 24px;
}

#pwa-coachmark-ios {
  bottom: 24px;
  left: 0;
  animation: iosBounce 1.5s infinite ease-in-out;
}

@keyframes iosBounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-15px); }
}

#pwa-coachmark-android {
  top: 36px;
  left: 0;
  animation: androidBounce 1.5s infinite ease-in-out;
}

@keyframes androidBounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(15px); }
}

.coachmark-content {
  background: var(--primary-accent);
  color: #FAFAFA;
  border-radius: 18px;
  padding: 14px 20px;
  max-width: 320px;
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.35);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  text-align: center;
  position: relative;
  pointer-events: auto;
}

.coachmark-text {
  font-size: 12px;
  font-weight: 600;
  line-height: 1.5;
}

.coachmark-arrow-down {
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid var(--primary-accent);
  margin-top: 4px;
}

.coachmark-arrow-up {
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 10px solid var(--primary-accent);
  margin-bottom: 4px;
}

/* Persistent Today screen header installer badge */
.pwa-header-install-badge {
  background: transparent;
  border: 1px solid #D4B886;
  color: #D4B886;
  font-size: 11px;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
  margin-right: 8px;
  transition: var(--transition-smooth);
  animation: pwaPulse 2.5s infinite ease-in-out;
  box-shadow: 0 0 8px rgba(212, 184, 134, 0.15);
}

.pwa-header-install-badge:hover {
  background: #f7eedb;
  color: #795d30;
}

@keyframes pwaPulse {
  0%, 100% { 
    box-shadow: 0 0 8px rgba(212, 184, 134, 0.15); 
    border-color: #D4B886;
  }
  50% { 
    box-shadow: 0 0 16px rgba(212, 184, 134, 0.45); 
    border-color: var(--secondary-accent);
  }
}

/* Browser fallback text link */
.pwa-store-browser-link-row {
  display: flex;
  justify-content: center;
  margin-top: 8px;
}

.pwa-browser-link-btn {
  background: none;
  border: none;
  font-size: 11px;
  color: var(--text-secondary);
  text-decoration: underline;
  cursor: pointer;
  font-weight: 500;
  transition: var(--transition-smooth);
}

.pwa-browser-link-btn:hover {
  color: var(--text-primary);
}

/* ==========================================================================
   Legal Footer & Consent Banner Styling (Round 10)
   ========================================================================== */
.app-legal-footer {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-top: 32px;
  margin-bottom: 8px;
}

.app-legal-link-btn {
  background: none;
  border: none;
  font-size: 11px;
  color: var(--text-secondary);
  text-decoration: underline;
  cursor: pointer;
  font-weight: 500;
  font-family: var(--font-body);
  transition: var(--transition-smooth);
}

.app-legal-link-btn:hover {
  color: var(--text-primary);
}

/* Privacy & Consent Banner styling */
#analytics-consent-banner {
  position: absolute;
  bottom: 88px; /* Slightly above the bottom navigation bar */
  left: 0;
  width: 100%;
  padding: 0 16px;
  z-index: 100000;
  animation: slideUpConsent 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

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

.consent-card {
  background: var(--surface-color);
  border-radius: var(--radius-md);
  padding: 16px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
  border: 1px solid var(--border-color);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.consent-icon {
  font-size: 20px;
  background: var(--primary-light);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  flex-shrink: 0;
}

.consent-info h4 {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.consent-info p {
  font-size: 11px;
  line-height: 1.4;
  color: var(--text-secondary);
}

.consent-buttons {
  display: flex;
  gap: 8px;
  margin-top: 4px;
}

.consent-buttons button {
  cursor: pointer;
  font-family: var(--font-body);
  font-weight: 600;
  transition: var(--transition-smooth);
}

.consent-buttons button:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

/* Success PWA Installed Toast styling */
#pwa-installed-toast {
  position: absolute;
  bottom: 88px;
  left: 0;
  width: 100%;
  padding: 0 16px;
  z-index: 100000;
  animation: slideUpConsent 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.toast-card {
  background: var(--surface-color);
  border-radius: var(--radius-md);
  padding: 16px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
  border: 1px solid var(--border-color);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.toast-info {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.toast-icon {
  font-size: 20px;
  background: var(--secondary-light);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  flex-shrink: 0;
}

.toast-info h4 {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.toast-info p {
  font-size: 11px;
  line-height: 1.4;
  color: var(--text-secondary);
  text-align: left;
}

.toast-close-btn {
  background: var(--primary-accent);
  color: #FAFAFA;
  border: none;
  padding: 8px 16px;
  font-size: 11px;
  font-weight: 700;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: var(--transition-smooth);
}

.toast-close-btn:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

/* History detailed analytics zoom button */
.history-detail-btn {
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: 14px;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 8px;
  transition: var(--transition-smooth);
  display: flex;
  align-items: center;
  justify-content: center;
}

.history-detail-btn:hover {
  background: var(--primary-light);
  color: var(--primary-accent);
  transform: scale(1.1);
}

