/* ===================================================
   ESHOM CABIN PRESS — Main Stylesheet
   Palette: Burgundy, Forest Green, Aged Gold, Parchment
   =================================================== */

/* Self-hosted serif webfonts (H2.3, 2026-06-04). Replaces the render-blocking
   Google Fonts @import in style.css. woff2 mirrored to /fonts/ (variable fonts:
   one file per family/style/range, shared across weights). Rendering is identical
   to the prior Google Fonts CSS. */
@font-face{font-family:'IM Fell English';font-style:italic;font-weight:400;font-display:swap;src:url('/fonts/imfellenglish-italic-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'IM Fell English';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/imfellenglish-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Crimson Pro';font-style:italic;font-weight:300;font-display:swap;src:url('/fonts/crimsonpro-italic-vietnamese.woff2') format('woff2');unicode-range:U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;}
@font-face{font-family:'Crimson Pro';font-style:italic;font-weight:300;font-display:swap;src:url('/fonts/crimsonpro-italic-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Crimson Pro';font-style:italic;font-weight:300;font-display:swap;src:url('/fonts/crimsonpro-italic-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Crimson Pro';font-style:italic;font-weight:400;font-display:swap;src:url('/fonts/crimsonpro-italic-vietnamese.woff2') format('woff2');unicode-range:U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;}
@font-face{font-family:'Crimson Pro';font-style:italic;font-weight:400;font-display:swap;src:url('/fonts/crimsonpro-italic-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Crimson Pro';font-style:italic;font-weight:400;font-display:swap;src:url('/fonts/crimsonpro-italic-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Crimson Pro';font-style:normal;font-weight:300;font-display:swap;src:url('/fonts/crimsonpro-normal-vietnamese.woff2') format('woff2');unicode-range:U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;}
@font-face{font-family:'Crimson Pro';font-style:normal;font-weight:300;font-display:swap;src:url('/fonts/crimsonpro-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Crimson Pro';font-style:normal;font-weight:300;font-display:swap;src:url('/fonts/crimsonpro-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Crimson Pro';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/crimsonpro-normal-vietnamese.woff2') format('woff2');unicode-range:U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;}
@font-face{font-family:'Crimson Pro';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/crimsonpro-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Crimson Pro';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/crimsonpro-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Crimson Pro';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/crimsonpro-normal-vietnamese.woff2') format('woff2');unicode-range:U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;}
@font-face{font-family:'Crimson Pro';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/crimsonpro-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Crimson Pro';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/crimsonpro-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Cinzel';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/cinzel-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Cinzel';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/cinzel-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Cinzel';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/cinzel-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Cinzel';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/cinzel-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Cinzel';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/cinzel-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Cinzel';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/cinzel-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}

/* ---- CSS Variables ---- */
:root {
  --burgundy:       #7A1C2E;
  --dark-burgundy:  #4A0E1A;
  --deep-red:       #2E0A11;
  --gold:           #C9A84C;
  --gold-light:     #E2C97E;
  --gold-dim:       #8B6914;
  --gold-text:      #B89328; /* H2.2 F5: contrast-safe gold for small label text (AA on dark bg); --gold-dim stays for borders/fills */
  --forest:         #2D3D2A;
  --dark-forest:    #1A2318;
  --parchment:      #F2E4C4;
  --cream:          #FAF3E3;
  --bark:           #5C3317;
  --ash:            #C4B49A;
  --shadow:         #0D0B08;
  --smoke:          #E8DCC8;

  --font-display:   'IM Fell English', serif;
  --font-title:     'Cinzel', serif;
  --font-body:      'Crimson Pro', serif;

  --radius:         4px;
  --transition:     0.3s ease;
}

/* ---- Reset & Base ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: var(--font-body);
  background-color: var(--shadow);
  color: var(--parchment);
  line-height: 1.7;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a  { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* ---- Scrollbar ---- */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--deep-red); }
::-webkit-scrollbar-thumb { background: var(--gold-dim); border-radius: 4px; }

/* ================================================
   NAVIGATION
   ================================================ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 3rem;
  height: 80px;
  background: linear-gradient(to bottom, rgba(13,11,8,0.97) 0%, rgba(13,11,8,0.85) 100%);
  border-bottom: 1px solid rgba(201,168,76,0.2);
  backdrop-filter: blur(6px);
  transition: background var(--transition);
}

.nav.scrolled {
  background: rgba(13,11,8,0.98);
  border-bottom-color: rgba(201,168,76,0.4);
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.nav-logo img {
  height: 54px;
  width: auto;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.6));
}

.nav-links {
  display: flex;
  gap: 2.5rem;
  align-items: center;
}

.nav-links a {
  font-family: var(--font-title);
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ash);
  transition: color var(--transition);
  position: relative;
}

.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0; right: 0;
  height: 1px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}

.nav-links a:hover, .nav-links a.active { color: var(--gold); }
.nav-links a:hover::after, .nav-links a.active::after { transform: scaleX(1); }

.nav-cart {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-title);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--parchment);
  background: var(--burgundy);
  border: 1px solid var(--gold-dim);
  padding: 0.45rem 1.1rem;
  border-radius: var(--radius);
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition);
}

.nav-cart:hover { background: var(--dark-burgundy); border-color: var(--gold); }
.nav-cart .count {
  background: var(--gold);
  color: var(--shadow);
  border-radius: 50%;
  width: 18px; height: 18px;
  font-size: 0.65rem;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
}

.nav-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 4px;
  /* H2.2 (2026-06-03): now a real <button> for keyboard/AT access — reset the
     native button chrome so it renders identically to the old <div>. */
  background: none;
  border: 0;
  margin: 0;
  -webkit-appearance: none;
  appearance: none;
}
.nav-hamburger span {
  width: 24px; height: 2px;
  background: var(--parchment);
  transition: var(--transition);
}

/* H2.2 (2026-06-03): visible keyboard-focus ring (keyboard only, so mouse
   clicks don't get an outline). No layout impact — uses outline, not border. */
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}

/* ================================================
   HERO
   ================================================ */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  background: var(--deep-red);
}

.hero-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 70%, rgba(74,14,26,0.7) 0%, transparent 70%),
    radial-gradient(ellipse 50% 80% at 20% 30%, rgba(45,61,42,0.4) 0%, transparent 60%),
    radial-gradient(ellipse 50% 80% at 80% 30%, rgba(45,61,42,0.4) 0%, transparent 60%),
    linear-gradient(175deg, #0D0B08 0%, #1A0A10 40%, #0D0B08 100%);
}

.hero-texture {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C9A84C' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

.hero-content {
  position: relative;
  z-index: 3;
  text-align: center;
  max-width: 800px;
  padding: 0 2rem;
  padding-top: 80px;
}

.hero-eyebrow {
  font-family: var(--font-title);
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.5rem;
  opacity: 0;
  animation: fadeUp 0.8s ease 0.3s forwards;
}

.hero-eyebrow::before, .hero-eyebrow::after {
  content: '— ';
  opacity: 0.6;
}
.hero-eyebrow::after { content: ' —'; }

.hero-logo {
  width: 220px;
  height: 220px;
  object-fit: contain;
  margin: 0 auto 2rem;
  filter: drop-shadow(0 8px 32px rgba(0,0,0,0.7));
  opacity: 0;
  animation: fadeDown 0.9s ease 0.1s forwards;
  display: block;
}

.hero-headline {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 5vw, 4rem);
  line-height: 1.2;
  color: var(--parchment);
  margin-bottom: 1.25rem;
  text-shadow: 0 2px 20px rgba(0,0,0,0.5);
  opacity: 0;
  animation: fadeUp 0.8s ease 0.5s forwards;
}

.hero-headline em {
  color: var(--gold-light);
  font-style: italic;
}

.hero-sub {
  font-size: 1.2rem;
  color: var(--ash);
  max-width: 520px;
  margin: 0 auto 2.5rem;
  font-style: italic;
  opacity: 0;
  animation: fadeUp 0.8s ease 0.7s forwards;
}

.hero-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeUp 0.8s ease 0.9s forwards;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-title);
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 0.85rem 2rem;
  border-radius: var(--radius);
  cursor: pointer;
  transition: all var(--transition);
  border: none;
}

.btn-primary {
  background: linear-gradient(135deg, var(--burgundy), var(--dark-burgundy));
  color: var(--parchment);
  border: 1px solid var(--gold-dim);
  box-shadow: 0 4px 20px rgba(122,28,46,0.4);
}
.btn-primary:hover {
  background: linear-gradient(135deg, #8F2236, #5A1020);
  border-color: var(--gold);
  box-shadow: 0 6px 28px rgba(122,28,46,0.6);
  transform: translateY(-2px);
}

.btn-outline {
  background: transparent;
  color: var(--gold);
  border: 1px solid var(--gold-dim);
}
.btn-outline:hover {
  background: rgba(201,168,76,0.08);
  border-color: var(--gold);
  transform: translateY(-2px);
}

.hero-scroll {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-title);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold-text);
  animation: fadeIn 1s ease 1.5s both;
  z-index: 1;
  pointer-events: none;
}

.hero-scroll-line {
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, var(--gold-dim), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}

/* ================================================
   SECTION COMMONS
   ================================================ */
.section {
  padding: 7rem 0;
}

.section-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
}

