/*
Theme Name: InkNovels
Template: fictioneer
Description: Premium dark theme for InkNovels web novel platform. Built for the US/UK market. SEO-optimized with Royal Road-inspired design.
Version: 2.0.0
Author: InkNovels
Text Domain: inknovels
*/

/* ============================================
   GOOGLE FONTS (loaded via functions.php)
   Inter, Outfit, Literata, JetBrains Mono
   ============================================ */

/* ============================================
   1. DESIGN TOKENS
   ============================================ */
:root {
  /* Dark Theme Palette */
  --ink-bg-deep: #080a12;
  --ink-bg-base: #0e1019;
  --ink-bg-surface: #161822;
  --ink-bg-card: #1c1f2e;
  --ink-bg-card-hover: #242840;
  --ink-bg-elevated: #2a2e42;
  --ink-border: rgba(139, 92, 246, 0.12);
  --ink-border-hover: rgba(139, 92, 246, 0.35);
  --ink-text-primary: #eef0f6;
  --ink-text-secondary: #8b92a8;
  --ink-text-muted: #5c6378;
  --ink-primary: #8b5cf6;
  --ink-primary-light: #a78bfa;
  --ink-primary-dark: #7c3aed;
  --ink-accent: #06b6d4;
  --ink-gold: #f59e0b;
  --ink-success: #22c55e;
  --ink-danger: #ef4444;
  --ink-glow: 0 0 20px rgba(139, 92, 246, 0.15);
  --ink-shadow-sm: 0 2px 8px rgba(0,0,0,0.3);
  --ink-shadow-md: 0 4px 20px rgba(0,0,0,0.4);
  --ink-shadow-lg: 0 8px 40px rgba(0,0,0,0.5);
  --ink-shadow-card: 0 4px 16px rgba(0,0,0,0.25);
  --ink-radius-sm: 8px;
  --ink-radius-md: 12px;
  --ink-radius-lg: 16px;
  --ink-radius-xl: 24px;
  --ink-transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ============================================
   2. GLOBAL OVERRIDES
   ============================================ */

/* Force dark background everywhere */
html.fictioneer-theme,
html.fictioneer-theme[data-mode="dark"] {
  --site-bg: var(--ink-bg-deep) !important;
  --e-body-bg: var(--ink-bg-deep) !important;
  --bg-50: var(--ink-bg-deep) !important;
  --bg-100: var(--ink-bg-base) !important;
  --bg-200: var(--ink-bg-surface) !important;
  --bg-300: var(--ink-bg-card) !important;
  --bg-400: var(--ink-bg-elevated) !important;
  --bg-900: var(--ink-text-primary) !important;
  --bg-1000: #ffffff !important;
  --secant: var(--ink-primary) !important;
  --e-body: var(--ink-text-primary) !important;
  --e-link: var(--ink-primary-light) !important;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
  letter-spacing: -0.011em;
  color: var(--ink-text-primary) !important;
  background: var(--ink-bg-deep) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ============================================
   3. TYPOGRAPHY
   ============================================ */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Outfit', 'Inter', sans-serif !important;
  font-weight: 700 !important;
  color: var(--ink-text-primary) !important;
  letter-spacing: -0.02em !important;
}

/* ============================================
   4. SITE LAYOUT / WRAPPER
   ============================================ */
.main__wrapper {
  max-width: 1280px !important;
  padding: 0 24px !important;
}

#site {
  background: var(--ink-bg-deep) !important;
}

.site-bg {
  background: var(--ink-bg-deep) !important;
}

.background-texture {
  background-image: none !important;
}

/* ============================================
   5. HEADER / NAVIGATION
   ============================================ */

/* Hide Fictioneer's default site header/branding on ALL pages
   Brand is in the nav bar already, no need for separate header block */
.header-background,
.header__content,
.header__title-wrapper,
.header__title,
.header__tagline,
.header__title-tagline {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
  visibility: hidden !important;
}

.navigation {
  background: rgba(14, 16, 25, 0.92) !important;
  backdrop-filter: blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
  border-bottom: 1px solid var(--ink-border) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3) !important;
}

.navigation__wrapper {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
}

