/* DayCarp CSS Bundle - Generated 2026-02-23T16:57:53Z */
/* Do not edit directly — edit source files and re-run build-css.sh */

/* === base/variables.css === */
/* ITCSS Layer: Base (Variables) */
/* CSS Variables - DayCarp Design System */
/* Intent: Quiet, dark, notebook-like. Color only when it means something. */
:root {
  /* Brand Colors — DayCarp identity */
  --sun-orange: #FF8A65;
  --sun-orange-light: #FFB74D;
  --sun-orange-dark: #FF7043;
  --dark-blue: #1A237E;
  --dark-blue-light: #3949AB;
  --light-blue: #42A5F5;
  --light-blue-light: #64B5F6;
  --light-blue-shadow: #1E88E5;
  
  /* Surface Hierarchy — whisper-quiet elevation shifts */
  --primary-bg: #0f1419;
  --secondary-bg: #151a23;
  --tertiary-bg: #1c2231;
  --tertiary-bg-rgb: 28, 34, 49;
  --quaternary-bg: #242d3d;
  --primary-text: #e8ecf1;
  --secondary-text: #9ca8b8;
  --muted-text: #6b7a8d;
  
  /* Accent — single accent, used with intention */
  --accent-color: #4da8da;
  --accent-hover: #3d8ab8;
  --accent-warm: var(--sun-orange);
  --accent-warm-light: var(--sun-orange-light);
  --accent-professional: var(--dark-blue);
  --accent-professional-light: var(--dark-blue-light);
  
  /* Gradients — used sparingly, only for brand moments */
  --gradient-primary: linear-gradient(135deg, var(--accent-color) 0%, var(--accent-hover) 100%);
  --gradient-warm: linear-gradient(135deg, var(--sun-orange) 0%, var(--sun-orange-dark) 100%);
  --gradient-professional: linear-gradient(135deg, var(--dark-blue) 0%, var(--dark-blue-light) 100%);
  --gradient-subtle: linear-gradient(135deg, var(--secondary-bg) 0%, var(--tertiary-bg) 100%);
  --gradient-glass: linear-gradient(135deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.02) 100%);
  
  /* Semantic Colors — slightly desaturated for dark mode */
  --success-color: #4aba7a;
  --success-light: #68D391;
  --warning-color: #e0944a;
  --warning-light: #F6AD55;
  --error-color: #e06060;
  --error-light: #FC8181;
  --info-color: var(--accent-color);
  
  /* Semantic backgrounds for save states */
  --success-bg: rgba(74, 186, 122, 0.12);
  --success-text: var(--success-color);
  --success-border: rgba(74, 186, 122, 0.25);
  
  --warning-bg: rgba(224, 148, 74, 0.12);
  --warning-text: var(--warning-color);
  --warning-border: rgba(224, 148, 74, 0.25);
  
  --error-bg: rgba(224, 96, 96, 0.12);
  --error-text: var(--error-color);
  --error-border: rgba(224, 96, 96, 0.25);
  
  /* Borders — rgba for quiet structure, not harsh lines */
  --border-color: rgba(255, 255, 255, 0.08);
  --border-light: rgba(255, 255, 255, 0.05);
  
  /* Shadows — subtle on dark, lean on borders for definition */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.2);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.25);
  --shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.35);
  --shadow-xl: 0 12px 32px rgba(0, 0, 0, 0.4);
  --shadow-2xl: 0 20px 40px rgba(0, 0, 0, 0.45);
  --shadow-inner: inset 0 1px 3px rgba(0, 0, 0, 0.3);
  --shadow-colored: 0 4px 12px rgba(77, 168, 218, 0.15);
  --shadow-warm: 0 4px 12px rgba(255, 138, 101, 0.15);
  
  /* Surface effects — minimal glass, prefer solid surfaces */
  --glass-bg: rgba(255, 255, 255, 0.04);
  --glass-bg-light: rgba(255, 255, 255, 0.06);
  --glass-border: rgba(255, 255, 255, 0.08);
  --glass-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
  --backdrop-blur: blur(8px);
  
  /* Lato Typography System */
  --font-family: 'Lato', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-family-display: 'Lato', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-family-mono: 'JetBrains Mono', 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
  
  /* Premium Font Scale */
  --font-size-xs: 0.75rem;     /* 12px */
  --font-size-sm: 0.875rem;    /* 14px */
  --font-size-base: 1rem;      /* 16px */
  --font-size-lg: 1.125rem;    /* 18px */
  --font-size-xl: 1.25rem;     /* 20px */
  --font-size-2xl: 1.5rem;     /* 24px */
  --font-size-3xl: 1.875rem;   /* 30px */
  --font-size-4xl: 2.25rem;    /* 36px */
  --font-size-5xl: 3rem;       /* 48px */
  
  /* Enhanced Font Weights */
  --font-weight-thin: 100;
  --font-weight-extralight: 200;
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;
  --font-weight-black: 900;
  
  /* Refined Line Heights */
  --line-height-none: 1;
  --line-height-tight: 1.25;
  --line-height-snug: 1.375;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose: 2;
  
  /* Letter Spacing */
  --letter-spacing-tighter: -0.05em;
  --letter-spacing-tight: -0.025em;
  --letter-spacing-normal: 0;
  --letter-spacing-wide: 0.025em;
  --letter-spacing-wider: 0.05em;
  --letter-spacing-widest: 0.1em;
  
  /* Spacing Scale - Consistent 8px base */
  --space-1: 0.25rem;  /* 4px */
  --space-2: 0.5rem;   /* 8px */
  --space-3: 0.75rem;  /* 12px */
  --space-4: 1rem;     /* 16px */
  --space-5: 1.25rem;  /* 20px */
  --space-6: 1.5rem;   /* 24px */
  --space-8: 2rem;     /* 32px */
  --space-10: 2.5rem;  /* 40px */
  --space-12: 3rem;    /* 48px */
  
  /* Legacy spacing (for gradual migration) */
  --spacing-xs: var(--space-1);
  --spacing-sm: var(--space-2);
  --spacing-md: var(--space-4);
  --spacing-lg: var(--space-6);
  --spacing-xl: var(--space-8);
  
  /* Border Radius */
  --radius-sm: 0.25rem;   /* 4px */
  --radius-md: 0.375rem;  /* 6px */
  --radius-lg: 0.5rem;    /* 8px */
  --radius-xl: 0.75rem;   /* 12px */
  --radius-full: 9999px;
  
  /* Component Sizes */
  --btn-height-sm: 32px;
  --btn-height-md: 40px;
  --btn-height-lg: 44px;
  
  /* Layout Dimensions */
  --header-height: 56px;
  --sidebar-width: 240px;
  --minimap-width: 120px;
  --note-max-width: 800px;
  
  /* Indentation System */
  --indent-base: 29px;
  --indent-mobile: 22px;
  --indent-small: 12px;
  
  /* Premium Animation & Transitions */
  --transition-fast: 0.15s ease;
  --transition-base: 0.2s ease;
  --transition-slow: 0.3s ease;
  --transition-slower: 0.5s ease;
  
  /* Premium Easing Functions */
  --ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
  --ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  --ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
  --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
  --ease-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
  --ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);
  --ease-spring: cubic-bezier(0.175, 0.885, 0.32, 1.275);
  --ease-smooth: cubic-bezier(0.4, 0, 0.2, 1);
  
  /* Specialized Transitions */
  --transition-colors: color 0.2s var(--ease-smooth), background-color 0.2s var(--ease-smooth), border-color 0.2s var(--ease-smooth);
  --transition-transform: transform 0.2s var(--ease-out-cubic);
  --transition-shadow: box-shadow 0.2s var(--ease-smooth);
  --transition-all-smooth: all 0.15s var(--ease-smooth);
  --transition-bounce: all 0.2s var(--ease-out-cubic);
  --transition-spring: all 0.25s var(--ease-out-cubic);
  
  /* Animation Durations */
  --duration-75: 75ms;
  --duration-100: 100ms;
  --duration-150: 150ms;
  --duration-200: 200ms;
  --duration-300: 300ms;
  --duration-500: 500ms;
  --duration-700: 700ms;
  --duration-1000: 1000ms;
  
  /* Z-Index Scale */
  --z-dropdown: 1000;
  --z-sticky: 1020;
  --z-fixed: 1030;
  --z-modal-backdrop: 1040;
  --z-modal: 1050;
  --z-popover: 1060;
  --z-tooltip: 1070;
  --z-toast: 1080;
  
  /* Breakpoints (for JS usage) */
  --breakpoint-sm: 480px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 1024px;
  --breakpoint-xl: 1280px;
}

/* Dark Mode Variables — app is dark-first, this ensures OS dark mode matches */
@media (prefers-color-scheme: dark) {
  :root {
    /* Already dark-first — no overrides needed, values match :root */
  }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  :root {
    --border-color: rgba(255, 255, 255, 0.25);
    --shadow: 0 0 0 1px rgba(255, 255, 255, 0.2);
    --shadow-lg: 0 0 0 2px rgba(255, 255, 255, 0.2);
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  :root {
    --transition-fast: 0.01ms;
    --transition-base: 0.01ms;
    --transition-slow: 0.01ms;
    --transition-bounce: 0.01ms;
  }
}
/* === base/reset.css === */
/* ITCSS Layer: Base (Reset) */
/* NOTE: Only set minimal body defaults here. All base font, color, and line-height should be set in typography.css for clarity. */
/* Modern CSS Reset */

/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin and padding */
* {
  margin: 0;
  padding: 0;
}

/* Remove list styles on ul, ol elements with a list role */
ul[role='list'],
ol[role='list'] {
  list-style: none;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: var(--line-height-normal);
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  color: var(--primary-text);
  background-color: var(--primary-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture {
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
   scroll-behavior: auto;
  }
  
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Focus styles for accessibility */
:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* Remove focus styles for mouse users */
:focus:not(:focus-visible) {
  outline: none;
}

/* Improve text rendering */
h1, h2, h3, h4, h5, h6 {
  text-rendering: optimizeLegibility;
}

/* Better button defaults */
button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

/* Better form defaults */
input, textarea, select {
  border: none;
  background: none;
  outline: none;
}

/* Remove default appearance for form elements */
input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
  -webkit-appearance: none;
}

/* Remove spinner from number inputs */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type="number"] {
  -moz-appearance: textfield;
}

/* Better table defaults */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* Remove default fieldset styles */
fieldset {
  border: none;
  padding: 0;
  margin: 0;
}

/* Better legend styles */
legend {
  padding: 0;
}
/* === base/typography.css === */
/* ITCSS Layer: Base (Typography) */
/* NOTE: This file is the canonical source for base font, color, and line-height for the body and headings. */
/* Premium Typography System */

/* Base Typography - Lato for body text */
body {
  font-family: var(--font-family);
  font-weight: 400;
  line-height: var(--line-height-normal);
  color: var(--primary-text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Display Typography - Playfair Display for branding and headings */
h1, h2, h3, h4, h5, h6,
.display-text,
.brand-text,
.logo-text {
  font-family: var(--font-family-display);
  font-weight: 600;
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--primary-text);
  margin: 0;
}

/* Heading Hierarchy */
h1, .h1 {
  font-size: var(--font-size-3xl);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-tighter);
}

h2, .h2 {
  font-size: var(--font-size-2xl);
  font-weight: 600;
}

h3, .h3 {
  font-size: var(--font-size-xl);
  font-weight: 600;
}

h4, .h4 {
  font-size: var(--font-size-lg);
  font-weight: 500;
}

h5, .h5 {
  font-size: var(--font-size-base);
  font-weight: 500;
}

h6, .h6 {
  font-size: var(--font-size-sm);
  font-weight: 500;
}

/* Body Text Variations - Lato */
.text-large {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
}

.text-base {
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
}

.text-small {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-normal);
}

.text-xs {
  font-size: var(--font-size-xs);
  line-height: var(--line-height-normal);
}

/* Font Weight Utilities */
.font-thin { font-weight: var(--font-weight-thin); }
.font-extralight { font-weight: var(--font-weight-extralight); }
.font-light { font-weight: var(--font-weight-light); }
.font-normal { font-weight: var(--font-weight-normal); }
.font-medium { font-weight: var(--font-weight-medium); }
.font-semibold { font-weight: var(--font-weight-semibold); }
.font-bold { font-weight: var(--font-weight-bold); }
.font-extrabold { font-weight: var(--font-weight-extrabold); }
.font-black { font-weight: var(--font-weight-black); }

/* Text Color Utilities */
.text-primary { color: var(--primary-text); }
.text-secondary { color: var(--secondary-text); }
.text-muted { color: var(--muted-text); }
.text-accent { color: var(--accent-color); }
.text-warm { color: var(--accent-warm); }
.text-professional { color: var(--accent-professional); }

/* Special Typography Effects */
.text-gradient {
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.text-gradient-warm {
  background: var(--gradient-warm);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.text-gradient-professional {
  background: var(--gradient-professional);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Letter Spacing Utilities */
.tracking-tighter { letter-spacing: var(--letter-spacing-tighter); }
.tracking-tight { letter-spacing: var(--letter-spacing-tight); }
.tracking-normal { letter-spacing: var(--letter-spacing-normal); }
.tracking-wide { letter-spacing: var(--letter-spacing-wide); }
.tracking-wider { letter-spacing: var(--letter-spacing-wider); }
.tracking-widest { letter-spacing: var(--letter-spacing-widest); }

/* Line Height Utilities */
.leading-none { line-height: var(--line-height-none); }
.leading-tight { line-height: var(--line-height-tight); }
.leading-snug { line-height: var(--line-height-snug); }
.leading-normal { line-height: var(--line-height-normal); }
.leading-relaxed { line-height: var(--line-height-relaxed); }
.leading-loose { line-height: var(--line-height-loose); }

/* Monospace Text */
.font-mono {
  font-family: var(--font-family-mono);
}

/* Text Alignment */
.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-justify { text-align: justify; }

/* Text Transform */
.uppercase { text-transform: uppercase; }
.lowercase { text-transform: lowercase; }
.capitalize { text-transform: capitalize; }
.normal-case { text-transform: none; }

/* Text Decoration */
.underline { text-decoration: underline; }
.line-through { text-decoration: line-through; }
.no-underline { text-decoration: none; }

/* Text Overflow */
.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.text-ellipsis {
  text-overflow: ellipsis;
}

.text-clip {
  text-overflow: clip;
}

/* Responsive Typography */
@media (max-width: 768px) {
  h1, .h1 {
    font-size: var(--font-size-2xl);
  }
  
  h2, .h2 {
    font-size: var(--font-size-xl);
  }
  
  h3, .h3 {
    font-size: var(--font-size-lg);
  }
  
  .text-large {
    font-size: var(--font-size-base);
  }
}

@media (max-width: 480px) {
  h1, .h1 {
    font-size: var(--font-size-xl);
  }
  
  h2, .h2 {
    font-size: var(--font-size-lg);
  }
}

/* Print Styles */
@media print {
  body {
    font-family: Georgia, 'Times New Roman', serif;
    color: #000;
  }
  
  h1, h2, h3, h4, h5, h6 {
    font-family: Georgia, 'Times New Roman', serif;
    color: #000;
  }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .text-gradient,
  .text-gradient-warm,
  .text-gradient-professional {
    -webkit-text-fill-color: var(--primary-text);
    background: none;
  }
}
/* === layout/containers.css === */
/* Layout Containers */

/* Main App Container */
.app-container {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  position: relative;
  z-index: 1; /* Lower than login screen z-index */
}

/* Main Content Area */
.main-content {
  flex: 1;
  padding: var(--spacing-md) 0;
  background: var(--primary-bg);
  position: relative;
  overflow: visible;
  min-height: calc(100vh - var(--header-height));
}

/* Note Container — same bg as main, no card shadow. Content IS the page. */
.note-container {
  max-width: var(--note-max-width);
  margin: 0 auto;
  background: var(--primary-bg);
  overflow: visible;
  position: relative;
  min-height: calc(100vh - 100px);
  display: flex;
  flex-direction: column;
}

/* Note Editor */
.note-editor {
  padding: var(--spacing-lg) var(--spacing-xl) var(--spacing-lg) var(--spacing-xl);
  min-height: calc(100vh - 140px);
  overflow-y: auto;
  position: relative;
  flex: 1;
}

/* Page Container (for tasks, settings, etc.) */
.page-container {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - 120px);
  background: var(--primary-bg);
}

.page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-lg);
  border-bottom: 1px solid var(--border-color);
  background: var(--secondary-bg);
}

.page-title h2 {
  margin: 0;
  color: var(--primary-text);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-semibold);
}

.page-subtitle {
  margin: var(--spacing-xs) 0 0 0;
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
}

.page-content {
  flex: 1;
  padding: var(--spacing-lg);
  overflow-y: auto;
}

/* Back Button */
.back-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--primary-bg);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
  text-decoration: none;
}

.back-btn:hover {
  border-color: var(--accent-color);
  color: var(--accent-color);
  background: var(--tertiary-bg);
}

/* Content Sections */
.content-section {
  margin-bottom: var(--spacing-xl);
}

.section-header {
  margin-bottom: var(--spacing-lg);
  padding-bottom: var(--spacing-md);
  border-bottom: 1px solid var(--border-color);
}

.section-header h3 {
  margin: 0 0 var(--spacing-xs) 0;
  color: var(--primary-text);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
}

.section-header p {
  margin: 0;
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
}

/* No Content State */
.no-content {
  text-align: center;
  padding: var(--spacing-xl) var(--spacing-lg);
  color: var(--secondary-text);
  max-width: 400px;
  margin: var(--spacing-xl) auto;
}

.no-content-icon {
  margin-bottom: var(--spacing-lg);
  opacity: 0.5;
}

.no-content h3 {
  margin-bottom: var(--spacing-md);
  color: var(--primary-text);
  font-size: var(--font-size-xl);
}

.no-content p {
  margin-bottom: var(--spacing-sm);
  line-height: var(--line-height-relaxed);
}

/* Responsive Adjustments */
@media (max-width: 768px) {
  .main-content {
    padding: var(--spacing-md);
    margin-right: 0; /* Remove minimap margin on mobile */
  }
  
  .page-header {
    flex-direction: column;
    gap: var(--spacing-md);
    align-items: stretch;
  }
  
  .page-content {
    padding: var(--spacing-md);
  }
}

@media (max-width: 480px) {
  .main-content {
    padding: var(--spacing-sm);
  }
  
  .page-header {
    padding: var(--spacing-md);
  }
  
  .page-content {
    padding: var(--spacing-sm);
  }
}

/* Minimap Layout Adjustment - Simplified for tablet range */
@media (min-width: 769px) and (max-width: 1200px) {
  .main-content {
    margin-right: calc(var(--minimap-width) + 20px);
  }
}
/* === layout/header.css === */
/* ITCSS Layer: Layout */
/* Premium Header Layout */

.app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-sm) var(--spacing-lg);
  background: var(--secondary-bg);
  border-bottom: 1px solid var(--border-color);
  height: var(--header-height);
  position: relative;
  z-index: var(--z-sticky);
  transition: var(--transition-all-smooth);
}

/* Removed gradient top-line — unnecessary decoration for a daily tool */

/* Header Left Section */
.header-left {
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
}

/* App Logo — clean, no decorative effects */
.app-logo {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  cursor: pointer;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-md);
  transition: var(--transition-all-smooth);
  text-decoration: none;
}

.app-logo:hover {
  background: rgba(255, 255, 255, 0.04);
}

.header-logo {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.header-left h1 {
  font-family: var(--font-family);
  font-size: var(--font-size-lg);
  font-weight: 700;
  color: var(--accent-color);
  margin: 0;
  letter-spacing: var(--letter-spacing-tight);
  font-style: normal;
}

/* Header Right Section */
.header-right {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}
/* pulse and fadeInOut keyframes defined in utilities.css — not duplicated here */

/* Save Notifications */
.save-notification {
  position: fixed;
  top: 20px;
  right: 20px;
  padding: 8px 16px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 500;
  z-index: 10000;
  animation: fadeInOut 2s ease-in-out;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.save-notification-saved {
  background: var(--success-bg);
  color: var(--success-text);
  border: 1px solid var(--success-border);
}

.save-notification-saving {
  background: var(--warning-bg);
  color: var(--warning-text);
  border: 1px solid var(--warning-border);
}

/* Conflict Resolution Dialog */
.conflict-dialog-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 20000;
  padding: var(--spacing-md);
}

.conflict-dialog {
  background: var(--secondary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  max-width: 400px;
  width: 90%;
  box-shadow: var(--glass-shadow);
  max-height: 90vh;
  overflow-y: auto;
}

.conflict-dialog h3 {
  margin: 0 0 var(--spacing-md) 0;
  color: var(--primary-text);
  font-size: var(--font-size-lg);
}

.conflict-dialog p {
  margin: 0 0 var(--spacing-lg) 0;
  color: var(--secondary-text);
  line-height: 1.5;
}

.conflict-options {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.conflict-options button {
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--tertiary-bg);
  color: var(--primary-text);
  cursor: pointer;
  transition: var(--transition-all-smooth);
}

.conflict-options button:hover {
  background: var(--primary-bg);
  border-color: var(--accent-color);
}

/* Mobile-specific conflict dialog */
@media (max-width: 768px) {
  .conflict-dialog-overlay {
    align-items: flex-start;
    padding-top: 20px;
  }
  
  .conflict-dialog {
    width: calc(100vw - 40px);
    max-width: none;
    padding: var(--spacing-md);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  }
  
  .conflict-dialog h3 {
    font-size: var(--font-size-base);
  }
  
  .conflict-dialog p {
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-md);
  }
  
  .conflict-options {
    gap: var(--spacing-xs);
  }
  
  .conflict-options button {
    padding: var(--spacing-md);
    font-size: var(--font-size-base);
    min-height: 44px;
  }
}

/* Merge Comparison Dialog */
.merge-comparison-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 20000;
  padding: var(--spacing-md);
}

.merge-comparison-dialog {
  background: var(--secondary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  max-width: 90vw;
  max-height: 90vh;
  width: 1000px;
  box-shadow: var(--glass-shadow);
  display: flex;
  flex-direction: column;
}

.merge-comparison-dialog h3 {
  margin: 0 0 var(--spacing-md) 0;
  color: var(--primary-text);
  font-size: var(--font-size-lg);
  text-align: center;
}

.merge-comparison-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
  flex: 1;
  min-height: 0;
  margin-bottom: var(--spacing-lg);
}

.merge-column {
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.merge-column h4 {
  margin: 0 0 var(--spacing-sm) 0;
  color: var(--primary-text);
  font-size: var(--font-size-md);
  padding: var(--spacing-sm);
  background: var(--tertiary-bg);
  border-radius: var(--radius-md);
  text-align: center;
}

.merge-content {
  flex: 1;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  background: var(--primary-bg);
  overflow-y: auto;
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  line-height: 1.4;
}

.local-content {
  border-left: 3px solid var(--accent-color);
}

.server-content {
  border-left: 3px solid var(--warning-color);
}

.bullet-preview {
  margin-bottom: var(--spacing-xs);
  padding: var(--spacing-xs);
  border-radius: var(--radius-sm);
  background: var(--secondary-bg);
  word-wrap: break-word;
}

.bullet-preview[data-level="1"] {
  margin-left: var(--spacing-md);
}

.bullet-preview[data-level="2"] {
  margin-left: calc(var(--spacing-md) * 2);
}

.bullet-preview[data-level="3"] {
  margin-left: calc(var(--spacing-md) * 3);
}

.bullet-preview[data-level="4"] {
  margin-left: calc(var(--spacing-md) * 4);
}

.bullet-preview[data-level="5"] {
  margin-left: calc(var(--spacing-md) * 5);
}

.bullet-preview[data-level="6"] {
  margin-left: calc(var(--spacing-md) * 6);
}

.bullet-preview[data-level="7"] {
  margin-left: calc(var(--spacing-md) * 7);
}

.empty-content {
  color: var(--secondary-text);
  font-style: italic;
  text-align: center;
  padding: var(--spacing-lg);
}

.merge-actions {
  border-top: 1px solid var(--border-color);
  padding-top: var(--spacing-md);
}

.merge-actions p {
  margin: 0 0 var(--spacing-md) 0;
  color: var(--secondary-text);
  line-height: 1.5;
  text-align: center;
}

.merge-buttons {
  display: flex;
  gap: var(--spacing-md);
  justify-content: center;
  flex-wrap: wrap;
}

.merge-btn {
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--tertiary-bg);
  color: var(--primary-text);
  cursor: pointer;
  transition: var(--transition-all-smooth);
  font-size: var(--font-size-sm);
}

.merge-btn:hover {
  background: var(--primary-bg);
  border-color: var(--accent-color);
}

.merge-btn[data-action="use_local"] {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
}

.merge-btn[data-action="use_local"]:hover {
  background: var(--accent-hover);
}

.merge-btn[data-action="use_server"] {
  background: #dc2626;
  color: white;
  border-color: #dc2626;
}

.merge-btn[data-action="use_server"]:hover {
  background: #b91c1c;
}

/* Responsive adjustments for merge dialog */
@media (max-width: 768px) {
  .merge-comparison-dialog {
    width: 95vw;
    height: 95vh;
    padding: var(--spacing-md);
  }
  
  .merge-comparison-content {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }
  
  .merge-buttons {
    flex-direction: column;
  }
  
  .merge-btn {
    width: 100%;
  }
}

/* Removed duplicate .conflict-options button:hover — already styled above at line 205 */

/* Icon Buttons — minimal, quiet hover */
.icon-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--muted-text);
  cursor: pointer;
  transition: color var(--transition-fast), background-color var(--transition-fast);
}

.icon-btn:hover {
  color: var(--primary-text);
  background: rgba(255, 255, 255, 0.06);
}

.icon-btn:active {
  background: rgba(255, 255, 255, 0.08);
}

/* Header Back Button — simple, no pseudo-elements */
.header-back-btn {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: transparent;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--secondary-text);
    font-size: var(--font-size-sm);
    font-weight: 500;
    cursor: pointer;
    transition: color var(--transition-fast), border-color var(--transition-fast);
    text-decoration: none;
}

.header-back-btn:hover {
    color: var(--primary-text);
    border-color: var(--accent-color);
}

/* Primary Icon Button */
.icon-btn.primary {
  background: var(--accent-color);
  color: white;
}

.icon-btn.primary:hover {
  color: white;
  background: var(--accent-hover);
}

/* Mobile-only logo in header-right — hidden on desktop */
.mobile-logo-btn {
  display: none;
}

.mobile-header-logo {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

/* Mobile Header Adjustments */
@media (max-width: 768px) {
  .app-header {
    padding: var(--spacing-sm) var(--spacing-md);
    flex-direction: column;
    gap: var(--spacing-sm);
    height: auto;
  }
  
  /* Hide header-left on mobile — logo moves into header-right */
  .header-left {
    display: none;
  }
  
  /* Header-right: logo + icon buttons in one row */
  .header-right {
    width: 100%;
    gap: var(--spacing-xs);
    flex: 0 0 auto;
    display: flex;
    align-items: center;
  }
  
  /* Show mobile logo as leftmost item, push icons to the right */
  .mobile-logo-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-xs);
    margin-right: auto;
    cursor: pointer;
    border-radius: var(--radius-md);
    transition: background-color var(--transition-fast);
  }
  
  .mobile-logo-btn:hover {
    background: rgba(255, 255, 255, 0.04);
  }
  
  .icon-btn {
    padding: var(--spacing-sm);
    min-width: var(--btn-height-md);
    min-height: var(--btn-height-md);
  }
}

@media (max-width: 480px) {
  .icon-btn {
    min-width: var(--btn-height-sm);
    min-height: var(--btn-height-sm);
  }
}

/* Focus States for Accessibility */
.icon-btn:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.app-logo:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .app-header {
    border-bottom-width: 2px;
  }
  
  .icon-btn {
    border: 1px solid var(--border-color);
  }
  
  .icon-btn:hover {
    border-color: var(--accent-color);
  }
}
/* === layout/navigation.css === */
/* Navigation Components */

/* Date Navigation */
.date-navigation {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.current-date {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  font-weight: var(--font-weight-medium);
  min-width: 120px;
  text-align: center;
  cursor: pointer;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-sm);
  transition: all var(--transition-base);
}

.current-date:hover {
  background: var(--tertiary-bg);
  color: var(--accent-color);
}

/* Enhanced navigation with logo colors */
.current-date.today {
  background: linear-gradient(135deg, var(--accent-color), var(--accent-hover));
  color: white;
  font-weight: var(--font-weight-semibold);
}

.current-date.today:hover {
  background: linear-gradient(135deg, var(--accent-hover), var(--accent-color));
  color: white;
}

/* Navigation Buttons */
.nav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  color: var(--secondary-text);
  cursor: pointer;
  transition: all var(--transition-base);
}

.nav-btn:hover {
  background: var(--tertiary-bg);
  color: var(--primary-text);
}

.nav-btn:active {
  transform: scale(0.95);
}

/* Mobile Date Navigation Bar */
.mobile-date-nav {
  display: none;
}

@media (max-width: 768px) {
  .mobile-date-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
    width: 100%;
    padding: var(--spacing-sm);
    background: var(--secondary-bg);
    border-radius: var(--radius-md);
    margin-top: var(--spacing-xs);
  }
  
  .mobile-date-nav .current-date {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    min-width: 0;
    text-align: center;
    flex: 1;
  }
  
  .mobile-date-nav .nav-btn {
    min-width: var(--btn-height-md);
    min-height: var(--btn-height-md);
    padding: var(--spacing-sm);
    background: var(--primary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
  }
  
  .mobile-date-nav .nav-btn:hover {
    background: var(--tertiary-bg);
    border-color: var(--accent-color);
  }
}

@media (max-width: 480px) {
  .mobile-date-nav .current-date {
    font-size: var(--font-size-sm);
  }
  
  .mobile-date-nav .nav-btn {
    min-width: var(--btn-height-sm);
    min-height: var(--btn-height-sm);
  }
}

/* Breadcrumb Navigation */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  margin-bottom: var(--spacing-md);
}

.breadcrumb-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.breadcrumb-link {
  color: var(--accent-color);
  text-decoration: none;
  transition: color var(--transition-base);
}

.breadcrumb-link:hover {
  color: var(--accent-hover);
  text-decoration: underline;
}

.breadcrumb-separator {
  color: var(--secondary-text);
  opacity: 0.5;
}

.breadcrumb-current {
  color: var(--primary-text);
  font-weight: var(--font-weight-medium);
}

/* Tab Navigation */
.tab-nav {
  display: flex;
  border-bottom: 1px solid var(--border-color);
  margin-bottom: var(--spacing-lg);
}

.tab-btn {
  background: none;
  border: none;
  padding: var(--spacing-md) var(--spacing-lg);
  cursor: pointer;
  color: var(--secondary-text);
  font-size: var(--font-size-base);
  border-bottom: 2px solid transparent;
  transition: all var(--transition-base);
  position: relative;
}

.tab-btn:hover {
  color: var(--primary-text);
  background: var(--tertiary-bg);
}

.tab-btn.active {
  color: var(--accent-color);
  border-bottom-color: var(--accent-color);
  background: var(--primary-bg);
}

.tab-btn:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: -2px;
}

/* Pagination Navigation */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-sm);
  margin: var(--spacing-lg) 0;
}

.pagination-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 var(--spacing-sm);
  background: var(--primary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
  text-decoration: none;
}

.pagination-btn:hover:not(:disabled) {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
  transform: translateY(-1px);
}

.pagination-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.pagination-btn.active {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
}

.pagination-ellipsis {
  color: var(--secondary-text);
  padding: 0 var(--spacing-xs);
  font-size: var(--font-size-sm);
}

/* Keyboard Navigation Hints */
.keyboard-hint {
  font-size: var(--font-size-xs);
  color: var(--secondary-text);
  opacity: 0.7;
  margin-left: var(--spacing-xs);
}

/* Focus Management */
.nav-btn:focus-visible,
.current-date:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .nav-btn,
  .tab-btn,
  .pagination-btn {
    border: 1px solid var(--border-color);
  }
  
  .nav-btn:hover,
  .tab-btn:hover,
  .pagination-btn:hover {
    border-color: var(--accent-color);
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .nav-btn:active {
    transform: none;
  }
  
  .pagination-btn:hover:not(:disabled) {
    transform: none;
  }
}

/* Dropdown Navigation */
.dropdown-container {
    position: relative;
    display: inline-block;
}

.dropdown-toggle {
    position: relative;
}

.dropdown-menu {
    position: absolute;
    top: 100%;
    right: 0;
    background: var(--tertiary-bg);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-md);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5), 0 2px 8px rgba(0, 0, 0, 0.3);
    min-width: 180px;
    z-index: 1000;
    margin-top: var(--spacing-xs);
    padding: var(--spacing-xs) 0;
}

.dropdown-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    background: none;
    border: none;
    color: var(--primary-text);
    font-size: var(--font-size-sm);
    cursor: pointer;
    transition: all var(--transition-base);
    text-align: left;
}

.dropdown-item:hover {
    background: rgba(255, 255, 255, 0.06);
    color: var(--accent-color);
}

.dropdown-item svg {
    flex-shrink: 0;
    opacity: 0.8;
}

.dropdown-item:hover svg {
    opacity: 1;
}

/* Ensure dropdown works on mobile */
@media (max-width: 768px) {
    .dropdown-container {
        position: relative;
    }
    
    .dropdown-menu {
        position: absolute;
        top: calc(100% + var(--spacing-xs));
        right: 0;
        left: auto;
        min-width: 200px;
        max-width: 280px;
        max-height: 80vh;
        overflow-y: auto;
        z-index: 10000;
        margin-top: var(--spacing-sm);
        /* Ensure it's visible on mobile */
        display: block;
    }
    
    /* Hide by default */
    .dropdown-menu.hidden {
        display: none;
    }
    
    .dropdown-toggle {
        touch-action: manipulation;
        -webkit-tap-highlight-color: transparent;
    }
    
    .dropdown-item {
        padding: var(--spacing-md) var(--spacing-lg);
        font-size: var(--font-size-base);
        touch-action: manipulation;
        -webkit-tap-highlight-color: transparent;
        min-height: 44px; /* iOS touch target */
        display: flex;
        align-items: center;
    }
}
/* === components/buttons.css === */
/* ITCSS Layer: Components */
/* Button Components */
/* Note: .btn-base and .focus-outline utilities are defined in utilities.css.
   Using standard CSS here (composes is CSS Modules only, not standard CSS). */

/* Base Button Styles */
button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
  transition: all var(--transition-base);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  user-select: none;
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

/* Action Buttons — solid colors, no shimmer, minimal movement */
.action-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--accent-color);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  color: white;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
  min-height: var(--btn-height-md);
}

.action-btn:hover:not(:disabled) {
  background: var(--accent-hover);
}

.action-btn:active {
  opacity: 0.9;
}

.action-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px rgba(77, 168, 218, 0.3);
}

/* Button Variants */
.action-btn.primary {
  background: var(--accent-color);
  color: white;
  border: 1px solid transparent;
}

.action-btn.primary:hover:not(:disabled) {
  background: var(--accent-hover);
}

.action-btn.secondary {
  background: transparent;
  color: var(--primary-text);
  border: 1px solid var(--border-color);
}

.action-btn.secondary:hover:not(:disabled) {
  border-color: var(--accent-color);
  color: var(--accent-color);
}

.action-btn.warm {
  background: var(--accent-warm);
  color: white;
  border: 1px solid transparent;
}

.action-btn.warm:hover:not(:disabled) {
  background: var(--sun-orange-dark);
}

.action-btn.danger {
  background: var(--error-color);
  color: white;
  border: 1px solid transparent;
}