.section-label {
  font-family: var(--font-title);
  font-size: 0.65rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.section-label::before {
  content: '';
  width: 30px;
  height: 1px;
  background: var(--gold-dim);
}

.section-heading {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  color: var(--parchment);
  line-height: 1.25;
  margin-bottom: 1rem;
}

.section-heading em { color: var(--gold-light); font-style: italic; }

.section-divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 2.5rem 0;
}
.section-divider::before, .section-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, transparent, rgba(201,168,76,0.3), transparent);
}
.section-divider span {
  color: var(--gold-text);
  font-size: 1rem;
}

/* ================================================
   FEATURED STRIP (below hero)
   ================================================ */
.strip {
  background: var(--dark-burgundy);
  border-top: 1px solid rgba(201,168,76,0.25);
  border-bottom: 1px solid rgba(201,168,76,0.25);
  padding: 1rem 0;
  overflow: hidden;
}

.strip-inner {
  display: flex;
  gap: 3rem;
  animation: marquee 25s linear infinite;
  white-space: nowrap;
}

.strip-item {
  font-family: var(--font-title);
  font-size: 0.68rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-shrink: 0;
}

.strip-item::after { content: '✦'; color: var(--gold-text); }

/* ================================================
   BOOKS / SHOP GRID
   ================================================ */