/* Site title in nav */
.navigation .icon-menu-brand,
.navigation__title {
  font-family: 'Outfit', sans-serif !important;
  font-weight: 800 !important;
  font-size: 1.5em !important;
  background: linear-gradient(135deg, var(--ink-primary-light), var(--ink-accent)) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

/* Nav links */
.navigation__list > li > a,
.main-navigation a {
  font-family: 'Inter', sans-serif !important;
  font-weight: 500 !important;
  font-size: 0.9em !important;
  letter-spacing: 0.01em !important;
  padding: 14px 16px !important;
  color: var(--ink-text-secondary) !important;
  transition: color var(--ink-transition), background var(--ink-transition) !important;
  border-radius: var(--ink-radius-sm) !important;
}

.navigation__list > li > a:hover,
.main-navigation a:hover {
  color: var(--ink-primary-light) !important;
  background: rgba(139, 92, 246, 0.08) !important;
}

/* Site header (hero area) */
.header__title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 2em !important;
  font-weight: 800 !important;
  background: linear-gradient(135deg, var(--ink-primary-light), var(--ink-accent)) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

.header__tagline {
  font-size: 0.9em !important;
  color: var(--ink-text-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  font-weight: 400 !important;
}

/* ============================================
   6. STORY CARDS — KEY FEATURE
   ============================================ */

/* Card base */
.card {
  background: var(--ink-bg-card) !important;
  border: 1px solid var(--ink-border) !important;
  border-radius: var(--ink-radius-md) !important;
  overflow: hidden !important;
  transition: all var(--ink-transition) !important;
  box-shadow: var(--ink-shadow-card) !important;
  position: relative !important;
}

.card:hover {
  border-color: var(--ink-border-hover) !important;
  box-shadow: var(--ink-shadow-md), var(--ink-glow) !important;
  transform: translateY(-4px) !important;
}

/* Card body / content area */
.card__body {
  padding: 16px 20px !important;
  background: var(--ink-bg-card) !important;
  clip-path: none !important;
}

.card__body.polygon {
  clip-path: none !important;
}

/* Card image (cover art) */
.card__image-container,
.card__image {
  background: linear-gradient(135deg, #1e1b4b, #312e81) !important;
  overflow: hidden !important;
}

.card__image img,
.card__image-container img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.card:hover .card__image img,
.card:hover .card__image-container img {
  transform: scale(1.06) !important;
}

/* Card title */
.card__title {
  margin-bottom: 6px !important;
}

.card__title a {
  font-family: 'Outfit', sans-serif !important;
  font-weight: 700 !important;
  font-size: 1.05em !important;
  color: var(--ink-text-primary) !important;
  text-decoration: none !important;
  transition: color var(--ink-transition) !important;
  line-height: 1.3 !important;
}

.card__title a:hover {
  color: var(--ink-primary-light) !important;
}

/* Card content / description */
.card__content,
.card__excerpt {
  color: var(--ink-text-secondary) !important;
  font-size: 0.88em !important;
  line-height: 1.65 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

/* Card footer (meta info) */
.card__footer {
  background: rgba(0, 0, 0, 0.15) !important;
  border-top: 1px solid var(--ink-border) !important;
  padding: 10px 20px !important;
  font-size: 0.82em !important;
  color: var(--ink-text-muted) !important;
  clip-path: none !important;
}

.card__footer.polygon {
  clip-path: none !important;
}

.card__footer-box {
  color: var(--ink-text-muted) !important;
}

.card__footer i,
.card-footer-icon {
  color: var(--ink-text-muted) !important;
  opacity: 0.7 !important;
}

/* ============================================
   7. TAXONOMY PILLS (Genre, Tags)
   ============================================ */
.cell-tax,
.tag-pill,
.card__tag-list a,
._taxonomy-pills a,
.story__tags a,
.cell-list a {
  background: rgba(139, 92, 246, 0.1) !important;
  color: var(--ink-primary-light) !important;
  border: 1px solid rgba(139, 92, 246, 0.2) !important;
  border-radius: 100px !important;
  padding: 4px 14px !important;
  font-size: 0.78em !important;
  font-weight: 500 !important;
  font-family: 'Inter', sans-serif !important;
  letter-spacing: 0.01em !important;
  transition: all var(--ink-transition) !important;
  display: inline-block !important;
  text-decoration: none !important;
  line-height: 1.4 !important;
}

.cell-tax:hover,
.tag-pill:hover,
.card__tag-list a:hover,
._taxonomy-pills a:hover {
  background: rgba(139, 92, 246, 0.2) !important;
  border-color: var(--ink-primary) !important;
  color: #c4b5fd !important;
  transform: translateY(-1px) !important;
}

/* Rating letter badge */
.rating-letter-label {
  background: var(--ink-bg-elevated) !important;
  border: 1px solid var(--ink-border) !important;
  border-radius: var(--ink-radius-sm) !important;
  color: var(--ink-text-secondary) !important;
  font-weight: 600 !important;
}

/* ============================================
   8. STORY DETAIL PAGE
   ============================================ */
.story {
  background: transparent !important;
}

.story__header {
  padding: 32px 0 !important;
}

.story__title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 2.4em !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
  line-height: 1.15 !important;
  background: linear-gradient(135deg, var(--ink-text-primary), var(--ink-primary-light)) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  margin-bottom: 12px !important;
}

/* Cover on story page */
.story__thumbnail img {
  border-radius: var(--ink-radius-md) !important;
  box-shadow: var(--ink-shadow-lg) !important;
  border: 1px solid var(--ink-border) !important;
  transition: transform 0.4s ease !important;
}

.story__thumbnail img:hover {
  transform: scale(1.02) !important;
}

/* Story action buttons */
.story .button,
.button._primary,
a.button._primary {
  background: linear-gradient(135deg, var(--ink-primary), var(--ink-primary-dark)) !important;
  color: white !important;
  border: none !important;
  border-radius: var(--ink-radius-sm) !important;
  padding: 12px 28px !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.95em !important;
  letter-spacing: 0.01em !important;
  transition: all var(--ink-transition) !important;
  box-shadow: 0 4px 14px rgba(139, 92, 246, 0.25) !important;
  cursor: pointer !important;
}

.story .button:hover,
.button._primary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(139, 92, 246, 0.4) !important;
  filter: brightness(1.1) !important;
}

/* Story stats grid */
.story__meta,
.story__info {
  color: var(--ink-text-secondary) !important;
}

/* Chapter list on story page */
.chapter-group__list-item {
  background: var(--ink-bg-surface) !important;
  border: 1px solid var(--ink-border) !important;
  border-radius: var(--ink-radius-sm) !important;
  margin-bottom: 4px !important;
  transition: all var(--ink-transition) !important;
  padding: 12px 16px !important;
}

.chapter-group__list-item:hover {
  background: var(--ink-bg-card-hover) !important;
  border-color: var(--ink-border-hover) !important;
}

.chapter-group__list-item a {
  color: var(--ink-text-primary) !important;
  text-decoration: none !important;
  font-weight: 500 !important;
}

.chapter-group__list-item a:hover {
  color: var(--ink-primary-light) !important;
}

/* ============================================
   9. CHAPTER READING PAGE
   ============================================ */
.chapter-formatting {
  max-width: 740px !important;
  margin: 0 auto !important;
  padding: 40px 24px !important;
}

.chapter-formatting p {
  font-family: 'Literata', 'Lora', Georgia, 'Times New Roman', serif !important;
  font-size: 1.12em !important;
  line-height: 1.95 !important;
  color: var(--ink-text-primary) !important;
  margin-bottom: 1.2em !important;
  word-spacing: 0.02em !important;
}

.chapter-formatting h1,
.chapter-formatting h2,
.chapter-formatting h3 {
  font-family: 'Outfit', sans-serif !important;
  margin: 1.5em 0 0.8em !important;
}

.chapter-formatting blockquote {
  background: rgba(139, 92, 246, 0.06) !important;
  border-left: 4px solid var(--ink-primary) !important;
  padding: 20px 24px !important;
  margin: 28px 0 !important;
  border-radius: 0 var(--ink-radius-sm) var(--ink-radius-sm) 0 !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  font-size: 0.9em !important;
  line-height: 1.7 !important;
  color: var(--ink-primary-light) !important;
}

.chapter-formatting em {
  color: var(--ink-text-secondary) !important;
  font-style: italic !important;
}

.chapter-formatting hr {
  border: none !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, var(--ink-border-hover), transparent) !important;
  margin: 48px auto !important;
  max-width: 200px !important;
}

/* Chapter nav buttons */
.chapter-navigation a {
  background: var(--ink-bg-card) !important;
  border: 1px solid var(--ink-border) !important;
  border-radius: var(--ink-radius-sm) !important;
  color: var(--ink-text-primary) !important;
  padding: 10px 20px !important;
  font-weight: 500 !important;
  transition: all var(--ink-transition) !important;
}

.chapter-navigation a:hover {
  background: var(--ink-bg-card-hover) !important;
  border-color: var(--ink-border-hover) !important;
  color: var(--ink-primary-light) !important;
}

/* Reading progress bar */
.progress__bar {
  background: linear-gradient(90deg, var(--ink-primary), var(--ink-accent)) !important;
  height: 3px !important;
}

/* ============================================
   10. SECTION HEADINGS (Homepage)
   ============================================ */
.canvas h2,
.main__background h2,
main h2 {
  font-family: 'Outfit', sans-serif !important;
  font-size: 1.6em !important;
  font-weight: 700 !important;
  color: var(--ink-text-primary) !important;
  margin: 40px 0 20px !important;
  padding-bottom: 12px !important;
  border-bottom: 2px solid rgba(139, 92, 246, 0.15) !important;
  letter-spacing: -0.02em !important;
}

/* ============================================
   11. CARD GRID LAYOUT
   ============================================ */
.card-list {
  gap: 20px !important;
  list-style: none !important;
  padding: 0 !important;
}

/* Story cards grid (show 4 per row) */
.card-list._grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 24px !important;
}