.action-btn.danger:hover:not(:disabled) {
  background: #c53030;
}

/* Standard button classes for modals */
.btn-danger {
  padding: 0.75rem 1rem;
  background: var(--error-color);
  color: white;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.btn-danger:hover {
  background: #c53030;
}

.action-btn.success {
  background: var(--success-color);
  color: white;
  border: 1px solid transparent;
}

.action-btn.success:hover:not(:disabled) {
  background: #3a9e68;
}

/* Button Sizes */
.action-btn.sm {
  padding: var(--spacing-xs) var(--spacing-sm);
  font-size: var(--font-size-xs);
  min-height: var(--btn-height-sm);
}

.action-btn.lg {
  padding: var(--spacing-md) var(--spacing-lg);
  font-size: var(--font-size-base);
  min-height: var(--btn-height-lg);
}

/* Close Button */
.close-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--secondary-text);
  font-size: 24px;
  cursor: pointer;
  transition: all var(--transition-base);
}

.close-btn:hover {
  background: var(--tertiary-bg);
  color: var(--primary-text);
}

/* Add Bullet Button */
.add-bullet-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-sm) var(--spacing-md);
  background: transparent;
  border: 1px dashed var(--border-color);
  border-radius: var(--radius-md);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
  width: 100%;
}

.add-bullet-btn:hover {
  border-color: var(--accent-color);
  color: var(--accent-color);
  background: rgba(59, 130, 246, 0.05);
}

/* Bullet Action Buttons */
.bullet-action-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  color: var(--secondary-text);
  cursor: pointer;
  transition: all var(--transition-base);
}

.bullet-action-btn:hover {
  background: var(--quaternary-bg);
  color: var(--primary-text);
}

/* Specific Bullet Action Button Styles */
/* Indent/Outdent buttons - Green theme */
.bullet-action-btn:nth-child(1),
.bullet-action-btn:nth-child(2) {
  background: rgba(34, 197, 94, 0.1);
  color: #22c55e;
}

.bullet-action-btn:nth-child(1):hover,
.bullet-action-btn:nth-child(2):hover {
  background: #22c55e;
  color: white;
}

/* Image maximize button - Purple theme */
.image-maximize-btn {
  background: rgba(147, 51, 234, 0.1);
  color: #9333ea;
}

.image-maximize-btn:hover {
  background: #9333ea;
  color: white;
}

/* Summarize button - Orange theme */
.summarize-btn {
  background: rgba(249, 115, 22, 0.1);
  color: #f97316;
}

.summarize-btn:hover {
  background: #f97316;
  color: white;
}

/* Auto-improve button - Pink theme */
.auto-improve-btn {
  background: rgba(236, 72, 153, 0.1);
  color: #ec4899;
}

.auto-improve-btn:hover {
  background: #ec4899;
  color: white;
}

/* Ask AI button - Blue theme (already defined in slash-commands.css) */
.ask-ai-btn {
  background: rgba(42, 157, 188, 0.1);
  color: #2a9dbc;
}

.ask-ai-btn:hover {
  background: #2a9dbc;
  color: white;
}

/* Delete button - Red theme */
.bullet-action-btn:last-child {
  background: rgba(239, 68, 68, 0.1);
  color: #ef4444;
}

.bullet-action-btn:last-child:hover {
  background: #ef4444;
  color: white;
}

/* Chart maximize button - Teal theme */
.chart-maximize-btn {
  background: rgba(20, 184, 166, 0.1);
  color: #14b8a6;
}

.chart-maximize-btn:hover {
  background: #14b8a6;
  color: white;
}

/* Filter Buttons — no movement, simple state change */
.filter-btn {
  padding: var(--spacing-xs) var(--spacing-sm);
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: color var(--transition-fast), background-color var(--transition-fast), border-color var(--transition-fast);
}

.filter-btn:hover {
  color: var(--primary-text);
  border-color: rgba(255, 255, 255, 0.15);
}

.filter-btn.active {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
  font-weight: var(--font-weight-medium);
}

/* Toggle Buttons */
.toggle-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--tertiary-bg);
  border: none;
  border-radius: var(--radius-sm);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
}

.toggle-btn:hover {
  background: var(--accent-color);
  color: white;
}

.toggle-btn.active {
  background: var(--accent-color);
  color: white;
}

/* Copy Button */
.copy-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--spacing-xs);
  border-radius: var(--radius-sm);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  transition: all var(--transition-base);
}

.copy-btn:hover {
  background: var(--quaternary-bg);
  color: var(--primary-text);
}

/* Authentication Buttons */
.auth-secondary-btn {
  width: auto;
  min-width: 120px;
  padding: var(--spacing-sm) var(--spacing-md);
  background: #6c757d;
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  cursor: pointer;
  transition: all var(--transition-base);
  box-shadow: 0 1px 2px rgba(108, 117, 125, 0.2);
  height: auto;
  line-height: 1.4;
}

.auth-secondary-btn:hover {
  background: #5a6268;
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(108, 117, 125, 0.3);
}

.auth-secondary-btn:active {
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(108, 117, 125, 0.2);
}

/* Message Close Button */
.message-close-btn {
  padding: var(--spacing-sm) var(--spacing-xl);
  background: var(--accent-color);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all var(--transition-base);
  min-width: 80px;
}

.message-close-btn:hover {
  background: var(--accent-hover);
}

/* Mobile Responsive Adjustments */
@media (max-width: 768px) {
  .action-btn {
    min-height: var(--btn-height-lg);
    font-size: var(--font-size-base);
    padding: var(--spacing-md) var(--spacing-lg);
  }
  
  .filter-btn {
    min-height: var(--btn-height-md);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
  }
  
  .close-btn {
    min-width: var(--btn-height-lg);
    min-height: var(--btn-height-lg);
    font-size: var(--font-size-xl);
  }
}

@media (max-width: 480px) {
  .action-btn {
    flex: 1;
  }
}

/* Focus States */
.action-btn:focus-visible,
.filter-btn:focus-visible,
.close-btn:focus-visible,
.toggle-btn:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* Points Preset Buttons */
.points-preset-buttons {
  display: flex;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-md);
  flex-wrap: wrap;
}

.points-preset-btn {
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--tertiary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all var(--transition-base);
  min-width: 40px;
  text-align: center;
}

.points-preset-btn:hover {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(42, 157, 188, 0.2);
}

.points-preset-btn:active {
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(42, 157, 188, 0.2);
}

/* Dark Mode Adjustments */
@media (prefers-color-scheme: dark) {
  .auth-secondary-btn {
    background: #495057;
    box-shadow: 0 1px 2px rgba(73, 80, 87, 0.3);
  }
  
  .auth-secondary-btn:hover {
    background: #3d4449;
    box-shadow: 0 2px 4px rgba(73, 80, 87, 0.4);
  }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .action-btn,
  .filter-btn,
  .toggle-btn {
    border-width: 2px;
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .action-btn:hover,
  .filter-btn:hover {
    transform: none;
  }
}
/* === components/forms.css === */
/* Form Components */

/* Base Form Styles */
form {
  width: 100%;
}

/* Form Groups */
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-md);
}

.form-grid {
  display: grid;
  gap: var(--spacing-md);
}

/* Labels */
label {
  font-weight: var(--font-weight-medium);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
  margin-bottom: var(--spacing-xs);
}

.label-required::after {
  content: ' *';
  color: var(--error-color);
}

/* Input Fields — inset feel, no movement on hover */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="url"],
input[type="tel"],
input[type="number"],
input[type="datetime-local"],
input[type="time"],
textarea,
select {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: rgba(0, 0, 0, 0.15);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  font-size: var(--font-size-base);
  color: var(--primary-text);
  font-family: inherit;
  line-height: var(--line-height-normal);
  letter-spacing: var(--letter-spacing-normal);
}

/* Date inputs - shorter width and native picker only */
input[type="date"] {
  width: auto;
  min-width: 150px;
  max-width: 200px;
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: rgba(0, 0, 0, 0.15);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  font-size: var(--font-size-base);
  color: var(--primary-text);
  font-family: inherit;
  line-height: var(--line-height-normal);
  cursor: pointer;
}

input[type="date"]::-webkit-calendar-picker-indicator {
  cursor: pointer;
}

/* Input Hover & Focus — no transform, just border change */
input:hover:not(:disabled),
textarea:hover:not(:disabled),
select:hover:not(:disabled) {
  border-color: rgba(255, 255, 255, 0.15);
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px rgba(77, 168, 218, 0.15);
}

input:focus::placeholder,
textarea:focus::placeholder {
  opacity: 0.4;
}

input::placeholder,
textarea::placeholder {
  color: var(--secondary-text);
  opacity: 1;
}

/* Input States */
input:disabled,
textarea:disabled,
select:disabled {
  background: var(--tertiary-bg);
  color: var(--secondary-text);
  cursor: not-allowed;
  opacity: 0.6;
}

input:invalid,
textarea:invalid {
  border-color: var(--error-color);
}

input:valid,
textarea:valid {
  border-color: var(--accent-color);
}

/* Form Group States */
.form-group.error input,
.form-group.error textarea,
.form-group.error select {
  border-color: var(--error-color);
  box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

.form-group.success input,
.form-group.success textarea,
.form-group.success select {
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(42, 157, 188, 0.1);
}

/* Error and Success Messages */
.form-error {
  color: var(--error-color);
  font-size: var(--font-size-sm);
  margin-top: var(--spacing-xs);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.form-success {
  color: var(--success-color);
  font-size: var(--font-size-sm);
  margin-top: var(--spacing-xs);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.form-help {
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  margin-top: var(--spacing-xs);
}

/* Textarea Specific */
textarea {
  min-height: 100px;
  resize: vertical;
  font-family: inherit;
}

/* Select Specific */
select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 8px center;
  background-repeat: no-repeat;
  background-size: 16px;
  padding-right: 40px;
  appearance: none;
}

/* Checkbox and Radio */
input[type="checkbox"],
input[type="radio"] {
  width: 16px;
  height: 16px;
  margin-right: var(--spacing-sm);
  margin-top: 0; /* Reset margin-top for proper alignment */
  cursor: pointer;
  accent-color: var(--accent-color);
}

/* Minimal Checkbox Label */
.checkbox-label {
  display: flex;
  align-items: center;
  cursor: pointer;
  font-size: var(--font-size-base);
  color: var(--primary-text);
  gap: var(--spacing-sm);
}

/* Hide custom checkmark - use native checkbox instead */
.checkbox-label input[type="checkbox"] {
  display: inline-block;
}

.checkmark {
  display: none; /* Hide custom checkmark */
}

/* Search Input Wrapper */
.search-input-wrapper {
  position: relative;
  margin-bottom: var(--spacing-md);
}

.search-input-wrapper input {
  width: 100%;
  padding: var(--spacing-md);
  padding-right: 40px;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  background: var(--primary-bg);
  color: var(--primary-text);
  transition: all var(--transition-base);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.search-input-wrapper input:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1), 0 1px 3px rgba(0, 0, 0, 0.1);
}

.search-clear-btn {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  color: var(--secondary-text);
  cursor: pointer;
  padding: 4px;
  border-radius: var(--radius-sm);
  transition: all var(--transition-base);
}

.search-clear-btn:hover {
  background: var(--tertiary-bg);
  color: var(--primary-text);
}

/* Date Range Inputs */
.date-range-inputs {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.date-range-inputs span {
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
}

.date-range-inputs input[type="date"] {
  flex: 1;
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
}

.date-range-inputs input[type="date"]:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

/* Form Actions */
.form-actions {
  display: flex;
  gap: var(--spacing-md);
  justify-content: flex-end;
  margin-top: var(--spacing-lg);
  padding-top: var(--spacing-lg);
  border-top: 1px solid var(--border-color);
}

/* Settings Form Specific — base styles here, overrides in pages/settings.css */
.settings-form {
  max-width: 600px;
  margin: 0 auto;
}

/* .settings-section and .settings-actions are defined in pages/settings.css
   which provides the enhanced, polished versions */

/* File Input */
input[type="file"] {
  padding: var(--spacing-sm);
  border: 1px dashed var(--border-color);
  border-radius: var(--radius-md);
  background: var(--secondary-bg);
  cursor: pointer;
}

input[type="file"]:hover {
  border-color: var(--accent-color);
  background: var(--tertiary-bg);
}

/* Form Validation */
.form-validation-summary {
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid var(--error-color);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
  color: var(--error-color);
}

.form-validation-summary h4 {
  margin: 0 0 var(--spacing-sm) 0;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
}

.form-validation-summary ul {
  margin: 0;
  padding-left: var(--spacing-lg);
}

.form-validation-summary li {
  font-size: var(--font-size-sm);
  margin-bottom: var(--spacing-xs);
}

/* Mobile Responsive */
@media (max-width: 768px) {
  input,
  textarea,
  select {
    font-size: 16px; /* Prevent zoom on iOS */
    min-height: var(--btn-height-lg);
  }
  
  .form-actions {
    flex-direction: column;
  }
  
  .settings-actions {
    flex-direction: column;
  }
  
  .settings-actions .action-btn {
    width: 100%;
  }
  
  .settings-section {
    padding: var(--spacing-md);
  }
  
  .date-range-inputs {
    flex-direction: column;
    align-items: stretch;
  }
  
  .date-range-inputs span {
    text-align: center;
  }
}

@media (max-width: 480px) {
  .settings-section {
    margin-bottom: var(--spacing-lg);
  }
  
  input,
  textarea,
  select {
    font-size: 16px; /* Prevent zoom on iOS */
  }
}

/* Focus States for Accessibility */
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  input,
  textarea,
  select {
    border-width: 2px;
  }
  
  .checkmark {
    border-width: 2px;
  }
}

/* Dark Mode Adjustments */
@media (prefers-color-scheme: dark) {
  select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23a0a0a0' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
  }
}

/* Smart Replace Template Styles — canonical versions in modals.css
   These base styles are retained for shared contexts */

.rules-section-header {
  margin: var(--spacing-lg) 0 var(--spacing-md) 0;
  padding-bottom: var(--spacing-xs);
  border-bottom: 2px solid var(--accent-color);
}

.rules-section-header h4 {
  color: var(--accent-color);
  margin: 0;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
}

.smart-replace-buttons {
  display: flex;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-md);
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .template-inputs {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }
  
  .template-arrow {
    transform: rotate(90deg);
    padding: var(--spacing-xs) 0;
  }
  
  .smart-replace-buttons {
    flex-direction: column;
  }
}
/* === components/modals.css === */
/* Modal Components — solid surfaces, no glass */

/* Base Modal */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-modal);
  padding: var(--spacing-lg);
  animation: modalBackdropFadeIn var(--duration-200) var(--ease-smooth);
}

.modal-content {
  background: var(--secondary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  width: 100%;
  max-width: 600px;
  max-height: 80vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  animation: modalContentFadeIn var(--duration-200) var(--ease-out-cubic);
  position: relative;
}

/* Calendar Modal Specific */
#calendar-modal .modal-content {
  max-width: 500px;
  max-height: 85vh;
  width: auto;
  padding: var(--spacing-lg);
}

/* Auto-Improve Modal Specific */
.large-modal {
  max-width: 800px;
}

.content-comparison {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
  margin: var(--spacing-md) 0;
}

.content-section h4 {
  margin: 0 0 var(--spacing-sm) 0;
  color: var(--primary-text);
  font-weight: 600;
}

.content-preview {
  background: var(--secondary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  max-height: 200px;
  overflow-y: auto;
  font-family: var(--font-mono);
  font-size: 0.9em;
  line-height: 1.4;
  white-space: pre-wrap;
}

.content-preview.original {
  border-left: 3px solid var(--warning-color);
}

.content-preview.improved {
  border-left: 3px solid var(--success-color);
}

/* Auto-improve button styling defined in buttons.css — not duplicated here */

/* Modal Animations — simple fade */
@keyframes modalBackdropFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes modalContentFadeIn {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Modal Header Close Button */
.modal-header .close-btn {
  position: absolute;
  top: 50%;
  right: var(--spacing-md);
  transform: translateY(-50%);
  background: transparent;
  border: none;
  transition: color var(--transition-fast);
}

.modal-header .close-btn:hover {
  color: var(--error-color);
}

/* auto-improve-btn:hover defined in buttons.css — not duplicated here */

/* Responsive adjustments for auto-improve modals */
@media (max-width: 768px) {
  .content-comparison {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }
  
  .large-modal {
    max-width: 95vw;
  }
}

@keyframes modalFadeIn {
  from {
    opacity: 0;
    transform: translateY(-20px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Modal Header */
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-lg);
  border-bottom: 1px solid var(--border-color);
  background: var(--primary-bg);
  position: sticky;
  top: 0;
  z-index: 10;
}

.modal-header h3 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--primary-text);
  margin: 0;
}

/* Modal Body */
.modal-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--spacing-lg);
}

/* Modal Footer */
.modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-md);
  padding: var(--spacing-lg);
  border-top: 1px solid var(--border-color);
  background: var(--secondary-bg);
}

/* Search Modal Specific */
.search-modal-content {
  max-height: 90vh;
  height: 90vh;
  display: flex;
  flex-direction: column;
  max-width: 800px;
}

.search-container {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: var(--spacing-md);
  overflow: hidden;
  flex: 1;
  min-height: 0;
}

.search-results-container {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--primary-bg);
}

.search-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-md);
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

.search-filters {
  display: flex;
  gap: var(--spacing-sm);
  flex-shrink: 0;
}

.advanced-filters-toggle {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--tertiary-bg);
  border: none;
  border-radius: var(--radius-sm);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
}

.advanced-filters-toggle:hover {
  background: var(--accent-color);
  color: white;
}

.advanced-filters {
  background: var(--secondary-bg);
  padding: var(--spacing-md);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-md);
  border: 1px solid var(--border-color);
}

.filter-group {
  margin-bottom: var(--spacing-md);
}

.filter-group:last-child {
  margin-bottom: var(--spacing-sm);
}

.filter-group label {
  display: block;
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  margin-bottom: var(--spacing-xs);
  font-weight: var(--font-weight-medium);
}

.date-shortcuts {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
  margin-bottom: var(--spacing-sm);
}

.date-shortcut-btn {
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--primary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
  white-space: nowrap;
}

.date-shortcut-btn:hover {
  background: var(--accent-color);
  border-color: var(--accent-color);
  color: white;
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(42, 157, 188, 0.2);
}

.date-shortcut-btn.active {
  background: var(--accent-professional);
  border-color: var(--accent-professional);
  color: white;
  font-weight: var(--font-weight-medium);
  box-shadow: 0 2px 4px rgba(3, 60, 92, 0.3);
}

.reset-filters-btn {
  padding: var(--spacing-xs) var(--spacing-md);
  background: var(--quaternary-bg);
  border: none;
  border-radius: var(--radius-sm);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
  width: 100%;
  margin-top: var(--spacing-xs);
}

.reset-filters-btn:hover {
  background: var(--tertiary-bg);
  color: var(--primary-text);
}


/* Message Modal */
.message-modal {
  max-width: 400px;
  max-height: auto;
}

.message-content {
  padding: var(--spacing-xl);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-lg);
}

.message-icon {
  width: 60px;
  height: 60px;
  background: var(--accent-color);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  color: white;
  font-weight: var(--font-weight-bold);
}

.message-text {
  font-size: var(--font-size-lg);
  color: var(--primary-text);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-normal);
}

/* Fullscreen Modal */
.fullscreen-modal {
  background: rgba(0, 0, 0, 0.95);
  padding: 0;
}

.fullscreen-content {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fullscreen-close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 48px;
  height: 48px;
  background: rgba(255, 255, 255, 0.1);
  border: none;
  border-radius: 50%;
  color: white;
  font-size: 32px;
  cursor: pointer;
  transition: background var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1001;
}

.fullscreen-close:hover {
  background: rgba(255, 255, 255, 0.2);
}

#fullscreen-image {
  max-width: 95%;
  max-height: 95%;
  object-fit: contain;
  border-radius: var(--radius-sm);
}

/* Import/Export Modal Specific */
.import-container,
.export-container {
  padding: var(--spacing-lg);
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.import-tabs {
  display: flex;
  border-bottom: 1px solid var(--border-color);
  margin-bottom: var(--spacing-lg);
}

.tab-content {
  display: none;
}

.tab-content.active {
  display: block;
}

.export-options {
  padding: var(--spacing-md);
  border-bottom: 1px solid var(--border-color);
  margin-bottom: var(--spacing-lg);
}

.export-preview {
  background: var(--secondary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--spacing-lg);
  margin-bottom: var(--spacing-lg);
  max-height: 300px;
  overflow-y: auto;
  font-family: var(--font-family);
  line-height: var(--line-height-relaxed);
  flex: 1;
  min-height: 0;
}

.export-preview h1,
.export-preview h2,
.export-preview h3 {
  margin-bottom: var(--spacing-md);
  color: var(--primary-text);
}

.export-preview ul {
  margin: 0;
  padding-left: var(--spacing-lg);
}

.export-preview li {
  margin-bottom: var(--spacing-xs);
  color: var(--primary-text);
}

.export-preview li ul {
  margin-top: var(--spacing-xs);
  padding-left: var(--spacing-lg);
}

.export-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-sm);
  flex-shrink: 0;
  padding-top: var(--spacing-md);
  border-top: 1px solid var(--border-color);
  margin-top: var(--spacing-md);
}

/* Drop Zone */
.drop-zone {
  border: 2px dashed var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--spacing-xl);
  text-align: center;
  color: var(--secondary-text);
  cursor: pointer;
  transition: all var(--transition-base);
}

.drop-zone:hover,
.drop-zone.dragover {
  border-color: var(--accent-color);
  background: rgba(59, 130, 246, 0.05);
  color: var(--accent-color);
}

.drop-zone svg {
  margin-bottom: var(--spacing-md);
  opacity: 0.5;
}

.drop-zone button {
  background: none;
  border: none;
  color: var(--accent-color);
  text-decoration: underline;
  cursor: pointer;
  font-size: inherit;
}

.upload-note {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  margin-top: var(--spacing-sm);
}

/* Progress Bar */
.progress-bar {
  width: 100%;
  height: 8px;
  background: var(--tertiary-bg);
  border-radius: var(--radius-sm);
  overflow: hidden;
  margin-bottom: var(--spacing-md);
}

.progress-fill {
  height: 100%;
  background: var(--accent-color);
  transition: width 0.3s ease;
  width: 0%;
}

/* Upload List */
.upload-list {
  margin-top: var(--spacing-lg);
  max-height: 300px;
  overflow-y: auto;
}

.upload-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-sm);
  background: var(--secondary-bg);
}

.upload-item-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  flex: 1;
}

.upload-item-name {
  font-weight: var(--font-weight-medium);
  color: var(--primary-text);
}

.upload-item-size {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
}

.upload-item-actions {
  display: flex;
  gap: var(--spacing-sm);
}

.upload-action-btn {
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--primary-text);
  cursor: pointer;
  font-size: var(--font-size-sm);
  transition: all var(--transition-base);
}

.upload-action-btn:hover {
  background: var(--tertiary-bg);
}

.upload-action-btn.overwrite {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
}

.upload-action-btn.skip {
  background: var(--secondary-text);
  color: white;
  border-color: var(--secondary-text);
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .modal {
    padding: var(--spacing-sm);
    align-items: flex-start;
    padding-top: 20px;
  }
  
  .modal-content {
    max-width: none;
    width: 100%;
    max-height: calc(100vh - 40px);
    overflow-y: auto;
    margin: 0;
  }
  
  .modal-header {
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--border-color);
    position: sticky;
    top: 0;
    background: var(--primary-bg);
    z-index: 10;
  }
  
  .search-container {
    padding: var(--spacing-md);
  }
  
  /* Calendar Modal Mobile */
  #calendar-modal .modal-content {
    max-width: none;
    width: 100%;
    max-height: calc(100vh - 40px);
  }
  
  .export-actions {
    display: flex;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
  }
  
  .import-container {
    padding: var(--spacing-md);
  }
  
  .import-tabs {
    margin-bottom: var(--spacing-md);
  }
  
  .tab-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    flex: 1;
    text-align: center;
  }
  
  .drop-zone {
    padding: var(--spacing-lg);
    min-height: 120px;
  }
  
  .drop-zone svg {
    width: 32px;
    height: 32px;
  }
  
  .upload-item {
    padding: var(--spacing-sm);
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-sm);
  }
  
  .upload-item-info {
    width: 100%;
  }
  
  .upload-item-actions {
    width: 100%;
    justify-content: flex-end;
  }
  
  .export-container {
    padding: var(--spacing-md);
  }
  
  .export-options {
    padding: var(--spacing-sm);
  }
  
  .export-preview {
    max-height: 50vh;
    overflow-y: auto;
    font-size: var(--font-size-sm);
  }
  
  .export-preview img {
    max-width: 100% !important;
    height: auto !important;
  }
  
  .date-shortcuts {
    gap: var(--spacing-xs);
  }
  
  .date-shortcut-btn {
    min-height: var(--btn-height-md);
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    border-radius: var(--radius-md);
  }
}

@media (max-width: 480px) {
  .modal {
    padding: var(--spacing-xs);
    padding-top: 10px;
  }
  
  .modal-content {
    max-height: calc(100vh - 20px);
  }
  
  .tab-btn {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-xs);
  }
  
  .drop-zone {
    padding: var(--spacing-md);
    min-height: 100px;
  }
  
  .upload-item {
    padding: var(--spacing-xs);
  }
}

/* Smart Replace Modal Specific */
#smart-replace-modal .modal-content {
    max-height: 95vh;
    height: 90vh;
    display: flex;
    flex-direction: column;
    max-width: 900px; /* Increased from 600px for better template editing */
}

.smart-replace-container {
    padding: var(--spacing-lg);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    flex: 1;
    overflow: hidden;
}

.smart-replace-intro {
    color: var(--secondary-text);
    font-size: var(--font-size-sm);
    line-height: var(--line-height-normal);
    margin-bottom: var(--spacing-md);
    flex-shrink: 0;
}

.smart-replace-rules {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    flex: 1;
    overflow-y: auto;
    padding: var(--spacing-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--secondary-bg);
    min-height: 0;
}

.smart-replace-rule {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  padding: var(--spacing-md);
  background: var(--primary-bg);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-color);
}

.rule-inputs {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex: 1;
}

.rule-inputs input {
  padding: var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  flex: 1;
  min-width: 0;
}

.rule-inputs input:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

.rule-arrow {
  color: var(--secondary-text);
  font-weight: var(--font-weight-bold);
  padding: 0 var(--spacing-xs);
  flex-shrink: 0;
}

.rule-actions {
  flex-shrink: 0;
}

.rule-delete-btn {
  width: 32px;
  height: 32px;
  border: none;
  border-radius: var(--radius-sm);
  background: var(--error-color);
  color: white;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-base);
}

.rule-delete-btn:hover {
  background: #c53030;
  transform: scale(1.1);
}

.no-rules-message {
  text-align: center;
  color: var(--secondary-text);
  padding: var(--spacing-xl);
}

.no-rules-message p {
  margin: 0 0 var(--spacing-sm) 0;
}

.smart-replace-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--border-color);
}

.smart-replace-main-actions {
    display: flex;
    gap: var(--spacing-sm);
}

/* Template Variable Insertion Styles */
.template-content-wrapper {
    position: relative;
    flex: 1;
    width: 100%;
}

.template-editor-section {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    width: 100%;
    margin-top: var(--spacing-sm);
}

.template-editor-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
}

.template-editor-label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--primary-text);
    margin: 0;
}

.insert-variable-btn {
    padding: var(--spacing-xs) var(--spacing-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--accent-color);
    color: white;
    cursor: pointer;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-base);
    white-space: nowrap;
    position: relative;
}

.insert-variable-btn:hover {
    background: var(--accent-professional);
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(42, 157, 188, 0.2);
}

.variable-dropdown-menu {
    position: absolute;
    top: 100%;
    right: 0;
    background: var(--primary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    min-width: 280px;
    max-height: 300px;
    overflow-y: auto;
    z-index: 1000;
    margin-top: 4px;
}

.variable-dropdown-menu.hidden {
    display: none;
}

.variable-item {
    padding: var(--spacing-sm) var(--spacing-md);
    cursor: pointer;
    border-bottom: 1px solid var(--border-color);
    font-size: var(--font-size-sm);
    line-height: 1.4;
    transition: background-color var(--transition-base);
}

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

.variable-item:hover {
    background: var(--tertiary-bg);
}

.variable-item:active {
    background: var(--accent-color);
    color: white;
}

/* Template input adjustments */
.template-inputs {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    flex: 1;
    width: 100%;
}

.template-trigger-row {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    width: 100%;
}

.template-trigger {
    flex: 1;
    min-width: 0;
    padding: var(--spacing-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
}

.template-trigger:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

.template-arrow {
    color: var(--secondary-text);
    font-weight: var(--font-weight-bold);
    flex-shrink: 0;
    transform: rotate(90deg);
    font-size: var(--font-size-lg);
}

.template-content {
    width: 100%;
    min-width: 0;
    padding: var(--spacing-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    font-family: var(--font-mono, 'Courier New', monospace);
    resize: vertical;
    min-height: 120px;
    line-height: 1.5;
}

.template-content:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

/* Template Preview Modal Styles */
#template-preview-modal .modal-content {
    max-width: 600px;
    max-height: 80vh;
}

.template-preview-content {
    background: var(--secondary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    font-family: var(--font-mono, 'Courier New', monospace);
    font-size: var(--font-size-sm);
    line-height: 1.6;
    white-space: pre-wrap;
    word-wrap: break-word;
    overflow-wrap: break-word;
    max-height: 400px;
    overflow-y: auto;
    color: var(--primary-text);
    border-left: 3px solid var(--accent-color);
}

.template-preview-content:empty::before {
    content: '(Empty template output)';
    color: var(--secondary-text);
    font-style: italic;
}

/* Template Bullets Editor Styles */
.template-bullets-editor {
    background: var(--secondary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    margin-top: var(--spacing-sm);
}

.template-bullets-editor.hidden {
    display: none;
}

.template-bullets-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
    min-height: 60px;
}

.template-bullet-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-xs);
    background: var(--primary-bg);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-color);
}

.template-bullet-item.level-0 {
    margin-left: 0;
}

.template-bullet-item.level-1 {
    margin-left: var(--spacing-lg);
}

.template-bullet-item.level-2 {
    margin-left: calc(var(--spacing-lg) * 2);
}

.template-bullet-item.level-3 {
    margin-left: calc(var(--spacing-lg) * 3);
}

.template-bullet-item.level-4 {
    margin-left: calc(var(--spacing-lg) * 4);
}

.template-bullet-item.level-5 {
    margin-left: calc(var(--spacing-lg) * 5);
}

.template-bullet-item.level-6 {
    margin-left: calc(var(--spacing-lg) * 6);
}

.template-bullet-item.level-7 {
    margin-left: calc(var(--spacing-lg) * 7);
}

.template-bullet-controls {
    display: flex;
    gap: var(--spacing-xs);
    flex-shrink: 0;
}

.template-bullet-outdent,
.template-bullet-indent {
    width: 24px;
    height: 24px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--tertiary-bg);
    color: var(--secondary-text);
    cursor: pointer;
    font-size: var(--font-size-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-base);
}

.template-bullet-outdent:hover:not(:disabled),
.template-bullet-indent:hover:not(:disabled) {
    background: var(--accent-color);
    color: white;
    border-color: var(--accent-color);
}

.template-bullet-outdent:disabled,
.template-bullet-indent:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.template-bullet-input {
    flex: 1;
    padding: var(--spacing-xs) var(--spacing-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    background: var(--primary-bg);
}

.template-bullet-input:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

.template-bullet-delete {
    width: 24px;
    height: 24px;
    border: none;
    border-radius: var(--radius-sm);
    background: var(--error-color);
    color: white;
    cursor: pointer;
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-bold);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-base);
    flex-shrink: 0;
}

.template-bullet-delete:hover {
    background: #c53030;
    transform: scale(1.1);
}

.template-bullets-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: var(--spacing-sm);
    border-top: 1px solid var(--border-color);
}

.add-template-bullet-btn,
.switch-to-text-btn {
    padding: var(--spacing-xs) var(--spacing-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: var(--font-size-sm);
    transition: all var(--transition-base);
}

.add-template-bullet-btn {
    background: var(--accent-color);
    color: white;
    border-color: var(--accent-color);
}

.add-template-bullet-btn:hover {
    background: var(--accent-professional);
    transform: translateY(-1px);
}

.switch-to-text-btn {
    background: var(--tertiary-bg);
    color: var(--primary-text);
}

.switch-to-text-btn:hover {
    background: var(--quaternary-bg);
}

/* Template Specific Styles */
.smart-replace-template {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    background: var(--primary-bg);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
}

.template-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-sm);
    align-items: center;
}

.template-test-btn {
    padding: var(--spacing-xs) var(--spacing-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--tertiary-bg);
    color: var(--primary-text);
    cursor: pointer;
    font-size: var(--font-size-sm);
    transition: all var(--transition-base);
}

.template-test-btn:hover {
    background: var(--accent-color);
    color: white;
    border-color: var(--accent-color);
}

.template-delete-btn {
    width: 32px;
    height: 32px;
    border: none;
    border-radius: var(--radius-sm);
    background: var(--error-color);
    color: white;
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-base);
}

.template-delete-btn:hover {
    background: #c53030;
    transform: scale(1.1);
}

.template-description {
    margin-top: var(--spacing-sm);
}

.template-description small {
    color: var(--secondary-text);
    font-size: var(--font-size-xs);
    line-height: 1.4;
}

/* Mobile Responsive for Smart Replace */
@media (max-width: 768px) {
  #smart-replace-modal .modal-content {
    max-width: 95vw;
    height: calc(100vh - 40px);
    margin: 20px;
  }
  
  .smart-replace-rule {
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-sm);
  }
  
  .rule-inputs {
    flex-direction: column;
    gap: var(--spacing-xs);
  }
  
  .rule-arrow {
    transform: rotate(90deg);
    padding: var(--spacing-xs) 0;
  }
  
  .smart-replace-actions {
    flex-direction: column;
    gap: var(--spacing-md);
  }
  
  .smart-replace-main-actions {
    width: 100%;
    justify-content: stretch;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .smart-replace-main-actions .action-btn {
    flex: 1;
    width: 100%;
  }
  
  .smart-replace-buttons {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .smart-replace-buttons .action-btn {
    width: 100%;
  }
  
  .template-editor-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-sm);
  }
  
  .insert-variable-btn {
    align-self: flex-end;
  }
  
  .template-content {
    min-height: 100px;
  }
}

/* Landscape orientation adjustments */
@media (max-width: 768px) and (orientation: landscape) {
  .modal-content {
    max-height: calc(100vh - 20px);
  }
  
  .search-results-container {
    max-height: 40vh;
  }
  
  .export-preview {
    max-height: 40vh;
  }
}

/* Focus States */
.modal:focus-within {
  outline: none;
}

/* Smooth Scrolling */
.modal-content,
.search-results-container,
.export-preview,
.upload-list {
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .modal-content {
    animation: none;
  }
  
  @keyframes modalFadeIn {
    from, to {
      opacity: 1;
      transform: none;
    }
  }
}

/* Session Expired Dialog */
.session-expired-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  padding: var(--spacing-lg);
  backdrop-filter: blur(4px);
}

