@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@400;700&family=Dancing+Script:wght@400;700&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap');


/* ==========================================
   Design System & Tokens (Floodra Brand)
   ========================================== */
:root {
  /* Default Theme: Deep Storm Indigo */
  --bg-start: #0a0b18;
  --bg-end: #030408;
  --glow-color: rgba(99, 102, 241, 0.25);
  --glow-bright: rgba(129, 140, 248, 0.8);
  --accent-color: #6366f1;
  --text-primary: #f3f4f6;
  --text-secondary: #9ca3af;
  --text-muted: #6b7280;
  
  /* Sophisticated Cathartic Palette Tokens */
  --color-mist: #94a3b8;
  --color-sage: #10b981;
  --color-ink: #0d0a15;
  
  --glass-bg: rgba(255, 255, 255, 0.02);
  --glass-border: rgba(255, 255, 255, 0.06);
  --glass-highlight: rgba(255, 255, 255, 0.1);
  --card-shadow: 0 12px 40px 0 rgba(0, 0, 0, 0.5);
  
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-sans: 'Plus Jakarta Sans', system-ui, sans-serif;
  --font-hand: 'Caveat', cursive;
  
  --transition-slow: 2.5s cubic-bezier(0.25, 1, 0.5, 1); /* Slower transitions for emotional gravitas */
  --transition-medium: 0.6s cubic-bezier(0.25, 1, 0.5, 1);
  --transition-fast: 0.25s cubic-bezier(0.25, 1, 0.5, 1);
  
  /* Responsive Header Variables */
  --header-bg: rgba(10, 8, 16, 0.82);
  --header-border: rgba(255, 255, 255, 0.08);
  --header-shadow: 0 4px 24px rgba(0, 0, 0, 0.35);
}

/* ==========================================
   EMOTIONAL GRADIENT PALETTES
   ========================================== */

/* Grief: Midnight Rain */
body.mood-grief {
  --bg-start: #050818;
  --bg-end: #010206;
  --accent-color: #6366f1;
  --glow-color: rgba(99, 102, 241, 0.25);
  --glow-bright: rgba(129, 140, 248, 0.8);
}

/* Anger: Embers Glow */
body.mood-anger {
  --bg-start: #1e0508;
  --bg-end: #050102;
  --accent-color: #ef4444;
  --glow-color: rgba(239, 68, 68, 0.25);
  --glow-bright: rgba(248, 113, 113, 0.8);
}

/* Nostalgia: Golden Dusk */
body.mood-nostalgia {
  --bg-start: #1c1108;
  --bg-end: #060301;
  --accent-color: #f59e0b;
  --glow-color: rgba(245, 158, 11, 0.2);
  --glow-bright: rgba(251, 191, 36, 0.8);
}

/* Peace: Sage Solace */
body.mood-peace {
  --bg-start: #02120b;
  --bg-end: #010503;
  --accent-color: #10b981;
  --glow-color: rgba(16, 185, 129, 0.2);
  --glow-bright: rgba(52, 211, 153, 0.8);
}

/* Hope: Aurora Dawn */
body.mood-hope {
  --bg-start: #031422;
  --bg-end: #01060a;
  --accent-color: #06b6d4;
  --glow-color: rgba(6, 182, 212, 0.25);
  --glow-bright: rgba(34, 211, 238, 0.8);
}

/* Numbness: Slate Mist */
body.mood-numbness {
  --bg-start: #16181e;
  --bg-end: #07080a;
  --accent-color: #94a3b8;
  --glow-color: rgba(148, 163, 184, 0.2);
  --glow-bright: rgba(203, 213, 225, 0.8);
}

/* ==========================================
   Base Elements & Reset
   ========================================== */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  background: radial-gradient(circle at 50% 50%, var(--bg-start) 0%, var(--bg-end) 100%);
  color: var(--text-primary);
  font-family: var(--font-sans);
  min-height: 100vh;
  overflow: hidden;
  transition: background var(--transition-slow);
  position: relative;
}

/* Canvas Background Overlay */
#bg-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

/* Lightning strike flash container overlay */
.lightning-flash-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #ffffff;
  z-index: 2;
  opacity: 0;
  pointer-events: none;
}

.lightning-flash-overlay.strike {
  animation: lightning-strike 0.5s ease-out;
}

/* Custom Scrollbars */
::-webkit-scrollbar {
  width: 6px;
}
::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.1);
}
::-webkit-scrollbar-thumb {
  background: var(--glass-border);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--accent-color);
}

/* ==========================================
   Layout Framework & View System
   ========================================== */
#app-container {
  position: relative;
  z-index: 3;
  width: 100vw;
  height: 100vh;
  display: flex;
  flex-direction: row;
  overflow: hidden;
}

.main-content-panel {
  display: flex;
  flex-direction: column;
  flex: 1;
  height: 100vh;
  position: relative;
  overflow: hidden;
}

header {
  padding: 1rem 2rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--glass-border);
  backdrop-filter: blur(8px);
  z-index: 10;
  flex-shrink: 0;
  opacity: 0; /* Hidden on gatehouse portal view by default */
  pointer-events: none;
  transform: translateY(-10px);
  transition: opacity var(--transition-medium), transform var(--transition-medium);
}

header.visible {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0);
}

.brand {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  cursor: pointer;
}

.brand-icon {
  width: 32px;
  height: 32px;
  background: radial-gradient(circle, var(--accent-color) 0%, transparent 70%);
  filter: drop-shadow(0 0 8px var(--accent-color));
  border-radius: 50%;
  position: relative;
  animation: pulse-glow 3s infinite alternate;
}

.brand-icon::after {
  content: '';
  position: absolute;
  top: 25%;
  left: 25%;
  width: 50%;
  height: 50%;
  background: #ffffff;
  border-radius: 50%;
  filter: blur(1px);
}

.brand h1 {
  font-family: var(--font-serif);
  font-weight: 400;
  letter-spacing: 3px;
  font-size: 1.6rem;
  background: linear-gradient(to right, #ffffff, var(--text-secondary));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Controls HUD */
.controls-hud {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.view-indicator {
  display: none; /* Hidden to optimize header space and avoid overlapping; the top navigation active tab represents the active view */
}

/* Elegant Mood Atmosphere Quick-Selector in Header */
.header-mood-selector {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  padding: 0.4rem 0.8rem;
  border-radius: 20px;
  backdrop-filter: blur(8px);
  margin-right: 0.5rem;
  transition: border-color var(--transition-fast);
}

.header-mood-selector:hover {
  border-color: var(--glass-highlight);
}

.header-mood-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition-medium);
  position: relative;
  background: currentColor;
}

.header-mood-dot.mood-grief { color: #6366f1; }
.header-mood-dot.mood-anger { color: #ef4444; }
.header-mood-dot.mood-nostalgia { color: #f59e0b; }
.header-mood-dot.mood-peace { color: #10b981; }
.header-mood-dot.mood-hope { color: #06b6d4; }
.header-mood-dot.mood-numbness { color: #94a3b8; }

.header-mood-dot:hover {
  transform: scale(1.3);
  box-shadow: 0 0 10px currentColor;
}

.header-mood-dot.active {
  transform: scale(1.4);
  border-color: #ffffff;
  box-shadow: 0 0 14px currentColor;
}

.hud-btn {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.hud-btn:hover {
  border-color: var(--accent-color);
  box-shadow: 0 0 12px var(--glow-color);
  transform: translateY(-2px);
}

.hud-btn svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}

/* Floating Audio settings panel */
.audio-panel {
  position: absolute;
  top: 5.5rem;
  right: 3rem;
  width: 260px;
  background: rgba(10, 8, 16, 0.85);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.5rem;
  backdrop-filter: blur(20px);
  box-shadow: var(--card-shadow);
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  transform: translateY(-10px);
  opacity: 0;
  pointer-events: none;
  transition: all var(--transition-medium);
}

.audio-panel.active {
  transform: translateY(0);
  opacity: 1;
  pointer-events: all;
}

.audio-panel h3 {
  font-size: 0.9rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--accent-color);
}

.volume-slider-container {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.volume-slider {
  flex-grow: 1;
  height: 4px;
  background: var(--glass-border);
  border-radius: 2px;
  outline: none;
  -webkit-appearance: none;
}

.volume-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 12px;
  height: 12px;
  background: var(--accent-color);
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 0 8px var(--accent-color);
  transition: transform 0.1s;
}

.volume-slider::-webkit-slider-thumb:hover {
  transform: scale(1.3);
}

.soundscape-selector {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
}

.sound-option {
  padding: 0.6rem 0.8rem;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  font-size: 0.85rem;
  text-align: left;
  cursor: pointer;
  transition: all var(--transition-fast);
  color: var(--text-secondary);
}

.sound-option:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: var(--text-secondary);
  color: var(--text-primary);
}

.sound-option.active {
  border-color: var(--accent-color);
  background: rgba(167, 139, 250, 0.05);
  color: var(--accent-color);
  font-weight: 500;
  box-shadow: inset 0 0 8px rgba(167, 139, 250, 0.1);
}

/* ==========================================
   Navigation Dock (Revamped Premium Floating Pill)
   ========================================== */
nav {
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 100;
  flex-shrink: 0;
  opacity: 0; /* Hidden on gatehouse view */
  pointer-events: none;
  transform: translateY(-5px);
  transition: opacity var(--transition-medium), transform var(--transition-medium);
}

nav.visible {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0);
}

.nav-dock {
  position: relative;
  background: rgba(10, 8, 16, 0.45);
  border: 1px solid var(--glass-border);
  padding: 0.28rem;
  border-radius: 24px;
  display: flex;
  gap: 0.22rem;
  backdrop-filter: blur(24px) saturate(120%);
  -webkit-backdrop-filter: blur(24px) saturate(120%);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4), inset 0 1px 1px rgba(255, 255, 255, 0.05);
  transition: border-color var(--transition-medium), box-shadow var(--transition-medium);
}

.nav-dock:hover {
  border-color: rgba(255, 255, 255, 0.15);
}

/* Sliding active indicator bubble */
.nav-pill-indicator {
  position: absolute;
  z-index: 1;
  border-radius: 18px;
  background: var(--accent-color);
  box-shadow: 0 4px 15px var(--glow-color);
  pointer-events: none;
  transition: left 0.38s cubic-bezier(0.25, 1, 0.5, 1), 
              width 0.38s cubic-bezier(0.25, 1, 0.5, 1),
              top 0.38s cubic-bezier(0.25, 1, 0.5, 1),
              height 0.38s cubic-bezier(0.25, 1, 0.5, 1),
              background var(--transition-medium),
              box-shadow var(--transition-medium);
}

.nav-item {
  position: relative;
  z-index: 2;
  background: transparent !important;
  border: none;
  padding: 0.35rem 0.72rem;
  border-radius: 18px;
  color: var(--text-secondary);
  font-size: 0.68rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-sans);
  font-weight: 500;
  transition: color var(--transition-medium), transform var(--transition-fast);
}

.nav-item svg {
  width: 13px;
  height: 13px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.75;
  transition: transform var(--transition-fast), stroke-width var(--transition-fast);
}

/* Gentle tactile lift on hover */
.nav-item:hover {
  color: var(--text-primary);
  transform: translateY(-1.5px);
}

.nav-item:hover svg {
  transform: scale(1.1);
  stroke-width: 2;
}

/* Fully contrast dark text on top of the glowing sliding pill */
.nav-item.active {
  color: #0d0a15 !important;
  font-weight: 700;
}

.nav-item.active svg {
  stroke-width: 2.25;
}

/* Scroll-to-Top and Scroll-to-Bottom Navigation Buttons */
.nav-scroll-btn {
  position: relative;
  z-index: 2;
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  color: var(--text-primary) !important;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color var(--transition-medium), transform var(--transition-fast), background-color var(--transition-medium), border-color var(--transition-medium);
  padding: 0;
  flex-shrink: 0;
}

.nav-scroll-btn svg {
  display: block;
  width: 14px !important;
  height: 14px !important;
  stroke: currentColor !important;
  stroke-width: 2.5 !important;
  fill: none !important;
  transition: transform var(--transition-fast);
}

.nav-scroll-btn:hover {
  color: var(--accent-color) !important;
  background-color: rgba(255, 255, 255, 0.12) !important;
  border-color: rgba(255, 255, 255, 0.2) !important;
  transform: translateY(0) scale(1.1);
}

.nav-scroll-btn.scroll-top:hover svg {
  transform: translateY(-2px);
}

.nav-scroll-btn.scroll-bottom:hover svg {
  transform: translateY(2px);
}

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

body.theme-light .nav-scroll-btn {
  background: rgba(0, 0, 0, 0.03) !important;
  border: 1px solid rgba(0, 0, 0, 0.06) !important;
  color: var(--text-primary) !important;
}

body.theme-light .nav-scroll-btn:hover {
  color: var(--accent-color) !important;
  background-color: rgba(0, 0, 0, 0.08) !important;
  border-color: rgba(0, 0, 0, 0.12) !important;
}

/* ==========================================
   View Container & System Switcher
   ========================================== */
main {
  flex-grow: 1;
  position: relative;
  overflow: hidden;
  width: 100%;
}

.view-section {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  pointer-events: none;
  transform: translateY(15px);
  transition: opacity var(--transition-medium), transform var(--transition-medium);
  overflow-y: auto;
  padding: 2rem 3rem;
  display: flex;
  flex-direction: column;
}

.view-section.active {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0);
}

/* ==========================================
   VIEW: Portal (The Forest Gatehouse)
   ========================================== */
#view-portal {
  display: flex;
  flex-direction: column;
  justify-content: flex-start; /* Changed from center to allow precise vertical positioning */
  padding-top: 3vh; /* Moved further upwards near the top as requested */
  align-items: center;
  text-align: center;
  height: 100%;
  padding-bottom: 4rem;
  z-index: 5;
  position: absolute;
  
  /* Pure dark with canvas rain - no bluish overlay */
  background: transparent;
  transition: background var(--transition-slow);
}

/* Pathway Guide line animation */
.portal-pathway-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  overflow: hidden;
}

.portal-pathway-svg {
  width: 100%;
  height: 100%;
  opacity: 0.35;
}

.pathway-line {
  stroke-dasharray: 12, 8;
  animation: flow-pathway 10s linear infinite;
}

@keyframes flow-pathway {
  0% {
    stroke-dashoffset: 160;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

.portal-welcome {
  max-width: 680px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  background: transparent;
  padding: 0.5rem 0 2rem 0; /* Reduced top padding to move text upwards */
  border: none;
  backdrop-filter: none;
  box-shadow: none;
}

.portal-welcome h2 {
  font-family: var(--font-serif);
  font-size: 4.8rem;
  font-weight: 300;
  letter-spacing: 8px;
  text-indent: 8px; /* Offsets letter-spacing to ensure absolute center alignment */
  line-height: 1.0; /* Reduced to pull subheading closer */
  color: #F4E8C1; /* Luminous, warm cream solid color - completely avoids all background-clip/text-fill browser clipping bugs */
  text-shadow: 0 4px 16px rgba(0, 0, 0, 0.9); /* Native high-contrast shadow - safe across all browsers and doesn't trigger compositor bugs */
  padding: 0.5rem 2rem 0 2rem; /* Reduced bottom padding */
  display: block;
  margin-bottom: 0rem; /* Removed bottom margin */
}

.portal-welcome p {
  font-family: var(--font-serif);
  font-size: 0.42rem; /* Extremely small, delicate font size for an elegant poetic quote line */
  font-style: italic;
  line-height: 1.0;
  color: var(--text-secondary);
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.8));
  max-width: none; /* No wrapping constraint */
  white-space: nowrap; /* Forces the text to stay strictly on one single line */
  letter-spacing: 2px; /* Subtle spacing for premium legibility */
  text-align: center;
  margin: 0.2rem auto 0 auto; /* Pulls the subtitle directly beneath FLOODRA h2, bypassing flexbox gaps */
}

.portal-welcome h3 {
  font-size: 0.95rem;
  color: var(--text-secondary);
  font-weight: 500;
  margin-top: -0.5rem; /* Positioned snugly beneath FLOODRA title since solace was removed */
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.8));
}

.theme-selector-group {
  margin-top: 1.8rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.8rem;
}

.theme-selector-group h3 {
  font-size: 0.9rem;
  color: var(--text-secondary);
  font-weight: 500;
  letter-spacing: 1px;
}

.theme-selector-grid {
  display: flex;
  gap: 1.2rem;
  justify-content: center;
  max-width: 500px;
}

.theme-btn {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  padding: 1rem 2rem;
  border-radius: 16px;
  cursor: pointer;
  font-size: 0.82rem;
  font-family: var(--font-sans);
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  transition: all var(--transition-medium);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.theme-btn .theme-icon {
  font-size: 1.1rem;
}

.theme-btn:hover {
  transform: translateY(-2px);
  border-color: var(--accent-color);
  color: var(--text-primary);
  box-shadow: 0 8px 25px var(--glow-color);
}

.theme-btn.active {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-primary);
  border-color: var(--accent-color);
  box-shadow: 0 0 20px var(--glow-bright);
}

/* Ensure buttons stand out properly in light mode */
body.theme-light .theme-btn.active {
  background: #ffffff;
  box-shadow: 0 0 20px rgba(181, 186, 157, 0.3);
}

.portal-action-btn {
  margin-top: 3.5rem; /* Moved upwards to harmonize with the tighter gatehouse spacing */
  background: #6366f1; /* Hardcoded brand purple background regardless of mood */
  border: 1px solid #6366f1; /* Solid purple border */
  padding: 0.75rem 1.8rem;
  border-radius: 25px;
  color: #ffffff; /* Crisp, high-contrast white text */
  font-family: var(--font-serif);
  font-size: 1rem;
  cursor: pointer;
  transition: all var(--transition-medium);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  letter-spacing: 2px;
  box-shadow: 0 4px 15px rgba(99, 102, 241, 0.4); /* Premium, soft purple glow shadow */
  animation: breathe 3s infinite ease-in-out;
}

.portal-action-btn:hover {
  background: #7579f5; /* Slightly lighter, vibrant purple highlight on hover */
  color: #ffffff; /* Keeps text crisp white */
  border-color: #7579f5;
  box-shadow: 0 0 25px rgba(99, 102, 241, 0.8); /* Beautiful glowing purple halo */
  transform: translateY(-2px); /* Elegant tactile lift gesture */
  animation-play-state: paused;
}

.portal-action-btn svg {
  width: 18px;
  height: 18px;
}

/* ==========================================
   VIEW: Writer's Salon (Sanctuary)
   ========================================== */
#view-journal {
  display: flex;
  flex-direction: column;
  gap: 3.5rem;
  height: 100%;
  overflow-y: auto;
  max-width: 1250px;
  margin: 0 auto;
  width: 100%;
}

.journal-desk {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  min-height: 900px;
  height: auto;
  flex-shrink: 0;
}

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

.desk-header h2 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 1.8rem;
}

.sheet-options {
  display: flex;
  gap: 0.75rem;
}

.sheet-btn {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  font-size: 0.8rem;
  padding: 0.4rem 0.8rem;
  border-radius: 12px;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.sheet-btn:hover, .sheet-btn.active {
  border-color: var(--accent-color);
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.05);
}

.paper-wrapper {
  flex-grow: 1;
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--card-shadow), 0 20px 50px rgba(0,0,0,0.5);
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.paper-sheet {
  flex-grow: 1;
  background: rgba(20, 18, 25, 0.65);
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  transition: all var(--transition-medium);
  position: relative;
}

/* Combined style: Starry Velvet Parchment */
.paper-sheet.style-starryvelvetparchment {
  background: radial-gradient(circle at center, #0f0a26 0%, #060410 70%, #010104 100%);
  color: #e2d9c2; /* Poetic warm parchment text color */
  border: 1px solid rgba(226, 217, 194, 0.08); /* Faint gold parchment border */
  box-shadow: inset 0 0 50px rgba(0, 0, 0, 0.65), var(--card-shadow);
}
.paper-sheet.style-starryvelvetparchment .letter-title,
.paper-sheet.style-starryvelvetparchment .letter-body {
  color: #e2d9c2;
}
.paper-sheet.style-starryvelvetparchment .letter-body::placeholder,
.paper-sheet.style-starryvelvetparchment .letter-title::placeholder {
  color: rgba(226, 217, 194, 0.38); /* Warm faded placeholder text */
}
.paper-sheet.style-starryvelvetparchment .letter-body {
  background-image: linear-gradient(rgba(226, 217, 194, 0.04) 1px, transparent 1px); /* Delicate parchment-gold ruled lines */
}

/* Dynamic contrast mapping for active paper skins */
.paper-sheet[class*="skin-"] .letter-title,
.paper-sheet[class*="skin-"] .letter-body {
  color: var(--journal-paper-color) !important;
}
.paper-sheet[class*="skin-"] .letter-title::placeholder,
.paper-sheet[class*="skin-"] .letter-body::placeholder {
  color: var(--journal-paper-color) !important;
  opacity: 0.45 !important;
}
.paper-sheet[class*="skin-"] .letter-title {
  border-bottom-color: var(--journal-paper-border) !important;
}
.paper-sheet.skin-parchment-sand .letter-body {
  background-image: linear-gradient(rgba(62, 47, 24, 0.07) 1px, transparent 1px) !important;
}
.paper-sheet.skin-starry-cosmic .letter-body {
  background-image: linear-gradient(rgba(226, 232, 240, 0.04) 1px, transparent 1px) !important;
}

.letter-title {
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  font-family: var(--font-serif);
  font-size: 1.5rem;
  color: var(--text-primary);
  outline: none;
  padding-bottom: 0.5rem;
  width: 100%;
}

.letter-title:focus {
  border-color: var(--accent-color);
}

.letter-body {
  background: transparent;
  border: none;
  resize: none;
  flex-grow: 1;
  font-family: var(--font-serif);
  font-size: 1.15rem;
  line-height: 2rem;
  color: var(--text-primary);
  outline: none;
  width: 100%;
  background-size: 100% 2rem;
  background-attachment: local;
  min-height: 520px; /* Increased from 360px */
}

@media (min-width: 1025px) {
  .letter-body {
    min-height: 650px; /* Increased from 480px */
  }
}

.font-serif { font-family: var(--font-serif); }
.font-sans { font-family: var(--font-sans); }
.font-hand { font-family: var(--font-hand); font-size: 1.6rem; line-height: 2.2rem; background-size: 100% 2.2rem; }

.letter-controls {
  padding: 1.25rem 2.5rem;
  background: rgba(0, 0, 0, 0.35);
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  flex-shrink: 0;
}

.privacy-toggle {
  display: flex;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  overflow: hidden;
  padding: 2px;
}

.privacy-btn {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: 0.75rem;
  padding: 0.4rem 0.9rem;
  border-radius: 18px;
  cursor: pointer;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  transition: all var(--transition-fast);
}

.privacy-btn.active {
  background: rgba(255, 255, 255, 0.06);
  color: var(--accent-color);
}

.privacy-btn svg {
  width: 12px;
  height: 12px;
  fill: currentColor;
}

.tag-selector-wrapper {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.tag-select {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  font-size: 0.75rem;
  padding: 0.4rem 0.8rem;
  border-radius: 12px;
  outline: none;
  cursor: pointer;
}

.tag-select:focus {
  border-color: var(--accent-color);
}

.release-group {
  display: flex;
  gap: 0.75rem;
}

.release-btn {
  padding: 0.6rem 1.2rem;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: all var(--transition-medium);
}

.release-btn.btn-discard {
  background: rgba(239, 68, 68, 0.08);
  border: 1px solid rgba(239, 68, 68, 0.2);
  color: #f87171;
}

.release-btn.btn-discard:hover {
  background: rgba(239, 68, 68, 0.16);
  border-color: rgba(239, 68, 68, 0.4);
  box-shadow: 0 0 10px rgba(239, 68, 68, 0.2);
}

.release-btn.btn-action {
  background: var(--accent-color);
  border: none;
  color: #0a0810;
}

.release-btn.btn-action:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 15px var(--glow-bright);
}

.release-btn.btn-save-vault {
  background: rgba(56, 189, 248, 0.08);
  border: 1px solid rgba(56, 189, 248, 0.3);
  color: #38bdf8;
}

.release-btn.btn-save-vault:hover {
  background: rgba(56, 189, 248, 0.16);
  border-color: rgba(56, 189, 248, 0.5);
  box-shadow: 0 0 10px rgba(56, 189, 248, 0.25);
  transform: translateY(-2px);
}

#release-options-menu {
  position: absolute;
  bottom: 5.5rem;
  right: 2.5rem;
  background: rgba(10, 8, 16, 0.95);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  width: 220px;
  box-shadow: var(--card-shadow);
  z-index: 50;
  transform: translateY(10px);
  opacity: 0;
  pointer-events: none;
  transition: all var(--transition-medium);
}

#release-options-menu.active {
  transform: translateY(0);
  opacity: 1;
  pointer-events: all;
}

.menu-option {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  padding: 0.6rem 1rem;
  border-radius: 8px;
  font-size: 0.85rem;
  text-align: left;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  transition: all var(--transition-fast);
}

.menu-option:hover {
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-primary);
}

.menu-option svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}

.menu-option.opt-save { color: #38bdf8; }
.menu-option.opt-burn { color: #f87171; }
.menu-option.opt-share { color: #c084fc; }
.menu-option.opt-circle { color: #10b981; width: 100%; }

.menu-option-with-submenu {
  position: relative;
  width: 100%;
}

.submenu-list {
  position: absolute;
  left: -210px;
  bottom: 0;
  background: rgba(10, 8, 16, 0.98);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  width: 200px;
  box-shadow: var(--card-shadow);
  opacity: 0;
  pointer-events: none;
  transform: translateX(10px);
  transition: all var(--transition-medium);
  z-index: 60;
}

.menu-option-with-submenu:hover .submenu-list,
.menu-option-with-submenu.active .submenu-list {
  opacity: 1;
  pointer-events: all;
  transform: translateX(0);
}

.submenu-option {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  padding: 0.5rem 0.75rem;
  border-radius: 6px;
  font-size: 0.8rem;
  text-align: left;
  cursor: pointer;
  width: 100%;
  transition: all var(--transition-fast);
}

.submenu-option:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--accent-color);
}

.submenu-arrow {
  margin-left: auto;
  font-size: 0.6rem;
  opacity: 0.6;
}

.canvas-animation-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
  pointer-events: none;
  border-radius: 16px;
}

/* Vault list */
.vault-panel {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  height: 700px;
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 2rem;
  backdrop-filter: blur(12px);
  box-shadow: var(--card-shadow);
}

.vault-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--glass-border);
  padding-bottom: 1rem;
}

.vault-header h3 {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  font-weight: 400;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.vault-header h3 svg {
  width: 18px;
  height: 18px;
  fill: var(--accent-color);
}

.vault-stats {
  font-size: 0.75rem;
  color: var(--text-secondary);
  background: rgba(255, 255, 255, 0.03);
  padding: 0.3rem 0.6rem;
  border-radius: 10px;
  border: 1px solid var(--glass-border);
}

.vault-list {
  flex-grow: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding-right: 0.25rem;
}

.vault-empty-state {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  height: 100%;
  color: var(--text-muted);
  text-align: center;
  padding: 2rem;
}

.vault-empty-state svg {
  width: 48px;
  height: 48px;
  stroke-width: 1;
  opacity: 0.4;
}

.vault-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 1.25rem;
  cursor: pointer;
  transition: all var(--transition-medium);
  position: relative;
}

.vault-card:hover {
  border-color: rgba(255, 255, 255, 0.15);
  background: rgba(255, 255, 255, 0.04);
  transform: translateY(-2px);
}

.vault-card.active {
  border-color: var(--accent-color);
  background: rgba(167, 139, 250, 0.02);
}

.vcard-header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.5rem;
  align-items: center;
}

.vcard-title {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 500;
  color: #ffffff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 70%;
}

.vcard-date {
  font-size: 0.75rem;
  color: var(--text-muted);
}

.vcard-snippet {
  font-size: 0.85rem;
  color: var(--text-secondary);
  line-height: 1.4;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.vcard-actions {
  display: flex;
  gap: 0.5rem;
  position: absolute;
  bottom: 1.25rem;
  right: 1.25rem;
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.vault-card:hover .vcard-actions {
  opacity: 1;
}

.vcard-btn {
  background: rgba(0, 0, 0, 0.4);
  border: 1px solid var(--glass-border);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.vcard-btn:hover {
  color: #ffffff;
}

.vcard-btn.delete:hover {
  background: #ef4444;
  border-color: #ef4444;
  color: #ffffff;
}

.vcard-btn svg {
  width: 12px;
  height: 12px;
  fill: currentColor;
}

/* ==========================================
   VIEW: Meadow Constellation (Sea)
   ========================================== */
#view-sea {
  padding: 0.5rem 0.75rem 4.5rem 0.75rem;
  max-width: 1250px;
  margin: 0 auto;
  width: 100%;
  display: flex;
  flex-direction: column;
  height: 100%;
  gap: 3.5rem;
  box-sizing: border-box;
}

.sea-layout-wrapper {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  min-height: 0;
  gap: 1.5rem;
}

.sea-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
}

.sea-info h2 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 1.8rem;
  margin-bottom: 0.25rem;
}

.sea-info p {
  font-size: 0.9rem;
  color: var(--text-secondary);
}

