/* ── RESET & VARS ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --hdr:   #2a2828;
  --cream: #FFF5D6;
  --bg:    #493b53;
  --mauve: #caabc7;
  --blue:  #7186B1;
}

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--cream);
  font-family: 'Josefin Sans', sans-serif;
  font-size: 16px;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }

/* ── TOP BAR ── */
#top-bar {
  background: var(--hdr);
  padding: 8px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12px;
  letter-spacing: .08em;
  border-bottom: 1px solid rgba(202,171,199,.2);
  position: sticky;
  top: 0;
  z-index: 1000;
}

#countdown {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--topbar_text);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
#countdown b { color: var(--cream); font-size: 14px; font-weight: 600; }
.cd-unit { text-align: center; }
.cd-lbl { display: block; font-size: 9px; color: var(--mauve); letter-spacing: .1em; margin-top: 1px; }

#socials-bar { display: flex; align-items: center; gap: 18px; }
#socials-bar a {
  color: var(--topbar_text);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  transition: color .2s;
  display: flex;
  align-items: center;
  gap: 5px;
}
#socials-bar a:hover { color: var(--cream); }
#socials-bar svg { width: 15px; height: 15px; fill: currentColor; }

/* ── MAIN NAV ── */
#main-nav {
  background: var(--hdr);
  background-image: url('/uploads/site/nav-texture.png');
  background-size: cover;
  background-position: center;
  padding: 16px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(202,171,199,.12);
  position: sticky;
  top: 41px;
  z-index: 999;
}

.nav-group { display: flex; align-items: center; gap: 28px; }
.nav-links  { display: flex; align-items: center; gap: 28px; }

/* ── HAMBURGER (hidden on desktop) ── */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: transparent;
  border: 1px solid rgba(202,171,199,.35);
  padding: 8px 10px;
  cursor: pointer;
  flex-shrink: 0;
}
.nav-hamburger span {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--cream);
  border-radius: 2px;
}

/* ── MOBILE DRAWER ── */
.mob-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.65);
  z-index: 1998;
}
.mob-overlay.open { display: block; }

.mob-drawer {
  position: fixed;
  top: 0; right: 0;
  width: min(280px, 82vw);
  height: 100vh;
  background: var(--hdr);
  background-image: url('/uploads/site/nav-texture.png');
  background-size: cover;
  z-index: 1999;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform .28s ease;
  overflow-y: auto;
  border-left: 1px solid rgba(202,171,199,.2);
}
.mob-drawer.open { transform: translateX(0); }

.mob-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px 16px;
  border-bottom: 1px solid rgba(202,171,199,.15);
}
.mob-name {
  font-family: 'Pinyon Script', cursive;
  font-size: 28px;
  color: var(--cream);
}
.mob-close {
  background: none;
  border: none;
  color: rgba(255,245,214,.5);
  font-size: 20px;
  cursor: pointer;
  line-height: 1;
  padding: 4px;
}
.mob-close:hover { color: var(--cream); }

.mob-item {
  display: block;
  padding: 12px 24px;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,245,214,.75);
  text-decoration: none;
  border-bottom: 1px solid rgba(202,171,199,.07);
  transition: background .15s, color .15s;
}
.mob-item:hover, .mob-item.active { color: var(--mauve); background: rgba(202,171,199,.06); }
.mob-item.mob-sub {
  padding-left: 40px;
  font-size: 11px;
  color: rgba(255,245,214,.5);
}
.mob-item.mob-accent { color: var(--blue); }

.nav-link {
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--cream);
  transition: color .2s;
}
.nav-link:hover,
.nav-link.active { color: var(--mauve); }
.nav-link.accent { color: var(--blue); }
.nav-link.accent:hover { color: var(--mauve); }

.nav-dropdown { position: relative; padding-bottom: 16px; margin-bottom: -16px; }
.nav-dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: var(--hdr);
  border: 1px solid rgba(202,171,199,.25);
  min-width: 210px;
  z-index: 9999;
  padding-top: 4px;
}
.nav-dropdown:hover .nav-dropdown-menu { display: block; }
.nav-dropdown-menu a {
  display: block;
  padding: 12px 20px;
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.nav-dropdown-menu a:hover { background: rgba(202,171,199,.12); color: var(--mauve); }

.nav-name {
  font-family: 'Pinyon Script', cursive;
  font-size: 58px;
  color: var(--cream);
  transition: color .2s;
  line-height: 1;
}
.nav-name:hover { color: var(--mauve); }

/* ── BUTTONS ── */
.btn {
  display: inline-block;
  padding: 12px 36px;
  border: 1px solid var(--mauve);
  color: var(--topbar_text);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-family: 'Josefin Sans', sans-serif;
  transition: all .22s;
  cursor: pointer;
  background: transparent;
}
.btn:hover { background: var(--mauve); color: var(--hdr); }

.btn-blue { border-color: var(--blue); color: var(--blue); }
.btn-blue:hover { background: var(--blue); color: var(--cream); }

.btn-row { display: flex; gap: 12px; flex-wrap: wrap; }

/* ── SECTION BASE ── */
.section { padding: 80px 40px; }

.section-label {
  font-size: 10px;
  letter-spacing: .4em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 10px;
}

.section-title {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(26px, 4vw, 42px);
  font-weight: 400;
  color: var(--cream);
  letter-spacing: .08em;
  margin-bottom: 48px;
}

/* ── HERO ── */
#hero {
  min-height: 88vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 80px 40px 60px;
  position: relative;
  overflow: hidden;
}

#hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 60% 40%, rgba(113,134,177,.15) 0%, transparent 65%),
    radial-gradient(ellipse at 20% 80%, rgba(202,171,199,.12) 0%, transparent 55%);
  pointer-events: none;
}

.hero-eyebrow {
  font-size: 11px;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--topbar_text);
  margin-bottom: 18px;
}

.hero-name {
  font-family: 'Pinyon Script', cursive;
  font-size: clamp(80px, 14vw, 160px);
  color: var(--cream);
  line-height: 1;
  margin-bottom: 14px;
  position: relative;
  z-index: 1;
}

.hero-sub {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px;
  font-style: italic;
  color: rgba(255,245,214,.65);
  margin-bottom: 44px;
  letter-spacing: .04em;
}

/* ── FEATURED BOOK ── */
#featured {
  padding: 80px 40px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  max-width: 1100px;
  margin: 0 auto;
  align-items: center;
}

.book-cover-img {
  width: 100%;
  max-width: 340px;
  aspect-ratio: 2/3;
  object-fit: cover;
  display: block;
  border: 1px solid rgba(202,171,199,.2);
}