.books-section {
  background: linear-gradient(to bottom, var(--shadow) 0%, #120a0d 50%, var(--shadow) 100%);
}

.books-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 2rem;
  margin-top: 3rem;
}

.book-card {
  background: linear-gradient(145deg, #1A100D, #120A0D);
  border: 1px solid rgba(201,168,76,0.12);
  border-radius: 6px;
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
  position: relative;
}

.book-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(201,168,76,0.04) 0%, transparent 50%);
  pointer-events: none;
}

.book-card:hover {
  transform: translateY(-6px);
  border-color: rgba(201,168,76,0.4);
  box-shadow: 0 16px 48px rgba(0,0,0,0.5), 0 0 20px rgba(201,168,76,0.07);
}

.book-cover {
  aspect-ratio: unset;
  min-height: 200px;
  background: linear-gradient(145deg, var(--dark-forest), var(--forest));
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.book-cover img {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
}

.book-cover-img {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
  transition: transform 0.5s ease;
}

.book-card:hover .book-cover-img { transform: scale(1.05); }

.book-cover-placeholder {
  text-align: center;
  padding: 2rem 1rem;
}

.book-cover-placeholder .book-title-text {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--parchment);
  line-height: 1.3;
  margin-bottom: 0.5rem;
}

.book-cover-placeholder .book-author-text {
  font-family: var(--font-title);
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--gold-text);
}

.book-cover-art {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  padding: 1.5rem;
  background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, transparent 50%);
}

.book-badge {
  font-family: var(--font-title);
  font-size: 0.58rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  background: var(--burgundy);
  color: var(--gold-light);
  border: 1px solid var(--gold-dim);
  padding: 0.25rem 0.6rem;
  border-radius: 2px;
}

/* ── Dynamic book badges — overlay pills ── */
.book-badge-overlay {
  position: absolute;
  bottom: .65rem;
  left: .65rem;
  z-index: 10;
  pointer-events: none;
  /* 13.c: stack multiple pills vertically (e.g. New Release + Pre-order) */
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: .3rem;
}
.book-badge-pill {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-family: var(--font-title);
  font-size: .56rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: .3rem .7rem;
  border-radius: 20px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-weight: 700;
}
.book-badge-pill.new-release {
  background: rgba(110,24,40,.82);
  color: #F2E4C4;
  border: 1px solid rgba(201,168,76,.45);
  box-shadow: 0 2px 12px rgba(0,0,0,.4);
}
.book-badge-pill.coming-soon {
  background: rgba(26,14,18,.8);
  color: rgba(201,168,76,.9);
  border: 1px solid rgba(201,168,76,.3);
  box-shadow: 0 2px 8px rgba(0,0,0,.35);
}
.book-badge-pill.preorder {
  background: rgba(201,168,76,.92);
  color: #2A0A11;
  border: 1px solid rgba(110,24,40,.45);
  box-shadow: 0 2px 10px rgba(0,0,0,.35);
}