.sea-filters {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.filter-btn {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  padding: 0.4rem 1rem;
  border-radius: 15px;
  font-size: 0.8rem;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.filter-btn:hover, .filter-btn.active {
  border-color: var(--accent-color);
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.03);
}

.constellation-universe {
  flex-grow: 1;
  min-height: 500px; /* Prevent being squeezed to nothing by the footer */
  background: radial-gradient(circle, rgba(16,13,31,0.2) 0%, rgba(5,4,9,0.7) 100%);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  position: relative;
  overflow: hidden;
  cursor: grab;
  box-shadow: var(--card-shadow);
}

.constellation-universe:active {
  cursor: grabbing;
}

.sea-star {
  position: absolute;
  width: 14px;
  height: 14px;
  background: radial-gradient(circle, #ffffff 10%, transparent 80%);
  border-radius: 50%;
  cursor: pointer;
  transition: transform 0.3s;
  z-index: 5;
}

.sea-star::before {
  content: '';
  position: absolute;
  top: -6px;
  left: -6px;
  right: -6px;
  bottom: -6px;
  border-radius: 50%;
  background: var(--accent-color);
  opacity: 0.2;
  filter: blur(2px);
  animation: pulse-ring 4s infinite ease-in-out;
}

.sea-star:hover {
  transform: scale(1.6);
  z-index: 10;
}

.sea-star.star-grief { --accent-color: #6366f1; }
.sea-star.star-anger { --accent-color: #ef4444; }
.sea-star.star-nostalgia { --accent-color: #f59e0b; }
.sea-star.star-peace { --accent-color: #10b981; }
.sea-star.star-hope { --accent-color: #06b6d4; }
.sea-star.star-numbness { --accent-color: #94a3b8; }

.star-tooltip {
  position: absolute;
  background: rgba(10, 8, 16, 0.95);
  border: 1px solid var(--glass-border);
  padding: 0.8rem 1.2rem;
  border-radius: 12px;
  backdrop-filter: blur(16px);
  box-shadow: var(--card-shadow);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.25s cubic-bezier(0.25, 1, 0.5, 1);
  z-index: 100;
  width: 200px;
  max-width: calc(100vw - 30px); /* Ensure it never goes wider than mobile screens minus margins */
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.star-tooltip.active {
  opacity: 1;
}

.tooltip-title {
  font-family: var(--font-serif);
  font-size: 0.92rem;
  font-weight: 500;
  color: #ffffff;
  margin-bottom: 0.35rem;
  line-height: 1.3;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.tooltip-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.7rem;
  color: var(--accent-color);
  gap: 0.5rem;
}

/* Shared Echoes Section & Cards (Feed Constellation) */
.sea-echoes-section {
  margin-top: 3.5rem;
  margin-bottom: 2rem;
  padding: 0 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.sea-echoes-section h3 {
  font-family: var(--font-serif);
  font-size: 1.75rem;
  font-weight: 400;
  color: var(--text-primary);
  margin: 0;
  letter-spacing: -0.01em;
}

.sea-echoes-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.5rem;
  border-bottom: 1px solid var(--glass-border);
  padding-bottom: 1rem;
  margin-bottom: 0.5rem;
}

.sea-search-box {
  width: 280px;
  flex-shrink: 0;
}

.sea-search-inner {
  position: relative;
  width: 100%;
}

.sea-search-inner .search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  color: var(--text-muted);
  pointer-events: none;
  stroke: currentColor;
}

.sea-search-inner input {
  width: 100%;
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 0.6rem 1rem 0.6rem 2.2rem;
  font-size: 0.85rem;
  font-family: var(--font-sans);
  color: var(--text-primary);
  outline: none;
  transition: all var(--transition-fast);
  box-sizing: border-box;
}

.sea-search-inner input:focus {
  border-color: var(--accent-color);
  background: rgba(0, 0, 0, 0.35);
  box-shadow: 0 0 10px rgba(99, 102, 241, 0.25);
}

body.theme-light .sea-search-inner input {
  background: rgba(255, 255, 255, 0.75);
  border-color: rgba(0, 0, 0, 0.12);
  color: var(--text-primary);
}

body.theme-light .sea-search-inner input:focus {
  background: #ffffff;
  border-color: var(--accent-color);
}

.sea-echoes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1.75rem; /* Space between card items */
  width: 100%;
}

.sea-echo-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  cursor: pointer;
  transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.15);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  position: relative;
  overflow: hidden;
}

.sea-echo-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 4px;
  background: var(--mood-color, var(--accent-color));
  border-radius: 4px 0 0 4px;
  opacity: 0.8;
  transition: width var(--transition-fast);
}

.sea-echo-card:hover {
  transform: translateY(-4px);
  border-color: var(--mood-color, var(--accent-color));
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25), 0 0 15px var(--glow-color, var(--mood-color));
  background: rgba(255, 255, 255, 0.04);
}

.sea-echo-card:hover::before {
  width: 6px;
}

/* Mood colors mapping to coordinates */
.sea-echo-card.grief {
  --mood-color: #6366f1;
  --glow-color: rgba(99, 102, 241, 0.25);
}
.sea-echo-card.anger {
  --mood-color: #ef4444;
  --glow-color: rgba(239, 68, 68, 0.25);
}
.sea-echo-card.nostalgia {
  --mood-color: #f59e0b;
  --glow-color: rgba(245, 158, 11, 0.2);
}
.sea-echo-card.peace {
  --mood-color: #10b981;
  --glow-color: rgba(16, 185, 129, 0.2);
}
.sea-echo-card.hope {
  --mood-color: #06b6d4;
  --glow-color: rgba(6, 182, 212, 0.25);
}
.sea-echo-card.numbness {
  --mood-color: #94a3b8;
  --glow-color: rgba(148, 163, 184, 0.2);
}

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

.sea-echo-tag {
  color: var(--mood-color, var(--accent-color));
  font-weight: 500;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  background: rgba(255, 255, 255, 0.03);
  padding: 0.2rem 0.6rem;
  border-radius: 20px;
  border: 1px solid var(--glass-border);
}

.sea-echo-date {
  color: var(--text-muted);
  font-size: 0.75rem;
  font-family: var(--font-sans);
}

.sea-echo-title {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--text-primary);
  margin: 0;
  line-height: 1.35;
}

.sea-echo-body {
  color: var(--text-secondary);
  font-size: 0.95rem;
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  margin: 0;
  flex-grow: 1;
}

.sea-echo-footer {
  display: flex;
  gap: 1.25rem;
  border-top: 1px solid var(--glass-border);
  padding-top: 0.85rem;
  margin-top: 0.5rem;
  color: var(--text-muted);
}

.sea-echo-action {
  display: flex;
  align-items: center;
  font-size: 0.8rem;
  color: var(--text-secondary);
  font-family: var(--font-sans);
}

.sea-echo-action svg {
  color: var(--text-muted);
  transition: color var(--transition-fast);
}

.sea-echo-card:hover .sea-echo-action svg {
  color: var(--mood-color, var(--accent-color));
}

/* Light Mode Overrides */
body.theme-light .sea-echo-card {
  box-shadow: 0 4px 20px rgba(31, 36, 26, 0.05);
}

body.theme-light .sea-echo-card:hover {
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 12px 30px rgba(31, 36, 26, 0.12);
}

body.theme-light .sea-echo-tag {
  background: rgba(31, 36, 26, 0.04);
}

.hearth-main-column {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  min-width: 0;
}

/* Hearth WHO Research Section */
.hearth-research-section {
  border-top: 1px solid var(--glass-border);
  padding-top: 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.research-section-header {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}

.research-icon {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: rgba(99, 102, 241, 0.06);
  border: 1px solid var(--glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-color);
  flex-shrink: 0;
  box-shadow: 0 0 15px rgba(99, 102, 241, 0.08);
}

.research-icon svg {
  width: 24px;
  height: 24px;
}

.research-title-block h3 {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 400;
  color: var(--text-primary);
  margin: 0 0 0.25rem 0;
  letter-spacing: -0.01em;
}

.research-subtitle {
  font-size: 0.9rem;
  color: var(--text-secondary);
  margin: 0;
}

.research-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 2rem;
  width: 100%;
}

.research-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.15);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.research-card:hover {
  transform: translateY(-4px);
  border-color: var(--accent-color);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25), 0 0 15px var(--glow-color);
  background: rgba(255, 255, 255, 0.04);
}

.research-card-tag {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--accent-color);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-family: var(--font-sans);
}

.research-card-title {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  font-weight: 400;
  color: var(--text-primary);
  margin: 0;
  line-height: 1.35;
}

.research-card-body {
  color: var(--text-secondary);
  font-size: 0.92rem;
  line-height: 1.6;
  margin: 0;
  flex-grow: 1;
}

.research-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--glass-border);
  padding-top: 0.85rem;
  margin-top: 0.5rem;
  font-size: 0.78rem;
  color: var(--text-muted);
}

.research-metric {
  font-weight: 500;
  color: var(--text-secondary);
}

.research-focus {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  padding: 0.25rem 0.6rem;
  border-radius: 12px;
  font-size: 0.75rem;
  color: var(--text-secondary);
}

/* Light Mode Overrides for research section */
body.theme-light .research-icon {
  background: rgba(31, 36, 26, 0.03);
  border-color: rgba(31, 36, 26, 0.1);
  box-shadow: none;
}

body.theme-light .research-card {
  box-shadow: 0 4px 20px rgba(31, 36, 26, 0.05);
}

body.theme-light .research-card:hover {
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 12px 30px rgba(31, 36, 26, 0.12);
}

body.theme-light .research-focus {
  background: rgba(31, 36, 26, 0.04);
}

/* Modal letter reader card */
.letter-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(5, 4, 9, 0.85);
  backdrop-filter: blur(16px);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity var(--transition-medium), visibility var(--transition-medium);
}

.letter-modal-overlay.active {
  opacity: 1;
  pointer-events: all;
  visibility: visible;
}

.letter-modal-card {
  width: 90%;
  max-width: 600px;
  background: radial-gradient(circle at top, #191624 0%, #0d0a15 100%);
  border: 1px solid var(--glass-border);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 30px 100px rgba(0, 0, 0, 0.8);
  display: flex;
  flex-direction: column;
  transform: scale(0.9) translateY(20px);
  transition: all var(--transition-medium);
}

.letter-modal-overlay.active .letter-modal-card {
  transform: scale(1) translateY(0);
}

.modal-header {
  padding: 1.5rem 2rem;
  border-bottom: 1px solid var(--glass-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.modal-header h3 {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  font-weight: 400;
}

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

.modal-close-btn:hover {
  background: rgba(255, 255, 255, 0.05);
  color: #ffffff;
}

.modal-close-btn svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}

.modal-body {
  padding: 2.5rem;
  overflow-y: auto;
  max-height: 400px;
  font-family: var(--font-serif);
  font-size: 1.15rem;
  line-height: 2rem;
  color: var(--text-primary);
  border-bottom: 1px solid var(--glass-border);
  background-image: linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px);
  background-size: 100% 2rem;
}

.modal-footer {
  padding: 1.5rem 2rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(0, 0, 0, 0.2);
}

.support-actions-wrapper {
  display: flex;
  gap: 1rem;
}

.support-btn {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  padding: 0.6rem 1.2rem;
  border-radius: 20px;
  font-size: 0.85rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: all var(--transition-medium);
}

.support-btn:hover {
  border-color: var(--accent-color);
  color: var(--text-primary);
  transform: translateY(-2px);
}

.support-btn.active {
  background: rgba(167, 139, 250, 0.1);
  border-color: var(--accent-color);
  color: var(--accent-color);
}

.support-btn svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

.modal-letter-tag {
  font-size: 0.75rem;
  padding: 0.3rem 0.8rem;
  border-radius: 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
}


.canvas-controls {
  position: absolute;
  top: 2.5rem;
  left: 2.5rem;
  z-index: 10;
  background: rgba(10, 8, 16, 0.8);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 0.75rem;
  display: flex;
  gap: 0.5rem;
  backdrop-filter: blur(12px);
  box-shadow: var(--card-shadow);
}

.canvas-tool-btn {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  width: 40px;
  height: 40px;
  border-radius: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
}

.canvas-tool-btn:hover {
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.03);
}

.canvas-tool-btn.active {
  background: var(--accent-color);
  color: #0d0a15;
  font-weight: 600;
}

.canvas-tool-btn svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.canvas-divider {
  width: 1px;
  background: var(--glass-border);
  margin: 0.25rem 0;
}

.brush-settings-drawer {
  position: absolute;
  top: 6.5rem;
  left: 2.5rem;
  z-index: 10;
  background: rgba(10, 8, 16, 0.9);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1rem 1.25rem;
  width: 180px;
  backdrop-filter: blur(12px);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-5px);
  transition: all var(--transition-medium);
}

.brush-settings-drawer.active {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0);
}

.brush-settings-drawer label {
  font-size: 0.75rem;
  color: var(--text-secondary);
  display: flex;
  justify-content: space-between;
}

.reflection-drawing-board {
  flex-grow: 1;
  background: radial-gradient(circle, #0c0914 0%, #030206 100%);
  border: 1px solid var(--glass-border);
  border-radius: 24px;
  overflow: hidden;
  position: relative;
  box-shadow: inset 0 0 40px rgba(0,0,0,0.8), var(--card-shadow);
}

#paint-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: crosshair;
  touch-action: none; /* Block default touch scrolling to allow finger/pen/stylus drawing */
}

#paint-canvas:focus {
  outline: none;
}

.reflection-drawing-board:focus-within {
  border-color: var(--accent-color);
  box-shadow: inset 0 0 40px rgba(0,0,0,0.8), 0 0 25px var(--glow-color), var(--card-shadow);
}

/* Dynamic Virtual Keyboard Cursor */
.keyboard-brush-cursor {
  position: absolute;
  border: 2px solid var(--accent-color);
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%, -50%);
  z-index: 10;
  box-sizing: border-box;
  transition: width 0.1s cubic-bezier(0.25, 1, 0.5, 1),
              height 0.1s cubic-bezier(0.25, 1, 0.5, 1),
              border-color 0.2s ease,
              box-shadow 0.2s ease;
}

.keyboard-brush-cursor::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 6px;
  height: 6px;
  background: var(--text-primary);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 4px rgba(255,255,255,0.8);
}

.keyboard-brush-cursor.drawing {
  background: rgba(255, 255, 255, 0.08);
  border-style: dashed;
  animation: cursor-drawing-pulse 1s infinite alternate cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes cursor-drawing-pulse {
  0% { transform: translate(-50%, -50%) scale(0.95); opacity: 0.8; }
  100% { transform: translate(-50%, -50%) scale(1.15); opacity: 1; }
}

.canvas-intro-instruction {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  pointer-events: none;
  max-width: 450px;
  color: var(--text-muted);
  font-family: var(--font-serif);
  transition: opacity 0.5s;
  /* Prevent browser text selection from blocking drag start */
  user-select: none;
  -webkit-user-select: none;
}

.canvas-intro-instruction * {
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
}

.canvas-intro-instruction h3 {
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--text-secondary);
  margin-bottom: 0.5rem;
}

.canvas-intro-instruction p {
  font-size: 0.9rem;
  line-height: 1.5;
}

/* ==========================================
   VIEW: Parlor Fireplace (Hearth)
   ========================================== */
#view-hearth {
  max-width: 1300px;
  margin: 0 auto;
  width: 100%;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow-y: auto;
  gap: 2rem;
}

.hearth-header-top {
  margin-bottom: 0.5rem;
  flex-shrink: 0;
}

.hearth-title {
  font-family: var(--font-serif);
  font-weight: 300;
  font-size: 2.2rem;
  letter-spacing: -0.5px;
  margin-bottom: 0.5rem;
  background: linear-gradient(135deg, #ffffff 0%, #a78bfa 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.hearth-subtitle {
  font-size: 0.95rem;
  color: var(--text-secondary);
  max-width: 800px;
  line-height: 1.5;
}

.circle-list-horizontal {
  position: sticky;
  top: -2rem; /* Align with padding of view-section */
  z-index: 10;
  background: var(--bg-end);
  display: flex;
  flex-direction: row;
  gap: 1rem;
  overflow-x: auto;
  padding: 12px 6px;
  margin-bottom: 0.5rem;
  scrollbar-width: thin;
  transition: background var(--transition-slow);
  flex-shrink: 0;
}

/* Custom modern scrollbar for the horizontal list */
.circle-list-horizontal::-webkit-scrollbar {
  height: 6px;
}
.circle-list-horizontal::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.05);
  border-radius: 10px;
}
.circle-list-horizontal::-webkit-scrollbar-thumb {
  background: var(--glass-border);
  border-radius: 10px;
}
.circle-list-horizontal::-webkit-scrollbar-thumb:hover {
  background: var(--accent-color);
}

.circle-btn {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 0.75rem 1.25rem;
  cursor: pointer;
  text-align: left;
  transition: all var(--transition-medium);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 220px;
  flex-shrink: 0;
}

.circle-btn:hover {
  border-color: rgba(255, 255, 255, 0.15);
  background: rgba(255, 255, 255, 0.03);
  transform: translateY(-3px);
}

.circle-btn.active {
  border-color: var(--accent-color);
  background: rgba(167, 139, 250, 0.03);
  box-shadow: inset 0 0 10px rgba(167, 139, 250, 0.05);
}

.circle-name {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--text-primary);
  white-space: nowrap;
}

.circle-btn.active .circle-name {
  color: var(--accent-color);
}

.circle-pop {
  font-size: 0.75rem;
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  gap: 0.4rem;
  white-space: nowrap;
}

.hearth-chamber {
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid var(--glass-border);
  border-radius: 24px;
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  height: auto;
  min-height: 550px;
  backdrop-filter: blur(12px);
  box-shadow: var(--card-shadow);
  flex-shrink: 0;
}

.chamber-banner {
  border-bottom: 1px solid var(--glass-border);
  padding-bottom: 1.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.chamber-title-block h3 {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 400;
  margin-bottom: 0.25rem;
}

.chamber-title-block p {
  font-size: 0.9rem;
  color: var(--text-secondary);
}

.prompt-card {
  background: linear-gradient(135deg, rgba(255,255,255,0.03) 0%, rgba(255,255,255,0.01) 100%);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.5rem;
  display: flex;
  gap: 1.25rem;
  align-items: center;
}

.prompt-icon {
  width: 44px;
  height: 44px;
  background: rgba(167, 139, 250, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-color);
  flex-shrink: 0;
}

.prompt-icon svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.prompt-details {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.prompt-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--accent-color);
  font-weight: 600;
}

.prompt-text {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.05rem;
  line-height: 1.4;
  color: #ffffff;
}

.random-inspiration-container {
  display: flex;
  flex-direction: row;
  gap: 1.25rem;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
  flex-shrink: 0;
}

.random-inspiration-card {
  flex: 1;
  background: rgba(255, 255, 255, 0.015);
  border: 1px dashed var(--glass-border);
  border-radius: 14px;
  padding: 0.9rem 1.25rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 0.5rem;
  transition: all var(--transition-fast);
}

.random-inspiration-card:hover {
  background: rgba(255, 255, 255, 0.025);
  border-color: rgba(255, 255, 255, 0.12);
}

.random-inspiration-text {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.85rem;
  line-height: 1.45;
  color: var(--text-secondary);
}

.random-inspiration-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.7rem;
  color: var(--text-muted);
}

.random-inspiration-tag {
  color: var(--accent-color);
  font-weight: 600;
  text-transform: uppercase;
}

.notes-pinboard {
  flex-grow: 1;
  overflow-y: visible;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 1.6rem;
  padding-right: 0.25rem;
}

.recent-pins-section {
  margin-top: 4.5rem;
  margin-bottom: 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  flex-shrink: 0;
  border-top: 1px solid var(--glass-border);
  padding-top: 3rem;
}

.recent-pins-header h3 {
  font-family: var(--font-serif);
  font-weight: 300;
  font-size: 2rem;
  letter-spacing: -0.5px;
  margin-bottom: 0.5rem;
  background: linear-gradient(135deg, #ffffff 0%, #a78bfa 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.recent-pins-header p {
  font-size: 0.95rem;
  color: var(--text-secondary);
  max-width: 800px;
  line-height: 1.5;
}

.recent-pins-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 1.6rem;
  padding: 8px 4px;
}

.sticky-note {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1rem;
  transition: transform var(--transition-medium), border-color var(--transition-medium), background var(--transition-medium), box-shadow var(--transition-medium);
  box-shadow: var(--card-shadow);
  position: relative;
  transform: rotate(var(--note-tilt, 0deg));
  transform-origin: center;
}

.sticky-note:hover {
  transform: translateY(-8px) rotate(calc(var(--note-tilt, 0deg) * 0.4)) scale(1.02) !important;
  border-color: rgba(255, 255, 255, 0.16) !important;
  background: rgba(255, 255, 255, 0.04) !important;
  z-index: 10 !important;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.45), var(--glow-bright) !important;
}

.sticky-note-text {
  font-family: var(--font-serif);
  font-size: 1rem;
  line-height: 1.5;
  color: var(--text-primary);
}

.sticky-note-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.75rem;
  color: var(--text-secondary);
  border-top: 1px dashed rgba(255, 255, 255, 0.08);
  padding-top: 0.75rem;
}

.sticky-note-date {
  color: var(--text-muted);
}

.note-creator-box {
  display: flex;
  gap: 0.75rem;
  border-top: 1px solid var(--glass-border);
  padding-top: 1.5rem;
}

.note-input {
  flex-grow: 1;
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1rem 1.25rem;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.9rem;
  outline: none;
  resize: none;
  height: 52px;
  transition: all var(--transition-fast);
}

.note-input:focus {
  border-color: var(--accent-color);
  background: rgba(0, 0, 0, 0.3);
  box-shadow: 0 0 10px var(--glow-color);
}

.note-submit-btn {
  background: var(--accent-color);
  border: none;
  color: #0d0a15;
  padding: 0 1.5rem;
  border-radius: 16px;
  cursor: pointer;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  transition: all var(--transition-fast);
}

.note-submit-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 15px var(--glow-bright);
}

.note-submit-btn svg {
  width: 14px;
  height: 14px;
}

/* ==========================================
   Keyframe Animations
   ========================================== */
@keyframes pulse-glow {
  0% {
    box-shadow: 0 0 12px var(--glow-color);
    filter: drop-shadow(0 0 6px var(--accent-color));
  }
  100% {
    box-shadow: 0 0 24px var(--glow-bright);
    filter: drop-shadow(0 0 12px var(--accent-color));
  }
}

@keyframes pulse-ring {
  0% {
    transform: scale(0.9);
    opacity: 0.1;
  }
  50% {
    opacity: 0.35;
  }
  100% {
    transform: scale(1.4);
    opacity: 0;
  }
}

@keyframes breathe {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 12px var(--glow-color);
  }
  50% {
    transform: scale(1.02);
    box-shadow: 0 0 20px var(--glow-bright);
  }
}

/* Lightning flash double trigger stroke */
@keyframes lightning-strike {
  0%, 100% {
    opacity: 0;
  }
  10%, 25% {
    opacity: 0.75;
  }
  15% {
    opacity: 0.15;
  }
  30% {
    opacity: 0;
  }
}

/* ==========================================
   Responsive Adaptations
   ========================================== */
@media (max-width: 1024px) {
  #view-journal {
    overflow-y: auto;
  }
  .journal-desk {
    height: auto;
    min-height: 800px;
  }

  .reflection-drawing-board {
    height: 450px;
  }
  .vault-panel {
    height: 400px;
  }
  #view-hearth {
    height: 100% !important;
    overflow-y: auto !important;
  }
  .hearth-layout-wrapper {
    grid-template-columns: 1fr;
  }
  .hearth-chamber {
    height: auto !important;
    min-height: 500px;
    flex-shrink: 0 !important;
  }
  .hearth-sidebar {
    position: static;
    align-self: stretch;
  }
  /* ── Tablet Header (768-1024px) ── */
  header {
    padding: 0.8rem 1.5rem !important;
    background: rgba(10, 8, 16, 0.75);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    flex-wrap: wrap !important;
    row-gap: 0.6rem !important;
  }
  .brand h1 {
    font-size: 1.3rem;
    letter-spacing: 2.5px;
  }
  .brand-icon {
    width: 26px;
    height: 26px;
  }
  .controls-hud {
    gap: 0.6rem;
    margin-top: -2px !important; /* Move HUD slightly up in header */
  }
  .hud-btn {
    width: 32px;
    height: 32px;
  }
  .hud-btn svg {
    width: 13px;
    height: 13px;
  }
  .hud-signin-btn {
    padding: 0.3rem 0.7rem;
    font-size: 0.68rem;
  }
  .audio-panel {
    right: 1.5rem;
  }
  .view-section {
    padding: 1.5rem 1.5rem 7.5rem 1.5rem;
  }

  /* Wrap navigation bar inside header on tablet & mobile */
  nav {
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
    order: 3 !important;
    margin-top: 6px !important; /* Bring navigation tabs down a bit */
    position: static !important;
    transform: none !important;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-medium);
  }

  nav.visible {
    opacity: 1 !important;
    pointer-events: all !important;
    transform: none !important;
  }

  .nav-dock {
    padding: 0.3rem !important;
    border-radius: 20px !important;
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
    width: auto !important;
    gap: 0.4rem !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
  }

  .nav-pill-indicator {
    border-radius: 16px !important;
  }

  .nav-item {
    padding: 0.5rem 0.8rem !important;
    border-radius: 16px !important;
    font-size: 0.72rem !important;
    gap: 0.4rem !important;
    display: flex !important;
    align-items: center !important;
  }

  .nav-item span {
    display: inline !important;
  }

  .nav-item svg {
    width: 14px !important;
    height: 14px !important;
    margin: 0 !important;
  }

  .nav-scroll-btn {
    width: 28px !important;
    height: 28px !important;
  }

  .nav-scroll-btn svg {
    width: 12px !important;
    height: 12px !important;
  }
}

@media (max-width: 768px) {
  /* ── Mobile Header: Glassmorphism floating bar ── */
  header {
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 0 !important;
    padding: 0.6rem 1rem !important;
    position: sticky !important;
    top: 0;
    width: 100%;
    background: var(--header-bg) !important;
    backdrop-filter: blur(24px) saturate(140%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(140%) !important;
    border-bottom: 1px solid var(--header-border) !important;
    box-shadow: var(--header-shadow) !important;
    z-index: 200 !important;
    min-height: 56px;
  }

  /* Brand: icon + name visible together on mobile */
  .brand {
    gap: 0.5rem;
    flex-shrink: 0;
  }

  .brand-icon {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
  }

  .brand h1 {
    font-size: 1.05rem !important;
    letter-spacing: 2.5px !important;
    display: block !important;  /* Show brand on mobile */
    background: linear-gradient(to right, #ffffff, var(--text-secondary)) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
  }

  /* Sidebar toggle button (hamburger) */
  .sidebar-toggle-btn {
    width: 36px;
    height: 36px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border) !important;
    margin-right: 0.5rem;
    flex-shrink: 0;
    padding: 0;
    color: var(--text-primary) !important;
  }

  .sidebar-toggle-btn svg {
    width: 18px;
    height: 18px;
  }

  /* HUD button cluster: compact, pill-grouped */
  .controls-hud {
    display: flex !important;
    align-items: center !important;
    gap: 0.4rem !important;
    flex-shrink: 0;
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 24px;
    padding: 0.3rem 0.5rem;
    margin-top: -3px !important; /* Move HUD slightly up on mobile */
  }

  /* Make navigation items icon-only on mobile viewports for compact spacing */
  .nav-item {
    font-size: 0 !important;
    gap: 0 !important;
    padding: 0.6rem 0.8rem !important;
    border-radius: 20px !important;
  }

  .nav-item span {
    display: none !important;
  }

  .nav-item svg {
    width: 18px !important;
    height: 18px !important;
  }

  .nav-scroll-btn {
    width: 32px !important;
    height: 32px !important;
  }

  .nav-scroll-btn svg {
    width: 14px !important;
    height: 14px !important;
  }

  /* Compact circular HUD buttons */
  .hud-btn {
    width: 32px !important;
    height: 32px !important;
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 50% !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
    flex-shrink: 0;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--text-primary) !important;
    transition: all var(--transition-fast) !important;
  }

  .hud-btn:hover, .hud-btn:active {
    background: var(--glass-highlight) !important;
    border-color: var(--accent-color) !important;
    transform: scale(1.08) !important;
    box-shadow: 0 0 10px var(--glow-color) !important;
  }

  .hud-btn svg {
    width: 14px !important;
    height: 14px !important;
  }

  /* Sign In button: pill icon-only on mobile */
  .hud-signin-btn {
    padding: 0 !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    justify-content: center !important;
    gap: 0 !important;
    border: 1px solid var(--glass-border) !important;
    background: var(--glass-bg) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
    flex-shrink: 0;
    display: flex !important;
    align-items: center !important;
    color: var(--text-primary) !important;
    transition: all var(--transition-fast) !important;
    position: relative !important;
  }

  .hud-signin-btn:hover, .hud-signin-btn:active {
    background: var(--glass-highlight) !important;
    border-color: var(--accent-color) !important;
    box-shadow: 0 0 10px var(--glow-color) !important;
    transform: scale(1.08) !important;
  }

  .hud-signin-btn .signin-label {
    display: none !important;
  }

  .hud-signin-btn svg {
    width: 14px !important;
    height: 14px !important;
  }

  .hud-signin-btn.logged-in {
    border-color: #10b981 !important;
    background: rgba(16, 185, 129, 0.1) !important;
    box-shadow: 0 0 8px rgba(16, 185, 129, 0.25) !important;
  }

  .hud-signin-btn.logged-in:hover {
    border-color: #34d399 !important;
    box-shadow: 0 0 12px rgba(16, 185, 129, 0.4) !important;
  }

  .hud-signin-btn .profile-dot {
    position: absolute !important;
    bottom: -1px !important;
    right: -1px !important;
    z-index: 5 !important;
  }



  .view-indicator {
    display: none;
  }

  .mood-selector-grid {
    gap: 0.6rem;
  }

  .mood-btn {
    padding: 0.6rem 1.2rem;
    font-size: 0.68rem;
  }

  /* Responsive Writer's Salon Sheet and Templates */
  .paper-sheet {
    padding: 1.5rem !important;
    gap: 1.2rem !important;
  }
  .letter-controls {
    padding: 1rem 1.5rem !important;
  }
  .obituary-form,
  .museum-form {
    padding: 1rem !important;
    gap: 1rem !important;
  }
}

/* ==========================================
   FLOODRA ARTISTIC & TACTILE ENHANCEMENTS
   ========================================== */

/* 1. Procedural SVG Paper Grain Overlay
   Gives major card elements an authentic, heavy, archival paper feel. */
.paper-sheet::before,
.vault-card::before,
.sticky-note::before,
.letter-modal-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events: none;
  mix-blend-mode: overlay;
  border-radius: inherit;
  z-index: 1;
}

/* Ensure child elements are above the paper grain overlay */
.paper-sheet > *,
.vault-card > *,
.sticky-note > *,
.letter-modal-card > * {
  position: relative;
  z-index: 2;
}

/* 2. Format Selector Layout (Letter, Poem, Art Concept) */
.format-selector {
  display: flex;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  padding: 0.3rem;
  border-radius: 14px;
  backdrop-filter: blur(8px);
  gap: 0.25rem;
}

.format-btn {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: 500;
  padding: 0.4rem 0.9rem;
  border-radius: 9px;
  cursor: pointer;
  transition: all var(--transition-fast);
}

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

.format-btn.active {
  background: var(--accent-color);
  color: #0d0a15;
  font-weight: 600;
  box-shadow: 0 4px 10px var(--glow-color);
}

/* 3. Soul Weight Tracker Capsule */
.soul-weight-tracker {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(255, 255, 255, 0.01);
  border: 1px dashed var(--glass-border);
  padding: 0.4rem 0.9rem;
  border-radius: 12px;
  font-size: 0.8rem;
  font-family: var(--font-sans);
  color: var(--text-secondary);
  transition: border-color var(--transition-medium), color var(--transition-medium);
}

.soul-weight-tracker:hover {
  border-color: var(--accent-color);
  color: var(--text-primary);
}

.tracker-label {
  letter-spacing: 0.5px;
  opacity: 0.75;
}

.tracker-value {
  font-family: var(--font-serif);
  font-weight: 600;
  color: var(--accent-color);
  text-shadow: 0 0 8px var(--glow-color);
  transition: transform var(--transition-fast);
}

.tracker-value.decrease {
  transform: scale(1.3);
}

/* 4. Page-Flip 3D Perspective Card Flip */
.paper-wrapper {
  perspective: 1500px;
  transform-style: preserve-3d;
  transition: transform 1.1s cubic-bezier(0.645, 0.045, 0.355, 1.0), opacity 1.0s ease, filter 1.0s ease;
  position: relative;
}

.paper-wrapper.flipping {
  transform: rotateY(-180deg) scale(0.9) translateZ(-80px);
  opacity: 0;
  filter: blur(10px);
}

/* 5. The Avian Spine (ghostly ribcage back grid) */
.avian-spine-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  transition: opacity var(--transition-medium);
  overflow: hidden;
}

.paper-sheet.format-letter .avian-spine-container {
  opacity: 1;
}

.avian-spine-container svg {
  width: 100%;
  height: 100%;
  color: var(--accent-color);
}

/* Breathing / Ripple typing effect for paper */
@keyframes typing-ripple {
  0%, 100% {
    transform: scale(1.0) rotate(0deg);
  }
  25% {
    transform: scale(1.002) rotate(0.05deg) translateY(-0.5px);
  }
  75% {
    transform: scale(0.999) rotate(-0.05deg) translateY(0.5px);
  }
}

.paper-sheet.typing-nudge {
  animation: typing-ripple 0.18s ease-out;
}

/* Starling Flying Overlays */
.canvas-animation-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
  pointer-events: none;
  border-radius: inherit;
}

/* Ink blurring on letter during starlings takeoff */
.paper-sheet.blur-ink .letter-body,
.paper-sheet.blur-ink .letter-title {
  filter: blur(8px);
  opacity: 0.15;
  transition: filter 1.8s ease-in-out, opacity 1.8s ease-in-out;
}

/* 6. The Waterlogged Candle (Poem mode companion - nested) */
.candle-container {
  position: absolute;
  top: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  width: 52px;
  height: 120px;
  z-index: 12;
  display: flex;
  flex-direction: column;
  align-items: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--transition-medium), transform var(--transition-medium);
}

.candle-glass {
  width: 32px;
  height: 120px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: none;
  border-radius: 12px 12px 0 0;
  position: relative;
  overflow: hidden;
  box-shadow: inset 0 0 10px rgba(255, 255, 255, 0.03);
}