.book-cover-placeholder {
  width: 100%;
  max-width: 340px;
  aspect-ratio: 2/3;
  background: linear-gradient(160deg, #1a0a00 0%, #3d1a06 40%, #6b2e0e 70%, #2a0000 100%);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 28px;
  border: 1px solid rgba(202,171,199,.15);
}

.book-cover-placeholder span {
  font-family: 'Cormorant SC', serif;
  font-size: 16px;
  letter-spacing: .2em;
  color: #FFB347;
  text-align: center;
  text-shadow: 0 0 18px #ff6600;
  padding: 0 12px;
}

.work-placeholder-img {
  background: linear-gradient(170deg, #2d1f3d 0%, #493b53 100%);
}

.book-series {
  font-size: 10px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 10px;
}

.book-title {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(28px, 4vw, 46px);
  font-weight: 400;
  color: var(--cream);
  letter-spacing: .06em;
  margin-bottom: 16px;
}

.book-desc {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  line-height: 1.7;
  color: rgba(255,245,214,.75);
  font-style: italic;
  margin-bottom: 28px;
}

/* ── WORKS / GRID ── */
.works-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 40px;
  max-width: 1100px;
  margin: 0 auto;
}

.work-card { text-align: center; }

.work-img {
  width: 100%;
  max-width: 200px;
  aspect-ratio: 2/3;
  object-fit: cover;
  margin: 0 auto 20px;
  display: block;
  border: 1px solid rgba(202,171,199,.15);
  transition: transform .3s, box-shadow .3s;
}
.work-img:hover { transform: translateY(-6px); box-shadow: 0 20px 50px rgba(0,0,0,.4); }

.work-title {
  font-family: 'Cormorant SC', serif;
  font-size: 18px;
  font-weight: 400;
  color: var(--cream);
  margin-bottom: 10px;
  letter-spacing: .05em;
}

.work-tagline {
  font-family: 'Cormorant Garamond', serif;
  font-size: 16px;
  font-style: italic;
  color: rgba(255,245,214,.65);
  line-height: 1.6;
  margin-bottom: 18px;
}

/* ── DIVIDER ── */
.ornament {
  text-align: center;
  padding: 16px 0;
  color: rgba(202,171,199,.3);
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  letter-spacing: 18px;
}

/* ── ABOUT SNIPPET ── */
#about-snippet {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
  padding: 80px 40px;
}

.about-pull {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(20px, 3vw, 32px);
  font-weight: 300;
  font-style: italic;
  color: var(--cream);
  line-height: 1.55;
  margin-bottom: 28px;
}
.about-pull strong { font-weight: 600; font-style: normal; color: var(--mauve); }

/* ── ABOUT PAGE ── */
.about-page { width: 100%; padding: 0; }
.about-page h1 { font-family: 'Cormorant SC', serif; font-size: 42px; font-weight: 400; color: var(--cream); letter-spacing: .08em; margin-bottom: 32px; }
.about-body { font-family: 'Cormorant Garamond', serif; font-size: 20px; line-height: 1.8; color: rgba(255,245,214,.82); }
.about-body p { margin-bottom: 20px; }

/* ── UNHINGED BAND ── */
#unhinged-band {
  background: var(--hdr);
  border-top: 1px solid rgba(202,171,199,.15);
  border-bottom: 1px solid rgba(202,171,199,.15);
  padding: 48px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
}

.unhinged-left { flex: 1; min-width: 260px; }
.unhinged-tag { font-size: 10px; letter-spacing: .35em; text-transform: uppercase; color: var(--blue); margin-bottom: 8px; }
.unhinged-hed { font-family: 'Cormorant SC', serif; font-size: 30px; color: var(--cream); letter-spacing: .1em; margin-bottom: 12px; }
.unhinged-desc { font-family: 'Cormorant Garamond', serif; font-size: 17px; font-style: italic; color: rgba(255,245,214,.65); line-height: 1.6; }

/* ── MAILING LIST ── */
#mailing-section {
  padding: 80px 40px;
  max-width: 540px;
  margin: 0 auto;
  text-align: center;
}
#mailing-section h2 {
  font-family: 'Cormorant SC', serif;
  font-size: 28px;
  font-weight: 400;
  color: var(--cream);
  letter-spacing: .1em;
  margin-bottom: 12px;
}
#mailing-section p {
  font-family: 'Cormorant Garamond', serif;
  font-size: 17px;
  font-style: italic;
  color: rgba(255,245,214,.6);
  margin-bottom: 28px;
  line-height: 1.6;
}

.mail-form { display: flex; border: 1px solid rgba(202,171,199,.35); }
.mail-form input {
  flex: 1;
  background: transparent;
  border: none;
  padding: 14px 16px;
  color: var(--cream);
  font-family: 'Josefin Sans', sans-serif;
  font-size: 13px;
  outline: none;
}
.mail-form input::placeholder { color: rgba(255,245,214,.35); }
.mail-form button {
  background: var(--mauve);
  border: none;
  padding: 14px 22px;
  color: var(--hdr);
  font-family: 'Josefin Sans', sans-serif;
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s;
}
.mail-form button:hover { background: var(--cream); }
.mail-msg { margin-top: 12px; font-size: 13px; color: var(--mauve); }

/* ── CONTACT PAGE ── */
.contact-page { width: 100%; padding: 60px 80px 100px; box-sizing: border-box; }
.contact-page h1 { font-family: 'Cormorant SC', serif; font-size: 42px; font-weight: 400; color: var(--cream); letter-spacing: .08em; margin-bottom: 48px; max-width: 1100px; margin-left: auto; margin-right: auto; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; max-width: 1100px; margin: 0 auto; }
.contact-block h2 { font-family: 'Cormorant SC', serif; font-size: 18px; font-weight: 400; color: var(--mauve); letter-spacing: .1em; margin-bottom: 16px; }
.contact-block p { font-family: 'Cormorant Garamond', serif; font-size: 17px; font-style: italic; color: rgba(255,245,214,.7); line-height: 1.65; margin-bottom: 10px; }
.contact-block a { color: var(--blue); border-bottom: 1px solid transparent; transition: border-color .2s; }
.contact-block a:hover { border-color: var(--blue); }
.contact-socials { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }
.contact-soc { padding: 9px 18px; border: 1px solid rgba(202,171,199,.25); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,245,214,.65); transition: all .2s; }
.contact-soc:hover { border-color: var(--mauve); color: var(--mauve); }

/* ── EVENTS PAGE ── */
.events-page { max-width: 820px; margin: 0 auto; padding: 80px 40px; }
.events-page h1 { font-family: 'Cormorant SC', serif; font-size: 42px; font-weight: 400; color: var(--cream); letter-spacing: .08em; margin-bottom: 48px; }
.event-row { display: flex; gap: 20px; align-items: flex-start; padding: 24px 0; border-bottom: 1px solid rgba(202,171,199,.12); }
.event-date-box { min-width: 60px; text-align: center; background: rgba(202,171,199,.08); padding: 10px 6px; border: 1px solid rgba(202,171,199,.18); flex-shrink: 0; }
.ev-month { font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--mauve); display: block; }
.ev-day { font-family: 'Cormorant SC', serif; font-size: 22px; color: var(--cream); display: block; }
.ev-name { font-family: 'Cormorant SC', serif; font-size: 17px; font-weight: 400; color: var(--cream); margin-bottom: 6px; }
.ev-loc { font-size: 12px; color: rgba(255,245,214,.45); letter-spacing: .05em; }
.ev-desc { font-family: 'Cormorant Garamond', serif; font-size: 15px; font-style: italic; color: rgba(255,245,214,.6); margin-top: 8px; line-height: 1.5; }