.session-expired-dialog {
  background: var(--primary-bg);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  padding: var(--spacing-xl);
  max-width: 400px;
  width: 100%;
  text-align: center;
  animation: sessionExpiredFadeIn 0.3s ease-out;
  border: 2px solid var(--warning-color, #f59e0b);
}

@keyframes sessionExpiredFadeIn {
  from {
    opacity: 0;
    transform: translateY(-30px) scale(0.9);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.session-expired-icon {
  font-size: 48px;
  margin-bottom: var(--spacing-lg);
  display: block;
}

.session-expired-dialog h3 {
  color: var(--warning-color, #f59e0b);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  margin: 0 0 var(--spacing-md) 0;
}

.session-expired-dialog p {
  color: var(--primary-text);
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--spacing-md) 0;
}

.session-expired-dialog p:last-of-type {
  margin-bottom: var(--spacing-lg);
}

.session-expired-dialog .btn {
  min-width: 120px;
  font-weight: var(--font-weight-medium);
}

/* Global Context Styles — using design system variables */
.global-context-section {
  margin: var(--spacing-md) 0;
  padding: var(--spacing-sm);
  background: rgba(var(--tertiary-bg-rgb), 0.3);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
}

.global-context-preview {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  font-style: italic;
  margin-top: var(--spacing-xs);
  padding: var(--spacing-xs);
  background: var(--tertiary-bg);
  border-radius: var(--radius-sm);
}

.global-context-item {
  margin-bottom: var(--spacing-lg);
  padding: var(--spacing-md);
  background: var(--secondary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
}

.context-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-sm);
  gap: var(--spacing-sm);
}

.context-name-container {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  flex: 1;
}

.context-name-input {
  flex: 1;
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
}

.context-name-input[readonly] {
  background: var(--tertiary-bg);
  color: var(--secondary-text);
}

.default-badge {
  background: var(--accent-color);
  color: white;
  padding: 2px var(--spacing-xs);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
}

.context-actions {
  display: flex;
  gap: var(--spacing-xs);
}

.context-content-container {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.context-content-input {
  width: 100%;
  padding: var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-family: inherit;
  font-size: var(--font-size-sm);
  resize: vertical;
  min-height: 80px;
}

.context-content-input:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px rgba(66, 165, 245, 0.15);
}

.action-btn.small {
  padding: var(--spacing-xs) var(--spacing-sm);
  font-size: var(--font-size-xs);
  min-height: auto;
}

/* .action-btn.danger is already defined in buttons.css */

@media (max-width: 768px) {
  .context-header {
    flex-direction: column;
    align-items: stretch;
  }
  
  .context-actions {
    justify-content: flex-end;
  }
}

/* Global Context Multiple Checkboxes */
.global-context-checkboxes {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-xs);
}

.global-context-checkbox-item {
  padding: var(--spacing-sm);
  background: var(--tertiary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
}

.section-label {
  font-weight: var(--font-weight-medium);
  color: var(--primary-text);
  margin-bottom: var(--spacing-xs);
  display: block;
}
/* === components/loading.css === */
/* Premium Loading States & Animations */

/* Shimmer Loading Effect */
@keyframes shimmer {
  0% {
    background-position: -200px 0;
  }
  100% {
    background-position: calc(200px + 100%) 0;
  }
}

.loading-shimmer {
  background: linear-gradient(90deg, var(--tertiary-bg) 25%, var(--quaternary-bg) 50%, var(--tertiary-bg) 75%);
  background-size: 200px 100%;
  animation: shimmer 1.5s infinite;
}

/* Pulse Loading */
@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}

.loading-pulse {
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

/* Spinner Loading */
/* Removed duplicate @keyframes spin; now defined globally in utilities.css */

.loading-spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  border-top-color: currentColor;
  animation: spin 1s ease-in-out infinite;
}

.loading-spinner.lg {
  width: 32px;
  height: 32px;
  border-width: 3px;
}

/* Premium Button Loading State */
.action-btn.loading {
  position: relative;
  color: transparent;
  pointer-events: none;
}

.action-btn.loading::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top: 2px solid white;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

/* Skeleton Loading */
.skeleton {
  background: var(--gradient-subtle);
  border-radius: var(--radius-md);
  position: relative;
  overflow: hidden;
}

.skeleton::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
  animation: shimmer 1.5s infinite;
}

.skeleton-text {
  height: 1em;
  margin-bottom: 0.5em;
}

.skeleton-text:last-child {
  margin-bottom: 0;
  width: 80%;
}

.skeleton-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
}

.skeleton-button {
  height: 40px;
  width: 120px;
}

/* Progress Bar */
.progress-bar {
  width: 100%;
  height: 8px;
  background: var(--tertiary-bg);
  border-radius: var(--radius-full);
  overflow: hidden;
  position: relative;
}

.progress-fill {
  height: 100%;
  background: var(--gradient-primary);
  border-radius: var(--radius-full);
  transition: width var(--duration-300) var(--ease-out-cubic);
  position: relative;
}

.progress-fill::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  animation: shimmer 2s infinite;
}

/* Indeterminate Progress */
@keyframes indeterminate {
  0% {
    left: -35%;
    right: 100%;
  }
  60% {
    left: 100%;
    right: -90%;
  }
  100% {
    left: 100%;
    right: -90%;
  }
}

.progress-indeterminate {
  position: relative;
  overflow: hidden;
}

.progress-indeterminate::before {
  content: '';
  position: absolute;
  height: 100%;
  background: var(--gradient-primary);
  animation: indeterminate 2.1s cubic-bezier(0.65, 0.815, 0.735, 0.395) infinite;
}

/* Floating Action Button with Pulse */
.fab {
  position: fixed;
  bottom: var(--spacing-lg);
  right: var(--spacing-lg);
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--gradient-primary);
  color: white;
  border: none;
  box-shadow: var(--shadow-xl);
  cursor: pointer;
  transition: var(--transition-all-smooth);
  z-index: var(--z-fixed);
}

.fab:hover {
  transform: scale(1.1);
  box-shadow: var(--shadow-2xl), 0 0 20px rgba(66, 165, 245, 0.4);
}

.fab.pulse::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 50%;
  background: var(--accent-color);
  animation: pulse-ring 2s infinite;
}

@keyframes pulse-ring {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  100% {
    transform: scale(2);
    opacity: 0;
  }
}

/* Micro-interactions */
.bounce-in {
  animation: bounceIn var(--duration-500) var(--ease-bounce);
}

@keyframes bounceIn {
  0% {
    opacity: 0;
    transform: scale(0.3);
  }
  50% {
    opacity: 1;
    transform: scale(1.05);
  }
  70% {
    transform: scale(0.9);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

.fade-in-up {
  animation: fadeInUp var(--duration-500) var(--ease-out-cubic);
}

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

.slide-in-right {
  animation: slideInRight var(--duration-300) var(--ease-out-cubic);
}

@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Hover Lift Effect */
.hover-lift {
  transition: var(--transition-transform);
}

.hover-lift:hover {
  transform: translateY(-2px);
}

/* Glow Effect */
.glow {
  position: relative;
}

.glow::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: inherit;
  padding: 1px;
  background: var(--gradient-primary);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  opacity: 0;
  transition: opacity var(--duration-300) var(--ease-smooth);
}

.glow:hover::before {
  opacity: 1;
}

/* Success/Error State Animations */
@keyframes checkmark {
  0% {
    stroke-dashoffset: 100;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

.checkmark {
  stroke-dasharray: 100;
  animation: checkmark var(--duration-500) var(--ease-out-cubic) forwards;
}

@keyframes error-shake {
  0%, 100% {
    transform: translateX(0);
  }
  10%, 30%, 50%, 70%, 90% {
    transform: translateX(-2px);
  }
  20%, 40%, 60%, 80% {
    transform: translateX(2px);
  }
}

.error-shake {
  animation: error-shake var(--duration-500) var(--ease-out-cubic);
}

/* Global AI Progress Indicator */
.ai-progress-indicator {
  position: fixed;
  top: var(--spacing-lg);
  right: var(--spacing-lg);
  width: 48px;
  height: 48px;
  background: var(--gradient-primary);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-xl);
  z-index: var(--z-modal);
  opacity: 0;
  transform: scale(0.8) translateY(-10px);
  transition: all var(--duration-300) var(--ease-out-cubic);
  pointer-events: none;
}

.ai-progress-indicator.visible {
  opacity: 1;
  transform: scale(1) translateY(0);
}

.ai-progress-indicator .spinner {
  width: 24px;
  height: 24px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top: 2px solid white;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

/* Subtle pulse effect for the indicator */
.ai-progress-indicator::before {
  content: '';
  position: absolute;
  top: -4px;
  left: -4px;
  right: -4px;
  bottom: -4px;
  border-radius: 50%;
  background: var(--gradient-primary);
  opacity: 0.3;
  animation: pulse-ring 2s infinite;
  z-index: -1;
}

/* Mobile responsive adjustments */
@media (max-width: 768px) {
  .ai-progress-indicator {
    top: var(--spacing-md);
    right: var(--spacing-md);
    width: 40px;
    height: 40px;
  }
  
  .ai-progress-indicator .spinner {
    width: 20px;
    height: 20px;
  }
}
/* === components/bullets.css === */
/* Bullet List System */

/* Bullet List Container */
.bullet-list {
  margin-bottom: var(--spacing-lg);
}

/* Bullet Item */
.bullet-item {
  display: flex;
  align-items: flex-start;
  margin-bottom: 0;
  position: relative;
  transition: margin-left 0.15s ease;
}

/* Visual separation between top-level bullets */
.bullet-item:not(.nested) {
  position: relative;
}

/* Add border line above top-level bullets for visual separation */
.bullet-item:not(.nested):not(:first-child) {
  padding-top: var(--spacing-xs);
  margin-top: var(--spacing-xs);
  border-top: 1px solid var(--border-color);
}

/* Alternative approach: Add spacing and border above any top-level bullet that follows another bullet */
.bullet-item + .bullet-item:not(.nested) {
  padding-top: var(--spacing-xs);
  margin-top: var(--spacing-xs);
  border-top: 1px solid var(--border-color);
}

/* Bullet Indentation System */
/* DRY bullet indentation: Use data-level attribute and CSS variable for indentation */
.bullet-item.nested[data-level] {
  margin-left: calc(var(--indent-base) * attr(data-level number, 1));
}
.bullet-item.nested {
  margin-left: var(--indent-base);
  transition: margin-left 0.15s ease;
}

.bullet-item.nested-1 {
  margin-left: calc(var(--indent-base) * 1);
}

.bullet-item.nested-2 {
  margin-left: calc(var(--indent-base) * 2);
}

.bullet-item.nested-3 {
  margin-left: calc(var(--indent-base) * 3);
}

.bullet-item.nested-4 {
  margin-left: calc(var(--indent-base) * 4);
}

.bullet-item.nested-5 {
  margin-left: calc(var(--indent-base) * 5);
}

.bullet-item.nested-6 {
  margin-left: calc(var(--indent-base) * 6);
}

.bullet-item.nested-7 {
  margin-left: calc(var(--indent-base) * 7);
}

/* Mobile-specific bullet hierarchy indicators */
@media (max-width: 768px) {
  .bullet-item.nested {
    position: relative;
  }
  
  /* Remove the vertical line indicators on mobile - they were appearing through bullet markers */
  /* The indentation itself provides sufficient visual hierarchy on mobile devices */
}

/* Smooth transitions for level changes */
.bullet-item {
  transition: margin-left 0.15s ease, opacity 0.1s ease;
}

/* Prevent layout shift during updates */
.bullet-item.updating {
  transition: none;
}


/* Collapsible bullet functionality */
.bullet-item:not(.nested) .bullet-marker {
  cursor: pointer;
  position: relative;
}

.collapse-toggle {
  position: absolute;
  left: -20px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--secondary-text);
  font-size: 12px;
  transition: all var(--transition-base);
  opacity: 0;
  z-index: 5;
}

.bullet-item:not(.nested):hover .collapse-toggle {
  opacity: 1;
}

.bullet-item:not(.nested).has-children .collapse-toggle {
  opacity: 1;
}

.collapse-toggle:hover {
  color: var(--primary-text);
  background: transparent;
  border-radius: var(--radius-sm);
}

.collapse-toggle.collapsed {
  transform: translateY(-50%) rotate(-120deg);
}

/* Hide nested bullets when parent is collapsed */
.bullet-item.collapsed + .bullet-item.nested,
.bullet-item.collapsed ~ .bullet-item.nested {
  display: none;
}

/* Show nested bullets that belong to non-collapsed parents */
.bullet-item:not(.collapsed) + .bullet-item.nested,
.bullet-item:not(.collapsed) ~ .bullet-item.nested {
  display: flex;
}

/* Special handling for nested bullet visibility */
.bullet-item.nested.hidden-by-collapse {
  display: none !important;
}

/* Bullet Marker */
.bullet-marker {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  margin-right: var(--spacing-sm);
  margin-top: 2px;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.bullet-dot {
  width: 8px;
  height: 8px;
  background: var(--accent-color);
  border-radius: var(--radius-sm);
  transition: all var(--transition-base);
}

.bullet-item:hover .bullet-dot {
  background: var(--accent-warm);
}

.bullet-item:not(.nested) .bullet-dot {
  background: var(--accent-professional);
}

.bullet-item:not(.nested):hover .bullet-dot {
  background: var(--accent-warm);
}

/* Bullet Content */
.bullet-content {
  flex: 1 1 0%;
  min-height: 24px;
  padding: 2px 0;
  border: none;
  background: transparent;
  color: var(--primary-text);
  font-family: inherit;
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
  resize: none;
  outline: none;
  overflow: hidden;
  word-wrap: break-word;
  white-space: pre-wrap;
  height: auto;
  overflow-wrap: break-word;
  box-shadow: none;
  filter: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  /* Prevent width expansion during height recalculation */
  max-width: 100%;
  box-sizing: border-box;
}

.bullet-content:focus {
  background: transparent;
  border-radius: 0;
  min-height: inherit;
  height: auto;
  overflow: visible;
  white-space: pre-wrap;
  word-wrap: break-word;
  overflow-wrap: break-word;
  box-shadow: none;
  filter: none;
}

.bullet-content::placeholder {
  color: var(--secondary-text);
}

/* Bullet Display for hashtag rendering */
.bullet-display {
  flex: 1;
  min-height: 24px;
  padding: 2px 0;
  color: var(--primary-text);
  font-family: inherit;
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
  cursor: text;
  white-space: pre-wrap;
  word-wrap: break-word;
  overflow-wrap: break-word;
  box-shadow: none;
  filter: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  /* Allow inline elements like images to flow properly */
  display: block;
}

/* Focus styling for bullet display when navigating with arrow keys */
.bullet-display:focus {
  background-color: transparent;
}

/* Remove all hover effects on bullet content to prevent drop shadows */
.bullet-display:hover,
.bullet-content:hover,
.bullet-item .bullet-display:hover,
.bullet-item .bullet-content:hover,
.bullet-item.nested .bullet-display:hover,
.bullet-item.nested .bullet-content:hover {
  background: transparent;
  box-shadow: none;
  filter: none;
}

/* Bullet Actions */
.bullet-actions {
  position: absolute; /* Use absolute positioning relative to bullet item */
  top: -20px;
  right: 0;
  display: none;
  align-items: center;
  gap: var(--spacing-xs);
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-md);
  z-index: 10050; /* Much higher than header and other elements */
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border-color);
  transform: translate3d(0, 0, 0); /* Force hardware acceleration */
}

/* Dark mode support for transparent background */
@media (prefers-color-scheme: dark) {
  .bullet-actions {
    background: rgba(31, 41, 55, 0.42);
  }
}

.bullet-item:hover .bullet-actions {
  display: flex;
}

/* Ensure bullet items have relative positioning for absolute positioned actions */
.bullet-item {
  position: relative;
}

/* Position relative for action buttons - padding removed as note-editor has top padding */
.bullet-item {
  position: relative;
}

/* Hashtags */
.hashtag {
  color: var(--accent-color);
  text-decoration: none;
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all var(--transition-base);
  /* Prevent vertical padding from inflating the line box (keeps single-line height stable) */
  padding: 0 6px;
  border-radius: var(--radius-sm);
  background: rgba(42, 157, 188, 0.1);
  /* Use outline so we don’t affect line height like border does */
  outline: 1px solid rgba(42, 157, 188, 0.2);
  outline-offset: -1px;
  border: 0;
}

.hashtag:hover {
  color: white;
  background: var(--accent-color);
  outline: 1px solid var(--accent-color);
}

.hashtag:active {
  transform: translateY(0);
  background: var(--accent-hover);
}

/* Formatted Numbers */
.formatted-number {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
  /* Subtle styling to indicate formatted display */
  color: inherit;
}

/* Blue commas in formatted numbers */
.number-comma {
  color: var(--accent-color);
}

/* Image display in bullets */
.bullet-image {
  max-height: 200px;
  border-radius: var(--radius-sm);
  margin: 0;
  cursor: zoom-in;
}

.bullet-display img {
  max-height: 200px;
  border-radius: var(--radius-sm);
  margin: 0;
}

/* Image container with fullscreen button */
.image-container {
  position: relative;
  display: inline-block;
  margin: 2px 8px 2px 0;
  line-height: 0;
  vertical-align: top;
  max-width: 200px;
}

.image-container:hover .fullscreen-btn {
  opacity: 1;
}

.fullscreen-btn {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 32px;
  height: 32px;
  background: rgba(0, 0, 0, 0.7);
  border: none;
  border-radius: var(--radius-sm);
  color: white;
  cursor: pointer;
  opacity: 0;
  transition: opacity var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
}

.fullscreen-btn:hover {
  background: rgba(0, 0, 0, 0.9);
}

/* Drag and Drop Styles */
.bullet-item.dragging {
  opacity: 0.5;
  transform: rotate(1deg) scale(0.98);
  z-index: 1000;
  position: relative;
  background: rgba(59, 130, 246, 0.05);
  border-radius: var(--radius-sm);
}

.bullet-item.drag-over {
  background: var(--tertiary-bg);
  border-radius: var(--radius-sm);
}

.bullet-list.dragging-active .bullet-item:not(.dragging) {
  transition: transform var(--transition-base);
}

.bullet-list.dragging-active .bullet-item.drag-target-above {
  transform: translateY(3px);
}

.bullet-list.dragging-active .bullet-item.drag-target-below {
  transform: translateY(-3px);
}

.drop-target {
  background: rgba(59, 130, 246, 0.1);
  border: none;
  border-radius: var(--radius-sm);
}


@keyframes highlight-flash {
  0%, 50%, 100% { background: transparent; }
}

.highlight-flash {
  /* No animation - clean interface */
}

/* In-Page Search Highlights */
.in-page-highlight,
mark.in-page-highlight {
  background: rgba(251, 191, 36, 0.4) !important;
  color: inherit !important;
  padding: 1px 2px;
  border-radius: 2px;
}

.in-page-highlight-current,
mark.in-page-highlight-current {
  background: rgba(251, 191, 36, 0.7) !important;
  outline: 2px solid #f59e0b;
}

/* Search overlay for textareas */
.search-overlay {
  position: absolute;
  pointer-events: none;
  background: white;
  z-index: 0;
  white-space: pre-wrap;
  word-wrap: break-word;
  overflow: hidden;
  color: transparent;
}

.search-overlay mark {
  color: transparent;
  background: rgba(251, 191, 36, 0.4);
}

.search-overlay mark.in-page-highlight-current {
  background: rgba(251, 191, 36, 0.7);
}

/* Ensure bullet content is above overlay */
.bullet-item {
  position: relative;
}

.bullet-content {
  position: relative;
  z-index: 1;
}

/* Mobile Responsive Adjustments */
@media (max-width: 768px) {
  /* Update indentation system for mobile */
  :root {
    --indent-base: var(--indent-mobile);
  }
  
  .bullet-item {
    margin-bottom: var(--spacing-sm);
  }
  
  .bullet-content {
    font-size: var(--font-size-base);
    padding: 1px 0; /* Keep same padding as desktop for proper alignment */
    min-height: var(--btn-height-lg); /* Better touch target */
    word-wrap: break-word;
    overflow-wrap: break-word;
    white-space: pre-wrap;
    max-width: 100%;
    box-sizing: border-box;
    overflow: visible;
    height: auto;
  }
  
  .bullet-content:focus {
    overflow: visible;
    height: auto;
    min-height: var(--btn-height-lg);
  }
  
  /* Fix bullet marker alignment */
  .bullet-marker {
    align-items: flex-start;
    padding-top: 0; /* Remove extra padding */
    flex-shrink: 0;
    margin-top: 2px; /* Small offset to align with text baseline, not pushed down */
  }
  
  .bullet-dot {
    margin-top: 0; /* Remove extra margin that causes offset */
  }
  
  .bullet-actions {
    gap: var(--spacing-xs);
    right: var(--spacing-sm);
    top: var(--spacing-sm);
  }
  
  /* Better touch targets for hashtags */
  .hashtag {
    padding: 4px 8px;
    margin: 2px;
    min-height: 28px;
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    font-size: var(--font-size-sm);
  }
  
  /* Better bullet content wrapping */
  .bullet-content {
    line-height: var(--line-height-normal);
    word-break: break-word;
    hyphens: auto;
  }
}

@media (max-width: 480px) {
  /* Even more reduced indentation for very small screens */
  :root {
    --indent-base: var(--indent-small);
  }
}

/* Dark mode support for search overlay */
@media (prefers-color-scheme: dark) {
  .search-overlay {
    background: var(--primary-bg);
  }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .bullet-dot {
    border: 1px solid currentColor;
  }
  
  .hashtag {
    border-width: 2px;
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .bullet-item {
    animation: none;
  }
  
  .bullet-dot:hover {
    transform: none;
  }
  
  .hashtag:hover {
    transform: none;
  }
  
  @keyframes fadeIn {
    from, to {
      opacity: 1;
      transform: none;
    }
  }
  
  @keyframes highlight-flash {
    from, to {
      background: rgba(59, 130, 246, 0.3);
    }
  }
}

/* Touch Improvements */
.bullet-content {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.hashtag {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Prevent text selection on interactive elements */
.bullet-marker,
.bullet-actions,
.collapse-toggle {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* Focus styles for accessibility */
.bullet-content:focus-visible {
  outline: none;
}

.hashtag:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}
/* URL Link Styling */
.url-link {
  color: var(--accent-color);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: all var(--transition-base);
  font-weight: var(--font-weight-medium);
  display: inline;
  vertical-align: baseline;
  line-height: inherit;
  /* Fix margin/padding to match regular text */
  margin: 0;
  padding: 0;
  /* Ensure links don't affect bullet spacing */
  position: relative;
}

/* When a link is the first element in bullet content, add spacing to match regular text */
.bullet-content > .url-link:first-child,
.bullet-display > .url-link:first-child {
  /* Add left padding to compensate for the missing space */
  padding-left: 2px;
}

.url-link:hover {
  color: var(--accent-hover);
  border-bottom-color: var(--accent-hover);
  text-decoration: none;
}

.url-link:visited {
  color: var(--accent-professional);
}

.url-link:visited:hover {
  color: var(--accent-hover);
}

/* Ensure URL links don't interfere with bullet editing or layout */
.bullet-display .url-link,
.bullet-content .url-link {
  pointer-events: auto;
  display: inline;
  vertical-align: baseline;
  line-height: inherit;
  margin: 0;
  padding: 0;
}

/* Ensure bullet items with links maintain proper structure */
.bullet-item .bullet-content,
.bullet-item .bullet-display {
  /* Ensure consistent padding */
  padding: 1px 0;
}

/* Override mobile padding for bullet-display to match bullet-content */
@media (max-width: 768px) {
  .bullet-display {
    padding: 1px 0; /* Keep consistent with bullet-content */
  }
}

/* Make sure bullet marker always has consistent spacing */
.bullet-marker {
  margin-right: var(--spacing-sm);
  flex-shrink: 0;
}

/* Additional spacing fix for when content starts with a link */
.bullet-content:before,
.bullet-display:before {
  content: '';
  display: inline-block;
  width: 0;
}

/* Preserve proper indentation for nested bullets with links */
.bullet-item.nested:has(.url-link) {
  margin-left: var(--indent-base);
}

.bullet-item.nested-1:has(.url-link) {
  margin-left: calc(var(--indent-base) * 1);
}

.bullet-item.nested-2:has(.url-link) {
  margin-left: calc(var(--indent-base) * 2);
}

.bullet-item.nested-3:has(.url-link) {
  margin-left: calc(var(--indent-base) * 3);
}

.bullet-item.nested-4:has(.url-link) {
  margin-left: calc(var(--indent-base) * 4);
}

.bullet-item.nested-5:has(.url-link) {
  margin-left: calc(var(--indent-base) * 5);
}

.bullet-item.nested-6:has(.url-link) {
  margin-left: calc(var(--indent-base) * 6);
}

.bullet-item.nested-7:has(.url-link) {
  margin-left: calc(var(--indent-base) * 7);
}

/* AI Summarize Button Animation */
@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.summarize-btn {
  position: relative;
}

.summarize-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* === components/block-editor.css === */
/* Block Editor - Notion/LogSeq-style contenteditable editor */

/* Block Editor Container */
.block-editor {
    outline: none;
    min-height: 200px;
    padding: var(--spacing-sm) 0;
}

.block-editor:focus {
    outline: none;
}

/* Block Item */
.block-item {
    display: flex;
    align-items: flex-start;
    margin-bottom: 0;
    position: relative;
    transition: margin-left 0.15s ease;
    border-radius: var(--radius-sm);
    padding: 2px 4px;
}

/* Visual separation between top-level blocks — very subtle */
.block-item:not(.nested):not(:first-child) {
    padding-top: 3px;
    margin-top: 3px;
    border-top: 1px solid rgba(255, 255, 255, 0.04);
}

/* Block Indentation System */
.block-item.nested {
    margin-left: var(--indent-base);
    transition: margin-left 0.15s ease;
}

.block-item.nested-1 { margin-left: calc(var(--indent-base) * 1); }
.block-item.nested-2 { margin-left: calc(var(--indent-base) * 2); }
.block-item.nested-3 { margin-left: calc(var(--indent-base) * 3); }
.block-item.nested-4 { margin-left: calc(var(--indent-base) * 4); }
.block-item.nested-5 { margin-left: calc(var(--indent-base) * 5); }
.block-item.nested-6 { margin-left: calc(var(--indent-base) * 6); }
.block-item.nested-7 { margin-left: calc(var(--indent-base) * 7); }

/* Block Marker */
.block-marker {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    margin-right: var(--spacing-sm);
    margin-top: 2px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
}

.block-dot {
    width: 6px;
    height: 6px;
    background: var(--muted-text);
    border-radius: 50%;
    transition: background-color var(--transition-fast);
    cursor: grab;
    opacity: 0.5;
}

.block-item:hover .block-dot {
    opacity: 0.8;
    background: var(--secondary-text);
}

.block-item:not(.nested) .block-dot {
    width: 7px;
    height: 7px;
    background: var(--secondary-text);
    opacity: 0.6;
}

.block-item:not(.nested):hover .block-dot {
    background: var(--accent-color);
    opacity: 0.8;
}

/* Block Content - The main editable area */
.block-content {
    flex: 1 1 0%;
    min-height: 24px;
    padding: 2px 4px;
    border: none;
    background: transparent;
    color: var(--primary-text);
    font-family: inherit;
    font-size: var(--font-size-base);
    line-height: var(--line-height-normal);
    outline: none;
    word-wrap: break-word;
    white-space: pre-wrap;
    overflow-wrap: break-word;
    cursor: text;
}

.block-content:empty::before {
    content: attr(data-placeholder);
    color: var(--secondary-text);
    pointer-events: none;
}

.block-content:focus {
    background: rgba(77, 168, 218, 0.03);
    border-radius: var(--radius-sm);
}

/* Block Selection Styles */
.block-item.block-selected {
    background: rgba(59, 130, 246, 0.1);
    border-radius: var(--radius-sm);
}

.block-item.block-selected .block-content {
    background: transparent;
}

/* Native selection styling within blocks */
.block-editor ::selection {
    background: rgba(59, 130, 246, 0.3);
}

.block-editor ::-moz-selection {
    background: rgba(59, 130, 246, 0.3);
}

/* Kebab Menu Button — appears to the left of the block dot on hover */
.kebab-menu-btn {
    position: absolute;
    left: -18px;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 20px;
    padding: 0;
    margin: 0;
    border: none;
    background: transparent;
    color: var(--secondary-text);
    font-size: 14px;
    line-height: 1;
    letter-spacing: 1px;
    cursor: pointer;
    opacity: 0;
    transition: opacity var(--transition-base), color var(--transition-base);
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
}

.block-item:hover .kebab-menu-btn,
.block-item:focus-within .kebab-menu-btn {
    opacity: 1;
}

.kebab-menu-btn:hover {
    color: var(--primary-text);
    background: var(--tertiary-bg);
}

.kebab-menu-btn:focus-visible {
    opacity: 1;
    outline: 2px solid var(--accent-color);
    outline-offset: 1px;
}

/* Kebab Dropdown Menu — elevated surface, visible border */
.kebab-dropdown {
    position: fixed;
    z-index: 10060;
    min-width: 180px;
    background: var(--tertiary-bg);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-md);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5), 0 2px 8px rgba(0, 0, 0, 0.3);
    padding: var(--spacing-xs) 0;
    opacity: 0;
    transform: translateY(-4px);
    transition: opacity 0.12s ease, transform 0.12s ease;
    pointer-events: none;
}

.kebab-dropdown.open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.kebab-menu-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    width: 100%;
    padding: 6px 12px;
    border: none;
    background: transparent;
    color: var(--primary-text);
    font-size: var(--font-size-sm);
    cursor: pointer;
    text-align: left;
    transition: background var(--transition-fast);
    white-space: nowrap;
}

.kebab-menu-item:hover {
    background: rgba(255, 255, 255, 0.06);
}

.kebab-menu-item svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    color: var(--secondary-text);
}

.kebab-menu-item:hover svg {
    color: var(--primary-text);
}

.kebab-menu-item-danger {
    color: var(--error-color, #ef4444);
}

.kebab-menu-item-danger svg {
    color: var(--error-color, #ef4444);
}

.kebab-menu-item-danger:hover {
    background: rgba(239, 68, 68, 0.08);
}

.kebab-menu-divider {
    height: 1px;
    background: var(--border-color);
    margin: var(--spacing-xs) 0;
}

/* Collapse Toggle — positioned farther left than the kebab menu button */
.block-item .collapse-toggle {
    position: absolute;
    left: -36px;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    background: transparent;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--secondary-text);
    font-size: 12px;
    transition: all var(--transition-base);
    opacity: 0;
    z-index: 5;
}

.block-item:not(.nested):hover .collapse-toggle {
    opacity: 1;
}

.collapse-toggle:hover {
    color: var(--primary-text);
}

.collapse-toggle.collapsed {
    transform: translateY(-50%) rotate(-120deg);
}

/* Multi-Select Toolbar */
.multi-select-toolbar {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: var(--primary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--spacing-sm) var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    box-shadow: var(--shadow-lg);
    z-index: 10000;
    opacity: 0;
    transition: all 0.2s ease;
}

.multi-select-toolbar.visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.toolbar-info {
    font-size: var(--font-size-sm);
    color: var(--secondary-text);
    padding-right: var(--spacing-md);
    border-right: 1px solid var(--border-color);
}

.toolbar-info .selected-count {
    font-weight: var(--font-weight-semibold);
    color: var(--primary-text);
}

.toolbar-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--secondary-text);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: all var(--transition-base);
}

.toolbar-btn:hover {
    background: var(--tertiary-bg);
    color: var(--primary-text);
}

.toolbar-btn svg {
    width: 16px;
    height: 16px;
}

/* Selection Analysis Toolbar (number selection — reuses multi-select-toolbar base) */
.selection-analysis-toolbar {
    gap: var(--spacing-lg);
}

.selection-analysis-toolbar .selection-analysis-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.selection-analysis-toolbar .analysis-label {
    color: var(--muted-text);
    font-size: var(--font-size-xs);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
}

.selection-analysis-toolbar .selection-value {
    color: var(--accent-color);
    text-decoration: none;
    cursor: pointer;
    font-size: var(--font-size-sm);
    transition: all var(--transition-fast);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
}

.selection-analysis-toolbar .selection-value:hover {
    background: rgba(66, 165, 245, 0.15);
    color: var(--primary-text);
}

.selection-analysis-toolbar .selection-value strong {
    font-weight: var(--font-weight-bold);
    color: var(--primary-text);
}

.selection-analysis-toolbar .selection-value:hover strong {
    color: var(--accent-color);
}

/* Special Content Rendering */

/* Hashtags — subtle inline chips */
.block-content .hashtag {
    color: var(--accent-color);
    text-decoration: none;
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: color var(--transition-fast), background-color var(--transition-fast);
    padding: 1px 5px;
    border-radius: var(--radius-sm);
    background: rgba(77, 168, 218, 0.08);
    border: 0;
}

.block-content .hashtag:hover {
    color: white;
    background: var(--accent-color);
}

/* URLs */
.block-content .url-link {
    color: var(--accent-color);
    text-decoration: underline;
    cursor: pointer;
}

.block-content .url-link:hover {
    color: var(--accent-hover);
}

/* Images */
.block-content .block-image {
    max-height: 200px;
    border-radius: var(--radius-sm);
    margin: 4px 0;
    cursor: zoom-in;
}

/* TODO Items */
.block-content .todo-item {
    display: inline-flex;
    align-items: flex-start;
    gap: var(--spacing-xs);
}

.block-content .todo-checkbox {
    width: 16px;
    height: 16px;
    margin-top: 3px; /* Align checkbox with first line of text when using flex-start */
    cursor: pointer;
    accent-color: var(--accent-color);
}

.block-content .todo-text.done-text {
    text-decoration: line-through;
    color: var(--secondary-text);
}

/* Code */
.block-content .inline-code {
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', 'Fira Code', monospace;
    font-size: 0.9em;
    background: var(--tertiary-bg);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    color: var(--accent-warm);
}

/* AI Thinking Block — inline loading indicator */
.block-item.ai-thinking-block {
    pointer-events: none;
    opacity: 0.9;
}

.block-item.ai-thinking-block .block-content {
    background: rgba(66, 165, 245, 0.06);
    border-radius: var(--radius-sm);
    padding: var(--spacing-xs) var(--spacing-sm);
    color: var(--accent-color);
    font-size: var(--font-size-sm);
    cursor: default;
    user-select: none;
    -webkit-user-select: none;
}

.ai-thinking-content {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.ai-thinking-label {
    font-weight: var(--font-weight-medium);
    color: var(--accent-color);
}

.ai-thinking-dots {
    display: inline-flex;
    gap: 3px;
}

.ai-thinking-dots span {
    width: 5px;
    height: 5px;
    background: var(--accent-color);
    border-radius: 50%;
    animation: ai-dot-pulse 1.4s ease-in-out infinite;
}

.ai-thinking-dots span:nth-child(2) {
    animation-delay: 0.2s;
}

.ai-thinking-dots span:nth-child(3) {
    animation-delay: 0.4s;
}

@keyframes ai-dot-pulse {
    0%, 80%, 100% {
        opacity: 0.3;
        transform: scale(0.8);
    }
    40% {
        opacity: 1;
        transform: scale(1);
    }
}

/* AI thinking progress bar */
.ai-thinking-progress {
    height: 2px;
    background: rgba(66, 165, 245, 0.15);
    border-radius: 1px;
    margin-top: 6px;
    overflow: hidden;
}

.ai-thinking-progress-bar {
    height: 100%;
    background: var(--accent-color);
    border-radius: 1px;
    width: 30%;
    animation: ai-progress-slide 2s ease-in-out infinite;
}

@keyframes ai-progress-slide {
    0% {
        width: 0%;
        margin-left: 0%;
    }
    50% {
        width: 40%;
        margin-left: 30%;
    }
    100% {
        width: 0%;
        margin-left: 100%;
    }
}

/* Multi-block selection mode */
.block-editor.block-selection-active {
    /* Prevent native text selection during block selection */
    user-select: none;
    -webkit-user-select: none;
}

.block-editor.block-selection-active .block-content {
    /* Override contenteditable selection */
    user-select: none;
    -webkit-user-select: none;
    cursor: default;
}

/* Drag and Drop — minimal disruption, only show drop indicator */
.block-editor.dragging-active {
    cursor: grabbing !important;
}

.block-item.dragging {
    opacity: 0.3;
    pointer-events: none;
}

.block-item.drag-over {
    /* No background change — drop indicator is sufficient */
}

/* Drag handle cursor */
.drag-handle {
    cursor: grab;
}

.drag-handle:active {
    cursor: grabbing;
}

/* Drop indicator styles */
.drop-indicator {
    pointer-events: none;
    position: relative;
}

.drop-indicator::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 4px;
    background: var(--accent-color);
    border-radius: 2px;
    box-shadow: 0 0 10px rgba(59, 130, 246, 0.5);
}