.candle-wax {
  position: absolute;
  bottom: 0;
  left: 3px;
  width: 24px;
  height: 100%; /* Transitions down to 15% as text is typed */
  background: linear-gradient(to top, rgba(244, 232, 193, 0.25) 0%, rgba(255, 255, 255, 0.4) 90%, rgba(244, 232, 193, 0.8) 100%);
  border-radius: 4px 4px 0 0;
  box-shadow: 0 0 15px rgba(244, 232, 193, 0.15), inset 0 0 5px rgba(255, 255, 255, 0.2);
  transition: height 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.candle-wick {
  width: 2px;
  height: 8px;
  background: #374151;
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
}

/* Position wick relative to wax height */
.candle-container .candle-wick {
  top: auto;
  bottom: 100%; /* Aligns wick right on top of wax */
  margin-bottom: 0px;
  transition: bottom 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.candle-flame {
  width: 10px;
  height: 18px;
  background: radial-gradient(circle, #ffffff 10%, #fef08a 35%, #f97316 70%, rgba(239, 68, 68, 0) 100%);
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%) scale(1.0);
  margin-bottom: 7px;
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  filter: drop-shadow(0 0 8px #f97316);
  z-index: 6;
  animation: flame-flicker 0.15s infinite alternate;
  transform-origin: bottom center;
  transition: bottom 0.5s cubic-bezier(0.25, 1, 0.5, 1), opacity var(--transition-medium), transform var(--transition-medium);
}

@keyframes flame-flicker {
  0% {
    transform: translateX(-50%) scaleX(0.95) scaleY(1.05) rotate(-1deg);
  }
  100% {
    transform: translateX(-50%) scaleX(1.05) scaleY(0.95) rotate(1deg);
  }
}

.candle-base {
  width: 48px;
  height: 6px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--glass-border);
  border-radius: 3px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.3);
}

/* Dynamic Candle Response Animations during typing */
.candle-flame.active-typing {
  animation: flame-flicker-typing 0.08s infinite alternate !important;
  filter: drop-shadow(0 0 16px #f59e0b) drop-shadow(0 0 4px #ef4444) !important;
  transform: translateX(-50%) scale(1.15) !important;
}

@keyframes flame-flicker-typing {
  0% {
    transform: translateX(-50%) scaleX(0.85) scaleY(1.15) rotate(-3deg);
  }
  50% {
    transform: translateX(-50%) scaleX(1.15) scaleY(0.85) rotate(3deg);
  }
  100% {
    transform: translateX(-50%) scaleX(0.95) scaleY(1.05) rotate(-1deg);
  }
}

.wax-glow-pool {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: #fef08a;
  border-radius: 50% 50% 0 0;
  box-shadow: 0 0 10px #f59e0b;
  opacity: 0.6;
  animation: pool-glow 2s infinite alternate;
}

@keyframes pool-glow {
  0% {
    opacity: 0.4;
    box-shadow: 0 0 8px #f59e0b;
  }
  100% {
    opacity: 0.8;
    box-shadow: 0 0 14px #f59e0b;
  }
}

.wax-driplet {
  position: absolute;
  top: 0;
  left: 4px;
  width: 3px;
  height: 6px;
  background: rgba(244, 232, 193, 0.9);
  border-radius: 50%;
  opacity: 0;
  pointer-events: none;
  z-index: 5;
}

.wax-driplet.dripping {
  animation: wax-drip-down 1.5s cubic-bezier(0.4, 0, 0.6, 1) forwards;
}

@keyframes wax-drip-down {
  0% {
    top: 0;
    opacity: 0;
    transform: scale(0.5);
  }
  10% {
    top: 0;
    opacity: 1;
    transform: scale(1);
  }
  90% {
    opacity: 0.8;
    transform: scale(1) translateY(80px);
  }
  100% {
    opacity: 0;
    transform: scale(0.2) translateY(95px);
  }
}

/* Adjust textarea margin to universally clear the 220px companion card */
.letter-body {
  margin-right: 16rem !important;
  transition: margin-right var(--transition-medium);
}

/* 6b. Floating Feather (Letter format companion - nested) */
.feather-container {
  position: absolute;
  top: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  width: 52px;
  height: 120px;
  z-index: 12;
  display: flex;
  flex-direction: column;
  align-items: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--transition-medium), transform var(--transition-medium);
}

.feather-glass {
  width: 32px;
  height: 120px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: none;
  border-radius: 12px 12px 0 0;
  position: relative;
  overflow: hidden;
  box-shadow: inset 0 0 10px rgba(255, 255, 255, 0.03);
}

.feather-wrapper {
  position: absolute;
  bottom: 12px;
  left: 50%;
  margin-left: -13px; /* centers 26px width inside 32px glass */
  width: 26px;
  height: 90px;
  color: var(--accent-color);
  opacity: calc(0.45 + var(--writing-progress, 0) * 0.55);
  filter: drop-shadow(0 0 calc(4px + var(--writing-progress, 0) * 16px) var(--glow-color));
  transform-origin: bottom center;
  animation: feather-sway 4s ease-in-out infinite alternate;
  animation-duration: calc(4.5s - var(--writing-progress, 0) * 3s); /* Speeds up from 4.5s down to 1.5s! */
  transition: opacity 0.5s ease, filter 0.5s ease;
}

@keyframes feather-sway {
  0% {
    transform: rotate(-3deg) translateY(0);
  }
  100% {
    transform: rotate(3deg) translateY(-8px) rotateX(5deg);
  }
}

.feather-base {
  width: 48px;
  height: 6px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--glass-border);
  border-radius: 3px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.3);
}

/* Active Typing state for feather container */
.feather-container.active-typing .feather-wrapper {
  animation: feather-typing-sway 0.1s infinite alternate !important;
}

@keyframes feather-typing-sway {
  0% {
    transform: rotate(-7deg) translateY(-3px) scale(1.04);
  }
  100% {
    transform: rotate(7deg) translateY(-9px) scale(0.96);
  }
}

/* Ink-light particle styling */
.feather-particles {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.feather-particle {
  position: absolute;
  bottom: 15px;
  background: var(--accent-color);
  border-radius: 50%;
  opacity: 0;
  pointer-events: none;
  filter: blur(0.5px) drop-shadow(0 0 5px var(--accent-color));
}

/* 6c. Geometric Dandelion Core (Art format companion) */
/* Universal Companion Card Container */
.dandelion-core-container {
  position: absolute;
  right: 2.2rem;
  top: 4.5rem;
  width: 220px !important;
  height: 310px !important;
  z-index: 15;
  display: flex;
  flex-direction: column;
  align-items: center;
  pointer-events: all !important;
  opacity: 1 !important;
  transform: translateX(0) scale(1.0) !important;
  transition: opacity var(--transition-medium), transform var(--transition-medium);
}

/* Center companions inside the top glass frame of the card */
.dandelion-core-container .candle-container,
.dandelion-core-container .feather-container {
  position: absolute;
  top: 1.5rem;
  left: 50%;
  right: auto;
  transform: translateX(-50%);
  width: 52px;
  height: 120px;
  z-index: 12;
  pointer-events: none;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Hide their default metal cylinder bases inside the premium card */
.dandelion-core-container .candle-base,
.dandelion-core-container .feather-base {
  display: none !important;
}

/* Default hidden state inside the card container */
.dandelion-core-container .candle-container,
.dandelion-core-container .feather-container,
.dandelion-core-container .dandelion-glass {
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity var(--transition-medium) !important;
}

/* Show only the companion corresponding to the active format */
.paper-sheet.format-poem .candle-container {
  opacity: 1 !important;
  pointer-events: all !important;
}

.paper-sheet.format-letter .feather-container {
  opacity: 1 !important;
  pointer-events: all !important;
}

.paper-sheet.format-art:not(.has-artifact) .dandelion-glass {
  opacity: 1 !important;
  pointer-events: all !important;
}

/* Ensure once an artifact is loaded/rendered, only the dandelion-glass is hidden in art format */
.paper-sheet.format-art.has-artifact .dandelion-glass {
  opacity: 0 !important;
  display: none !important;
}

.dandelion-head {
  position: absolute;
  bottom: 45px; /* Center beautifully inside glass */
  left: 50%;
  transform: translateX(-50%) scale(calc(0.75 + var(--writing-progress, 0) * 0.35));
  width: 10px;
  height: 10px;
  color: var(--accent-color);
  transition: transform 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.dandelion-center-core {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  background: currentColor;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 10px currentColor;
  opacity: calc(0.45 + var(--writing-progress, 0) * 0.55);
}

.dandelion-seeds-radial {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
}

.dandelion-seed-stem {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: calc(16px + var(--writing-progress, 0) * 14px); /* Stalk grows in length dynamically! */
  background: linear-gradient(to top, currentColor, rgba(255, 255, 255, 0.1));
  transform-origin: bottom center;
  transform: translate(-50%, 0) rotate(var(--angle));
  color: var(--accent-color);
  opacity: calc(0.3 + var(--writing-progress, 0) * 0.7);
  transition: height 0.5s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.5s cubic-bezier(0.25, 1, 0.5, 1);
  
  /* Twitching and pulsating speed scales with progress */
  animation: dandelion-seed-twitch calc(4.5s - var(--writing-progress, 0) * 4s) ease-in-out infinite alternate;
  animation-delay: calc(var(--angle) * -0.015s); /* Organic desynchronization */
}

@keyframes dandelion-seed-twitch {
  0% {
    transform: translate(-50%, 0) rotate(calc(var(--angle) - calc(0.5deg + var(--writing-progress, 0) * 4.5deg))) scaleY(0.97);
  }
  100% {
    transform: translate(-50%, 0) rotate(calc(var(--angle) + calc(0.5deg + var(--writing-progress, 0) * 4.5deg))) scaleY(1.05);
  }
}

.dandelion-seed-tip {
  position: absolute;
  top: 0;
  left: 50%;
  width: 4px;
  height: 4px;
  background: currentColor;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 6px currentColor;
}

/* Active Jitter typing feedback for Dandelion */
.dandelion-core-container.active-typing .dandelion-head {
  animation: dandelion-jitter 0.07s infinite alternate !important;
}

@keyframes dandelion-jitter {
  0% {
    transform: translateX(-50%) rotate(-1.5deg) scale(calc(0.78 + var(--writing-progress, 0) * 0.35));
  }
  100% {
    transform: translateX(-50%) rotate(1.5deg) scale(calc(0.72 + var(--writing-progress, 0) * 0.35));
  }
}

@keyframes feather-particle-float {
  0% {
    transform: translateY(0) translateX(0) scale(0.4);
    opacity: 0;
  }
  20% {
    opacity: calc(0.5 + var(--writing-progress, 0) * 0.5);
  }
  100% {
    transform: translateY(-90px) translateX(calc(-15px + 30px * var(--rand-dir, 0.5))) scale(1.3);
    opacity: 0;
  }
}



/* 7. Dandelion Membrane Container (Art format) */
.dandelion-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  transition: opacity var(--transition-medium);
  overflow: hidden;
}

.paper-sheet.format-art .dandelion-container {
  opacity: 1;
}

.dandelion-container svg {
  width: 100%;
  height: 100%;
  color: var(--accent-color);
}

/* 7b. Creeping Ivy Container (Journal format) */
.ivy-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  transition: opacity var(--transition-medium);
  overflow: hidden;
}

.paper-sheet.format-journal .ivy-container {
  opacity: 1;
}

.ivy-container svg {
  width: 100%;
  height: 100%;
  color: var(--accent-color);
}

.ivy-leaf {
  transform: scale(var(--scale, 0.4));
  opacity: var(--opacity, 0.05);
  transition: transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.6s ease;
  color: var(--accent-color);
}

/* Specify exact transform-origins mapping to viewbox coordinates */
#ivy-leaf-0 { transform-origin: 15px 165px; }
#ivy-leaf-1 { transform-origin: 12px 130px; }
#ivy-leaf-2 { transform-origin: 18px 95px; }
#ivy-leaf-3 { transform-origin: 14px 60px; }
#ivy-leaf-4 { transform-origin: 15px 30px; }

/* Shift textarea slightly to the right in journal mode to protect readability from crawling ivy */
.paper-sheet.format-journal .letter-body {
  margin-left: 2.8rem;
  transition: margin-left var(--transition-medium);
}

/* 7c. Lyre & Laurel Poetry Watermark (Poem format) */
.poetry-lyre-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  transition: opacity var(--transition-medium);
  overflow: hidden;
}

.paper-sheet.format-poem .poetry-lyre-container {
  opacity: 1;
}

.poetry-lyre-container svg {
  width: 100%;
  height: 100%;
  color: var(--accent-color);
}

.poetry-lyre-instrument, .poetry-laurel {
  transform-origin: center;
  transition: transform var(--transition-slow), opacity var(--transition-medium), filter var(--transition-slow);
}

/* Active typing response for Lyre & Laurel */
.poetry-lyre-container.active-typing .poetry-lyre-instrument {
  transform: scale(1.04);
  filter: drop-shadow(0 0 12px var(--accent-color));
}

.poetry-lyre-container.active-typing .poetry-laurel {
  transform: scale(1.02);
  filter: drop-shadow(0 0 8px var(--accent-color));
}

/* Centered Poetry Text Aesthetics Override */
.paper-sheet.format-poem .letter-title {
  text-align: center !important;
  font-family: var(--font-serif) !important;
  font-style: italic !important;
  font-size: 1.8rem !important;
  letter-spacing: 0.08em !important;
  border-bottom: 1px dashed rgba(226, 217, 194, 0.15) !important;
  margin-bottom: 2.5rem !important;
  transition: all var(--transition-medium) !important;
}

.paper-sheet.format-poem .letter-body {
  text-align: center !important;
  font-family: var(--font-serif) !important;
  font-style: italic !important;
  font-size: 1.25rem !important;
  line-height: 2.6rem !important; /* Spacious stanzas */
  letter-spacing: 0.04em !important;
  background-image: none !important; /* Pristine floating background without rigid rules */
  transition: all var(--transition-medium) !important;
}


/* 8. Faint Lana Del Rey Lyric Inspiration */
.sentiment-inspiration {
  margin-top: auto !important; /* Push to bottom of the flex container */
  margin-bottom: 0.5rem; /* Space from the bottom edge of the sheet */
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.82rem;
  letter-spacing: 0.3px;
  color: var(--journal-paper-color, var(--text-secondary)); /* Use var(--text-secondary) as a better fallback for higher contrast */
  opacity: 0.9; /* Highly visible and completely readable by default */
  pointer-events: none;
  transition: opacity var(--transition-slow), color var(--transition-fast);
  white-space: normal; /* Safe wrapping on all screen sizes */
  text-align: center;
  width: 100%;
  box-sizing: border-box;
  z-index: 2;
}

/* Show when paper-sheet contains text or is active */
.paper-sheet:focus-within .sentiment-inspiration,
.paper-sheet .letter-body:not(:placeholder-shown) ~ .sentiment-inspiration,
.paper-sheet #journal-visual-sheet:has(textarea:not(:placeholder-shown), input[type="text"]:not(:placeholder-shown)) ~ .sentiment-inspiration {
  opacity: 1; /* Fully visible and readable when writing or focused */
  color: var(--journal-paper-color, var(--text-primary));
}

@media (max-width: 600px) {
  .sentiment-inspiration {
    font-size: 0.75rem !important;
    line-height: 1.35 !important;
    margin-top: auto !important;
    margin-bottom: 0.25rem !important;
  }
}

/* 9. Previous Sessions Bleed Ghosts Layer */
.bleed-ghosts-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.bleed-ghost {
  position: absolute;
  width: 90%;
  left: 5%;
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--accent-color);
  font-size: 0.95rem;
  line-height: 1.6;
  opacity: 0.015; /* Ultra-low opacity shimmer */
  transform-origin: center center;
  transition: opacity 2.5s ease, transform 2.5s ease, filter 2.5s ease;
  user-select: none;
  pointer-events: none;
  white-space: pre-wrap;
  filter: blur(1.5px);
}

/* When releasing, ghosts ripple away and fade down */
.bleed-ghost.rippling {
  opacity: 0 !important;
  transform: scale(1.12) rotate(1deg) translateY(-25px);
  filter: blur(5px);
}

/* 10. Premium Custom HTML CSS Tooltips for Header mooddots
   Uses CSS attr data-tooltip to prevent ugly platform default title rendering */
.header-mood-dot {
  /* Override default title */
  cursor: pointer;
}

.header-mood-dot::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: -32px;
  left: 50%;
  transform: translateX(-50%) translateY(5px);
  background: rgba(8, 6, 12, 0.92);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 500;
  padding: 0.25rem 0.55rem;
  border-radius: 7px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(10px);
  transition: opacity var(--transition-fast), transform var(--transition-fast);
  z-index: 1000;
}

.header-mood-dot:hover::after {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ==========================================
   Subscriber Glassmorphic Modal
   ========================================== */
.subscribe-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(3, 2, 7, 0.7);
  backdrop-filter: blur(25px);
  z-index: 1000;
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity var(--transition-medium), visibility var(--transition-medium);
}

.subscribe-modal-overlay.active {
  opacity: 1;
  pointer-events: all;
  visibility: visible;
}

.subscribe-modal-card {
  position: relative;
  width: 100%;
  max-width: 440px;
  background: rgba(15, 12, 23, 0.65);
  border: 1px solid var(--glass-border);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.8), 0 0 40px var(--glow-color);
  padding: 3rem 2.5rem;
  border-radius: 24px;
  text-align: center;
  transform: scale(0.92) translateY(15px);
  transition: transform var(--transition-medium), opacity var(--transition-medium);
  backdrop-filter: blur(15px);
}

.subscribe-modal-overlay.active .subscribe-modal-card {
  transform: scale(1) translateY(0);
}

.subscribe-modal-card .modal-close-btn {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
}

.subscribe-modal-header {
  margin-bottom: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.subscribe-icon-glow {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(99, 102, 241, 0.08);
  border: 1px solid var(--glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-color);
  margin-bottom: 1.5rem;
  box-shadow: 0 0 25px var(--glow-color);
  animation: pulse-glow 3s infinite alternate;
}

.subscribe-icon-glow svg {
  width: 28px;
  height: 28px;
  fill: currentColor;
}

.subscribe-modal-card h3 {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: 1px;
  margin-bottom: 0.75rem;
  background: linear-gradient(to bottom, #ffffff, var(--text-secondary));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.subscribe-modal-card p {
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.6;
}

.subscribe-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.input-wrapper {
  position: relative;
  width: 100%;
}

.subscribe-form input[type="email"] {
  width: 100%;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid var(--glass-border);
  padding: 0.9rem 1.2rem;
  border-radius: 12px;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.92rem;
  outline: none;
  transition: all var(--transition-fast);
}

.subscribe-form input[type="email"]:focus {
  border-color: var(--accent-color);
  background: rgba(0, 0, 0, 0.4);
}

.input-border-glow {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 12px;
  pointer-events: none;
  border: 1px solid transparent;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  z-index: 2;
}

.subscribe-form input[type="email"]:focus + .input-border-glow {
  border-color: var(--accent-color);
  box-shadow: 0 0 10px var(--glow-color);
}

.subscribe-error-msg {
  font-size: 0.78rem;
  color: #f87171;
  text-align: left;
  margin-top: -0.5rem;
  min-height: 1rem;
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.subscribe-error-msg.visible {
  opacity: 1;
}

.subscribe-submit-btn {
  background: var(--accent-color);
  color: #0d0a15;
  border: none;
  padding: 0.9rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 4px 15px var(--glow-color);
  transition: all var(--transition-fast);
}

.subscribe-submit-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px var(--glow-bright);
}

.subscribe-submit-btn:active {
  transform: translateY(0);
}

/* Success State Screen */
.subscribe-success-msg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(13, 10, 20, 0.98);
  border-radius: 24px;
  padding: 3rem 2.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  transform: scale(0.96);
  transition: all var(--transition-medium);
  z-index: 5;
}

.subscribe-success-msg.visible {
  opacity: 1;
  pointer-events: all;
  transform: scale(1);
}

.success-checkmark {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: rgba(16, 185, 129, 0.1);
  border: 2px solid #10b981;
  color: #10b981;
  font-size: 1.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  box-shadow: 0 0 20px rgba(16, 185, 129, 0.3);
  animation: scale-up-bounce 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) both;
}

.subscribe-success-msg h4 {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  font-weight: 400;
  margin-bottom: 0.75rem;
  color: #10b981;
}

@keyframes scale-up-bounce {
  0% { transform: scale(0); opacity: 0; }
  100% { transform: scale(1); opacity: 1; }
}


/* ==========================================
   Sign In Header Pill & Auth Modal
   ========================================== */
.hud-signin-btn {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  padding: 0.35rem 0.82rem;
  border-radius: 20px;
  display: flex;
  align-items: center;
  gap: 0.38rem;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 500;
  transition: all var(--transition-fast);
  backdrop-filter: blur(8px);
  letter-spacing: 0.5px;
}

.hud-signin-btn:hover {
  border-color: var(--accent-color);
  box-shadow: 0 0 12px var(--glow-color);
  transform: translateY(-1.5px);
}

.hud-signin-btn svg {
  width: 11px;
  height: 11px;
  fill: currentColor;
}

/* Active Profile State styling */
.hud-signin-btn.logged-in {
  border-color: #10b981;
  background: rgba(16, 185, 129, 0.05);
}

.hud-signin-btn.logged-in:hover {
  box-shadow: 0 0 12px rgba(16, 185, 129, 0.25);
  border-color: #34d399;
}

.hud-signin-btn .profile-dot {
  width: 6px;
  height: 6px;
  background: #10b981;
  border-radius: 50%;
  box-shadow: 0 0 6px #10b981;
}

/* Modal styling */
.auth-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(3, 2, 7, 0.7);
  backdrop-filter: blur(25px);
  z-index: 1000;
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity var(--transition-medium), visibility var(--transition-medium);
}

.auth-modal-overlay.active {
  opacity: 1;
  pointer-events: all;
  visibility: visible;
}

.auth-modal-card {
  position: relative;
  width: 100%;
  max-width: 440px;
  background: rgba(15, 12, 23, 0.65);
  border: 1px solid var(--glass-border);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.8), 0 0 40px var(--glow-color);
  padding: 3rem 2.5rem;
  border-radius: 24px;
  text-align: center;
  transform: scale(0.92) translateY(15px);
  transition: transform var(--transition-medium), opacity var(--transition-medium);
  backdrop-filter: blur(15px);
}

.auth-modal-overlay.active .auth-modal-card {
  transform: scale(1) translateY(0);
}

.auth-modal-card .modal-close-btn {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
}

.auth-modal-header {
  margin-bottom: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.auth-icon-glow {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(99, 102, 241, 0.08);
  border: 1px solid var(--glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-color);
  margin-bottom: 1.5rem;
  box-shadow: 0 0 25px var(--glow-color);
  animation: pulse-glow 3s infinite alternate;
  position: relative;
  overflow: hidden;
  transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.auth-icon-glow.clickable {
  cursor: pointer;
}

.auth-icon-glow.clickable:hover {
  transform: scale(1.08);
  border-color: var(--accent-color);
  box-shadow: 0 0 35px var(--glow-color), inset 0 0 10px rgba(99, 102, 241, 0.4);
}

/* Elegant dark hover overlay to change picture */
.auth-icon-glow.clickable::after {
  content: 'Edit';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.65);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  opacity: 0;
  transition: opacity var(--transition-fast);
  pointer-events: none;
  border-radius: 50%;
  z-index: 2;
}

.auth-icon-glow.clickable:hover::after {
  opacity: 1;
}

.auth-icon-glow svg {
  width: 28px;
  height: 28px;
  fill: currentColor;
  transition: opacity var(--transition-fast);
}

.auth-modal-card h3 {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: 1px;
  margin-bottom: 0.75rem;
  background: linear-gradient(to bottom, #ffffff, var(--text-secondary));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.auth-modal-card p {
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.6;
}

/* Form Container elements */
.google-auth-btn {
  width: 100%;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  padding: 0.85rem 1.2rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  transition: all var(--transition-fast);
  backdrop-filter: blur(5px);
  margin-bottom: 1.25rem;
}

.google-auth-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: var(--text-secondary);
  transform: translateY(-1.5px);
  box-shadow: 0 4px 15px rgba(255, 255, 255, 0.05);
}

.google-icon {
  width: 18px;
  height: 18px;
}

.auth-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin: 1.5rem 0;
  color: var(--text-muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.auth-divider::before,
.auth-divider::after {
  content: '';
  flex-grow: 1;
  height: 1px;
  background: var(--glass-border);
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.auth-form input[type="email"] {
  width: 100%;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid var(--glass-border);
  padding: 0.9rem 1.2rem;
  border-radius: 12px;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.92rem;
  outline: none;
  transition: all var(--transition-fast);
}

.auth-form input[type="email"]:focus {
  border-color: var(--accent-color);
  background: rgba(0, 0, 0, 0.4);
}

.auth-form input[type="email"]:focus + .input-border-glow {
  border-color: var(--accent-color);
  box-shadow: 0 0 10px var(--glow-color);
}

.auth-error-msg {
  font-size: 0.78rem;
  color: #f87171;
  text-align: left;
  margin-top: -0.5rem;
  min-height: 1rem;
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.auth-error-msg.visible {
  opacity: 1;
}

.auth-submit-btn {
  background: var(--accent-color);
  color: #0d0a15;
  border: none;
  padding: 0.9rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 4px 15px var(--glow-color);
  transition: all var(--transition-fast);
  width: 100%;
}

.auth-submit-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px var(--glow-bright);
}

.auth-submit-btn:active {
  transform: translateY(0);
}

/* Success State Screen */
.auth-success-msg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(13, 10, 20, 0.98);
  border-radius: 24px;
  padding: 3rem 2.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  transform: scale(0.96);
  transition: all var(--transition-medium);
  z-index: 5;
}

.auth-success-msg.visible {
  opacity: 1;
  pointer-events: all;
  transform: scale(1);
}

.auth-success-msg h4 {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  font-weight: 400;
  margin-bottom: 0.75rem;
  color: #10b981;
}

/* Profile Container & Sign Out Button styles */
.auth-profile-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  margin-top: 1rem;
}

.profile-info-card {
  width: 100%;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  padding: 1.5rem;
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  backdrop-filter: blur(5px);
}

.profile-field {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.88rem;
}

.profile-field .label {
  color: var(--text-muted);
  font-family: var(--font-sans);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.profile-field .value {
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-weight: 500;
}

.profile-field .value.provider {
  font-size: 0.75rem;
  background: rgba(99, 102, 241, 0.15);
  color: #a5b4fc;
  padding: 0.2rem 0.6rem;
  border-radius: 10px;
  text-transform: capitalize;
}

/* Profile Avatar Image overlay inside .auth-icon-glow */
.profile-avatar-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  z-index: 1;
}

/* Username edit field styling */
.username-edit-wrapper {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid var(--glass-border);
  padding: 0.2rem 0.4rem 0.2rem 0.8rem;
  border-radius: 12px;
  transition: all var(--transition-fast);
}

.username-edit-wrapper:focus-within {
  border-color: var(--accent-color);
  box-shadow: 0 0 10px var(--glow-color);
}

.profile-username-input {
  background: transparent;
  border: none;
  outline: none;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.88rem;
  width: 140px;
  padding: 0.3rem 0;
}

.profile-username-input::placeholder {
  color: var(--text-muted);
  opacity: 0.6;
}

.username-save-btn {
  background: var(--accent-color);
  color: #0d0a15;
  border: none;
  padding: 0.35rem 0.8rem;
  border-radius: 8px;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.username-save-btn:hover {
  background: var(--text-primary);
  color: #0d0a15;
  transform: translateY(-0.5px);
}

.profile-export-btn {
  background: rgba(16, 185, 129, 0.08);
  color: #34d399;
  border: 1px solid rgba(16, 185, 129, 0.3);
  padding: 0.9rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
  width: 100%;
  letter-spacing: 0.5px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.profile-export-btn:hover {
  background: rgba(16, 185, 129, 0.15);
  border-color: #34d399;
  box-shadow: 0 0 15px rgba(16, 185, 129, 0.3);
  transform: translateY(-1.5px);
}

.profile-export-btn:active {
  transform: translateY(0);
}

.auth-signout-btn {
  background: rgba(239, 68, 68, 0.1);
  color: #f87171;
  border: 1px solid rgba(239, 68, 68, 0.3);
  padding: 0.9rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
  width: 100%;
  letter-spacing: 0.5px;
}

.auth-signout-btn:hover {
  background: rgba(239, 68, 68, 0.2);
  border-color: #f87171;
  box-shadow: 0 0 15px rgba(239, 68, 68, 0.3);
  transform: translateY(-1.5px);
}

.auth-signout-btn:active {
  transform: translateY(0);
}

/* ==========================================
   Interactive Profile Daily Mood Logger styles
   ========================================== */
.profile-mood-logger {
  width: 100%;
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  backdrop-filter: blur(10px);
  margin-top: 1.5rem;
  margin-bottom: 2rem;
  box-shadow: var(--card-shadow);
  text-align: center;
}

@media (min-width: 1025px) {
  .profile-mood-logger {
    display: grid;
    grid-template-columns: 1fr 1.8fr 0.8fr;
    align-items: center;
    gap: 2.5rem;
    padding: 2rem;
    text-align: left;
    background: rgba(0, 0, 0, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.04);
  }
  .profile-mood-logger h4 {
    grid-column: 1 / -1;
    margin-bottom: -0.5rem;
  }
  .profile-mood-slider-row {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
    padding: 0;
  }
  .profile-mood-save-btn {
    align-self: center;
    margin-top: 0;
  }
  .profile-mood-confirmation {
    grid-column: 1 / -1;
    text-align: center;
  }
}

.profile-mood-logger h4 {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--text-primary);
  margin: 0;
  letter-spacing: 0.3px;
}

.profile-mood-slider-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 0;
}

.profile-mood-emoji {
  font-size: 2.2rem;
  filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.15));
  transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  cursor: default;
  user-select: none;
}

.profile-mood-emoji:hover {
  transform: scale(1.15);
}

/* Custom premium range slider */
.profile-mood-slider {
  -webkit-appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.1);
  outline: none;
  transition: background 0.3s;
}

.profile-mood-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--accent-color, #6366f1);
  border: 2px solid #fff;
  box-shadow: 0 0 12px var(--accent-color, #6366f1);
  cursor: pointer;
  transition: transform 0.2s, background-color 0.3s, box-shadow 0.3s;
}

.profile-mood-slider::-webkit-slider-thumb:hover {
  transform: scale(1.2);
}

.profile-mood-slider::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--accent-color, #6366f1);
  border: 2px solid #fff;
  box-shadow: 0 0 12px var(--accent-color, #6366f1);
  cursor: pointer;
  border: none;
  transition: transform 0.2s, background-color 0.3s, box-shadow 0.3s;
}

.profile-mood-slider::-moz-range-thumb:hover {
  transform: scale(1.2);
}

.profile-mood-label {
  font-size: 0.85rem;
  font-family: var(--font-sans);
  color: var(--text-secondary);
  font-weight: 500;
  letter-spacing: 0.3px;
  transition: color 0.3s;
}

.profile-mood-note {
  width: 100%;
  height: 80px;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 0.75rem;
  color: var(--text-primary);
  font-family: var(--font-serif);
  font-size: 0.9rem;
  line-height: 1.4;
  resize: none;
  outline: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.profile-mood-note:focus {
  border-color: var(--accent-color, #6366f1);
  box-shadow: 0 0 10px rgba(99, 102, 241, 0.15);
}

.profile-mood-save-btn {
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.2), rgba(139, 92, 246, 0.2));
  color: var(--text-primary);
  border: 1px solid rgba(99, 102, 241, 0.4);
  padding: 0.75rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
  width: 100%;
  letter-spacing: 0.5px;
}

.profile-mood-save-btn:hover {
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.35), rgba(139, 92, 246, 0.35));
  border-color: var(--accent-color, #6366f1);
  box-shadow: 0 0 15px rgba(99, 102, 241, 0.25);
  transform: translateY(-1px);
}

.profile-mood-save-btn:active {
  transform: translateY(0);
}

.profile-mood-confirmation {
  font-family: var(--font-serif);
  font-size: 0.88rem;
  font-style: italic;
  color: #10b981; /* Soft emerald green for comfort/success */
  text-align: center;
  margin: 0;
  padding: 0.5rem 0.25rem 0 0.25rem;
  line-height: 1.4;
  animation: fadeInComfort 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;
  filter: drop-shadow(0 0 8px rgba(16, 185, 129, 0.2));
}

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

/* Ensure auth-modal-card can scroll if content exceeds screen height */
.auth-modal-card {
  max-height: 90vh;
  overflow-y: auto;
}

.auth-modal-card::-webkit-scrollbar {
  width: 6px;
}

.auth-modal-card::-webkit-scrollbar-track {
  background: transparent;
}

.auth-modal-card::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 3px;
}

.auth-modal-card::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.25);
}

/* ==========================================
   AI Image Generation & Soul Artifact Layouts
   ========================================== */

/* Wide margin for Art sheet to hold frame */
.paper-sheet.format-art .letter-body {
  margin-right: 16rem !important;
  transition: margin-right var(--transition-medium);
}

/* Enable dandelion-core-container for all formats to support companions and layout flow */
.dandelion-core-container {
  pointer-events: all !important;
}

/* Show the companion-level soul artifact frame only in Art format when an artifact is active */
.paper-sheet.format-art.has-artifact .soul-artifact-frame {
  display: flex !important;
}

/* Hide it on any other formats or when there's no active artifact */
.paper-sheet:not(.format-art) .soul-artifact-frame,
.paper-sheet:not(.has-artifact) .soul-artifact-frame {
  display: none !important;
}

/* Hide inline sheet-level artifact frame in Art format when there's an active artifact */
.paper-sheet.format-art.has-artifact .sheet-artifact-frame {
  display: none !important;
}

/* Ensure default visual companions are hidden when an artifact image is active on the sheet */
.paper-sheet.has-artifact .candle-container,
.paper-sheet.has-artifact .feather-container,
.paper-sheet.has-artifact .dandelion-glass {
  opacity: 0 !important;
  pointer-events: none !important;
  display: none !important;
}

