/* ============================================
   THE LIVING STORYBOOK — Main Stylesheet
   Design System: "The Living Storybook"
   ============================================ */

/* ── Design Tokens ── */
:root {
  --surface: #eff8fe;
  --surface-dim: #c8d7df;
  --surface-container-lowest: #ffffff;
  --surface-container-low: #e7f1f8;
  --surface-container: #dfeaf1;
  --surface-container-high: #d9e4ec;
  --surface-container-highest: #d1dfe7;

  --primary: #005f9b;
  --primary-container: #5cb1ff;
  --on-primary: #ffffff;
  --on-primary-container: #002e4d;

  --secondary: #6d5a00;
  --secondary-container: #fad538;
  --secondary-fixed: #fad538;
  --on-secondary-container: #5a4a00;

  --tertiary: #7b5ea7;
  --tertiary-container: #e8d8ff;

  --error: #ba1a1a;
  --error-container: #ffdad6;
  --on-error: #ffffff;

  --on-background: #273034;
  --on-surface: #273034;
  --on-surface-variant: #5a6268;
  --outline-variant: #a5aeb4;

  --font-family: 'Plus Jakarta Sans', sans-serif;

  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem;
  --space-4: 1rem; --space-5: 1.25rem; --space-6: 1.5rem;
  --space-8: 2.75rem; --space-10: 3.5rem; --space-12: 4rem;

  --radius-sm: 0.5rem; --radius-md: 1rem; --radius-lg: 2rem;
  --radius-xl: 3rem; --radius-full: 9999px;

  --shadow-ambient: 0 8px 32px rgba(39, 48, 52, 0.06);
  --shadow-float: 0 12px 40px rgba(39, 48, 52, 0.08);
  --ghost-border: rgba(165, 174, 180, 0.15);
}

/* ── Reset ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-family);
  background: var(--surface);
  color: var(--on-surface);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
h1,h2,h3,h4,h5,h6,p,span,label { color: var(--on-surface); }

/* ── Typography ── */
.display-lg { font-size: 3.5rem; font-weight: 800; line-height: 1.1; letter-spacing: -0.02em; }
.display-md { font-size: 2.5rem; font-weight: 800; line-height: 1.15; }
.headline { font-size: 2rem; font-weight: 700; line-height: 1.2; }
.title-lg { font-size: 1.5rem; font-weight: 700; }
.title-md { font-size: 1.25rem; font-weight: 700; line-height: 1.3; }
.body-lg { font-size: 1rem; font-weight: 400; line-height: 1.7; }
.body-md { font-size: 0.9rem; font-weight: 400; line-height: 1.6; color: var(--on-surface-variant); }
.label { font-size: 0.8rem; font-weight: 500; letter-spacing: 0.04em; color: var(--on-surface-variant); }
.subtitle { color: var(--on-surface-variant); max-width: 480px; }

/* ── Layout ── */
.container { max-width: 960px; margin: 0 auto; padding: 0 var(--space-6); }
.section-header { text-align: center; margin-bottom: var(--space-10); }
.section-header .subtitle { margin: var(--space-3) auto 0; }
.section-cta { text-align: center; margin-top: var(--space-8); }
.centered { justify-content: center; }