/* Coming soon card overlay */
.book-cover-coming-soon-overlay {
  position: absolute;
  inset: 0;
  background: rgba(13,8,5,.55);
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .6rem;
  z-index: 8;
  opacity: 0;
  transition: opacity .25s ease;
}
.book-cover:hover .book-cover-coming-soon-overlay { opacity: 1; }
.coming-soon-notify-btn {
  font-family: var(--font-title);
  font-size: .6rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  background: rgba(110,24,40,.9);
  color: var(--gold-light);
  border: 1px solid rgba(201,168,76,.4);
  padding: .55rem 1.25rem;
  border-radius: 4px;
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}
.coming-soon-notify-btn:hover {
  background: var(--burgundy);
  border-color: var(--gold-dim);
}

/* Notify Me modal */
.notify-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.7);
  z-index: 9800;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
}
.notify-modal-overlay.open {
  opacity: 1;
  pointer-events: all;
}
.notify-modal {
  background: #1A0E12;
  border: 1px solid rgba(201,168,76,.2);
  border-radius: 8px;
  padding: 2rem;
  max-width: 420px;
  width: 100%;
  text-align: center;
  position: relative;
  transform: translateY(12px);
  transition: transform .25s;
}
.notify-modal-overlay.open .notify-modal { transform: translateY(0); }
.notify-modal-close {
  position: absolute;
  top: .75rem;
  right: .75rem;
  background: none;
  border: none;
  color: var(--ash);
  font-size: 1.1rem;
  cursor: pointer;
  line-height: 1;
  padding: .25rem;
}

.book-info {
  padding: 1.25rem;
}

.book-meta {
  font-family: var(--font-title);
  font-size: 0.6rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-text);
  margin-bottom: 0.4rem;
}

.book-name {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--parchment);
  line-height: 1.3;
  margin-bottom: 0.3rem;
}

.book-author {
  font-size: 0.88rem;
  color: var(--ash);
  font-style: italic;
  margin-bottom: 0.75rem;
}

.book-desc {
  font-size: 0.9rem;
  color: var(--ash);
  line-height: 1.6;
  margin-bottom: 1rem;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.book-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(201,168,76,0.1);
}

.book-price {
  font-family: var(--font-title);
  font-size: 1.1rem;
  color: var(--gold);
}

.book-price .orig {
  font-size: 0.8rem;
  color: var(--ash);
  text-decoration: line-through;
  margin-left: 0.4rem;
}

.btn-add {
  background: var(--dark-forest);
  color: var(--gold-light);
  border: 1px solid rgba(201,168,76,0.25);
  font-family: var(--font-title);
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.45rem 0.9rem;
  border-radius: var(--radius);
  cursor: pointer;
  transition: all var(--transition);
}

.btn-add:hover {
  background: var(--forest);
  border-color: var(--gold);
}

/* ================================================
   FEATURED BOOK (full width spotlight)
   ================================================ */
.featured-section {
  background: linear-gradient(135deg, var(--dark-forest) 0%, var(--dark-burgundy) 100%);
  border-top: 1px solid rgba(201,168,76,0.15);
  border-bottom: 1px solid rgba(201,168,76,0.15);
}

.featured-inner {
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
}

/* All slides occupy the same grid cell — container height = tallest slide */
.feat-slide {
  grid-area: 1 / 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s ease;
  min-height: 0;
}

.feat-slide-active {
  opacity: 1;
  pointer-events: auto;
}

.featured-book-visual {
  position: relative;
  align-self: start;
}

.featured-book-cover {
  aspect-ratio: unset;
  max-width: 380px;
  border-radius: 6px;
  overflow: hidden;
  position: relative;
  box-shadow: -20px 20px 60px rgba(0,0,0,0.6), 4px 4px 0 rgba(201,168,76,0.15);
  display: inline-block;
  width: 100%;
}

.featured-book-cover img {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
}

.featured-book-bg {
  width: 100%;
  height: 100%;
  background: linear-gradient(145deg, #2D3D2A, #1A2318);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem 2rem;
  text-align: center;
}

.featured-book-bg .big-title {
  font-family: var(--font-display);
  font-size: 1.8rem;
  color: var(--parchment);
  line-height: 1.3;
  margin-bottom: 1rem;
}

.featured-book-bg .big-author {
  font-family: var(--font-title);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
}

.featured-ornament {
  position: absolute;
  bottom: -1.5rem;
  right: -1.5rem;
  width: 80px; height: 80px;
  background: var(--burgundy);
  border: 2px solid var(--gold-dim);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-title);
  font-size: 0.6rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold);
  text-align: center;
  line-height: 1.4;
}