/* Drag ghost is styled inline in JS for proper positioning */

/* Dark Mode — app is dark-first, minimal overrides */
@media (prefers-color-scheme: dark) {
    .kebab-dropdown {
        background: var(--tertiary-bg);
        border-color: rgba(255, 255, 255, 0.12);
    }
    
    .block-item.block-selected {
        background: rgba(77, 168, 218, 0.1);
    }
    
    .block-content:focus {
        background: rgba(77, 168, 218, 0.03);
    }
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .block-item {
        margin-bottom: var(--spacing-sm);
        /* Larger touch targets on mobile */
        padding: var(--spacing-xs) var(--spacing-sm);
    }
    
    .block-content {
        font-size: var(--font-size-base);
        min-height: var(--btn-height-lg);
        /* Ensure adequate touch target height */
        padding: var(--spacing-sm) var(--spacing-xs);
        /* Prevent text selection issues on touch */
        -webkit-user-select: text;
        user-select: text;
        /* Improve touch scrolling */
        -webkit-overflow-scrolling: touch;
    }
    
    .block-marker {
        /* Larger drag handle on mobile */
        width: 28px;
        height: 28px;
    }
    
    .block-dot {
        /* Larger touch target for drag handle */
        width: 12px;
        height: 12px;
    }
    
    /* Kebab menu button always visible on mobile (no hover) */
    .kebab-menu-btn {
        opacity: 1;
        width: 24px;
        height: 24px;
        font-size: 16px;
    }
    
    /* Larger touch targets for kebab dropdown items */
    .kebab-menu-item {
        padding: 10px 14px;
        font-size: var(--font-size-base);
    }
    
    .kebab-menu-item svg {
        width: 20px;
        height: 20px;
    }
    
    .multi-select-toolbar {
        bottom: 10px;
        padding: var(--spacing-xs) var(--spacing-sm);
        gap: var(--spacing-sm);
    }
    
    .toolbar-btn {
        width: 44px;
        height: 44px;
        min-width: 44px;
        min-height: 44px;
    }
    
    .toolbar-btn svg {
        width: 20px;
        height: 20px;
    }
    
    /* Collapse toggle larger on mobile */
    .collapse-toggle {
        width: 24px;
        height: 24px;
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    .toolbar-info {
        display: none;
    }
    
    .block-content {
        /* Slightly smaller font on very small screens */
        font-size: calc(var(--font-size-base) - 1px);
    }
    
    /* Compact hint bar on small screens */
    .hotkey-hint-bar {
        gap: var(--spacing-sm);
        padding: var(--spacing-xs) var(--spacing-sm);
    }
    
    .hotkey-hint-divider {
        display: none;
    }
}

/* Touch device specific styles */
.touch-device .kebab-menu-btn {
    /* Always visible on touch devices (no hover state) */
    opacity: 1;
}

/* Hide hotkey hint bar on touch devices — no physical keyboard */
.touch-device .hotkey-hint-bar {
    display: none !important;
}

/* Virtual keyboard handling */
.keyboard-open .multi-select-toolbar {
    /* Hide toolbar when keyboard is open to avoid overlap */
    transform: translateX(-50%) translateY(100px);
    opacity: 0;
    pointer-events: none;
}

.multi-select-toolbar.keyboard-hidden {
    transform: translateX(-50%) translateY(100px);
    opacity: 0;
    pointer-events: none;
}

/* Improve focus visibility on mobile */
.touch-device .block-content:focus {
    background: rgba(59, 130, 246, 0.08);
    outline: 2px solid rgba(59, 130, 246, 0.3);
    outline-offset: 2px;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
    .block-item {
        transition: none;
    }
    
    .multi-select-toolbar {
        transition: opacity 0.1s ease;
    }
}

/* Hotkey Hint Bar — whisper-quiet, barely there */
.hotkey-hint-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
    padding: 4px var(--spacing-md);
    background: var(--primary-bg);
    border-top: 1px solid rgba(255, 255, 255, 0.04);
    z-index: 9999;
    opacity: 0;
    transform: translateY(100%);
    transition: opacity 0.15s ease, transform 0.15s ease;
    pointer-events: none;
    flex-wrap: wrap;
}

.hotkey-hint-bar.visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}


.hotkey-hint {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-size-xs);
    color: var(--secondary-text);
    white-space: nowrap;
}

.hotkey-hint kbd {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 3px;
    font-family: var(--font-family-mono);
    font-size: 10px;
    color: var(--secondary-text);
    line-height: 1;
}

.hotkey-hint .hint-label {
    color: var(--muted-text);
    font-size: 11px;
}

.hotkey-hint-divider {
    width: 1px;
    height: 16px;
    background: var(--border-color);
    flex-shrink: 0;
}

/* AI section of hint bar — only visible when AI is enabled */
.hotkey-hint.ai-hint {
    color: var(--accent-color);
}

.hotkey-hint.ai-hint kbd {
    border-color: rgba(66, 165, 245, 0.3);
    background: rgba(66, 165, 245, 0.1);
}

.hotkey-hint.ai-hint .hint-label {
    color: var(--accent-color);
}

/* Ancestor Breadcrumb / Tree Connector
 *
 * When editing a nested bullet, an SVG overlay draws L-shaped connector
 * lines from the focused bullet's dot up through each ancestor's dot to
 * the root.  The SVG is managed by BlockEditor.showAncestorBreadcrumb().
 *
 * The CSS below just highlights the ancestor dots so they stand out along
 * the path.
 */

.block-item.ancestor-active .block-dot {
    background: var(--accent-color);
    opacity: 0.8;
}

/* Print Styles */
@media print {
    .kebab-menu-btn,
    .kebab-dropdown,
    .multi-select-toolbar,
    .collapse-toggle,
    .hotkey-hint-bar {
        display: none !important;
    }
    
    .block-item.block-selected {
        background: transparent;
    }
}

/* === components/search.css === */
/* Search Components */

/* Search Results */
.search-results-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-sm) var(--spacing-md);
  border-bottom: 1px solid var(--border-color);
  background: var(--secondary-bg);
  position: sticky;
  top: 0;
  z-index: 10;
}

.results-count {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  font-weight: var(--font-weight-medium);
}

.sort-options select {
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
}

.search-results-list {
  padding: var(--spacing-xs);
}

.search-result {
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-xs);
  cursor: pointer;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
  background: transparent;
}

.search-result:hover,
.search-result.highlighted {
  background: rgba(255, 255, 255, 0.03);
  border-color: var(--accent-color);
}

.search-result:last-child {
  border-bottom: none;
}

.search-result-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-xs);
}

.search-result-date {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  font-weight: var(--font-weight-medium);
}

.search-result-type {
  font-size: var(--font-size-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-md);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.search-result-type.content {
  background: rgba(59, 130, 246, 0.1);
  color: var(--accent-color);
}

.search-result-type.hashtag {
  background: rgba(16, 185, 129, 0.1);
  color: #10b981;
}

.search-result-type.topic {
  background: rgba(245, 158, 11, 0.1);
  color: #f59e0b;
}

.search-result-content {
  color: var(--primary-text);
  line-height: var(--line-height-relaxed);
  font-size: var(--font-size-base);
  margin-top: var(--spacing-sm);
}

.search-result-content mark {
  background: rgba(251, 191, 36, 0.4);
  color: inherit;
  padding: 2px 4px;
  border-radius: var(--radius-sm);
  font-weight: var(--font-weight-medium);
}

.search-result-indent {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  font-style: italic;
  margin-top: var(--spacing-xs);
}

/* Pagination Controls */
.pagination-controls {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-md);
  border-top: 1px solid var(--border-color);
  background: var(--secondary-bg);
}

.pagination-pages {
  display: flex;
  gap: var(--spacing-xs);
  align-items: center;
}

.pagination-page {
  min-width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--primary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
  text-decoration: none;
}

.pagination-page:hover {
  background: var(--tertiary-bg);
}

.pagination-page.active {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
}

.pagination-ellipsis {
  color: var(--secondary-text);
  padding: 0 var(--spacing-xs);
}

/* Search History and Suggestions */
.search-suggestions,
.search-history {
  padding: var(--spacing-lg);
  text-align: center;
}

.suggestions-title,
.history-title {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  margin-bottom: var(--spacing-md);
}

.search-tips {
  text-align: left;
  max-width: 400px;
  margin: 0 auto;
  background: var(--secondary-bg);
  padding: var(--spacing-md);
  border-radius: var(--radius-md);
}

.search-tips p {
  font-weight: var(--font-weight-medium);
  margin-bottom: var(--spacing-sm);
}

.search-tips ul {
  list-style: none;
  padding: 0;
}

.search-tips li {
  padding: var(--spacing-xs) 0;
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
}

.history-item {
  padding: var(--spacing-sm) var(--spacing-md);
  margin: var(--spacing-xs) var(--spacing-md);
  background: var(--secondary-bg);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--transition-base);
  text-align: left;
}

.history-item:hover {
  background: var(--tertiary-bg);
  transform: translateX(4px);
}

/* No Results */
.no-results {
  padding: var(--spacing-xl);
  text-align: center;
  color: var(--secondary-text);
}

.no-results-hint {
  font-size: var(--font-size-sm);
  margin-top: var(--spacing-sm);
}

/* In-Page Search Highlight (injected by SearchManager.highlightCurrentMatch) */
.in-page-search-highlight {
  background: rgba(251, 191, 36, 0.5);
  color: inherit;
  padding: 1px 2px;
  border-radius: var(--radius-sm);
  outline: 2px solid rgba(251, 191, 36, 0.8);
  outline-offset: 0;
}

.in-page-match-active {
  box-shadow: inset 0 0 0 2px rgba(251, 191, 36, 0.3);
}

/* In-Page Search Bar */
.in-page-search-bar {
  position: fixed;
  top: 60px;
  right: 20px;
  background: var(--primary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-modal);
  padding: var(--spacing-sm);
}

.in-page-search-container {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

#in-page-search-input {
  width: 200px;
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
}

.in-page-search-count {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  min-width: 60px;
  text-align: center;
}

.in-page-search-btn {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  color: var(--secondary-text);
  cursor: pointer;
  transition: all var(--transition-base);
}

.in-page-search-btn:hover {
  background: var(--tertiary-bg);
  color: var(--primary-text);
}

/* Search Result States */
.search-result.selected {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
}

.search-result.selected .search-result-date,
.search-result.selected .search-result-content,
.search-result.selected .search-result-indent {
  color: white;
}

.search-result.selected .search-result-type {
  background: rgba(255, 255, 255, 0.2);
  color: white;
}

/* Search Loading State */
.search-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
  color: var(--secondary-text);
}

.search-loading .spinner {
  width: 20px;
  height: 20px;
  border: 2px solid var(--border-color);
  border-top: 2px solid var(--accent-color);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-right: var(--spacing-sm);
}

/* Removed duplicate @keyframes spin; now defined globally in utilities.css */

/* Search Error State */
.search-error {
  padding: var(--spacing-lg);
  text-align: center;
  color: var(--error-color);
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid var(--error-color);
  border-radius: var(--radius-md);
  margin: var(--spacing-md);
}

.search-error h4 {
  margin: 0 0 var(--spacing-sm) 0;
  font-size: var(--font-size-base);
}

.search-error p {
  margin: 0;
  font-size: var(--font-size-sm);
}

/* Search Keyboard Navigation */
.search-result.keyboard-focus {
  background: var(--tertiary-bg);
  border-color: var(--accent-color);
  outline: 2px solid var(--accent-color);
  outline-offset: -2px;
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .search-result {
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-md);
  }
  
  .in-page-search-bar {
    position: fixed;
    top: auto;
    bottom: 20px;
    right: 20px;
    left: 20px;
    width: auto;
  }
  
  #in-page-search-input {
    width: 100%;
    flex: 1;
  }
  
  .in-page-search-container {
    width: 100%;
  }
  
  .search-tips {
    padding: var(--spacing-sm);
  }
  
  .pagination-controls {
    flex-wrap: wrap;
    gap: var(--spacing-xs);
  }
  
  .pagination-page {
    min-width: 40px;
    height: 40px;
  }
}

@media (max-width: 480px) {
  .search-result-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-xs);
  }
  
  .search-result-type {
    align-self: flex-start;
  }
  
  .pagination-controls {
    padding: var(--spacing-sm);
  }
  
  .pagination-page {
    min-width: 36px;
    height: 36px;
    font-size: var(--font-size-xs);
  }
}

/* Focus States */
.search-result:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.pagination-page:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.in-page-search-btn:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .search-result {
    border: 1px solid var(--border-color);
  }
  
  .search-result:hover,
  .search-result.highlighted {
    border-width: 2px;
  }
  
  .search-result-type {
    border: 1px solid currentColor;
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .history-item:hover {
    transform: none;
  }
  
  .search-loading .spinner {
    animation: none;
  }
  
  /* Removed duplicate reduced-motion @keyframes spin; now handled globally */
}

/* Touch Improvements */
.search-result {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.pagination-page {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Smooth Scrolling */
.search-results-list {
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}
/* === components/calendar.css === */
/* Calendar Widget */

#calendar-widget {
  padding: var(--spacing-lg);
}

.calendar-controls {
  margin-bottom: var(--spacing-lg);
}

.calendar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-md);
}

.calendar-quick-actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  justify-content: space-between;
}

.today-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--accent-color);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all var(--transition-base);
}

.today-btn:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}

.date-input-container {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.direct-date-input {
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  background: var(--primary-bg);
  color: var(--primary-text);
  transition: border-color var(--transition-base);
}

.direct-date-input:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

.jump-to-date-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: var(--tertiary-bg);
  border: none;
  border-radius: var(--radius-md);
  color: var(--secondary-text);
  cursor: pointer;
  transition: all var(--transition-base);
}

.jump-to-date-btn:hover {
  background: var(--accent-color);
  color: white;
}

.calendar-nav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--secondary-text);
  cursor: pointer;
  transition: all var(--transition-base);
}

.calendar-nav-btn:hover {
  background: var(--tertiary-bg);
  color: var(--primary-text);
}

.calendar-month-year {
  font-weight: var(--font-weight-semibold);
  color: var(--primary-text);
  font-size: var(--font-size-lg);
}

/* Calendar Grid */
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 2px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: var(--radius-md);
  overflow: hidden;
  min-width: 0;
  padding: 2px;
  border: 1px solid var(--border-color);
}

.calendar-day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--primary-bg);
  color: var(--secondary-text);
  cursor: pointer;
  transition: background-color var(--transition-fast), color var(--transition-fast);
  font-size: var(--font-size-sm);
  position: relative;
  min-height: 40px;
  min-width: 0;
  padding: var(--spacing-xs);
  border-radius: var(--radius-sm);
  box-sizing: border-box;
}

.calendar-day:hover {
  background: var(--accent-color);
  color: white;
}

.calendar-day.today {
  background: linear-gradient(135deg, var(--accent-warm), #FFA726);
  color: var(--accent-professional);
  font-weight: var(--font-weight-semibold);
  box-shadow: 0 2px 8px rgba(254, 180, 69, 0.4);
}

.calendar-day.viewing {
  outline: 3px solid var(--accent-professional);
  outline-offset: -3px;
  font-weight: var(--font-weight-semibold);
  z-index: 1;
  background: rgba(3, 60, 92, 0.1);
}

.calendar-day.other-month {
  color: var(--secondary-text);
  opacity: 0.6;
}

.calendar-day.has-notes {
  position: relative;
  background: rgba(42, 157, 188, 0.15);
  color: var(--accent-professional);
  font-weight: var(--font-weight-semibold);
  border: 1px solid rgba(42, 157, 188, 0.3);
}

.calendar-day.has-notes:hover {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
}

.calendar-day.has-notes::before {
  content: '';
  position: absolute;
  top: 3px;
  right: 3px;
  width: 8px;
  height: 8px;
  background: var(--accent-color);
  border-radius: 50%;
  z-index: 2;
  box-shadow: 0 1px 3px rgba(42, 157, 188, 0.5);
}

/* Special styling for today when it has notes */
.calendar-day.today.has-notes {
  background: linear-gradient(135deg, var(--accent-warm), #FFA726);
  color: var(--accent-professional);
  border: 2px solid var(--accent-professional);
}

.calendar-day.today.has-notes::before {
  background: var(--accent-professional);
  box-shadow: 0 1px 3px rgba(3, 60, 92, 0.5);
}

/* Special styling for viewing date when it has notes */
.calendar-day.viewing.has-notes {
  background: rgba(3, 60, 92, 0.2);
  color: var(--accent-professional);
}

/* Special styling for today + viewing (same date) */
.calendar-day.today.viewing {
  outline: 3px solid var(--accent-professional);
  background: linear-gradient(135deg, var(--accent-warm), #FFA726);
}

/* Special styling for today + viewing + has notes */
.calendar-day.today.viewing.has-notes {
  background: linear-gradient(135deg, var(--accent-warm), #FFA726);
  outline: 3px solid var(--accent-professional);
  border: 2px solid var(--accent-professional);
}

/* Calendar Day Names Header */
.calendar-day-names {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  background: var(--border-color);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  overflow: hidden;
  margin-bottom: 1px;
}

.calendar-day-name {
  background: var(--secondary-bg);
  color: var(--secondary-text);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  padding: var(--spacing-sm);
  text-align: center;
  letter-spacing: 0.5px;
}

/* Calendar Loading State */
.calendar-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
  color: var(--secondary-text);
}

.calendar-loading .spinner {
  width: 20px;
  height: 20px;
  border: 2px solid var(--border-color);
  border-top: 2px solid var(--accent-color);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-right: var(--spacing-sm);
}

/* Calendar Error State */
.calendar-error {
  padding: var(--spacing-lg);
  text-align: center;
  color: var(--error-color);
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid var(--error-color);
  border-radius: var(--radius-md);
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .calendar-quick-actions {
    flex-direction: column;
    gap: var(--spacing-sm);
  }

  .today-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-base);
    min-height: var(--btn-height-lg);
  }

  .direct-date-input {
    padding: var(--spacing-sm);
    font-size: var(--font-size-base);
    min-height: var(--btn-height-lg);
  }

  .jump-to-date-btn {
    width: var(--btn-height-lg);
    height: var(--btn-height-lg);
  }
  
  .calendar-day {
    min-height: var(--btn-height-lg);
    font-size: var(--font-size-base);
    border-radius: var(--radius-sm);
  }
  
  .calendar-day-name {
    padding: var(--spacing-sm);
    font-size: var(--font-size-xs);
  }
  
  .calendar-nav-btn {
    width: var(--btn-height-md);
    height: var(--btn-height-md);
  }
  
  .calendar-month-year {
    font-size: var(--font-size-base);
  }
}

@media (max-width: 480px) {
  #calendar-widget {
    padding: var(--spacing-md);
  }
  
  .calendar-controls {
    margin-bottom: var(--spacing-md);
  }
  
  .calendar-header {
    flex-direction: column;
    gap: var(--spacing-sm);
    text-align: center;
  }
  
  .calendar-day {
    min-height: 36px;
    font-size: var(--font-size-sm);
  }
  
  .calendar-day.has-notes::before {
    width: 6px;
    height: 6px;
    top: 2px;
    right: 2px;
  }
  
  .today-btn,
  .direct-date-input {
    width: 100%;
  }
  
  .date-input-container {
    width: 100%;
  }
  
  .jump-to-date-btn {
    width: var(--btn-height-md);
    height: var(--btn-height-md);
  }
}

/* Focus States */
.calendar-day:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
  z-index: 10;
}

.today-btn:focus-visible,
.jump-to-date-btn:focus-visible,
.calendar-nav-btn:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.direct-date-input:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .calendar-day {
    border: 1px solid var(--border-color);
  }
  
  .calendar-day:hover,
  .calendar-day.today,
  .calendar-day.viewing,
  .calendar-day.has-notes {
    border-width: 2px;
  }
  
  .calendar-day.has-notes::before {
    border: 1px solid var(--primary-bg);
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .calendar-day:hover {
    transform: none;
  }
  
  .today-btn:hover {
    transform: none;
  }
  
  .calendar-loading .spinner {
    animation: none;
  }
}

/* Touch Improvements */
.calendar-day {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.today-btn,
.jump-to-date-btn,
.calendar-nav-btn {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Keyboard Navigation */
.calendar-day.keyboard-focus {
  outline: 2px solid var(--accent-color);
  outline-offset: -2px;
  z-index: 10;
}

/* Calendar Animation */
.calendar-grid {
  animation: calendarFadeIn 0.3s ease-out;
}

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

@media (prefers-reduced-motion: reduce) {
  .calendar-grid {
    animation: none;
  }
  
  @keyframes calendarFadeIn {
    from, to {
      opacity: 1;
      transform: none;
    }
  }
}
/* === pages/login.css === */
/* ITCSS Layer: Pages */
/* Login Page Styles */

/* Login Container */
.login-container {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: url('../daycarp-login.png') center center / cover no-repeat;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1000; /* Ensure login screen appears above everything */
}

.login-container::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.3);
  z-index: 1;
}

/* Login Form — solid surface, no glass */
.login-form {
  position: relative;
  z-index: 2;
  background: rgba(15, 20, 25, 0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: var(--spacing-xl);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  width: 100%;
  max-width: 400px;
  text-align: center;
  animation: loginFormFadeIn 0.3s var(--ease-out-cubic);
}

@keyframes loginFormFadeIn {
  from {
    opacity: 0;
    transform: translateY(-20px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Login Logo */
.login-logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-sm);
}

.logo-image {
  width: 64px;
  height: 64px;
  object-fit: contain;
  transition: transform var(--transition-base);
}

.login-logo:hover .logo-image {
  transform: scale(1.05);
}

.login-form h1 {
  font-family: var(--font-family);
  font-size: var(--font-size-2xl);
  font-weight: 700;
  margin: 0;
  color: var(--accent-color);
  letter-spacing: var(--letter-spacing-tight);
  font-style: normal;
}

.login-form p {
  color: var(--primary-text);
  margin-bottom: var(--spacing-xl);
  font-size: var(--font-size-base);
  font-style: italic;
  opacity: 0.9;
}

/* Login Form Inputs — inset, no movement */
.login-form input {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  margin-bottom: var(--spacing-md);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  background: rgba(0, 0, 0, 0.2);
  color: var(--primary-text);
  transition: border-color var(--transition-fast);
  min-height: 48px;
}

.login-form input:hover:not(:focus) {
  border-color: rgba(255, 255, 255, 0.12);
}

.login-form input:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px rgba(77, 168, 218, 0.15);
}

.login-form input::placeholder {
  color: var(--muted-text);
}

.login-form input:focus::placeholder {
  opacity: 0.4;
}

/* Login Form Button — solid, no shimmer */
.login-form button[type="submit"] {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--accent-color);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: background-color var(--transition-fast);
  min-height: 48px;
}

.login-form button[type="submit"]:hover {
  background: var(--accent-hover);
}

.login-form button[type="submit"]:active {
  opacity: 0.9;
}

/* Button Loading State */
.login-form button[type="submit"]:disabled {
  opacity: 0.7;
  cursor: not-allowed;
  transform: none;
}

.login-form button[type="submit"].loading::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 16px;
  height: 16px;
  border: 2px solid transparent;
  border-top: 2px solid white;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

.login-form button[type="submit"].loading {
  color: transparent;
}

/* Authentication Links */
.auth-links {
  text-align: center;
  margin-top: var(--spacing-lg);
  display: flex;
  justify-content: center;
  gap: var(--spacing-md);
}

/* Authentication Secondary Button */
.auth-secondary-btn {
  width: auto;
  min-width: 120px;
  padding: var(--spacing-md) var(--spacing-lg);
  background: #6c757d;
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-normal);
  cursor: pointer;
  transition: all var(--transition-base);
  box-shadow: 0 1px 2px rgba(108, 117, 125, 0.2);
  min-height: 48px;
  line-height: 1.4;
}

.auth-secondary-btn:hover {
  background: #5a6268;
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(108, 117, 125, 0.3);
}

.auth-secondary-btn:active {
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(108, 117, 125, 0.2);
}

/* Form Validation */
.login-form .form-error {
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid var(--error-color);
  border-radius: var(--radius-md);
  padding: var(--spacing-sm) var(--spacing-md);
  margin-bottom: var(--spacing-md);
  color: var(--error-color);
  font-size: var(--font-size-sm);
  text-align: left;
}

.login-form .form-success {
  background: rgba(40, 167, 69, 0.1);
  border: 1px solid var(--success-color);
  border-radius: var(--radius-md);
  padding: var(--spacing-sm) var(--spacing-md);
  margin-bottom: var(--spacing-md);
  color: var(--success-color);
  font-size: var(--font-size-sm);
  text-align: left;
}

/* Input Validation States */
.login-form input.error {
  border-color: var(--error-color);
  box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

.login-form input.success {
  border-color: var(--success-color);
  box-shadow: 0 0 0 3px rgba(40, 167, 69, 0.1);
}

/* Password Visibility Toggle */
.password-input-wrapper {
  position: relative;
}

.password-toggle {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--secondary-text);
  cursor: pointer;
  padding: var(--spacing-xs);
  border-radius: var(--radius-sm);
  transition: all var(--transition-base);
}

.password-toggle:hover {
  color: var(--primary-text);
  background: var(--tertiary-bg);
}

/* Remember Me Checkbox */
.remember-me {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-md);
  text-align: left;
}

.remember-me input[type="checkbox"] {
  width: auto;
  margin: 0;
}

.remember-me label {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  cursor: pointer;
  margin: 0;
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .login-container {
    padding: var(--spacing-md);
  }
  
  .login-form {
    padding: var(--spacing-lg);
    width: 100%;
    max-width: none;
  }
  
  .logo-image {
    width: 56px;
    height: 56px;
  }
  
  .login-form input {
    font-size: 16px; /* Prevent zoom on iOS */
    padding: var(--spacing-md);
    min-height: var(--btn-height-lg);
  }
  
  .login-form button[type="submit"] {
    padding: var(--spacing-md);
    min-height: var(--btn-height-lg);
    font-size: var(--font-size-base);
  }
  
  .login-form h1 {
    font-size: var(--font-size-xl);
  }
}

@media (max-width: 480px) {
  .login-container {
    padding: var(--spacing-sm);
  }
  
  .login-form {
    padding: var(--spacing-md);
  }
  
  .logo-image {
    width: 48px;
    height: 48px;
  }
  
  .login-form h1 {
    font-size: var(--font-size-lg);
  }
  
  .auth-links {
    flex-direction: column;
    gap: var(--spacing-sm);
  }
}

/* Focus States for Accessibility */
.login-form input:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.login-form button:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .login-form {
    border: 2px solid var(--border-color);
  }
  
  .login-form input,
  .login-form button {
    border-width: 2px;
  }
  
  .login-form h1 {
    -webkit-text-fill-color: var(--primary-text);
    background: none;
  }
}

/* Dark Mode Adjustments */
@media (prefers-color-scheme: dark) {
  .login-container::before {
    background: rgba(0, 0, 0, 0.5);
  }
  
  .login-form h1 {
    background: linear-gradient(135deg, var(--accent-color), var(--accent-warm));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .login-form {
    animation: none;
  }
  
  .login-form input:focus,
  .login-form button:hover {
    transform: none;
  }
  
  .logo-image {
    transition: none;
  }
  
  .login-logo:hover .logo-image {
    transform: none;
  }
  
  @keyframes loginFormFadeIn {
    from, to {
      opacity: 1;
      transform: none;
    }
  }
}

/* Touch Improvements */
.login-form input,
.login-form button {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Smooth Scrolling */
.login-container {
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}
/* === pages/notes.css === */
/* Notes Page Styles */

/* Note Header (if needed) */
.note-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-lg);
  border-bottom: 1px solid var(--border-color);
}

.note-header h2 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--primary-text);
  margin: 0;
}

.note-actions {
  display: flex;
  gap: var(--spacing-sm);
}

/* Note Content Specific Styles */
.note-content {
  padding: var(--spacing-lg);
  min-height: 400px;
}

/* Empty Note State */
.empty-note {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
  text-align: center;
  color: var(--secondary-text);
  min-height: 300px;
}

.empty-note-icon {
  width: 64px;
  height: 64px;
  margin-bottom: var(--spacing-lg);
  opacity: 0.5;
}

.empty-note h3 {
  margin-bottom: var(--spacing-md);
  color: var(--primary-text);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-medium);
}

.empty-note p {
  margin-bottom: var(--spacing-lg);
  max-width: 400px;
  line-height: var(--line-height-relaxed);
}

.empty-note .action-btn {
  margin-top: var(--spacing-md);
}

/* Note Metadata */
.note-metadata {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  padding: var(--spacing-md) var(--spacing-lg);
  background: var(--secondary-bg);
  border-bottom: 1px solid var(--border-color);
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
}

.note-date {
  font-weight: var(--font-weight-medium);
  color: var(--accent-color);
}

.note-word-count {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.note-last-modified {
  margin-left: auto;
  font-style: italic;
}

/* Note Statistics */
.note-stats {
  display: flex;
  gap: var(--spacing-lg);
  padding: var(--spacing-md) var(--spacing-lg);
  background: var(--tertiary-bg);
  border-top: 1px solid var(--border-color);
  font-size: var(--font-size-sm);
}

.note-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-xs);
}

.note-stat-value {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--accent-color);
}

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

/* Note Auto-save Indicator */
.auto-save-indicator {
  position: fixed;
  top: calc(var(--header-height) + 10px);
  right: 20px;
  background: var(--success-color);
  color: white;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  opacity: 0;
  transform: translateY(-10px);
  transition: all var(--transition-base);
  z-index: var(--z-toast);
  pointer-events: none;
}

.auto-save-indicator.show {
  opacity: 1;
  transform: translateY(0);
}

.auto-save-indicator.saving {
  background: var(--warning-color);
  color: var(--primary-text);
}

.auto-save-indicator.error {
  background: var(--error-color);
}

/* Note Toolbar */
.note-toolbar {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-lg);
  background: var(--secondary-bg);
  border-bottom: 1px solid var(--border-color);
}

.toolbar-group {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding-right: var(--spacing-md);
  border-right: 1px solid var(--border-color);
}

.toolbar-group:last-child {
  border-right: none;
  margin-left: auto;
}

.toolbar-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  color: var(--secondary-text);
  cursor: pointer;
  transition: all var(--transition-base);
}

.toolbar-btn:hover {
  background: var(--tertiary-bg);
  color: var(--primary-text);
}

.toolbar-btn.active {
  background: var(--accent-color);
  color: white;
}

.toolbar-separator {
  width: 1px;
  height: 20px;
  background: var(--border-color);
  margin: 0 var(--spacing-xs);
}

/* Note Search within page */
.note-search {
  position: relative;
  margin-bottom: var(--spacing-md);
}

.note-search-input {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  padding-right: 100px;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
  transition: all var(--transition-base);
}

.note-search-input:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.note-search-controls {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.note-search-count {
  font-size: var(--font-size-xs);
  color: var(--secondary-text);
  min-width: 40px;
  text-align: center;
}

/* Note Tags */
.note-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
  padding: var(--spacing-md) var(--spacing-lg);
  background: var(--secondary-bg);
  border-bottom: 1px solid var(--border-color);
}

.note-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--accent-color);
  color: white;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  transition: all var(--transition-base);
}

.note-tag:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}

.note-tag-remove {
  background: none;
  border: none;
  color: white;
  cursor: pointer;
  padding: 0;
  width: 14px;
  height: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background var(--transition-base);
}

.note-tag-remove:hover {
  background: rgba(255, 255, 255, 0.2);
}

/* Note Breadcrumbs */
.note-breadcrumbs {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-lg);
  background: var(--tertiary-bg);
  border-bottom: 1px solid var(--border-color);
  font-size: var(--font-size-sm);
}

.breadcrumb-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  color: var(--secondary-text);
}

.breadcrumb-link {
  color: var(--accent-color);
  text-decoration: none;
  transition: color var(--transition-base);
}

.breadcrumb-link:hover {
  color: var(--accent-hover);
  text-decoration: underline;
}

.breadcrumb-separator {
  color: var(--secondary-text);
  opacity: 0.5;
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .note-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-md);
  }
  
  .note-metadata {
    flex-wrap: wrap;
    gap: var(--spacing-sm);
  }
  
  .note-last-modified {
    margin-left: 0;
    width: 100%;
  }
  
  .note-stats {
    justify-content: space-around;
    flex-wrap: wrap;
  }
  
  .note-toolbar {
    flex-wrap: wrap;
    gap: var(--spacing-xs);
  }
  
  .toolbar-group {
    border-right: none;
    padding-right: 0;
  }
  
  .note-tags {
    gap: var(--spacing-xs);
  }
  
  .note-breadcrumbs {
    flex-wrap: wrap;
  }
  
  .auto-save-indicator {
    position: static;
    margin: var(--spacing-sm) var(--spacing-lg);
    width: fit-content;
  }
}

@media (max-width: 480px) {
  .note-content {
    padding: var(--spacing-md);
  }
  
  .note-metadata,
  .note-stats,
  .note-toolbar,
  .note-tags,
  .note-breadcrumbs {
    padding: var(--spacing-sm) var(--spacing-md);
  }
  
  .empty-note {
    padding: var(--spacing-lg) var(--spacing-md);
  }
  
  .empty-note-icon {
    width: 48px;
    height: 48px;
  }
  
  .note-stat {
    min-width: 60px;
  }
  
  .toolbar-btn {
    width: 28px;
    height: 28px;
  }
}

/* Focus States */
.toolbar-btn:focus-visible,
.note-tag:focus-visible,
.breadcrumb-link:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .note-metadata,
  .note-stats,
  .note-toolbar,
  .note-tags,
  .note-breadcrumbs {
    border-bottom-width: 2px;
  }
  
  .toolbar-group {
    border-right-width: 2px;
  }
  
  .note-tag {
    border: 1px solid var(--accent-color);
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .note-tag:hover {
    transform: none;
  }
  
  .auto-save-indicator {
    transition: opacity var(--transition-base);
  }
  
  .auto-save-indicator.show {
    transform: none;
  }
}

/* Touch Improvements */
.toolbar-btn,
.note-tag,
.breadcrumb-link {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Print Styles */
@media print {
  .note-toolbar,
  .note-breadcrumbs,
  .auto-save-indicator {
    display: none;
  }
  
  .note-container {
    box-shadow: none;
    border: none;
  }
  
  .note-metadata,
  .note-stats {
    background: transparent;
    border: none;
  }
}

/* Drag and drop image support for note editor */
#note-editor {
  transition: background-color var(--transition-base), border-color var(--transition-base);
  border-radius: var(--radius-md);
}

#note-editor.dragover {
  background-color: rgba(66, 165, 245, 0.05);
  outline: 2px dashed var(--accent-color);
  outline-offset: 4px;
}