/* ── Flash Messages ── */
.flash-message {
  position: fixed; top: 5.5rem; left: 50%; transform: translateX(-50%);
  z-index: 200; display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-full);
  font-weight: 600; font-size: 0.9rem;
  box-shadow: var(--shadow-float);
  animation: slideDown 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  max-width: 90%;
}
.flash-success { background: #d4edda; color: #155724; }
.flash-error { background: #ffdad6; color: #ba1a1a; }
.flash-warning { background: #fff3cd; color: #856404; }
.flash-info { background: var(--surface-container-lowest); color: var(--on-surface); }
.flash-close { background: none; border: none; font-size: 1.1rem; cursor: pointer; padding: 0 var(--space-2); opacity: 0.6; }
.flash-close:hover { opacity: 1; }

/* ── Nav ── */
.nav-glass {
  position: fixed; top: var(--space-4); left: 50%; transform: translateX(-50%);
  width: min(92%, 920px); z-index: 100;
  background: rgba(92, 177, 255, 0.6);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius-full);
  padding: var(--space-3) var(--space-5);
  box-shadow: var(--shadow-float);
  border: 1px solid var(--ghost-border);
  animation: slideDown 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
  transition: padding 0.3s, background 0.3s;
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); }
.nav-logo { display: flex; align-items: center; gap: var(--space-2); text-decoration: none; }
.logo-icon { font-size: 1.6rem; }
.logo-text { font-size: 1.2rem; font-weight: 800; color: var(--on-primary); }
.nav-links { display: flex; gap: var(--space-4); }
.nav-link { color: var(--on-primary); font-weight: 600; font-size: 0.9rem; opacity: 0.85; transition: opacity 0.2s; }
.nav-link { text-transform: uppercase; letter-spacing: 0.04em; }
.nav-link:hover, .nav-link.active { opacity: 1; }
.nav-actions { display: flex; align-items: center; gap: var(--space-3); }
.nav-mobile-toggle { display: none; background: none; border: none; font-size: 1.4rem; cursor: pointer; color: var(--on-primary); }

/* User Dropdown */
.nav-user-menu { position: relative; }
.nav-user-btn {
  display: flex; align-items: center; gap: var(--space-2);
  background: rgba(255,255,255,0.2); border: none;
  border-radius: var(--radius-full);
  padding: var(--space-1) var(--space-3) var(--space-1) var(--space-2);
  cursor: pointer; font-family: var(--font-family); font-weight: 600; font-size: 0.85rem; color: var(--on-primary);
  transition: background 0.2s;
}
.nav-user-btn:hover { background: rgba(255,255,255,0.3); }
.nav-avatar { font-size: 1.4rem; }
.nav-caret { font-size: 0.7rem; opacity: 0.7; }
.user-dropdown {
  position: absolute; top: calc(100% + 8px); right: 0;
  background: var(--surface-container-lowest);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-float);
  min-width: 180px; padding: var(--space-2) 0;
  display: none; animation: fadeInUp 0.2s ease-out;
}
.user-dropdown.open { display: block; }
.dropdown-item {
  display: block; padding: var(--space-3) var(--space-5);
  font-size: 0.9rem; font-weight: 500; color: var(--on-surface);
  transition: background 0.15s;
}
.dropdown-item { text-transform: uppercase; letter-spacing: 0.04em; }
.dropdown-item:hover { background: var(--surface-container-low); }
.dropdown-danger { color: var(--error); }
.dropdown-divider { height: 1px; background: var(--ghost-border); margin: var(--space-2) 0; }

/* ── Buttons ── */
.btn-primary {
  display: inline-flex; align-items: center; gap: var(--space-2);
  background: linear-gradient(135deg, var(--primary), var(--primary-container));
  color: var(--on-primary); border: none;
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-full);
  font-family: var(--font-family); font-size: 1rem; font-weight: 700;
  cursor: pointer;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s;
  box-shadow: var(--shadow-ambient);
}
.btn-primary:hover { transform: scale(1.05); box-shadow: var(--shadow-float); }
.btn-primary:active { transform: scale(0.97); }
.btn-primary.btn-sm { padding: var(--space-2) var(--space-4); font-size: 0.85rem; }
.btn-primary.btn-full { width: 100%; justify-content: center; padding: var(--space-4) var(--space-6); font-size: 1.1rem; }

.btn-secondary {
  display: inline-flex; align-items: center; gap: var(--space-2);
  background: var(--secondary-container); color: var(--on-secondary-container); border: none;
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-full);
  font-family: var(--font-family); font-size: 1rem; font-weight: 700;
  cursor: pointer;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s;
  box-shadow: var(--shadow-ambient);
}
.btn-secondary:hover { transform: scale(1.05); box-shadow: var(--shadow-float); }
.btn-secondary:active { transform: scale(0.97); }
.btn-secondary.btn-sm { padding: var(--space-2) var(--space-4); font-size: 0.85rem; }