.featured-text .section-label { margin-bottom: 1rem; }

.featured-text blockquote {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-style: italic;
  color: var(--ash);
  border-left: 3px solid var(--gold-dim);
  padding-left: 1.5rem;
  margin: 2rem 0;
  line-height: 1.7;
}

.featured-text blockquote cite {
  display: block;
  font-family: var(--font-title);
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--gold-text);
  font-style: normal;
  margin-top: 0.75rem;
}

.featured-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 2rem;
}

/* ================================================
   ABOUT SECTION
   ================================================ */
.about-section {
  background: var(--shadow);
  position: relative;
  overflow: hidden;
}

.about-section::before {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 500px; height: 500px;
  background: radial-gradient(ellipse, rgba(45,61,42,0.15) 0%, transparent 70%);
  pointer-events: none;
}

.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6rem;
  align-items: center;
}

.about-logo-wrap {
  display: flex;
  justify-content: center;
  position: relative;
}

.about-logo-wrap img {
  width: 340px;
  filter: drop-shadow(0 12px 40px rgba(0,0,0,0.6));
  animation: floatLogo 6s ease-in-out infinite;
}

.about-ring {
  position: absolute;
  inset: -20px;
  border: 1px solid rgba(201,168,76,0.08);
  border-radius: 50%;
}

.about-ring-2 {
  position: absolute;
  inset: -50px;
  border: 1px solid rgba(201,168,76,0.04);
  border-radius: 50%;
}

.about-text p {
  font-size: 1.05rem;
  color: var(--ash);
  margin-bottom: 1.25rem;
}

.about-text p strong {
  color: var(--parchment);
  font-weight: 600;
}

.about-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin: 2.5rem 0;
  padding: 2rem;
  background: rgba(201,168,76,0.04);
  border: 1px solid rgba(201,168,76,0.12);
  border-radius: 6px;
}

.stat-item { text-align: center; }

.stat-number {
  font-family: var(--font-display);
  font-size: 2.2rem;
  color: var(--gold);
  display: block;
}

.stat-label {
  font-family: var(--font-title);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ash);
  margin-top: 0.25rem;
}

/* ================================================
   NEWSLETTER
   ================================================ */
.newsletter-section {
  background: linear-gradient(135deg, var(--dark-burgundy) 0%, #1a0d14 50%, var(--dark-forest) 100%);
  border-top: 1px solid rgba(201,168,76,0.15);
  text-align: center;
}

.newsletter-form {
  display: flex;
  gap: 0;
  max-width: 480px;
  margin: 2rem auto 0;
  border: 1px solid var(--gold-dim);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}

.newsletter-form input {
  flex: 1;
  background: rgba(255,255,255,0.05);
  border: none;
  padding: 0.9rem 1.25rem;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--parchment);
  outline: none;
}

.newsletter-form input::placeholder { color: var(--ash); opacity: 0.6; }

.newsletter-form button {
  background: var(--burgundy);
  color: var(--gold-light);
  border: none;
  padding: 0.9rem 1.5rem;
  font-family: var(--font-title);
  font-size: 0.68rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  cursor: pointer;
  border-left: 1px solid var(--gold-dim);
  transition: background var(--transition);
  white-space: nowrap;
}

.newsletter-form button:hover { background: #8F2236; }

.newsletter-note {
  font-size: 0.8rem;
  color: var(--ash);
  font-style: italic;
  margin-top: 1rem;
  opacity: 0.7;
}

/* ================================================
   FOOTER
   ================================================ */
.footer {
  background: var(--deep-red);
  border-top: 1px solid rgba(201,168,76,0.2);
  padding: 4rem 0 2rem;
}

.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 3rem;
  margin-bottom: 3rem;
}

.footer-brand img {
  height: 80px;
  width: 80px;
  object-fit: contain;
  margin-bottom: 1rem;
}

.footer-brand p {
  font-size: 0.9rem;
  color: var(--ash);
  line-height: 1.7;
  max-width: 260px;
}

.footer-col h4 {
  font-family: var(--font-title);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.25rem;
}

.footer-col ul li {
  margin-bottom: 0.6rem;
}

.footer-col ul li a {
  font-size: 0.9rem;
  color: var(--ash);
  transition: color var(--transition);
}
.footer-col ul li a:hover { color: var(--gold-light); }