/* Art visualizer expanded container */
.paper-sheet.format-art .dandelion-core-container {
  opacity: 1;
  transform: translateX(0) scale(1.0);
  width: 220px !important;
  height: 310px !important;
  right: 2.2rem;
  top: 4.5rem;
  pointer-events: all !important;
}

/* Reposition dandelion head to act as decorative floating icon inside card */
.paper-sheet.format-art .dandelion-glass {
  position: absolute;
  top: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  width: 32px;
  height: 100px;
  background: transparent;
  border: none;
  box-shadow: none;
  z-index: 12;
  pointer-events: none;
}

.paper-sheet.format-art .dandelion-base {
  display: none !important; /* Hide metal cylinder base inside card */
}

.paper-sheet.format-art .dandelion-head {
  bottom: 25px;
}

/* Hide original visualizer elements when artifact is rendered */
.paper-sheet.format-art.has-artifact .dandelion-glass {
  display: none !important;
}

/* Soul Artifact Card Frame */
.soul-artifact-frame {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  background: rgba(10, 8, 16, 0.4);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  backdrop-filter: blur(12px);
  z-index: 10;
  overflow: hidden;
  box-shadow: var(--card-shadow), inset 0 0 15px rgba(255, 255, 255, 0.02);
  pointer-events: all;
  transition: all var(--transition-medium);
}

/* Empty State Choices styling */
.artifact-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 1.5rem;
  text-align: center;
}

.artifact-placeholder-icon {
  font-size: 2rem;
  margin-bottom: 0.5rem;
  filter: drop-shadow(0 0 10px rgba(167, 139, 250, 0.3));
  opacity: 0.15; /* Sits behind the floating dandelion */
}

.artifact-empty-state h4 {
  font-family: var(--font-serif);
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
  letter-spacing: 0.5px;
}

.artifact-desc {
  font-size: 0.72rem;
  color: var(--text-secondary);
  line-height: 1.4;
  margin-bottom: 1.25rem;
  max-width: 170px;
}

.artifact-choices {
  display: flex;
  gap: 0.5rem;
  width: 100%;
  z-index: 15;
}

.artifact-choice-btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  padding: 0.6rem 0.4rem;
  color: var(--text-secondary);
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.artifact-choice-btn svg {
  width: 14px;
  height: 14px;
  color: var(--text-secondary);
  transition: color var(--transition-fast);
}

.artifact-choice-btn:hover {
  background: rgba(167, 139, 250, 0.08);
  border-color: var(--accent-color);
  color: var(--text-primary);
  transform: translateY(-2px);
}

.artifact-choice-btn:hover svg {
  color: var(--accent-color);
}

/* Loading State (Water bleeding rings) */
.artifact-loading-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 1.5rem;
  text-align: center;
  background: rgba(5, 4, 8, 0.85);
  z-index: 20;
}

.meditative-spinner {
  position: relative;
  width: 60px;
  height: 60px;
  margin-bottom: 1.5rem;
}

.spinner-ring {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 2px solid transparent;
  border-radius: 50%;
  mix-blend-mode: screen;
}

.ring-1 {
  border-top-color: var(--accent-color);
  animation: spin-clockwise 2.5s linear infinite;
}

.ring-2 {
  border-right-color: #06b6d4; /* Hope Cyan */
  animation: spin-counterclockwise 3.5s linear infinite;
  transform: scale(0.8);
}

.ring-3 {
  border-bottom-color: #ef4444; /* Anger Crimson */
  animation: spin-clockwise 4.5s linear infinite;
  transform: scale(0.6);
}

@keyframes spin-clockwise {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

@keyframes spin-counterclockwise {
  0% { transform: rotate(360deg); }
  100% { transform: rotate(0deg); }
}

.loading-phase-text {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.4;
  animation: breathe-text 2s infinite alternate;
}

@keyframes breathe-text {
  0% { opacity: 0.5; }
  100% { opacity: 1; }
}

/* Final Display Card & Metadata Overlay */
.artifact-display-state {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  z-index: 10;
}

.artifact-image-container {
  width: 100%;
  height: 190px;
  overflow: hidden;
  position: relative;
  border-bottom: 1px solid var(--glass-border);
}

.artifact-image-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.artifact-display-state:hover .artifact-image-container img {
  transform: scale(1.05);
}

.artifact-glint {
  position: absolute;
  top: 0;
  left: -150%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.08) 35%,
    rgba(255, 255, 255, 0.18) 50%,
    rgba(255, 255, 255, 0.08) 65%,
    rgba(255, 255, 255, 0) 100%
  );
  z-index: 15;
  pointer-events: none;
  transform: skewX(-20deg);
}

.artifact-display-state:hover .artifact-glint {
  left: 150%;
  transition: left 1.2s cubic-bezier(0.19, 1, 0.22, 1);
}

.artifact-metadata {
  padding: 0.75rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  background: rgba(0, 0, 0, 0.3);
  flex-grow: 1;
}

.metadata-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.7rem;
  color: var(--text-muted);
}

.metadata-row.header-row {
  margin-bottom: 0.15rem;
}

.artifact-id {
  font-weight: 600;
  color: var(--text-primary);
  font-family: var(--font-sans);
}

.validated-badge {
  font-size: 0.6rem;
  text-transform: uppercase;
  font-weight: 700;
  padding: 0.1rem 0.4rem;
  border-radius: 6px;
  background: rgba(167, 139, 250, 0.15);
  color: var(--accent-color);
  border: 1px solid rgba(167, 139, 250, 0.3);
  text-shadow: 0 0 5px var(--glow-color);
  box-shadow: 0 0 10px rgba(167, 139, 250, 0.1);
}

.validated-badge.sanctuary-crafted {
  background: rgba(52, 211, 153, 0.15) !important;
  color: #34d399 !important;
  border-color: rgba(52, 211, 153, 0.3) !important;
  text-shadow: 0 0 5px rgba(52, 211, 153, 0.2) !important;
  box-shadow: 0 0 10px rgba(52, 211, 153, 0.1) !important;
}

.meta-label {
  opacity: 0.75;
}

.meta-val {
  color: var(--text-secondary);
  font-weight: 500;
}

.artifact-reset-btn {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.6);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  font-size: 0.65rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 18;
  transition: all var(--transition-fast);
}

.artifact-reset-btn:hover {
  background: #ef4444;
  color: #ffffff;
  border-color: #ef4444;
  transform: scale(1.1);
}

/* Vault List thumbnail displays */
.vcard-thumbnail {
  width: 44px;
  height: 60px;
  border-radius: 8px;
  border: 1px solid var(--glass-border);
  overflow: hidden;
  flex-shrink: 0;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.4);
}

.vcard-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ==========================================
   Secrets Glassmorphic Modal Overlay
   ========================================== */
.secrets-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(3, 2, 7, 0.7);
  backdrop-filter: blur(25px);
  z-index: 1000;
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity var(--transition-medium), visibility var(--transition-medium);
}

.secrets-modal-overlay.active {
  opacity: 1;
  pointer-events: all;
  visibility: visible;
}

.secrets-modal-card {
  position: relative;
  width: 100%;
  max-width: 440px;
  background: rgba(15, 12, 23, 0.65);
  border: 1px solid var(--glass-border);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.8), 0 0 40px var(--glow-color);
  padding: 3rem 2.5rem;
  border-radius: 24px;
  text-align: center;
  transform: scale(0.92) translateY(15px);
  transition: transform var(--transition-medium), opacity var(--transition-medium);
  backdrop-filter: blur(15px);
}

.secrets-modal-overlay.active .secrets-modal-card {
  transform: scale(1) translateY(0);
}

.secrets-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.secrets-form input[type="password"] {
  width: 100%;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid var(--glass-border);
  padding: 0.9rem 1.2rem;
  border-radius: 12px;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.92rem;
  outline: none;
  transition: all var(--transition-fast);
}

.secrets-form input[type="password"]:focus {
  border-color: var(--accent-color);
  background: rgba(0, 0, 0, 0.4);
}

.secrets-form input[type="password"]:focus + .input-border-glow {
  border-color: var(--accent-color);
  box-shadow: 0 0 10px var(--glow-color);
}

.secrets-actions {
  display: flex;
  gap: 1rem;
}

.secrets-test-btn {
  flex: 1;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  padding: 0.9rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.secrets-test-btn:hover {
  background: rgba(255, 255, 255, 0.07);
  border-color: var(--text-secondary);
  transform: translateY(-1.5px);
}

.secrets-save-btn {
  flex: 1;
  background: var(--accent-color);
  color: #0d0a15;
  border: none;
  padding: 0.9rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 4px 15px var(--glow-color);
  transition: all var(--transition-fast);
}

.secrets-save-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px var(--glow-bright);
}

.secrets-status-msg {
  font-size: 0.78rem;
  min-height: 1.2rem;
  margin-top: -0.25rem;
  text-align: center;
  transition: color 0.2s ease;
}

.secrets-status-msg.success {
  color: #10b981;
}

.secrets-status-msg.error {
  color: #f87171;
}

.secrets-status-msg.info {
  color: var(--text-secondary);
}

/* ==========================================
   MOOD ANALYSER STYLES (BELOW WRITER'S SALON)
   ========================================== */
.mood-analyser-container {
  grid-column: 1 / -1; /* Spans across both columns */
  margin-top: 4rem;
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 2.2rem;
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  box-shadow: var(--glass-shadow);
  transition: all 0.4s ease;
  position: relative;
  z-index: 10;
  flex-shrink: 0;
}

.mood-analyser-container:hover {
  border-color: rgba(255, 255, 255, 0.12);
  box-shadow: 0 15px 45px rgba(0, 0, 0, 0.45);
}

.analyser-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  margin-bottom: 2rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  padding-bottom: 1.2rem;
}

.analyser-title-block h3 {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin: 0 0 0.4rem 0;
  letter-spacing: 0.3px;
}

.analyser-title-block h3 svg {
  width: 22px;
  height: 22px;
  color: var(--accent-color, #6366f1);
  filter: drop-shadow(0 0 8px rgba(99, 102, 241, 0.4));
}

.analyser-subtitle {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  color: var(--text-secondary);
  margin: 0;
}

.analyser-action-btn {
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.2), rgba(236, 72, 153, 0.2));
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--text-primary);
  border-radius: 12px;
  padding: 0.6rem 1.4rem;
  font-size: 0.88rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  transition: transform 0.2s, background 0.3s, border-color 0.3s;
  box-shadow: 0 4px 15px rgba(0,0,0,0.2);
}

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

.analyser-action-btn:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.35), rgba(236, 72, 153, 0.35));
  border-color: rgba(255, 255, 255, 0.25);
  box-shadow: 0 0 15px rgba(99, 102, 241, 0.25);
}

.analyser-action-btn:active {
  transform: translateY(0);
}

/* Loading State styles */
.analyser-loading-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2.5rem;
  gap: 1rem;
  background: rgba(0, 0, 0, 0.15);
  border-radius: 12px;
  margin-bottom: 2rem;
  border: 1px dashed rgba(255, 255, 255, 0.08);
}

/* Gemini Output Box */
.analyser-output-frame {
  position: relative;
  background: rgba(99, 102, 241, 0.04);
  border: 1px solid rgba(99, 102, 241, 0.15);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25), inset 0 0 20px rgba(99, 102, 241, 0.03);
  border-radius: 16px;
  padding: 2.2rem;
  margin-bottom: 2.5rem;
  animation: slideUpFade 0.6s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

.oracle-badge {
  position: absolute;
  top: -10px;
  left: 2rem;
  background: linear-gradient(135deg, #6366f1, #ec4899);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  padding: 0.25rem 0.8rem;
  border-radius: 20px;
  letter-spacing: 0.8px;
  box-shadow: 0 2px 10px rgba(99, 102, 241, 0.35);
}

.oracle-content {
  font-size: 1.05rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.95);
  font-style: italic;
  white-space: pre-wrap;
}

.oracle-close-btn {
  position: absolute;
  top: 1rem;
  right: 1.2rem;
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 1.1rem;
  cursor: pointer;
  transition: color 0.2s;
}

.oracle-close-btn:hover {
  color: var(--text-primary);
}

/* Mood History Table Styling */
.mood-history-table-wrapper {
  overflow-x: auto;
  background: rgba(0, 0, 0, 0.18);
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.mood-history-table {
  width: 100%;
  border-collapse: collapse;
  text-align: left;
  font-size: 0.95rem;
}

/* Strict responsive column width allocations */
.mood-history-table th:nth-child(1),
.mood-history-table td:nth-child(1) {
  width: 22%;
  min-width: 140px;
}

.mood-history-table th:nth-child(2),
.mood-history-table td:nth-child(2) {
  width: 18%;
  min-width: 120px;
}

.mood-history-table th:nth-child(3),
.mood-history-table td:nth-child(3) {
  width: auto;
  min-width: 220px;
}

.mood-history-table th:nth-child(4),
.mood-history-table td:nth-child(4) {
  width: 240px;
  min-width: 240px;
  text-align: right;
}

.mood-history-table th {
  background: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding: 1.0rem 1.2rem;
  font-family: var(--font-sans);
  font-weight: 600;
  color: var(--text-secondary);
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.mood-history-table td {
  padding: 1.0rem 1.2rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  color: var(--text-primary);
  line-height: 1.5;
  overflow: hidden;
  font-size: 0.95rem;
}

.mood-history-table tbody tr:last-child td {
  border-bottom: none;
}

.mood-history-table tbody tr {
  transition: background 0.2s;
}

.mood-history-table tbody tr:hover {
  background: rgba(255, 255, 255, 0.015);
}

.table-time {
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--text-muted);
  white-space: nowrap;
}

.table-mood-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.35rem 0.75rem;
  border-radius: 20px;
  font-size: 0.8rem;
  font-weight: 500;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.table-note-text {
  font-family: var(--font-serif);
  font-style: italic;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  color: rgba(255, 255, 255, 0.85);
  word-break: break-word;
  overflow-wrap: break-word;
  white-space: normal;
  font-size: 0.9rem;
}

.table-note-text.empty {
  color: var(--text-muted);
}

/* Premium Thumbnail Previews inside Private Vault Table (Doubled size) */
.table-artifact-thumbnail-container {
  width: 80px;
  height: 64px;
  aspect-ratio: 1000 / 800;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--glass-border);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
  background: #000;
  flex-shrink: 0;
  transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.25s ease;
  position: relative;
}

.table-artifact-thumbnail-container:hover {
  transform: scale(1.06);
  box-shadow: 0 8px 20px var(--glow-color, rgba(99, 102, 241, 0.35));
}

.table-artifact-thumbnail {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Premium Watercolor, Vignette & Kintsugi overlays with Blur Bloom animation */
@keyframes bloomIn {
  from {
    opacity: 0;
    transform: scale(0.97) rotate(-0.5deg);
    filter: blur(10px) sepia(0.3);
  }
  to {
    opacity: 1;
    transform: scale(1) rotate(0deg);
    filter: blur(0) sepia(0);
  }
}

.artifact-image-container img, 
.sheet-artifact-image-container img,
.modal-rendered-image,
.note-rendered-image,
.table-artifact-thumbnail {
  animation: bloomIn 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* Golden kintsugi radial overlay & vignette depth shading */
.artifact-image-container::after, 
.sheet-artifact-image-container::after,
.modal-image-container::after,
.note-image-container::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  background: radial-gradient(circle at 30% 20%, rgba(212, 175, 55, 0.12) 0%, transparent 45%),
              radial-gradient(circle at 80% 70%, rgba(212, 175, 55, 0.08) 0%, transparent 55%),
              linear-gradient(45deg, rgba(212, 175, 55, 0.04) 0%, transparent 70%);
  mix-blend-mode: color-dodge;
  box-shadow: inset 0 0 25px rgba(0, 0, 0, 0.65);
  z-index: 2;
  transition: opacity 0.3s ease;
}

/* Support Circle scroll viewport with customized glass scrollbar */
.circles-scroll-viewport {
  max-height: 220px;
  overflow-y: auto;
  padding-right: 6px;
  margin-top: 0.5rem;
}

.circles-scroll-viewport::-webkit-scrollbar {
  width: 6px;
}

.circles-scroll-viewport::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.02);
  border-radius: 3px;
}

.circles-scroll-viewport::-webkit-scrollbar-thumb {
  background: var(--accent-color, #6366f1);
  border-radius: 3px;
}

/* Responsive constraints to fit small display heights beautifully */
@media (max-height: 750px) {
  .mood-release-modal-card {
    max-height: 92vh;
    overflow-y: auto;
    padding: 1.5rem;
  }
  .circles-scroll-viewport {
    max-height: 130px;
  }
}

@media (max-width: 768px) {
  .mood-history-table th:nth-child(1),
  .mood-history-table td:nth-child(1) {
    width: 25%;
    min-width: 90px;
  }
  .mood-history-table th:nth-child(2),
  .mood-history-table td:nth-child(2) {
    width: 22%;
    min-width: 80px;
  }
  .mood-history-table th:nth-child(4),
  .mood-history-table td:nth-child(4) {
    width: auto;
    min-width: 220px; /* Expand to fit action buttons nicely on mobile viewports */
  }
  .mood-history-table td {
    padding: 0.75rem 0.5rem;
    font-size: 0.8rem;
  }
  .mood-history-table th {
    padding: 0.75rem 0.5rem;
    font-size: 0.7rem;
  }
  .table-artifact-thumbnail-container {
    width: 60px !important;
    height: 48px !important;
    border-radius: 6px !important;
  }
  .table-action-btn {
    padding: 0.3rem 0.5rem !important;
    font-size: 0.75rem !important;
    margin-bottom: 0.25rem !important;
    border-radius: 6px !important;
    display: inline-block !important;
  }
}

/* Premium Shared Letter Detail Modal Image Canvas style */
.modal-image-container {
  position: relative;
  width: 100%;
  max-height: 280px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--glass-border);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
  margin-bottom: 1.2rem;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-rendered-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Campfire Board Sticky Notes Image Canvas style */
.note-image-container {
  position: relative;
  width: 100%;
  height: 130px;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  margin-bottom: 0.75rem;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.note-rendered-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.table-action-btn {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  cursor: pointer;
  padding: 0.45rem 0.85rem;
  font-size: 0.8rem;
  border-radius: 8px;
  transition: all 0.2s ease-in-out;
  font-weight: 500;
}

.btn-table-sit {
  color: var(--accent-color, #6366f1);
}

.btn-table-sit:hover {
  background: rgba(99, 102, 241, 0.1);
  color: #fff;
}

.btn-table-release {
  color: #c9bcfd;
  margin-left: 0.3rem;
}

.btn-table-release:hover {
  background: rgba(162, 114, 248, 0.15);
  color: #fff;
}

.btn-table-delete {
  color: rgba(239, 68, 68, 0.7);
  margin-left: 0.3rem;
}

.btn-table-delete:hover {
  background: rgba(239, 68, 68, 0.1);
  color: #ef4444;
}

.btn-table-candle {
  color: rgba(251, 191, 36, 0.85);
  margin-left: 0.3rem;
}

.btn-table-candle:hover {
  background: rgba(251, 191, 36, 0.1);
  color: #fbbf24;
}

.table-empty-state {
  text-align: center;
  padding: 3rem 1rem !important;
  color: var(--text-muted);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.95rem;
}



/* ==========================================
   Archives of the Heart & Subscription Checkout
   ========================================== */

.archives-heart-section {
  width: 100%;
  background: var(--glass-bg); /* Translucent dark glass background */
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 2.2rem 1.8rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  box-shadow: var(--card-shadow);
  margin: 1.5rem 0;
  box-sizing: border-box;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}

.archive-icon-container {
  width: 48px;
  height: 48px;
  background: rgba(255, 255, 255, 0.03); /* Translucent icon tray */
  border: 1px solid var(--glass-border);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.2rem;
  color: var(--text-secondary);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.archive-icon-container svg {
  width: 22px;
  height: 22px;
  stroke: var(--text-secondary);
  stroke-width: 1.5;
}

.archive-title {
  font-family: var(--font-serif);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: 0.15em;
  margin: 0 0 0.6rem 0;
  text-transform: uppercase;
}

.archive-desc {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--text-muted);
  margin: 0 0 1.2rem 0;
  max-width: 320px;
}

.export-status-pill {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  color: #ffffff;
  background: var(--accent-color);
  padding: 0.25rem 0.85rem;
  border-radius: 50px;
  margin-bottom: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  box-shadow: 0 2px 6px rgba(99, 102, 241, 0.2);
  transition: all var(--transition-fast);
}

.export-status-pill.subscribed {
  box-shadow: 0 0 12px rgba(245, 158, 11, 0.3);
}

.export-format-select {
  background: rgba(255, 255, 255, 0.04) !important;
  color: var(--text-primary) !important;
  border: 1px solid var(--glass-border) !important;
}
.export-format-select:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  border-color: var(--accent-color) !important;
}
.export-format-select option {
  background: #111019 !important;
  color: #ffffff !important;
}
body.theme-light .export-format-select option {
  background: #ffffff !important;
  color: #1f241a !important;
}

.profile-export-pill-btn {
  background: rgba(255, 255, 255, 0.03); /* Glassmorphic pill button */
  color: var(--text-primary);
  border: 1px solid var(--glass-border);
  padding: 0.85rem 1.8rem;
  border-radius: 50px; /* Perfect rounded pill shape */
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.08em;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  box-sizing: border-box;
  transition: all var(--transition-fast);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.profile-export-pill-btn svg {
  stroke: currentColor;
  stroke-width: 2;
  transition: transform 0.25s ease;
}

.profile-export-pill-btn:hover {
  background: var(--accent-color); /* Turns vibrant purple/violet on hover */
  color: #0d0a15; /* High contrast dark text */
  border-color: var(--accent-color);
  box-shadow: 0 6px 15px var(--glow-color);
  transform: translateY(-1.5px);
}

.profile-export-pill-btn:hover svg {
  stroke: #0d0a15;
  transform: translateY(1.5px);
}

.profile-export-pill-btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}


/* ==========================================
   Emotional Archive & Keepsake Builder View
   ========================================== */

#view-archive {
  padding: 2.5rem;
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
  height: 100%;
  display: none; /* Controlled by switchView */
  flex-direction: column;
  gap: 3.5rem;
  box-sizing: border-box;
}

.archive-layout-wrapper {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  gap: 2rem;
}

#view-archive.active {
  display: flex !important;
}

.archive-view-header {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  text-align: left;
  border-bottom: 1px solid var(--glass-border);
  padding-bottom: 1.5rem;
}

.archive-back-btn {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.45rem 1rem;
  border-radius: 30px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  transition: all var(--transition-fast);
}

.archive-back-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-primary);
  border-color: var(--accent-color);
  transform: translateX(-2px);
}

.archive-view-title-block {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.archive-view-title {
  font-family: var(--font-serif);
  font-size: 1.85rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
  letter-spacing: -0.01em;
}

.archive-view-subtitle {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--text-muted);
  margin: 0;
  line-height: 1.5;
}

.archive-layout-container {
  display: flex;
  gap: 2rem;
  width: 100%;
  box-sizing: border-box;
  align-items: flex-start;
}

@media (max-width: 900px) {
  .archive-layout-container {
    flex-direction: column;
  }
  .archive-main-column, .archive-sidebar-column {
    width: 100% !important;
    max-width: none !important;
  }
}

.archive-main-column {
  flex: 2;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.archive-sidebar-column {
  flex: 1;
  max-width: 380px;
  position: sticky;
  top: 100px;
}

/* Filters row styling */
.archive-filters-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem;
  background: rgba(255, 255, 255, 0.01);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.2rem;
}

.archive-filter-group {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  text-align: left;
}

.archive-filter-group label {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
}

.archive-filter-select {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  border-radius: 8px;
  padding: 0.5rem 0.8rem;
  font-size: 0.8rem;
  font-family: var(--font-sans);
  outline: none;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.archive-filter-select:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: var(--accent-color);
}

.archive-filter-select option {
  background: #121019;
  color: #ffffff;
}

/* Controls above the cards grid */
.archive-grid-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px dashed var(--glass-border);
  padding-bottom: 0.8rem;
}

.archive-results-count {
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-secondary);
}

.archive-bulk-actions {
  display: flex;
  gap: 0.5rem;
}

.archive-btn-small {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 600;
  padding: 0.25rem 0.6rem;
  border-radius: 6px;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.archive-btn-small:hover {
  background: var(--accent-color);
  color: #0d0a15;
  border-color: var(--accent-color);
}

/* Cards Grid */
.archive-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1.2rem;
  max-height: 600px;
  overflow-y: auto;
  padding-right: 0.4rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.1) transparent;
}

.archive-cards-grid::-webkit-scrollbar {
  width: 6px;
}
.archive-cards-grid::-webkit-scrollbar-track {
  background: transparent;
}
.archive-cards-grid::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 3px;
}
.archive-cards-grid::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.25);
}

/* Individual Archive Card */
.archive-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  text-align: left;
  position: relative;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  user-select: none;
}

.archive-card:hover {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.15);
}

.archive-card.selected {
  border-color: var(--accent-color);
  box-shadow: 0 0 15px rgba(99, 102, 241, 0.2);
  background: rgba(99, 102, 241, 0.02);
}

.archive-card-checkbox {
  display: none !important;
}

.archive-card-header {
  display: flex;
  gap: 0.4rem;
  align-items: center;
  flex-wrap: wrap;
  padding-right: 4.8rem !important; /* Avoid overlap with Select button */
}

.archive-card-select-btn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 600;
  padding: 0.25rem 0.6rem;
  border-radius: 6px;
  cursor: pointer;
  transition: all var(--transition-fast);
  z-index: 5;
}

.archive-card-select-btn:hover,
.archive-card-select-btn.active {
  background: var(--accent-color);
  color: #0d0a15;
  border-color: var(--accent-color);
}

.archive-card-badge {
  font-family: var(--font-sans);
  font-size: 0.58rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  line-height: 1;
}

.archive-card-badge.badge-private {
  background: rgba(99, 102, 241, 0.15);
  color: #818cf8;
  border: 1px solid rgba(99, 102, 241, 0.3);
}

.archive-card-badge.badge-shared {
  background: rgba(16, 185, 129, 0.15);
  color: #34d399;
  border: 1px solid rgba(16, 185, 129, 0.3);
}

.archive-card-badge.badge-format {
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-secondary);
  border: 1px solid var(--glass-border);
}

.archive-card-title {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.archive-card-snippet {
  font-family: var(--font-sans);
  font-size: 0.8rem;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  min-height: 3.6rem;
}

.archive-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
  padding-top: 0.6rem;
  font-size: 0.72rem;
}

.archive-card-date {
  color: var(--text-muted);
}

.archive-card-mood {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  color: var(--text-secondary);
  font-weight: 500;
}

.archive-card-mood-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.archive-card-artwork {
  width: 100%;
  height: 100px;
  border-radius: 8px;
  object-fit: cover;
  margin-bottom: 0.2rem;
  border: 1px solid var(--glass-border);
}

.archive-empty-state {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 250px;
  border: 1px dashed var(--glass-border);
  border-radius: 16px;
  color: var(--text-muted);
  font-family: var(--font-serif);
  font-style: italic;
  gap: 0.5rem;
}

/* Sidebar Keepsake Builder Styling */
.keepsake-builder-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 1.8rem;
  box-shadow: var(--card-shadow);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  text-align: left;
}

.keepsake-card-title {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: var(--text-primary);
  margin: 0;
}

.keepsake-card-desc {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.82rem;
  color: var(--text-muted);
  line-height: 1.4;
  margin: 0;
}

.keepsake-input-group {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.keepsake-input-group label {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text-muted);
  letter-spacing: 0.5px;
}

.keepsake-text-input {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  border-radius: 8px;
  padding: 0.5rem 0.8rem;
  font-size: 0.82rem;
  font-family: var(--font-sans);
  outline: none;
  transition: all var(--transition-fast);
}

.keepsake-text-input:focus {
  border-color: var(--accent-color);
  box-shadow: 0 0 10px rgba(99, 102, 241, 0.15);
}

.keepsake-format-select {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  border-radius: 8px;
  padding: 0.5rem 0.8rem;
  font-size: 0.82rem;
  font-family: var(--font-sans);
  outline: none;
  cursor: pointer;
}

.keepsake-format-select option {
  background: #121019;
  color: #ffffff;
}

/* Export Mode Toggle Buttons */
.keepsake-mode-btn {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  text-align: center;
  transition: all var(--transition-fast);
}
.keepsake-mode-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
  color: var(--text-primary);
}
.keepsake-mode-btn.active {
  border-color: var(--accent-color);
  background: rgba(99, 102, 241, 0.08);
  color: var(--text-primary);
  box-shadow: 0 2px 8px rgba(99, 102, 241, 0.15);
}

body.theme-light .keepsake-mode-btn {
  background: #ffffff;
  border-color: rgba(0, 0, 0, 0.08);
  color: #4a5442;
}
body.theme-light .keepsake-mode-btn:hover {
  background: rgba(0, 0, 0, 0.02);
}
body.theme-light .keepsake-mode-btn.active {
  border-color: var(--accent-color);
  background: rgba(99, 102, 241, 0.05);
  color: var(--accent-color);
}

/* Themes Grid Selector */
.keepsake-themes-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem;
}

.keepsake-theme-btn {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  padding: 0.6rem;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  font-family: var(--font-sans);
  transition: all var(--transition-fast);
}

.keepsake-theme-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
}

.keepsake-theme-btn.active {
  border-color: var(--accent-color);
  background: rgba(99, 102, 241, 0.08);
  box-shadow: 0 2px 8px rgba(99, 102, 241, 0.15);
}

.keepsake-theme-btn .theme-icon {
  font-size: 1.25rem;
}

.keepsake-theme-btn .theme-label {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--text-secondary);
}

.keepsake-theme-btn.active .theme-label {
  color: var(--text-primary);
}