.btn-icon {
  background: var(--surface-container); border: none;
  width: 36px; height: 36px; border-radius: var(--radius-full);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 1rem;
  transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.2s;
}
.btn-icon:hover { transform: scale(1.1); background: var(--surface-container-high); }
.btn-icon-danger:hover { background: #ffdad6; }

/* ── Pills ── */
.pill {
  display: inline-flex; align-items: center; gap: var(--space-1);
  background: var(--surface-container); color: var(--on-surface-variant); border: none;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  font-family: var(--font-family); font-size: 0.85rem; font-weight: 600;
  cursor: pointer;
  transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.2s;
}
.pill:hover { transform: scale(1.05); background: var(--surface-container-high); }
.pill-active { background: linear-gradient(135deg, var(--primary), var(--primary-container)); color: var(--on-primary); }

/* ── Hero ── */
.hero {
  background: var(--surface-container-low);
  padding: 8rem var(--space-6) var(--space-12);
  position: relative; overflow: hidden; min-height: 85vh;
  display: flex; align-items: center;
}
.hero-content {
  display: grid; grid-template-columns: 1.2fr 1fr;
  align-items: center; gap: var(--space-10);
}
.hero-label { font-size: 0.95rem; font-weight: 700; color: var(--primary); margin-bottom: var(--space-3); animation: fadeInUp 0.6s ease-out 0.2s both; }
.hero .display-lg {
  background: linear-gradient(135deg, var(--primary), var(--tertiary));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; animation: fadeInUp 0.6s ease-out 0.3s both;
}
.hero-desc { margin-top: var(--space-5); color: var(--on-surface-variant); max-width: 420px; animation: fadeInUp 0.6s ease-out 0.4s both; }
.hero-actions { display: flex; gap: var(--space-4); margin-top: var(--space-8); flex-wrap: wrap; animation: fadeInUp 0.6s ease-out 0.5s both; }
.hero-meta { display: flex; gap: var(--space-3); margin-top: var(--space-6); flex-wrap: wrap; animation: fadeInUp 0.6s ease-out 0.6s both; }
.hero-illustration { position: relative; display: flex; align-items: center; justify-content: center; min-height: 380px; }
.bunny-container {
  width: 220px; height: 220px;
  background: var(--surface-container-lowest);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-float);
  animation: float 4s ease-in-out infinite;
  position: relative; z-index: 2;
}
.bunny { font-size: 6rem; animation: bounce-gentle 2s ease-in-out infinite; }
.cloud { position: absolute; font-size: 3rem; opacity: 0.6; animation: float 6s ease-in-out infinite; }
.cloud-1 { top: 10%; left: 5%; animation-delay: 0s; font-size: 4rem; opacity: 0.4; }
.cloud-2 { top: 5%; right: 10%; animation-delay: 2s; font-size: 2.5rem; opacity: 0.5; }
.cloud-3 { bottom: 15%; right: 5%; animation-delay: 1s; font-size: 2rem; }
.hero-wave {
  position: absolute; bottom: -2px; left: 0; right: 0;
  height: 80px; background: var(--surface);
  clip-path: ellipse(55% 100% at 50% 100%);
}

/* ── Page Header ── */
.page-header {
  padding: 8rem 0 var(--space-8);
  background: var(--surface-container-low);
  text-align: center;
}
.page-header .subtitle {
  margin: var(--space-3) auto 0;
  text-align: center;
}
.page-header .display-md {
  background: linear-gradient(135deg, var(--primary), var(--tertiary));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Search ── */
.search-section { padding: var(--space-8) 0 var(--space-6); }
.search-bar {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--surface-dim);
  border-radius: var(--radius-full);
  padding: var(--space-4) var(--space-6);
  max-width: 560px; margin: 0 auto var(--space-6);
  transition: box-shadow 0.3s;
}
.search-bar:focus-within { box-shadow: var(--shadow-float); }
.search-icon { font-size: 1.2rem; flex-shrink: 0; }
.search-input {
  flex: 1; border: none; background: transparent;
  font-family: var(--font-family); font-size: 1rem;
  color: var(--on-surface); outline: none;
}
.search-input::placeholder { color: var(--on-surface-variant); }
.category-pills { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.categories-section { padding: var(--space-6) 0; }

/* ── Story Cards ── */
.stories-section { padding: var(--space-10) 0 var(--space-12); }
.stories-section.alt-bg { background: var(--surface-container-low); }
.story-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-8); }
.story-card {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-ambient); cursor: pointer;
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s;
}
.story-card-shell { position: relative; }
.story-card:hover { transform: translateY(-8px) scale(1.02); box-shadow: var(--shadow-float); }
.card-bookmark-form {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  z-index: 5;
}
.card-bookmark-btn {
  width: 36px;
  height: 36px;
  border: none;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 6px 14px rgba(39, 48, 52, 0.2);
  cursor: pointer;
  font-size: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s, background 0.2s;
}
.card-bookmark-btn:hover {
  transform: translateY(-1px) scale(1.05);
  background: #ffffff;
}
.card-bookmark-btn.active {
  background: #ffe9b3;
}