/* ── BOOK DETAIL PAGE ── */
.book-detail { max-width: 1000px; margin: 0 auto; padding: 80px 40px; display: grid; grid-template-columns: 280px 1fr; gap: 64px; align-items: start; }
.book-detail-cover { width: 100%; aspect-ratio: 2/3; object-fit: cover; border: 1px solid rgba(202,171,199,.2); }
.book-detail-title { font-family: 'Cormorant SC', serif; font-size: clamp(28px,4vw,46px); font-weight: 400; color: var(--cream); letter-spacing: .06em; margin-bottom: 16px; }
.book-detail-body { font-family: 'Cormorant Garamond', serif; font-size: 18px; line-height: 1.8; color: rgba(255,245,214,.78); margin-bottom: 28px; }

/* ── #UNHINGEDPIT PAGE ── */
.pit-page { max-width: 820px; margin: 0 auto; padding: 80px 40px; text-align: center; }
.pit-page h1 { font-family: 'Cormorant SC', serif; font-size: 48px; font-weight: 400; color: var(--cream); letter-spacing: .08em; margin-bottom: 16px; }
.pit-page .sub { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-style: italic; color: rgba(255,245,214,.65); margin-bottom: 40px; line-height: 1.6; }

/* ── FOOTER ── */
footer {
  background: var(--hdr);
  border-top: 1px solid rgba(202,171,199,.15);
  padding: 48px 40px;
  display: flex;
  justify-content: space-between;
  gap: 48px;
  flex-wrap: wrap;
}
.footer-col h3 { font-family: 'Cormorant SC', serif; font-size: 13px; letter-spacing: .2em; text-transform: uppercase; color: var(--cream); margin-bottom: 18px; }

.event-item { display: flex; gap: 12px; margin-bottom: 14px; align-items: flex-start; }

.social-btns { display: flex; gap: 8px; flex-wrap: wrap; }
.soc-btn { display: flex; align-items: center; gap: 6px; padding: 9px 14px; border: 1px solid rgba(202,171,199,.22); color: rgba(255,245,214,.65); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; transition: all .2s; }
.soc-btn:hover { border-color: var(--mauve); color: var(--mauve); }

.footer-more { color: var(--blue); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; margin-top: 8px; display: inline-block; }
.footer-bottom { background: var(--hdr); border-top: 1px solid rgba(202,171,199,.1); padding: 16px 40px; display: flex; justify-content: space-between; align-items: center; }
.footer-bottom p { font-size: 10px; letter-spacing: .1em; color: rgba(255,245,214,.3); }
.footer-sig { font-family: 'Pinyon Script', cursive; font-size: 24px; color: rgba(255,245,214,.3); }

/* ── PAGE HERO (inner pages) ── */
.page-hero { padding: 60px 40px 40px; text-align: center; }
.page-hero h1 { font-family: 'Cormorant SC', serif; font-size: clamp(32px,6vw,56px); font-weight: 400; color: var(--cream); letter-spacing: .08em; }
.page-hero .subtitle { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-style: italic; color: rgba(255,245,214,.6); margin-top: 10px; }

/* ── RESPONSIVE ── */
@media (max-width: 860px) {
  #top-bar, #main-nav { padding: 8px 18px; }
  .nav-group { gap: 12px; }
  .nav-name { font-size: 28px; }
  #featured { grid-template-columns: 1fr; max-width: 420px; }
  .contact-grid { grid-template-columns: 1fr; }
  .book-detail { grid-template-columns: 1fr; max-width: 420px; }
  .section { padding: 60px 18px; }
  #hero { padding: 60px 18px 40px; }
  footer { padding: 32px 18px; }
  #unhinged-band { padding: 36px 18px; }
}

/* ── BOOK SLIDER ─────────────────────────────────────────── */
#book-slider {
  min-height: 88vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  position: relative;
  background: var(--hdr);
}

/* Blurred cover background — set via JS per slide */
#slider-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: blur(28px) brightness(0.45) saturate(1.2);
  transform: scale(1.08); /* prevent blur edge bleed */
  transition: background-image .6s ease;
  z-index: 0;
}

.slider-track-wrap {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 80px 100px;
}

.slide {
  display: none;
  animation: slideIn .5s ease;
}
.slide.active { display: block; }

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

.slide-inner {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 60px;
  align-items: center;
}

.slide-cover {
  position: relative;
  flex-shrink: 0;
}
.slide-cover img {
  width: 100%;
  max-width: 320px;
  aspect-ratio: 2/3;
  object-fit: cover;
  display: block;
  border: 1px solid rgba(202,171,199,.2);
  box-shadow: 0 40px 100px rgba(0,0,0,.7);
}
.slide-cover-placeholder {
  width: 100%;
  max-width: 320px;
  aspect-ratio: 2/3;
  background: linear-gradient(160deg, #1a0a00 0%, #3d1a06 40%, #6b2e0e 70%, #2a0000 100%);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 28px;
  border: 1px solid rgba(202,171,199,.15);
  box-shadow: 0 40px 100px rgba(0,0,0,.7);
}
.slide-cover-placeholder span {
  font-family: 'Cormorant SC', serif;
  font-size: 14px;
  letter-spacing: .2em;
  color: #FFB347;
  text-align: center;
  padding: 0 12px;
}

/* Text info box */
.slide-info {
  background: var(--slider_box, rgba(20, 14, 28, 0.72));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(202,171,199,.18);
  border-radius: 4px;
  padding: 36px 40px;
}

.slide-series {
  font-size: 10px;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 12px;
}
.slide-title {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(36px, 5.5vw, 64px);
  font-weight: 400;
  color: var(--cream);
  letter-spacing: .04em;
  margin-bottom: 20px;
  line-height: 1.05;
}
.slide-tagline {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-style: italic;
  color: rgba(255,245,214,.72);
  line-height: 1.65;
  margin-bottom: 14px;
}
.slide-desc {
  font-family: 'Cormorant Garamond', serif;
  font-size: 17px;
  color: rgba(255,245,214,.55);
  line-height: 1.75;
  margin-bottom: 32px;
}

/* Arrows */
.slider-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: 1px solid rgba(202,171,199,.3);
  color: var(--topbar_text);
  width: 44px;
  height: 44px;
  font-size: 18px;
  cursor: pointer;
  transition: all .2s;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
}
.slider-arrow:hover { background: var(--mauve); color: var(--hdr); border-color: var(--mauve); }
.slider-prev { left: 20px; }
.slider-next { right: 20px; }

/* Dots */
.slider-dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 44px;
}
.slider-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(202,171,199,.25);
  border: none;
  cursor: pointer;
  transition: all .2s;
  padding: 0;
}
.slider-dot.active { background: var(--mauve); transform: scale(1.3); }

@media (max-width: 900px) {
  #book-slider { min-height: auto; }
  .slider-track-wrap { padding: 48px 24px 36px; }
  .slide-inner { grid-template-columns: 1fr; max-width: 380px; margin: 0 auto; gap: 32px; }
  .slider-arrow { display: none; }
  .slide-cover img, .slide-cover-placeholder { max-width: 220px; margin: 0 auto; }
}