#note-editor.dragover::after {
  content: 'Drop images here to upload';
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--accent-color);
  color: white;
  padding: var(--spacing-lg) var(--spacing-xl);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  box-shadow: var(--shadow-lg);
  z-index: 1000;
  pointer-events: none;
}

/* Hashtag Page Date Separators */
.hashtag-date-separator {
  margin: 2rem 0 1rem 0;
  padding: 0.75rem 1rem;
  background: linear-gradient(135deg, var(--accent-color) 0%, var(--accent-hover) 100%);
  color: white;
  border-radius: 8px;
  cursor: pointer;
  transition: box-shadow 0.2s;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.hashtag-date-separator:hover {
  /* Removed transform animation that moves text */
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.hashtag-date-separator h3 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Removed calendar icon from hashtag-date-separator */

/* First date separator should have more top margin */
.hashtag-date-separator:first-child {
  margin-top: 0;
}

/* Hashtag page specific styles */
body.hashtag-page .hashtag-date-separator {
  animation: slideIn 0.3s ease-out;
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateX(-20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Mobile responsive */
@media (max-width: 768px) {
  .hashtag-date-separator {
    margin: 1.5rem 0 0.75rem 0;
    padding: 0.5rem 0.75rem;
  }
  
  .hashtag-date-separator h3 {
    font-size: 1rem;
  }
  
  .hashtag-date-separator:hover {
    transform: translateX(2px);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .hashtag-date-separator {
    transition: none;
  }
  
  .hashtag-date-separator:hover {
    transform: none;
  }
  
  body.hashtag-page .hashtag-date-separator {
    animation: none;
  }
}
/* === pages/tasks.css === */
/* Tasks Page Styles — using design system variables */

/* Page Actions */
.page-actions {
    margin-bottom: var(--spacing-lg);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-md);
}

/* Active Filter Display */
.active-filter {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-sm);
    background: var(--tertiary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
}

/* Active Hashtag Filter Display */
#active-hashtag-filter {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--accent-color);
    color: white;
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--spacing-md);
}

.hashtags-container {
    display: flex;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
}

.hashtag-filter-tag {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
}

.remove-hashtag-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    background: transparent;
    border: none;
    border-radius: var(--radius-sm);
    color: white;
    cursor: pointer;
    transition: all var(--transition-base);
}

.remove-hashtag-btn:hover {
    background: rgba(255, 255, 255, 0.3);
}

#active-hashtag-filter .clear-filter-btn {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: rgba(255, 255, 255, 0.2);
    color: white;
    border: none;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    cursor: pointer;
    transition: background-color var(--transition-base);
}

#active-hashtag-filter .clear-hashtag-btn:hover {
    background: rgba(255, 255, 255, 0.3);
}

.clear-filter-btn {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--error-color);
    color: white;
    border: none;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    cursor: pointer;
    transition: background-color var(--transition-base);
}

.clear-filter-btn:hover {
    background: #dc2626;
}

.clear-date-btn {
    margin-top: var(--spacing-sm);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--tertiary-bg);
    color: var(--secondary-text);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    cursor: pointer;
    transition: background-color var(--transition-base);
}

.clear-date-btn:hover {
    background: var(--quaternary-bg);
}

.page-actions .btn-primary {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--accent-color);
    color: white;
    border: none;
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: background-color var(--transition-base);
}

.page-actions .btn-primary:hover {
    background: var(--accent-hover);
}

/* Task Edit Modal */
.task-edit-container {
    padding: var(--spacing-md);
}

.task-edit-container .form-group {
    margin-bottom: var(--spacing-md);
}

.task-edit-container label {
    display: block;
    margin-bottom: var(--spacing-sm);
    font-weight: var(--font-weight-medium);
    color: var(--primary-text);
}

.task-edit-container input,
.task-edit-container textarea {
    width: 100%;
    padding: var(--spacing-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    transition: border-color var(--transition-base);
}

.task-edit-container input:focus,
.task-edit-container textarea:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(66, 165, 245, 0.1);
}

.task-edit-container textarea {
    resize: vertical;
    min-height: 80px;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-md);
}

.task-edit-container small {
    display: block;
    margin-top: var(--spacing-xs);
    font-size: var(--font-size-xs);
    color: var(--muted-text);
}

.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--border-color);
}

.btn-secondary {
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--tertiary-bg);
    color: var(--primary-text);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    cursor: pointer;
    transition: background-color var(--transition-base);
}

.btn-secondary:hover {
    background: var(--quaternary-bg);
}

.btn-primary {
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--accent-color);
    color: white;
    border: none;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: background-color var(--transition-base);
}

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

/* Delete button styling */
.task-action-btn.delete-btn {
    color: var(--error-color);
}

.task-action-btn.delete-btn:hover {
    background: var(--error-bg);
    color: #b91c1c;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .form-row {
        grid-template-columns: 1fr;
    }
    
    .page-actions {
        flex-direction: column;
        align-items: stretch;
        gap: 0.75rem;
        margin-bottom: 1rem;
    }
    
    .active-filter {
        order: 1;
        justify-content: center;
    }
    
    .page-actions .btn-primary {
        order: 2;
        align-self: center;
        min-width: 200px;
    }
    
    .form-actions {
        flex-direction: column;
    }
    
    .form-actions button {
        width: 100%;
    }
    
    /* Make task controls stack on mobile */
    .task-controls {
        display: flex;
        flex-direction: column;
        gap: 1rem;
        align-items: stretch;
        padding: 1rem;
        grid-template-columns: none;
    }
    
    .task-filters {
        display: flex;
        overflow-x: auto;
        gap: 0.5rem;
        width: 100%;
        order: 1;
        padding-bottom: 0.25rem;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }
    
    .task-filters::-webkit-scrollbar {
        display: none;
    }
    
    .task-filter-btn {
        padding: 0.75rem 1rem;
        font-size: 0.8rem;
        text-align: center;
        border-radius: 8px;
        min-height: 44px; /* Better touch target */
        white-space: nowrap;
        flex-shrink: 0;
    }
    
    .task-view-controls {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.5rem;
        width: 100%;
        order: 2;
    }
    
    .task-view-btn {
        padding: 0.75rem 0.5rem;
        font-size: 0.8rem;
        text-align: center;
        border-radius: 8px;
        min-height: 44px; /* Better touch target */
    }
    
    .task-sort {
        width: 100%;
        order: 3;
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
        align-items: stretch;
        justify-self: stretch;
    }
    
    .task-sort-label {
        display: block;
        margin-bottom: 0;
        font-weight: 600;
        text-align: center;
        font-size: 0.875rem;
    }
    
    .task-sort-select {
        width: 100%;
        padding: 0.75rem;
        font-size: 0.875rem;
        border-radius: 8px;
        min-height: 44px; /* Better touch target */
        min-width: auto;
    }
    
    /* Make table more mobile friendly */
    .tasks-table-container {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    
    .tasks-table {
        font-size: 0.8rem;
        min-width: 600px; /* Prevent table from being too cramped */
    }
    
    .task-content-cell {
        max-width: 200px;
        min-width: 120px;
    }
    
    .task-actions {
        gap: 0.25rem;
    }
    
    .task-action-btn {
        padding: 0.5rem;
        width: 36px;
        height: 36px;
        border-radius: 6px;
    }
    
    /* Better spacing for mobile */
    .page-header {
        padding: 1rem 0.5rem;
    }
    
    .page-content {
        padding: 0 0.5rem;
    }
}

@media (max-width: 480px) {
    .task-filter-btn {
        padding: 0.6rem 0.4rem;
        font-size: 0.75rem;
        flex: 1;
        min-width: 0;
        text-align: center;
    }
    
    .task-view-btn {
        padding: 0.6rem 0.4rem;
        font-size: 0.75rem;
    }
    
    .page-actions .btn-primary {
        padding: 0.75rem 1rem;
        font-size: 0.8rem;
        min-width: 180px;
    }
    
    .task-controls {
        padding: 0 0.25rem;
    }
    
    .tasks-table {
        font-size: 0.75rem;
    }
    
    .task-action-btn {
        width: 32px;
        height: 32px;
        padding: 0.4rem;
    }
}

/* Task Controls */
.task-controls {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--spacing-lg);
  align-items: center;
  margin-bottom: 5px;
  padding: var(--spacing-md);
  background: var(--secondary-bg);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-color);
}

/* Task Sort */
.task-sort {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  justify-self: end;
  margin-left: auto;
}

.task-sort-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--secondary-text);
  white-space: nowrap;
}

.task-sort-select {
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
  min-width: 200px;
  cursor: pointer;
}

.task-sort-select:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

/* Fix dropdown options styling */
.task-sort-select option {
  background: var(--primary-bg);
  color: var(--primary-text);
}

.task-view-controls {
  display: flex;
  gap: var(--spacing-xs);
}

.task-view-btn {
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--tertiary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.task-view-btn:hover {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
}

.task-view-btn.active {
  background: var(--accent-professional);
  color: white;
  border-color: var(--accent-professional);
  font-weight: var(--font-weight-medium);
}

/* Tasks Table */
.tasks-table-container {
  background: var(--primary-bg);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-color);
  overflow: hidden;
  margin-bottom: var(--spacing-lg);
}

.tasks-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--primary-bg);
}

.tasks-table th {
  background: var(--secondary-bg);
  padding: var(--spacing-md);
  text-align: left;
  font-weight: var(--font-weight-semibold);
  color: var(--primary-text);
  border-bottom: 2px solid var(--border-color);
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.tasks-table td {
  padding: var(--spacing-md);
  border-bottom: 1px solid var(--border-color);
  vertical-align: top;
}

.tasks-table tr:last-child td {
  border-bottom: none;
}

.tasks-table tr:hover {
  background: var(--tertiary-bg);
}

/* Table Column Sizes */
.task-checkbox-col {
  width: 60px;
  text-align: center;
}

.task-content-col {
  width: 40%;
  min-width: 200px;
}

.task-due-date-col {
  width: 120px;
}

.task-points-col {
  width: 80px;
  text-align: center;
}

.task-note-col {
  width: 120px;
}

.task-hashtags-col {
  width: 150px;
}

.task-actions-col {
  width: 100px;
  text-align: center;
}

/* Task Row Styles */
.task-row {
  transition: background-color var(--transition-base);
}

.task-row.completed {
  opacity: 0.7;
  background: var(--quaternary-bg);
}

.task-row.completed .task-content {
  text-decoration: line-through;
  color: var(--secondary-text);
}

/* Task Content Cell */
.task-content-cell {
  max-width: 0;
}

.task-content {
  font-size: var(--font-size-base);
  color: var(--primary-text);
  line-height: var(--line-height-normal);
  margin: 0;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

/* Editable Fields */
.task-field-editable {
  cursor: pointer;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-sm);
  transition: all var(--transition-base);
  border: 1px solid transparent;
}

.task-field-editable:hover {
  background: var(--tertiary-bg);
  border-color: var(--border-color);
}

.task-field-editable:focus {
  outline: none;
  border-color: var(--accent-color);
  background: var(--primary-bg);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

/* Due Date Styles */
.task-due-date {
  font-size: var(--font-size-sm);
  color: var(--primary-text);
  font-weight: var(--font-weight-medium);
}

.task-due-date.overdue {
  color: var(--error-color);
  font-weight: var(--font-weight-bold);
}

.task-due-date.today {
  color: var(--accent-warm);
  font-weight: var(--font-weight-bold);
}

.task-due-date.upcoming {
  color: var(--success-color);
}

/* Points Styles */
.task-points {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--accent-color);
  background: rgba(59, 130, 246, 0.1);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-full);
  display: inline-block;
  min-width: 30px;
  text-align: center;
}

/* Note Link Styles */
.task-note-link {
  color: var(--accent-color);
  text-decoration: none;
  font-size: var(--font-size-sm);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-sm);
  transition: all var(--transition-base);
}

.task-note-link:hover {
  background: var(--tertiary-bg);
  color: var(--accent-professional);
}

/* Hashtags Styles */
.task-hashtags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
}

.task-hashtag {
  background: var(--tertiary-bg);
  color: var(--accent-color);
  padding: 2px var(--spacing-xs);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  transition: all var(--transition-base);
}

.task-hashtag:hover {
  background: var(--accent-color);
  color: white;
}

/* Actions Styles */
.task-actions {
  display: flex;
  gap: var(--spacing-xs);
  justify-content: center;
}

.task-action-btn {
  padding: var(--spacing-xs);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--secondary-text);
  cursor: pointer;
  transition: all var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
}

.task-action-btn:hover {
  border-color: var(--accent-color);
  color: var(--accent-color);
  background: var(--tertiary-bg);
}

/* Hashtag View */
.hashtag-view {
  margin-bottom: var(--spacing-lg);
}

.hashtag-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--spacing-md);
}

.hashtag-group {
  background: var(--secondary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--spacing-md);
}

.hashtag-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-md);
  padding-bottom: var(--spacing-sm);
  border-bottom: 1px solid var(--border-color);
}

.hashtag-name {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--accent-color);
}

.hashtag-stats {
  display: flex;
  gap: var(--spacing-md);
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
}

.hashtag-stat {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.hashtag-tasks {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.hashtag-task {
  padding: var(--spacing-sm);
  background: var(--primary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
}

/* Form Elements for Editing */
.task-edit-input,
.task-edit-select {
  width: 100%;
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
}

.task-edit-input:focus,
.task-edit-select:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

/* Loading and Empty States */
.tasks-table-container.empty {
  display: none;
}

.hashtag-view.empty {
  display: none;
}

/* Task Item */
.task-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md) var(--spacing-lg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--secondary-bg);
  transition: all var(--transition-base);
  box-shadow: var(--shadow);
  position: relative;
}

.task-item:hover {
  border-color: var(--accent-color);
  background: var(--tertiary-bg);
  box-shadow: var(--shadow-lg);
  transform: translateY(-1px);
}

.task-item.completed {
  opacity: 0.7;
  background: var(--quaternary-bg);
}

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

/* Task Content */
.task-content {
  flex: 1;
  min-width: 0;
}

.task-text {
  font-size: var(--font-size-base);
  color: var(--primary-text);
  margin-bottom: var(--spacing-xs);
  word-wrap: break-word;
  line-height: var(--line-height-normal);
  font-weight: var(--font-weight-normal);
}

.task-meta {
  display: flex;
  gap: var(--spacing-md);
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  flex-wrap: wrap;
  align-items: center;
}

.task-date {
  font-weight: var(--font-weight-semibold);
  color: var(--accent-color);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.task-level {
  opacity: 0.7;
  background: var(--tertiary-bg);
  padding: 2px var(--spacing-xs);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.task-priority {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
}

.task-priority.high {
  background: rgba(220, 53, 69, 0.1);
  color: var(--error-color);
}

.task-priority.medium {
  background: rgba(245, 158, 11, 0.1);
  color: #f59e0b;
}

.task-priority.low {
  background: rgba(16, 185, 129, 0.1);
  color: #10b981;
}

/* Task Field Editing Modals */
.points-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-md);
}

.points-option {
  padding: var(--spacing-md);
  border: 2px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  cursor: pointer;
  transition: all var(--transition-base);
  text-align: center;
  min-height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.points-option:hover {
  border-color: var(--accent-color);
  background: var(--tertiary-bg);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.points-option.selected {
  border-color: var(--accent-color);
  background: var(--accent-color);
  color: white;
  box-shadow: var(--shadow-lg);
}

.form-input {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-base);
  transition: border-color var(--transition-base);
}

.form-input:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

.form-group {
  margin-bottom: var(--spacing-md);
}

.form-group label {
  display: block;
  margin-bottom: var(--spacing-xs);
  font-weight: var(--font-weight-medium);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
}

/* Mobile responsive for points grid */
@media (max-width: 480px) {
  .points-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .points-option {
    padding: var(--spacing-sm);
    font-size: var(--font-size-base);
    min-height: 50px;
  }
}

/* Task Actions */
.task-actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-shrink: 0;
}

.task-checkbox {
  width: 20px;
  height: 20px;
  border: 2px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  cursor: pointer;
  transition: all var(--transition-base);
  position: relative;
  flex-shrink: 0;
}

.task-checkbox:hover {
  border-color: var(--accent-color);
  background: var(--tertiary-bg);
}

.task-checkbox.checked {
  background: var(--accent-color);
  border-color: var(--accent-color);
}

.task-checkbox.checked::after {
  content: '';
  position: absolute;
  left: 6px;
  top: 2px;
  width: 4px;
  height: 8px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.task-goto-btn {
  flex-shrink: 0;
  padding: var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--secondary-text);
  cursor: pointer;
  transition: all var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  min-height: 36px;
  text-decoration: none;
}

.task-goto-btn:hover {
  border-color: var(--accent-color);
  color: var(--accent-color);
  background: var(--tertiary-bg);
  transform: translateX(2px);
}

/* Task Filters */
.task-filters {
  display: flex;
  gap: var(--spacing-sm);
  margin-bottom: 0;
  flex-wrap: wrap;
}

.task-filter-btn {
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--tertiary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
  position: relative;
}

.task-filter-btn:hover {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
}

.task-filter-btn.active {
  background: var(--accent-professional);
  color: white;
  border-color: var(--accent-professional);
  font-weight: var(--font-weight-medium);
}

.task-filter-count {
  background: var(--accent-warm);
  color: var(--accent-professional);
  font-size: var(--font-size-xs);
  padding: 2px 6px;
  border-radius: var(--radius-full);
  margin-left: var(--spacing-xs);
  font-weight: var(--font-weight-semibold);
}

/* Task Statistics */
.task-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
  padding: var(--spacing-lg);
  background: var(--secondary-bg);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-color);
}

.task-stat {
  text-align: center;
  padding: var(--spacing-md);
  background: var(--primary-bg);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-color);
}

.task-stat-value {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--accent-color);
  margin-bottom: var(--spacing-xs);
}

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

/* Task Search */
.task-search {
  position: relative;
  margin-bottom: var(--spacing-lg);
}

.task-search-input {
  width: 100%;
  padding: var(--spacing-md);
  padding-right: 40px;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-base);
  transition: all var(--transition-base);
}

.task-search-input:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.task-search-clear {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--secondary-text);
  cursor: pointer;
  padding: var(--spacing-xs);
  border-radius: var(--radius-sm);
  transition: all var(--transition-base);
}

.task-search-clear:hover {
  background: var(--tertiary-bg);
  color: var(--primary-text);
}

/* Task Sorting */
.task-sort {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: 0;
}

.task-sort-label {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  font-weight: var(--font-weight-medium);
}

.task-sort-select {
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
}

/* Task Loading State */
.tasks-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
  color: var(--secondary-text);
}

.tasks-loading .spinner {
  width: 24px;
  height: 24px;
  border: 2px solid var(--border-color);
  border-top: 2px solid var(--accent-color);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-right: var(--spacing-sm);
}

/* Task Error State */
.tasks-error {
  padding: var(--spacing-lg);
  text-align: center;
  color: var(--error-color);
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid var(--error-color);
  border-radius: var(--radius-md);
}

/* Tasks Modal Specific */
.tasks-container {
  padding: var(--spacing-lg);
}

.tasks-modal .modal-content {
  max-width: 900px;
}

.no-tasks {
  text-align: center;
  padding: var(--spacing-xl);
  color: var(--secondary-text);
}

.no-tasks h3 {
  margin-bottom: var(--spacing-md);
  color: var(--primary-text);
}

.no-tasks p {
  margin-bottom: var(--spacing-sm);
  line-height: var(--line-height-relaxed);
}

/* Tablet Responsive */
@media (min-width: 769px) and (max-width: 1024px) {
  .task-item {
    padding: var(--spacing-sm) var(--spacing-md);
  }
  
  .task-text {
    font-size: var(--font-size-sm);
  }
  
  .task-meta {
    gap: var(--spacing-sm);
  }
  
  .task-goto-btn {
    min-width: 32px;
    min-height: 32px;
  }
  
  .task-stats {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-sm);
  }
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .task-item {
    padding: var(--spacing-sm) var(--spacing-md);
    gap: var(--spacing-sm);
  }
  
  .task-content {
    flex: 1;
    min-width: 0;
  }
  
  .task-text {
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-xs);
  }
  
  .task-meta {
    gap: var(--spacing-sm);
    flex-wrap: wrap;
  }
  
  .task-date {
    font-size: var(--font-size-xs);
  }
  
  .task-level {
    font-size: 10px;
    padding: 1px var(--spacing-xs);
  }
  
  .task-goto-btn {
    min-width: 32px;
    min-height: 32px;
    padding: var(--spacing-xs);
  }
  
  .task-goto-btn svg {
    width: 14px;
    height: 14px;
  }
  
  .task-filters {
    justify-content: space-between;
    gap: var(--spacing-xs);
  }
  
  .task-stats {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
  }
  
  .task-sort {
    flex-direction: column;
    align-items: stretch;
  }
  
  .task-sort-select {
    width: 100%;
  }
}

@media (max-width: 480px) {
  .tasks-list {
    gap: var(--spacing-xs);
  }
  
  .task-item {
    padding: var(--spacing-sm);
    border-radius: var(--radius-sm);
  }
  
  .task-text {
    font-size: var(--font-size-sm);
    line-height: 1.4;
  }
  
  .task-meta {
    gap: var(--spacing-xs);
  }
  
  .task-date {
    font-size: 11px;
  }
  
  .task-level {
    font-size: 9px;
    padding: 1px 4px;
  }
  
  .task-goto-btn {
    min-width: 28px;
    min-height: 28px;
    padding: 4px;
  }
  
  .task-goto-btn svg {
    width: 12px;
    height: 12px;
  }
  
  .task-stats {
    grid-template-columns: 1fr;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm);
  }
  
  .task-stat {
    padding: var(--spacing-sm);
  }
  
  .task-stat-value {
    font-size: var(--font-size-xl);
  }
  
  .task-filters {
    gap: var(--spacing-xs);
  }
  
  .task-filter-btn {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-xs);
  }
}

/* Focus States */
.task-checkbox:focus-visible,
.task-goto-btn:focus-visible,
.task-filter-btn:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .task-item {
    border-width: 2px;
  }
  
  .task-checkbox {
    border-width: 2px;
  }
  
  .task-priority.high,
  .task-priority.medium,
  .task-priority.low {
    border: 1px solid currentColor;
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .task-item:hover {
    transform: none;
  }
  
  .task-goto-btn:hover {
    transform: none;
  }
  
  .tasks-loading .spinner {
    animation: none;
  }
}

/* Touch Improvements */
.task-checkbox,
.task-goto-btn,
.task-filter-btn {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Print Styles */
@media print {
  .task-filters,
  .task-search,
  .task-sort,
  .task-actions {
    display: none;
  }
  
  .task-item {
    break-inside: avoid;
    box-shadow: none;
    border: 1px solid #ccc;
  }
  
  .task-stats {
    break-inside: avoid;
  }
}
/* === pages/settings.css === */
/* Settings Page Styles */

/* Settings Container */
.settings-container {
  padding: var(--spacing-lg);
  max-width: 900px;
  margin: 0 auto;
}

/* Settings Form */
.settings-form {
  max-width: 100%;
  margin: 0 auto;
}

.settings-section {
  margin-bottom: var(--spacing-xl);
  padding: var(--spacing-lg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  background: var(--secondary-bg);
  position: relative;
  transition: border-color var(--transition-fast);
}

.settings-section:hover {
  border-color: rgba(255, 255, 255, 0.12);
}

.settings-section:last-child {
  margin-bottom: 0;
}

/* Settings Section Header */
.section-header {
  margin-bottom: var(--spacing-lg);
  padding-bottom: var(--spacing-md);
  border-bottom: 1px solid var(--border-color);
}

.section-header h3 {
  margin: 0 0 var(--spacing-xs) 0;
  color: var(--primary-text);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  letter-spacing: -0.01em;
}

.section-header p {
  margin: 0;
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
}

.section-icon {
  width: 28px;
  height: 28px;
  color: var(--accent-color);
  flex-shrink: 0;
  filter: drop-shadow(0 2px 4px rgba(59, 130, 246, 0.3));
}

/* Form Grid */
.form-grid {
  display: grid;
  gap: var(--spacing-md);
}

.form-grid.two-column {
  grid-template-columns: 1fr 1fr;
}

/* Settings Actions */
.settings-actions {
  display: flex;
  gap: var(--spacing-md);
  justify-content: flex-end;
  margin-top: var(--spacing-xl);
  padding-top: var(--spacing-lg);
  border-top: 1px solid var(--border-color);
}

/* Settings Tabs */
.settings-tabs {
  display: flex;
  border-bottom: 1px solid var(--border-color);
  margin-bottom: var(--spacing-xl);
  background: var(--secondary-bg);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  overflow: hidden;
}

.settings-tab {
  flex: 1;
  padding: var(--spacing-md) var(--spacing-lg);
  background: transparent;
  border: none;
  border-bottom: 3px solid transparent;
  color: var(--secondary-text);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
}

.settings-tab:hover {
  color: var(--primary-text);
  background: var(--tertiary-bg);
}

.settings-tab.active {
  color: var(--accent-color);
  background: var(--primary-bg);
  border-bottom-color: var(--accent-color);
}

.settings-tab-icon {
  width: 20px;
  height: 20px;
}

/* Settings Content */
.settings-content {
  display: none;
}

.settings-content.active {
  display: block;
}

/* Profile Settings */
.profile-avatar {
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-lg);
}

.avatar-image {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--accent-color);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
}

.avatar-upload {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.avatar-upload-btn {
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--tertiary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
}

.avatar-upload-btn:hover {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
}

.avatar-help {
  font-size: var(--font-size-xs);
  color: var(--secondary-text);
}

/* Preference Settings */
.preference-group {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md);
  background: var(--primary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-md);
  transition: border-color var(--transition-fast);
}

.preference-group:hover {
  border-color: rgba(255, 255, 255, 0.12);
}

.preference-info {
  flex: 1;
  padding-right: var(--spacing-md);
}

.preference-title {
  font-weight: var(--font-weight-medium);
  color: var(--primary-text);
  margin-bottom: var(--spacing-xs);
  font-size: var(--font-size-base);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.preference-description {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  line-height: var(--line-height-relaxed);
}

.preference-control {
  flex-shrink: 0;
  margin-left: var(--spacing-md);
}

/* Toggle Switch */
.toggle-switch {
  position: relative;
  width: 48px;
  height: 26px;
  background: var(--quaternary-bg);
  border-radius: 13px;
  cursor: pointer;
  transition: background var(--transition-base);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.15);
}

.toggle-switch:hover {
  background: var(--border-light);
}

.toggle-switch.active {
  background: var(--accent-color);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1);
}

.toggle-switch.active:hover {
  background: var(--accent-hover);
}

.toggle-switch::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  background: white;
  border-radius: 50%;
  transition: transform var(--transition-base);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}

.toggle-switch.active::after {
  transform: translateX(22px);
}

/* Select Dropdown */
.settings-select {
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-size: var(--font-size-sm);
  cursor: pointer;
  min-width: 160px;
  transition: border-color var(--transition-base), box-shadow var(--transition-base);
  font-weight: var(--font-weight-normal);
}

.settings-select:hover {
  border-color: var(--accent-color);
}

.settings-select:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(66, 165, 245, 0.15);
}

/* Danger Zone */
.danger-zone {
  border-color: var(--error-color);
  background: linear-gradient(135deg, rgba(220, 53, 69, 0.08) 0%, rgba(220, 53, 69, 0.03) 100%);
}

.danger-zone::before {
  background: linear-gradient(90deg, var(--error-color), #dc2626);
}

.danger-zone .section-header {
  border-bottom-color: rgba(220, 53, 69, 0.3);
}

.danger-zone .section-header h3 {
  color: var(--error-color);
}

.danger-zone .section-icon {
  color: var(--error-color);
  filter: drop-shadow(0 2px 4px rgba(220, 53, 69, 0.3));
}

.danger-action {
  background: var(--error-color);
  color: white;
  border: 1px solid var(--error-color);
}

.danger-action:hover {
  background: #c82333;
  border-color: #c82333;
}

/* Settings Success/Error Messages */
.settings-message {
  padding: var(--spacing-md);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-lg);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.settings-message.success {
  background: rgba(40, 167, 69, 0.1);
  border: 1px solid var(--success-color);
  color: var(--success-color);
}

.settings-message.error {
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid var(--error-color);
  color: var(--error-color);
}

.settings-message.info {
  background: rgba(59, 130, 246, 0.1);
  border: 1px solid var(--accent-color);
  color: var(--accent-color);
}

.settings-message-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

/* Settings Loading State */
.settings-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
  color: var(--secondary-text);
}

.settings-loading .spinner {
  width: 24px;
  height: 24px;
  border: 2px solid var(--border-color);
  border-top: 2px solid var(--accent-color);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-right: var(--spacing-sm);
}

/* Data Export/Import */
.data-actions {
  display: flex;
  gap: var(--spacing-md);
  flex-wrap: wrap;
}

.data-action-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-md) var(--spacing-lg);
  background: var(--tertiary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  color: var(--primary-text);
  text-decoration: none;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all var(--transition-base);
}

.data-action-btn:hover {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
  transform: translateY(-1px);
}

.data-action-icon {
  width: 18px;
  height: 18px;
}

/* Storage Usage */
.storage-usage {
  background: var(--primary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--spacing-lg);
}

.storage-bar {
  width: 100%;
  height: 8px;
  background: var(--tertiary-bg);
  border-radius: var(--radius-sm);
  overflow: hidden;
  margin: var(--spacing-md) 0;
}

.storage-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent-color), var(--accent-warm));
  transition: width var(--transition-base);
}

.storage-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
}

.storage-used {
  font-weight: var(--font-weight-medium);
  color: var(--primary-text);
}

/* Tablet and Desktop Responsive Optimizations */
@media (min-width: 769px) {
  .settings-section {
    padding: var(--spacing-lg);
  }
  
  .form-grid {
    gap: var(--spacing-md);
  }
  
  .section-header {
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
  }
}

@media (min-width: 1201px) {
  .settings-container {
    padding: var(--spacing-xl);
  }
  
  .settings-section {
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-lg);
  }
  
  .form-grid {
    gap: var(--spacing-sm);
  }
  
  .section-header {
    margin-bottom: var(--spacing-lg);
  }
  
  .settings-actions {
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-md);
  }
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .settings-container {
    padding: var(--spacing-md);
  }
  
  .settings-section {
    padding: var(--spacing-md);
  }
  
  .settings-actions {
    flex-direction: column;
  }
  
  .settings-actions .action-btn {
    width: 100%;
  }
  
  .settings-tabs {
    flex-direction: column;
  }
  
  .settings-tab {
    border-bottom: none;
    border-right: 3px solid transparent;
    justify-content: flex-start;
    padding: var(--spacing-sm) var(--spacing-md);
  }
  
  .settings-tab.active {
    border-right-color: var(--accent-color);
    border-bottom-color: transparent;
  }
  
  .form-grid.two-column {
    grid-template-columns: 1fr;
  }
  
  .profile-avatar {
    flex-direction: column;
    text-align: center;
  }
  
  .preference-group {
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-md);
  }
  
  .preference-control {
    margin-left: 0;
    align-self: flex-end;
  }
  
  .data-actions {
    flex-direction: column;
  }
  
  .data-action-btn {
    justify-content: center;
  }
}

@media (max-width: 480px) {
  .settings-section {
    margin-bottom: var(--spacing-lg);
  }
  
  .avatar-image {
    width: 60px;
    height: 60px;
    font-size: var(--font-size-xl);
  }
  
  .settings-tab {
    padding: var(--spacing-sm);
    font-size: var(--font-size-sm);
  }
  
  .preference-group {
    padding: var(--spacing-sm);
  }
}

/* Focus States */
.settings-tab:focus-visible,
.toggle-switch:focus-visible,
.avatar-upload-btn:focus-visible,
.data-action-btn:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .settings-section,
  .preference-group,
  .storage-usage {
    border-width: 2px;
  }
  
  .toggle-switch {
    border: 1px solid var(--border-color);
  }
  
  .toggle-switch.active {
    border-color: var(--accent-color);
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .toggle-switch::after {
    transition: none;
  }
  
  .data-action-btn:hover {
    transform: none;
  }
  
  .settings-loading .spinner {
    animation: none;
  }
}

/* Touch Improvements */
.settings-tab,
.toggle-switch,
.avatar-upload-btn,
.data-action-btn {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Print Styles */
@media print {
  .settings-actions,
  .data-actions,
  .avatar-upload {
    display: none;
  }
  
  .settings-section {
    break-inside: avoid;
    box-shadow: none;
  }
  
  .settings-tabs {
    display: none;
  }
  
  .settings-content {
    display: block !important;
  }
}
/* === pages/hashtag-page.css === */
/* Hashtag Page Styles — using design system variables */

/* Thread boundary visual feedback */
.thread-boundary {
    border-top: 2px solid var(--border-color);
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-sm);
}

.thread-contains-match {
    background-color: rgba(251, 191, 36, 0.1);
    border-left: 3px solid var(--warning-color);
    padding-left: var(--spacing-xs);
    margin-left: calc(var(--spacing-xs) * -1);
}

.thread-group {
    position: relative;
    margin-bottom: var(--spacing-md);
}

.thread-group:hover {
    background-color: rgba(66, 165, 245, 0.05);
    border-radius: var(--radius-sm);
}

.thread-collapse-toggle {
    position: absolute;
    left: -25px;
    top: 5px;
    cursor: pointer;
    color: var(--secondary-text);
    font-size: var(--font-size-xs);
    transition: transform var(--transition-base);
}

.thread-collapse-toggle:hover {
    color: var(--accent-color);
}

.thread-collapse-toggle.collapsed {
    transform: rotate(-90deg);
}

.thread-collapsed .bullet-item[data-level]:not([data-level="0"]) {
    display: none !important;
}

.hashtag-page-container {
    max-width: 900px;
    margin: 0 auto;
    padding: var(--spacing-xl) var(--spacing-md);
    min-height: 100vh;
}

.hashtag-page-header {
    margin-bottom: var(--spacing-xl);
    padding-bottom: var(--spacing-md);
    border-bottom: 2px solid var(--border-color);
}

.hashtag-page-title {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.hashtag-page-title h1 {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-semibold);
    color: var(--primary-text);
    margin: 0;
}

.hashtag-page-title .hashtag-symbol {
    color: var(--accent-color);
    font-weight: var(--font-weight-bold);
}

.hashtag-page-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    color: var(--secondary-text);
    font-size: var(--font-size-sm);
}

.hashtag-page-back {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--accent-color);
    text-decoration: none;
    font-weight: var(--font-weight-medium);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    transition: background-color var(--transition-base);
}

.hashtag-page-back:hover {
    background-color: var(--tertiary-bg);
}

.hashtag-page-back::before {
    content: '←';
    font-size: var(--font-size-lg);
}

.hashtag-date-group {
    margin-bottom: var(--spacing-xl);
}

.hashtag-date-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background: linear-gradient(135deg, var(--accent-color) 0%, var(--accent-hover) 100%);
    color: white;
    border-radius: var(--radius-lg);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-base);
    cursor: pointer;
    transition: box-shadow var(--transition-base);
}

.hashtag-date-header:hover {
    box-shadow: var(--shadow-sm);
}

.hashtag-date-header::before {
    content: '📅';
    font-size: var(--font-size-lg);
}

.hashtag-bullet-list {
    margin-top: var(--spacing-md);
}

/* Use the same bullet styles as the notes page */
.hashtag-page-container .bullet-item {
    margin-bottom: var(--spacing-sm);
}