/* Live Preview Card styling */
.keepsake-preview-wrapper {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.keepsake-theme-preview {
  border-radius: 12px;
  padding: 1rem;
  font-size: 0.8rem;
  min-height: 120px;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
}

.preview-card-header {
  display: flex;
  justify-content: space-between;
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.preview-badge {
  font-weight: 700;
}

.preview-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
}

.preview-snippet {
  margin: 0;
  font-size: 0.72rem;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Status and Action Buttons inside Builder Card */
.keepsake-status-pill {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 600;
  color: #ffffff;
  background: var(--accent-color);
  padding: 0.25rem 0.65rem;
  border-radius: 50px;
  text-align: center;
  align-self: flex-start;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.keepsake-status-pill.subscribed {
  box-shadow: 0 0 8px rgba(245, 158, 11, 0.3);
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

.keepsake-progress-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  text-align: left;
}

.keepsake-progress-status {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--text-secondary);
}

.keepsake-progress-track {
  width: 100%;
  height: 4px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 20px;
  overflow: hidden;
}

.keepsake-progress-bar {
  height: 100%;
  background: var(--accent-color);
  border-radius: 20px;
  transition: width 0.3s ease;
}

.keepsake-export-btn {
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-primary);
  border: 1px solid var(--glass-border);
  padding: 0.75rem 1.2rem;
  border-radius: 30px;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.08em;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  box-sizing: border-box;
  transition: all var(--transition-fast);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.keepsake-export-btn:hover {
  background: var(--accent-color);
  color: #0d0a15;
  border-color: var(--accent-color);
  box-shadow: 0 6px 15px var(--glow-color);
  transform: translateY(-1.5px);
}

.keepsake-export-btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

/* ==========================================
   Artistic Keepsake Theme Implementations
   ========================================== */

/* 1. Vintage Letters Theme */
.keepsake-theme-preview.vintage {
  background: #f4edd8 !important;
  color: #3e2f18 !important;
  font-family: Georgia, serif !important;
  border: 1px solid #dcd1b3 !important;
  box-shadow: inset 0 0 20px #eadebe !important;
}
.keepsake-theme-preview.vintage .preview-badge {
  color: #7c6d50;
  border-bottom: 1px dashed #c0b298;
}
.keepsake-theme-preview.vintage .preview-date {
  color: #7c6d50;
}
.keepsake-theme-preview.vintage .preview-title {
  color: #2c1d0f;
}
.keepsake-theme-preview.vintage .preview-snippet {
  color: #5c4a30;
  font-style: italic;
}

/* 2. Rain-Stained Pages Theme */
.keepsake-theme-preview.rain {
  background: linear-gradient(135deg, #2b3a4a 0%, #1e2530 100%) !important;
  color: #e2e8f0 !important;
  font-family: 'Courier New', Courier, monospace !important;
  border: 1px solid #4a5d6e !important;
  box-shadow: inset 0 0 15px rgba(0,0,0,0.4) !important;
  background-image: radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px) !important;
  background-size: 10px 10px !important;
}
.keepsake-theme-preview.rain .preview-badge {
  color: #94a3b8;
  border: 1px solid rgba(255,255,255,0.15);
  padding: 0 4px;
}
.keepsake-theme-preview.rain .preview-date {
  color: #64748b;
}
.keepsake-theme-preview.rain .preview-title {
  color: #38bdf8;
  text-shadow: 0 0 8px rgba(56,189,248,0.2);
}
.keepsake-theme-preview.rain .preview-snippet {
  color: #cbd5e1;
}

/* 3. Burned Paper Theme */
.keepsake-theme-preview.burned {
  background: #0f0f0f !important;
  color: #ea580c !important;
  font-family: 'Cinzel', Georgia, serif !important;
  border: 1px solid #7c2d12 !important;
  box-shadow: inset 0 0 25px #3a160b, 0 0 8px rgba(234, 88, 12, 0.15) !important;
}
.keepsake-theme-preview.burned .preview-badge {
  color: #f97316;
  background: rgba(249, 115, 22, 0.08);
}
.keepsake-theme-preview.burned .preview-date {
  color: #7c2d12;
}
.keepsake-theme-preview.burned .preview-title {
  color: #f97316;
  text-shadow: 0 0 5px rgba(249, 115, 22, 0.3);
}
.keepsake-theme-preview.burned .preview-snippet {
  color: #c2410c;
}

/* 4. Floating Bottle Theme */
.keepsake-theme-preview.bottle {
  background: linear-gradient(135deg, #062227 0%, #031114 100%) !important;
  color: #2dd4bf !important;
  font-family: 'Outfit', sans-serif !important;
  border: 1px solid #14b8a6 !important;
  box-shadow: inset 0 0 15px rgba(20, 184, 166, 0.15) !important;
}
.keepsake-theme-preview.bottle .preview-badge {
  color: #0d9488;
}
.keepsake-theme-preview.bottle .preview-date {
  color: #115e59;
}
.keepsake-theme-preview.bottle .preview-title {
  color: #5eead4;
}
.keepsake-theme-preview.bottle .preview-snippet {
  color: #0f766e;
}

/* Light Theme overrides for Archive view */
body.theme-light #view-archive {
  background: transparent;
}
body.theme-light .archive-filters-row {
  background: rgba(0, 0, 0, 0.02);
  border-color: rgba(0, 0, 0, 0.08);
}
body.theme-light .archive-filter-select {
  background: #ffffff;
  border-color: rgba(0, 0, 0, 0.1);
  color: #1f241a;
}
body.theme-light .archive-filter-select option {
  background: #ffffff;
  color: #1f241a;
}
body.theme-light .archive-btn-small {
  background: rgba(0, 0, 0, 0.02);
  border-color: rgba(0, 0, 0, 0.08);
  color: #4a5442;
}
body.theme-light .archive-btn-small:hover {
  background: var(--accent-color);
  color: #ffffff;
  border-color: var(--accent-color);
}
body.theme-light .keepsake-text-input {
  background: #ffffff;
  border-color: rgba(0, 0, 0, 0.1);
  color: #1f241a;
}
body.theme-light .keepsake-format-select {
  background: #ffffff;
  border-color: rgba(0, 0, 0, 0.1);
  color: #1f241a;
}
body.theme-light .keepsake-format-select option {
  background: #ffffff;
  color: #1f241a;
}
body.theme-light .keepsake-theme-btn {
  background: #ffffff;
  border-color: rgba(0, 0, 0, 0.08);
}
body.theme-light .keepsake-theme-btn:hover {
  background: rgba(0, 0, 0, 0.02);
}
body.theme-light .keepsake-theme-btn.active {
  border-color: var(--accent-color);
  background: rgba(99, 102, 241, 0.05);
}
body.theme-light .keepsake-export-btn {
  background: #ffffff;
  border-color: rgba(0, 0, 0, 0.1);
  color: #1f241a;
}
body.theme-light .keepsake-export-btn:hover {
  background: var(--accent-color);
  color: #ffffff;
  border-color: var(--accent-color);
}

/* Compilation Progress Tracking Aesthetics */
.export-progress-container {
  width: 100%;
  margin-bottom: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  text-align: left;
  box-sizing: border-box;
}

.export-progress-status {
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--text-secondary);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.compilation-progress-track {
  width: 100%;
  height: 5px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  box-sizing: border-box;
}

.compilation-progress-bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--accent-color), #a78bfa);
  border-radius: 20px;
  box-shadow: 0 0 10px var(--glow-color);
  transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.compilation-preview-box {
  background: rgba(0, 0, 0, 0.25);
  border-left: 2px solid var(--accent-color);
  padding: 0.6rem 1rem;
  border-radius: 4px;
  font-size: 0.78rem;
  font-family: var(--font-serif);
  color: var(--text-muted);
  line-height: 1.5;
  font-style: italic;
  margin-top: 0.2rem;
  box-sizing: border-box;
  box-shadow: inset 0 2px 5px rgba(0, 0, 0, 0.3);
  text-align: left;
}

.compilation-preview-box .preview-label {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--accent-color);
  margin-right: 0.4rem;
  font-style: normal;
  display: inline-block;
}

.compilation-preview-box .preview-text {
  word-break: break-all;
  white-space: pre-wrap;
}

/* Subscription Overlay styling (Fixed Fullscreen Backdrop) */
.subscription-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(3, 2, 7, 0.7);
  backdrop-filter: blur(25px);
  z-index: 2000; /* Ensure it overlays everything including other modals */
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity var(--transition-medium), visibility var(--transition-medium);
}

.subscription-overlay.active {
  opacity: 1;
  pointer-events: all;
  visibility: visible;
}

/* Subscription Centered Modal Card */
.subscription-modal-card {
  position: relative;
  width: 100%;
  max-width: 450px;
  max-height: 85vh;
  background: rgba(15, 12, 23, 0.75);
  border: 1px solid var(--glass-border);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.85), 0 0 40px var(--glow-color);
  padding: 3rem 2.5rem;
  border-radius: 24px;
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  box-sizing: border-box;
  transform: scale(0.92) translateY(15px);
  transition: transform var(--transition-medium), opacity var(--transition-medium);
}

.subscription-overlay.active .subscription-modal-card {
  transform: scale(1) translateY(0);
}

/* Custom scrollbar for checkout card */
.subscription-modal-card::-webkit-scrollbar {
  width: 6px;
}

.subscription-modal-card::-webkit-scrollbar-track {
  background: transparent;
}

.subscription-modal-card::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 3px;
}

.subscription-modal-card::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.25);
}

/* Close button on overlay */
.sub-overlay-close {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  background: transparent;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0.25rem;
  transition: color var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5;
}

.sub-overlay-close svg {
  width: 20px;
  height: 20px;
}

.sub-overlay-close:hover {
  color: var(--text-primary);
}

/* Glassmorphic Custom Alert Modal Overlay & Card styling */
.alert-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(3, 2, 7, 0.7);
  backdrop-filter: blur(25px);
  z-index: 3000; /* High z-index to overlay everything else */
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity var(--transition-medium), visibility var(--transition-medium);
}

.alert-modal-overlay.active {
  opacity: 1;
  pointer-events: all;
  visibility: visible;
}

.alert-modal-card {
  position: relative;
  width: 100%;
  max-width: 420px;
  background: rgba(15, 12, 23, 0.75);
  border: 1px solid var(--glass-border);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.85), 0 0 35px var(--glow-color);
  padding: 3rem 2.5rem 2.5rem 2.5rem;
  border-radius: 24px;
  text-align: center;
  transform: scale(0.92) translateY(15px);
  transition: transform var(--transition-medium), opacity var(--transition-medium);
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  box-sizing: border-box;
}

.alert-modal-overlay.active .alert-modal-card {
  transform: scale(1) translateY(0);
}

.alert-modal-header {
  margin-bottom: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.8rem;
}

.alert-icon-glow {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.5rem;
  box-shadow: 0 0 20px rgba(255, 255, 255, 0.05);
}

.alert-emoji {
  font-size: 1.6rem;
}

.alert-modal-header h3 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: 1px;
  color: var(--text-primary);
  margin: 0;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.1);
}

.alert-modal-header p {
  font-size: 0.84rem;
  color: var(--text-secondary);
  line-height: 1.6;
  margin: 0;
}

.alert-modal-actions {
  display: flex;
  justify-content: center;
}

/* Alert Ok Button */
.alert-ok-btn {
  background: var(--accent-color);
  color: #0d0a15;
  border: 1px solid var(--accent-color);
  padding: 0.65rem 2.5rem;
  border-radius: 30px;
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.05em;
  transition: all var(--transition-fast);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.alert-ok-btn:hover {
  background: transparent;
  color: var(--text-primary);
  border-color: var(--glass-border);
  box-shadow: 0 0 15px var(--glow-color);
}

.sub-header {
  text-align: center;
  margin-bottom: 1.8rem;
  margin-top: 1rem;
}

.sub-header h4 {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: 1.5px;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
  background: linear-gradient(to bottom, #ffffff, #c7d2fe);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.sub-header p {
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.5;
  max-width: 320px;
  margin: 0 auto;
}

/* Tiers Container */
.sub-tiers-container {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.8rem;
}

/* Individual card styling */
.sub-tier-card {
  display: flex;
  flex-direction: column;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  padding: 1.2rem;
  border-radius: 14px;
  cursor: pointer;
  position: relative;
  transition: all var(--transition-fast);
  text-align: left;
}

.sub-tier-card .sub-tier-radio {
  position: absolute;
  top: 1.2rem;
  right: 1.2rem;
  accent-color: var(--accent-color);
  cursor: pointer;
}

.sub-tier-info {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 0.4rem;
  padding-right: 2rem; /* Avoid radio button overlap */
}

.sub-tier-name {
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
}

.sub-tier-price {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--accent-color);
}

.sub-tier-price span {
  font-size: 0.72rem;
  color: var(--text-muted);
  font-family: var(--font-sans);
  font-weight: 400;
}

.sub-tier-desc {
  font-size: 0.78rem !important;
  color: var(--text-muted) !important;
  line-height: 1.4 !important;
  margin: 0 !important;
  text-align: left !important;
}

/* Selected state of tier card */
.sub-tier-card.selected {
  background: rgba(99, 102, 241, 0.08);
  border-color: var(--accent-color);
  box-shadow: 0 0 15px rgba(99, 102, 241, 0.15);
}

.sub-tier-card:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.12);
}

.sub-tier-card.selected:hover {
  background: rgba(99, 102, 241, 0.12);
  border-color: var(--accent-color);
}

/* Payment Form inputs */
.sub-form-group {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin-bottom: 1rem;
  text-align: left;
}

.sub-form-group label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  font-weight: 500;
}

.sub-input-wrapper {
  position: relative;
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  padding: 0.65rem 0.85rem;
  transition: all var(--transition-fast);
}

.sub-input-wrapper:focus-within {
  border-color: var(--accent-color);
  box-shadow: 0 0 8px var(--glow-color);
}

.sub-payment-input {
  background: transparent;
  border: none;
  outline: none;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.85rem;
  width: 100%;
  box-sizing: border-box;
}

.sub-payment-input::placeholder {
  color: var(--text-muted);
  opacity: 0.5;
}

.sub-input-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

/* Error message */
.sub-error-msg {
  color: #f87171 !important;
  font-size: 0.78rem !important;
  min-height: 18px;
  margin-bottom: 1rem !important;
  text-align: center !important;
  display: none;
}

.sub-error-msg.visible {
  display: block;
}

/* Purchase button loading animation */
@keyframes loading-fade {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 1; }
}

.purchase-loading-dots {
  animation: loading-fade 1.5s infinite;
  letter-spacing: 0.5px;
}

/* Purchase button */
.sub-submit-btn {
  background: var(--accent-color);
  color: #0d0a15;
  border: none;
  padding: 0.9rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.5px;
  width: 100%;
  transition: all var(--transition-fast);
  margin-top: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sub-submit-btn:hover {
  background: var(--text-primary);
  box-shadow: 0 0 15px rgba(255, 255, 255, 0.2);
  transform: translateY(-1.5px);
}

.sub-submit-btn:active {
  transform: translateY(0);
}

.sub-submit-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* ==========================================
   MULTI-GATEWAY PAYMENT INTERFACES STYLE
   ========================================== */

.sub-payment-methods {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin: 1.5rem 0 1.2rem 0;
  text-align: left;
}

.sub-pm-title {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  font-weight: 600;
}

.sub-pm-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.8rem;
}

.sub-pm-btn {
  background: rgba(255, 255, 255, 0.01);
  border: 1px solid var(--glass-border);
  padding: 0.7rem 0.9rem;
  border-radius: 10px;
  color: var(--text-secondary);
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
}

.sub-pm-btn:hover {
  background: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.12);
  color: var(--text-primary);
}

.sub-pm-btn.active {
  background: rgba(99, 102, 241, 0.06);
  border-color: var(--accent-color);
  color: var(--text-primary);
  box-shadow: 0 0 12px rgba(99, 102, 241, 0.15);
}

.sub-pm-btn .pm-icon {
  flex-shrink: 0;
  transition: transform var(--transition-fast);
}

.sub-pm-btn:hover .pm-icon {
  transform: scale(1.05);
}

.sub-form-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.2rem;
}

.card-networks-container {
  display: flex;
  gap: 0.35rem;
  align-items: center;
}

.network-logo {
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 3px;
  background: #090a10;
  padding: 1px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
}

/* PayPal Glass Block */
.paypal-info-box {
  background: rgba(255, 255, 255, 0.01);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 1.2rem;
  margin-bottom: 1.2rem;
  text-align: left;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  animation: fadeIn var(--transition-fast) forwards;
}

.paypal-logo-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: rgba(59, 130, 246, 0.12);
  border: 1px solid rgba(59, 130, 246, 0.22);
  color: #3b82f6;
  padding: 0.3rem 0.65rem;
  border-radius: 20px;
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 700;
  margin-bottom: 0.65rem;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.paypal-instructions {
  font-size: 0.78rem !important;
  color: var(--text-muted) !important;
  line-height: 1.45 !important;
  margin: 0 0 1rem 0 !important;
}

/* Transition Section In */
.payment-fields-section {
  width: 100%;
  animation: fadeIn var(--transition-fast) forwards;
}

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

/* Subscription Buttons and Cancellation Styling */
.sub-btn-group {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 0.8rem;
  margin-top: 0.8rem;
  width: 100%;
}

.sub-submit-btn {
  margin-top: 0 !important; /* Overrides previous top margin to align with grid */
}

.sub-cancel-btn {
  background: rgba(255, 255, 255, 0.02);
  color: var(--text-secondary);
  border: 1px solid var(--glass-border);
  padding: 0.9rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  letter-spacing: 0.5px;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}

.sub-cancel-btn:hover {
  background: rgba(239, 68, 68, 0.06);
  border-color: rgba(239, 68, 68, 0.35);
  color: #ef4444;
  box-shadow: 0 0 12px rgba(239, 68, 68, 0.15);
  transform: translateY(-1.5px);
}

.sub-cancel-btn:active {
  transform: translateY(0);
}

.profile-cancel-sub-btn {
  background: rgba(239, 68, 68, 0.04);
  color: rgba(239, 68, 68, 0.85);
  border: 1px solid rgba(239, 68, 68, 0.18);
  padding: 0.5rem 1.2rem;
  border-radius: 50px;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.05em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0.5rem auto 1rem auto;
  box-sizing: border-box;
  transition: all var(--transition-fast);
  text-transform: uppercase;
  max-width: fit-content;
}

.profile-cancel-sub-btn:hover {
  background: rgba(239, 68, 68, 0.12);
  color: #fca5a5;
  border-color: rgba(239, 68, 68, 0.35);
  box-shadow: 0 0 10px rgba(239, 68, 68, 0.15);
  transform: translateY(-1.5px);
}

.profile-cancel-sub-btn:active {
  transform: translateY(0);
}

/* ==========================================
   JOURNAL WRITING STATIONERY TEMPLATES
   ========================================== */

.paper-sheet:not(.format-journal) .journal-templates-container {
  display: none !important;
}

.journal-templates-container {
  margin: 0.5rem 0 0.8rem 0;
  padding: 0.4rem 0.8rem;
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid rgba(255, 255, 255, 0.03);
  border-radius: 10px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.01), 0 4px 15px rgba(0, 0, 0, 0.2);
  animation: fadeIn var(--transition-fast) ease-out;
  position: relative;
  z-index: 10;
}

.templates-label {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: 0.4rem;
}

.templates-scroll-row {
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  padding-bottom: 0.3rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.08) transparent;
}

.templates-scroll-row::-webkit-scrollbar {
  height: 4px;
}

.templates-scroll-row::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.08);
  border-radius: 10px;
}

.template-pill {
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid rgba(255, 255, 255, 0.04);
  padding: 0.32rem 0.75rem;
  border-radius: 15px;
  color: var(--text-secondary);
  font-family: var(--font-sans);
  font-size: 0.72rem;
  white-space: nowrap;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.template-pill:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
  color: var(--text-primary);
  transform: translateY(-1px);
}

.template-pill.active {
  background: var(--accent-color);
  border-color: var(--accent-color);
  color: #0b0711 !important;
  font-weight: 600;
  box-shadow: 0 0 12px var(--glow-color);
}

/* ==========================================
   LETTER WRITING TEMPLATES FOR THE UNSAID
   ========================================== */

.paper-sheet:not(.format-letter) .letter-templates-container {
  display: none !important;
}

.letter-templates-container {
  margin: 0.8rem 0 1.2rem 0;
  padding: 0.6rem 1rem;
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid rgba(255, 255, 255, 0.03);
  border-radius: 12px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.01), 0 4px 15px rgba(0, 0, 0, 0.2);
  animation: fadeIn var(--transition-fast) ease-out;
  position: relative;
  z-index: 10;
}

.letter-categories-row {
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  padding-bottom: 0.5rem;
  margin-bottom: 0.75rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.08) transparent;
}

.letter-categories-row::-webkit-scrollbar {
  height: 3px;
}

.letter-categories-row::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.08);
  border-radius: 10px;
}

.category-tab {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.04);
  padding: 0.35rem 0.75rem;
  border-radius: 6px;
  color: var(--text-muted);
  font-family: var(--font-sans);
  font-size: 0.72rem;
  white-space: nowrap;
  cursor: pointer;
  transition: all var(--transition-fast);
  position: relative;
}

.category-tab:hover {
  background: rgba(255, 255, 255, 0.025);
  border-color: rgba(255, 255, 255, 0.08);
  color: var(--text-secondary);
}

.category-tab.active {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.15);
  color: var(--text-primary);
  font-weight: 500;
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.05), 0 0 8px rgba(255, 255, 255, 0.03);
}

.category-tab.active::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 15%;
  right: 15%;
  height: 1.5px;
  background: var(--accent-color);
  box-shadow: 0 0 4px var(--accent-color);
  border-radius: 1px;
}

.letter-templates-row {
  margin-top: 0.25rem;
}

/* ==========================================
   POETRY WRITING TEMPLATES WITH GEMINI AI
   ========================================== */

.paper-sheet:not(.format-poem) .poetry-templates-container {
  display: none !important;
}

.poetry-templates-container {
  margin: 0.8rem 0 1.2rem 0;
  padding: 0.6rem 1rem;
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid rgba(255, 255, 255, 0.03);
  border-radius: 12px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.01), 0 4px 15px rgba(0, 0, 0, 0.2);
  animation: fadeIn var(--transition-fast) ease-out;
  position: relative;
  z-index: 10;
}

/* Premium AI Poetry buttons with shimmering violet/purple gradient, glow shadow, and elegant hover animations */
.template-pill.forge-ai-template {
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.15) 0%, rgba(167, 139, 250, 0.08) 100%);
  border: 1px solid rgba(139, 92, 246, 0.25);
  box-shadow: 0 0 4px rgba(139, 92, 246, 0.1);
  color: #c4b5fd; /* Soft light violet */
  position: relative;
  overflow: hidden;
}

.template-pill.forge-ai-template::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(
    120deg,
    transparent,
    rgba(255, 255, 255, 0.15),
    transparent
  );
  transform: skewX(-25deg);
  transition: left 0.6s ease;
}

.template-pill.forge-ai-template:hover::before {
  left: 150%;
  transition: left 0.6s ease;
}

.template-pill.forge-ai-template:hover {
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.25) 0%, rgba(167, 139, 250, 0.15) 100%);
  border-color: rgba(139, 92, 246, 0.4);
  box-shadow: 0 0 10px rgba(139, 92, 246, 0.25);
  color: #e9d5ff; /* Shimmer white-purple */
}

.template-pill.forge-ai-template.active {
  background: linear-gradient(135deg, #8b5cf6 0%, #a78bfa 100%) !important;
  border-color: #a78bfa !important;
  color: #0b0711 !important;
  font-weight: 600;
  box-shadow: 0 0 16px rgba(139, 92, 246, 0.6) !important;
}


/* ==========================================================================
   UNIVERSAL EDIT / DELETE INTERACTION STYLES (WRITER'S SALON REFAC)
   ========================================================================== */

/* Inline Edit Modal Inputs */
.edit-modal-title {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  color: var(--text-primary);
  font-family: var(--font-serif);
  font-size: 1.4rem;
  padding: 0.6rem 1rem;
  margin: 1.5rem 2rem 0.5rem 2rem;
  width: calc(100% - 4rem);
  box-sizing: border-box;
  outline: none;
  transition: border-color var(--transition-fast);
}
.edit-modal-title:focus {
  border-color: var(--accent-color);
  box-shadow: 0 0 8px var(--glow-color);
}

.edit-modal-body {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  color: var(--text-primary);
  font-family: var(--font-serif);
  font-size: 1.15rem;
  line-height: 2rem;
  padding: 1rem 1.5rem;
  margin: 0.5rem 2rem 1.5rem 2rem;
  width: calc(100% - 4rem);
  height: 250px;
  box-sizing: border-box;
  resize: none;
  outline: none;
  transition: border-color var(--transition-fast);
}
.edit-modal-body:focus {
  border-color: var(--accent-color);
  box-shadow: 0 0 8px var(--glow-color);
}

/* Author Actions Wrapper and Buttons */
.author-actions-wrapper {
  display: flex;
  gap: 0.75rem;
  padding: 0 2rem 1.5rem 2rem;
  justify-content: flex-end;
  border-bottom: 1px solid var(--glass-border);
}

.author-btn {
  padding: 0.5rem 1rem;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  transition: all var(--transition-medium);
}

.author-btn.btn-edit-letter {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
}
.author-btn.btn-edit-letter:hover {
  border-color: var(--accent-color);
  box-shadow: 0 0 10px var(--glow-color);
}

.author-btn.btn-delete-letter {
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.2);
  color: #f87171;
}
.author-btn.btn-delete-letter:hover {
  background: rgba(239, 68, 68, 0.2);
  border-color: rgba(239, 68, 68, 0.4);
}

.author-btn.btn-save-edit {
  background: var(--accent-color);
  border: none;
  color: #0a0810;
}
.author-btn.btn-save-edit:hover {
  box-shadow: 0 0 10px var(--glow-bright);
}

.author-btn.btn-cancel-edit {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
}
.author-btn.btn-cancel-edit:hover {
  color: var(--text-primary);
}

/* User-owned Sticky Notes Hover Actions */
.sticky-note.user-owned {
  position: relative;
}

.note-actions {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  display: flex;
  gap: 0.4rem;
  opacity: 0;
  transition: opacity var(--transition-fast);
  z-index: 10;
}

.sticky-note.user-owned:hover .note-actions {
  opacity: 1;
}

.note-action-btn {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(10, 8, 16, 0.85);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.75rem;
  transition: all var(--transition-fast);
}

.note-action-btn:hover {
  background: #ffffff;
  color: #0a0810;
  border-color: #ffffff;
}

.note-action-btn.btn-delete-note:hover {
  background: #ef4444;
  color: #ffffff;
  border-color: #ef4444;
}

/* Sticky Note Inline Textarea and Buttons (Editing mode) */
.edit-note-textarea {
  width: 100%;
  height: 100px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  color: var(--text-primary);
  font-family: var(--font-serif);
  font-size: 0.95rem;
  padding: 0.5rem;
  box-sizing: border-box;
  resize: none;
  outline: none;
  margin-bottom: 0.5rem;
}
.edit-note-textarea:focus {
  border-color: var(--accent-color);
}

.edit-note-actions {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
}

.edit-note-btn {
  padding: 0.3rem 0.75rem;
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  border: none;
  transition: all var(--transition-fast);
}

.edit-note-btn.btn-save-note {
  background: var(--accent-color);
  color: #0a0810;
}


/* ==========================================================================
   VISUAL STATIONERY JOURNAL DESIGN SYSTEM
   ========================================================================== */

/* Show/Hide Toggling based on Active format class */
.paper-sheet.format-journal .letter-title,
.paper-sheet.format-journal .letter-body {
  display: none !important;
}

.paper-sheet:not(.format-journal) .journal-templates-container,
.paper-sheet:not(.format-journal) .journal-visual-sheet {
  display: none !important;
}
/* Custom Paper Skins on Paper Sheet */
.paper-sheet {
  --journal-paper-bg: #ffe3e3;
  --journal-paper-color: #5a2e2e;
  --journal-paper-accent: #f87b72;
  --journal-paper-border: rgba(248, 123, 114, 0.18);
  --journal-paper-focus: rgba(248, 123, 114, 0.4);
}

.paper-sheet.skin-watercolor-blush {
  --journal-paper-bg: #ffe3e3;
  --journal-paper-color: #5a2e2e;
  --journal-paper-accent: #f87b72;
  --journal-paper-border: rgba(248, 123, 114, 0.2);
  --journal-paper-focus: rgba(248, 123, 114, 0.45);
  background: radial-gradient(circle at center, #fff0f0 0%, #ffe3e3 100%) !important;
  box-shadow: 0 20px 50px rgba(248, 123, 114, 0.15) !important;
}

.paper-sheet.skin-parchment-sand {
  --journal-paper-bg: #f4edd8;
  --journal-paper-color: #3e2f18;
  --journal-paper-accent: #a88d60;
  --journal-paper-border: rgba(168, 141, 96, 0.22);
  --journal-paper-focus: rgba(168, 141, 96, 0.45);
  background: #f4edd8 !important;
  box-shadow: 0 20px 50px rgba(168, 141, 96, 0.15) !important;
}

.paper-sheet.skin-porcelain-cream {
  --journal-paper-bg: #fafafa;
  --journal-paper-color: #2c3e50;
  --journal-paper-accent: #8e9aaf;
  --journal-paper-border: rgba(142, 154, 175, 0.22);
  --journal-paper-focus: rgba(142, 154, 175, 0.45);
  background: #fafafa !important;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.08) !important;
}

.paper-sheet.skin-starry-cosmic {
  --journal-paper-bg: #0a0b16;
  --journal-paper-color: #e2e8f0;
  --journal-paper-accent: #9f9fed;
  --journal-paper-border: rgba(159, 159, 237, 0.2);
  --journal-paper-focus: rgba(159, 159, 237, 0.45);
  background: radial-gradient(circle at 30% 20%, #161730 0%, #0a0b16 100%) !important;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5) !important;
}

.paper-sheet.skin-classic-grid {
  --journal-paper-bg: #fdfdfd;
  --journal-paper-color: #2f3640;
  --journal-paper-accent: #718093;
  --journal-paper-border: rgba(113, 128, 147, 0.2);
  --journal-paper-focus: rgba(113, 128, 147, 0.45);
  background: #fdfdfd !important;
  background-image: radial-gradient(rgba(113, 128, 147, 0.15) 1px, transparent 1px) !important;
  background-size: 20px 20px !important;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.08) !important;
}

.journal-design-palette {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  padding: 0.8rem 1.2rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  margin-bottom: 1.2rem;
  position: relative;
  z-index: 10;
  box-sizing: border-box;
}

.palette-section {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.palette-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-secondary);
}

.palette-options {
  display: flex;
  gap: 0.4rem;
}

.palette-btn {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  padding: 0;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.1);
  background-color: transparent;
}

.palette-btn:hover {
  transform: scale(1.15);
}

.palette-btn.active {
  border-color: var(--accent-color);
  box-shadow: 0 0 10px var(--accent-color);
  transform: scale(1.1);
}

.palette-btn.accent-btn {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.15);
}
.palette-btn.accent-btn.active {
  background: rgba(255, 255, 255, 0.15);
  border: 2px solid var(--accent-color);
}

/* Art Accents SVG Overlays */
.journal-art-accents {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
  overflow: hidden;
  border-radius: inherit;
}

.journal-art-accents .accent-svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity var(--transition-medium) ease;
}

.paper-sheet.accent-botanical .accent-botanical-svg { opacity: 0.15; }
.paper-sheet.accent-roses .accent-roses-svg { opacity: 0.22; }
.paper-sheet.accent-butterfly .accent-butterfly-svg { opacity: 0.25; }
.paper-sheet.accent-kintsugi .accent-kintsugi-svg { opacity: 0.38; }

/* Interactive Journal Visual Sheet Layout */
.journal-visual-sheet {
  width: 100%;
  min-height: 480px;
  background: transparent;
  color: var(--journal-paper-color);
  z-index: 3;
  position: relative;
  box-sizing: border-box;
}

.journal-template-view {
  width: 100%;
  animation: fadeIn var(--transition-medium) ease-in-out;
}

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

/* Common form inputs & textareas inside stationery */
.journal-visual-sheet input[type="text"],
.journal-visual-sheet textarea {
  border: none;
  border-bottom: 1px solid var(--journal-paper-border);
  background: transparent;
  color: var(--journal-paper-color);
  font-family: inherit;
  outline: none;
  transition: border-color var(--transition-fast), background-color var(--transition-fast);
  padding: 0.2rem 0.4rem;
  box-sizing: border-box;
}
/* Ensure inputs inside stationery are fully responsive and scale to container */
.journal-visual-sheet input[type="text"]:not(.journal-date-input),
.journal-visual-sheet textarea {
  width: 100%;
}

.journal-visual-sheet input[type="text"]:focus,
.journal-visual-sheet textarea:focus {
  border-bottom-color: var(--journal-paper-accent);
  background: rgba(255, 255, 255, 0.05);
}

.journal-visual-sheet textarea {
  resize: vertical;
}

/* Rule lined textareas pattern backgrounds */
.classic-ruled-textarea,
.botanical-ruled-textarea,
.blossom-ruled-textarea {
  width: 100%;
  line-height: 2.2rem !important;
  font-size: 1.15rem;
  font-family: var(--font-hand), 'Dancing Script', cursive !important;
  background-image: linear-gradient(transparent, transparent calc(2.2rem - 1px), var(--journal-paper-border) calc(2.2rem - 1px)) !important;
  background-size: 100% 2.2rem !important;
  border: none !important;
  padding: 0.4rem 0.8rem !important;
  box-sizing: border-box;
  resize: none !important;
  min-height: 400px;
}

/* Cursive title header styles */
.journal-cursive-title {
  font-family: var(--font-hand), 'Dancing Script', cursive !important;
  font-size: 2.2rem !important;
  font-weight: 500;
  width: 60%;
  border-bottom: 1px solid var(--journal-paper-border) !important;
  padding: 0.3rem !important;
  color: var(--journal-paper-color);
}

.journal-date-input {
  font-family: var(--font-serif), serif;
  font-size: 0.95rem;
  width: 130px;
  text-align: right;
  border-bottom: 1px solid var(--journal-paper-border) !important;
}

/* Template 1: Classic Free-Write styles */
.classic-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 1.5rem;
}

.classic-date-container {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-serif), serif;
  font-size: 0.95rem;
  color: var(--journal-paper-color);
  opacity: 0.85;
}

/* Template 2: Self-Care Wellness Tracker Grid */
.selfcare-grid {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  width: 100%;
}

.selfcare-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 2px solid var(--journal-paper-border);
  padding-bottom: 0.8rem;
  margin-bottom: 0.4rem;
}

.selfcare-title {
  font-size: 2rem;
  margin: 0;
  color: var(--journal-paper-accent);
}

.selfcare-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.5rem;
}

.selfcare-date {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.9rem;
}

.selfcare-days {
  display: flex;
  gap: 0.3rem;
}

.day-circle {
  width: 25px;
  height: 25px;
  border-radius: 50%;
  border: 1px solid var(--journal-paper-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--transition-fast) cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.day-circle:hover {
  transform: scale(1.15);
  border-color: var(--journal-paper-accent);
}

.day-circle.active {
  background: var(--journal-paper-accent);
  color: var(--journal-paper-bg);
  border-color: var(--journal-paper-accent);
  box-shadow: 0 3px 8px var(--journal-paper-border);
  transform: scale(1.1);
}

/* Selfcare Row Layout */
.selfcare-row-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
}

@media (max-width: 768px) {
  .selfcare-row-split {
    grid-template-columns: 1fr;
  }
}

.selfcare-box {
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid var(--journal-paper-border);
  border-radius: 12px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  box-sizing: border-box;
}