.card-bookmark-btn.popping,
.card-bookmark-btn:active {
  animation: bookmark-pop 0.28s ease-out;
}

@keyframes bookmark-pop {
  0% { transform: scale(1); }
  45% { transform: scale(1.22); }
  100% { transform: scale(1); }
}
.card-illustration {
  height: 260px; display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, #d0e8ff, #b3d4f0);
}
.card-bg-blue { background: linear-gradient(135deg, #d0e8ff, #b3d4f0); }
.card-bg-yellow { background: linear-gradient(135deg, #fff3c4, #fae6a0); }
.card-bg-green { background: linear-gradient(135deg, #c8f7dc, #a5e8c0); }
.card-bg-purple { background: linear-gradient(135deg, #e8d8ff, #d4c0f0); }
.card-book {
  width: min(64%, 170px);
  aspect-ratio: 2 / 3;
  border-radius: 14px;
  overflow: hidden;
  position: relative;
  background: linear-gradient(160deg, #ffffff, #e8f3ff);
  box-shadow:
    0 14px 26px rgba(25, 35, 42, 0.24),
    -10px 0 0 rgba(255, 255, 255, 0.22);
  transform: perspective(900px) rotateY(-7deg) rotateX(1.5deg);
  transform-origin: center left;
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.35s;
}

.card-book::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 10px;
  background: linear-gradient(to right, rgba(0, 0, 0, 0.26), rgba(0, 0, 0, 0.04));
  z-index: 2;
}

.card-book::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: -22%;
  width: 44%;
  transform: skewX(-14deg);
  background: linear-gradient(to right, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.35));
  pointer-events: none;
}

.story-card:hover .card-book {
  transform: perspective(900px) rotateY(-3deg) rotateX(1deg) translateY(-3px);
  box-shadow:
    0 18px 32px rgba(25, 35, 42, 0.28),
    -10px 0 0 rgba(255, 255, 255, 0.26);
}

.card-emoji {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 4rem;
  position: relative;
  z-index: 1;
  background: linear-gradient(145deg, #f7fcff, #dcecff);
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.story-card:hover .card-emoji { transform: scale(1.08); }
.card-cover-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: relative;
  z-index: 1;
}
.card-badge {
  position: absolute; top: var(--space-3); right: var(--space-3);
  background: var(--secondary-container); color: var(--on-secondary-container);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: 0.75rem; font-weight: 700;
}
.card-body { padding: var(--space-5) var(--space-6) var(--space-6); }
.card-body .title-md { margin-bottom: var(--space-2); }
.card-body .body-md { margin-bottom: var(--space-4); }
.card-footer { display: flex; gap: var(--space-4); flex-wrap: wrap; }

.pagination-wrap {
  display: flex;
  gap: var(--space-2);
  justify-content: center;
  flex-wrap: wrap;
  margin-top: var(--space-8);
}

.pagination-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background: var(--surface-container);
  color: var(--on-surface);
  font-weight: 700;
  font-size: 0.85rem;
  padding: 0 var(--space-3);
  transition: transform 0.2s, background 0.2s;
}

.pagination-btn:hover {
  transform: translateY(-2px);
  background: var(--surface-container-high);
}

.pagination-btn.active {
  background: linear-gradient(135deg, var(--primary), var(--primary-container));
  color: var(--on-primary);
}

/* ── CTA Section ── */
.cta-section { padding: var(--space-12) 0; }
.cta-card {
  background: linear-gradient(135deg, var(--primary), var(--primary-container));
  border-radius: var(--radius-xl);
  padding: var(--space-12) var(--space-8);
  text-align: center; color: var(--on-primary);
}
.cta-card h2, .cta-card p { color: var(--on-primary); }
.cta-card p { opacity: 0.9; margin: var(--space-3) auto var(--space-6); max-width: 400px; }
.cta-illustration { font-size: 3rem; margin-bottom: var(--space-4); }
.cta-card .btn-primary {
  background: var(--surface-container-lowest); color: var(--primary);
}

/* ── Empty State ── */
.empty-state {
  text-align: center; padding: var(--space-12) var(--space-6);
  color: var(--on-surface-variant);
}
.empty-icon { font-size: 4rem; display: block; margin-bottom: var(--space-4); opacity: 0.5; }

/* ── Auth Pages ── */
.auth-page { background: var(--surface); }
.auth-wrapper {
  min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr;
}
.auth-illustration {
  background: linear-gradient(135deg, var(--primary), var(--primary-container));
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: var(--space-12); color: var(--on-primary); position: relative; overflow: hidden;
}
.auth-illustration h2, .auth-illustration p { color: var(--on-primary); }
.auth-illustration p { opacity: 0.85; margin-top: var(--space-3); }
.auth-clouds { position: absolute; width: 100%; height: 100%; top: 0; left: 0; }
.auth-clouds .cloud { position: absolute; animation: float 6s ease-in-out infinite; }
.auth-clouds .c1 { top: 15%; left: 10%; font-size: 3rem; opacity: 0.3; }
.auth-clouds .c2 { top: 25%; right: 15%; font-size: 2rem; opacity: 0.4; animation-delay: 1s; }
.auth-clouds .c3 { bottom: 20%; left: 20%; font-size: 2.5rem; opacity: 0.25; animation-delay: 2s; }
.auth-mascot { font-size: 5rem; margin-bottom: var(--space-6); position: relative; z-index: 2; animation: bounce-gentle 3s ease-in-out infinite; }
.auth-welcome { position: relative; z-index: 2; }

.auth-card {
  display: flex; flex-direction: column; justify-content: center;
  padding: var(--space-12) var(--space-8);
  max-width: 480px; margin: 0 auto; width: 100%;
}
.auth-header { margin-bottom: var(--space-8); }
.auth-logo { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-6); }
.auth-logo .logo-text { color: var(--primary); }
.auth-header .headline { margin-bottom: var(--space-2); }
.auth-form { display: flex; flex-direction: column; gap: var(--space-5); }
.auth-footer { margin-top: var(--space-6); text-align: center; }
.auth-link { color: var(--primary); font-weight: 700; }
.auth-link:hover { text-decoration: underline; }

/* ── Form Fields ── */
.form-group { display: flex; flex-direction: column; }
.form-label { font-size: 0.85rem; font-weight: 700; margin-bottom: var(--space-2); color: var(--on-surface); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.form-row .flex-2 { grid-column: span 1; }
.input-field {
  width: 100%; background: var(--surface-container-highest); border: none;
  border-radius: var(--radius-xl); padding: var(--space-4) var(--space-5);
  font-family: var(--font-family); font-size: 1rem; color: var(--on-surface); outline: none;
  transition: box-shadow 0.2s, background 0.3s;
}
.input-field::placeholder { color: var(--on-surface-variant); }
.input-field:focus { box-shadow: 0 0 0 3px rgba(92, 177, 255, 0.3); }
.input-field.input-sm { padding: var(--space-3) var(--space-4); font-size: 0.9rem; border-radius: var(--radius-lg); }
.textarea { border-radius: var(--radius-lg); resize: vertical; min-height: 80px; }
select.input-field { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' fill='none' stroke='%23273034' stroke-width='2'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; }

.input-password-wrap { position: relative; }
.password-toggle {
  position: absolute; right: var(--space-4); top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; font-size: 1.1rem; opacity: 0.6;
}
.password-toggle:hover { opacity: 1; }

.input-error { background: rgba(251, 81, 81, 0.12); animation: wiggle 0.5s ease-in-out; }
.error-text { margin-top: var(--space-2); font-size: 0.85rem; font-weight: 600; color: var(--error); }

.form-check { display: flex; align-items: center; }
.check-label { display: flex; align-items: center; gap: var(--space-2); font-size: 0.9rem; cursor: pointer; }
.check-label input[type="checkbox"] { width: 18px; height: 18px; border-radius: var(--radius-sm); accent-color: var(--primary); }
.form-actions { display: flex; gap: var(--space-4); margin-top: var(--space-4); }

/* ── Profile ── */
.profile-section { padding: var(--space-8) 0 var(--space-12); }
.profile-card {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-xl); padding: var(--space-10);
  text-align: center; max-width: 500px; margin: 0 auto;
  box-shadow: var(--shadow-ambient);
}
.profile-avatar { font-size: 4rem; margin-bottom: var(--space-4); }
.profile-stats { display: flex; justify-content: center; gap: var(--space-8); margin: var(--space-6) 0; }
.stat { text-align: center; }
.stat-number { display: block; font-size: 1.6rem; font-weight: 800; color: var(--primary); line-height: 1.2; }

/* ── User Dashboard ── */
.dashboard-section { padding: var(--space-8) 0 var(--space-12); }

.dashboard-layout {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: var(--space-6);
  align-items: start;
}

.dashboard-main-content {
  min-width: 0;
}

.dashboard-sidebar-nav {
  position: sticky;
  top: 6.5rem;
  background: var(--surface-container-lowest);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-ambient);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.dashboard-sidebar-nav .title-md {
  margin-bottom: var(--space-2);
}

.dashboard-nav-link {
  display: block;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--on-surface-variant);
  transition: background 0.2s, color 0.2s, transform 0.2s;
}

.dashboard-nav-link:hover {
  background: var(--surface-container-low);
  color: var(--on-surface);
  transform: translateX(2px);
}

.dashboard-nav-link.active {
  background: var(--surface-container-low);
  color: var(--primary);
  font-weight: 700;
}

.dashboard-user-card {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-ambient);
}

.dashboard-user-head {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
}

.dashboard-user-bio {
  margin-top: var(--space-2);
  max-width: 680px;
}

.dashboard-stats-grid {
  margin-top: var(--space-6);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-4);
}

.dashboard-stat-card {
  background: var(--surface-container-low);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  text-align: center;
}

.dashboard-user-actions {
  justify-content: center;
}

.dashboard-columns {
  margin-top: var(--space-8);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-6);
}

.dashboard-panel {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-ambient);
  padding: var(--space-6);
}

.dashboard-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.dashboard-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.dashboard-list-item {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  background: var(--surface-container-low);
  border-radius: var(--radius-lg);
  padding: var(--space-3);
  transition: transform 0.2s, box-shadow 0.2s;
}

.dashboard-list-item:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-ambient);
}