.footer-bottom {
  border-top: 1px solid rgba(201,168,76,0.1);
  padding-top: 1.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}

.footer-copy {
  font-size: 0.8rem;
  color: var(--ash);
  opacity: 0.6;
}

.footer-social {
  display: flex;
  gap: 0.75rem;
  align-items: center;
}

.footer-social a {
  width: 34px; height: 34px;
  border: 1px solid rgba(201,168,76,0.2);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
  overflow: hidden;
  padding: 6px;
}

.footer-social a img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
  opacity: 0.75;
  transition: opacity var(--transition);
}

.footer-social a:hover {
  border-color: var(--gold);
  background: rgba(201,168,76,0.08);
}
.footer-social a:hover img {
  opacity: 1;
}

/* ================================================
   CART SIDEBAR
   ================================================ */
.cart-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 2000;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition);
}

.cart-overlay.open {
  opacity: 1;
  pointer-events: all;
}

.cart-sidebar {
  position: fixed;
  top: 0; right: 0;
  height: 100%;
  height: 100dvh;
  width: 400px;
  max-width: 100vw;
  background: #1A0E12;
  border-left: 1px solid rgba(201,168,76,0.2);
  z-index: 2001;
  transform: translateX(100%);
  transition: transform 0.35s ease;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  -webkit-overflow-scrolling: touch;
}

.cart-sidebar.open { transform: translateX(0); }

.cart-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem;
  border-bottom: 1px solid rgba(201,168,76,0.15);
}

.cart-header h3 {
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: var(--parchment);
}

.cart-close {
  background: none;
  border: none;
  color: var(--ash);
  font-size: 1.5rem;
  cursor: pointer;
  transition: color var(--transition);
}
.cart-close:hover { color: var(--gold); }

.cart-items {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
  overscroll-behavior: contain;
  padding: 1rem 1.5rem;
}

.cart-empty {
  text-align: center;
  padding: 4rem 2rem;
  color: var(--ash);
  font-style: italic;
}

.cart-item {
  display: flex;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(201,168,76,0.08);
}

.cart-item-cover {
  width: 60px;
  aspect-ratio: 2/3;
  background: var(--forest);
  border-radius: 3px;
  flex-shrink: 0;
  overflow: hidden;
}

.cart-item-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cart-item-info { flex: 1; }

.cart-item-name {
  font-family: var(--font-display);
  font-size: 0.95rem;
  color: var(--parchment);
  margin-bottom: 0.2rem;
}

.cart-item-format {
  font-size: 0.78rem;
  color: var(--ash);
  margin-bottom: 0.5rem;
}

.cart-item-price {
  font-family: var(--font-title);
  font-size: 0.9rem;
  color: var(--gold);
}

.cart-item-remove {
  background: none;
  border: none;
  color: var(--ash);
  cursor: pointer;
  font-size: 0.8rem;
  padding: 0.25rem;
  transition: color var(--transition);
  align-self: flex-start;
}
.cart-item-remove:hover { color: #e05565; }

.cart-footer {
  padding: 1.5rem;
  border-top: 1px solid rgba(201,168,76,0.15);
}

.cart-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--parchment);
}

.cart-total span:last-child { color: var(--gold); }

.btn-checkout {
  width: 100%;
  justify-content: center;
  padding: 1rem;
}

/* ================================================
   TOAST
   ================================================ */
.toast {
  position: fixed;
  bottom: 5.5rem;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--forest);
  border: 1px solid var(--gold-dim);
  color: var(--parchment);
  padding: 0.9rem 1.5rem;
  border-radius: 4px;
  font-family: var(--font-body);
  font-size: 0.95rem;
  z-index: 3000;
  transform: translateY(100px);
  opacity: 0;
  transition: all 0.3s ease;
  max-width: 320px;
}