/* Chapter cards (horizontal list layout) */
.card-list:not(._grid) {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
  gap: 16px !important;
}

/* Small cards (chapters) - make them more compact */
.card._small {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
}

.card._small .card__image-container,
.card._small .card__image {
  width: 80px !important;
  min-width: 80px !important;
  flex-shrink: 0 !important;
}

.card._small .card__body {
  padding: 12px 16px !important;
  flex: 1 !important;
}

/* ============================================
   12. FOOTER
   ============================================ */
.footer {
  background: var(--ink-bg-base) !important;
  border-top: 1px solid var(--ink-border) !important;
  padding: 40px 0 !important;
  color: var(--ink-text-muted) !important;
}

.footer a {
  color: var(--ink-text-secondary) !important;
  transition: color var(--ink-transition) !important;
}

.footer a:hover {
  color: var(--ink-primary-light) !important;
}

.footer__wrapper {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
}

/* ============================================
   13. BUTTONS (Global)
   ============================================ */
.button,
button,
input[type="submit"] {
  font-family: 'Inter', sans-serif !important;
  font-weight: 500 !important;
  border-radius: var(--ink-radius-sm) !important;
  transition: all var(--ink-transition) !important;
}

/* ============================================
   14. SEARCH
   ============================================ */
.search-form input[type="search"],
.search-form input[type="text"] {
  background: var(--ink-bg-surface) !important;
  border: 1px solid var(--ink-border) !important;
  border-radius: var(--ink-radius-sm) !important;
  color: var(--ink-text-primary) !important;
  padding: 10px 16px !important;
  font-family: 'Inter', sans-serif !important;
  transition: border-color var(--ink-transition) !important;
}