.box-title {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--journal-paper-accent);
  opacity: 0.9;
}

.selfcare-box .bullet-lines {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.bullet-line {
  display: flex;
  align-items: center;
  font-family: var(--font-serif);
  font-size: 0.95rem;
  gap: 0.4rem;
}

.selfcare-line-input {
  flex-grow: 1;
  font-size: 0.95rem;
}

.selfcare-textarea {
  width: 100%;
  flex-grow: 1;
  height: 80px;
  font-size: 0.95rem;
  line-height: 1.4rem;
  border: none !important;
  border-bottom: 1px solid var(--journal-paper-border) !important;
  padding: 0.2rem !important;
}

/* Water Droplets */
.water-droplets {
  display: flex;
  gap: 0.6rem;
  justify-content: space-between;
  padding: 0.3rem 0;
}

.droplet {
  font-size: 1.5rem;
  cursor: pointer;
  filter: grayscale(1) opacity(0.25);
  transition: all var(--transition-fast) cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.droplet:hover {
  transform: scale(1.25);
  filter: grayscale(0.5) opacity(0.7);
}

.droplet.active {
  filter: grayscale(0) opacity(1);
  transform: scale(1.15);
  text-shadow: 0 0 10px rgba(54, 162, 235, 0.5);
  animation: dropletSplash 0.4s ease;
}

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

.water-progress-label {
  font-size: 0.75rem;
  text-align: right;
  opacity: 0.8;
  font-family: var(--font-sans);
}

/* Mood Smileys */
.mood-smileys {
  display: flex;
  justify-content: space-between;
  padding: 0.3rem 0;
}

.mood-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
  font-size: 1.5rem;
  background: transparent;
  border: none;
  cursor: pointer;
  filter: grayscale(0.8) opacity(0.4);
  transition: all var(--transition-fast);
  padding: 0;
}

.mood-btn:hover {
  filter: grayscale(0.3) opacity(0.8);
  transform: scale(1.2);
}

.mood-btn.active {
  filter: grayscale(0) opacity(1);
  transform: scale(1.1);
  text-shadow: 0 0 8px rgba(255, 165, 0, 0.4);
}

.mood-label-small {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--journal-paper-color);
  opacity: 0.6;
}

.mood-btn.active .mood-label-small {
  opacity: 1;
  color: var(--journal-paper-accent);
}

/* ==========================================================================
   CREATIVE GUIDED JOURNALING TEMPLATES (9 PREMIUM EMOTIONAL JOURNALS)
   ========================================================================== */

/* Common Header Layout for Journal Templates */
.blank-header,
.bottle-header,
.burn-header,
.mirror-header,
.rain-header,
.obituary-header,
.museum-header,
.moon-header,
.train-header,
.things-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  border-bottom: 2px dashed var(--journal-paper-border);
  padding-bottom: 0.8rem;
  margin-bottom: 1.5rem;
}

.bottle-title,
.burn-title,
.mirror-title,
.rain-title,
.obituary-title,
.museum-title,
.moon-title,
.train-title,
.things-title {
  font-size: 2.2rem;
  margin: 0;
  font-weight: 500;
  color: var(--journal-paper-accent);
}

.blank-date-container,
.bottle-date-container,
.burn-date-container,
.mirror-date-container,
.rain-date-container,
.obituary-date-container,
.museum-date-container,
.moon-date-container,
.train-date-container,
.things-date-container {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

/* Lined textareas for cursive writing */
.blank-ruled-textarea,
.bottle-ruled-textarea,
.burn-ruled-textarea,
.rain-ruled-textarea,
.moon-ruled-textarea {
  width: 100%;
  line-height: 2.2rem !important;
  font-size: 1.15rem;
  font-family: var(--font-hand), 'Dancing Script', cursive !important;
  background-image: linear-gradient(transparent, transparent calc(2.2rem - 1px), var(--journal-paper-border) calc(2.2rem - 1px)) !important;
  background-size: 100% 2.2rem !important;
  border: none !important;
  padding: 0.4rem 0.8rem !important;
  box-sizing: border-box;
  background-color: transparent !important;
  color: var(--journal-paper-color) !important;
  outline: none;
  min-height: 380px; /* Increased from 250px to provide a larger writing canvas */
}

/* Template 1: The Letter Bottle Journal */
.bottle-fields {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.bottle-input-row {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.bottle-field-label {
  font-family: var(--font-serif), serif;
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--journal-paper-color);
  opacity: 0.8;
}

.bottle-recipient-input {
  width: 100%;
}

.bottle-current-select {
  border: none;
  border-bottom: 1px solid var(--journal-paper-border) !important;
  background: transparent;
  color: var(--journal-paper-color);
  font-family: var(--font-serif), serif;
  outline: none;
  padding: 0.4rem;
  font-size: 0.95rem;
  cursor: pointer;
  border-radius: 4px;
}

.bottle-current-select:focus {
  border-bottom-color: var(--journal-paper-accent) !important;
  background: rgba(255, 255, 255, 0.05);
}

.bottle-current-select option {
  background-color: var(--journal-paper-bg);
  color: var(--journal-paper-color);
}

/* Template 2: Burn After Writing */
.burn-fields {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.burn-input-row {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.burn-field-label {
  font-family: var(--font-serif), serif;
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--journal-paper-color);
  opacity: 0.8;
}

.burn-heavy-input {
  width: 100%;
}

.burn-action-row {
  display: flex;
  justify-content: center;
  margin-top: 1.5rem;
}

.burn-draft-btn {
  background: linear-gradient(135deg, #ff4500, #ff8c00);
  border: none;
  color: #ffffff !important;
  padding: 0.8rem 2rem;
  border-radius: 30px;
  font-family: var(--font-serif), serif;
  font-size: 1.1rem;
  font-weight: bold;
  cursor: pointer;
  transition: all var(--transition-medium);
  box-shadow: 0 4px 15px rgba(255, 69, 0, 0.4);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.burn-draft-btn:hover {
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 6px 20px rgba(255, 69, 0, 0.6);
  background: linear-gradient(135deg, #ff5722, #ffb300);
}

.burn-draft-btn:active {
  transform: translateY(1px);
}

/* Paper Burn Animation Overlays */
.burn-animating {
  animation: paperBurnAndDissolve 2.5s forwards cubic-bezier(0.25, 0.8, 0.25, 1);
  pointer-events: none;
}

@keyframes paperBurnAndDissolve {
  0% {
    filter: blur(0px) brightness(1) contrast(1);
    transform: scale(1);
    opacity: 1;
  }
  30% {
    filter: blur(2px) brightness(1.5) sepia(0.5) hue-rotate(-10deg);
    transform: scale(0.98);
    opacity: 0.9;
  }
  60% {
    filter: blur(6px) brightness(2) sepia(1) hue-rotate(-20deg);
    transform: scale(0.92) rotate(-1deg);
    opacity: 0.6;
    box-shadow: inset 0 0 50px rgba(255, 69, 0, 0.5);
  }
  100% {
    filter: blur(20px) brightness(0) sepia(1) hue-rotate(-30deg);
    transform: scale(0.8) translateY(-20px) rotate(-3deg);
    opacity: 0;
  }
}

/* Template 3: The Mirror Pages */
.mirror-intro-text {
  font-family: var(--font-serif), serif;
  font-style: italic;
  font-size: 1.05rem;
  opacity: 0.85;
  margin-bottom: 1.5rem;
  text-align: center;
}

.mirror-interview-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin-top: 1rem;
}

.mirror-box {
  background: rgba(255, 255, 255, 0.015);
  border: 1px dashed var(--journal-paper-border);
  border-radius: 12px;
  padding: 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  transition: border-color var(--transition-fast), background-color var(--transition-fast);
}

.mirror-box:focus-within {
  border-color: var(--journal-paper-accent);
  background: rgba(255, 255, 255, 0.04);
}

.mirror-prompt {
  font-family: var(--font-serif), serif;
  font-size: 1.05rem;
  line-height: 1.5rem;
  color: var(--journal-paper-color);
  opacity: 0.95;
  font-weight: 500;
}

.mirror-textarea {
  width: 100%;
  height: 140px; /* Increased from 90px */
  font-size: 1rem;
  line-height: 1.5rem;
  padding: 0.4rem !important;
  font-family: var(--font-hand), 'Dancing Script', cursive !important;
  color: var(--journal-paper-color);
  background: transparent;
  border: none !important;
  border-bottom: 1px solid var(--journal-paper-border) !important;
  resize: none !important;
}

/* Template 4: Rain-Stained Thoughts */
.rain-fields {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.rain-slider-row {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--journal-paper-border);
  border-radius: 12px;
  padding: 1rem;
  margin-bottom: 1.5rem;
}

.rain-field-label {
  font-family: var(--font-serif), serif;
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--journal-paper-color);
  opacity: 0.8;
}

.slider-label-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.6rem;
}

.rain-intensity-value {
  font-family: var(--font-serif), serif;
  font-size: 0.9rem;
  font-weight: bold;
  color: var(--journal-paper-accent);
}

.rain-intensity-slider,
.moon-gravity-slider {
  -webkit-appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 3px;
  background: var(--journal-paper-border);
  outline: none;
  margin: 0.5rem 0;
}

.rain-intensity-slider::-webkit-slider-thumb,
.moon-gravity-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--journal-paper-accent);
  cursor: pointer;
  transition: transform var(--transition-fast);
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
}

.rain-intensity-slider::-webkit-slider-thumb:hover,
.moon-gravity-slider::-webkit-slider-thumb:hover {
  transform: scale(1.2);
}

/* Template 5: Dream Obituary Journal */
.obituary-intro-text {
  font-family: var(--font-serif), serif;
  font-style: italic;
  font-size: 1.15rem;
  line-height: 1.6;
  opacity: 0.8;
  text-align: center;
  margin-bottom: 2rem;
  color: var(--journal-paper-color);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.obituary-form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  border: 4px double var(--journal-paper-color);
  border-radius: 4px;
  padding: 2rem;
  background: rgba(0, 0, 0, 0.015);
  position: relative;
  overflow: hidden;
}

/* Solemn Memorial Header */
.obituary-memorial-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.8rem;
  border-bottom: 1px solid var(--journal-paper-color);
  padding-bottom: 1.2rem;
  margin-bottom: 0.5rem;
}

.obituary-memorial-title {
  font-family: var(--font-serif), serif;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 4px;
  color: var(--journal-paper-color);
  text-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
  text-align: center;
}

/* Flickering Candle Symbolism */
.obituary-candle-decor {
  width: 14px;
  height: 35px;
  background: var(--journal-paper-color);
  border-radius: 4px 4px 1px 1px;
  position: relative;
  opacity: 0.85;
}

.obituary-candle-wick {
  width: 2px;
  height: 8px;
  background: #333;
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
}

.obituary-candle-flame {
  width: 10px;
  height: 16px;
  background: radial-gradient(circle at bottom, #ffeaad, #ffa500, #ff4500);
  border-radius: 50% 50% 20% 20% / 60% 60% 40% 40%;
  position: absolute;
  top: -24px;
  left: 50%;
  transform: translateX(-50%);
  filter: drop-shadow(0 0 6px rgba(255, 140, 0, 0.6));
  animation: candleFlickerWarm 2.5s infinite alternate ease-in-out;
}

@keyframes candleFlickerWarm {
  0% { transform: translateX(-50%) scale(0.95) rotate(-2deg); opacity: 0.9; }
  25% { transform: translateX(-50%) scale(1.05) rotate(1deg); opacity: 0.98; }
  50% { transform: translateX(-50%) scale(0.98) rotate(-1deg); opacity: 0.93; }
  75% { transform: translateX(-50%) scale(1.03) rotate(2deg); opacity: 1; }
  100% { transform: translateX(-50%) scale(1) rotate(-1.5deg); opacity: 0.95; }
}

/* Faint Wilted Flower SVGs */
.obituary-wilted-flower-svg {
  position: absolute;
  width: 100px;
  height: 100px;
  color: var(--journal-paper-color);
  pointer-events: none;
  z-index: 1;
}

.obituary-wilted-flower-svg.left-flower {
  top: 10px;
  left: 10px;
  transform: rotate(-15deg);
}

.obituary-wilted-flower-svg.right-flower {
  bottom: 10px;
  right: 10px;
  transform: rotate(165deg);
}

@media (max-width: 580px) {
  .obituary-wilted-flower-svg {
    width: 60px;
    height: 60px;
    opacity: 0.15;
  }
  .obituary-wilted-flower-svg.left-flower {
    top: 5px;
    left: 5px;
  }
  .obituary-wilted-flower-svg.right-flower {
    bottom: 5px;
    right: 5px;
  }
}

/* Obituary Grid splitting */
.obituary-row-split {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 1.5rem;
  min-width: 0;
}

@media (max-width: 850px) {
  .obituary-row-split {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
}

.obituary-input-col,
.obituary-input-row,
.obituary-textarea-box {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  position: relative;
  z-index: 2; /* Lay above SVGs */
  min-width: 0;
}

.obituary-field-label {
  font-family: var(--font-serif), serif;
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--journal-paper-color);
  opacity: 0.75;
}

.obituary-form input[type="text"] {
  border: none;
  border-bottom: 1px dashed var(--journal-paper-color) !important;
  background: transparent;
  color: var(--journal-paper-color);
  font-family: var(--font-serif), serif;
  font-size: 1.05rem;
  padding: 0.4rem;
  outline: none;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  min-width: 0;
}

.obituary-form input[type="text"]:focus {
  border-bottom-style: solid !important;
  background: rgba(0,0,0,0.01);
}

.obituary-body-textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  min-width: 0;
  height: 320px; /* Increased from 180px */
  line-height: 2.2rem !important;
  font-size: 1.15rem;
  font-family: var(--font-hand), 'Dancing Script', cursive !important;
  color: var(--journal-paper-color) !important;
  background-image: linear-gradient(transparent, transparent calc(2.2rem - 1px), var(--journal-paper-border) calc(2.2rem - 1px)) !important;
  background-size: 100% 2.2rem !important;
  background-color: transparent !important;
  border: none !important;
  padding: 0.4rem 0.8rem !important;
  resize: none !important;
  outline: none;
}

.obituary-body-textarea:focus {
  background: rgba(0,0,0,0.01);
}

/* Cause of Death Interactive Selectors */
.obituary-cause-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-top: 0.2rem;
}

.cause-pill {
  background: rgba(0, 0, 0, 0.02);
  border: 1px solid var(--journal-paper-color);
  color: var(--journal-paper-color);
  opacity: 0.7;
  padding: 0.5rem 1rem;
  border-radius: 20px;
  font-family: var(--font-serif), serif;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}

.cause-pill:hover {
  background: rgba(0, 0, 0, 0.05);
  opacity: 0.9;
  transform: translateY(-1px);
}

.cause-pill.active {
  background: var(--journal-paper-color);
  color: var(--journal-paper-bg) !important;
  opacity: 1;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

/* Template 6: The Museum of Lost Things */
.museum-intro-text {
  font-family: var(--font-serif), serif;
  font-style: italic;
  font-size: 1.15rem;
  line-height: 1.6;
  opacity: 0.8;
  text-align: center;
  margin-bottom: 2rem;
  color: var(--journal-paper-color);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.museum-form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  border: 1px solid var(--journal-paper-color);
  border-radius: 4px;
  padding: 2rem;
  background: rgba(255, 255, 255, 0.015);
  position: relative;
  overflow: hidden;
  box-shadow: inset 0 0 40px rgba(0, 0, 0, 0.01);
}

/* Archive Stamped Branding */
.museum-archive-stamp {
  position: absolute;
  top: 15px;
  right: 15px;
  border: 2px solid var(--journal-paper-accent);
  color: var(--journal-paper-accent);
  font-family: monospace;
  font-weight: bold;
  font-size: 0.75rem;
  padding: 0.2rem 0.5rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  transform: rotate(6deg);
  opacity: 0.6;
  pointer-events: none;
  border-radius: 3px;
}

@media (max-width: 950px) {
  .museum-archive-stamp {
    position: relative;
    top: 0;
    right: 0;
    margin: 0 auto 1.5rem auto;
    transform: rotate(-3deg);
    display: block;
    width: fit-content;
    text-align: center;
  }
}

/* Museum Archive Split layout */
.museum-archive-grid {
  display: grid;
  grid-template-columns: 1fr 200px;
  gap: 2rem;
  align-items: start;
  min-width: 0;
}

@media (max-width: 950px) {
  .museum-archive-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .museum-polaroid-container {
    margin: 0 auto;
  }
}

.museum-form-inputs {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  min-width: 0;
}

.museum-row-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  min-width: 0;
}

@media (max-width: 768px) {
  .museum-row-split {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
}

/* Make form padding and gaps more compact on smaller screens */
@media (max-width: 480px) {
  .obituary-form,
  .museum-form {
    padding: 1.2rem;
    gap: 1.2rem;
  }
}

@media (max-width: 768px) {
  .obituary-intro-text,
  .museum-intro-text {
    font-size: 1rem;
    margin-bottom: 1.25rem;
  }
  .obituary-memorial-title {
    font-size: 1.15rem;
    letter-spacing: 2px;
  }
}

.museum-input-col,
.museum-input-row,
.museum-textarea-box {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 0;
}

.museum-field-label {
  font-family: var(--font-serif), serif;
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--journal-paper-color);
  opacity: 0.75;
}

.museum-form input[type="text"] {
  border: none;
  border-bottom: 1px solid var(--journal-paper-color) !important;
  background: transparent;
  color: var(--journal-paper-color);
  font-family: monospace;
  font-size: 1rem;
  padding: 0.4rem;
  outline: none;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  min-width: 0;
}

.museum-form input[type="text"]:focus {
  border-bottom-width: 2px !important;
  background: rgba(0,0,0,0.01);
}

.museum-body-textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  min-width: 0;
  height: 320px; /* Increased from 180px */
  line-height: 2.0rem !important;
  font-size: 1.05rem;
  padding: 0.4rem 0.8rem !important;
  border: none !important;
  border-bottom: 1px solid var(--journal-paper-border) !important;
  background-image: linear-gradient(transparent, transparent calc(2.0rem - 1px), var(--journal-paper-border) calc(2.0rem - 1px)) !important;
  background-size: 100% 2.0rem !important;
  background-color: transparent !important;
  color: var(--journal-paper-color) !important;
  resize: none !important;
  outline: none;
}

/* Typewriter Fonts Override */
.font-typewriter,
.museum-body-textarea.font-typewriter {
  font-family: 'Courier New', Courier, monospace !important;
  font-weight: 500;
  letter-spacing: -0.2px;
}

/* Category pills selector */
.museum-category-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.2rem;
}

.category-pill {
  background: rgba(0, 0, 0, 0.02);
  border: 1px solid var(--journal-paper-color);
  color: var(--journal-paper-color);
  opacity: 0.75;
  padding: 0.4rem 0.8rem;
  border-radius: 4px;
  font-family: var(--font-serif), serif;
  font-size: 0.8rem;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
}

.category-pill:hover {
  background: rgba(0, 0, 0, 0.05);
  opacity: 0.95;
}

.category-pill.active {
  background: var(--journal-paper-color);
  color: var(--journal-paper-bg) !important;
  opacity: 1;
}

/* Polaroid Container CSS mockup */
.museum-polaroid-container {
  width: 200px;
  perspective: 1000px;
}

.museum-polaroid {
  width: 100%;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.1);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  padding: 12px 12px 28px 12px;
  border-radius: 2px;
  transform: rotate(-2deg);
  transition: transform var(--transition-medium), box-shadow var(--transition-medium);
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  backface-visibility: hidden;
}

.museum-polaroid:hover {
  transform: rotate(1deg) translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
}

/* Tape effect at the top */
.museum-polaroid::before {
  content: '';
  position: absolute;
  top: -15px;
  left: 50%;
  transform: translateX(-50%) rotate(-4deg);
  width: 80px;
  height: 25px;
  background: rgba(226, 219, 195, 0.65);
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  z-index: 5;
}

.polaroid-photo {
  width: 100%;
  height: 150px;
  background: #f7f7f7;
  border: 1px solid rgba(0, 0, 0, 0.05);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.polaroid-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.polaroid-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  color: #a0a0a0;
  text-align: center;
  padding: 1rem;
}

.polaroid-placeholder-icon {
  width: 24px;
  height: 24px;
  opacity: 0.5;
}

.polaroid-placeholder .placeholder-text {
  font-family: monospace;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 1px;
}

.polaroid-placeholder .placeholder-subtext {
  font-size: 0.55rem;
  line-height: 1.3;
  opacity: 0.7;
}

.polaroid-caption {
  font-size: 0.75rem;
  text-align: center;
  color: #333333 !important;
}

/* Candlelight Overlay on Paper Sheet when Obituary active */
.paper-sheet.template-active-obituary {
  box-shadow: 0 12px 50px rgba(255, 140, 0, 0.05), inset 0 0 80px rgba(139, 90, 43, 0.05) !important;
}

.paper-sheet.template-active-obituary #journal-visual-sheet::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(circle at 10% 10%, rgba(255, 140, 0, 0.09) 0%, transparent 70%);
  pointer-events: none;
  z-index: 4;
  mix-blend-mode: color-burn;
  border-radius: 8px;
  animation: candleAmbientFlicker 6s infinite alternate ease-in-out;
}

@keyframes candleAmbientFlicker {
  0% { opacity: 0.85; }
  30% { opacity: 1; }
  60% { opacity: 0.9; }
  100% { opacity: 0.95; }
}

/* Template 7: Letters Left on the Moon */
.moon-phase-selector-row {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--journal-paper-border);
  border-radius: 12px;
  padding: 1rem;
  margin-bottom: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.moon-field-label {
  font-family: var(--font-serif), serif;
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--journal-paper-color);
  opacity: 0.8;
}

.moon-phases-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
}

.moon-phase-btn {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--journal-paper-border);
  border-radius: 8px;
  padding: 0.5rem;
  cursor: pointer;
  color: var(--journal-paper-color);
  font-size: 1.4rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  transition: all var(--transition-fast);
}

.moon-phase-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  transform: translateY(-2px);
}

.moon-phase-btn.active {
  background: rgba(255, 255, 255, 0.12);
  border-color: var(--journal-paper-accent);
  box-shadow: 0 0 10px rgba(159, 159, 237, 0.3);
}

.moon-gravity-val {
  font-family: var(--font-serif), serif;
  font-size: 0.9rem;
  font-weight: bold;
  color: var(--journal-paper-accent);
}

.moon-slider-row {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--journal-paper-border);
  border-radius: 12px;
  padding: 1rem;
  margin-bottom: 1.5rem;
}

/* Template 8: The Last Train Home */
.train-intro-text {
  font-family: var(--font-serif), serif;
  font-style: italic;
  font-size: 1.05rem;
  opacity: 0.85;
  text-align: center;
  margin-bottom: 1.5rem;
}

.train-ticket-form {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  border: 1px dashed var(--journal-paper-accent);
  border-radius: 12px;
  padding: 1.5rem;
  background: rgba(255, 255, 255, 0.015);
  position: relative;
  overflow: hidden;
}

/* Visual ticket notches on left/right borders */
.train-ticket-form::before,
.train-ticket-form::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 20px;
  height: 20px;
  background: var(--journal-paper-bg);
  border: 1px dashed var(--journal-paper-accent);
  border-radius: 50%;
  transform: translateY(-50%);
  z-index: 2;
}

.train-ticket-form::before {
  left: -11px;
}

.train-ticket-form::after {
  right: -11px;
}

.train-row-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
}

@media (max-width: 600px) {
  .train-row-split {
    grid-template-columns: 1fr;
  }
}

.train-input-col,
.train-input-row,
.train-textarea-box {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.train-field-label {
  font-family: var(--font-serif), serif;
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--journal-paper-color);
  opacity: 0.8;
}

.train-body-textarea {
  width: 100%;
  height: 320px; /* Increased from 180px */
  line-height: 2.2rem !important;
  font-size: 1.15rem;
  font-family: var(--font-hand), 'Dancing Script', cursive !important;
  background-image: linear-gradient(transparent, transparent calc(2.2rem - 1px), var(--journal-paper-border) calc(2.2rem - 1px)) !important;
  background-size: 100% 2.2rem !important;
  background-color: transparent !important;
  color: var(--journal-paper-color) !important;
  border: none !important;
  padding: 0.4rem 0.8rem !important;
  resize: none !important;
  outline: none;
}

/* Template 9: The Things I Couldn't Say */
.things-form {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  border-top: 1px solid var(--journal-paper-border);
  padding-top: 1.5rem;
}

.things-row-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
}

@media (max-width: 600px) {
  .things-row-split {
    grid-template-columns: 1fr;
  }
}

.things-input-col,
.things-textarea-box {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.things-field-label {
  font-family: var(--font-serif), serif;
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--journal-paper-color);
  opacity: 0.8;
}

.things-body-textarea {
  width: 100%;
  height: 350px; /* Increased from 220px */
  line-height: 2.2rem !important;
  font-size: 1.15rem;
  font-family: var(--font-hand), 'Dancing Script', cursive !important;
  background-image: linear-gradient(transparent, transparent calc(2.2rem - 1px), var(--journal-paper-border) calc(2.2rem - 1px)) !important;
  background-size: 100% 2.2rem !important;
  background-color: transparent !important;
  color: var(--journal-paper-color) !important;
  border: none !important;
  padding: 0.4rem 0.8rem !important;
  resize: none !important;
  outline: none;
}



/* ==========================================================================
   HIGH-FIDELITY PDF PRINT AND EXPORT MEDIA OVERRIDES
   ========================================================================== */

@media print {
  /* Absolute full-bleed settings */
  html, body {
    margin: 0 !important;
    padding: 0 !important;
    background: #ffffff !important;
    width: 100% !important;
    height: 100% !important;
    overflow: visible !important;
    font-size: 12pt !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  /* Completely hide all non-journal elements */
  body * {
    visibility: hidden !important;
  }

  /* Display only the writing paper sheet */
  #paper-sheet,
  #paper-sheet * {
    visibility: visible !important;
  }

  #paper-sheet {
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    width: 210mm !important; /* Force exact standard A4 width */
    min-height: 297mm !important; /* Force exact standard A4 height */
    margin: 0 !important;
    padding: 20mm 15mm 20mm 15mm !important; /* Gorgeous luxury print borders */
    box-sizing: border-box !important;
    background: var(--journal-paper-bg, #ffffff) !important;
    color: var(--journal-paper-color, #1a1a1a) !important;
    box-shadow: none !important;
    border: none !important;
    border-radius: 0 !important;
    z-index: 999999 !important;
  }

  /* Clear all custom app-background styling */
  #paper-sheet::before,
  #paper-sheet::after {
    display: none !important;
  }

  /* Ensure text colors, backgrounds, and accents are perfectly preserved */
  .paper-sheet.skin-watercolor-blush {
    background: radial-gradient(circle at center, #fff0f0 0%, #ffe3e3 100%) !important;
  }
  .paper-sheet.skin-parchment-sand {
    background: #f4edd8 !important;
  }
  .paper-sheet.skin-porcelain-cream {
    background: #fafafa !important;
  }
  .paper-sheet.skin-starry-cosmic {
    background: radial-gradient(circle at 30% 20%, #161730 0%, #0a0b16 100%) !important;
  }
  .paper-sheet.skin-classic-grid {
    background: #fdfdfd !important;
    background-image: radial-gradient(rgba(113, 128, 147, 0.15) 1px, transparent 1px) !important;
    background-size: 20px 20px !important;
  }

  /* Display Art Overlays */
  .journal-art-accents,
  .journal-art-accents .accent-svg {
    display: block !important;
    visibility: visible !important;
  }

  /* Explicitly hide writing workspace toolbars and popups */
  #journal-design-palette,
  #journal-templates-container,
  #release-options-menu,
  .letter-controls,
  .release-group,
  .desk-header,
  #ivy-container,
  #avian-spine-container,
  #dandelion-core-container,
  #dandelion-container,
  #poetry-lyre-container {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* Hide placeholder text of empty elements */
  input::placeholder,
  textarea::placeholder {
    color: transparent !important;
    opacity: 0 !important;
  }

  /* Format visual fields for beautiful, clean paper rendering */
  .journal-visual-sheet input[type="text"],
  .journal-visual-sheet textarea {
    border: none !important;
    border-bottom: 1px dashed var(--journal-paper-border) !important;
    background: transparent !important;
    color: var(--journal-paper-color) !important;
    outline: none !important;
    box-shadow: none !important;
    resize: none !important;
    font-size: 11pt !important;
  }

  .classic-ruled-textarea,
  .botanical-ruled-textarea,
  .blossom-ruled-textarea {
    border: none !important;
    line-height: 2.2rem !important;
    background-image: linear-gradient(transparent, transparent calc(2.2rem - 1px), var(--journal-paper-border) calc(2.2rem - 1px)) !important;
    background-size: 100% 2.2rem !important;
  }

  /* Make sure days and droplets preserve active colors when printed */
  .day-circle {
    border-color: var(--journal-paper-accent) !important;
  }
  .day-circle.active {
    background: var(--journal-paper-accent) !important;
    color: var(--journal-paper-bg) !important;
  }

  .droplet {
    opacity: 0.15 !important;
  }
  .droplet.active {
    opacity: 1 !important;
    filter: none !important;
  }

  .mood-btn {
    opacity: 0.25 !important;
  }
  .mood-btn.active {
    opacity: 1 !important;
    filter: none !important;
  }
}

/* ==========================================================================
   STATIC THEME SYSTEM & HIGH-CONTRAST LIGHT MODE (FLOODRA BRAND)
   ========================================================================== */

/* Dark Mode (Midnight Rain) - Default state variables */
body.theme-dark {
  --bg-start: #0a0b18;
  --bg-end: #030408;
  --accent-color: #6366f1;
  --text-primary: #f3f4f6;
  --text-secondary: #9ca3af;
  --text-muted: #6b7280;
  --glow-color: rgba(99, 102, 241, 0.25);
  --glow-bright: rgba(129, 140, 248, 0.8);
  --glass-bg: rgba(255, 255, 255, 0.02);
  --glass-border: rgba(255, 255, 255, 0.06);
  --glass-highlight: rgba(255, 255, 255, 0.1);
  --card-shadow: 0 12px 40px 0 rgba(0, 0, 0, 0.5);
  --color-ink: #0d0a15;
}

/* Light Mode (Sage & Olive Green) variables */
body.theme-light {
  --bg-start: #6B705C;
  --bg-end: #4B503F;
  --accent-color: #B5BA9D; /* Light glowing moss accent */
  --text-primary: #1F241A; /* Deep forest-charcoal typography */
  --text-secondary: #3B4033; /* Medium olive-grey text */
  --text-muted: #6E7565; /* Muted placeholder/borders */
  --glow-color: rgba(181, 186, 157, 0.15);
  --glow-bright: rgba(181, 186, 157, 0.6);
  --glass-bg: rgba(255, 255, 255, 0.82); /* Keep opaque light glass background */
  --glass-border: rgba(31, 36, 26, 0.12); /* Subtle deep glass borders */
  --glass-highlight: rgba(255, 255, 255, 0.4);
  --card-shadow: 0 12px 40px 0 rgba(31, 36, 26, 0.12);
  --color-ink: #1F241A;

  /* Responsive Header Variables */
  --header-bg: rgba(242, 245, 238, 0.88);
  --header-border: rgba(31, 36, 26, 0.12);
  --header-shadow: 0 4px 24px rgba(31, 36, 26, 0.08);
}

/* Light mode specific component overrides for premium legibility and contrast */
body.theme-light .audio-panel,
body.theme-light .nav-dock,
body.theme-light .star-tooltip,
body.theme-light .circle-header,
body.theme-light .circle-picker,
body.theme-light .templates-panel,
body.theme-light .submenu-panel,
body.theme-light .profile-panel,
body.theme-light .modal-card,
body.theme-light .auth-card {
  background: rgba(255, 255, 255, 0.85) !important;
  border-color: rgba(31, 36, 26, 0.14) !important;
  color: var(--text-primary) !important;
  box-shadow: 0 10px 30px rgba(31, 36, 26, 0.08) !important;
}

body.theme-light .paper-sheet {
  background: rgba(255, 255, 255, 0.85) !important;
  border-color: rgba(31, 36, 26, 0.12) !important;
  box-shadow: 0 15px 45px rgba(31, 36, 26, 0.06) !important;
}

/* Ensure visual companion glasses have dark contrast backgrounds in light theme */
body.theme-light .candle-glass,
body.theme-light .feather-glass,
body.theme-light .dandelion-glass {
  background: rgba(10, 8, 16, 0.75) !important;
  border-color: rgba(31, 36, 26, 0.18) !important;
  box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.3) !important;
}

body.theme-light .journal-design-palette {
  background: rgba(31, 36, 26, 0.04) !important;
  border-color: rgba(31, 36, 26, 0.1) !important;
}


body.theme-light .brand h1 {
  background: linear-gradient(to right, var(--text-primary), var(--text-secondary)) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  color: transparent !important;
}

body.theme-light h1,
body.theme-light h2,
body.theme-light h3,
body.theme-light h4,
body.theme-light h5,
body.theme-light h6 {
  color: var(--text-primary) !important;
}

body.theme-light input,
body.theme-light textarea,
body.theme-light select {
  color: var(--text-primary) !important;
  background-color: rgba(255, 255, 255, 0.6) !important;
  border-color: rgba(31, 36, 26, 0.15) !important;
}

body.theme-light input::placeholder,
body.theme-light textarea::placeholder {
  color: var(--text-muted) !important;
}

body.theme-light .nav-item {
  color: var(--text-secondary);
}

body.theme-light .nav-item.active {
  color: var(--accent-color);
}

body.theme-light .nav-pill-indicator {
  background: rgba(107, 112, 92, 0.08) !important;
  border: 1px solid rgba(107, 112, 92, 0.18) !important;
}

body.theme-light ::-webkit-scrollbar-thumb {
  background: rgba(107, 112, 92, 0.25);
}

body.theme-light ::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.1);
}