/* ── DYNAMIC COLOR VAR MAPPINGS ─────────────────────────── */
/* These map the granular --color_* vars from admin settings */
#top-bar            { background: var(--topbar_bg, var(--hdr)); }
#top-bar,
#socials-bar a,
#countdown          { color: var(--topbar_text, var(--mauve)); }
#countdown b        { color: var(--cream); }

#main-nav           { background-color: var(--hdr); }
.nav-link           { color: var(--nav_link, var(--cream)); }
.nav-link:hover,
.nav-link.active    { color: var(--nav_hover, var(--mauve)); }
.nav-name           { color: var(--nav_name, var(--cream)); font-size: 58px; }
.nav-dropdown-menu  { background: var(--hdr); border-color: var(--border_global, rgba(202,171,199,.25)); }

.section-label      { color: var(--section_label, var(--blue)); }
.ornament           { color: var(--ornament, rgba(202,171,199,.3)); }

.btn {
  border-color: var(--btn_border, var(--mauve));
  color: var(--btn_text, var(--mauve));
}
.btn:hover {
  background: var(--btn_hover_bg, var(--mauve));
  color: var(--btn_hover_text, var(--hdr));
  border-color: var(--btn_hover_bg, var(--mauve));
}
.btn-blue {
  border-color: var(--btn2_border, var(--blue));
  color: var(--btn2_text, var(--blue));
}
.btn-blue:hover {
  background: var(--btn2_border, var(--blue));
  color: var(--cream);
}

footer,
.footer-bottom      { background: var(--footer_bg, var(--hdr)); border-color: var(--footer_border, rgba(202,171,199,.15)); }
.footer-col h3      { color: var(--cream); }
.soc-btn            { border-color: var(--border_global, rgba(202,171,199,.22)); color: var(--footer_text, rgba(255,245,214,.65)); }
.footer-bottom p    { color: var(--footer_text, rgba(255,245,214,.3)); }
.footer-sig         { color: var(--footer_text, rgba(255,245,214,.3)); }

#unhinged-band      { background: var(--unhinged_bg, var(--hdr)); border-color: var(--unhinged_border, rgba(202,171,199,.15)); }

/* ── SITE IMAGES ─────────────────────────────────────────── */

/* Header / top bar texture */
#top-bar {
  background-image: none;
  background-size: cover;
  background-position: center;
}

/* Contact page background */
.contact-page-bg {
  position: relative;
  margin-bottom: 80px;
  padding-bottom: 60px;
  width: 100%;
}
.contact-page-bg::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 60px;
  background-image: url('/uploads/site/connect-bg.png');
  background-size: cover;
  background-position: center top;
  opacity: 1;
  pointer-events: none;
  z-index: 0;
  border-top: 4px solid var(--hdr);
  border-bottom: 4px solid var(--hdr);
}
.contact-page-bg > * { position: relative; z-index: 1; }

/* Fire & Water books page background */
.fire-water-page {
  background-image: url('/uploads/site/fire-water-bg.png');
  background-size: cover;
  background-position: center top;
  background-attachment: scroll;
}
.fire-water-page::before { display: none; }

/* Radley Universe page background */
.radley-page {
  background-image: url('/uploads/site/radley-bg.png');
  background-size: cover;
  background-position: center top;
  background-attachment: scroll;
}
.radley-page::before { display: none; }
.radley-page .page-hero,
.radley-page .section {
  position: relative;
  z-index: 1;
  background: transparent;
}
/* Radley needs dark text since background is light */
.radley-page .page-hero h1 { color: #1a0e0a; }
.radley-page .page-hero .subtitle { color: rgba(42,31,26,0.75); }

/* Blog list */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 40px 80px;
}
.blog-card {
  background: rgba(42, 40, 40, 0.6);
  border: 1px solid rgba(202, 171, 199, 0.15);
  transition: border-color .25s, transform .25s;
  overflow: hidden;
}
.blog-card:hover { border-color: var(--mauve); transform: translateY(-4px); }
.blog-card-cover {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  display: block;
}
.blog-card-cover-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, var(--hdr) 0%, var(--bg) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.blog-card-body { padding: 24px; }
.blog-card-date {
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 8px;
}
.blog-card-title {
  font-family: 'Cormorant SC', serif;
  font-size: 20px;
  font-weight: 400;
  color: var(--cream);
  margin-bottom: 12px;
  line-height: 1.3;
  text-decoration: none;
  display: block;
}
.blog-card-title:hover { color: var(--mauve); }
.blog-card-excerpt {
  font-family: 'Cormorant Garamond', serif;
  font-size: 15px;
  font-style: italic;
  color: rgba(255, 245, 214, 0.6);
  line-height: 1.65;
  margin-bottom: 18px;
}
.blog-card-read {
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--mauve);
  text-decoration: none;
}
.blog-card-read:hover { text-decoration: underline; }

/* Single blog post */
.blog-post { max-width: 760px; margin: 0 auto; padding: 60px 40px 100px; }
.blog-post-cover {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  display: block;
  margin-bottom: 48px;
  border: 1px solid rgba(202,171,199,.15);
}
.blog-post-meta {
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 14px;
}
.blog-post-title {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(28px, 5vw, 52px);
  font-weight: 400;
  color: var(--cream);
  line-height: 1.15;
  margin-bottom: 40px;
}
.blog-post-body {
  font-family: 'Cormorant Garamond', serif;
  font-size: 19px;
  line-height: 1.85;
  color: rgba(255, 245, 214, 0.82);
}
.blog-post-body p { margin-bottom: 20px; }
.blog-post-body h2, .blog-post-body h3 {
  font-family: 'Cormorant SC', serif;
  font-weight: 400;
  color: var(--cream);
  margin: 36px 0 14px;
}
.blog-post-body a { color: var(--blue); }
.blog-post-body a:hover { color: var(--mauve); }
.blog-post-body img { max-width: 100%; height: auto; margin: 24px 0; }
.blog-post-body ul, .blog-post-body ol { padding-left: 24px; margin-bottom: 20px; }
.blog-post-body strong { color: var(--cream); }
.blog-post-nav {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  margin-top: 60px;
  padding-top: 32px;
  border-top: 1px solid rgba(202,171,199,.15);
}
.blog-post-nav a {
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--mauve);
}

@media (max-width: 860px) {
  .blog-grid { grid-template-columns: 1fr; padding: 0 18px 60px; }
  .blog-post { padding: 40px 18px 60px; }
}