.dashboard-book-thumb {
  width: 52px;
  aspect-ratio: 2 / 3;
  border-radius: 8px;
  background: linear-gradient(150deg, #f2f7ff, #d8e8f8);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}

.dashboard-book-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dashboard-comment-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background: var(--surface-container);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.dashboard-item-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.dashboard-item-title {
  font-size: 0.92rem;
  line-height: 1.4;
}

.dashboard-comment-text {
  margin-top: var(--space-1);
}

.dashboard-comment-list {
  gap: var(--space-2);
}

.dashboard-comment-row {
  align-items: center;
}

.dashboard-comment-line {
  margin-top: var(--space-1);
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.dashboard-comment-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.dashboard-comment-story-link {
  color: var(--on-surface);
}

.dashboard-comment-story-link:hover {
  color: var(--primary);
}

.comment-edit-modal-card {
  width: min(620px, 100%);
}

.comment-edit-modal-target {
  margin-bottom: var(--space-3);
  color: var(--on-surface-variant);
}

.dashboard-comment-meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.comment-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.comment-status-badge.visible {
  background: #d4edda;
  color: #155724;
}

.comment-status-badge.hidden {
  background: #ffdad6;
  color: #9d1010;
}

.dashboard-suggest-head {
  margin-top: var(--space-8);
}

@media (min-width: 769px) and (max-width: 1200px) {
  .dashboard-layout { grid-template-columns: 200px minmax(0, 1fr); }
  .dashboard-columns { grid-template-columns: 1fr 1fr; }
}

/* ── Footer ── */
.footer { background: var(--surface-dim); padding: var(--space-10) 0 var(--space-6); }
.footer-content { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: var(--space-6); margin-bottom: var(--space-8); }
.footer-brand { display: flex; flex-direction: column; gap: var(--space-2); }
.footer-brand .logo-icon { font-size: 2rem; }
.footer-brand .logo-text { font-size: 1.4rem; color: var(--on-surface); }
.footer-tagline { color: var(--on-surface-variant); }
.footer-links { display: flex; gap: var(--space-5); flex-wrap: wrap; }
.footer-link { color: var(--on-surface-variant); font-weight: 600; font-size: 0.9rem; transition: color 0.2s; }
.footer-link { text-transform: uppercase; letter-spacing: 0.04em; }
.footer-link:hover { color: var(--primary); }
.footer-copy { text-align: center; padding-top: var(--space-6); border-top: 1px solid var(--ghost-border); }

/* ── Error Page ── */
.error-page { min-height: 100vh; display: flex; align-items: center; justify-content: center; }
.error-content { text-align: center; }
.error-emoji { font-size: 5rem; display: block; margin-bottom: var(--space-4); animation: bounce-gentle 2s ease-in-out infinite; }
.error-page .display-lg {
  background: linear-gradient(135deg, var(--primary), var(--tertiary));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.error-page .body-lg { margin: var(--space-3) 0 var(--space-6); color: var(--on-surface-variant); }

/* ── Animations ── */
@keyframes slideDown {
  from { opacity: 0; transform: translateX(-50%) translateY(-30px); }
  to { opacity: 1; transform: translateX(-50%) translateY(0); }
}
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-16px); }
}
@keyframes bounce-gentle {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-8px) rotate(3deg); }
}
@keyframes wiggle {
  0% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-4px); }
  80% { transform: translateX(4px); }
  100% { transform: translateX(0); }
}