.search-form input[type="search"]:focus,
.search-form input[type="text"]:focus {
  border-color: var(--ink-primary) !important;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1) !important;
  outline: none !important;
}

/* ============================================
   15. MODALS / SETTINGS
   ============================================ */
.modal__wrapper {
  background: var(--ink-bg-card) !important;
  border: 1px solid var(--ink-border) !important;
  border-radius: var(--ink-radius-lg) !important;
  box-shadow: var(--ink-shadow-lg) !important;
}

.modal__header {
  font-family: 'Outfit', sans-serif !important;
  font-weight: 700 !important;
  border-bottom: 1px solid var(--ink-border) !important;
}

/* ============================================
   16. BREADCRUMBS
   ============================================ */
.breadcrumbs {
  font-size: 0.85em !important;
  color: var(--ink-text-muted) !important;
}

.breadcrumbs a {
  color: var(--ink-text-secondary) !important;
  transition: color var(--ink-transition) !important;
}

.breadcrumbs a:hover {
  color: var(--ink-primary-light) !important;
}

/* ============================================
   17. FOLLOW/BOOKMARK/CHECKMARK ICONS
   ============================================ */
.checkmark,
.follow-toggle,
.reminder-toggle {
  color: var(--ink-text-muted) !important;
  transition: color var(--ink-transition) !important;
}