/* ── BLOG BLOCK RENDERER ─────────────────────────────────── */
.blog-block-heading {
  font-family: 'Cormorant SC', serif;
  font-weight: 400;
  color: var(--cream);
  margin: 32px 0 14px;
  line-height: 1.2;
}
.blog-block-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 19px;
  line-height: 1.85;
  color: rgba(255,245,214,.82);
  margin-bottom: 20px;
}
.blog-block-text a  { color: var(--blue); }
.blog-block-text ul,
.blog-block-text ol { padding-left: 24px; margin-bottom: 14px; }
.blog-block-image   { margin: 28px 0; }
.blog-block-image img { max-width: 100%; }
.blog-block-caption {
  font-family: 'Cormorant Garamond', serif;
  font-size: 13px;
  font-style: italic;
  color: rgba(255,245,214,.45);
  margin-top: 8px;
  text-align: center;
}
.blog-block-quote {
  border-left: 3px solid var(--mauve);
  margin: 28px 0;
  padding: 12px 20px;
}
.blog-block-quote-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px;
  font-style: italic;
  color: rgba(255,245,214,.85);
  line-height: 1.65;
  margin-bottom: 8px;
}
.blog-block-cite {
  font-size: 12px;
  letter-spacing: .12em;
  color: rgba(255,245,214,.4);
  font-style: normal;
  display: block;
}
.blog-block-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin-bottom: 24px;
}
.blog-col {
  font-family: 'Cormorant Garamond', serif;
  font-size: 17px;
  line-height: 1.75;
  color: rgba(255,245,214,.78);
}
.blog-block-button { margin: 28px 0; }
.blog-block-divider { border: none; border-top: 1px solid rgba(202,171,199,.25); margin: 32px 0; }
@media (max-width: 600px) {
  .blog-block-columns { grid-template-columns: 1fr; }
}

/* ── BLOCK EDITOR (admin) ────────────────────────────────── */
.be-toolbar {
  background: var(--hdr);
  border-bottom: 1px solid var(--border);
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
}
.be-toolbar-label {
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,245,214,.35);
  margin-right: 4px;
  flex-shrink: 0;
}
.be-block-list { padding: 10px; display: flex; flex-direction: column; gap: 6px; min-height: 60px; }

/* ── LARGER BODY TEXT ─────────────────────────────────────── */
.book-desc           { font-size: 20px; }
.slide-tagline       { font-size: 24px; }
.slide-desc          { font-size: 19px; }
.work-tagline        { font-size: 18px; }
.about-pull          { font-size: clamp(22px, 3vw, 36px); }
.about-body          { font-size: 22px; }
.blog-card-excerpt   { font-size: 17px; }
.blog-post-body      { font-size: 22px; }
.blog-block-text     { font-size: 22px; }
.unhinged-desc       { font-size: 19px; }
.ev-desc             { font-size: 17px; }
.hero-sub            { font-size: 22px; }

/* ── ABOUT PAGE LAYOUT ───────────────────────────────────── */
.about-layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 64px;
  align-items: start;
  max-width: 900px;
  margin: 0 auto;
}
.author-photo {
  width: 100%;
  border-radius: 4px;
  border: 1px solid rgba(202,171,199,.2);
  box-shadow: 0 20px 60px rgba(0,0,0,.4);
  display: block;
}
@media (max-width: 720px) {
  .about-layout { grid-template-columns: 1fr; }
  .about-photo-col { text-align: center; }
  .author-photo { max-width: 240px; margin: 0 auto; }
}

/* ══════════════════════════════════════════════════════════
   MOBILE — COMPREHENSIVE OVERHAUL
   ══════════════════════════════════════════════════════════ */

@media (max-width: 860px) {

  /* ── NAV ── */
  #main-nav { padding: 10px 16px; top: 0; }
  #main-nav .nav-group { display: none; }
  #main-nav .nav-name  { font-size: 28px; }
  .nav-hamburger       { display: flex; }

  /* ── TOP BAR ── */
  #top-bar {
    padding: 8px 16px;
    flex-direction: column;
    gap: 6px;
    text-align: center;
  }
  #countdown { justify-content: center; font-size: 10px; }
  #socials-bar { justify-content: center; gap: 14px; }
  #socials-bar svg { width: 18px; height: 18px; }

  /* ── BOOK SLIDER ── */
  #book-slider { min-height: auto; }
  .slider-track-wrap { padding: 36px 20px 28px; }
  .slide-inner {
    grid-template-columns: 1fr;
    gap: 24px;
    max-width: 100%;
    text-align: center;
  }
  .slide-cover img,
  .slide-cover-placeholder { max-width: 200px; margin: 0 auto; }
  .slide-info { padding: 24px 20px; }
  .slide-title { font-size: clamp(28px, 8vw, 42px); }
  .slide-tagline { font-size: 18px; }
  .slide-desc { font-size: 16px; }
  .btn-row { justify-content: center; }
  .slider-arrow { display: none; }
  .slider-dots { margin-top: 24px; }

  /* ── SECTIONS ── */
  .section { padding: 48px 20px; }
  .page-hero { padding: 48px 20px 32px; }
  .works-grid { gap: 32px; }

  /* ── BOOKS ── */
  #featured { gap: 32px; padding: 48px 20px; }
  .book-detail { padding: 40px 20px 60px; gap: 32px; }
  .book-detail-title { font-size: clamp(24px, 7vw, 36px); }

  /* ── ABOUT PAGE ── */
  .about-layout { grid-template-columns: 1fr; gap: 32px; }
  .about-photo-col { text-align: center; }
  .author-photo { max-width: 200px; margin: 0 auto; }
  .about-page { padding: 40px 20px 60px; }
  .about-body { font-size: 18px; }

  /* ── CONTACT PAGE ── */
  .contact-page { padding: 40px 24px 80px; }
  .contact-grid { grid-template-columns: 1fr; gap: 36px; }
  .contact-page-bg::before {
    left: 16px; right: 16px;
    top: 12px;
    border-radius: 8px;
  }
  .contact-socials { justify-content: flex-start; }

  /* ── EVENTS ── */
  .events-page { padding: 40px 20px 60px; }

  /* ── BLOG ── */
  .blog-grid { grid-template-columns: 1fr; padding: 0 20px 60px; gap: 24px; }
  .blog-post { padding: 40px 20px 60px; }
  .blog-post-title { font-size: clamp(24px, 7vw, 40px); }
  .blog-post-body { font-size: 18px; }
  .blog-block-text { font-size: 18px; }
  .blog-block-columns { grid-template-columns: 1fr; }

  /* ── UNHINGED PIT ── */
  .unhinged-row { grid-template-columns: 1fr; }
  .unhinged-photo img { height: 240px; }

  /* ── MAILING LIST ── */
  #mailing-section { padding: 48px 20px; }
  .mail-form { flex-direction: column; }
  .mail-form input { padding: 14px 16px; border-bottom: none; }
  .mail-form button { padding: 14px; width: 100%; }

  /* ── FOOTER ── */
  footer { flex-direction: column; padding: 36px 20px; gap: 32px; }
  .footer-bottom { padding: 14px 20px; flex-direction: column; gap: 6px; text-align: center; }
  .social-btns { justify-content: flex-start; }

  /* ── FIRE & WATER / RADLEY ── */
  .fire-water-page .page-hero,
  .radley-page .page-hero,
  .fire-water-page .section,
  .radley-page .section { padding-left: 20px; padding-right: 20px; }

  /* ── BOOK SERIES GRIDS ── */
  .works-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .work-img { max-width: 160px; }
}