/* Ensure background SVGs are styled properly in light mode */
body.theme-light .portal-pathway-svg path {
  stroke: var(--accent-color) !important;
}

/* Light mode specific overrides for Meadow Constellation star letter popups */
body.theme-light .letter-modal-overlay {
  background: rgba(44, 48, 38, 0.45) !important;
  backdrop-filter: blur(25px) !important;
  -webkit-backdrop-filter: blur(25px) !important;
}

body.theme-light .letter-modal-card {
  background: rgba(255, 255, 255, 0.94) !important;
  border-color: rgba(107, 112, 92, 0.25) !important;
  color: var(--text-primary) !important;
  box-shadow: 0 25px 50px -12px rgba(44, 48, 38, 0.2), 0 0 30px rgba(181, 186, 157, 0.25) !important;
}

body.theme-light .modal-body {
  background-image: linear-gradient(rgba(107, 112, 92, 0.05) 1px, transparent 1px) !important;
  color: var(--text-primary) !important;
}

body.theme-light .modal-footer {
  background: rgba(0, 0, 0, 0.03) !important;
  border-top: 1px solid rgba(107, 112, 92, 0.15) !important;
}

body.theme-light .modal-close-btn {
  color: var(--text-secondary) !important;
}

body.theme-light .modal-close-btn:hover {
  background: rgba(0, 0, 0, 0.06) !important;
  color: var(--text-primary) !important;
}

body.theme-light .modal-letter-tag {
  background: rgba(107, 112, 92, 0.05) !important;
  border-color: rgba(107, 112, 92, 0.15) !important;
  color: var(--text-secondary) !important;
}

body.theme-light .support-btn {
  background: rgba(255, 255, 255, 0.7) !important;
  border-color: rgba(107, 112, 92, 0.2) !important;
  color: #3B4033 !important;
}

body.theme-light .support-btn:hover {
  background: rgba(255, 255, 255, 0.95) !important;
  border-color: #6B705C !important;
  color: #1F241A !important;
  box-shadow: 0 4px 12px rgba(107, 112, 92, 0.1) !important;
}

body.theme-light .support-btn.active {
  background: rgba(107, 112, 92, 0.08) !important;
  border-color: #6B705C !important;
  color: #4B503F !important;
}

body.theme-light .author-btn.btn-delete-letter {
  color: #dc2626 !important;
  background: rgba(220, 38, 38, 0.05) !important;
  border-color: rgba(220, 38, 38, 0.15) !important;
}

body.theme-light .author-btn.btn-delete-letter:hover {
  background: rgba(220, 38, 38, 0.12) !important;
  border-color: rgba(220, 38, 38, 0.3) !important;
}



/* ==========================================================================
   GLASSMORPHIC MOOD RELEASE POPOVER OVERLAY
   ========================================================================== */
.mood-release-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(3, 2, 7, 0.7);
  backdrop-filter: blur(25px);
  -webkit-backdrop-filter: blur(25px);
  z-index: 1001; /* Ensure it floats above ordinary modals */
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity var(--transition-medium, 0.3s) ease, visibility var(--transition-medium, 0.3s) ease;
}

.mood-release-modal-overlay.active {
  opacity: 1;
  pointer-events: all;
  visibility: visible;
}

.mood-release-modal-card {
  position: relative;
  width: 100%;
  max-width: 500px;
  background: rgba(15, 12, 23, 0.65);
  border: 1px solid var(--glass-border);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.8), 0 0 40px var(--glow-color);
  padding: 2.5rem 2.2rem;
  border-radius: 24px;
  text-align: center;
  transform: scale(0.92) translateY(15px);
  transition: transform var(--transition-medium, 0.3s) cubic-bezier(0.34, 1.56, 0.64, 1), opacity var(--transition-medium, 0.3s) ease;
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
}

.mood-release-modal-overlay.active .mood-release-modal-card {
  transform: scale(1) translateY(0);
}

.mood-release-icon-glow {
  width: 56px;
  height: 56px;
  margin: 0 auto 1.25rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-color);
  box-shadow: 0 0 20px var(--glow-color);
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.mood-release-modal-card:hover .mood-release-icon-glow {
  transform: rotate(15deg) scale(1.08);
}

.mood-release-modal-header h3 {
  font-family: var(--font-serif), serif;
  font-size: 1.5rem;
  font-weight: 500;
  margin-bottom: 0.5rem;
  color: var(--text-primary);
  letter-spacing: -0.01em;
}

.mood-release-subtitle {
  color: var(--text-secondary);
  font-size: 0.9rem;
  line-height: 1.5;
  margin-bottom: 1.75rem;
  margin-top: 0;
}

.mood-release-choices {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.75rem;
}

.mood-release-btn-choice {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.25rem 1.4rem;
  text-align: left;
  cursor: pointer;
  width: 100%;
  color: inherit;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  position: relative;
}

.mood-release-btn-choice:hover:not(.disabled) {
  background: rgba(255, 255, 255, 0.05);
  border-color: var(--accent-color);
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2), 0 0 15px var(--glow-color);
  transform: translateY(-2px);
}

.mood-release-btn-choice:active:not(.disabled) {
  transform: translateY(0);
}

.mood-release-btn-choice.disabled {
  opacity: 0.45;
  cursor: not-allowed;
  border-style: dashed;
}

.mood-choice-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.mood-choice-emoji {
  font-size: 1.2rem;
  line-height: 1;
}

.mood-choice-title {
  font-family: var(--font-sans), sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary);
}

.mood-choice-desc {
  font-size: 0.8rem;
  color: var(--text-secondary);
  line-height: 1.4;
  margin: 0;
}

.mood-choice-warning {
  font-size: 0.76rem;
  color: #f87171; /* High contrast pastel red */
  line-height: 1.3;
  margin: 0.25rem 0 0 0;
  font-weight: 500;
  text-align: left;
}

.mood-release-footer {
  display: flex;
  justify-content: center;
}

.mood-release-cancel-btn {
  background: transparent;
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  padding: 0.55rem 1.75rem;
  border-radius: 20px;
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 500;
  transition: all 0.2s ease;
}

.mood-release-cancel-btn:hover {
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-primary);
  border-color: var(--text-muted);
}

/* Light mode overrides for the release popup */
body.theme-light .mood-release-modal-overlay {
  background: rgba(44, 48, 38, 0.45);
}

body.theme-light .mood-release-modal-card {
  background: rgba(255, 255, 255, 0.9) !important;
  border-color: rgba(31, 36, 26, 0.14) !important;
  box-shadow: 0 25px 50px -12px rgba(31, 36, 26, 0.15), 0 0 30px var(--glow-color) !important;
}

body.theme-light .mood-release-icon-glow {
  background: rgba(107, 112, 92, 0.06);
  border-color: rgba(31, 36, 26, 0.1);
}

body.theme-light .mood-release-btn-choice {
  background: rgba(255, 255, 255, 0.5);
  border-color: rgba(31, 36, 26, 0.1);
}

body.theme-light .mood-release-btn-choice:hover:not(.disabled) {
  background: rgba(255, 255, 255, 0.85);
  border-color: var(--accent-color);
  box-shadow: 0 0 15px var(--glow-color);
}

body.theme-light .mood-choice-warning {
  color: #dc2626; /* Darker red for light background */
}

/* Styling for Vault release circle buttons */
.circle-release-btn {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 0.8rem 1rem;
  text-align: left;
  cursor: pointer;
  color: var(--text-primary);
  font-family: var(--font-sans), sans-serif;
  font-size: 0.88rem;
  font-weight: 500;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.circle-release-btn:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: var(--accent-color);
  box-shadow: 0 4px 10px rgba(0,0,0,0.15), 0 0 10px var(--glow-color);
  transform: translateY(-1px);
}
.circle-release-btn:active {
  transform: translateY(0);
}

body.theme-light .circle-release-btn {
  background: rgba(255, 255, 255, 0.5);
  border-color: rgba(31, 36, 26, 0.1);
  color: var(--text-primary);
}
body.theme-light .circle-release-btn:hover {
  background: rgba(255, 255, 255, 0.85);
  border-color: var(--accent-color);
  box-shadow: 0 0 15px var(--glow-color);
}

/* ==========================================================================
   Sheet-level Image Submit Feature (Dashed Cards matching Photo)
   ========================================================================== */
.sheet-artifact-frame {
  max-width: 380px; /* Super small compact width */
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  margin-top: 0.5rem;
  margin-bottom: 1.2rem;
  display: flex;
  flex-direction: column;
  transition: all var(--transition-medium);
  z-index: 5;
}

/* Hide image submit in letters, poetry, and journals formats */
.paper-sheet:not(.format-art) .sheet-artifact-frame {
  display: none !important;
}

.sheet-image-submit-container {
  display: flex;
  gap: 0.75rem; /* Super small gap */
  width: 100%;
}

.sheet-submit-card {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.015);
  border: 1.2px dashed rgba(255, 255, 255, 0.15);
  border-radius: 10px; /* Slimmer border radius */
  padding: 0.8rem 0.5rem; /* Super small compact padding */
  cursor: pointer;
  outline: none;
  transition: all var(--transition-medium);
  color: var(--text-secondary);
}

.sheet-submit-icon {
  width: 16px; /* Super small compact icon size */
  height: 16px;
  margin-bottom: 0.3rem; /* Tiny margin */
  color: var(--text-secondary);
  opacity: 0.5;
  transition: all var(--transition-medium);
}

.sheet-submit-label {
  font-family: var(--font-sans);
  font-size: 0.62rem; /* Shrunk font size for super small style */
  font-weight: 600;
  letter-spacing: 0.05em; /* Narrower tracking to avoid wrapping */
  color: var(--text-secondary);
  opacity: 0.6;
  text-align: center;
  transition: all var(--transition-medium);
}

/* Hover effects for dashed cards */
.sheet-submit-card:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--accent-color);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.sheet-submit-card:hover .sheet-submit-icon {
  color: var(--accent-color);
  opacity: 0.9;
  transform: scale(1.05);
}

.sheet-submit-card:hover .sheet-submit-label {
  color: var(--text-primary);
  opacity: 0.9;
}

/* Hide original sidebar artifact choice empty state, since the new premium sheet-level dashed cards are now the only entry point */
.artifact-empty-state {
  display: none !important;
}

/* Handle styles for Light-colored templates/skins */
.paper-sheet.skin-watercolor-blush .sheet-submit-card,
.paper-sheet.skin-parchment-sand .sheet-submit-card,
.paper-sheet.skin-porcelain-cream .sheet-submit-card,
.paper-sheet.skin-classic-grid .sheet-submit-card {
  background: rgba(0, 0, 0, 0.015);
  border-color: rgba(0, 0, 0, 0.12);
}

.paper-sheet.skin-watercolor-blush .sheet-submit-card:hover,
.paper-sheet.skin-parchment-sand .sheet-submit-card:hover,
.paper-sheet.skin-porcelain-cream .sheet-submit-card:hover,
.paper-sheet.skin-classic-grid .sheet-submit-card:hover {
  background: rgba(0, 0, 0, 0.03);
  border-color: var(--journal-paper-accent);
}

.paper-sheet.skin-watercolor-blush .sheet-submit-card .sheet-submit-icon,
.paper-sheet.skin-parchment-sand .sheet-submit-card .sheet-submit-icon,
.paper-sheet.skin-porcelain-cream .sheet-submit-card .sheet-submit-icon,
.paper-sheet.skin-classic-grid .sheet-submit-card .sheet-submit-icon {
  color: var(--journal-paper-color);
}

.paper-sheet.skin-watercolor-blush .sheet-submit-card .sheet-submit-label,
.paper-sheet.skin-parchment-sand .sheet-submit-card .sheet-submit-label,
.paper-sheet.skin-porcelain-cream .sheet-submit-card .sheet-submit-label,
.paper-sheet.skin-classic-grid .sheet-submit-card .sheet-submit-label {
  color: var(--journal-paper-color);
}

/* Title label styled perfectly below image submit frame */
.sheet-title-label {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--text-secondary);
  opacity: 0.45;
  margin-bottom: 0.25rem;
  text-transform: uppercase;
}

/* Light themes Title label adjustment */
.paper-sheet.skin-watercolor-blush .sheet-title-label,
.paper-sheet.skin-parchment-sand .sheet-title-label,
.paper-sheet.skin-porcelain-cream .sheet-title-label,
.paper-sheet.skin-classic-grid .sheet-title-label {
  color: var(--journal-paper-color);
  opacity: 0.45;
}

/* Completely hide the title label and input from all formats to let writers focus on raw content */
.sheet-title-label,
.letter-title {
  display: none !important;
}

/* Loading state styling on the sheet */
.sheet-artifact-loading-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3rem 1.5rem;
  background: rgba(0, 0, 0, 0.15);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  backdrop-filter: blur(8px);
}

/* Display State Card on the sheet */
.sheet-artifact-display-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  background: rgba(10, 8, 16, 0.3);
  border: 1px solid var(--glass-border);
  border-radius: 24px;
  padding: 1.5rem;
  backdrop-filter: blur(12px);
  box-shadow: var(--card-shadow);
}

/* Skin overrides for loaded card */
.paper-sheet.skin-watercolor-blush .sheet-artifact-display-card,
.paper-sheet.skin-parchment-sand .sheet-artifact-display-card,
.paper-sheet.skin-porcelain-cream .sheet-artifact-display-card,
.paper-sheet.skin-classic-grid .sheet-artifact-display-card {
  background: rgba(255, 255, 255, 0.4);
  border-color: var(--journal-paper-border);
}

.sheet-artifact-image-container {
  position: relative;
  width: 100%;
  max-height: 380px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  background: #000;
}

.sheet-artifact-image-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-medium);
}

.sheet-artifact-display-card:hover .sheet-artifact-image-container img {
  transform: scale(1.02);
}

.sheet-artifact-glint {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(255,255,255,0.15) 0%, rgba(255,255,255,0) 50%, rgba(255,255,255,0) 100%);
  z-index: 2;
  pointer-events: none;
}

/* Metadata formatting inside the sheet card */
.sheet-artifact-metadata {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.sheet-metadata-row.header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding-bottom: 0.75rem;
}

.paper-sheet.skin-watercolor-blush .sheet-metadata-row.header-row,
.paper-sheet.skin-parchment-sand .sheet-metadata-row.header-row,
.paper-sheet.skin-porcelain-cream .sheet-metadata-row.header-row,
.paper-sheet.skin-classic-grid .sheet-metadata-row.header-row {
  border-bottom-color: rgba(0, 0, 0, 0.06);
}

.sheet-artifact-id {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--accent-color);
}

.sheet-badge {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 0.25rem 0.6rem;
  border-radius: 20px;
}

.sheet-metadata-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}

.sheet-metadata-cell {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
}

.sheet-meta-label {
  color: var(--text-secondary);
  opacity: 0.8;
  font-weight: 500;
}

.sheet-meta-val {
  color: var(--text-primary);
  font-weight: 600;
}

/* Reset button for sheet card */
.sheet-artifact-reset-btn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  cursor: pointer;
  z-index: 10;
  transition: all var(--transition-fast);
}

.sheet-artifact-reset-btn:hover {
  background: #ef4444;
  border-color: #ef4444;
  transform: rotate(90deg) scale(1.1);
}


/* Modals Overlay Common base matching subscribe/auth modals */
.contact-modal-overlay,
.help-modal-overlay,
.admin-inbox-modal-overlay,
.story-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(3, 2, 7, 0.75);
  backdrop-filter: blur(25px);
  z-index: 1000;
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity var(--transition-medium), visibility var(--transition-medium);
}

.contact-modal-overlay.active,
.help-modal-overlay.active,
.admin-inbox-modal-overlay.active,
.story-modal-overlay.active {
  opacity: 1;
  pointer-events: all;
  visibility: visible;
}

/* Light Theme overrides for overlays */
body.theme-light .contact-modal-overlay,
body.theme-light .help-modal-overlay,
body.theme-light .admin-inbox-modal-overlay,
body.theme-light .story-modal-overlay {
  background: rgba(240, 236, 228, 0.6);
  backdrop-filter: blur(25px);
}

/* Contact Modal Card */
.contact-modal-card {
  position: relative;
  width: 100%;
  max-width: 440px;
  background: rgba(15, 12, 23, 0.65);
  border: 1px solid var(--glass-border);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.8), 0 0 40px var(--glow-color);
  padding: 3rem 2.5rem;
  border-radius: 24px;
  text-align: center;
  transform: scale(0.92) translateY(15px);
  transition: transform var(--transition-medium), opacity var(--transition-medium);
  backdrop-filter: blur(15px);
}
body.theme-light .contact-modal-card {
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.1), 0 0 20px rgba(0, 0, 0, 0.05);
}

.contact-modal-overlay.active .contact-modal-card {
  transform: scale(1) translateY(0);
}

.contact-modal-header {
  margin-bottom: 2rem;
}

.contact-icon-glow, .help-icon-glow, .admin-icon-glow {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--accent-color);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  box-shadow: 0 0 20px var(--glow-color);
  animation: pulseGlow 3s infinite ease-in-out;
}
.contact-icon-glow svg, .help-icon-glow svg, .admin-icon-glow svg {
  width: 26px;
  height: 26px;
}

@keyframes pulseGlow {
  0%, 100% { box-shadow: 0 0 15px var(--glow-color); transform: scale(1); }
  50% { box-shadow: 0 0 30px var(--glow-bright); transform: scale(1.05); }
}

.contact-poetic-sub {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-top: 0.5rem;
}

.contact-email-card {
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.8rem;
  backdrop-filter: blur(5px);
}
body.theme-light .contact-email-card {
  background: rgba(0, 0, 0, 0.03);
  border: 1px solid rgba(0, 0, 0, 0.06);
}

.contact-email-label {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
  font-weight: 600;
}

.contact-email-value {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--accent-color);
  text-decoration: none;
  transition: all var(--transition-fast);
  letter-spacing: 0.5px;
}
.contact-email-value:hover {
  transform: scale(1.02);
  text-shadow: 0 0 12px var(--glow-bright);
}

.contact-copy-btn {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  padding: 0.45rem 1rem;
  border-radius: 20px;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  cursor: pointer;
  display: flex;
  align-items: center;
  transition: all var(--transition-fast);
}
.contact-copy-btn:hover {
  border-color: var(--accent-color);
  background: var(--glass-highlight);
  box-shadow: 0 0 10px var(--glow-color);
  transform: translateY(-1px);
}
.contact-copy-btn.copied {
  background: rgba(16, 185, 129, 0.15);
  border-color: #10b981;
  color: #10b981;
}

/* Help Center Modal Card */
.help-modal-card {
  position: relative;
  width: 90%;
  max-width: 900px;
  height: 80vh;
  max-height: 640px;
  background: rgba(15, 12, 23, 0.65);
  border: 1px solid var(--glass-border);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.8), 0 0 40px var(--glow-color);
  padding: 2.5rem;
  border-radius: 24px;
  transform: scale(0.92) translateY(15px);
  transition: transform var(--transition-medium), opacity var(--transition-medium);
  backdrop-filter: blur(15px);
  display: flex;
  flex-direction: column;
}
body.theme-light .help-modal-card {
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.1), 0 0 20px rgba(0, 0, 0, 0.05);
}

.help-modal-overlay.active .help-modal-card {
  transform: scale(1) translateY(0);
}

.help-modal-header {
  text-align: center;
  margin-bottom: 1.5rem;
  flex-shrink: 0;
}
.help-modal-header h3 {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.3rem;
}
.help-modal-header p {
  font-family: var(--font-sans);
  font-size: 0.82rem;
  color: var(--text-secondary);
}

/* Split Pane Layout */
.help-modal-body {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 2rem;
  flex: 1;
  overflow: hidden;
  min-height: 0;
}

/* Left Pane: Pathways */
.help-pathways-pane {
  border-right: 1px solid var(--glass-border);
  padding-right: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  overflow-y: auto;
}
body.theme-light .help-pathways-pane {
  border-color: rgba(0, 0, 0, 0.08);
}

.pane-title {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
  font-weight: 700;
  margin-bottom: 0.5rem;
}

.pathway-buttons-list {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.btn-pathway {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  padding: 0.75rem 1rem;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: 0.76rem;
  font-weight: 500;
  text-align: left;
  line-height: 1.4;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.btn-pathway:hover {
  background: var(--glass-highlight);
  border-color: var(--accent-color);
  color: var(--text-primary);
  transform: translateX(4px);
  box-shadow: 0 0 10px var(--glow-color);
}
.btn-pathway .highlight-speak {
  color: var(--accent-color);
  font-weight: 600;
  letter-spacing: 0.5px;
}

/* Right Pane: Conversational Chat */
.help-chat-pane {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  height: 100%;
}

.help-chat-log {
  flex: 1;
  overflow-y: auto;
  padding-right: 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  margin-bottom: 1rem;
}

/* Chat Message Bubbles */
.chat-message {
  display: flex;
  flex-direction: column;
  max-width: 80%;
  animation: bubbleIn 0.4s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

@keyframes bubbleIn {
  0% { opacity: 0; transform: translateY(10px) scale(0.96); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

.chat-message.system {
  align-self: flex-start;
}
.chat-message.system .chat-bubble {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  border-bottom-left-radius: 4px;
}
body.theme-light .chat-message.system .chat-bubble {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.06);
}

.chat-message.user {
  align-self: flex-end;
}
.chat-message.user .chat-bubble {
  background: rgba(99, 102, 241, 0.15);
  border: 1px solid rgba(99, 102, 241, 0.3);
  color: var(--text-primary);
  border-bottom-right-radius: 4px;
  box-shadow: 0 4px 15px rgba(99, 102, 241, 0.1);
}
body.theme-light .chat-message.user .chat-bubble {
  background: rgba(99, 102, 241, 0.1);
  border-color: rgba(99, 102, 241, 0.2);
}

.chat-bubble {
  padding: 0.9rem 1.1rem;
  border-radius: 16px;
  font-family: var(--font-sans);
  font-size: 0.82rem;
  line-height: 1.5;
  word-break: break-word;
}
.chat-bubble p {
  margin-bottom: 0.5rem;
}
.chat-bubble p:last-child {
  margin-bottom: 0;
}
.chat-bubble ul, .chat-bubble ol {
  margin-left: 1.2rem;
  margin-bottom: 0.5rem;
}

.chat-time {
  font-size: 0.65rem;
  color: var(--text-muted);
  margin-top: 0.3rem;
  padding: 0 0.4rem;
  align-self: flex-start;
}
.chat-message.user .chat-time {
  align-self: flex-end;
}

/* Typing Indicator */
.help-typing-indicator {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 1rem;
  align-self: flex-start;
  margin-bottom: 0.5rem;
}
.typing-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent-color);
  animation: typingBounce 1.4s infinite ease-in-out;
}
.typing-dot:nth-child(1) { animation-delay: 0s; }
.typing-dot:nth-child(2) { animation-delay: 0.2s; }
.typing-dot:nth-child(3) { animation-delay: 0.4s; }

.typing-label {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  color: var(--text-muted);
  margin-left: 0.4rem;
  font-style: italic;
}

@keyframes typingBounce {
  0%, 80%, 100% { transform: translateY(0); opacity: 0.4; }
  40% { transform: translateY(-4px); opacity: 1; }
}

/* Chat Input Form */
.help-chat-form {
  flex-shrink: 0;
}
.chat-input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  padding: 0.35rem 0.5rem 0.35rem 1rem;
  transition: all var(--transition-fast);
}
.chat-input-wrapper:focus-within {
  border-color: var(--accent-color);
  box-shadow: 0 0 15px var(--glow-color);
  background: rgba(0, 0, 0, 0.3);
}
body.theme-light .chat-input-wrapper {
  background: rgba(0, 0, 0, 0.02);
  border-color: rgba(0, 0, 0, 0.08);
}
body.theme-light .chat-input-wrapper:focus-within {
  background: rgba(0, 0, 0, 0.03);
}

.chat-input-field {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.8rem;
  padding: 0.4rem 0;
}
.chat-input-field::placeholder {
  color: var(--text-muted);
}

.chat-send-btn {
  background: var(--accent-color);
  border: none;
  outline: none;
  color: #fff;
  width: 32px;
  height: 32px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.chat-send-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 0 10px var(--glow-bright);
}
.chat-send-btn svg {
  width: 14px;
  height: 14px;
}

/* Inline Creator Ticket Form inside Chat */
.inline-ticket-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  padding: 1.25rem;
  margin: 0.5rem 0;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  animation: bubbleIn 0.4s cubic-bezier(0.25, 1, 0.5, 1) forwards;
  max-width: 100%;
}
body.theme-light .inline-ticket-card {
  background: rgba(0, 0, 0, 0.02);
  border-color: rgba(0, 0, 0, 0.06);
}

.ticket-header-title {
  font-family: var(--font-serif);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--accent-color);
  letter-spacing: 0.5px;
}

.ticket-field {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.ticket-field label {
  font-family: var(--font-sans);
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
  font-weight: 600;
}
.ticket-textarea {
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  padding: 0.6rem;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.78rem;
  line-height: 1.4;
  resize: none;
  height: 80px;
  outline: none;
  transition: all var(--transition-fast);
}
.ticket-textarea:focus, .ticket-input:focus {
  border-color: var(--accent-color);
  box-shadow: 0 0 8px var(--glow-color);
}
.ticket-input {
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  padding: 0.5rem 0.6rem;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.78rem;
  outline: none;
  transition: all var(--transition-fast);
}

.btn-ticket-submit {
  background: var(--accent-color);
  color: #fff;
  border: none;
  outline: none;
  padding: 0.6rem;
  border-radius: 8px;
  font-family: var(--font-sans);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-transform: uppercase;
}
.btn-ticket-submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 0 10px var(--glow-bright);
}
.btn-ticket-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Admin button inside Profile Card */
.profile-admin-btn {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  padding: 0.75rem 1rem;
  border-radius: 30px;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  width: 100%;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}
.profile-admin-btn:hover {
  border-color: var(--accent-color);
  background: var(--glass-highlight);
  box-shadow: 0 0 12px var(--glow-color);
  transform: translateY(-1px);
}
.admin-btn-icon {
  color: var(--accent-color);
  transition: transform var(--transition-medium);
}
.profile-admin-btn:hover .admin-btn-icon {
  transform: rotate(45deg);
}

/* Creator Inbox Console Modal Card */
.admin-inbox-modal-card {
  position: relative;
  width: 90%;
  max-width: 950px;
  height: 80vh;
  max-height: 640px;
  background: rgba(15, 12, 23, 0.65);
  border: 1px solid var(--glass-border);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.8), 0 0 40px var(--glow-color);
  padding: 2.5rem;
  border-radius: 24px;
  transform: scale(0.92) translateY(15px);
  transition: transform var(--transition-medium), opacity var(--transition-medium);
  backdrop-filter: blur(15px);
  display: flex;
  flex-direction: column;
}
body.theme-light .admin-inbox-modal-card {
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.1), 0 0 20px rgba(0, 0, 0, 0.05);
}

.admin-inbox-modal-overlay.active .admin-inbox-modal-card {
  transform: scale(1) translateY(0);
}

.admin-inbox-modal-header {
  text-align: center;
  margin-bottom: 1.5rem;
  flex-shrink: 0;
}
.admin-inbox-modal-header h3 {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.3rem;
}
.admin-inbox-modal-header p {
  font-family: var(--font-sans);
  font-size: 0.82rem;
  color: var(--text-secondary);
}

/* Admin Table Wrapper */
.admin-inbox-table-wrapper {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  background: rgba(0, 0, 0, 0.2);
}
body.theme-light .admin-inbox-table-wrapper {
  background: rgba(0, 0, 0, 0.01);
  border-color: rgba(0, 0, 0, 0.06);
}

.admin-inbox-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  color: var(--text-primary);
  text-align: left;
}

.admin-inbox-table th {
  position: sticky;
  top: 0;
  background: rgba(15, 12, 23, 0.95);
  padding: 0.85rem 1rem;
  font-weight: 600;
  color: var(--text-secondary);
  border-bottom: 1px solid var(--glass-border);
  text-transform: uppercase;
  font-size: 0.65rem;
  letter-spacing: 0.8px;
  z-index: 5;
}
body.theme-light .admin-inbox-table th {
  background: rgba(255, 255, 255, 0.95);
  border-bottom-color: rgba(0, 0, 0, 0.08);
}

.admin-inbox-table td {
  padding: 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
  vertical-align: top;
  line-height: 1.5;
}
body.theme-light .admin-inbox-table td {
  border-bottom-color: rgba(0, 0, 0, 0.03);
}

.admin-inbox-table tr:hover td {
  background: rgba(255, 255, 255, 0.01);
}
body.theme-light .admin-inbox-table tr:hover td {
  background: rgba(0, 0, 0, 0.005);
}

.admin-row-date {
  color: var(--text-muted);
  font-size: 0.7rem;
  white-space: nowrap;
}

.admin-row-contact {
  font-weight: 500;
  color: var(--text-primary);
  word-break: break-all;
}

.admin-row-desc {
  color: var(--text-secondary);
  word-break: break-word;
  white-space: pre-wrap;
}

/* Status Badges */
.status-badge {
  display: inline-block;
  padding: 0.2rem 0.5rem;
  border-radius: 12px;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.status-badge.status-pending {
  background: rgba(245, 158, 11, 0.12);
  color: #f59e0b;
  border: 1px solid rgba(245, 158, 11, 0.25);
}
.status-badge.status-resolved {
  background: rgba(16, 185, 129, 0.12);
  color: #10b981;
  border: 1px solid rgba(16, 185, 129, 0.25);
}

/* Admin Actions Row */
.admin-actions-cell {
  display: flex;
  gap: 0.4rem;
  align-items: center;
}

.btn-admin-action {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.btn-admin-action svg {
  width: 13px;
  height: 13px;
}
.btn-admin-action:hover {
  color: var(--text-primary);
  transform: translateY(-1px);
}
.btn-admin-action.btn-resolve:hover {
  border-color: #10b981;
  color: #10b981;
  background: rgba(16, 185, 129, 0.1);
  box-shadow: 0 0 8px rgba(16, 185, 129, 0.2);
}
.btn-admin-action.btn-erase:hover {
  border-color: #ef4444;
  color: #ef4444;
  background: rgba(239, 68, 68, 0.1);
  box-shadow: 0 0 8px rgba(239, 68, 68, 0.2);
}

/* Admin Empty State */
.admin-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
  text-align: center;
}
.admin-empty-state .empty-icon {
  font-size: 2.2rem;
  margin-bottom: 1rem;
  animation: floatEmpty 4s infinite ease-in-out;
}
.admin-empty-state p {
  font-family: var(--font-sans);
  font-size: 0.8rem;
  color: var(--text-muted);
  max-width: 280px;
  line-height: 1.5;
}

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

/* Responsive Overrides */
@media (max-width: 768px) {
  .help-modal-card {
    height: 90vh;
    max-height: none;
    padding: 1.5rem;
  }
  .help-modal-body {
    grid-template-columns: 1fr;
    gap: 1rem;
    overflow-y: auto;
  }
  .help-pathways-pane {
    border-right: none;
    border-bottom: 1px solid var(--glass-border);
    padding-right: 0;
    padding-bottom: 1rem;
    max-height: 160px;
    overflow-y: auto;
    flex-shrink: 0;
  }
  .admin-inbox-modal-card {
    height: 90vh;
    max-height: none;
    padding: 1.5rem;
  }
}

/* Premium Uniform Sizing for Picture Submissions/Cards (1000x800px Aspect Ratio) */
.sheet-artifact-image-container, 
.modal-image-container, 
.note-image-container, 
.artifact-image-container {
  max-width: 1000px !important;
  width: 100% !important;
  aspect-ratio: 1000 / 800 !important;
  height: auto !important;
  max-height: none !important;
}

.sheet-artifact-image-container img,
.modal-image-container img,
.modal-rendered-image,
.note-image-container img,
.note-rendered-image,
.artifact-image-container img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* Tone Button styles and animations */
.btn-tone {
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  color: var(--accent-color, #6366f1) !important;
  transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.btn-tone:hover {
  background: rgba(99, 102, 241, 0.12) !important;
  border-color: rgba(99, 102, 241, 0.3) !important;
  transform: translateY(-1px);
  box-shadow: 0 0 12px rgba(99, 102, 241, 0.25);
}

.letter-controls #btn-draft-tone {
  display: none !important;
}

.sentiment-inspiration.fade-out-transient {
  animation: fadeOutTransient 3.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  opacity: 1 !important;
}

@keyframes fadeOutTransient {
  0% {
    opacity: 1;
    filter: drop-shadow(0 0 8px var(--accent-color, #6366f1));
  }
  20% {
    opacity: 1;
  }
  100% {
    opacity: 0.9; /* Back to original high-contrast state */
    filter: none;
  }
}

/* Journal Flex Ordering to place image submit under templates */
.paper-sheet.format-journal {
  padding-top: 1.25rem !important; /* Reduce top padding from 2.5rem to 1.25rem */
  gap: 0.75rem !important; /* Tighten flex gap from 1.5rem to 0.75rem */
}

.paper-sheet.format-journal #journal-design-palette {
  order: 1;
  margin-bottom: 0.25rem !important; /* Compact margin from 1.2rem */
}
.paper-sheet.format-journal #journal-templates-container {
  order: 2;
  margin-top: 0 !important;
  margin-bottom: 0.25rem !important; /* Compact margin from 1.2rem */
}
.paper-sheet.format-journal .sheet-artifact-frame {
  order: 3;
}
.paper-sheet.format-journal #journal-visual-sheet {
  order: 4;
}

/* Flex layout ordering for letters and poetry to place design palette at the top */
.paper-sheet.format-letter,
.paper-sheet.format-poem {
  padding-top: 1.25rem !important;
  gap: 0.75rem !important;
}

.paper-sheet.format-letter #journal-design-palette,
.paper-sheet.format-poem #journal-design-palette,
.paper-sheet.format-art #journal-design-palette {
  order: 1;
  margin-bottom: 0.25rem !important;
}