.reveal {
  opacity: 0; transform: translateY(32px);
  transition: opacity 0.7s cubic-bezier(0.34, 1.56, 0.64, 1),
              transform 0.7s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.reveal.visible { opacity: 1; transform: translateY(0); }

/* Fallback: if JS disabled, avoid permanently hidden content. */
html.no-js .reveal,
body.no-js .reveal {
  opacity: 1;
  transform: none;
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .display-lg { font-size: 2.4rem; }
  .display-md { font-size: 2rem; }
  .headline { font-size: 1.6rem; }
  .card-illustration { height: 230px; }
  .card-book { width: min(62%, 150px); }
  .hero-content { grid-template-columns: 1fr; text-align: center; }
  .hero-desc { margin-left: auto; margin-right: auto; }
  .hero-actions, .hero-meta { justify-content: center; }
  .hero-illustration { min-height: 260px; }
  .bunny-container { width: 160px; height: 160px; }
  .bunny { font-size: 4rem; }
  .nav-links { display: none; }
  .nav-actions .btn-secondary { display: none; }
  .nav-mobile-toggle { display: block; }
  .story-grid { grid-template-columns: 1fr; }
  .auth-wrapper { grid-template-columns: 1fr; }
  .auth-illustration { display: none; }
  .auth-card { padding: var(--space-8) var(--space-6); }
  .form-row { grid-template-columns: 1fr; }
  .dashboard-layout { grid-template-columns: 1fr; }
  .dashboard-sidebar-nav {
    position: static;
    flex-direction: row;
    overflow-x: auto;
    white-space: nowrap;
    padding: var(--space-4);
  }
  .dashboard-sidebar-nav .title-md {
    display: none;
  }
  .dashboard-user-head { flex-direction: column; }
  .dashboard-stats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dashboard-columns { grid-template-columns: 1fr; }
  .dashboard-comment-row {
    align-items: flex-start;
    flex-wrap: wrap;
  }
  .dashboard-comment-actions {
    width: 100%;
    margin-left: 0;
    justify-content: flex-end;
  }
  .footer-content { flex-direction: column; align-items: center; text-align: center; }
  .footer-links { justify-content: center; }
}

/* ============================================
   PDF READER & UPLOAD
   ============================================ */

.reader-header {
  padding: 7rem 0 var(--space-8);
  background: var(--surface-container-low);
}
.back-link {
  display: inline-block; color: var(--primary);
  font-weight: 700; font-size: 0.9rem;
  margin-bottom: var(--space-5); transition: transform 0.2s;
}
.back-link:hover { transform: translateX(-4px); }
.reader-info { display: flex; align-items: center; gap: var(--space-5); }
.reader-emoji { font-size: 3.5rem; }
.reader-meta { display: flex; gap: var(--space-3); margin-top: var(--space-3); flex-wrap: wrap; }
.reader-excerpt { margin-top: var(--space-5); color: var(--on-surface-variant); max-width: 600px; }
.reader-bookmark-form { margin-top: var(--space-4); }
.reader-cover-wrap {
  margin-top: var(--space-5);
}

.reader-cover-image {
  width: min(280px, 100%);
  aspect-ratio: 2 / 3;
  object-fit: cover;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-float);
}
.reader-content { padding: var(--space-8) 0 var(--space-12); }