/* Extra small phones */
@media (max-width: 480px) {
  .works-grid { grid-template-columns: 1fr; }
  .section-title { font-size: 28px; }
  .nav-name { font-size: 26px !important; }
  .about-pull { font-size: 20px; }
  .hero-sub { font-size: 18px; }
  .blog-post-nav { flex-direction: column; gap: 12px; }
  #top-bar { font-size: 10px; }
  .contact-page-bg::before { left: 12px; right: 12px; }
}

/* ── ABOUT PAGE BACKGROUND ──────────────────────────────── */
/* ── ABOUT PAGE ─────────────────────────────────────────── */
.about-bg-wrap {
  position: relative;
  width: 100%;
  margin: 40px 0 60px;
  border-top: 4px solid var(--hdr);
  border-bottom: 4px solid var(--hdr);
  overflow: hidden;
  min-height: 400px;
  display: flex;
  justify-content: center;
}
.about-bg-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url('/uploads/site/about-bg.png');
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.about-bg-wrap > * { position: relative; z-index: 1; width: 100%; }

.about-layout {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 0;
  align-items: stretch;
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
}
.about-photo-col {
  padding: 40px 24px 40px 40px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}
.about-text-panel {
  background: var(--about_panel, rgba(30, 18, 35, 0.72));
  padding: 40px 44px 40px 28px;
  backdrop-filter: blur(2px);
}
.about-text-panel p {
  color: #FFF5D6 !important;
  font-size: 17px;
  line-height: 1.85;
  margin-bottom: 16px;
}
.about-bg-wrap .author-photo {
  width: 100%;
  border-radius: 4px;
  border: 3px solid rgba(255,245,214,.3);
  box-shadow: 0 12px 40px rgba(0,0,0,.5);
  display: block;
}
@media (max-width: 720px) {
  .about-layout { grid-template-columns: 1fr; }
  .about-photo-col { padding: 28px 28px 12px; justify-content: center; }
  .about-photo-col .author-photo { max-width: 200px; }
  .about-text-panel { padding: 16px 24px 32px; }
  .about-bg-wrap { margin: 0 16px 40px; }
}

/* ── DYNAMIC BACKGROUND IMAGES (from Settings) ──────────── */
/* Falls back to hardcoded paths if var is none */

#top-bar {
  background-image: var(--bg_topbar, none);
  background-size: cover;
  background-position: center;
}

#main-nav {
  background-image: var(--bg_nav, url('/uploads/site/nav-texture.png'));
  background-size: cover;
  background-position: center;
}

/* Slider BG is set via JS data-cover, but also honour setting for a static fallback */
#slider-bg { background-image: var(--bg_homepage, none); }

.fire-water-page {
  background-image: var(--bg_fire_water, url('/uploads/site/fire-water-bg.png'));
  background-attachment: scroll;
}

.radley-page {
  background-image: var(--bg_radley, url('/uploads/site/radley-bg.png'));
  background-attachment: scroll;
}

.about-bg-wrap::before {
  background-image: var(--bg_about, url('/uploads/site/about-bg.png'));
}

.contact-page-bg::before {
  background-image: var(--bg_contact, url('/uploads/site/connect-bg.png'));
}

/* ── DYNAMIC FONT SIZES ──────────────────────────────────── */
body                  { font-size: var(--fs-base, 18px); }
.blog-post-body,
.blog-block-text,
.about-text-panel p,
.contact-block p,
.ev-desc              { font-size: var(--fs-body, 20px); }
.nav-link             { font-size: var(--fs-nav, 11px); }

/* ── WIDER CONTENT MARGINS ───────────────────────────────── */
.slider-track-wrap    { padding-left: 60px; padding-right: 60px; }
.blog-grid            { max-width: 1300px; padding-left: 60px; padding-right: 60px; }
.blog-post            { max-width: 860px; }
.about-page           { padding-left: 40px; padding-right: 40px; }
/* about-bg-wrap max-width removed */
.contact-page         { max-width: 940px; padding: 60px 100px 100px; }
section.section,
.events-page          { max-width: 1200px; margin-left: auto; margin-right: auto; padding-left: 60px; padding-right: 60px; }
.page-hero            { padding-left: 60px; padding-right: 60px; }
footer > .footer-inner { max-width: 1200px; }

@media (max-width: 860px) {
  .slider-track-wrap { padding-left: 20px; padding-right: 20px; }
  .blog-grid         { padding-left: 20px; padding-right: 20px; }
  .about-page        { padding-left: 16px; padding-right: 16px; }
  .contact-page      { padding: 40px 24px 80px; }
  .page-hero         { padding-left: 20px; padding-right: 20px; }
}

/* ── DISRUPTORS SCRIPT / PINYON SCRIPT for site name ─────── */
.nav-name,
.mob-name,
.footer-sig {
  font-family: 'Disruptors Script', 'Pinyon Script', cursive;
}

/* ── ABOUT PHOTO: LIFTED EFFECT (no border) ──────────────── */
.about-bg-wrap .author-photo {
  border: none;
  border-radius: 4px;
  box-shadow:
    0 6px 12px rgba(0,0,0,.18),
    0 18px 40px rgba(0,0,0,.32),
    0 40px 80px rgba(0,0,0,.28);
  transform: perspective(800px) rotateY(2deg) rotateX(-1deg);
  transition: transform .3s ease, box-shadow .3s ease;
}
.about-bg-wrap .author-photo:hover {
  transform: perspective(800px) rotateY(0deg) rotateX(0deg) translateY(-4px);
  box-shadow:
    0 8px 20px rgba(0,0,0,.22),
    0 24px 52px rgba(0,0,0,.36),
    0 50px 100px rgba(0,0,0,.3);
}

/* ── CONTACT & ABOUT CENTERING ───────────────────────────── */
/* Inner wrapper centers content while section is full width */
.contact-page-inner {
  max-width: 1100px;
  margin: 0 auto;
}
.about-photo-col {
  padding: 48px 32px 48px 48px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}
.about-text-panel {
  padding: 48px 64px 48px 40px;
}

/* ── CENTER ABOUT AND CONTACT CONTENT ────────────────────── */
.about-bg-wrap .about-layout {
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
}
.contact-page {
  max-width: 1200px;
  margin: 0 auto;
}
.contact-grid {
  max-width: 100%;
}

/* ── FONT SIZE SETTINGS — applied directly via layout injection ── */
/* These get overridden by inline <style> from layout.php */

/* ── RADLEY UNIVERSE book card buttons — add text box ── */
.radley-page .work-card {
  position: relative;
}
.radley-page .work-desc-box {
  background: rgba(20, 14, 28, 0.65);
  padding: 14px 16px;
  margin: 10px 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: 16px;
  line-height: 1.65;
  color: var(--cream);
}
.radley-page .work-desc-box.transparent {
  background: transparent;
}

/* ── FIRE & WATER page — fix section backgrounds after removing tint ── */
.fire-water-page .page-hero,
.fire-water-page .section {
  background: transparent;
}