/* Highlight matching bullets */
.hashtag-page-container .bullet-item.is-match {
    background: rgba(59, 130, 246, 0.03);
    border-left: 3px solid var(--accent-color);
    padding-left: 0.5rem;
    margin-left: -0.5rem;
    border-radius: 4px;
}

.hashtag-page-container .bullet-item.is-match .bullet-dot {
    background: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
}

/* Save indicator */
.hashtag-save-indicator {
    position: fixed;
    bottom: var(--spacing-xl);
    right: var(--spacing-xl);
    padding: var(--spacing-sm) var(--spacing-lg);
    background: var(--secondary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--primary-text);
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.3s;
    pointer-events: none;
    z-index: var(--z-toast);
}

.hashtag-save-indicator.visible {
    opacity: 1;
    transform: translateY(0);
}

.hashtag-save-indicator.saving {
    color: var(--warning-color);
}

.hashtag-save-indicator.saved {
    color: var(--success-color);
}

.hashtag-save-indicator.error {
    color: var(--error-color);
}

/* Loading state */
.hashtag-page-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 400px;
    gap: var(--spacing-md);
}

.hashtag-page-loading .spinner {
    width: 40px;
    height: 40px;
    border: 4px solid var(--border-color);
    border-top-color: var(--accent-color);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

/* @keyframes spin defined in utilities.css */

/* Empty state */
.hashtag-page-empty {
    text-align: center;
    padding: var(--spacing-xl) var(--spacing-xl);
    color: var(--secondary-text);
}

.hashtag-page-empty h2 {
    font-size: var(--font-size-2xl);
    margin-bottom: var(--spacing-sm);
    color: var(--primary-text);
}

/* Responsive */
@media (max-width: 768px) {
    .hashtag-page-container {
        padding: var(--spacing-md) var(--spacing-sm);
    }
    
    .hashtag-page-title h1 {
        font-size: var(--font-size-2xl);
    }
    
    .hashtag-bullet-item.level-1 {
        padding-left: var(--spacing-lg);
    }
    
    .hashtag-bullet-item.level-2 {
        padding-left: calc(var(--spacing-lg) * 2);
    }
    
    .hashtag-bullet-item.level-3 {
        padding-left: calc(var(--spacing-lg) * 3);
    }
    
    .hashtag-bullet-item.level-4 {
        padding-left: calc(var(--spacing-lg) * 4);
    }
    
    .hashtag-save-indicator {
        bottom: var(--spacing-md);
        right: var(--spacing-md);
        font-size: var(--font-size-xs);
        padding: var(--spacing-sm) var(--spacing-md);
    }
}
/* === pages/hashtag-directory.css === */
/* Hashtag Directory Page Styles — using design system variables */

/* Page Controls */
.hashtag-directory-controls {
    margin-bottom: var(--spacing-lg);
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: var(--spacing-md);
}

.hashtag-sort {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.hashtag-sort-label {
    font-size: var(--font-size-sm);
    color: var(--secondary-text);
    font-weight: var(--font-weight-medium);
}

.hashtag-sort-select {
    padding: var(--spacing-xs) var(--spacing-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--primary-bg);
    color: var(--primary-text);
    font-size: var(--font-size-sm);
    min-width: 200px;
    cursor: pointer;
}

.hashtag-sort-select:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

/* Fix dropdown options styling */
.hashtag-sort-select option {
    background: var(--primary-bg);
    color: var(--primary-text);
}

/* Hashtag Directory Grid */
.hashtag-directory-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.hashtag-directory-card {
    background: var(--tertiary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    transition: border-color var(--transition-base), box-shadow var(--transition-base);
    box-shadow: var(--shadow-xs);
    cursor: pointer;
}

.hashtag-directory-card:hover {
    box-shadow: var(--shadow-sm);
    border-color: var(--accent-color);
    background: var(--quaternary-bg);
}

.hashtag-card-content {
    margin-bottom: 0;
}

.hashtag-name {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--primary-text);
    margin: 0 0 var(--spacing-sm) 0;
    word-break: break-word;
}

.hashtag-stats {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    font-size: var(--font-size-sm);
    color: var(--secondary-text);
}

.hashtag-count {
    font-weight: var(--font-weight-medium);
    color: var(--accent-color);
}

.hashtag-last-used {
    font-size: var(--font-size-xs);
    color: var(--muted-text);
}

/* Remove explicit view button - hashtag cards are now clickable */
.hashtag-card-actions {
    display: none;
}

/* Loading State */
.hashtag-directory-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-xl);
    text-align: center;
    color: var(--secondary-text);
}

.hashtag-directory-loading .spinner {
    margin-bottom: var(--spacing-md);
}

/* No Hashtags State */
#no-hashtags {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--secondary-text);
}

#no-hashtags .no-content-icon {
    margin-bottom: var(--spacing-md);
    color: var(--muted-text);
}

#no-hashtags h3 {
    margin-bottom: var(--spacing-sm);
    color: var(--primary-text);
}

/* Responsive Design */
@media (max-width: 768px) {
    .hashtag-directory-grid {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
        gap: var(--spacing-sm);
    }
    
    .hashtag-directory-card {
        padding: var(--spacing-md);
    }
    
    .hashtag-directory-controls {
        justify-content: space-between;
    }
}

@media (max-width: 480px) {
    .hashtag-directory-grid {
        grid-template-columns: 1fr;
    }
    
    .hashtag-directory-controls {
        flex-direction: column;
        align-items: stretch;
    }
    
    .hashtag-sort {
        justify-content: space-between;
    }
}
/* === features/drag-drop.css === */
/* ITCSS Layer: Features */
/* Drag and Drop System */

/* Drag Handle */
.drag-handle {
  cursor: grab;
  padding: 6px;
  border-radius: var(--radius-sm);
  opacity: 0.5;
  transition: opacity var(--transition-base);
  margin-left: 4px;
  color: var(--secondary-text);
}

.drag-handle:hover {
  opacity: 1;
  background: var(--tertiary-bg);
  color: var(--primary-text);
}

.drag-handle:active {
  cursor: grabbing;
}

/* Dragging State — just dim, no layout shift */
.bullet-item.dragging {
  opacity: 0.3;
}

/* Enhanced Drop Indicators */
.drop-indicator {
  position: relative;
  height: 3px;
  background: var(--accent-color);
  margin: 4px 0;
  border-radius: 2px;
  opacity: 0.9;
  transition: opacity 0.1s ease;
  box-shadow: 0 0 8px rgba(59, 130, 246, 0.4);
  display: block;
  visibility: visible;
  z-index: 10000;
  width: 100%;
}

.drop-indicator.hidden {
  display: none;
  opacity: 0;
}

.drop-indicator::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 12px solid var(--accent-color);
  margin-left: -12px;
}

.drop-indicator::after {
  content: attr(data-level-text);
  position: absolute;
  right: -80px;
  top: -15px;
  background: var(--accent-color);
  color: white;
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
  opacity: 0.95;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  pointer-events: none;
}

/* Level-specific Drop Indicators */
.drop-indicator.level-0 {
  margin-left: 0;
  width: 100%;
}

.drop-indicator.level-0::after {
  content: "Top Level";
}

.drop-indicator.level-1 {
  margin-left: var(--indent-base);
  width: calc(100% - var(--indent-base));
}

.drop-indicator.level-1::after {
  content: "Sub-bullet";
}

.drop-indicator.level-2 {
  margin-left: calc(var(--indent-base) * 2);
  width: calc(100% - calc(var(--indent-base) * 2));
}

.drop-indicator.level-2::after {
  content: "Level 2";
}

.drop-indicator.level-3 {
  margin-left: calc(var(--indent-base) * 3);
  width: calc(100% - calc(var(--indent-base) * 3));
}

.drop-indicator.level-3::after {
  content: "Level 3";
}

.drop-indicator.level-4 {
  margin-left: calc(var(--indent-base) * 4);
  width: calc(100% - calc(var(--indent-base) * 4));
}

.drop-indicator.level-4::after {
  content: "Level 4";
}

.drop-indicator.level-5 {
  margin-left: calc(var(--indent-base) * 5);
  width: calc(100% - calc(var(--indent-base) * 5));
}

.drop-indicator.level-5::after {
  content: "Level 5";
}

.drop-indicator.level-6 {
  margin-left: calc(var(--indent-base) * 6);
  width: calc(100% - calc(var(--indent-base) * 6));
}

.drop-indicator.level-6::after {
  content: "Level 6";
}

.drop-indicator.level-7 {
  margin-left: calc(var(--indent-base) * 7);
  width: calc(100% - calc(var(--indent-base) * 7));
}

.drop-indicator.level-7::after {
  content: "Level 7";
}

/* Visual feedback during drag — minimal, no layout shifts */
.bullet-item.drag-over {
  /* Drop indicator line is sufficient — no background change needed */
}

/* Removed translateY shifts on neighboring items — they cause disorienting layout jumps */

.drop-target {
  background: rgba(59, 130, 246, 0.1);
  border: 1px dashed var(--accent-color);
  border-radius: var(--radius-sm);
}

/* Drag Ghost */
.drag-ghost {
  position: fixed;
  pointer-events: none;
  z-index: 10001;
  background: var(--primary-bg);
  border: 1px solid var(--accent-color);
  border-radius: var(--radius-sm);
  padding: var(--spacing-sm);
  box-shadow: var(--shadow-lg);
  opacity: 0.9;
  transform: rotate(2deg);
  max-width: 300px;
  font-size: var(--font-size-sm);
  color: var(--primary-text);
}

/* Drag Placeholder */
.drag-placeholder {
  height: 40px;
  background: rgba(59, 130, 246, 0.1);
  border: 2px dashed var(--accent-color);
  border-radius: var(--radius-md);
  margin: var(--spacing-sm) 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-color);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  animation: dragPlaceholderPulse 2s ease-in-out infinite;
}

@keyframes dragPlaceholderPulse {
  0%, 100% {
    opacity: 0.5;
  }
  50% {
    opacity: 1;
  }
}

/* Drag Zone Highlighting */
.drag-zone {
  position: relative;
}

.drag-zone.drag-over {
  background: rgba(59, 130, 246, 0.05);
  border-radius: var(--radius-md);
}

.drag-zone.drag-over::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border: 2px dashed var(--accent-color);
  border-radius: var(--radius-md);
  pointer-events: none;
  animation: dragZonePulse 1s ease-in-out infinite;
}

@keyframes dragZonePulse {
  0%, 100% {
    opacity: 0.3;
  }
  50% {
    opacity: 0.7;
  }
}

/* Drag Feedback */
.drag-feedback {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--accent-color);
  color: white;
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  z-index: 10002;
  opacity: 0;
  transform: translateX(-50%) translateY(-10px);
  transition: all var(--transition-base);
  pointer-events: none;
}

.drag-feedback.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.drag-feedback.success {
  background: var(--success-color);
}

.drag-feedback.error {
  background: var(--error-color);
}

/* Sortable List States */
.sortable-list {
  position: relative;
}

.sortable-list.sorting {
  user-select: none;
}

.sortable-item {
  position: relative;
  transition: transform var(--transition-base);
}

.sortable-item.sortable-chosen {
  opacity: 0.8;
}

.sortable-item.sortable-ghost {
  opacity: 0.4;
  background: var(--tertiary-bg);
}

/* Touch Drag Support */
.drag-handle {
  touch-action: none;
}

/* Mobile Drag Adjustments */
@media (max-width: 768px) {
  .drag-handle {
    opacity: 1; /* Always visible on mobile */
    padding: var(--spacing-sm);
    margin-left: var(--spacing-xs);
  }
  
  .drop-indicator::after {
    right: -60px;
    font-size: 10px;
    padding: 2px 6px;
  }
  
  .drag-ghost {
    max-width: 250px;
    font-size: var(--font-size-xs);
  }
  
  .drag-placeholder {
    height: 36px;
    font-size: var(--font-size-xs);
  }
  
  /* Adjust drop indicator margins for mobile indentation */
  .drop-indicator.level-1 {
    margin-left: var(--indent-mobile);
    width: calc(100% - var(--indent-mobile));
  }
  
  .drop-indicator.level-2 {
    margin-left: calc(var(--indent-mobile) * 2);
    width: calc(100% - calc(var(--indent-mobile) * 2));
  }
  
  .drop-indicator.level-3 {
    margin-left: calc(var(--indent-mobile) * 3);
    width: calc(100% - calc(var(--indent-mobile) * 3));
  }
  
  .drop-indicator.level-4 {
    margin-left: calc(var(--indent-mobile) * 4);
    width: calc(100% - calc(var(--indent-mobile) * 4));
  }

  .drop-indicator.level-5 {
    margin-left: calc(var(--indent-mobile) * 5);
    width: calc(100% - calc(var(--indent-mobile) * 5));
  }

  .drop-indicator.level-6 {
    margin-left: calc(var(--indent-mobile) * 6);
    width: calc(100% - calc(var(--indent-mobile) * 6));
  }

  .drop-indicator.level-7 {
    margin-left: calc(var(--indent-mobile) * 7);
    width: calc(100% - calc(var(--indent-mobile) * 7));
  }
}

@media (max-width: 480px) {
  .drop-indicator::after {
    display: none; /* Hide level text on very small screens */
  }
  
  .drag-feedback {
    font-size: var(--font-size-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
  }
  
  /* Adjust for small mobile indentation */
  .drop-indicator.level-1 {
    margin-left: var(--indent-small);
    width: calc(100% - var(--indent-small));
  }
  
  .drop-indicator.level-2 {
    margin-left: calc(var(--indent-small) * 2);
    width: calc(100% - calc(var(--indent-small) * 2));
  }
  
  .drop-indicator.level-3 {
    margin-left: calc(var(--indent-small) * 3);
    width: calc(100% - calc(var(--indent-small) * 3));
  }
  
  .drop-indicator.level-4 {
    margin-left: calc(var(--indent-small) * 4);
    width: calc(100% - calc(var(--indent-small) * 4));
  }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .drop-indicator {
    background: var(--primary-text);
    box-shadow: none;
  }
  
  .drop-indicator::before {
    border-left-color: var(--primary-text);
  }
  
  .drop-indicator::after {
    background: var(--primary-text);
    border: 1px solid var(--primary-bg);
  }
  
  .bullet-item.dragging {
    border: 2px solid var(--accent-color);
  }
  
  .drop-target {
    border-width: 2px;
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .bullet-item.dragging {
    transform: scale(0.98);
  }
  
  .bullet-list.dragging-active .bullet-item.drag-target-above,
  .bullet-list.dragging-active .bullet-item.drag-target-below {
    transform: none;
  }
  
  .drag-ghost {
    transform: none;
  }
  
  .drag-placeholder {
    animation: none;
  }
  
  .drag-zone.drag-over::before {
    animation: none;
    opacity: 0.5;
  }
  
  @keyframes dragPlaceholderPulse {
    0%, 100% {
      opacity: 0.7;
    }
  }
  
  @keyframes dragZonePulse {
    0%, 100% {
      opacity: 0.5;
    }
  }
}

/* Accessibility */
.drag-handle:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* Prevent text selection during drag */
.bullet-list.dragging-active {
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}

/* No transform transitions on items during drag — prevents layout shifts */

/* Drag cursor states */
.drag-handle {
  cursor: grab;
}

.drag-handle:active,
.bullet-list.dragging-active .drag-handle {
  cursor: grabbing;
}

/* Ensure proper stacking */
.drop-indicator {
  position: relative;
  z-index: 10000;
}

.bullet-item.dragging {
  z-index: 10001;
}

.drag-ghost {
  z-index: 10002;
}

.drag-feedback {
  z-index: 10003;
}
/* === features/minimap.css === */
/* Minimap Feature — Sublime Text-style document minimap sidebar */

/* Fix for smooth scroll interference during minimap drag */
html.minimap-dragging,
html.minimap-dragging body,
body.minimap-dragging {
  scroll-behavior: auto !important;
}

.minimap-dragging * {
  scroll-behavior: auto !important;
}

/* ── Container ── */
.minimap-container {
  position: fixed;
  top: calc(var(--header-height) + var(--spacing-sm));
  right: 0;
  width: var(--minimap-width);
  height: calc(100vh - var(--header-height) - var(--spacing-sm) - var(--spacing-lg));
  max-height: calc(100vh - var(--header-height) - var(--spacing-sm) - var(--spacing-lg));
  min-height: 200px;
  background: var(--secondary-bg);
  border-left: 1px solid var(--border-color);
  border-top: 1px solid var(--border-color);
  border-bottom: 1px solid var(--border-color);
  overflow: hidden;
  z-index: var(--z-fixed);
  cursor: pointer;
  user-select: none;
  display: block;
  visibility: visible;
  opacity: 1;
  box-shadow: -2px 0 10px rgba(0, 0, 0, 0.15);
  backdrop-filter: blur(8px);
  pointer-events: auto;
  touch-action: pan-y;
}

/* ── Content area ── */
.minimap-content {
  position: relative;
  padding: 8px;
  height: 100%;
  overflow: hidden;
}

/* ── Minimap lines (visual representation of content blocks) ── */
/* Heights and widths are set dynamically in JavaScript based on content scaling */
.minimap-line {
  margin-bottom: 2px;
  background: var(--secondary-text);
  opacity: 0.3;
  border-radius: 1px;
  display: block;
  cursor: pointer;
}

.minimap-line:hover {
  opacity: 0.6;
}

/* Level-based indentation (CSS defaults; JS overrides width/marginLeft inline) */
.minimap-line.level-0 {
  opacity: 0.5;
}

.minimap-line.level-1 {
  opacity: 0.4;
}

.minimap-line.level-2 {
  opacity: 0.35;
}

.minimap-line.level-3 {
  opacity: 0.3;
}

.minimap-line.level-4 {
  opacity: 0.25;
}

/* Empty lines */
.minimap-line.empty {
  height: 1px;
  width: 5px;
  opacity: 0.2;
}

/* Content-type visual differentiation */
.minimap-line.hashtag {
  background: var(--accent-color);
  opacity: 0.5;
}

.minimap-line.has-images {
  background: linear-gradient(90deg, var(--secondary-text) 0%, rgba(59, 130, 246, 0.3) 100%);
  opacity: 0.6;
  border-left: 2px solid rgba(59, 130, 246, 0.5);
  padding-left: 2px;
}

.minimap-line.code-block {
  background: var(--accent-professional);
  opacity: 0.4;
  border-radius: 2px;
}

.minimap-line.todo {
  background: var(--accent-warm);
  opacity: 0.5;
  position: relative;
}

.minimap-line.todo::before {
  content: '';
  position: absolute;
  left: -2px;
  top: 0;
  width: 2px;
  height: 100%;
  background: var(--accent-warm);
  border-radius: 1px;
}

/* ── Viewport indicator (draggable scroll position overlay) ── */
.minimap-viewport {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: rgba(59, 130, 246, 0.15);
  border: 1px solid rgba(59, 130, 246, 0.5);
  border-radius: 2px;
  cursor: ns-resize;
  min-height: 20px;
  z-index: 10;
  pointer-events: all;
  touch-action: pan-y;
}

.minimap-viewport:hover {
  background: rgba(59, 130, 246, 0.25);
  border-color: var(--accent-color);
}

.minimap-viewport.dragging {
  background: rgba(59, 130, 246, 0.35);
  border-color: var(--accent-color);
  cursor: grabbing;
}

/* ── Collapse state ── */
.minimap-container.collapsed {
  width: 20px;
  cursor: pointer;
}

.minimap-container.collapsed .minimap-content {
  display: none;
}

.minimap-container.collapsed::after {
  content: '◀';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(90deg);
  color: var(--secondary-text);
  font-size: 12px;
}

.minimap-container.collapsed:hover::after {
  color: var(--accent-color);
}

/* ── Loading state ── */
.minimap-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--secondary-text);
  font-size: var(--font-size-xs);
}

.minimap-loading .spinner {
  width: 16px;
  height: 16px;
  border: 1px solid var(--border-color);
  border-top: 1px solid var(--accent-color);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-bottom: var(--spacing-xs);
}

/* ── Responsive: hide on mobile ── */
@media (max-width: 768px) {
  .minimap-container {
    display: none !important;
  }
}

/* ── Responsive: show on tablet and desktop ── */
@media (min-width: 769px) {
  .minimap-container {
    display: block;
  }
}

/* ── Hide minimap on non-note pages ── */
#tasks-view .minimap-container,
.tasks-page .minimap-container,
body.tasks-page .minimap-container {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.settings-page .minimap-container,
body.settings-page .minimap-container {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.membership-page .minimap-container,
body.membership-page .minimap-container {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Remove right margin from main content on special pages */
.tasks-page .main-content,
.settings-page .main-content,
.membership-page .main-content,
body.tasks-page .main-content,
body.settings-page .main-content,
body.membership-page .main-content {
  margin-right: 0 !important;
}

/* ── Accessibility: aria-hidden toggle ── */
.minimap-container[aria-hidden="true"] {
  display: none;
}

/* ── High Contrast Mode ── */
@media (prefers-contrast: high) {
  .minimap-container {
    border-left-width: 2px;
    border-top-width: 2px;
  }

  .minimap-line {
    opacity: 0.8;
  }

  .minimap-viewport {
    border-width: 2px;
    background: rgba(0, 0, 0, 0.2);
  }

  .minimap-line.hashtag,
  .minimap-line.has-images,
  .minimap-line.code-block,
  .minimap-line.todo {
    outline: 1px solid currentColor;
    outline-offset: 0px;
  }
}

/* ── Reduced Motion ── */
@media (prefers-reduced-motion: reduce) {
  .minimap-line,
  .minimap-viewport {
    animation: none;
    transition: none;
  }
}

/* ── Performance: promote viewport for GPU compositing ── */
.minimap-viewport {
  will-change: top, height;
}

/* === features/slash-commands.css === */
/* Slash Commands Feature */

/* Code Block Styles */
.code-block {
  background: var(--secondary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  margin: var(--spacing-sm) 0;
  overflow: hidden;
  box-shadow: var(--shadow);
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
}

/* Inline code-block copy button — canonical styles below after .code-header */

.code-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--tertiary-bg);
  border-bottom: 1px solid var(--border-color);
  font-size: var(--font-size-sm);
}

.code-label {
  font-weight: var(--font-weight-medium);
  color: var(--secondary-text);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.code-label::before {
  content: '{ }';
  font-family: var(--font-family-mono);
  color: var(--accent-color);
  font-weight: var(--font-weight-bold);
}

.copy-code-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--spacing-xs);
  border-radius: var(--radius-sm);
  color: var(--secondary-text);
  font-size: var(--font-size-sm);
  transition: all var(--transition-base);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.copy-code-btn:hover {
  background: var(--quaternary-bg);
  color: var(--primary-text);
}

.copy-code-btn:active {
  background: var(--accent-color);
  color: white;
}

.copy-code-btn.copied {
  background: var(--success-color);
  color: white;
}

.copy-code-btn.copied::after {
  content: 'Copied!';
  margin-left: var(--spacing-xs);
}

.code-block pre {
  margin: 0;
  padding: var(--spacing-md);
  background: var(--primary-bg);
  overflow-x: auto;
  font-family: var(--font-family-mono);
  font-size: var(--font-size-sm);
  line-height: 1.4;
  color: var(--primary-text);
}

.code-block code {
  color: var(--primary-text);
  background: none;
  padding: 0;
  border-radius: 0;
  font-family: inherit;
  font-size: inherit;
}

/* Syntax Highlighting */
.code-block .keyword {
  color: #d73a49;
  font-weight: var(--font-weight-medium);
}

.code-block .string {
  color: #032f62;
}

.code-block .comment {
  color: #6a737d;
  font-style: italic;
}

.code-block .number {
  color: #005cc5;
}

.code-block .function {
  color: #6f42c1;
}

.code-block .variable {
  color: #e36209;
}

/* Dark mode syntax highlighting */
@media (prefers-color-scheme: dark) {
  .code-block .keyword {
    color: #ff7b72;
  }
  
  .code-block .string {
    color: #a5d6ff;
  }
  
  .code-block .comment {
    color: #8b949e;
  }
  
  .code-block .number {
    color: #79c0ff;
  }
  
  .code-block .function {
    color: #d2a8ff;
  }
  
  .code-block .variable {
    color: #ffa657;
  }
}

/* Todo Item Styles */
.todo-item {
    display: inline-flex; /* Use inline-flex to not break text flow */
    align-items: flex-start; /* Top-align checkbox with first line of text (matches bullet dot) */
    gap: var(--spacing-sm);
    margin: 0; /* Remove vertical margin to align with bullet text */
    padding: 0; /* Remove padding - parent bullet-display already has it */
    vertical-align: top; /* Ensure inline alignment */
}

.todo-item:hover {
  background: transparent;
}

/* Minimal native HTML checkbox styling */
.todo-checkbox {
  width: 14px;
  height: 14px;
  cursor: pointer;
  flex-shrink: 0;
  accent-color: var(--accent-color);
  margin-right: 0px !important;
  margin-left: 5px;
}

.todo-text {
    flex: 1;
    line-height: var(--line-height-normal);
    color: var(--primary-text);
    display: inline-block; /* Ensure proper inline flow */
    vertical-align: top; /* Align with checkbox */
}

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

/* Todo Priority Indicators */
.todo-item.priority-high {
  border-left: 3px solid var(--error-color);
  padding-left: var(--spacing-sm);
}

.todo-item.priority-medium {
  border-left: 3px solid var(--warning-color);
  padding-left: var(--spacing-sm);
}

.todo-item.priority-low {
  border-left: 3px solid var(--success-color);
  padding-left: var(--spacing-sm);
}

/* Todo Due Date */
.todo-due-date {
  font-size: var(--font-size-xs);
  color: var(--secondary-text);
  margin-top: var(--spacing-xs);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.todo-due-date.overdue {
  color: var(--error-color);
  font-weight: var(--font-weight-medium);
}

.todo-due-date.due-soon {
  color: var(--warning-color);
  font-weight: var(--font-weight-medium);
}

/* Slash Command Autocomplete */
.slash-autocomplete {
  position: absolute;
  background: var(--primary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-popover);
  max-width: 300px;
  max-height: 200px;
  overflow-y: auto;
}

.slash-command-option {
  padding: var(--spacing-sm) var(--spacing-md);
  cursor: pointer;
  transition: background var(--transition-base);
  border-bottom: 1px solid var(--border-color);
}

.slash-command-option:last-child {
  border-bottom: none;
}

.slash-command-option:hover,
.slash-command-option.selected {
  background: var(--tertiary-bg);
}

.slash-command-option.selected {
  background: var(--accent-color);
  color: white;
}

.slash-command-name {
  font-weight: var(--font-weight-medium);
  color: var(--primary-text);
  margin-bottom: var(--spacing-xs);
}

.slash-command-option.selected .slash-command-name {
  color: white;
}

.slash-command-description {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  line-height: var(--line-height-normal);
}

.slash-command-option.selected .slash-command-description {
  color: rgba(255, 255, 255, 0.8);
}

.slash-command-shortcut {
  font-size: var(--font-size-xs);
  color: var(--secondary-text);
  font-family: var(--font-family-mono);
  background: var(--tertiary-bg);
  padding: 2px 4px;
  border-radius: var(--radius-sm);
  margin-left: var(--spacing-sm);
}

.slash-command-option.selected .slash-command-shortcut {
  background: rgba(255, 255, 255, 0.2);
  color: white;
}

/* Quote Block */
.quote-block {
  border-left: 4px solid var(--accent-color);
  padding-left: var(--spacing-md);
  margin: var(--spacing-md) 0;
  font-style: italic;
  color: var(--secondary-text);
  background: rgba(42, 157, 188, 0.05);
  padding: var(--spacing-md);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

.quote-block::before {
  content: '"';
  font-size: var(--font-size-2xl);
  color: var(--accent-color);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  float: left;
  margin-right: var(--spacing-xs);
  margin-top: -4px;
}

/* Callout Blocks */
.callout-block {
  padding: var(--spacing-md);
  border-radius: var(--radius-md);
  margin: var(--spacing-md) 0;
  border-left: 4px solid;
  position: relative;
}

.callout-block.info {
  background: rgba(59, 130, 246, 0.1);
  border-left-color: var(--accent-color);
  color: var(--primary-text);
}

.callout-block.warning {
  background: rgba(245, 158, 11, 0.1);
  border-left-color: var(--warning-color);
  color: var(--primary-text);
}

.callout-block.error {
  background: rgba(220, 53, 69, 0.1);
  border-left-color: var(--error-color);
  color: var(--primary-text);
}

.callout-block.success {
  background: rgba(16, 185, 129, 0.1);
  border-left-color: var(--success-color);
  color: var(--primary-text);
}

.callout-title {
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--spacing-sm);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.callout-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* Table Block */
.table-block {
  margin: var(--spacing-md) 0;
  overflow-x: auto;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-color);
}

.table-block table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

.table-block th,
.table-block td {
  padding: var(--spacing-sm) var(--spacing-md);
  text-align: left;
  border-bottom: 1px solid var(--border-color);
}

.table-block th {
  background: var(--secondary-bg);
  font-weight: var(--font-weight-semibold);
  color: var(--primary-text);
}

.table-block tr:last-child td {
  border-bottom: none;
}

.table-block tr:hover {
  background: var(--tertiary-bg);
}

/* Mobile optimizations for slash commands */
@media (max-width: 768px) {
  .code-block pre {
    font-size: var(--font-size-xs);
    padding: var(--spacing-sm);
  }
  
  .code-header {
    padding: var(--spacing-xs);
  }
  
  .copy-code-btn {
    min-width: 32px;
    min-height: 32px;
  }
  
  /* Fix TODO checkbox alignment on mobile to match bullet markers */
  .todo-item {
    padding: 0; /* Remove any padding - parent has it */
    margin: 0;
    align-items: center; /* Center items vertically */
  }
  
  .todo-checkbox {
    width: 14px;
    height: 14px;
    min-width: 14px;
    margin-right: 0px !important;
    margin-left: 5px;
  }
  
  .todo-text {
    padding: 0; /* Remove padding to align with checkbox */
    min-height: 20px; /* Maintain minimum touch target */
  }
  
  .slash-autocomplete {
    max-width: calc(100vw - 40px);
    left: 20px !important;
    right: 20px !important;
    width: auto !important;
  }
  
  .quote-block {
    padding: var(--spacing-sm);
    margin: var(--spacing-sm) 0;
  }
  
  .callout-block {
    padding: var(--spacing-sm);
    margin: var(--spacing-sm) 0;
  }
  
  .table-block {
    font-size: var(--font-size-xs);
  }
  
  .table-block th,
  .table-block td {
    padding: var(--spacing-xs) var(--spacing-sm);
  }
}

/* Dark mode adjustments for slash commands */
@media (prefers-color-scheme: dark) {
  .code-block {
    background: #2d2d2d;
    border-color: #404040;
  }
  
  .code-header {
    background: #3a3a3a;
    border-bottom-color: #404040;
  }
  
  .code-block pre {
    background: #1a1a1a;
  }
  
  .copy-code-btn:hover {
    background: #4a4a4a;
  }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .code-block,
  .quote-block,
  .callout-block,
  .table-block {
    border-width: 2px;
  }
  
  .slash-autocomplete {
    border-width: 2px;
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .todo-item:hover {
    background: transparent;
  }
  
  .copy-code-btn.copied {
    transition: none;
  }
}

/* Focus States */
.todo-checkbox:focus-visible,
.copy-code-btn:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.slash-command-option:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: -2px;
}

/* Touch Improvements */
.todo-checkbox,
.copy-code-btn {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Smooth Scrolling */
.slash-autocomplete {
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}

/* Animation for slash command insertion */
.slash-command-inserted {
  animation: slashCommandInserted 0.3s ease-out;
}

@keyframes slashCommandInserted {
  0% {
    background: rgba(42, 157, 188, 0.3);
    transform: scale(1.02);
  }
  100% {
    background: transparent;
    transform: scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .slash-command-inserted {
    animation: none;
  }
  
  @keyframes slashCommandInserted {
    0%, 100% {
      background: transparent;
      transform: none;
    }
  }
}

/* AI Processing Styles */
.ai-processing {
  background: var(--secondary-bg);
  border: 1px solid var(--accent-color);
  border-radius: var(--radius-md);
  margin: var(--spacing-sm) 0;
  overflow: hidden;
  box-shadow: var(--shadow);
}

.ai-processing-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-xs) var(--spacing-sm);
  background: rgba(42, 157, 188, 0.1);
  border-bottom: 1px solid var(--accent-color);
  font-size: var(--font-size-sm);
}

.ai-processing-label {
  font-weight: var(--font-weight-medium);
  color: var(--accent-color);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.ai-processing-label::before {
  content: '🤖';
  font-size: var(--font-size-md);
}

.ai-spinner {
  width: 16px;
  height: 16px;
  border: 2px solid var(--border-color);
  border-top: 2px solid var(--accent-color);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.ai-prompt {
  padding: var(--spacing-sm);
  font-style: italic;
  color: var(--secondary-text);
  background: var(--primary-bg);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
}

/* Ask AI Modal Styles */
#ask-ai-modal .modal-content {
  max-width: 600px;
}

.context-section {
  margin-bottom: var(--spacing-md);
}

.context-section label {
  display: block;
  font-weight: var(--font-weight-medium);
  color: var(--primary-text);
  margin-bottom: var(--spacing-xs);
}

.context-preview {
  background: var(--secondary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--spacing-sm);
  max-height: 150px;
  overflow-y: auto;
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  line-height: var(--line-height-normal);
}

.prompt-section {
  margin-bottom: var(--spacing-md);
}

.prompt-section label {
  display: block;
  font-weight: var(--font-weight-medium);
  color: var(--primary-text);
  margin-bottom: var(--spacing-xs);
}

#ai-prompt {
  width: 100%;
  min-height: 80px;
  padding: var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--primary-bg);
  color: var(--primary-text);
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
  resize: vertical;
  transition: border-color var(--transition-base);
}

#ai-prompt:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px rgba(42, 157, 188, 0.2);
}

#ai-prompt::placeholder {
  color: var(--secondary-text);
  opacity: 0.7;
}

/* Ask AI Button Styles - Consistent with other action buttons */
.ask-ai-btn {
  background: rgba(42, 157, 188, 0.1);
  color: #2a9dbc;
  border: none;
}

.ask-ai-btn:hover {
  background: #2a9dbc;
  color: white;
}

.ask-ai-btn:active {
  transform: translateY(1px);
}

/* Mobile optimizations for AI features */
@media (max-width: 768px) {
  .ai-processing {
    margin: var(--spacing-xs) 0;
  }
  
  .ai-processing-header {
    padding: var(--spacing-xs);
  }
  
  .ai-prompt {
    padding: var(--spacing-xs);
    font-size: var(--font-size-sm);
  }
  
  #ask-ai-modal .modal-content {
    max-width: calc(100vw - 40px);
    margin: 20px;
    height: calc(100vh - 40px);
    display: flex;
    flex-direction: column;
  }
  
  .context-preview {
    max-height: 100px;
    font-size: var(--font-size-xs);
  }
  
  #ai-prompt {
    min-height: 40vh;
    font-size: var(--font-size-sm);
    flex: 1;
  }
  
  .prompt-section {
    flex: 1;
    display: flex;
    flex-direction: column;
  }
  
  .prompt-section label {
    margin-bottom: var(--spacing-sm);
  }
  
  .context-section {
    margin-bottom: var(--spacing-md);
  }
}