.checkmark:hover,
.follow-toggle:hover,
.reminder-toggle:hover {
  color: var(--ink-primary-light) !important;
}

.checkmark._marked,
.follow-toggle._followed {
  color: var(--ink-primary) !important;
}

/* ============================================
   18. SCROLLBAR
   ============================================ */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--ink-bg-deep);
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--ink-primary), var(--ink-primary-dark));
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, var(--ink-primary-light), var(--ink-primary));
}

/* ============================================
   19. SELECTION
   ============================================ */
::selection {
  background: rgba(139, 92, 246, 0.3);
  color: #fff;
}

/* ============================================
   20. ARCHIVE PAGES (Stories listing)
   ============================================ */
.stories__list,
.archive .card-list {
  gap: 24px !important;
}

/* ============================================
   21. MOBILE MENU
   ============================================ */
.mobile-menu__frame {
  background: var(--ink-bg-card) !important;
  border-right: 1px solid var(--ink-border) !important;
}

.mobile-menu a {
  color: var(--ink-text-primary) !important;
  padding: 12px 20px !important;
  font-weight: 500 !important;
}

.mobile-menu a:hover {
  background: rgba(139, 92, 246, 0.08) !important;
  color: var(--ink-primary-light) !important;
}

/* ============================================
   22. RESPONSIVE
   ============================================ */
@media (max-width: 1024px) {
  .main__wrapper {
    padding: 0 16px !important;
  }
}

@media (max-width: 768px) {
  .header__title {
    font-size: 1.5em !important;
  }
  
  .story__title {
    font-size: 1.8em !important;
  }

  .chapter-formatting p {
    font-size: 1.05em !important;
    line-height: 1.85 !important;
  }

  .card-list._grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
    gap: 16px !important;
  }

  .canvas h2,
  main h2 {
    font-size: 1.3em !important;
  }
}

@media (max-width: 480px) {
  .card-list._grid {
    grid-template-columns: 1fr !important;
  }

  .chapter-formatting {
    padding: 24px 16px !important;
  }
}

/* ============================================
   23. ANIMATIONS
   ============================================ */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.card {
  animation: fadeInUp 0.4s ease both;
}

.card:nth-child(1) { animation-delay: 0.05s; }
.card:nth-child(2) { animation-delay: 0.1s; }
.card:nth-child(3) { animation-delay: 0.15s; }
.card:nth-child(4) { animation-delay: 0.2s; }
.card:nth-child(5) { animation-delay: 0.25s; }
.card:nth-child(6) { animation-delay: 0.3s; }

/* ============================================
   24. MISC / CLEANUP
   ============================================ */

/* Remove Fictioneer's polygon clip paths */
.polygon {
  clip-path: none !important;
}

/* Remove textures */
.background-texture::before,
.background-texture::after {
  display: none !important;
}

/* Clean links */
a {
  color: var(--ink-primary-light) !important;
  transition: color var(--ink-transition) !important;
}

a:hover {
  color: var(--ink-accent) !important;
}

/* No results text */
.no-results {
  color: var(--ink-text-muted) !important;
  font-style: italic !important;
  text-align: center !important;
  padding: 40px 0 !important;
}

/* Smooth page transitions */
html {
  scroll-behavior: smooth;
}

/* ============================================
   25. HOMEPAGE-SPECIFIC LAYOUT FIXES
   ============================================ */

/* Make canvas (homepage) full-width */
.canvas.canvas-site {
  max-width: 100% !important;
  padding: 0 !important;
}

/* Fix card grid on homepage to be 4 columns */
.inknovels-home .card-list {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 24px !important;
}

@media (max-width: 1024px) {
  .inknovels-home .card-list,
  .card-list._grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

@media (max-width: 768px) {
  .inknovels-home .card-list,
  .card-list._grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 16px !important;
  }
}

@media (max-width: 480px) {
  .inknovels-home .card-list,
  .card-list._grid {
    grid-template-columns: 1fr !important;
  }
}