.toast.show {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

/* ================================================
   SHOP PAGE
   ================================================ */
.shop-hero {
  width: 100%;
  min-height: 260px;
  height: 36vh;
  display: flex;
  align-items: flex-end;
  background: linear-gradient(135deg, var(--dark-forest), var(--deep-red));
  border-bottom: 1px solid rgba(201,168,76,0.15);
  padding-bottom: 3rem;
  padding-top: 80px;
  position: relative;
  overflow: hidden;
  text-align: center;
}

.shop-filters {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin: 2.5rem 0;
  padding-bottom: 2rem;
  border-bottom: 1px solid rgba(201,168,76,0.1);
}

.filter-btn {
  font-family: var(--font-title);
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  background: transparent;
  color: var(--ash);
  border: 1px solid rgba(201,168,76,0.2);
  padding: 0.5rem 1.1rem;
  border-radius: 100px;
  cursor: pointer;
  transition: all var(--transition);
}

.filter-btn:hover, .filter-btn.active {
  background: var(--burgundy);
  color: var(--gold-light);
  border-color: var(--gold-dim);
}

select.filter-btn {
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  padding-right: 1.4rem;
  background-image: none;
}

select.filter-btn:focus {
  outline: none;
  border-color: var(--gold-dim);
}

/* ================================================
   ABOUT PAGE
   ================================================ */
.about-page-hero {
  min-height: 60vh;
  display: flex;
  align-items: center;
  background: linear-gradient(135deg, var(--deep-red) 0%, var(--dark-forest) 100%);
  padding-top: 80px;
  position: relative;
  overflow: hidden;
}

.about-page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23C9A84C' fill-opacity='0.02'%3E%3Cpath d='M0 0h40v40H0V0zm40 40h40v40H40V40z'/%3E%3C/g%3E%3C/svg%3E");
}

/* ================================================
   CONTACT / SUBMISSION PAGE
   ================================================ */
.form-section {
  background: var(--shadow);
  padding: 8rem 0;
}

.form-wrap {
  max-width: 640px;
  margin: 0 auto;
  padding: 0 2rem;
}

.form-group {
  margin-bottom: 1.5rem;
}

.form-group label {
  display: block;
  font-family: var(--font-title);
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-text);
  margin-bottom: 0.5rem;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(201,168,76,0.2);
  color: var(--parchment);
  font-family: var(--font-body);
  font-size: 1rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius);
  outline: none;
  transition: border-color var(--transition);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--gold-dim);
}