/* Dark mode adjustments for AI features */
@media (prefers-color-scheme: dark) {
  .ai-processing {
    background: #2d2d2d;
    border-color: var(--accent-color);
  }
  
  .ai-processing-header {
    background: rgba(42, 157, 188, 0.2);
  }
  
  .ai-prompt {
    background: #1a1a1a;
  }
  
  .context-preview {
    background: #2d2d2d;
    border-color: #404040;
  }
  
  #ai-prompt {
    background: #1a1a1a;
    border-color: #404040;
  }
  
  #ai-prompt:focus {
    border-color: var(--accent-color);
    box-shadow: 0 0 0 2px rgba(42, 157, 188, 0.3);
  }
}
/* === features/import-export.css === */
/* Import/Export Feature Styles */

/* Import Container */
.import-container {
  padding: var(--spacing-lg);
}

/* Import Tabs */
.import-tabs {
  display: flex;
  border-bottom: 1px solid var(--border-color);
  margin-bottom: var(--spacing-lg);
}

.tab-btn {
  background: none;
  border: none;
  padding: var(--spacing-md) var(--spacing-lg);
  cursor: pointer;
  color: var(--secondary-text);
  font-size: var(--font-size-base);
  border-bottom: 2px solid transparent;
  transition: all var(--transition-base);
  flex: 1;
  text-align: center;
}

.tab-btn:hover {
  color: var(--primary-text);
  background: var(--tertiary-bg);
}

.tab-btn.active {
  color: var(--accent-color);
  border-bottom-color: var(--accent-color);
  background: var(--primary-bg);
}

/* Tab Content */
.tab-content {
  display: none;
}

.tab-content.active {
  display: block;
}

/* Drop Zone */
.drop-zone {
  border: 2px dashed var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--spacing-xl);
  text-align: center;
  color: var(--secondary-text);
  cursor: pointer;
  transition: all var(--transition-base);
  background: var(--secondary-bg);
  position: relative;
  min-height: 200px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-md);
}

.drop-zone:hover,
.drop-zone.dragover {
  border-color: var(--accent-color);
  background: rgba(59, 130, 246, 0.05);
  color: var(--accent-color);
  transform: scale(1.02);
}

.drop-zone.dragover {
  border-style: solid;
  box-shadow: 0 0 20px rgba(59, 130, 246, 0.2);
}

.drop-zone svg {
  margin-bottom: var(--spacing-md);
  opacity: 0.5;
  transition: all var(--transition-base);
}

.drop-zone:hover svg,
.drop-zone.dragover svg {
  opacity: 1;
  transform: scale(1.1);
}

.drop-zone p {
  margin: 0;
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
}

.drop-zone button {
  background: none;
  border: none;
  color: var(--accent-color);
  text-decoration: underline;
  cursor: pointer;
  font-size: inherit;
  font-weight: var(--font-weight-medium);
  transition: color var(--transition-base);
}

.drop-zone button:hover {
  color: var(--accent-hover);
}

.upload-note {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  margin-top: var(--spacing-sm);
  opacity: 0.8;
}

/* File Input (hidden) */
input[type="file"] {
  display: none;
}

/* Upload List */
.upload-list {
  margin-top: var(--spacing-lg);
  max-height: 300px;
  overflow-y: auto;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--primary-bg);
}

.upload-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md);
  border-bottom: 1px solid var(--border-color);
  background: var(--secondary-bg);
  transition: background var(--transition-base);
}

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

.upload-item:hover {
  background: var(--tertiary-bg);
}

.upload-item-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  flex: 1;
  min-width: 0;
}

.upload-item-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  color: var(--accent-color);
}

.upload-item-details {
  flex: 1;
  min-width: 0;
}

.upload-item-name {
  font-weight: var(--font-weight-medium);
  color: var(--primary-text);
  margin-bottom: var(--spacing-xs);
  word-break: break-word;
}

.upload-item-size {
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
}

.upload-item-status {
  font-size: var(--font-size-xs);
  margin-top: var(--spacing-xs);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.upload-item-status.success {
  color: var(--success-color);
}

.upload-item-status.error {
  color: var(--error-color);
}

.upload-item-status.processing {
  color: var(--accent-color);
}

.upload-item-actions {
  display: flex;
  gap: var(--spacing-sm);
  flex-shrink: 0;
}

.upload-action-btn {
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--primary-bg);
  color: var(--primary-text);
  cursor: pointer;
  font-size: var(--font-size-sm);
  transition: all var(--transition-base);
}

.upload-action-btn:hover {
  background: var(--tertiary-bg);
  transform: translateY(-1px);
}

.upload-action-btn.overwrite {
  background: var(--accent-color);
  color: white;
  border-color: var(--accent-color);
}

.upload-action-btn.overwrite:hover {
  background: var(--accent-hover);
}

.upload-action-btn.skip {
  background: var(--secondary-text);
  color: white;
  border-color: var(--secondary-text);
}

.upload-action-btn.skip:hover {
  background: var(--primary-text);
}

/* Progress Bar */
.progress-bar {
  width: 100%;
  height: 8px;
  background: var(--tertiary-bg);
  border-radius: var(--radius-sm);
  overflow: hidden;
  margin-bottom: var(--spacing-md);
  position: relative;
}

.progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent-color), var(--accent-hover));
  transition: width 0.3s ease;
  width: 0%;
  position: relative;
}

.progress-fill::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  animation: progressShimmer 2s infinite;
}

@keyframes progressShimmer {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(100%);
  }
}

.progress-text {
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--secondary-text);
  margin-top: var(--spacing-sm);
}

/* Export Container */
.export-container {
  padding: var(--spacing-lg);
}

.export-options {
  padding: var(--spacing-md);
  border-bottom: 1px solid var(--border-color);
  margin-bottom: var(--spacing-lg);
  background: var(--secondary-bg);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
}

.export-preview {
  background: var(--secondary-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--spacing-lg);
  margin-bottom: var(--spacing-lg);
  max-height: 400px;
  overflow-y: auto;
  font-family: var(--font-family);
  line-height: var(--line-height-relaxed);
  position: relative;
}

.export-preview::before {
  content: 'Preview';
  position: absolute;
  top: var(--spacing-sm);
  right: var(--spacing-sm);
  background: var(--accent-color);
  color: white;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.export-preview h1,
.export-preview h2,
.export-preview h3 {
  margin-bottom: var(--spacing-md);
  color: var(--primary-text);
}

.export-preview ul {
  margin: 0;
  padding-left: var(--spacing-lg);
}

.export-preview li {
  margin-bottom: var(--spacing-xs);
  color: var(--primary-text);
}

.export-preview li ul {
  margin-top: var(--spacing-xs);
  padding-left: var(--spacing-lg);
}

.export-preview img {
  max-width: 200px;
  height: auto;
  border-radius: var(--radius-sm);
  margin: 2px 8px 2px 0;
  box-shadow: var(--shadow);
  display: inline-block;
  vertical-align: top;
}

.export-preview code {
  background: var(--tertiary-bg);
  padding: 2px 4px;
  border-radius: var(--radius-sm);
  font-family: var(--font-family-mono);
  font-size: 0.9em;
}

.export-preview pre {
  background: var(--tertiary-bg);
  padding: var(--spacing-md);
  border-radius: var(--radius-md);
  overflow-x: auto;
  font-family: var(--font-family-mono);
  font-size: var(--font-size-sm);
}

.export-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-sm);
}

/* Import/Export Status Messages */
.import-status,
.export-status {
  padding: var(--spacing-md);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-lg);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.import-status.success,
.export-status.success {
  background: rgba(40, 167, 69, 0.1);
  border: 1px solid var(--success-color);
  color: var(--success-color);
}

.import-status.error,
.export-status.error {
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid var(--error-color);
  color: var(--error-color);
}

.import-status.info,
.export-status.info {
  background: rgba(59, 130, 246, 0.1);
  border: 1px solid var(--accent-color);
  color: var(--accent-color);
}

.status-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

/* Import Statistics */
.import-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--spacing-md);
  margin: var(--spacing-lg) 0;
  padding: var(--spacing-lg);
  background: var(--secondary-bg);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-color);
}

.import-stat {
  text-align: center;
}

.import-stat-value {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--accent-color);
  margin-bottom: var(--spacing-xs);
}

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

/* Mobile Responsive */
@media (max-width: 768px) {
  .import-container,
  .export-container {
    padding: var(--spacing-md);
  }
  
  .import-tabs {
    margin-bottom: var(--spacing-md);
  }
  
  .tab-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    flex: 1;
    text-align: center;
  }
  
  .drop-zone {
    padding: var(--spacing-lg);
    min-height: 120px;
  }
  
  .drop-zone svg {
    width: 32px;
    height: 32px;
  }
  
  .upload-item {
    padding: var(--spacing-sm);
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-sm);
  }
  
  .upload-item-info {
    width: 100%;
  }
  
  .upload-item-actions {
    width: 100%;
    justify-content: flex-end;
  }
  
  .export-options {
    padding: var(--spacing-sm);
  }
  
  .export-preview {
    max-height: 50vh;
    overflow-y: auto;
    font-size: var(--font-size-sm);
  }
  
  .export-preview img {
    max-width: 150px !important;
    height: auto !important;
    margin: 2px 6px 2px 0 !important;
    display: inline-block !important;
    vertical-align: top !important;
  }
  
  .export-actions {
    display: flex;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
  }
  
  .export-actions .action-btn {
    flex: 1;
    min-width: 0;
  }
  
  .import-stats {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
  }
}

@media (max-width: 480px) {
  .tab-btn {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-xs);
  }
  
  .drop-zone {
    padding: var(--spacing-md);
    min-height: 100px;
  }
  
  .upload-item {
    padding: var(--spacing-xs);
  }
  
  .import-stats {
    grid-template-columns: 1fr;
  }
  
  .export-actions {
    flex-direction: column;
  }
}

/* Focus States */
.tab-btn:focus-visible,
.upload-action-btn:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.drop-zone:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 4px;
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .drop-zone {
    border-width: 3px;
  }
  
  .upload-item,
  .export-preview,
  .import-stats {
    border-width: 2px;
  }
  
  .progress-bar {
    border: 1px solid var(--border-color);
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .drop-zone:hover {
    transform: none;
  }
  
  .drop-zone:hover svg,
  .drop-zone.dragover svg {
    transform: none;
  }
  
  .upload-action-btn:hover {
    transform: none;
  }
  
  .progress-fill::after {
    animation: none;
  }
  
  @keyframes progressShimmer {
    0%, 100% {
      transform: none;
    }
  }
}

/* Touch Improvements */
.tab-btn,
.upload-action-btn,
.drop-zone {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Smooth Scrolling */
.upload-list,
.export-preview {
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}

/* Drag and Drop States */
.drop-zone.drag-enter {
  border-color: var(--accent-color);
  background: rgba(59, 130, 246, 0.1);
}

.drop-zone.drag-over {
  border-color: var(--accent-color);
  background: rgba(59, 130, 246, 0.15);
  transform: scale(1.02);
}

.drop-zone.drag-leave {
  border-color: var(--border-color);
  background: var(--secondary-bg);
  transform: scale(1);
}

/* File Type Icons */
.file-icon {
  width: 20px;
  height: 20px;
  margin-right: var(--spacing-sm);
}

.file-icon.markdown {
  color: var(--accent-color);
}

.file-icon.image {
  color: var(--accent-warm);
}

.file-icon.text {
  color: var(--secondary-text);
}

/* Loading States */
.import-loading,
.export-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
  color: var(--secondary-text);
}

.import-loading .spinner,
.export-loading .spinner {
  width: 24px;
  height: 24px;
  border: 2px solid var(--border-color);
  border-top: 2px solid var(--accent-color);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-right: var(--spacing-sm);
}
/* === features/membership.css === */
/* Membership Page Styles — using design system variables */
.membership-container {
    max-width: 800px;
    margin: 0 auto;
    padding: var(--spacing-lg);
}

.membership-card {
    background: var(--secondary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--spacing-lg);
    overflow: hidden;
}

.card-header {
    background: var(--tertiary-bg);
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--border-color);
}

.card-header h3 {
    margin: 0;
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--primary-text);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.beta-badge {
    background: var(--accent-color);
    color: white;
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
}

.card-content {
    padding: var(--spacing-lg);
}

.status-info,
.account-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.status-item,
.info-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--border-color);
}

.status-item:last-child,
.info-item:last-child {
    border-bottom: none;
}

.status-label,
.info-label {
    font-weight: var(--font-weight-medium);
    color: var(--secondary-text);
}

.status-value,
.info-value {
    font-weight: var(--font-weight-semibold);
    color: var(--primary-text);
}

/* Premium Features */
.premium-features h4 {
    margin: 0 0 var(--spacing-md) 0;
    color: var(--primary-text);
    font-size: var(--font-size-base);
}

.feature-list {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--spacing-lg) 0;
}

.feature-list li {
    padding: var(--spacing-xs) 0;
    color: var(--secondary-text);
    font-size: var(--font-size-sm);
}

/* Pricing Section */
.pricing-section {
    margin: var(--spacing-lg) 0;
}

.price-card {
    background: var(--primary-bg);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    text-align: center;
}

.price-header h4 {
    margin: 0 0 var(--spacing-sm) 0;
    color: var(--primary-text);
    font-size: var(--font-size-base);
}

.price {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-weight-bold);
    color: var(--accent-color);
    margin: var(--spacing-sm) 0;
}

.period {
    font-size: var(--font-size-sm);
    color: var(--secondary-text);
    font-weight: var(--font-weight-normal);
}

.price-features {
    margin: var(--spacing-md) 0;
    text-align: left;
}

.price-features p {
    margin: 0 0 var(--spacing-md) 0;
    color: var(--secondary-text);
    font-size: var(--font-size-sm);
}

.price-features ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.price-features li {
    padding: var(--spacing-xs) 0;
    color: var(--secondary-text);
    font-size: var(--font-size-sm);
    position: relative;
    padding-left: var(--spacing-md);
}

.price-features li:before {
    content: "✓";
    position: absolute;
    left: 0;
    color: var(--success-color);
    font-weight: var(--font-weight-bold);
}

.upgrade-btn {
    width: 100%;
    padding: var(--spacing-md) var(--spacing-md);
    background: var(--accent-color);
    color: white;
    border: none;
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    cursor: pointer;
    transition: all var(--transition-base);
}

.upgrade-btn:hover {
    background: var(--accent-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

.upgrade-btn.disabled {
    background: var(--tertiary-bg);
    color: var(--muted-text);
    cursor: not-allowed;
}

.upgrade-btn.disabled:hover {
    background: var(--tertiary-bg);
    transform: none;
    box-shadow: none;
}

.payment-note {
    background: var(--warning-bg);
    border: 1px solid var(--warning-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md) var(--spacing-md);
    margin-top: var(--spacing-md);
}

.payment-note p {
    margin: 0;
    font-size: var(--font-size-sm);
    color: var(--warning-text);
}

/* Trial Warning Styles */
.trial-warning {
    position: fixed;
    bottom: 20px;
    left: 20px;
    z-index: var(--z-toast);
    animation: slideInUp 0.3s ease-out;
}

.trial-warning-content {
    background: var(--warning-bg);
    border: 1px solid var(--warning-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md) var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    box-shadow: var(--shadow-lg);
    max-width: 400px;
}

.trial-icon {
    font-size: var(--font-size-base);
    flex-shrink: 0;
}

.trial-text {
    color: var(--warning-text);
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-sm);
    flex: 1;
}

.upgrade-now-btn {
    background: var(--accent-color);
    color: white;
    border: none;
    border-radius: var(--radius-sm);
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    cursor: pointer;
    transition: all var(--transition-base);
    white-space: nowrap;
}

.upgrade-now-btn:hover {
    background: var(--accent-hover);
}

.dismiss-trial-btn {
    background: none;
    border: none;
    color: var(--muted-text);
    cursor: pointer;
    padding: var(--spacing-xs);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color var(--transition-base);
}

.dismiss-trial-btn:hover {
    background: rgba(0, 0, 0, 0.1);
}

@keyframes slideInUp {
    from {
        transform: translateY(100%);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Responsive Design */
@media (max-width: 768px) {
    .membership-container {
        padding: var(--spacing-md);
    }
    
    .trial-warning {
        left: var(--spacing-md);
        right: var(--spacing-md);
        bottom: var(--spacing-md);
    }
    
    .trial-warning-content {
        flex-wrap: wrap;
        gap: var(--spacing-sm);
    }
    
    .trial-text {
        flex: 1 1 100%;
        order: 1;
    }
    
    .upgrade-now-btn {
        order: 2;
    }
    
    .dismiss-trial-btn {
        order: 3;
    }
}

/* Status Colors */
.status-value[data-status="premium"] {
    color: var(--success-color);
}

.status-value[data-status="trial"] {
    color: var(--warning-color);
}

.status-value[data-status="admin"] {
    color: var(--accent-color);
}

.status-value[data-days-remaining="0"],
.status-value[data-days-remaining="-1"],
.status-value[data-days-remaining="-2"],
.status-value[data-days-remaining="-3"],
.status-value[data-days-remaining="-4"],
.status-value[data-days-remaining="-5"],
.status-value[data-days-remaining="-6"],
.status-value[data-days-remaining="-7"] {
    color: var(--error-color);
    font-weight: 700;
}
/* Expired Warning Styles */
.expired-warning {
    background: var(--error-bg);
    border-color: var(--error-color);
}

.expired-warning .trial-warning-content {
    background: var(--error-bg);
    border-color: var(--error-color);
}

.expired-warning .trial-text {
    color: var(--error-color);
    font-weight: var(--font-weight-semibold);
}

/* Upgrade Popup Styles */
.upgrade-popup-content {
    max-width: 500px;
    text-align: center;
}

.upgrade-popup-header {
    padding: var(--spacing-lg) var(--spacing-lg) var(--spacing-md);
    border-bottom: 1px solid var(--border-color);
}

.upgrade-popup-header h3 {
    margin: 0 0 var(--spacing-sm) 0;
    color: var(--error-color);
    font-size: var(--font-size-2xl);
}

.upgrade-popup-header p {
    margin: 0;
    color: var(--secondary-text);
    font-size: var(--font-size-base);
}

.upgrade-popup-body {
    padding: var(--spacing-lg);
    display: flex;
    gap: var(--spacing-xl);
    align-items: center;
}

.upgrade-features {
    flex: 1;
    text-align: left;
}

.upgrade-features h4 {
    margin: 0 0 var(--spacing-md) 0;
    color: var(--primary-text);
    font-size: var(--font-size-base);
}

.upgrade-features ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.upgrade-features li {
    padding: var(--spacing-xs) 0;
    color: var(--secondary-text);
    font-size: var(--font-size-sm);
}

.upgrade-pricing {
    flex: 0 0 auto;
    text-align: center;
}

.price-display {
    margin-bottom: var(--spacing-sm);
}

/* .price and .period defined above */

.pricing-note {
    margin: 0;
    color: var(--muted-text);
    font-size: var(--font-size-xs);
}

.upgrade-popup-actions {
    padding: var(--spacing-md) var(--spacing-lg) var(--spacing-lg);
    display: flex;
    gap: var(--spacing-md);
    justify-content: center;
}

.upgrade-popup-actions .btn-primary {
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
}

.upgrade-popup-actions .btn-secondary {
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-base);
}

/* Simple Trial Indicator */
.trial-indicator {
    position: fixed;
    bottom: 20px;
    left: 20px;
    background: var(--warning-bg);
    color: var(--warning-color);
    border: 1px solid var(--warning-color);
    border-radius: var(--radius-md);
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    z-index: var(--z-toast);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    box-shadow: var(--shadow-lg);
}

.trial-indicator .trial-icon {
    font-size: var(--font-size-base);
}

.trial-indicator .trial-text {
    white-space: nowrap;
}

/* Read-only mode for expired accounts */
.read-only .bullet-content {
    pointer-events: none;
    opacity: 0.7;
}

.read-only .bullet-actions {
    display: none;
}

.read-only #bullet-list::before {
    content: "Read-only mode - Account expired";
    display: block;
    background: var(--error-bg);
    color: var(--error-color);
    padding: 12px 16px;
    margin-bottom: 16px;
    border-radius: 6px;
    font-weight: 600;
    text-align: center;
    border: 1px solid var(--error-color);
}
/* === features/carpy.css === */
/* Carpy Mascot — Bottom-right "peeking out of box" overlay */
/* Intent: A small, non-intrusive mascot that adds warmth without distracting. */
/* Carpy peeks out of a rounded box — the box clips the right and bottom edges, */
/* but the left and top of Carpy overflow, creating a "poking out" effect. */

.carpy-container {
  position: fixed;
  bottom: 8px;
  right: 8px;
  width: 88px;
  height: 88px;
  z-index: 999;
  pointer-events: none;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.4s var(--ease-out-cubic), transform 0.4s var(--ease-out-cubic);
}

.carpy-container.visible {
  opacity: 1;
  transform: translateY(0);
}

/* The "box" that clips the right and bottom edges */
.carpy-box {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 72px;
  height: 72px;
  background: var(--secondary-bg);
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}

/* The mascot image/video sits inside the box but is larger than it, */
/* so it overflows on the top-left (the box clips the bottom-right). */
.carpy-idle,
.carpy-video {
  position: absolute;
  bottom: -8px;
  right: -8px;
  width: 88px;
  height: 88px;
  object-fit: contain;
  object-position: bottom right;
  display: block;
}

.carpy-video.hidden {
  display: none;
}

.carpy-idle.hidden {
  display: none;
}

/* Carpy starts hidden (no .visible class) and is shown via JS after login. */

/* When hint bar is visible, shift Carpy up above it */
.carpy-container.hint-bar-visible {
  bottom: 44px;
}

/* Hover — allow clicking through but show a subtle interaction hint */
.carpy-container.interactive {
  pointer-events: auto;
  cursor: pointer;
}

/* Reduced motion — no entrance animation */
@media (prefers-reduced-motion: reduce) {
  .carpy-container {
    transition: opacity 0.01ms;
    transform: none;
  }
  
  .carpy-container.visible {
    transform: none;
  }
}

/* Hide on mobile and tablet */
@media (max-width: 768px) {
  .carpy-container {
    display: none;
  }
}

/* === responsive/mobile.css === */
/* ITCSS Layer: Responsive */
/* Mobile Responsive Styles */

/* Mobile-First Approach - These styles apply to all mobile devices */
@media (max-width: 768px) {
  
  /* Update CSS variables for mobile */
  :root {
    --indent-base: var(--indent-mobile);
    --header-height: auto; /* Variable height on mobile */
  }
  
  /* Header adjustments - Single row on mobile: logo + buttons */
  /* Main mobile header layout is in header.css @media block */
  
  .header-right {
    display: flex;
    align-items: center;
    overflow: visible;
    padding: var(--spacing-xs) 0;
    min-height: var(--btn-height-md);
  }
  
  /* Premium Mobile Enhancements */
  
  /* Reduce backdrop blur on mobile for performance */
  .modal {
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
  
  .modal-content {
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    margin: var(--spacing-md);
    max-width: calc(100vw - 2rem);
  }
  
  .app-header {
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
  }
  
  /* Optimize touch interactions */
  .action-btn,
  .icon-btn,
  .filter-btn {
    min-height: 44px; /* iOS recommended touch target */
    min-width: 44px;
  }
  
  /* Reduce transform effects on mobile for better performance */
  .action-btn:hover,
  .icon-btn:hover {
    transform: translateY(-1px); /* Reduced from -2px */
  }
  
  /* Optimize glassmorphism for mobile */
  .login-form {
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    margin: var(--spacing-md);
    max-width: calc(100vw - 2rem);
  }
  
  /* Mobile-optimized animations */
  .bounce-in,
  .fade-in-up,
  .slide-in-right {
    animation-duration: var(--duration-300); /* Faster on mobile */
  }
  
  /* Remove shadow effects on mobile for cleaner interface */
  .action-btn {
    box-shadow: none;
  }
  
  .action-btn:hover {
    box-shadow: none;
  }
  
  .icon-btn {
    padding: var(--spacing-sm);
    min-width: var(--btn-height-md);
    min-height: var(--btn-height-md);
  }
  
  /* Mobile date navigation bar */
  .mobile-date-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
    width: 100%;
    padding: var(--spacing-sm);
    background: var(--secondary-bg);
    border-radius: var(--radius-md);
    margin-top: var(--spacing-xs);
  }
  
  .mobile-date-nav .current-date {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    min-width: 0;
    text-align: center;
    flex: 1;
  }
  
  .mobile-date-nav .nav-btn {
    min-width: var(--btn-height-md);
    min-height: var(--btn-height-md);
    padding: var(--spacing-sm);
    background: var(--primary-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
  }
  
  .mobile-date-nav .nav-btn:hover {
    background: var(--tertiary-bg);
    border-color: var(--accent-color);
  }
  
  /* Main content */
  .main-content {
    padding: var(--spacing-sm) 0; /* Left and right padding set to 0 */
    margin-right: 0; /* Remove minimap margin on mobile */
  }
  
  /* Ensure minimap is completely hidden on mobile */
  .minimap-container {
    display: none !important;
  }
  
  .note-editor {
    padding: 30px var(--spacing-sm) var(--spacing-sm) var(--spacing-sm); /* Increased top padding for bullet-actions */
  }
  
  .note-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-md);
  }
  
  /* Bullets - Reduced indentation for mobile */
  .bullet-item {
    margin-bottom: 0;
  }
  
  .bullet-content {
    font-size: var(--font-size-base);
    padding: 1px 0; /* Keep consistent with desktop for proper alignment */
    min-height: var(--btn-height-lg); /* Better touch target */
    word-wrap: break-word;
    overflow-wrap: break-word;
    white-space: pre-wrap;
    max-width: 100%;
    box-sizing: border-box;
  }
  
  /* Remove any hover effects on bullet content for mobile */
  .bullet-content:hover,
  .bullet-display:hover {
    background: transparent;
    box-shadow: none;
  }
  
  /* Fix bullet marker alignment */
  .bullet-marker {
    align-items: flex-start;
    padding-top: 2px; /* Align with first line of text */
    flex-shrink: 0;
  }
  
  .bullet-dot {
    margin-top: 3px; /* Fine-tune vertical alignment with text */
  }
  
  .bullet-actions {
    gap: var(--spacing-xs);
    left: -5px;
    top: -29px;
    background: rgba(255, 255, 255, 0.95);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    border: 1px solid var(--border-color);
    backdrop-filter: blur(8px);
  }

  /* Image container adjustments for mobile */
  .image-container {
    max-width: 150px;
    margin: 2px 6px 2px 0;
  }

  .bullet-image,
  .bullet-display img {
    max-height: 150px;
  }


  /* Dark mode support for mobile */
  @media (prefers-color-scheme: dark) {
    .bullet-actions {
      background: rgba(31, 41, 55, 0.42);
    }
  }

  /* Bullet item positioning - padding removed as note-editor has top padding */
  .bullet-item {
    position: relative;
  }
  
  /* Modals */
  .modal {
    padding: var(--spacing-sm);
    align-items: flex-start;
    padding-top: 20px;
  }
  
  .modal-content {
    max-width: none;
    width: 100%;
    max-height: calc(100vh - 40px);
    overflow-y: auto;
    margin: 0;
  }
  
  .modal-header {
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--border-color);
    position: sticky;
    top: 0;
    background: var(--primary-bg);
    z-index: 10;
  }
  
  /* Search modal */
  .search-container {
    padding: var(--spacing-md);
  }

  .search-input {
    font-size: 16px; /* Prevent zoom on iOS */
  }

  /* Export actions */
  .export-actions {
    display: flex;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
  }

  .filter-buttons {
    gap: var(--spacing-xs);
    flex-wrap: wrap;
  }
  
  /* Consolidated button styles - remove redundant declarations */
  .filter-btn,
  .tab-btn,
  .date-shortcut-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    min-height: var(--btn-height-md);
    border-radius: var(--radius-md);
  }
  
  .search-results {
    max-height: 50vh;
  }
  
  .search-result {
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-md);
  }
  
  /* Import modal */
  .import-container {
    padding: var(--spacing-md);
  }
  
  .import-tabs {
    margin-bottom: var(--spacing-md);
  }
  
  .tab-btn {
    flex: 1;
    text-align: center;
  }
  
  .drop-zone {
    padding: var(--spacing-lg);
    min-height: 120px;
  }
  
  .drop-zone svg {
    width: 32px;
    height: 32px;
  }
  
  .upload-item {
    padding: var(--spacing-sm);
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-sm);
  }
  
  .upload-item-info {
    width: 100%;
  }
  
  .upload-item-actions {
    width: 100%;
    justify-content: flex-end;
  }
  
  /* Export modal */
  .export-container {
    padding: var(--spacing-md);
  }
  
  .export-options {
    padding: var(--spacing-sm);
  }
  
  .export-preview {
    max-height: 50vh;
    overflow-y: auto;
    font-size: var(--font-size-sm);
  }
  
  .export-preview img {
    max-width: 100% !important;
    height: auto !important;
  }
  
  /* Calendar modal */
  .calendar-container {
    padding: var(--spacing-md);
  }
  
  .calendar-quick-actions {
    flex-direction: column;
    gap: var(--spacing-sm);
  }

  .today-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-base);
    min-height: var(--btn-height-lg);
  }

  .direct-date-input {
    padding: var(--spacing-sm);
    font-size: var(--font-size-base);
    min-height: var(--btn-height-lg);
  }

  .jump-to-date-btn {
    width: var(--btn-height-lg);
    height: var(--btn-height-lg);
  }
  
  .calendar-day {
    min-height: var(--btn-height-lg);
    font-size: var(--font-size-base);
    border-radius: var(--radius-sm);
  }
  
  /* Touch improvements */
  .hashtag {
    padding: 4px 8px;
    margin: 2px;
    min-height: 28px;
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    font-size: var(--font-size-sm);
  }
  
  /* Better modal button spacing */
  .export-actions .action-btn {
    flex: 1;
    min-height: var(--btn-height-lg);
    font-size: var(--font-size-base);
  }
  
  /* Better search filter buttons */
  .filter-btn {
    min-height: 40px;
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
  }
  
  /* Date shortcut buttons inherit from consolidated styles above */
  
  /* Better bullet content wrapping */
  .bullet-content {
    line-height: var(--line-height-normal);
    word-break: break-word;
    hyphens: auto;
  }
  
  /* Improved modal headers */
  .modal-header h3 {
    font-size: var(--font-size-xl);
    line-height: 1.3;
  }
  
  /* Better close buttons */
  .close-btn {
    min-width: var(--btn-height-lg);
    min-height: var(--btn-height-lg);
    font-size: var(--font-size-xl);
  }
  
  /* Login screen */
  .login-container {
    padding: var(--spacing-md);
  }
  
  .login-form {
    padding: var(--spacing-lg);
    width: 100%;
    max-width: none;
  }
  
  .logo-image {
    width: 56px;
    height: 56px;
  }
  
  .login-form input {
    font-size: 16px; /* Prevent zoom on iOS */
    padding: var(--spacing-md);
    min-height: var(--btn-height-lg);
  }
  
  .login-form button {
    padding: var(--spacing-md);
    min-height: var(--btn-height-lg);
    font-size: var(--font-size-base);
  }
  
  /* Page containers */
  .page-header {
    flex-direction: column;
    gap: var(--spacing-md);
    align-items: stretch;
  }
  
  .page-content {
    padding: var(--spacing-md);
  }
  
  /* Settings */
  .settings-actions {
    flex-direction: column;
  }
  
  .settings-actions .action-btn {
    width: 100%;
  }
  
  /* Tasks */
  .task-item {
    padding: var(--spacing-xs) var(--spacing-sm);
    gap: var(--spacing-xs);
  }

  .task-text {
    font-size: var(--font-size-sm);
  }

  .task-meta {
    gap: var(--spacing-xs);
    justify-content: flex-start;
  }

  .task-goto-btn {
    min-width: 28px;
    min-height: 28px;
    padding: var(--spacing-xs);
  }
  
  /* Form improvements */
  input,
  textarea,
  select {
    font-size: 16px; /* Prevent zoom on iOS */
    min-height: var(--btn-height-lg);
  }
  
  /* Action buttons */
  .action-btn {
    min-height: var(--btn-height-lg);
    font-size: var(--font-size-base);
    padding: var(--spacing-md) var(--spacing-lg);
  }
}

/* Small mobile devices */
@media (max-width: 480px) {
  
  /* Update CSS variables for small mobile */
  :root {
    --indent-base: var(--indent-small);
  }
  
  .mobile-date-nav .current-date {
    font-size: var(--font-size-sm);
  }
  
  .icon-btn {
    min-width: var(--btn-height-sm);
    min-height: var(--btn-height-sm);
  }
  
  .mobile-date-nav .nav-btn {
    min-width: var(--btn-height-sm);
    min-height: var(--btn-height-sm);
  }
  
  .main-content {
    padding: var(--spacing-sm);
  }
  
  .modal {
    padding: var(--spacing-xs);
    padding-top: 10px;
  }
  
  .modal-content {
    max-height: calc(100vh - 20px);
  }
  
  .tab-btn {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-xs);
  }
  
  .drop-zone {
    padding: var(--spacing-md);
    min-height: 100px;
  }
  
  .upload-item {
    padding: var(--spacing-xs);
  }
  
  .logo-image {
    width: 48px;
    height: 48px;
  }
  
  .login-form h1 {
    font-size: var(--font-size-lg);
  }
  
  .auth-links {
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .page-header {
    padding: var(--spacing-md);
  }
  
  .page-content {
    padding: var(--spacing-sm);
  }
  
  .action-btn {
    flex: 1;
  }
  
  .calendar-day {
    min-height: 36px;
    font-size: var(--font-size-sm);
  }
  
  .calendar-day.has-notes::before {
    width: 6px;
    height: 6px;
    top: 2px;
    right: 2px;
  }
}

/* Landscape orientation adjustments */
@media (max-width: 768px) and (orientation: landscape) {
  .modal-content {
    max-height: calc(100vh - 20px);
  }
  
  .search-results {
    max-height: 40vh;
  }
  
  .export-preview {
    max-height: 40vh;
  }
}

/* Mobile keyboard handling */
.keyboard-open {
  height: 100vh;
  overflow: hidden;
}

.keyboard-open .modal-content {
  max-height: 60vh;
}

/* Touch improvements */
button, .hashtag, .search-result, .bullet-content {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Smooth scrolling for mobile */
.modal-content,
.search-results,
.export-preview,
.upload-list {
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}

/* Prevent text selection on interactive elements */
button, .hashtag, .nav-btn, .icon-btn, .tab-btn {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* Mobile-specific focus styles */
@media (max-width: 768px) {
  button:focus,
  input:focus,
  textarea:focus {
    outline: none;
    box-shadow: 0 0 0 2px var(--accent-color);
  }
}

/* Mobile Safari specific fixes */
@supports (-webkit-touch-callout: none) {
  /* iOS Safari */
  input[type="search"] {
    -webkit-appearance: none;
    border-radius: var(--radius-md);
  }
  
  input[type="date"] {
    -webkit-appearance: none;
    border-radius: var(--radius-md);
  }
  
  .modal-content {
    -webkit-overflow-scrolling: touch;
  }
}

/* Android Chrome specific fixes */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
  select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 8px center;
    background-repeat: no-repeat;
    background-size: 16px;
    padding-right: 40px;
  }
}

/* Consolidated mobile performance optimizations */
@media (max-width: 768px) {
  /* Hardware acceleration for better performance - applied selectively */
  .modal-content,
  .bullet-item,
  .search-result {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  
  /* Consolidated will-change properties */
  .modal-content,
  .bullet-list,
  .search-results {
    will-change: scroll-position;
  }
  
  .bullet-item {
    will-change: transform;
  }
  
  /* Prevent horizontal scrolling */
  html, body, #app {
    overflow-x: hidden;
  }
}

/* Reduce animations on mobile for better performance */
@media (max-width: 768px) and (prefers-reduced-motion: no-preference) {
  .bullet-item {
    animation-duration: 0.1s;
  }
  
  .modal-content {
    animation-duration: 0.15s;
  }
  
  * {
    transition-duration: 0.1s !important;
  }
}