/* ── INDIVIDUAL BOOK PAGE — text box over series background ── */
.book-detail {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 60px;
  align-items: start;
  max-width: 1100px;
  margin: 0 auto;
  padding: 80px 60px;
  position: relative;
  z-index: 1;
}
.book-detail-info {
  background: var(--book_detail_box, rgba(20, 14, 28, 0.72));
  backdrop-filter: blur(6px);
  border: 1px solid rgba(202,171,199,.18);
  border-radius: 4px;
  padding: 40px;
}
.radley-page .book-detail-info {
  background: var(--book_detail_radley, rgba(240, 228, 220, 0.82));
  border-color: rgba(42,31,26,.15);
}
/* ── ENSURE NAV/FOOTER COVER SERIES PAGE BACKGROUNDS ─────── */
#main-nav { isolation: isolate; }
footer, .footer-bottom { position: relative; z-index: 10; background: var(--footer_bg, var(--hdr)) !important; }

/* ══ ABOUT PAGE — DEFINITIVE RULES ══════════════════════════ */
.about-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  align-items: stretch;
  width: 100%;
  padding: 48px 0;
}

/* Photo col — pushed to the far left */
.about-photo-col {
  padding: 48px 20px 48px 48px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

/* Text panel — semi-transparent so background image shows through */
.about-text-panel {
  background: var(--about_panel, rgba(20, 12, 30, 0.68)) !important;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  padding: 48px 60px 48px 40px !important;
  font-family: 'Cormorant Garamond', serif;
}

.about-text-panel * {
  color: #FFF5D6 !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 20px;
  line-height: 1.85;
}

.about-text-panel p { margin-bottom: 16px; }

/* Author photo — lifted shadow, no border */
.about-bg-wrap .author-photo {
  width: 100%;
  border: none !important;
  border-radius: 4px;
  box-shadow: 0 8px 20px rgba(0,0,0,.25), 0 24px 52px rgba(0,0,0,.38), 0 50px 80px rgba(0,0,0,.28);
  transform: perspective(800px) rotateY(2deg) rotateX(-1deg);
  transition: transform .3s, box-shadow .3s;
  display: block;
}
.about-bg-wrap .author-photo:hover {
  transform: perspective(800px) rotateY(0) rotateX(0) translateY(-4px);
  box-shadow: 0 12px 28px rgba(0,0,0,.3), 0 32px 64px rgba(0,0,0,.42);
}

.about-bg-wrap .about-layout { max-width: 1400px; margin: 0 auto; width: 100%; }

@media (max-width: 720px) {
  .about-layout { grid-template-columns: 1fr !important; }
  .about-photo-col { padding: 28px 28px 12px; justify-content: center; }
  .about-photo-col .author-photo { max-width: 200px; }
  .about-text-panel { padding: 20px 24px 32px !important; }
}

/* ── ABOUT TEXT — shift panel further right ─────────────── */
.about-text-panel {
  margin-left: 60px !important;
}
@media (max-width: 720px) {
  .about-text-panel { margin-left: 0 !important; }
}

/* ── BOOK LIST CARD INFO BOX ─────────────────────────────── */
.book-card-info-box {
  background: var(--book_detail_box, rgba(20, 14, 28, 0.72));
  backdrop-filter: blur(4px);
  border: 1px solid rgba(202,171,199,.18);
  border-radius: 4px;
  padding: 20px 24px;
  margin-top: 12px;
  width: 100%;
}
.radley-page .book-card-info-box {
  background: var(--book_detail_radley, rgba(240, 228, 220, 0.82));
  border-color: rgba(42,31,26,.15);
}
/* ── ABOUT TEXT — fix opacity + push right ──────────────── */
.about-text-panel {
  background: var(--about_panel, rgba(20, 12, 30, 0.62)) !important;
  backdrop-filter: blur(3px) !important;
  margin-left: 80px !important;
  padding: 48px 60px 48px 40px !important;
}
@media (max-width: 720px) {
  .about-text-panel { margin-left: 0 !important; }
  .book-card-info-box { padding: 16px; }
}

/* ── RADLEY UNIVERSE — visible text and buttons ─────────── */
/* ── ABOUT — larger photo to fill column ── */
.about-bg-wrap .author-photo { max-width: 360px !important; width: 100% !important; }
.about-photo-col { padding: 0 24px 0 48px !important; justify-content: center !important; }

/* ══ ABOUT — FINAL ══════════════════════════════════════════ */
.about-bg-wrap {
  width: 100%;
  background-image: var(--bg_about, url('/uploads/site/about-bg.png'));
  background-size: cover;
  background-position: center;
  border-top: 4px solid var(--hdr);
  border-bottom: 4px solid var(--hdr);
  margin: 40px 0 60px;
}

.about-inner {
  display: grid;
  grid-template-columns: 380px 1fr;
  align-items: center;
  max-width: 1400px;
  margin: 0 auto;
  padding: 56px 0;
  gap: 0;
}

.about-photo-col {
  padding: 0 24px 0 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.about-photo-col .author-photo {
  width: 100%;
  max-width: 340px;
  border-radius: 4px;
  display: block;
  box-shadow: 0 12px 32px rgba(0,0,0,.35), 0 32px 64px rgba(0,0,0,.3);
}

.about-text-panel {
  margin: 0 60px 0 140px;
  padding: 36px 40px;
  border: 1px solid rgba(202,171,199,.2);
  border-radius: 4px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  line-height: 1.85;
  color: #FFF5D6 !important;
}

.about-text-panel p {
  color: #FFF5D6 !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 18px;
  line-height: 1.85;
  margin: 0 0 16px;
}

/* ── ABOUT MOBILE — override inline styles ───────────────── */
@media (max-width: 760px) {
  .about-inner,
  .about-bg-wrap .about-inner {
    display: block !important;
    padding: 28px 0 !important;
  }
  .about-photo-col {
    padding: 0 20px 20px !important;
    justify-content: center !important;
  }
  .about-photo-col .author-photo {
    max-width: 180px !important;
    margin: 0 auto !important;
  }
  .about-text-panel {
    margin: 0 16px 0 16px !important;
    padding: 24px 20px !important;
  }
  .about-bg-wrap {
    background-image: none !important;
    background-color: var(--bg) !important;
    border: none !important;
    margin: 0 0 32px !important;
  }
}

/* ══ ABOUT — ABSOLUTE FINAL DESKTOP ════════════════════════ */
@media (min-width: 761px) {
  .about-inner {
    display: grid !important;
    grid-template-columns: 380px 1fr !important;
    align-items: center !important;
    max-width: 1400px;
    margin: 0 auto;
    padding: 56px 0 !important;
  }
  .about-photo-col {
    padding: 0 24px 0 60px !important;
    justify-content: center !important;
  }
  .about-photo-col .author-photo {
    max-width: 340px !important;
    width: 100%;
  }
  .about-text-panel {
    margin: 0 60px 0 140px !important;
    padding: 36px 40px !important;
  }
}

/* ── ABOUT MOBILE — right edge fix ─────────────────────────*/
@media (max-width: 760px) {
  .about-page { padding: 0 16px !important; }
}

/* Radley Universe — buttons */
.radley-page .btn,
.radley-page .book-detail-info .btn {
  border-color: var(--radley_btn,      #2a1510) !important;
  color:         var(--radley_btn_text, #2a1510) !important;
  background:    rgba(255,255,255,0.35) !important;
}
.radley-page .btn:hover,
.radley-page .book-detail-info .btn:hover {
  background:    var(--radley_btn_hover_bg,   #2a1510) !important;
  color:         var(--radley_btn_hover_text, #FFF5D6) !important;
}

/* Radley text colors */
/* Fire & Water primary button (.btn) */
.fire-water-page .btn:not(.btn-blue) {
  border-color: var(--book_btn,          #caabc7) !important;
  color:         var(--book_btn_text,     #caabc7) !important;
  background:    transparent !important;
}
.fire-water-page .btn:not(.btn-blue):hover {
  background:    var(--book_btn_hover_bg,   #caabc7) !important;
  color:         var(--book_btn_hover_text, #2a2828) !important;
}

/* Fire & Water secondary button (.btn-blue = pre-order etc.) */
.fire-water-page .btn-blue {
  border-color: var(--book_btn2,          #7186B1) !important;
  color:         var(--book_btn2_text,     #7186B1) !important;
  background:    transparent !important;
}
.fire-water-page .btn-blue:hover {
  background:    var(--book_btn2_hover_bg,   #7186B1) !important;
  color:         var(--book_btn2_hover_text, #2a2828) !important;
}

/* Radley text */
/* Radley primary button */
.radley-page .btn:not(.btn-blue) {
  border-color: var(--radley_btn,          #2a1510) !important;
  color:         var(--radley_btn_text,     #2a1510) !important;
  background:    rgba(255,255,255,0.35) !important;
}
.radley-page .btn:not(.btn-blue):hover {
  background:    var(--radley_btn_hover_bg,   #2a1510) !important;
  color:         var(--radley_btn_hover_text, #FFF5D6) !important;
}

/* Radley secondary button */
.radley-page .btn-blue {
  border-color: var(--radley_btn2,          #2a1510) !important;
  color:         var(--radley_btn2_text,     #2a1510) !important;
  background:    rgba(255,255,255,0.35) !important;
}
.radley-page .btn-blue:hover {
  background:    var(--radley_btn2_hover_bg,   #2a1510) !important;
  color:         var(--radley_btn2_hover_text, #FFF5D6) !important;
}

/* Book list pages (books.php) — fire & water */
.fire-water-page .work-title         { color: var(--book_title,   #FFF5D6) !important; }
.fire-water-page .work-tagline       { color: var(--book_tagline, #FFF5D6) !important; }
.fire-water-page .book-series        { color: var(--book_series,  #caabc7) !important; }

/* Individual book page — radley */
.radley-page .book-series            { color: var(--radley_series,  #5a3a2a) !important; }
.radley-page .book-detail-title      { color: var(--radley_title,   #1a0e0a) !important; }
.radley-page .book-desc              { color: var(--radley_tagline, #2a1f1a) !important; }
.radley-page .book-detail-body       { color: var(--radley_body,    #2a1f1a) !important; }
.radley-page .book-detail-body *     { color: var(--radley_body,    #2a1f1a) !important; }

/* Book list pages — radley */
.radley-page .work-title             { color: var(--radley_title,   #1a0e0a) !important; }
.radley-page .work-tagline           { color: var(--radley_tagline, #2a1f1a) !important; }
.radley-page .book-series            { color: var(--radley_series,  #5a3a2a) !important; }

/* ══ BOOK & SERIES COLORS — single source of truth ════════ */

/* Fire & Water */
.fire-water-page .book-series        { color: var(--book_series,  #caabc7) !important; }
.fire-water-page .book-detail-title  { color: var(--book_title,   #FFF5D6) !important; }
.fire-water-page .work-title         { color: var(--book_title,   #FFF5D6) !important; }
.fire-water-page .book-desc          { color: var(--book_tagline, #FFF5D6) !important; }
.fire-water-page .work-tagline       { color: var(--book_tagline, #FFF5D6) !important; }
.fire-water-page .book-detail-body,
.fire-water-page .book-detail-body * { color: var(--book_body,    #FFF5D6) !important; }

.fire-water-page .btn:not(.btn-blue):not([style*="1ED760"]) {
  border-color: var(--book_btn,            #caabc7) !important;
  color:         var(--book_btn_text,       #caabc7) !important;
  background:    transparent !important;
}
.fire-water-page .btn:not(.btn-blue):not([style*="1ED760"]):hover {
  background:    var(--book_btn_hover_bg,   #caabc7) !important;
  color:         var(--book_btn_hover_text, #2a2828) !important;
}
.fire-water-page .btn-blue {
  border-color: var(--book_btn2,            #7186B1) !important;
  color:         var(--book_btn2_text,       #7186B1) !important;
  background:    transparent !important;
}
.fire-water-page .btn-blue:hover {
  background:    var(--book_btn2_hover_bg,   #7186B1) !important;
  color:         var(--book_btn2_hover_text, #2a2828) !important;
}

/* Radley Universe */
.radley-page .book-series        { color: var(--radley_series,  #5a3a2a) !important; }
.radley-page .book-detail-title  { color: var(--radley_title,   #1a0e0a) !important; }
.radley-page .work-title         { color: var(--radley_title,   #1a0e0a) !important; }
.radley-page .book-desc          { color: var(--radley_tagline, #2a1f1a) !important; }
.radley-page .work-tagline       { color: var(--radley_tagline, #2a1f1a) !important; }
.radley-page .book-detail-body,
.radley-page .book-detail-body * { color: var(--radley_body,    #2a1f1a) !important; }

.radley-page .btn:not(.btn-blue) {
  border-color: var(--radley_btn,            #2a1510) !important;
  color:         var(--radley_btn_text,       #2a1510) !important;
  background:    rgba(255,255,255,0.35) !important;
}
.radley-page .btn:not(.btn-blue):hover {
  background:    var(--radley_btn_hover_bg,   #2a1510) !important;
  color:         var(--radley_btn_hover_text, #FFF5D6) !important;
}
.radley-page .btn-blue {
  border-color: var(--radley_btn2,            #2a1510) !important;
  color:         var(--radley_btn2_text,       #2a1510) !important;
  background:    rgba(255,255,255,0.35) !important;
}
.radley-page .btn-blue:hover {
  background:    var(--radley_btn2_hover_bg,   #2a1510) !important;
  color:         var(--radley_btn2_hover_text, #FFF5D6) !important;
}

/* Series label — separate vars for slider vs book pages */
.slide-series { color: var(--slide_series, #caabc7) !important; }

/* ── BOOK DETAIL — mobile ───────────────────────────────── */
@media (max-width: 860px) {
  .book-detail {
    grid-template-columns: 1fr !important;
    padding: 32px 20px !important;
    gap: 24px !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .book-detail-cover {
    max-width: 200px !important;
    margin: 0 auto !important;
    display: block !important;
  }
  .book-detail-info {
    padding: 24px 20px !important;
    box-sizing: border-box !important;
  }
  .btn-row { flex-wrap: wrap !important; justify-content: center !important; }
}