.pdf-viewer-card {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-xl); overflow: hidden;
  box-shadow: var(--shadow-float);
}
.pdf-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-4) var(--space-6);
  background: var(--surface-container);
  flex-wrap: wrap; gap: var(--space-3);
}
.pdf-title { font-weight: 700; font-size: 0.9rem; }
.pdf-actions { display: flex; gap: var(--space-3); }
.pdf-embed-wrapper { width: 100%; }
.pdf-embed { width: 100%; height: 80vh; min-height: 500px; border: none; display: block; }
.pdf-mobile-fallback { display: none; text-align: center; padding: var(--space-8); }

.text-reader-card {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-xl);
  padding: var(--space-10) var(--space-8);
  box-shadow: var(--shadow-ambient);
  max-width: 700px; margin: 0 auto;
}
.story-text { font-size: 1.1rem; line-height: 2; color: var(--on-surface); }

.comments-section {
  margin-top: var(--space-10);
  background: var(--surface-container-lowest);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-ambient);
  padding: var(--space-8);
}

.comments-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.comment-form-card {
  background: var(--surface-container-low);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-bottom: var(--space-5);
}

.comment-form-actions {
  margin-top: var(--space-3);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}

.comment-login-link {
  color: var(--primary);
  font-weight: 700;
}

.comment-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.comment-item {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--surface-container-low);
  border-radius: var(--radius-md);
}