.form-group select option { background: #1A0E12; }

.form-group textarea { resize: vertical; min-height: 120px; }

/* ================================================
   ANIMATIONS
   ================================================ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

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

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes scrollPulse {
  0%, 100% { opacity: 0.5; transform: scaleY(1); }
  50%       { opacity: 1;   transform: scaleY(1.3); }
}

@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes floatLogo {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-14px); }
}

.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ================================================
   RESPONSIVE
   ================================================ */
@media (max-width: 900px) {
  .featured-inner,
  .about-grid { grid-template-columns: 1fr; gap: 3rem; }
  .about-logo-wrap { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .nav { padding: 0 1.5rem; }
  .nav-links { display: none; }
  .nav-hamburger { display: flex; }
}

@media (max-width: 600px) {
  .footer-grid { grid-template-columns: 1fr; }
  .hero-actions { flex-direction: column; align-items: center; }
  .about-stats { grid-template-columns: 1fr; }
  .nav-cart .cart-label { display: none; }
  .section { padding: 4rem 0; }
}


/* ================================================
   COPY PROTECTION
   ================================================ */
.protected-text,
.preview-content,
.book-excerpt {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* Watermark overlay on preview — subtle diagonal text */
.preview-content {
  position: relative;
}

.preview-content::after {
  content: 'PREVIEW ONLY · © ESHOM CABIN PRESS';
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-35deg);
  font-family: var(--font-title);
  font-size: 1.1rem;
  letter-spacing: 0.3em;
  color: rgba(201, 168, 76, 0.04);
  pointer-events: none;
  white-space: nowrap;
  z-index: 1;
}


/* ================================================
   GENRE SHOWCASE STRIPS (Homepage)
   ================================================ */
.genre-strip { padding:6rem 0; background:var(--shadow); border-top:1px solid rgba(201,168,76,0.07); }
.genre-strip:nth-child(even) { background:linear-gradient(to right,#0f0a0c,#111510,#0f0a0c); }
.genre-inner { max-width:1200px; margin:0 auto; padding:0 2rem; display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.genre-inner.reverse { direction:rtl; }
.genre-inner.reverse > * { direction:ltr; }
.genre-icon { font-size:3rem; margin-bottom:1.1rem; display:block; }
.genre-tag { font-family:var(--font-title); font-size:0.62rem; letter-spacing:0.25em; text-transform:uppercase; color:var(--gold); margin-bottom:0.65rem; }
.genre-headline { font-family:var(--font-display); font-size:clamp(1.5rem,3vw,2.2rem); color:var(--parchment); line-height:1.25; margin-bottom:1rem; }
.genre-body { font-size:1rem; color:var(--ash); line-height:1.8; margin-bottom:1.25rem; }
.genre-card { background:linear-gradient(145deg,rgba(201,168,76,0.06),rgba(201,168,76,0.02)); border:1px solid rgba(201,168,76,0.15); border-radius:8px; padding:2.25rem; text-align:center; }
.genre-card-icon { font-size:3.5rem; margin-bottom:.85rem; }
.genre-card-label { font-family:var(--font-title); font-size:0.62rem; letter-spacing:0.2em; text-transform:uppercase; color: var(--gold-text); }
.genre-card-title { font-family:var(--font-display); font-size:1.25rem; color:var(--parchment); margin:.4rem 0 .2rem; }
.genre-card-sub { font-size:0.88rem; color:var(--ash); font-style:italic; }
.genre-card-quote { font-family:var(--font-display); font-size:0.92rem; font-style:italic; color:var(--ash); border-top:1px solid rgba(201,168,76,0.14); padding-top:1.1rem; margin-top:1.1rem; line-height:1.7; }

/* ================================================
   OKLAHOMA SECTION (Homepage)
   ================================================ */
.oklahoma-section { padding:5rem 0; background:linear-gradient(135deg,var(--dark-forest),var(--dark-burgundy)); border-top:1px solid rgba(201,168,76,0.12); border-bottom:1px solid rgba(201,168,76,0.12); }
.oklahoma-inner { max-width:1100px; margin:0 auto; padding:0 2rem; display:grid; grid-template-columns:1fr 2fr; gap:4rem; align-items:center; }
.oklahoma-badge { text-align:center; }
.oklahoma-star { font-size:3.5rem; margin-bottom:.65rem; display:block; }
.oklahoma-state { font-family:var(--font-title); font-size:0.62rem; letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); }
.oklahoma-name { font-family:var(--font-display); font-size:1.8rem; color:var(--parchment); margin:.2rem 0; }

/* ================================================
   POLISHED CART IMPROVEMENTS
   ================================================ */
.cart-item-remove {
  background:rgba(201,168,76,0.08);
  border:1px solid rgba(201,168,76,0.15);
  color:var(--ash);
  cursor:pointer;
  font-size:0.75rem;
  width:22px; height:22px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  transition:all var(--transition);
  line-height:1;
}
.cart-item-remove:hover { background:rgba(200,80,80,0.25); border-color:rgba(200,80,80,0.5); color:#e08070; }

/* ================================================
   RESPONSIVE — GENRE & OKLAHOMA
   ================================================ */
@media (max-width:860px) {
  .genre-inner { grid-template-columns:1fr; gap:2.5rem; }
  .genre-inner.reverse { direction:ltr; }
  .oklahoma-inner { grid-template-columns:1fr; gap:2rem; }
  .oklahoma-badge { text-align:left; }
}


/* ================================================
   VIDEO HERO BACKGROUND
   ================================================ */
.hero-video-wrap {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.hero-video {
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  transform: translate(-50%, -50%);
  object-fit: cover;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(13,11,8,0.55) 0%,
    rgba(74,14,26,0.45) 40%,
    rgba(13,11,8,0.75) 100%
  );
}

/* When video is active, dim the existing hero-bg */
.hero.video-active .hero-bg {
  opacity: 0;
}
.hero.video-active .hero-texture {
  opacity: 0.3;
}

/* Ensure hero content sits above video */
.hero-content {
  position: relative;
  z-index: 4;
}

.hero-scroll {
  z-index: 1;
  pointer-events: none;
}

/* ── Featured Carousel Controls ─────────────────────── */
.feat-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(201,168,76,0.1);
}
.feat-arrow {
  background: none;
  border: 1px solid rgba(201,168,76,0.25);
  color: var(--gold-text);
  width: 38px; height: 38px;
  border-radius: 50%;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: .9rem;
  transition: all .2s ease;
}
.feat-arrow:hover { background: rgba(201,168,76,0.1); color: var(--gold); border-color: var(--gold); }
.feat-dots { display: flex; gap: .5rem; align-items: center; }
.feat-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  border: 1px solid rgba(201,168,76,0.4);
  background: transparent;
  cursor: pointer;
  padding: 0;
  transition: all .2s ease;
}
.feat-dot.active { background: var(--gold); border-color: var(--gold); width: 22px; border-radius: 4px; }
#featuredInner { transition: opacity .35s ease; }

/* ================================================
   ADMIN BANNER VIDEO (injected by site-content.js)
   ================================================ */
.ecp-banner-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  pointer-events: none;
}
/* Ensure content in banner containers sits above the video */
[data-ecp-banner] > *:not(.ecp-banner-video) {
  position: relative;
  z-index: 1;
}