/* Mobile accessibility improvements */
@media (max-width: 768px) {
  /* Larger touch targets */
  .icon-btn,
  .nav-btn,
  .filter-btn,
  .action-btn {
    min-width: 44px;
    min-height: 44px;
  }
  
  /* Better contrast for small screens */
  .secondary-text {
    color: var(--primary-text);
    opacity: 0.7;
  }
  
  /* Larger text for readability */
  .bullet-content,
  .search-result-content,
  .task-text {
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
  }
}
/* === responsive/tablet.css === */
/* Tablet Responsive Styles */

/* Tablet (769px - 1200px) - Simplified single breakpoint */
@media (min-width: 769px) and (max-width: 1200px) {
  
  /* Header adjustments for tablet */
  .app-header {
    padding: var(--spacing-md) var(--spacing-lg);
  }
  
  .header-left h1 {
    font-size: var(--font-size-xl);
  }
  
  .header-logo {
    width: 32px;
    height: 32px;
  }
  
  .header-right {
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: var(--spacing-sm);
  }
  
  /* Main content with standard minimap spacing */
  .main-content {
    padding: var(--spacing-lg) 0; /* Left and right padding set to 0 */
    margin-right: calc(var(--minimap-width) + 20px);
  }
  
  /* Note container adjustments */
  .note-container {
    max-width: 95%;
    margin: 0 auto;
  }
  
  .note-editor {
    padding: 30px var(--spacing-lg) var(--spacing-lg) var(--spacing-lg); /* Increased top padding for bullet-actions */
  }
  
  /* Bullet adjustments for tablet */
  .bullet-content {
    font-size: var(--font-size-base);
    padding: var(--spacing-sm) var(--spacing-md);
    min-height: 36px;
  }
  
  .bullet-content:focus {
    /* Padding removed to prevent indentation during editing */
  }
  
  /* Modal adjustments */
  .modal {
    padding: var(--spacing-lg);
  }
  
  .modal-content {
    max-width: 80%;
    max-height: 85vh;
  }
  
  /* Search modal specific */
  .search-modal-content {
    max-width: 85%;
    height: 85vh;
  }
  
  .search-container {
    padding: var(--spacing-lg);
  }
  
  .search-results {
    max-height: 60vh;
  }
  
  /* Smart Replace modal tablet optimizations */
  #smart-replace-modal .modal-content {
    max-width: 90vw;
    height: 85vh;
  }
  
  .smart-replace-rule {
    gap: var(--spacing-sm);
  }
  
  .rule-inputs {
    gap: var(--spacing-xs);
  }
  
  /* Task dashboard tablet optimizations */
  .task-controls {
    gap: var(--spacing-md);
  }
  
  .task-filters {
    gap: var(--spacing-xs);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }
  
  .task-filter-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
  }
  
  /* Ask AI modal tablet optimizations */
  #ask-ai-modal .modal-content {
    max-width: 600px;
    height: 70vh;
  }
  
  #ai-prompt {
    min-height: 200px;
  }
  
  /* Calendar adjustments */
  .calendar-day {
    min-height: 48px;
    font-size: var(--font-size-base);
  }
  
  .calendar-nav-btn {
    width: 36px;
    height: 36px;
  }
  
  /* Form adjustments */
  input,
  textarea,
  select {
    padding: var(--spacing-md);
    font-size: var(--font-size-base);
  }
  
  /* Consolidated button adjustments */
  .action-btn {
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--font-size-base);
    min-height: 40px;
  }
  
  .icon-btn {
    width: 36px;
    height: 36px;
  }
  
  .filter-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    min-height: 36px;
  }
  
  /* Hashtag adjustments */
  .hashtag {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-sm);
    min-height: 24px;
  }
  
  /* Task adjustments */
  .task-item {
    padding: var(--spacing-sm) var(--spacing-md);
  }
  
  .task-text {
    font-size: var(--font-size-sm);
  }
  
  .task-goto-btn {
    min-width: 32px;
    min-height: 32px;
  }
  
  /* Settings adjustments */
  .settings-section {
    padding: var(--spacing-lg);
  }
  
  .form-grid.two-column {
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-lg);
  }
  
  /* Import/Export adjustments */
  .drop-zone {
    padding: var(--spacing-xl);
    min-height: 180px;
  }
  
  .upload-item {
    padding: var(--spacing-md);
  }
  
  .export-preview {
    max-height: 60vh;
    padding: var(--spacing-lg);
  }
  
  /* Table adjustments */
  .table-block th,
  .table-block td {
    padding: var(--spacing-sm) var(--spacing-md);
  }
  
  /* Code block adjustments */
  .code-block pre {
    padding: var(--spacing-md);
    font-size: var(--font-size-sm);
  }
  
  /* Login adjustments */
  .login-form {
    max-width: 450px;
    padding: var(--spacing-xl);
  }
  
  .logo-image {
    width: 60px;
    height: 60px;
  }
  
  /* Page layout adjustments */
  .page-header {
    padding: var(--spacing-lg);
  }
  
  .page-content {
    padding: var(--spacing-lg);
  }
  
  /* Minimap uses standard desktop approach - no special sizing */
  .minimap-container {
    width: var(--minimap-width);
    display: block;
  }
  
  /* Line heights are now set dynamically in JavaScript for proportional scaling */
  .minimap-line {
    /* Height is set dynamically in JavaScript based on content scaling */
  }
  
  .minimap-line.hashtag {
    /* Height is set dynamically in JavaScript based on actual content size */
    /* Removed forced height restrictions to allow proper proportional scaling */
    margin-bottom: 2px;
    box-sizing: border-box;
  }
}

/* Tablet-specific touch improvements */
@media (min-width: 769px) and (max-width: 1200px) {
  
  /* Larger touch targets for tablet */
  .bullet-marker {
    width: 24px;
    height: 24px;
  }
  
  
  /* Better spacing for touch */
  .bullet-item {
    margin-bottom: 0;
  }
  
  /* Improved button spacing */
  .modal-footer {
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
  }
  
  /* Better form spacing */
  .form-group {
    margin-bottom: var(--spacing-lg);
  }
  
  /* Improved search results */
  .search-result {
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
  }
  
  /* Better task layout */
  .task-meta {
    gap: var(--spacing-sm);
  }
  
  /* Improved settings layout */
  .preference-group {
    padding: var(--spacing-lg);
  }
  
  /* Better calendar spacing */
  .calendar-controls {
    margin-bottom: var(--spacing-lg);
  }
  
  /* Improved drag handles */
  .drag-handle {
    padding: var(--spacing-sm);
    opacity: 0.7;
  }
  
  .drag-handle:hover {
    opacity: 1;
  }
}

/* Tablet-specific performance optimizations */
@media (min-width: 769px) and (max-width: 1200px) {
  
  /* Touch-optimized scrolling for tablet */
  .modal-content,
  .search-results,
  .export-preview,
  .bullet-list {
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
  }
  
  /* Consolidated will-change properties */
  .bullet-item {
    will-change: transform;
  }
  
  .modal-content {
    will-change: transform, opacity;
  }
}

/* Tablet reduced motion optimization */
@media (min-width: 769px) and (max-width: 1200px) and (prefers-reduced-motion: reduce) {
  * {
    transition-duration: 0.1s !important;
    animation-duration: 0.1s !important;
  }
}

/* Tablet accessibility improvements */
@media (min-width: 769px) and (max-width: 1200px) {
  
  /* Better focus indicators */
  button:focus-visible,
  input:focus-visible,
  textarea:focus-visible {
    outline: 3px solid var(--accent-color);
    outline-offset: 2px;
  }
  
  /* Improved contrast for medium screens */
  .secondary-text {
    opacity: 0.8;
  }
  
  /* Better text sizing */
  .bullet-content {
    line-height: var(--line-height-relaxed);
  }
  
  .search-result-content {
    line-height: var(--line-height-relaxed);
  }
  
  /* Improved button sizing */
  .close-btn {
    width: 40px;
    height: 40px;
    font-size: 20px;
  }
  
  /* Better modal header sizing */
  .modal-header h3 {
    font-size: var(--font-size-xl);
  }
}

/* Tablet-specific hover states */
@media (min-width: 769px) and (max-width: 1200px) and (hover: hover) {
  
  /* Enhanced hover effects for devices that support hover - removed for cohesion */
  .bullet-item:hover {
    background: transparent;
    border-radius: var(--radius-sm);
  }
  
  .search-result:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-lg);
  }
  
  .task-item:hover {
    transform: translateY(-1px);
  }
  
  .hashtag:hover {
    /* Removed transform for cleaner appearance */
  }
}

/* Tablet-specific grid layouts */
@media (min-width: 769px) and (max-width: 1200px) {
  
  .task-stats {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
  }
  
  .import-stats {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
  }
  
  .data-actions {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
  }
}

/* Tablet keyboard handling */
@media (min-width: 769px) and (max-width: 1200px) {
  
  /* Better keyboard navigation */
  .bullet-content:focus {
    background: transparent;
  }
  
  /* Improved tab navigation */
  .tab-btn:focus-visible {
    outline: 2px solid var(--accent-color);
    outline-offset: -2px;
  }
  
  /* Better modal focus management */
  .modal:focus-within {
    outline: none;
  }
  
  .modal-content:focus-within {
    box-shadow: var(--shadow-xl), 0 0 0 3px rgba(59, 130, 246, 0.1);
  }
}

/* Tablet print styles */
@media print and (min-width: 769px) and (max-width: 1200px) {
  
  .main-content {
    margin-right: 0;
    padding: var(--spacing-md);
  }
  
  .note-container {
    max-width: 100%;
    box-shadow: none;
    border: 1px solid #ccc;
  }
  
  .bullet-item {
    break-inside: avoid;
    margin-bottom: var(--spacing-sm);
  }
  
  .task-item {
    break-inside: avoid;
    box-shadow: none;
    border: 1px solid #ccc;
  }
}
/* === responsive/desktop.css === */
/* Desktop Responsive Styles */

/* Large Desktop (1200px+) */
@media (min-width: 1201px) {
  
  /* Header optimizations for large screens */
  .app-header {
    padding: var(--spacing-lg) var(--spacing-xl);
  }
  
  .header-left h1 {
    font-size: var(--font-size-2xl);
  }
  
  .header-logo {
    width: 36px;
    height: 36px;
  }
  
  /* Main content with full minimap */
  .main-content {
    padding: var(--spacing-sm) 0 var(--spacing-xl) 0; /* Left and right padding set to 0 */
    margin-right: calc(var(--minimap-width) + 20px);
  }
  
  /* Note container optimizations */
  .note-container {
    max-width: var(--note-max-width);
    margin: 0 auto;
  }
  
  .note-editor {
    padding: 30px var(--spacing-xl) var(--spacing-xl) var(--spacing-xl); /* Increased top padding for bullet-actions */
    min-height: calc(100vh - 200px);
  }
  
  /* Enhanced bullet system for desktop */
  .bullet-content {
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
    padding: var(--spacing-xs) var(--spacing-sm);
  }
  
  .bullet-content:focus {
    /* Padding removed to prevent indentation during editing */
  }
  
  /* Better hover states for desktop */
  .bullet-item:hover .bullet-actions {
    display: flex;
  }
  
  .bullet-item:hover .drag-handle {
    opacity: 1;
  }
  
  /* Ensure bullet actions are properly positioned on desktop */
  .bullet-actions {
    position: absolute;
    top: -20px;
    right: 0;
  }
  
  /* Modal optimizations */
  .modal {
    padding: var(--spacing-xl);
  }
  
  .modal-content {
    max-width: 70%;
    max-height: 90vh;
  }
  
  /* Search modal specific */
  .search-modal-content {
    max-width: 900px;
    height: 90vh;
  }
  
  .search-container {
    padding: var(--spacing-xl);
  }
  
  .search-results {
    max-height: 70vh;
  }
  
  /* Calendar optimizations */
  .calendar-day {
    min-height: 48px;
    font-size: var(--font-size-sm);
    padding: var(--spacing-xs);
  }
  
  .calendar-nav-btn {
    width: 40px;
    height: 40px;
  }
  
  /* Calendar modal desktop optimizations */
  #calendar-modal .modal-content {
    max-height: 90vh;
    padding: var(--spacing-xl);
    max-width: 520px;
  }
  
  /* Enhanced calendar grid for desktop */
  .calendar-grid {
    gap: 4px;
  }
  
  .calendar-day {
    min-height: 48px;
    font-size: var(--font-size-base);
  }
  
  .calendar-day-name {
    font-size: var(--font-size-sm);
    padding: var(--spacing-md);
  }
  
  /* Form optimizations */
  input,
  textarea,
  select {
    padding: var(--spacing-md);
    font-size: var(--font-size-base);
  }
  
  /* Consolidated button optimizations */
  .action-btn {
    padding: var(--spacing-md) var(--spacing-xl);
    font-size: var(--font-size-base);
    min-height: 44px;
  }
  
  .icon-btn {
    width: 40px;
    height: 40px;
  }
  
  .filter-btn {
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--font-size-sm);
    min-height: 36px;
  }
  
  /* Enhanced hashtag display */
  .hashtag {
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-size-sm);
    min-height: 28px;
  }
  
  /* Task optimizations */
  .task-item {
    padding: var(--spacing-sm) var(--spacing-md);
  }
  
  .task-text {
    font-size: var(--font-size-base);
  }
  
  .task-goto-btn {
    min-width: 36px;
    min-height: 36px;
  }
  
  /* Settings optimizations */
  .settings-section {
    padding: var(--spacing-xl);
  }
  
  .settings-form {
    max-width: 800px;
  }
  
  .form-grid.two-column {
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
  }
  
  /* Import/Export optimizations */
  .drop-zone {
    padding: calc(var(--spacing-xl) * 2);
    min-height: 240px;
  }
  
  .upload-item {
    padding: var(--spacing-lg);
  }
  
  .export-preview {
    max-height: 80vh;
    padding: var(--spacing-xl);
  }
  
  /* Table optimizations */
  .table-block th,
  .table-block td {
    padding: var(--spacing-md) var(--spacing-lg);
  }
  
  /* Code block optimizations */
  .code-block pre {
    padding: var(--spacing-lg);
    font-size: var(--font-size-base);
  }
  
  /* Login optimizations */
  .login-container {
    padding: var(--spacing-xl);
  }
  
  .login-form {
    max-width: 500px;
    padding: calc(var(--spacing-xl) * 2);
  }
  
  .logo-image {
    width: 72px;
    height: 72px;
  }
  
  /* Page layout optimizations */
  .page-header {
    padding: var(--spacing-xl);
  }
  
  .page-content {
    padding: var(--spacing-xl);
  }
  
  /* Full minimap for desktop */
  .minimap-container {
    width: var(--minimap-width);
    display: block;
  }
  
  /* Line heights are now set dynamically in JavaScript for proportional scaling */
  .minimap-line {
    /* Height is set dynamically in JavaScript based on content scaling */
  }
  
  /* Hashtag lines now use proportional heights like regular content on desktop */
  .minimap-line.hashtag {
    /* Height is set dynamically in JavaScript based on actual content size */
    /* Removed forced height restrictions to allow proper proportional scaling */
    margin-bottom: 2px;
    box-sizing: border-box;
  }
}

/* Ultra-wide Desktop (1400px+) */
@media (min-width: 1401px) {
  
  /* Even more spacious layout */
  .main-content {
    padding: var(--spacing-sm) calc(var(--spacing-xl) * 2) calc(var(--spacing-xl) * 2) calc(var(--spacing-xl) * 2);
  }
  
  .note-container {
    max-width: 1000px;
  }
  
  .note-editor {
    padding: 30px calc(var(--spacing-xl) * 2) calc(var(--spacing-xl) * 2) calc(var(--spacing-xl) * 2); /* Increased top padding for bullet-actions */
  }
  
  /* Enhanced modals for ultra-wide */
  .modal-content {
    max-width: 60%;
  }
  
  .search-modal-content {
    max-width: 1100px;
  }
  
  /* Better form layout */
  .settings-form {
    max-width: 900px;
  }
  
  .form-grid.two-column {
    gap: calc(var(--spacing-xl) * 2);
  }
  
  /* Enhanced task layout */
  .tasks-list {
    max-width: 1000px;
  }
  
  /* Better login layout */
  .login-form {
    max-width: 600px;
  }
}

/* Desktop-specific hover enhancements */
@media (min-width: 1201px) and (hover: hover) {
  
  /* Enhanced bullet hover effects - removed for cohesion */
  .bullet-item:hover {
    background: transparent;
    border-radius: var(--radius-sm);
    transition: all var(--transition-base);
  }
  
  /* Enhanced search result hover */
  .search-result:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-xl);
  }
  
  /* Enhanced task hover */
  .task-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-xl);
  }
  
  /* Enhanced hashtag hover */
  .hashtag:hover {
    /* Removed transform and box-shadow for cleaner appearance */
  }
  
  /* Enhanced button hover */
  .action-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(42, 157, 188, 0.3);
  }
  
  /* Enhanced filter button hover */
  .filter-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(42, 157, 188, 0.2);
  }
  
  /* Enhanced calendar day hover */
  .calendar-day:hover {
    transform: scale(1.05);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  }
  
  /* Enhanced modal hover effects */
  .modal-content {
    transition: transform var(--transition-base);
  }
  
  /* Enhanced drag handle hover */
  .drag-handle:hover {
    background: var(--tertiary-bg);
  }
}

/* Desktop-specific focus enhancements */
@media (min-width: 1201px) {
  
  /* Enhanced focus indicators */
  button:focus-visible,
  input:focus-visible,
  textarea:focus-visible,
  select:focus-visible {
    outline: 3px solid var(--accent-color);
    outline-offset: 3px;
    box-shadow: 0 0 0 6px rgba(59, 130, 246, 0.1);
  }
  
  /* Enhanced bullet focus */
  .bullet-content:focus {
    background: transparent;
  }
  
  /* Enhanced hashtag focus */
  .hashtag:focus-visible {
    outline: 2px solid var(--accent-color);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.1);
  }
  
  /* Enhanced modal focus */
  .modal-content:focus-within {
    box-shadow: var(--shadow-xl), 0 0 0 4px rgba(59, 130, 246, 0.1);
  }
}

/* Desktop keyboard shortcuts and navigation */
@media (min-width: 1201px) {
  
  /* Keyboard shortcut hints */
  .keyboard-hint {
    display: inline;
    opacity: 0.7;
  }
  
  /* Enhanced tab navigation */
  .tab-btn:focus-visible {
    outline: 2px solid var(--accent-color);
    outline-offset: -2px;
    background: var(--tertiary-bg);
  }
  
  /* Better modal keyboard navigation */
  .modal[tabindex="-1"]:focus {
    outline: none;
  }
  
  /* Enhanced search keyboard navigation */
  .search-result.keyboard-focus {
    background: var(--tertiary-bg);
    border-color: var(--accent-color);
    outline: 2px solid var(--accent-color);
    outline-offset: -2px;
  }
}

/* Desktop grid and layout optimizations */
@media (min-width: 1201px) {
  
  /* Enhanced task stats grid */
  .task-stats {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-lg);
  }
  
  /* Enhanced import stats grid */
  .import-stats {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-lg);
  }
  
  /* Enhanced data actions grid */
  .data-actions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-lg);
  }
  
  /* Enhanced settings tabs */
  .settings-tabs {
    display: flex;
    justify-content: center;
  }
  
  .settings-tab {
    min-width: 150px;
  }
  
  /* Enhanced filter layout */
  .task-filters,
  .search-filters {
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: var(--spacing-md);
  }
}

/* Desktop performance optimizations */
@media (min-width: 1201px) {
  
  /* Consolidated performance optimizations */
  .modal-content,
  .search-results,
  .export-preview,
  .bullet-list {
    scroll-behavior: smooth;
  }
  
  /* Consolidated will-change properties */
  .bullet-item {
    will-change: transform, background-color;
  }
  
  .modal-content {
    will-change: transform, opacity, box-shadow;
  }
  
  .search-result,
  .task-item,
  .hashtag,
  .action-btn,
  .filter-btn {
    will-change: transform, box-shadow;
  }
}

/* Desktop accessibility enhancements */
@media (min-width: 1201px) {
  
  /* Better contrast ratios */
  .secondary-text {
    opacity: 0.8;
  }
  
  /* Enhanced text sizing */
  .bullet-content {
    line-height: var(--line-height-relaxed);
  }
  
  .search-result-content,
  .task-text {
    line-height: var(--line-height-relaxed);
  }
  
  /* Better button sizing */
  .close-btn {
    width: 44px;
    height: 44px;
    font-size: 24px;
  }
  
  /* Enhanced modal header sizing */
  .modal-header h3 {
    font-size: var(--font-size-2xl);
  }
  
  /* Better form spacing */
  .form-group {
    margin-bottom: var(--spacing-lg);
  }
  
  /* Enhanced error messages */
  .form-error,
  .form-success {
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-base);
  }
}

/* Desktop print optimizations */
@media print and (min-width: 1201px) {
  
  .main-content {
    margin-right: 0;
    padding: var(--spacing-lg);
  }
  
  .note-container {
    max-width: 100%;
    box-shadow: none;
    border: none;
  }
  
  .bullet-item {
    break-inside: avoid;
    margin-bottom: var(--spacing-sm);
  }
  
  .task-item {
    break-inside: avoid;
    box-shadow: none;
    border: 1px solid #ccc;
    margin-bottom: var(--spacing-md);
  }
  
  .search-result {
    break-inside: avoid;
    box-shadow: none;
    border: 1px solid #ccc;
  }
  
  /* Hide interactive elements */
  .minimap-container,
  .drag-handle,
  .bullet-actions,
  .modal,
  .in-page-search-bar {
    display: none !important;
  }
  
  /* Optimize text for print */
  .bullet-content,
  .search-result-content,
  .task-text {
    color: #000 !important;
    background: transparent !important;
  }
  
  /* Optimize images for print */
  .bullet-image,
  .export-preview img {
    max-width: 100% !important;
    height: auto !important;
    break-inside: avoid;
  }
}

/* Desktop dark mode enhancements */
@media (min-width: 1201px) and (prefers-color-scheme: dark) {
  
  /* Enhanced shadows for dark mode */
  .modal-content {
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
  }
  
  .task-item:hover,
  .search-result:hover {
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.3);
  }
  
  /* Enhanced button shadows */
  .action-btn:hover {
    box-shadow: 0 4px 12px rgba(42, 157, 188, 0.4);
  }
  
  /* Enhanced calendar shadows */
  .calendar-day.today {
    box-shadow: 0 2px 8px rgba(254, 180, 69, 0.5);
  }
}

/* Desktop high contrast mode */
@media (min-width: 1201px) and (prefers-contrast: high) {
  
  /* Enhanced borders */
  .modal-content,
  .note-container,
  .task-item,
  .search-result {
    border: 2px solid var(--border-color);
  }
  
  /* Enhanced focus indicators */
  button:focus-visible,
  input:focus-visible,
  textarea:focus-visible {
    outline: 4px solid var(--accent-color);
    outline-offset: 2px;
  }
  
  /* Enhanced interactive elements */
  .hashtag,
  .filter-btn,
  .action-btn {
    border: 2px solid currentColor;
  }
}

/* Desktop reduced motion optimization */
@media (min-width: 1201px) and (prefers-reduced-motion: reduce) {
  
  /* Disable transform animations */
  .bullet-item:hover,
  .search-result:hover,
  .task-item:hover,
  .hashtag:hover,
  .action-btn:hover,
  .filter-btn:hover,
  .calendar-day:hover,
  .drag-handle:hover {
    transform: none;
  }
  
  /* Simplified transitions for reduced motion */
  * {
    transition: opacity var(--transition-base),
                color var(--transition-base),
                background-color var(--transition-base),
                border-color var(--transition-base) !important;
  }
  
  /* Reset will-change for better performance */
  .bullet-item,
  .modal-content,
  .search-result,
  .task-item,
  .hashtag,
  .action-btn,
  .filter-btn {
    will-change: auto;
  }
}
/* === base/utilities.css === */
/* Utility: Common button and focus styles */
.btn-base {
  border-radius: var(--radius-lg);
  font-family: inherit;
  transition: all var(--transition-base);
  cursor: pointer;
}
.focus-outline {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}
/* ITCSS Layer: Base (Utilities) */
/* Utility Classes */

/* Display */
.hidden {
  display: none !important;
}

.block {
  display: block;
}

.inline {
  display: inline;
}

.inline-block {
  display: inline-block;
}

.flex {
  display: flex;
}

.inline-flex {
  display: inline-flex;
}

.grid {
  display: grid;
}

.inline-grid {
  display: inline-grid;
}

/* Visibility */
.visible {
  visibility: visible;
}

.invisible {
  visibility: hidden;
}

/* Screen Reader Only */
.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;
}

/* Flexbox Utilities */
.flex-row {
  flex-direction: row;
}

.flex-col {
  flex-direction: column;
}

.flex-wrap {
  flex-wrap: wrap;
}

.flex-nowrap {
  flex-wrap: nowrap;
}

.items-start {
  align-items: flex-start;
}

.items-center {
  align-items: center;
}

.items-end {
  align-items: flex-end;
}

.items-stretch {
  align-items: stretch;
}

.justify-start {
  justify-content: flex-start;
}

.justify-center {
  justify-content: center;
}

.justify-end {
  justify-content: flex-end;
}

.justify-between {
  justify-content: space-between;
}

.justify-around {
  justify-content: space-around;
}

.justify-evenly {
  justify-content: space-evenly;
}

.flex-1 {
  flex: 1 1 0%;
}

.flex-auto {
  flex: 1 1 auto;
}

.flex-none {
  flex: none;
}

.flex-shrink-0 {
  flex-shrink: 0;
}

.flex-grow {
  flex-grow: 1;
}

/* Gap */
.gap-1 { gap: var(--space-1); }
.gap-2 { gap: var(--space-2); }
.gap-3 { gap: var(--space-3); }
.gap-4 { gap: var(--space-4); }
.gap-5 { gap: var(--space-5); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }

/* Spacing */
.m-0 { margin: 0; }
.m-1 { margin: var(--space-1); }
.m-2 { margin: var(--space-2); }
.m-3 { margin: var(--space-3); }
.m-4 { margin: var(--space-4); }
.m-5 { margin: var(--space-5); }
.m-6 { margin: var(--space-6); }
.m-8 { margin: var(--space-8); }
.m-auto { margin: auto; }

.mx-auto { margin-left: auto; margin-right: auto; }
.my-auto { margin-top: auto; margin-bottom: auto; }

.mt-0 { margin-top: 0; }
.mt-1 { margin-top: var(--space-1); }
.mt-2 { margin-top: var(--space-2); }
.mt-3 { margin-top: var(--space-3); }
.mt-4 { margin-top: var(--space-4); }
.mt-5 { margin-top: var(--space-5); }
.mt-6 { margin-top: var(--space-6); }
.mt-8 { margin-top: var(--space-8); }

.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: var(--space-1); }
.mb-2 { margin-bottom: var(--space-2); }
.mb-3 { margin-bottom: var(--space-3); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-5 { margin-bottom: var(--space-5); }
.mb-6 { margin-bottom: var(--space-6); }
.mb-8 { margin-bottom: var(--space-8); }

.ml-0 { margin-left: 0; }
.ml-1 { margin-left: var(--space-1); }
.ml-2 { margin-left: var(--space-2); }
.ml-3 { margin-left: var(--space-3); }
.ml-4 { margin-left: var(--space-4); }
.ml-5 { margin-left: var(--space-5); }
.ml-6 { margin-left: var(--space-6); }
.ml-8 { margin-left: var(--space-8); }

.mr-0 { margin-right: 0; }
.mr-1 { margin-right: var(--space-1); }
.mr-2 { margin-right: var(--space-2); }
.mr-3 { margin-right: var(--space-3); }
.mr-4 { margin-right: var(--space-4); }
.mr-5 { margin-right: var(--space-5); }
.mr-6 { margin-right: var(--space-6); }
.mr-8 { margin-right: var(--space-8); }

.p-0 { padding: 0; }
.p-1 { padding: var(--space-1); }
.p-2 { padding: var(--space-2); }
.p-3 { padding: var(--space-3); }
.p-4 { padding: var(--space-4); }
.p-5 { padding: var(--space-5); }
.p-6 { padding: var(--space-6); }
.p-8 { padding: var(--space-8); }

.px-0 { padding-left: 0; padding-right: 0; }
.px-1 { padding-left: var(--space-1); padding-right: var(--space-1); }
.px-2 { padding-left: var(--space-2); padding-right: var(--space-2); }
.px-3 { padding-left: var(--space-3); padding-right: var(--space-3); }
.px-4 { padding-left: var(--space-4); padding-right: var(--space-4); }
.px-5 { padding-left: var(--space-5); padding-right: var(--space-5); }
.px-6 { padding-left: var(--space-6); padding-right: var(--space-6); }
.px-8 { padding-left: var(--space-8); padding-right: var(--space-8); }

.py-0 { padding-top: 0; padding-bottom: 0; }
.py-1 { padding-top: var(--space-1); padding-bottom: var(--space-1); }
.py-2 { padding-top: var(--space-2); padding-bottom: var(--space-2); }
.py-3 { padding-top: var(--space-3); padding-bottom: var(--space-3); }
.py-4 { padding-top: var(--space-4); padding-bottom: var(--space-4); }
.py-5 { padding-top: var(--space-5); padding-bottom: var(--space-5); }
.py-6 { padding-top: var(--space-6); padding-bottom: var(--space-6); }
.py-8 { padding-top: var(--space-8); padding-bottom: var(--space-8); }

/* Width & Height */
.w-full { width: 100%; }
.w-auto { width: auto; }
.w-fit { width: fit-content; }

.h-full { height: 100%; }
.h-auto { height: auto; }
.h-fit { height: fit-content; }

.min-w-0 { min-width: 0; }
.min-h-0 { min-height: 0; }

.max-w-none { max-width: none; }
.max-w-xs { max-width: 20rem; }
.max-w-sm { max-width: 24rem; }
.max-w-md { max-width: 28rem; }
.max-w-lg { max-width: 32rem; }
.max-w-xl { max-width: 36rem; }
.max-w-2xl { max-width: 42rem; }
.max-w-3xl { max-width: 48rem; }
.max-w-4xl { max-width: 56rem; }
.max-w-full { max-width: 100%; }

/* Position */
.relative { position: relative; }
.absolute { position: absolute; }
.fixed { position: fixed; }
.sticky { position: sticky; }

.top-0 { top: 0; }
.right-0 { right: 0; }
.bottom-0 { bottom: 0; }
.left-0 { left: 0; }

/* Z-Index */
.z-0 { z-index: 0; }
.z-10 { z-index: 10; }
.z-20 { z-index: 20; }
.z-30 { z-index: 30; }
.z-40 { z-index: 40; }
.z-50 { z-index: 50; }

/* Overflow */
.overflow-hidden { overflow: hidden; }
.overflow-visible { overflow: visible; }
.overflow-auto { overflow: auto; }
.overflow-scroll { overflow: scroll; }

.overflow-x-hidden { overflow-x: hidden; }
.overflow-x-auto { overflow-x: auto; }
.overflow-y-hidden { overflow-y: hidden; }
.overflow-y-auto { overflow-y: auto; }

/* Border Radius */
.rounded-none { border-radius: 0; }
.rounded-sm { border-radius: var(--radius-sm); }
.rounded { border-radius: var(--radius-md); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-full { border-radius: var(--radius-full); }

/* Cursor */
.cursor-auto { cursor: auto; }
.cursor-default { cursor: default; }
.cursor-pointer { cursor: pointer; }
.cursor-wait { cursor: wait; }
.cursor-text { cursor: text; }
.cursor-move { cursor: move; }
.cursor-help { cursor: help; }
.cursor-not-allowed { cursor: not-allowed; }

/* User Select */
.select-none {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.select-text {
  -webkit-user-select: text;
  -moz-user-select: text;
  -ms-user-select: text;
  user-select: text;
}

.select-all {
  -webkit-user-select: all;
  -moz-user-select: all;
  -ms-user-select: all;
  user-select: all;
}

/* Pointer Events */
.pointer-events-none { pointer-events: none; }
.pointer-events-auto { pointer-events: auto; }

/* Touch Action */
.touch-auto { touch-action: auto; }
.touch-none { touch-action: none; }
.touch-pan-x { touch-action: pan-x; }
.touch-pan-y { touch-action: pan-y; }
.touch-manipulation { touch-action: manipulation; }

/* Opacity */
.opacity-0 { opacity: 0; }
.opacity-25 { opacity: 0.25; }
.opacity-50 { opacity: 0.5; }
.opacity-75 { opacity: 0.75; }
.opacity-100 { opacity: 1; }

/* Transform */
.transform { transform: translateZ(0); }
.transform-none { transform: none; }

/* Transition */
.transition-none { transition: none; }
.transition-all { transition: all var(--transition-base); }
.transition-colors { transition: color var(--transition-base), background-color var(--transition-base), border-color var(--transition-base); }
.transition-opacity { transition: opacity var(--transition-base); }
.transition-transform { transition: transform var(--transition-base); }

/* Animation */
@keyframes spin {
  to { transform: rotate(360deg); }
}

@keyframes ping {
  75%, 100% {
    transform: scale(2);
    opacity: 0;
  }
}

@keyframes pulse {
  50% { opacity: 0.5; }
}

@keyframes bounce {
  0%, 100% {
    transform: translateY(-25%);
    animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
  }
  50% {
    transform: none;
    animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
  }
}

.animate-spin { animation: spin 1s linear infinite; }
.animate-ping { animation: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite; }
.animate-pulse { animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite; }
.animate-bounce { animation: bounce 1s infinite; }

/* Save notification animation */
@keyframes fadeInOut {
  0% { opacity: 0; transform: translateY(-10px); }
  10% { opacity: 1; transform: translateY(0); }
  90% { opacity: 1; transform: translateY(0); }
  100% { opacity: 0; transform: translateY(-10px); }
}

/* Session takeover dialog styles - removed */

/* Save Status Indicator — minimal, barely visible, sits above hint bar */
.save-status {
  position: fixed;
  bottom: 8px;
  left: 8px;
  font-size: 11px;
  color: var(--muted-text);
  opacity: 0.6;
  font-family: var(--font-family);
  z-index: 10000;
  pointer-events: none;
  user-select: none;
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 4px 8px;
  background: transparent;
  transition: opacity 0.2s ease, bottom 0.15s ease;
}

.save-status.hidden {
  opacity: 0;
  pointer-events: none;
}

.save-status-icon {
  font-size: 8px;
  line-height: 1;
}

.save-status.saving .save-status-icon {
  color: var(--warning-color);
  animation: pulse 1.5s ease-in-out infinite;
}

.save-status.saved .save-status-icon {
  color: var(--success-color);
}

.save-status.unsaved .save-status-icon {
  color: var(--error-color);
}

.save-status-text {
  font-weight: var(--font-weight-medium);
  font-size: 11px;
}

.save-status-time {
  font-size: 10px;
  opacity: 0.7;
  margin-left: 4px;
}

/* Note: @keyframes pulse is already defined above (line 369).
   This save-status variant uses the same animation. */

/* Save status now uses CSS variables — no dark mode override needed */

/* Version Number — now inline on settings page */
.settings-version {
  text-align: center;
  padding: var(--spacing-lg) 0 var(--spacing-sm);
}

.version-number-inline {
  font-size: var(--font-size-xs);
  color: var(--muted-text);
  opacity: 0.6;
  font-family: var(--font-family-mono);
  user-select: none;
}