.paper-sheet.format-letter #letter-templates-container,
.paper-sheet.format-poem #poetry-templates-container {
  order: 2;
  margin-top: 0 !important;
  margin-bottom: 0.25rem !important;
}

.paper-sheet.format-letter .sheet-title-label,
.paper-sheet.format-poem .sheet-title-label,
.paper-sheet.format-art .sheet-title-label {
  order: 3;
  margin-top: 0.5rem !important;
}

.paper-sheet.format-letter #letter-title,
.paper-sheet.format-poem #letter-title,
.paper-sheet.format-art #letter-title {
  order: 4;
  margin-top: 0 !important;
}

.paper-sheet.format-letter #letter-body,
.paper-sheet.format-poem #letter-body,
.paper-sheet.format-art #letter-body {
  order: 5;
}

.paper-sheet.format-letter .sentiment-inspiration,
.paper-sheet.format-poem .sentiment-inspiration,
.paper-sheet.format-art .sentiment-inspiration {
  order: 6;
}

.paper-sheet.format-journal .sentiment-inspiration {
  order: 5;
}

/* Tighten all visual journal template header spacing */
.paper-sheet.format-journal .blank-header,
.paper-sheet.format-journal .bottle-header,
.paper-sheet.format-journal .burn-header,
.paper-sheet.format-journal .mirror-header,
.paper-sheet.format-journal .rain-header,
.paper-sheet.format-journal .obituary-header,
.paper-sheet.format-journal .museum-header,
.paper-sheet.format-journal .moon-header,
.paper-sheet.format-journal .train-header,
.paper-sheet.format-journal .things-header {
  padding-bottom: 0.35rem !important; /* Compact from 0.8rem */
  margin-bottom: 0.75rem !important; /* Compact from 1.5rem */
}

/* Our Story Modal Card Layout */
.story-modal-card {
  position: relative;
  width: 90%;
  max-width: 640px;
  max-height: 85vh;
  background: rgba(15, 12, 23, 0.65);
  border: 1px solid var(--glass-border);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.8), 0 0 40px var(--glow-color);
  padding: 3rem 2.5rem;
  border-radius: 24px;
  transform: scale(0.92) translateY(15px);
  transition: transform var(--transition-medium), opacity var(--transition-medium);
  backdrop-filter: blur(15px);
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

body.theme-light .story-modal-card {
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.1), 0 0 20px rgba(0, 0, 0, 0.05);
}

.story-modal-overlay.active .story-modal-card {
  transform: scale(1) translateY(0);
}

.story-modal-header {
  text-align: center;
  margin-bottom: 1.5rem;
  flex-shrink: 0;
}

.story-modal-header h3 {
  font-family: var(--font-serif);
  font-size: 1.8rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.3rem;
}

.story-poetic-sub {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-top: 0.5rem;
}

.story-icon-glow {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--accent-color);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  box-shadow: 0 0 20px var(--glow-color);
  animation: pulseGlow 3s infinite ease-in-out;
}

.story-icon-glow svg {
  width: 26px;
  height: 26px;
}

.story-content {
  overflow-y: auto;
  padding-right: 1.25rem;
  text-align: left;
  line-height: 1.7;
  color: var(--text-secondary);
  font-size: 0.95rem;
  font-family: var(--font-serif);
}

.story-content p {
  margin-bottom: 1.25rem;
}

.story-content p strong {
  color: var(--text-primary);
}

.story-content ul {
  list-style: none;
  padding-left: 0;
  margin-bottom: 1.25rem;
}

.story-content li {
  position: relative;
  padding-left: 1.5rem;
  margin-bottom: 0.85rem;
  font-family: var(--font-sans);
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

.story-content li::before {
  content: "✦";
  position: absolute;
  left: 0;
  color: var(--accent-color);
  font-size: 0.8rem;
}

.story-content li strong {
  color: var(--text-primary);
}

.story-signature {
  font-style: italic;
  color: var(--accent-color);
  text-align: center;
  margin-top: 1.5rem;
  font-size: 1rem;
}

/* Scrollbar styling for story content */
.story-content::-webkit-scrollbar {
  width: 6px;
}

.story-content::-webkit-scrollbar-track {
  background: transparent;
}

.story-content::-webkit-scrollbar-thumb {
  background: var(--glass-border);
  border-radius: 3px;
}

.story-content::-webkit-scrollbar-thumb:hover {
  background: var(--accent-color);
}

/* Mobile responsive overlay overrides */
@media (max-width: 768px) {
  .story-modal-card {
    height: 90vh;
    max-height: none;
    padding: 2.5rem 1.5rem;
  }
}

/* ==========================================================================
   FLOODRA CHATGPT-INSPIRED COLLAPSIBLE SIDEBAR SYSTEM
   ========================================================================== */

.floodra-sidebar {
  width: 280px;
  height: 100vh;
  background: rgba(11, 7, 18, 0.65);
  border-right: 1px solid rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(25px);
  -webkit-backdrop-filter: blur(25px);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  transition: width 0.35s cubic-bezier(0.4, 0, 0.2, 1), transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease;
  z-index: 100;
  overflow: hidden;
  opacity: 1;
  box-sizing: border-box;
  box-shadow: 4px 0 24px rgba(0, 0, 0, 0.15);
}

.theme-light .floodra-sidebar {
  background: rgba(246, 244, 238, 0.85);
  border-right-color: rgba(0, 0, 0, 0.06);
  box-shadow: 4px 0 24px rgba(0, 0, 0, 0.05);
}

.floodra-sidebar.collapsed {
  width: 0 !important;
  transform: translateX(-100%);
  opacity: 0;
  border-right: none;
  pointer-events: none;
}

/* Hide sidebar completely on Gatehouse Portal view */
.paper-sheet.format-journal .floodra-sidebar,
body:not(.sidebar-visible) .floodra-sidebar {
  width: 0 !important;
  transform: translateX(-100%);
  opacity: 0;
  border-right: none;
  pointer-events: none;
}

/* Sidebar Header */
.sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem 1.25rem 0.8rem 1.25rem;
  flex-shrink: 0;
}

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.sidebar-brand-icon {
  width: 22px;
  height: 22px;
  background: var(--accent-color);
  mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2L2 22h20L12 2z'/%3E%3C/svg%3E") no-repeat center;
  -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2L2 22h20L12 2z'/%3E%3C/svg%3E") no-repeat center;
  mask-size: contain;
  -webkit-mask-size: contain;
  filter: drop-shadow(0 0 4px var(--accent-color));
}

.sidebar-brand h2 {
  font-family: var(--font-sans);
  font-size: 0.95rem;
  letter-spacing: 3px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
  text-transform: uppercase;
}

.sidebar-collapse-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0.35rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: all var(--transition-fast);
}

.sidebar-collapse-btn:hover {
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.05);
}

.theme-light .sidebar-collapse-btn:hover {
  background: rgba(0, 0, 0, 0.04);
}

.sidebar-collapse-btn svg {
  width: 18px;
  height: 18px;
}

/* Sidebar Toggle Trigger in Header HUD */
.sidebar-toggle-btn {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0.45rem;
  display: none; /* hidden on portal view */
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  margin-right: 0.8rem;
  transition: all var(--transition-fast);
}

header.visible .sidebar-toggle-btn {
  display: flex;
}

.sidebar-toggle-btn:hover {
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.05);
  transform: scale(1.05);
}

.theme-light .sidebar-toggle-btn:hover {
  background: rgba(0, 0, 0, 0.04);
}

.sidebar-toggle-btn svg {
  width: 20px;
  height: 20px;
}

/* Action button container */
.sidebar-action-container {
  padding: 0.5rem 1.25rem;
  flex-shrink: 0;
}

.sidebar-new-expr-btn {
  width: 100%;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.sidebar-new-expr-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.1);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.theme-light .sidebar-new-expr-btn {
  background: rgba(0, 0, 0, 0.015);
  border-color: rgba(0, 0, 0, 0.06);
}

.theme-light .sidebar-new-expr-btn:hover {
  background: rgba(0, 0, 0, 0.04);
  border-color: rgba(0, 0, 0, 0.1);
}

.sidebar-new-expr-btn svg {
  width: 16px;
  height: 16px;
  color: var(--accent-color);
}

/* Search Box */
.sidebar-search-box {
  padding: 0.5rem 1.25rem 0.8rem 1.25rem;
  flex-shrink: 0;
}

.sidebar-search-inner {
  position: relative;
  width: 100%;
}

.sidebar-search-inner .search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  color: var(--text-muted);
  pointer-events: none;
}

.sidebar-search-inner input {
  width: 100%;
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 8px;
  padding: 0.5rem 0.75rem 0.5rem 2.2rem;
  font-size: 0.8rem;
  font-family: var(--font-sans);
  color: var(--text-primary);
  outline: none;
  transition: all var(--transition-fast);
  box-sizing: border-box;
}

.sidebar-search-inner input:focus {
  border-color: var(--accent-color);
  background: rgba(0, 0, 0, 0.35);
  box-shadow: 0 0 8px rgba(99, 102, 241, 0.2);
}

.theme-light .sidebar-search-inner input {
  background: rgba(255, 255, 255, 0.75);
  border-color: rgba(0, 0, 0, 0.08);
  color: var(--text-primary);
}

.theme-light .sidebar-search-inner input:focus {
  background: #ffffff;
  border-color: var(--accent-color);
}

/* Scrollable content area */
.sidebar-scrollable-content {
  flex: 1;
  overflow-y: auto;
  padding: 0 1.25rem 1.5rem 1.25rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.08) transparent;
}

.theme-light .sidebar-scrollable-content {
  scrollbar-color: rgba(0, 0, 0, 0.1) transparent;
}

.sidebar-scrollable-content::-webkit-scrollbar {
  width: 4px;
}

.sidebar-scrollable-content::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.05);
  border-radius: 2px;
}

.theme-light .sidebar-scrollable-content::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.08);
}

.sidebar-section {
  margin-bottom: 1.5rem;
}

.sidebar-section-header {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text-muted);
  margin-bottom: 0.6rem;
}

/* Navigation Lists */
.sidebar-nav-list, .sidebar-submenu, .sidebar-history-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sidebar-nav-list > li {
  margin-bottom: 0.35rem;
}

.sidebar-nav-item {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 0.75rem;
  border-radius: 8px;
  color: var(--text-secondary);
  text-decoration: none;
  font-family: var(--font-sans);
  font-size: 0.84rem;
  font-weight: 500;
  transition: all var(--transition-fast);
}

.sidebar-nav-item:hover {
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-primary);
}

.theme-light .sidebar-nav-item:hover {
  background: rgba(0, 0, 0, 0.025);
}

.sidebar-nav-item.active {
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-primary);
  font-weight: 600;
  border-left: 2px solid var(--accent-color);
}

.theme-light .sidebar-nav-item.active {
  background: rgba(0, 0, 0, 0.04);
}

.sidebar-nav-item .nav-icon {
  font-size: 1rem;
  display: inline-block;
  width: 20px;
  text-align: center;
}

/* Quick access template submenu */
.sidebar-submenu {
  padding-left: 1.25rem;
  margin-top: 0.25rem;
  border-left: 1px solid rgba(255, 255, 255, 0.04);
  margin-left: 1.35rem;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.theme-light .sidebar-submenu {
  border-left-color: rgba(0, 0, 0, 0.05);
}

.sidebar-submenu-item {
  display: block;
  padding: 0.35rem 0.6rem;
  border-radius: 6px;
  color: var(--text-muted);
  font-family: var(--font-sans);
  font-size: 0.75rem;
  text-decoration: none;
  transition: all var(--transition-fast);
}

.sidebar-submenu-item:hover {
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.02);
}

.theme-light .sidebar-submenu-item:hover {
  background: rgba(0, 0, 0, 0.015);
}

.sidebar-submenu-item.active {
  color: var(--accent-color) !important;
  font-weight: 600;
  background: rgba(99, 102, 241, 0.06);
}

/* History List */
.sidebar-history-list li {
  padding: 0.45rem 0.75rem;
  border-radius: 6px;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  color: var(--text-secondary);
  cursor: pointer;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  transition: all var(--transition-fast);
}

.sidebar-history-list li:hover {
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-primary);
}

.theme-light .sidebar-history-list li:hover {
  background: rgba(0, 0, 0, 0.025);
}

.sidebar-history-list li.history-empty {
  cursor: default;
  color: var(--text-muted);
  font-style: italic;
  font-size: 0.75rem;
  padding-left: 0.75rem;
}

.sidebar-history-list li.history-empty:hover {
  background: transparent;
  color: var(--text-muted);
}

.sidebar-history-list li .history-date {
  display: block;
  font-size: 0.65rem;
  color: var(--text-muted);
  margin-top: 0.15rem;
}

/* Recommendation Card */
.sidebar-recommend-card {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.02) 0%, rgba(255, 255, 255, 0.005) 100%);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 10px;
  padding: 0.8rem;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.theme-light .sidebar-recommend-card {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.6) 0%, rgba(255, 255, 255, 0.2) 100%);
  border-color: rgba(0, 0, 0, 0.04);
}

.recommend-title {
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: bold;
  text-transform: uppercase;
  color: var(--accent-color);
  margin-bottom: 0.35rem;
  letter-spacing: 0.5px;
}

.recommend-body {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  line-height: 1.4;
  color: var(--text-secondary);
}

/* User Profile Widget Footer */
.sidebar-footer {
  padding: 1rem 1.25rem;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
  background: rgba(0, 0, 0, 0.15);
  flex-shrink: 0;
}

.theme-light .sidebar-footer {
  border-top-color: rgba(0, 0, 0, 0.06);
  background: rgba(0, 0, 0, 0.015);
}

.sidebar-user-widget {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  position: relative;
}

.user-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  transition: transform 0.25s ease;
}

.theme-light .user-avatar {
  background: rgba(0, 0, 0, 0.02);
  border-color: rgba(0, 0, 0, 0.06);
}

.sidebar-user-widget:hover .user-avatar {
  transform: scale(1.08);
}

.user-info {
  flex: 1;
  overflow: hidden;
}

.user-name {
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: bold;
  color: var(--text-primary);
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.user-mood-status {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  color: var(--text-muted);
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.user-badge {
  font-family: var(--font-sans);
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  background: var(--accent-color);
  color: #0b0711;
  padding: 0.15rem 0.4rem;
  border-radius: 4px;
  letter-spacing: 0.5px;
}

/* Sidebar Responsive Mechanics for Mobile / Tablet */
@media (max-width: 768px) {
  .floodra-sidebar {
    position: absolute;
    left: 0;
    top: 0;
    height: 100vh;
    width: 280px !important;
    transform: translateX(-100%);
    opacity: 0;
    box-shadow: 8px 0 30px rgba(0, 0, 0, 0.6);
    pointer-events: none;
  }

  /* When mobile active, override collapsed translateX and opacity */
  body.sidebar-mobile-active .floodra-sidebar {
    transform: translateX(0) !important;
    opacity: 1 !important;
    pointer-events: all !important;
    width: 280px !important;
  }

  .sidebar-overlay {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 98;
    animation: fadeIn var(--transition-fast) ease-out;
  }

  body.sidebar-mobile-active .sidebar-overlay {
    display: block;
  }
}

/* ==========================================================================
   MODERN MINIMALIST WEBSITE FOOTER
   ========================================================================== */
.app-footer {
  margin-top: auto;
  flex-shrink: 0;
  width: 100%;
  border-top: 1px solid var(--glass-border);
  padding: 3rem 0 2rem 0; /* Flush alignment with container content edges */
  box-sizing: border-box;
  z-index: 10;
  transition: border-color 0.35s ease;
}

body.theme-light .app-footer {
  border-top-color: rgba(31, 36, 26, 0.1);
}

.footer-container {
  max-width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.footer-columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 2rem;
}

.footer-column h4 {
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 0.82rem;
  font-weight: 700;
  margin-bottom: 1rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  opacity: 0.85;
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.footer-links a,
.footer-links button {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: var(--text-secondary);
  text-decoration: none;
  font-family: var(--font-sans);
  font-size: 0.84rem;
  transition: all var(--transition-fast);
  display: inline-block;
  text-align: left;
}

.footer-links a:hover,
.footer-links button:hover {
  color: var(--accent-color);
  transform: translateX(3px);
  text-shadow: 0 0 6px var(--glow-color);
}

.subscribe-pill-btn {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  padding: 0.5rem 1.25rem;
  border-radius: 9999px;
  font-family: var(--font-sans);
  font-size: 0.82rem;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: all var(--transition-fast);
  backdrop-filter: blur(4px);
}

.subscribe-pill-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: var(--accent-color);
  box-shadow: 0 0 12px var(--glow-color);
  transform: translateY(-1px);
}

.subscribe-pill-btn:active {
  transform: translateY(0);
}

body.theme-light .subscribe-pill-btn {
  background: rgba(0, 0, 0, 0.02);
  border-color: rgba(31, 36, 26, 0.15);
  color: var(--text-primary);
}

body.theme-light .subscribe-pill-btn:hover {
  background: rgba(0, 0, 0, 0.05);
  border-color: var(--accent-color);
}

.footer-socials {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 1rem;
}

.footer-socials a {
  color: var(--text-secondary);
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}

.footer-socials a:hover {
  color: var(--accent-color);
  transform: scale(1.15);
  filter: drop-shadow(0 0 4px var(--accent-color));
}

.social-icon {
  width: 20px;
  height: 20px;
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  padding-top: 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}

body.theme-light .footer-bottom {
  border-top-color: rgba(31, 36, 26, 0.08);
}

.footer-copyright {
  color: var(--text-secondary);
  font-family: var(--font-sans);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 2px;
  text-align: center;
}

.footer-tagline {
  color: var(--text-muted);
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-style: italic;
  text-align: center;
  letter-spacing: 0.5px;
}

/* Purpose Modal Overlay */
.purpose-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(11, 7, 18, 0.5);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.purpose-modal-overlay.active {
  opacity: 1;
  pointer-events: all;
}

.purpose-modal-card {
  width: 90%;
  max-width: 580px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 20px;
  padding: 3rem 2.5rem;
  box-shadow: var(--card-shadow);
  position: relative;
  transform: translateY(20px);
  transition: transform 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

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

body.theme-light .purpose-modal-overlay {
  background: rgba(31, 36, 26, 0.3);
}

body.theme-light .purpose-modal-card {
  background: rgba(255, 255, 255, 0.9);
  border-color: rgba(31, 36, 26, 0.15);
}

.purpose-modal-header {
  text-align: center;
  margin-bottom: 2rem;
}

.purpose-icon-glow {
  width: 54px;
  height: 54px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem auto;
  color: var(--accent-color);
  box-shadow: 0 0 20px rgba(99, 102, 241, 0.1);
}

body.theme-light .purpose-icon-glow {
  background: rgba(31, 36, 26, 0.02);
  border-color: rgba(31, 36, 26, 0.08);
  box-shadow: none;
}

.purpose-icon-glow svg {
  width: 24px;
  height: 24px;
}

.purpose-modal-header h3 {
  font-family: var(--font-sans);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
  letter-spacing: 0.5px;
}

.purpose-poetic-sub {
  font-size: 0.86rem;
  color: var(--text-secondary);
  font-style: italic;
}

.purpose-content {
  line-height: 1.7;
  color: var(--text-secondary);
  font-size: 0.95rem;
  font-family: var(--font-serif);
}

.purpose-content p {
  margin-bottom: 1.25rem;
}

.purpose-content p strong {
  color: var(--text-primary);
}

/* Responsive Overrides */
@media (max-width: 768px) {
  .app-footer {
    padding: 2rem 0 1.5rem 0;
  }
  .footer-columns {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 1.5rem;
  }
  .footer-links a:hover {
    transform: none;
  }
  .footer-socials {
    justify-content: center;
  }
  .purpose-modal-card {
    padding: 2.5rem 1.5rem;
  }
}

/* ==========================================================================
   HIGH-FIDELITY MOBILE & TABLET DEVICE RESPONSIVENESS OVERRIDES
   ========================================================================== */

/* 1. Global View paddings and general layouts */
@media (max-width: 768px) {
  .view-section {
    padding: 1.5rem 1.25rem 7.5rem 1.25rem !important;
  }
}

/* 2. Gatehouse (Portal screen) */
@media (max-width: 768px) {
  .portal-welcome h2 {
    font-size: 3rem !important;
    letter-spacing: 4px !important;
    text-indent: 4px !important;
  }
}

@media (max-width: 480px) {
  .portal-welcome h2 {
    font-size: 2.2rem !important;
    letter-spacing: 2px !important;
    text-indent: 2px !important;
  }
}

@media (max-width: 600px) {
  .theme-selector-grid {
    flex-direction: column !important;
    width: 100% !important;
    gap: 0.75rem !important;
  }
  .theme-btn {
    width: 100% !important;
    justify-content: center !important;
    padding: 0.85rem 1.25rem !important;
  }
  .portal-welcome {
    width: 100% !important;
    box-sizing: border-box !important;
    padding: 0.5rem 1rem 2rem 1rem !important;
  }
}

/* 3. Writer's Salon (Desk Screen) */
@media (max-width: 600px) {
  .desk-header {
    flex-direction: column !important;
    align-items: center !important;
    gap: 1.2rem !important;
    text-align: center !important;
  }
  .desk-header h2 {
    font-size: 1.5rem !important;
  }
}

@media (max-width: 480px) {
  .format-selector {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 0.35rem !important;
    padding: 0.4rem !important;
    width: 100% !important;
  }
  .format-btn {
    padding: 0.4rem 0.6rem !important;
    font-size: 0.75rem !important;
    flex: 1 1 calc(50% - 0.35rem) !important;
    text-align: center !important;
  }
}

@media (max-width: 768px) {
  .letter-controls {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 1.2rem !important;
    padding: 1.25rem 1.5rem !important;
  }
  .release-group {
    flex-direction: column !important;
    gap: 0.6rem !important;
    width: 100% !important;
  }
  .release-btn {
    width: 100% !important;
    justify-content: center !important;
    padding: 0.75rem 1.2rem !important;
  }
  .tag-selector-wrapper {
    width: 100% !important;
  }
  .tag-select {
    width: 100% !important;
    box-sizing: border-box !important;
    text-align: center !important;
  }
}

/* 4. Hearth (Circle Screen) */
@media (max-width: 600px) {
  .random-inspiration-container {
    flex-direction: column !important;
    gap: 0.75rem !important;
    margin-top: 1rem !important;
  }
  .random-inspiration-card {
    padding: 0.8rem 1rem !important;
  }
}

@media (max-width: 480px) {
  .note-creator-box {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0.75rem !important;
  }
  .note-input {
    width: 100% !important;
    box-sizing: border-box !important;
    height: 60px !important;
  }
  .note-submit-btn {
    width: 100% !important;
    padding: 0.8rem 1.5rem !important;
  }
}

@media (max-width: 580px) {
  .notes-pinboard,
  .recent-pins-grid {
    grid-template-columns: 1fr !important;
    gap: 1.2rem !important;
  }
  .hearth-chamber {
    padding: 1.5rem 1.25rem !important;
  }
}

@media (max-width: 480px) {
  .sticky-note {
    transform: none !important; /* Reset tilt on narrow screens to prevent edges from overlapping screen bounds */
  }
  .sticky-note:hover {
    transform: translateY(-4px) scale(1.01) !important;
  }
}

/* 5. Archive Screen */
@media (max-width: 580px) {
  .archive-cards-grid {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
  }
  .archive-filters-row {
    grid-template-columns: 1fr !important;
    padding: 1rem !important;
    gap: 0.8rem !important;
  }
}

@media (max-width: 900px) {
  .archive-sidebar-column {
    position: static !important;
    max-width: none !important;
    width: 100% !important;
  }
}

/* 6. Modals & Overlays */
@media (max-width: 580px) {
  .subscribe-modal-card,
  .auth-modal-card,
  .secrets-modal-card,
  .mood-release-modal-card,
  .contact-modal-card,
  .admin-inbox-modal-card,
  .story-modal-card,
  .letter-modal-card {
    width: 92% !important;
    max-width: none !important;
    padding: 2.2rem 1.25rem !important;
    border-radius: 20px !important;
  }
  
  .letter-modal-card .modal-header {
    padding: 1.25rem 1.25rem !important;
  }
  .letter-modal-card .modal-body {
    padding: 1.5rem 1.25rem !important;
    font-size: 1.05rem !important;
    line-height: 1.8rem !important;
    max-height: 280px !important; /* Cap body height on phones to prevent clipping buttons */
  }
  .letter-modal-card .modal-footer {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 1.2rem !important;
    padding: 1.25rem 1.25rem !important;
  }
  .support-actions-wrapper {
    flex-direction: column !important;
    gap: 0.6rem !important;
    width: 100% !important;
  }
  .support-btn {
    width: 100% !important;
    justify-content: center !important;
    padding: 0.65rem 1.25rem !important;
  }
}

@media (max-width: 768px) {
  .sidebar-overlay {
    position: fixed !important; /* Ensure it blocks scrolling clicks across the whole document height */
    width: 100vw !important;
    height: 100vh !important;
  }
}

/* 7. HUD & Floating panels — audio panel reposition on very small screens */
@media (max-width: 480px) {
  .brand h1 {
    display: none !important;
  }
  .audio-panel {
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    top: 4.5rem !important;
    width: 90% !important;
    max-width: 280px !important;
  }
}

@media (max-width: 580px) {
  #release-options-menu {
    right: 50% !important;
    transform: translateX(50%) !important;
    bottom: 5.5rem !important;
    width: 90% !important;
    max-width: 240px !important;
  }
}

/* ==========================================
   RESPONSIVE LAYOUT AND OVERFLOW FIXES
   ========================================== */

/* 1. Universal Support Circle Selector (Hearth Page) Mobile/Tablet Styles */
@media (max-width: 768px) {
  .circle-list-horizontal {
    top: -1.5rem !important; /* Align with mobile view-section padding */
    padding: 8px 4px !important;
    gap: 0.75rem !important;
  }
  .circle-btn {
    min-width: 170px !important;
    padding: 0.6rem 1rem !important;
  }
  .circle-name {
    font-size: 0.95rem !important;
  }
  .circle-pop {
    font-size: 0.7rem !important;
  }
}

/* 2. Text Editor & Companion Card (Feather/Candle/Dandelion) Layout Responsiveness */
@media (max-width: 1024px) {
  /* Override global margin-right on text editors to prevent extreme squishing */
  .letter-body {
    margin-right: 0 !important;
  }
  
  /* Reset journal-specific left margin as well for a centered screen balance */
  .paper-sheet.format-journal .letter-body {
    margin-left: 0 !important;
  }
}

/* Tablet layout: scale and tuck companion card to the side */
@media (min-width: 601px) and (max-width: 1024px) {
  .dandelion-core-container {
    top: 2rem !important;
    right: 2rem !important;
    transform: scale(0.65) !important;
    transform-origin: top right !important;
  }
  .letter-body {
    margin-right: 9rem !important; /* Provide clearance for the 0.65 scaled card */
  }
}

/* Mobile layout: center companion card at the top, allowing full-width writing below with minimal vertical space */
@media (max-width: 600px) {
  .dandelion-core-container {
    position: relative !important;
    top: 0 !important;
    right: auto !important;
    margin: 0.1rem auto -0.4rem auto !important; /* Tiny top margin, negative bottom margin to pull text up */
    width: 80px !important; /* Reduced from 100px */
    height: 100px !important; /* Reduced from 130px */
    z-index: 5 !important;
    pointer-events: none !important;
    transform: scale(0.48) !important; /* Scaled down further to 0.48 */
    transform-origin: top center !important;
  }
  
  /* Artistic Release specific ultra-small companion spacing to maximize canvas */
  .paper-sheet.format-art .dandelion-core-container {
    position: relative !important;
    top: 0 !important;
    right: auto !important;
    margin: 0.05rem auto -0.8rem auto !important; /* Extremely small margins to pull writing up */
    width: 70px !important; /* Even narrower */
    height: 50px !important; /* Extremely small vertical layout height of 50px */
    z-index: 5 !important;
    pointer-events: none !important;
    transform: scale(0.32) !important; /* Highly compressed to 0.32 scale */
    transform-origin: top center !important;
    opacity: 1 !important;
  }

  .dandelion-core-container .candle-glass,
  .dandelion-core-container .feather-glass,
  .dandelion-core-container .dandelion-glass {
    background: rgba(10, 8, 16, 0.72) !important; /* Dark glass background to prevent crashing with paper backgrounds */
    border-color: rgba(255, 255, 255, 0.18) !important; /* High contrast border */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.35) !important;
  }

  .paper-sheet.format-art .dandelion-glass {
    background: rgba(10, 8, 16, 0.72) !important; /* Dark glass background to prevent crashing with paper backgrounds */
    border-color: rgba(255, 255, 255, 0.18) !important; /* High contrast border */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.35) !important;
    border-radius: 12px 12px 0 0 !important;
    width: 32px !important;
    height: 100px !important;
    display: block !important;
  }
}

/* 3. stationery/design palette toolbar responsive grid */
@media (max-width: 480px) {
  .journal-design-palette {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0.8rem !important;
    padding: 0.8rem 1rem !important;
  }
  .palette-section {
    justify-content: space-between !important;
  }
}

/* 4. Moon Phase text hiding on narrow viewports */
@media (max-width: 580px) {
  .moon-phase-btn .phase-name {
    display: none !important;
  }
}

/* 5. Last Train Home template row split responsive */
@media (max-width: 768px) {
  .train-row-split {
    grid-template-columns: 1fr !important;
  }
}

/* 6. Universal Scrollable & Safe Alignment Modals for Mobile & Tablet */
.letter-modal-overlay,
.subscribe-modal-overlay,
.auth-modal-overlay,
.secrets-modal-overlay,
.alert-modal-overlay,
.mood-release-modal-overlay,
.contact-modal-overlay,
.help-modal-overlay,
.admin-inbox-modal-overlay,
.story-modal-overlay,
.purpose-modal-overlay {
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}

@media (max-width: 768px) {
  .letter-modal-overlay,
  .subscribe-modal-overlay,
  .auth-modal-overlay,
  .secrets-modal-overlay,
  .alert-modal-overlay,
  .mood-release-modal-overlay,
  .contact-modal-overlay,
  .help-modal-overlay,
  .admin-inbox-modal-overlay,
  .story-modal-overlay,
  .purpose-modal-overlay {
    align-items: flex-start !important;
    padding: 2rem 0 !important;
  }
}