.comment-avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-container);
  flex-shrink: 0;
}

.comment-body {
  flex: 1;
  min-width: 0;
}

.comment-meta {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
  flex-wrap: wrap;
}

.comment-author {
  font-size: 0.92rem;
}

.comment-text {
  color: var(--on-surface);
  word-break: break-word;
}

.upload-area {
  position: relative;
  border: 2px dashed var(--outline-variant);
  border-radius: var(--radius-lg);
  padding: var(--space-8); text-align: center; cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
}
.upload-area:hover, .upload-area.drag-over {
  border-color: var(--primary-container);
  background: rgba(92, 177, 255, 0.05);
}
.upload-input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.upload-icon { font-size: 2.5rem; margin-bottom: var(--space-3); display: block; }
.upload-link { color: var(--primary); font-weight: 700; }
.upload-placeholder { display: flex; flex-direction: column; align-items: center; }
.upload-preview { display: flex; align-items: center; gap: var(--space-3); justify-content: center; }
.upload-file-icon { font-size: 1.8rem; }
.upload-file-name { font-weight: 700; font-size: 0.95rem; }
.current-pdf {
  margin-top: var(--space-3); display: flex; align-items: center;
  gap: var(--space-4); font-size: 0.85rem; color: var(--on-surface-variant);
}
.pdf-view-link { color: var(--primary); font-weight: 700; }

.card-badge-pdf {
  position: absolute; bottom: var(--space-3); right: var(--space-3);
  background: rgba(39, 48, 52, 0.7); color: white;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: 0.7rem; font-weight: 700; backdrop-filter: blur(4px);
}

/* story-card as link */
a.story-card { display: block; color: inherit; text-decoration: none; }

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 26, 31, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 220;
  padding: var(--space-4);
}

.modal-card {
  width: min(680px, 100%);
  max-height: 92vh;
  overflow-y: auto;
  background: var(--surface-container-lowest);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-float);
  padding: var(--space-6);
}

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

.cover-preview-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  margin-top: var(--space-4);
}

.cover-preview-book {
  width: min(220px, 100%);
  aspect-ratio: 2 / 3;
  border-radius: var(--radius-md);
  object-fit: cover;
  box-shadow: var(--shadow-ambient);
}

.cover-editor {
  background: var(--surface-container-low);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}

.cover-editor-stage {
  position: relative;
  width: 100%;
  max-width: 560px;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--radius-md);
  background: #101820;
}

.cover-editor-stage img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.crop-overlay {
  position: absolute;
  border: 2px solid #ffffff;
  box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.45);
  cursor: move;
}

.crop-overlay::after {
  content: '';
  position: absolute;
  right: -7px;
  bottom: -7px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.2);
  cursor: nwse-resize;
}

.cover-editor-actions {
  margin-top: var(--space-4);
  display: flex;
  gap: var(--space-3);
}

@media (max-width: 768px) {
  .reader-info { flex-direction: column; align-items: flex-start; }
  .reader-emoji { font-size: 2.5rem; }
  .pdf-embed { height: 60vh; min-height: 400px; }
  .pdf-toolbar { flex-direction: column; align-items: flex-start; }
  .pdf-mobile-fallback { display: block; }
  .text-reader-card { padding: var(--space-6); }
  .comments-section { padding: var(--space-6); }
  .comment-form-actions {
    flex-direction: column;
    align-items: flex-start;
  }
}
