/* ================================================================

   BECOME BOOKSTORE v2 — Ultimate Premium CSS

   ================================================================ */



/* ---- RESET & TYPOGRAPHY ---- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { 
  background:var(--bg); 
  color:var(--text); 
  font-family:'Inter Tight', sans-serif; 
  overflow-x:hidden; 
  line-height:1.6; 
  transition:background 0.4s var(--ease), color 0.4s var(--ease); 
  scrollbar-width: thin;
  scrollbar-color: var(--gold) var(--bg);
}
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--gold); border-radius:3px; }

/* Prevent body scrolling when reader or any modal/drawer is open */
body:has(.reader-modal.open),
body:has(.cart-drawer.open),
body:has(.checkout-modal.open),
body:has(.admin-login-modal.open),
body:has(.admin-panel.open),
body:has(.promo-modal.open),
body:has(.confirm-modal.open),
body:has(.wish-panel.open),
body.no-scroll {
  overflow: hidden !important;
}

::selection { background:var(--gold); color:var(--bg); }

a { text-decoration:none; color:inherit; }

img { max-width:100%; display:block; }

button { font-family:inherit; cursor:pointer; }

::-webkit-scrollbar { width:6px; }

::-webkit-scrollbar-track { background:var(--bg); }

::-webkit-scrollbar-thumb { background:var(--gold); border-radius:3px; }



/* ---- TOKENS & RESPONSIVE THEMES ---- */

:root {

  /* Fonts */

  --font-serif: 'Cormorant Garamond', serif;

  --font-title: 'Cormorant Garamond', serif;

  --font-sans:  'Inter Tight', sans-serif;



  /* Light Theme (Warm Sand - Default) */

  --bg:         #FAF8F5; /* Beautiful clean warm sand paper color */
  --bg-rgb:     250, 248, 245;

  --bg2:        #F4F1EA; /* Slightly darker sand for structure */

  --bg3:        #FAF8F5; /* Cards and elements background */

  --surface:    rgba(26,27,30,0.03);  /* Soft organic container */

  --surface2:   rgba(26,27,30,0.06);

  --border:     rgba(110,125,108,0.22); /* Delicate sage green border lines */

  --border2:    rgba(26,27,30,0.07);

  --text:       #1A1B1E; /* Deep Charcoal Ink */

  --text2:      rgba(26,27,30,0.72); /* Muted secondary charcoal */

  --text3:      rgba(26,27,30,0.42); /* Subdued tertiary text */

  

  --gold:       #C85A3F; /* Elegant Muted Terracotta Red */

  --gold-rgb:   200, 90, 63; /* Terracotta RGB components */

  --gold-lt:    #D9765D;

  --gold-dk:    #A74026;

  --gold-glow:  rgba(200,90,63,0.12);



  --r-sm:       6px;

  --r-md:       12px;

  --r-lg:       18px;

  --r-xl:       24px;

  --r-full:     9999px;

  --ease:       cubic-bezier(.25, .8, .25, 1);

  --shadow-card: 0 8px 30px rgba(28,29,33,0.05);

  --shadow-gold: 0 4px 15px rgba(200,90,63,0.15);

}



/* Dark Theme overrides (Matte Charcoal) */

body.dark-theme {

  --bg:         #121316; /* Clean matte charcoal */
  --bg-rgb:     18, 19, 22;

  --bg2:        #18191D;

  --bg3:        #1B1C20;

  --surface:    rgba(255,255,255,0.04);

  --surface2:   rgba(255,255,255,0.07);

  --border:     rgba(229,193,88,0.18); /* Elegant warm ochre border */

  --border2:    rgba(255,255,255,0.08);

  --text:       #ECECEB; /* Clean paper white */

  --text2:      rgba(236,236,235,0.72);

  --text3:      rgba(236,236,235,0.42);

  

  --gold:       #E5C158; /* Butter Ochre Yellow for contrast */

  --gold-rgb:   229, 193, 88; /* Butter Ochre RGB components */

  --gold-lt:    #EED07E;

  --gold-dk:    #C9A43C;

  --gold-glow:  rgba(229,193,88,0.12);

  

  --shadow-card: 0 8px 45px rgba(0,0,0,0.4);

  --shadow-gold: 0 4px 15px rgba(229,193,88,0.22);

}



/* ---- CUSTOM CURSOR ---- */

.cursor-glow {

  width:400px; height:400px; border-radius:50%;

  background:radial-gradient(circle, rgba(var(--gold-rgb),.07), transparent 70%);

  position:fixed; top:0; left:0; pointer-events:none; z-index:9999;

  transform:translate(-50%,-50%);

  transition:transform .12s var(--ease);

}



/* ================================================================

   LOADER

   ================================================================ */

.loader {

  position:fixed; inset:0; z-index:10000;

  background:var(--bg);

  display:flex; align-items:center; justify-content:center;

  transition:opacity .6s var(--ease), visibility .6s;

}

.loader.done { opacity:0; visibility:hidden; pointer-events:none; }

.loader-inner { text-align:center; }

.loader-logo { font-size:3rem; margin-bottom:12px; animation:pulse 1.5s ease-in-out infinite; }

.loader-title {

  font-family:var(--font-title),serif; font-size:1.4rem; font-weight:700;

  letter-spacing:.2em; color:var(--gold); margin-bottom:28px;

}

.loader-bar {

  width:200px; height:3px; background:var(--surface2);

  border-radius:var(--r-full); overflow:hidden; margin:0 auto;

}

.loader-fill {

  height:100%; width:0;

  background:var(--gold);

  border-radius:var(--r-full);

  animation:loader-progress 1.8s var(--ease) forwards;

}

@keyframes loader-progress { to { width:100%; } }

@keyframes pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.15)} }



/* ================================================================

   NAVBAR

   ================================================================ */

.navbar {

  position:fixed; top:0; left:0; right:0; z-index:1000;

  transition:background .4s var(--ease), border-color .4s var(--ease),

             backdrop-filter .4s var(--ease), box-shadow .4s var(--ease);

}

.navbar.scrolled {

  background:rgba(7,9,15,.9); backdrop-filter:blur(28px);

  border-bottom:1px solid var(--border);

  box-shadow:0 4px 40px rgba(0,0,0,.5);

}

.nav-wrap {

  max-width:1320px; margin:0 auto; padding:0 28px;

  height:72px; display:flex; align-items:center; gap:32px;

  position:relative;

}

.logo {

  display:flex; align-items:center; gap:10px;

  font-family:var(--font-title),serif; font-size:1.35rem; font-weight:700;

  color:var(--gold); letter-spacing:.14em; flex-shrink:0;

  transition:text-shadow .3s;

}

.logo:hover { text-shadow:0 0 24px rgba(var(--gold-rgb),.6); }

.logo-book { font-size:1.5rem; }

.nav-menu {

  flex:1; display:flex; align-items:center; justify-content:center;

  gap:4px; list-style:none;

}

.nm-link {

  font-size:.88rem; font-weight:500; letter-spacing:.04em;

  color:var(--text2); padding:8px 16px; border-radius:var(--r-sm);

  transition:color .25s, background .25s;

  position:relative;

}

.nm-link::after {

  content:''; position:absolute; bottom:4px; left:50%;

  transform:translateX(-50%); width:0; height:2px;

  background:var(--gold); border-radius:2px;

  transition:width .3s var(--ease);

}

.nm-link:hover, .nm-link.active { color:var(--text); }

.nm-link:hover::after, .nm-link.active::after { width:55%; }



.nav-actions { display:flex; align-items:center; gap:8px; margin-left:auto; }

.na-btn {

  width:40px; height:40px; border-radius:var(--r-sm);

  background:none; border:none;

  display:flex; align-items:center; justify-content:center;

  color:var(--text2); transition:color .25s, background .25s;

  position:relative;

}

.na-btn:hover { color:var(--gold); background:var(--surface); }

.na-cart-btn {

  display:flex; align-items:center; gap:8px;

  background:rgba(var(--gold-rgb),.12); border:1px solid var(--border);

  color:var(--gold); font-size:.88rem; font-weight:700;

  padding:0 18px; height:40px; border-radius:var(--r-sm);

  letter-spacing:.06em; transition:all .25s; position:relative;

}

.na-cart-btn:hover { background:var(--gold); color:var(--bg); border-color:var(--gold); box-shadow:var(--shadow-gold); }

.na-badge {

  position:absolute; top:-7px; right:-7px;

  width:18px; height:18px; border-radius:50%;

  background:var(--gold); color:var(--bg);

  font-size:.65rem; font-weight:900;

  display:flex; align-items:center; justify-content:center;

  transition:transform .2s;

}

.wish-badge { background:#e85d75; color:#fff; }

.hamburger {

  display:none; flex-direction:column; gap:5px;

  background:none; border:none; padding:6px;

}

.hamburger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:all .3s var(--ease); }



/* Search Bar */

.search-bar {

  background:rgba(7,9,15,.97); backdrop-filter:blur(28px);

  border-bottom:1px solid var(--border);

  overflow:hidden; max-height:0;

  transition:max-height .4s var(--ease), padding .4s var(--ease);

}

.search-bar.open { max-height:140px; padding:16px 28px; }

.sb-inner {

  max-width:700px; margin:0 auto;

  display:flex; align-items:center; gap:14px;

  background:var(--surface2); border:1px solid var(--border2);

  border-radius:var(--r-md); padding:14px 20px;

  transition:border-color .25s;

}

.sb-inner:focus-within { border-color:var(--gold); }

.sb-icon { color:var(--text3); flex-shrink:0; }

.sb-input {

  flex:1; background:none; border:none; outline:none;

  color:var(--text); font-size:1rem; font-family:inherit;

}

.sb-input::placeholder { color:var(--text3); }

.sb-esc {

  font-size:.7rem; color:var(--text3);

  border:1px solid var(--border2); border-radius:4px;

  padding:2px 6px; letter-spacing:.08em; flex-shrink:0;

}

.sb-suggestions { max-width:700px; margin:12px auto 0; }

.sb-suggestion-title { font-size:.72rem; color:var(--text3); letter-spacing:.1em; text-transform:uppercase; margin-bottom:8px; }

.sb-pills { display:flex; gap:8px; flex-wrap:wrap; }

.sb-pill {

  font-size:.8rem; color:var(--gold); border:1px solid var(--border);

  padding:4px 14px; border-radius:var(--r-full); cursor:pointer;

  transition:all .2s;

}

.sb-pill:hover { background:var(--gold); color:var(--bg); }



/* ================================================================

   HERO

   ================================================================ */

.hero { position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; background:var(--bg); }

.hero-bg { 
  position: absolute; 
  inset: 0; 
  opacity: 0.18; /* Rich detailed library backdrop presence */
  mix-blend-mode: normal; 
  pointer-events: none; 
  transition: opacity 0.3s;
}

body.dark-theme .hero-bg { 
  opacity: 0.11; 
  mix-blend-mode: normal; 
}

.hero-bg-img { 
  width: 100%; 
  height: 100%; 
  object-fit: cover; 
  filter: grayscale(0.15) sepia(0.25) contrast(1.02) brightness(0.98); /* Sepia warm sand tones */
  transition: all 0.3s;
}

body.dark-theme .hero-bg-img {
  filter: grayscale(0.3) sepia(0.15) brightness(0.55) contrast(1.05); /* Charcoal dark theme adaptation */
}

.hero-gradient { 
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, var(--bg) 28%, rgba(250, 248, 245, 0.6) 55%, rgba(250, 248, 245, 0.15) 100%);
  z-index: 1;
  pointer-events: none;
}

body.dark-theme .hero-gradient {
  background: linear-gradient(to right, var(--bg) 28%, rgba(26, 27, 30, 0.6) 55%, rgba(26, 27, 30, 0.15) 100%);
}

.hero-vignette { 
  position: absolute;
  inset: 0;
  background: radial-gradient(circle, transparent 40%, rgba(250, 248, 245, 0.6) 80%, var(--bg) 100%);
  z-index: 1;
  pointer-events: none;
}

body.dark-theme .hero-vignette {
  background: radial-gradient(circle, transparent 40%, rgba(26, 27, 30, 0.6) 80%, var(--bg) 100%);
}

.hero-canvas { 
  position: absolute; 
  inset: 0; 
  pointer-events: none; 
  z-index: 1; 
  display: block; 
  opacity: 0.8;
}



.hero-content {

  position:relative; z-index:2;

  width:100%; max-width:1320px; margin:0 auto;

  padding:120px 28px 80px;

  display:grid; grid-template-columns:1fr auto;

  align-items:center; gap:60px;

}

.hc-tag {

  display:inline-flex; align-items:center; gap:8px;

  background:var(--surface); border:1px solid var(--border);

  color:var(--gold); font-size:.78rem; font-weight:700;

  letter-spacing:.14em; text-transform:uppercase;

  padding:7px 18px; border-radius:var(--r-full); width:fit-content;

  margin-bottom:24px;

}

.hc-tag-dot {

  width:6px; height:6px; border-radius:50%;

  background:var(--gold);

}



.hc-title {

  font-family:var(--font-title);

  font-size:clamp(2.8rem,5.5vw,5rem);

  font-weight:700; line-height:1.08; letter-spacing:-.01em;

  color:var(--text);

  margin-bottom:24px;

}

.hc-title-em { font-style:italic; font-family:var(--font-serif); font-weight:300; color:var(--text2); }

.hc-title-gold {

  color:var(--gold);

}

.hc-desc {

  font-size:1.08rem; color:var(--text2); line-height:1.75;

  font-weight:300; margin-bottom:36px; max-width:520px;

}

.d-none-mob { }



.hc-btns { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:44px; }



/* Buttons */

.btn-gold {

  display:inline-flex; align-items:center; gap:10px;

  background:var(--gold);

  color:var(--bg); font-weight:800; font-size:.9rem;

  padding:14px 28px; border-radius:var(--r-md); border:none;

  letter-spacing:.04em; transition:all 0.3s var(--ease);

}

.btn-gold:hover { background:var(--gold-dk); box-shadow:var(--shadow-gold); transform:translateY(-2px); }

.btn-ghost {

  display:inline-flex; align-items:center; gap:10px;

  background:var(--surface); border:1px solid var(--border2);

  color:var(--text); font-weight:600; font-size:.9rem;

  padding:14px 26px; border-radius:var(--r-md);

  letter-spacing:.04em; transition:all .3s;

}

.btn-ghost:hover { border-color:var(--gold); color:var(--gold); background:rgba(200,90,63,0.06); }

.btn-gold-outline {

  display:inline-flex; align-items:center; gap:10px;

  background:transparent; border:1.5px solid var(--gold);

  color:var(--gold); font-weight:700; font-size:.9rem;

  padding:14px 36px; border-radius:var(--r-md);

  letter-spacing:.06em; transition:all .3s;

}

.btn-gold-outline:hover { background:var(--gold); color:var(--bg); box-shadow:var(--shadow-gold); }

.btn-gold-sm {

  display:inline-flex; align-items:center; gap:8px;

  background:var(--gold);

  color:var(--bg); font-weight:800; font-size:.82rem;

  padding:10px 20px; border-radius:var(--r-sm); border:none;

  letter-spacing:.04em; transition:all .3s var(--ease); white-space:nowrap;

}

.btn-gold-sm:hover { background:var(--gold-dk); box-shadow:var(--shadow-gold); transform:translateY(-1px); }



.hc-stats { display:flex; align-items:center; gap:28px; }

.hc-stat { display:flex; flex-direction:column; gap:2px; }

.hc-stat b { font-family:var(--font-title),serif; font-size:1.6rem; font-weight:700; color:var(--gold); line-height:1; }

.hc-stat span { font-size:.72rem; color:var(--text3); letter-spacing:.1em; text-transform:uppercase; }

.hc-stat-sep { width:1px; height:40px; background:var(--border); }



/* Book Showcase */

.hc-right { position:relative; }

.book-showcase {
  position:relative; width:420px; /* Expanded from 320px for a massive, premium presence */
  animation:showcase-levitate 7s ease-in-out infinite;
}

@keyframes showcase-levitate {
  0%,100%{transform:translateY(0) rotateY(-6deg)} 50%{transform:translateY(-22px) rotateY(-8deg)}
}

.bs-glow {
  position:absolute; inset:-60px;
  background:radial-gradient(ellipse,rgba(var(--gold-rgb),.25),transparent 70%);
  animation:glow-pulse 4s ease-in-out infinite; pointer-events:none;
}

@keyframes glow-pulse { 0%,100%{opacity:.5;transform:scale(1)} 50%{opacity:1;transform:scale(1.08)} }

.bs-rings { position:absolute; inset:0; pointer-events:none; }

.bs-ring {
  position:absolute; border-radius:50%;
  border:1px solid rgba(var(--gold-rgb),.15);
  animation:ring-spin linear infinite;
}

.r1 { width:480px; height:480px; top:50%; left:50%; transform:translate(-50%,-50%); animation-duration:20s; }

.r2 { width:380px; height:380px; top:50%; left:50%; transform:translate(-50%,-50%); animation-duration:15s; border-color:rgba(var(--gold-rgb),.1); }

.r3 { width:280px; height:280px; top:50%; left:50%; transform:translate(-50%,-50%); animation-duration:10s; border-color:rgba(var(--gold-rgb),.08); }

@keyframes ring-spin { to { transform:translate(-50%,-50%) rotate(360deg); } }

.bs-cover {

  position:relative; border-radius:var(--r-sm);

  box-shadow:-16px 24px 60px rgba(0,0,0,.7), 6px 0 0 rgba(var(--gold-rgb),.4);

  overflow:hidden;

}

.bs-cover-img { width:100%; display:block; }

.bs-cover-shine {

  position:absolute; inset:0;

  background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 50%,transparent 100%);

  pointer-events:none;

}

.bs-badge {

  position:absolute; bottom:20px; right:-20px;

  background:rgba(7,9,15,.9); backdrop-filter:blur(16px);

  border:1px solid var(--border); border-radius:var(--r-md);

  padding:12px 16px; display:flex; align-items:center; gap:10px;

  box-shadow:0 8px 24px rgba(0,0,0,.5);

}

.bs-badge-icon { font-size:1.4rem; }

.bs-badge-top { font-size:.78rem; font-weight:800; color:var(--gold); letter-spacing:.06em; }

.bs-badge-sub { font-size:.68rem; color:var(--text3); margin-top:2px; }

.bs-label {

  text-align:center; margin-top:16px;

  font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;

  color:var(--gold); font-weight:700;

}



/* Scroll hint */

.hero-scroll {

  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);

  z-index:2; display:flex; flex-direction:column; align-items:center; gap:10px;

  animation:fadeIn 1.5s 1.5s both;

}

.hero-scroll span { font-size:.7rem; color:var(--text3); letter-spacing:.14em; text-transform:uppercase; }

.hs-wheel {

  width:22px; height:32px; border:2px solid rgba(var(--gold-rgb),.35);

  border-radius:11px; position:relative;

}

.hs-wheel::after {

  content:''; position:absolute;

  width:4px; height:8px; background:var(--gold); border-radius:2px;

  top:5px; left:50%; transform:translateX(-50%);

  animation:wheel-scroll 2.5s ease-in-out infinite;

}

@keyframes wheel-scroll { 0%,100%{transform:translateX(-50%) translateY(0);opacity:1} 50%{transform:translateX(-50%) translateY(8px);opacity:.3} }



/* ================================================================

   TRUST BAR

   ================================================================ */

.trust-bar {

  background:var(--bg2); border-top:1px solid var(--border); border-bottom:1px solid var(--border);

  padding:28px 28px;

}

.tb-inner {

  max-width:1100px; margin:0 auto;

  display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;

}

.tb-item {

  display:flex; align-items:center; gap:14px;

  padding:10px 20px; flex:1; min-width:200px;

  cursor:pointer;

  border-radius:var(--r-md);

  transition:all 0.3s var(--ease);

}

.tb-item:hover {

  background:var(--surface);

  transform:translateY(-3px);

  box-shadow:0 6px 16px rgba(var(--gold-rgb), 0.06);

}

.tb-item:hover .tb-icon {

  color:var(--gold);

  transform:scale(1.1);

  opacity:1;

}

.tb-icon { font-size:1.6rem; flex-shrink:0; opacity:0.85; transition:all 0.3s var(--ease); }

.tb-item div { display:flex; flex-direction:column; gap:2px; }

.tb-item b { font-size:.9rem; font-weight:700; color:var(--text); font-family:var(--font-sans); }

.tb-item span { font-size:.78rem; color:var(--text2); }

.tb-sep { width:1px; height:32px; background:var(--border); flex-shrink:0; }



/* ---- TICKER (Removed to make the site modern and clean) ---- */

.ticker { display: none; }



/* ================================================================

   FILTER / SEARCH BAR

   ================================================================ */

.filter-section { padding:40px 0 20px; background:var(--bg2); border-bottom:1px solid var(--border); }

.container { max-width:1320px; margin:0 auto; padding:0 28px; }

.filter-bar {
  display: flex;
  gap: 0;
  flex-wrap: nowrap;
  align-items: stretch;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 100px;
  padding: 6px;
  box-shadow: var(--shadow-card), 0 12px 36px rgba(0,0,0,0.03);
}

.fb-select-wrap {
  position: relative;
  flex: 1;
  min-width: 160px;
  display: flex;
  align-items: center;
  padding: 0 24px;
  border-radius: 100px;
  transition: background 0.3s var(--ease);
}

.fb-select-wrap:hover {
  background: rgba(var(--gold-rgb), 0.04);
}

.fb-select-wrap:not(:first-child)::before {
  content: '';
  position: absolute;
  left: 0;
  top: 25%;
  height: 50%;
  width: 1px;
  background: var(--border);
  opacity: 0.7;
}

.fb-select {
  width: 100%;
  background: none;
  border: none;
  outline: none;
  color: var(--text);
  font-size: .9rem;
  font-family: inherit;
  padding: 8px 32px 8px 0;
  cursor: pointer;
  appearance: none;
}

.fb-select option {
  background: var(--bg2);
  color: var(--text);
}

.fb-chevron {
  position: absolute;
  right: 24px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--text3);
  transition: transform 0.3s var(--ease), color 0.3s;
}

.fb-find {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--gold);
  color: var(--bg);
  font-weight: 800;
  font-size: .95rem;
  padding: 0 36px;
  border-radius: 100px;
  border: none;
  letter-spacing: .04em;
  transition: all 0.3s var(--ease);
  white-space: nowrap;
}

.fb-find:hover {
  background: var(--gold-dk);
  box-shadow: var(--shadow-gold);
  transform: scale(1.02);
}



/* ================================================================

   SECTIONS BASE

   ================================================================ */

.section { padding:100px 0; }

.sec-head { text-align:center; margin-bottom:60px; }

.sec-tag {

  display:inline-block;

  font-size:.73rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase;

  color:var(--gold); background:rgba(var(--gold-rgb),.1); border:1px solid rgba(var(--gold-rgb),.2);

  padding:6px 16px; border-radius:var(--r-full); margin-bottom:16px;

}

.sec-title {

  font-family:var(--font-title),serif;

  font-size:clamp(1.9rem,3vw,2.8rem);

  font-weight:700; letter-spacing:.02em; line-height:1.15; margin-bottom:12px;

}

.sec-sub { font-size:.96rem; color:var(--text2); max-width:440px; margin:0 auto; }

.gold { color:var(--gold); }

.sec-more { display:flex; justify-content:center; margin-top:52px; }



/* ================================================================

   BOOKS GRID

   ================================================================ */

.books-grid {

  display:grid;

  grid-template-columns:repeat(3, 1fr);

  gap:28px;

}



.bk-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: transform .4s cubic-bezier(0.2, 0.8, 0.2, 1), border-color .35s, box-shadow .4s;
  position: relative;
  display: flex;
  flex-direction: column;
}

.bk-card:hover {
  transform: translateY(-10px);
  border-color: rgba(var(--gold-rgb), .45);
  box-shadow: 0 30px 70px rgba(0,0,0,.25), 0 0 0 1px rgba(var(--gold-rgb), .2);
}

.bk-featured {
  border-color: rgba(var(--gold-rgb), .35);
  background: linear-gradient(180deg, rgba(var(--gold-rgb), .05) 0%, rgba(var(--gold-rgb), .01) 100%);
}

.bk-img-wrap {
  position: relative;
  aspect-ratio: 3/4;
  overflow: hidden;
  margin: 14px 14px 0;
  border-radius: calc(var(--r-lg) - 4px);
  background: var(--bg2);
  box-shadow: inset 0 0 30px rgba(0,0,0,.08);
}

/* Spine Shadow Overlay to make covers 3D */
.bk-img-wrap::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 12px;
  background: linear-gradient(to right, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.1) 25%, rgba(0,0,0,0.03) 60%, rgba(0,0,0,0) 100%);
  z-index: 1;
  pointer-events: none;
}

.bk-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.bk-card:hover .bk-img {
  transform: scale(1.04);
}

.bk-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .6s cubic-bezier(0.2, 0.8, 0.2, 1);
  position: relative;
}

.bk-card:hover .bk-placeholder {
  transform: scale(1.04);
}

.bk-pl-shine {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.03) 50%, rgba(255,255,255,0) 100%);
  pointer-events: none;
}

.bk-placeholder::before {
  content: '';
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(var(--gold-rgb), 0.2);
  border-radius: var(--r-sm);
  pointer-events: none;
}

.bk-pl-content {
  text-align: center;
  padding: 20px;
  z-index: 1;
}

.bk-pl-icon {
  font-size: 2.8rem;
  margin-bottom: 12px;
  color: var(--gold);
}

.bk-pl-icon svg {
  width: 48px;
  height: 48px;
  color: var(--gold);
  stroke: var(--gold);
}

.bk-pl-name {
  font-family: var(--font-title), serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 6px;
  letter-spacing: .02em;
  text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.bk-pl-author {
  font-size: .78rem;
  color: rgba(255,255,255,.6);
  text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}

.bk-badge-new {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--gold);
  color: var(--bg);
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--r-full);
  z-index: 2;
  box-shadow: 0 4px 10px rgba(0,0,0,0.25);
}

.bk-badge-hot {
  position: absolute;
  top: 12px;
  right: 52px;
  background: #e85d75;
  color: #fff;
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--r-full);
  z-index: 2;
  box-shadow: 0 4px 10px rgba(0,0,0,0.25);
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

.bk-actions {
  position: absolute;
  top: 12px;
  right: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  z-index: 3;
}

.bk-action-btn {
  width: 34px;
  height: 34px;
  border-radius: var(--r-sm);
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .3s cubic-bezier(0.2, 0.8, 0.2, 1);
  transform: translateX(48px);
  opacity: 0;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.bk-card:hover .bk-action-btn {
  transform: translateX(0);
  opacity: 1;
}

.bk-wish:hover {
  color: #ffffff !important;
  border-color: #e85d75 !important;
  background: #e85d75 !important;
}

.bk-wish.wishlisted {
  color: #ffffff !important;
  fill: #ffffff !important;
  border-color: #e85d75 !important;
  background: #e85d75 !important;
}

.bk-preview:hover {
  color: #ffffff !important;
  border-color: var(--gold) !important;
  background: var(--gold) !important;
}

/* Premium full-cover glassmorphic hover panel */
.bk-hover-panel {
  position: absolute;
  inset: 0;
  background: rgba(18, 19, 22, 0.82);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 24px 18px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 12px;
  opacity: 0;
  transform: scale(0.96);
  transition: all 0.35s cubic-bezier(0.2, 0.8, 0.2, 1);
  z-index: 2;
  pointer-events: none;
}

.bk-card:hover .bk-hover-panel,
.bk-card.active-touch .bk-hover-panel {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}

.bk-desc-short {
  font-size: .8rem;
  color: rgba(255,255,255,0.85);
  line-height: 1.5;
  margin-bottom: 8px;
  font-weight: 400;
}

.bk-add-btn {
  width: 100%;
  background: var(--gold);
  color: var(--bg);
  font-weight: 800;
  font-size: .84rem;
  padding: 10px;
  border-radius: var(--r-sm);
  border: none;
  letter-spacing: .04em;
  transition: all .25s var(--ease);
  cursor: pointer;
}

.bk-add-btn:hover {
  background: var(--gold-dk);
  box-shadow: var(--shadow-gold);
}

.bk-hover-panel .btn-gold-sm,
.bk-hover-panel .btn-ghost-sm {
  width: 100%;
  box-sizing: border-box;
  text-align: center;
  padding: 8px 12px;
  font-size: 0.8rem;
  border-radius: var(--r-sm);
}

.bk-hover-panel .btn-ghost-sm {
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fff;
  background: transparent;
  transition: all 0.25s;
}

.bk-hover-panel .btn-ghost-sm:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: #fff;
}

.bk-info {
  padding: 18px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.bk-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.bk-genre {
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gold);
}

.bk-rating-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  background: rgba(var(--gold-rgb), .08);
  border: 1px solid rgba(var(--gold-rgb), .2);
  color: var(--gold);
  padding: 3px 8px;
  border-radius: var(--r-full);
  font-size: .72rem;
  font-weight: 800;
  line-height: 1;
}

.bk-rating-star {
  font-size: .75rem;
  margin-top: -1px;
}

.bk-title {
  font-family: var(--font-title), serif;
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: .02em;
  margin-bottom: 4px;
  color: var(--text);
}

.bk-author {
  font-size: .82rem;
  color: var(--text2);
  margin-bottom: 14px;
}

.bk-author span {
  color: var(--gold-lt);
  font-weight: 500;
}

/* Premium Specification Grid (similar to Real Estate / Recipe chips) */
.bk-specs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-bottom: 16px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 10px 0;
  margin-top: auto;
}

.bk-spec-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  text-align: center;
}

.bk-spec-item svg {
  color: var(--gold);
  opacity: 0.85;
}

.bk-spec-item span {
  font-size: .64rem;
  color: var(--text3);
  font-weight: 500;
  white-space: nowrap;
}

.bk-price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
}

.bk-price {
  font-family: var(--font-title), serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--gold);
}

.bk-price-old {
  font-size: .85rem;
  color: var(--text3);
  text-decoration: line-through;
  margin-left: 6px;
}

.bk-discount {
  font-size: .64rem;
  font-weight: 800;
  background: rgba(var(--gold-rgb), .12);
  color: var(--gold);
  padding: 2px 6px;
  border-radius: var(--r-full);
  margin-left: 6px;
}

.bk-rating-count {
  font-size: .72rem;
  color: var(--text3);
}



/* ================================================================

   CATEGORIES

   ================================================================ */

.cats-section { background:var(--bg2); }

.cats-grid {

  display:grid;

  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));

  gap:18px;

}

.cat-card {

  background:var(--surface); border:1px solid var(--border);

  border-radius:var(--r-lg); padding:32px 20px 24px;

  text-align:center; cursor:pointer;

  position:relative; overflow:hidden;

  transition:all .35s var(--ease);

  display:flex; flex-direction:column; align-items:center;

}

.cat-card::before {

  content:''; position:absolute; inset:0;

  background:linear-gradient(135deg,rgba(var(--gold-rgb),.06),transparent);

  opacity:0; transition:opacity .35s;

}

.cat-card:hover { transform:translateY(-6px); border-color:rgba(var(--gold-rgb),.45); box-shadow:0 16px 40px rgba(0,0,0,.4), var(--shadow-gold); }

.cat-card:hover::before { opacity:1; }

.cat-icon-wrap {

  width:64px; height:64px; border-radius:50%;

  background:rgba(var(--gold-rgb),.1); border:1px solid rgba(var(--gold-rgb),.2);

  display:flex; align-items:center; justify-content:center;

  margin-bottom:14px; transition:transform .35s var(--ease);

  font-size:1.8rem;

}

.cat-card:hover .cat-icon-wrap { transform:scale(1.1) rotate(-5deg); }

.cat-card h3 { font-family:var(--font-title),serif; font-size:.85rem; font-weight:700; letter-spacing:.04em; margin-bottom:6px; }

.cat-card p { font-size:.72rem; color:var(--gold); font-weight:700; margin-bottom:12px; }

.cat-arrow {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--surface2);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text2);
  transition: all 0.35s var(--ease);
  margin-top: auto;
}

.cat-card:hover .cat-arrow {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--bg);
  transform: translateX(6px);
  box-shadow: var(--shadow-gold);
}



/* ================================================================

   BESTSELLERS

   ================================================================ */

.bs-section { }

.bs-list { display:flex; flex-direction:column; gap:18px; }

.bs-row {

  display:grid; grid-template-columns:56px 72px 1fr auto;

  align-items:center; gap:24px;

  background:var(--surface); border:1px solid var(--border);

  border-radius:var(--r-lg); padding:22px 28px;

  transition:all .3s var(--ease); cursor:pointer; position:relative;

}

.bs-row::before {

  content:''; position:absolute; left:0; top:0; bottom:0; width:3px;

  background:linear-gradient(var(--gold-dk),var(--gold));

  border-radius:3px 0 0 3px; opacity:0; transition:opacity .3s;

}

.bs-row:hover { border-color:rgba(var(--gold-rgb),.35); background:rgba(var(--gold-rgb),.04); transform:translateX(4px); }

.bs-row:hover::before { opacity:1; }

.bs-num {

  font-family:var(--font-title),serif; font-size:2rem; font-weight:900;

  color:rgba(var(--gold-rgb),.2); line-height:1; text-align:center;

}

.bs-thumb { width:64px; height:90px; border-radius:var(--r-sm); overflow:hidden; flex-shrink:0; box-shadow:0 4px 16px rgba(0,0,0,.5); }

.bs-thumb img { width:100%; height:100%; object-fit:cover; }

.bs-thumb-ph {

  display:flex; align-items:center; justify-content:center;

  font-size:2rem; border-radius:var(--r-sm); height:90px;

}

.bs-body { min-width:0; }

.bs-top-row { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:6px; }

.bs-title { font-family:var(--font-title),serif; font-size:1rem; font-weight:700; letter-spacing:.03em; }

.bs-author-name { font-size:.82rem; color:var(--gold-lt); font-weight:600; margin-bottom:8px; }

.bs-blurb { font-size:.82rem; color:var(--text2); line-height:1.5; margin-bottom:10px; }

.bs-rating-badge {

  background:rgba(var(--gold-rgb),.12); border:1px solid var(--border);

  color:var(--gold); font-size:.78rem; font-weight:800;

  padding:4px 12px; border-radius:var(--r-full); white-space:nowrap;

}

.bs-tags-row { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }

.bs-tag {

  font-size:.68rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;

  color:var(--text2); background:var(--surface2); border:1px solid var(--border2);

  padding:3px 10px; border-radius:var(--r-full);

}

.new-tag { color:var(--gold); border-color:rgba(var(--gold-rgb),.3); background:rgba(var(--gold-rgb),.08); }

.bs-progress { display:flex; align-items:center; gap:10px; }

.bs-progress-label { font-size:.68rem; color:var(--text3); white-space:nowrap; }

.bs-progress-bar { flex:1; height:4px; background:var(--surface2); border-radius:2px; overflow:hidden; }

.bs-progress-fill { height:100%; background:linear-gradient(90deg,var(--gold-dk),var(--gold)); border-radius:2px; transition:width 1.2s var(--ease); }

.bs-progress-pct { font-size:.72rem; font-weight:700; color:var(--gold); white-space:nowrap; }

.bs-cta { display:flex; flex-direction:column; align-items:flex-end; gap:10px; flex-shrink:0; }

.bs-price { font-family:var(--font-title),serif; font-size:1.2rem; font-weight:700; color:var(--gold); }



/* ================================================================

   AUTHOR

   ================================================================ */

.author-section { background:var(--bg2); }

.author-wrap {

  max-width:800px; margin:0 auto;

  display:flex; flex-direction:column; align-items:center;

  text-align:center;

}

.author-info-col {

  display:flex; flex-direction:column; align-items:center;

  text-align:center;

  width:100%;

}

.author-socials { display:flex; gap:12px; justify-content:center; margin-bottom:28px; }

.as-btn {

  width:42px; height:42px; border-radius:var(--r-sm);

  background:var(--surface); border:1px solid var(--border);

  display:flex; align-items:center; justify-content:center;

  font-size:.9rem; color:var(--text2); transition:all .25s;

}

.as-btn:hover { background:rgba(var(--gold-rgb),.15); border-color:var(--gold); color:var(--gold); }

.author-name { font-family:var(--font-title),serif; font-size:3rem; font-weight:900; letter-spacing:.02em; margin:12px 0 4px; }

.author-title { font-size:.88rem; color:var(--text3); letter-spacing:.08em; margin-bottom:24px; }

.author-bio { font-size:.96rem; color:var(--text2); line-height:1.8; margin-bottom:16px; max-width:720px; }

.author-bio em { color:var(--gold-lt); font-style:normal; font-weight:600; }

.author-stats { display:flex; gap:48px; margin:28px 0 36px; justify-content:center; }

.as-stat { display:flex; flex-direction:column; gap:4px; }

.as-stat b { font-family:var(--font-title),serif; font-size:1.8rem; font-weight:700; color:var(--gold); }

.as-stat span { font-size:.72rem; color:var(--text3); letter-spacing:.1em; text-transform:uppercase; }



/* ================================================================

   QUOTE

   ================================================================ */

.quote-section {

  position:relative; padding:120px 0;

  background:linear-gradient(135deg,var(--bg) 0%,var(--bg3) 50%,var(--bg) 100%);

  overflow:hidden; text-align:center;

}

.quote-canvas { position:absolute; inset:0; pointer-events:none; }

.quote-inner { position:relative; z-index:1; max-width:760px; margin:0 auto; padding:0 28px; }

.qi-mark {

  font-family:'Cormorant Garamond',serif; font-size:9rem; line-height:.6;

  color:var(--gold); opacity:.25; display:block; margin-bottom:24px;

}

.qi-text {

  font-family:'Cormorant Garamond',serif;

  font-size:clamp(1.6rem,3.5vw,2.6rem);

  font-weight:400; font-style:italic;

  color:var(--text); line-height:1.55; margin-bottom:28px;

}

.qi-cite {

  display:block; font-family:'Inter',sans-serif;

  font-size:.82rem; letter-spacing:.14em; text-transform:uppercase;

  color:var(--gold); font-style:normal; font-weight:700;

}



/* ================================================================

   REVIEWS

   ================================================================ */

.reviews-section { background:var(--bg2); }

.reviews-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:24px; }

.rv-card {

  background:var(--surface); border:1px solid var(--border);

  border-radius:var(--r-lg); padding:32px 28px;

  position:relative; transition:all .35s var(--ease);

}

.rv-card:hover { transform:translateY(-4px); border-color:rgba(var(--gold-rgb),.3); box-shadow:var(--shadow-card); }

.rv-featured { border-color:rgba(var(--gold-rgb),.35); background:rgba(var(--gold-rgb),.04); }

.rv-stars { color:var(--gold); font-size:1rem; letter-spacing:3px; margin-bottom:16px; }

.rv-text {

  font-family:'Cormorant Garamond',serif; font-size:1.05rem;

  color:var(--text2); line-height:1.65; margin-bottom:24px; font-style:italic;

}

.rv-author { display:flex; align-items:center; gap:14px; }

.rv-avatar {

  width:44px; height:44px; border-radius:50%;

  display:flex; align-items:center; justify-content:center;

  font-size:1.1rem; font-weight:800; color:#fff; flex-shrink:0;

}

.rv-author b { display:block; font-size:.92rem; color:var(--text); }

.rv-author span { font-size:.78rem; color:var(--text3); }

.rv-badge {

  position:absolute; top:20px; right:20px;

  background:linear-gradient(135deg,var(--gold-dk),var(--gold));

  color:var(--bg); font-size:.65rem; font-weight:900;

  letter-spacing:.1em; text-transform:uppercase;

  padding:4px 12px; border-radius:var(--r-full);

}



/* ================================================================

   NEWSLETTER

   ================================================================ */

.newsletter-section { padding:80px 0; }

.nl-card {

  display:grid; grid-template-columns:1fr 1fr; gap:72px;

  background:linear-gradient(135deg,rgba(var(--gold-rgb),.08),rgba(var(--gold-rgb),.03));

  border:1px solid rgba(var(--gold-rgb),.22);

  border-radius:var(--r-xl); padding:64px;

  position:relative; overflow:hidden;

}

.nl-card::before {

  content:''; position:absolute; top:-80px; right:-80px;

  width:400px; height:400px; border-radius:50%;

  background:radial-gradient(circle,rgba(var(--gold-rgb),.1),transparent 70%);

  pointer-events:none;

}

.nl-title {

  font-family:var(--font-title),serif; font-size:2rem; font-weight:700;

  line-height:1.2; margin:12px 0 16px;

}

.nl-sub { font-size:.96rem; color:var(--text2); line-height:1.7; margin-bottom:24px; }

.nl-perks { list-style:none; display:flex; flex-direction:column; gap:8px; }

.nl-perks li { font-size:.88rem; color:var(--gold-lt); font-weight:600; }

.nl-form { display:flex; flex-direction:column; gap:16px; }

.nl-field { display:flex; flex-direction:column; gap:6px; }

.nl-label { font-size:.78rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text3); }

.nl-input {

  background:rgba(255,255,255,.05); border:1px solid var(--border2);

  border-radius:var(--r-md); padding:13px 18px;

  color:var(--text); font-size:.96rem; font-family:inherit; outline:none;

  transition:border-color .25s, box-shadow .25s;

}

.nl-input:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(var(--gold-rgb),.12); }

.nl-input::placeholder { color:var(--text3); }

.nl-submit { width:100%; justify-content:center; padding:15px; }

.nl-disclaimer { font-size:.75rem; color:var(--text3); margin-top:12px; }



/* ================================================================

   FOOTER

   ================================================================ */

.footer { background:rgba(0,0,0,.5); border-top:1px solid var(--border); }

.footer-top { padding:72px 0 56px; }

.ft-grid { display:grid; grid-template-columns:2.2fr 1fr 1fr 1.4fr; gap:48px; }

.ft-logo {

  font-family:var(--font-title),serif; font-size:1.45rem; font-weight:700;

  color:var(--gold); letter-spacing:.12em; margin-bottom:16px;

}

.ft-tagline { font-size:.88rem; color:var(--text3); line-height:1.7; margin-bottom:28px; }

.ft-socials { display:flex; gap:10px; }

.ft-social {

  width:40px; height:40px; border-radius:var(--r-sm);

  background:var(--surface); border:1px solid var(--border);

  display:flex; align-items:center; justify-content:center;

  color:var(--text3); transition:all .25s;

}

.ft-social:hover { background:rgba(var(--gold-rgb),.15); border-color:var(--gold); color:var(--gold); }

.ft-col-title {

  font-family:var(--font-title),serif; font-size:.78rem; font-weight:700;

  letter-spacing:.14em; text-transform:uppercase; color:var(--gold);

  margin-bottom:22px;

}

.ft-col ul { list-style:none; display:flex; flex-direction:column; gap:11px; }

.ft-col ul li a, .ft-col ul li { font-size:.86rem; color:var(--text3); transition:color .25s; }

.ft-col ul li a:hover { color:var(--gold); }

.ft-contact span { margin-right:8px; }

.footer-bottom { border-top:1px solid var(--border); padding:24px 0; }

.fb-inner {

  display:flex; align-items:center; justify-content:space-between;

  flex-wrap:wrap; gap:16px;

}

.fb-inner p { font-size:.8rem; color:var(--text3); }

.fb-links { display:flex; gap:24px; }

.fb-links a { font-size:.8rem; color:var(--text3); transition:color .25s; }

.fb-links a:hover { color:var(--gold); }



/* ================================================================

   CART DRAWER

   ================================================================ */

.drawer-backdrop {

  position:fixed; inset:0; z-index:1100;

  background:rgba(0,0,0,.65); backdrop-filter:blur(6px);

  opacity:0; pointer-events:none; transition:opacity .4s var(--ease);

}

.drawer-backdrop.active { opacity:1; pointer-events:all; }

.cart-drawer {

  position:fixed; right:0; top:0; bottom:0; z-index:1200;

  width:min(420px,100vw); background:var(--bg2);

  border-left:1px solid var(--border);

  display:flex; flex-direction:column;

  transform:translateX(100%); transition:transform .45s var(--ease);

}

.cart-drawer.open { transform:translateX(0); }

.cd-head {

  display:flex; align-items:flex-start; justify-content:space-between;

  padding:28px; border-bottom:1px solid var(--border);

}

.cd-title { font-family:var(--font-title),serif; font-size:1.1rem; font-weight:700; color:var(--gold); letter-spacing:.08em; }

.cd-subtitle { font-size:.8rem; color:var(--text3); margin-top:4px; }

.cd-close {

  width:36px; height:36px; border-radius:var(--r-sm);

  background:var(--surface); border:1px solid var(--border2);

  color:var(--text3); display:flex; align-items:center; justify-content:center;

  transition:all .25s;

}

.cd-close:hover { color:var(--gold); border-color:var(--border); }

.cd-body { flex:1; overflow-y:auto; padding:20px 28px; }

.cd-empty {

  display:flex; flex-direction:column; align-items:center; justify-content:center;

  gap:16px; height:100%; text-align:center; padding:40px 0;

}

.cde-icon { font-size:3.5rem; }

.cd-empty h4 { font-family:var(--font-title),serif; font-size:1rem; font-weight:700; color:var(--text); }

.cd-empty p { font-size:.86rem; color:var(--text3); }

.cd-item {

  display:flex; gap:16px; align-items:flex-start;

  padding:16px 0; border-bottom:1px solid var(--border2);

  animation:slide-in .3s var(--ease) both;

}

@keyframes slide-in { from{opacity:0;transform:translateX(16px)} to{opacity:1;transform:translateX(0)} }

.cd-item:last-child { border-bottom:none; }

.cdi-thumb {

  width:54px; height:76px; border-radius:var(--r-sm);

  background:var(--surface2); border:1px solid var(--border2);

  display:flex; align-items:center; justify-content:center;

  font-size:1.6rem; flex-shrink:0; overflow:hidden;

}

.cdi-info { flex:1; min-width:0; }

.cdi-title { font-family:var(--font-title),serif; font-size:.88rem; font-weight:700; margin-bottom:6px; }

.cdi-qty-row { display:flex; align-items:center; gap:10px; }

.cdi-qty-btn {

  width:26px; height:26px; border-radius:6px;

  background:var(--surface2); border:1px solid var(--border2);

  color:var(--text); font-size:1rem; line-height:1;

  display:flex; align-items:center; justify-content:center;

  transition:all .2s;

}

.cdi-qty-btn:hover { border-color:var(--gold); color:var(--gold); }

.cdi-qty { font-size:.88rem; font-weight:700; min-width:20px; text-align:center; }

.cdi-price { font-size:.96rem; font-weight:800; color:var(--gold); margin-top:6px; }

.cdi-remove {

  background:none; border:none; font-size:.72rem; color:var(--text3);

  padding:4px; transition:color .2s; cursor:pointer;

}

.cdi-remove:hover { color:#e85d75; }

.cd-foot { padding:20px 28px 28px; border-top:1px solid var(--border); }

.cd-summary { display:flex; flex-direction:column; gap:10px; margin-bottom:20px; }

.cd-sum-row { display:flex; justify-content:space-between; align-items:center; font-size:.88rem; color:var(--text2); }

.cd-free { color:#4ade80; font-weight:700; }

.cd-total-row { padding-top:10px; border-top:1px solid var(--border2); }

.cd-total-val { font-family:var(--font-title),serif; font-size:1.4rem; font-weight:700; color:var(--gold); }

.cd-checkout { width:100%; justify-content:center; padding:16px; margin-bottom:12px; }

.cd-continue { width:100%; background:none; border:none; font-size:.84rem; color:var(--text3); padding:8px; transition:color .2s; }

.cd-continue:hover { color:var(--gold); }



/* ================================================================

   TOAST STACK

   ================================================================ */

.toast-stack { position:fixed; bottom:28px; right:28px; z-index:3000; display:flex; flex-direction:column-reverse; gap:10px; }

.toast-item {
  display:flex; align-items:center; gap:12px;
  background:rgba(11,14,26,.97); border:1px solid var(--border);
  backdrop-filter:blur(24px); border-radius:var(--r-md);
  padding:14px 20px; min-width:260px; max-width:340px;
  box-shadow:0 8px 32px rgba(0,0,0,.6);
  animation:toast-in .4s var(--ease) both;
  cursor:pointer;
  color: #FAF8F5 !important;
}

.toast-item.gold { border-color:rgba(var(--gold-rgb),.4); }

.toast-item.hide { animation:toast-out .35s var(--ease) forwards; }

@keyframes toast-in { from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }

@keyframes toast-out { to{opacity:0;transform:translateX(20px)} }

.toast-icon { font-size:1.2rem; flex-shrink:0; color: rgba(255, 255, 255, 0.7); }
.toast-item.gold .toast-icon { color: var(--gold) !important; }
.toast-msg { font-size:.86rem; color: #FAF8F5 !important; font-weight:600; }







/* ================================================================

   AOS (scroll reveal)

   ================================================================ */

[data-aos] { opacity:0; transition:opacity .7s var(--ease), transform .7s var(--ease); }

[data-aos="fade-up"]   { transform:translateY(36px); }

[data-aos="fade-left"] { transform:translateX(36px); }

[data-aos="zoom-in"]   { transform:scale(.94); }

[data-aos].aos-animate { opacity:1; transform:none; }



/* ================================================================

   RESPONSIVE

   ================================================================ */

@media(max-width:1100px) {

  .hero-content { 
    grid-template-columns:1fr; 
    text-align: center;
    justify-items: center;
    padding: 100px 20px 60px;
    gap: 40px;
  }

  .hc-left {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .hc-desc {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 32px;
  }

  .hc-btns {
    justify-content: center;
    width: 100%;
  }

  .hc-stats {
    justify-content: center;
    width: 100%;
  }

  .hc-right {
    display: flex !important;
    justify-content: center;
    margin-top: 20px;
    width: 100%;
  }

  .book-showcase {
    width: 300px;
    margin: 0 auto;
  }

  .r1 { width: 360px; height: 360px; }
  .r2 { width: 300px; height: 300px; }
  .r3 { width: 240px; height: 240px; }

  .author-stats { justify-content:center; }

  .ft-grid { grid-template-columns:1fr 1fr; }

  .nl-card { grid-template-columns:1fr; gap:40px; padding:48px 36px; }

}

@media(max-width:768px) {

  .nav-wrap {
    padding: 0 16px;
    gap: 16px;
    height: 64px;
  }

  .logo {
    font-size: 1.2rem;
  }

  .nav-actions {
    gap: 6px;
  }

  .na-btn {
    width: 36px;
    height: 36px;
  }

  .na-cart-btn {
    padding: 0 12px;
    height: 36px;
    font-size: 0.8rem;
  }

  .nav-menu { 
    display: none; 
    position: absolute; 
    top: 100%; 
    left: 0; 
    right: 0; 
    background: rgba(var(--bg-rgb), 0.96) !important; 
    backdrop-filter: blur(20px) !important; 
    -webkit-backdrop-filter: blur(20px) !important; 
    flex-direction: column; 
    padding: 20px 16px; 
    border-bottom: 1px solid var(--border); 
    gap: 6px; 
    z-index: 1001 !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
  }

  .nav-menu.open { display: flex; }

  .nav-menu .nm-link {
    width: 100%;
    text-align: center;
    padding: 12px;
    font-size: 1rem;
    font-weight: 600;
    border-radius: var(--r-sm);
    transition: background 0.25s, color 0.25s;
    color: var(--text2) !important;
  }
  .nav-menu .nm-link:hover, .nav-menu .nm-link.active {
    background: var(--surface2) !important;
    color: var(--gold) !important;
  }
  .nav-menu .nm-link::after {
    display: none !important;
  }

  .hamburger { display:flex; }

  .books-grid { 
    grid-template-columns: 1fr; 
    gap: 32px;
  }

  .bk-card {
    max-width: 420px;
    margin: 0 auto;
    width: 100%;
  }

  .cats-grid { grid-template-columns:repeat(2,1fr); }

  .bs-row {
    grid-template-columns: 40px 64px 1fr;
    grid-template-areas: 
      "num thumb body"
      "cta cta cta";
    gap: 16px;
    padding: 16px;
  }
  
  .bs-num { grid-area: num; align-self: center; }
  .bs-thumb { grid-area: thumb; }
  .bs-body { grid-area: body; }
  
  .bs-cta {
    grid-area: cta;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    margin-top: 8px;
    border-top: 1px dashed var(--border);
    padding-top: 12px;
    width: 100%;
  }

  .bs-cta .bs-price {
    margin-right: auto;
    font-size: 1.1rem;
    font-weight: 700;
  }

  .bs-cta button, .bs-cta a {
    width: auto !important;
    flex: 1 1 auto;
    text-align: center;
    justify-content: center;
  }

  .quotes-grid { grid-template-columns: repeat(2, 1fr); }

  .tb-inner { 
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    padding: 24px 16px;
  }

  .tb-sep { display:none; }

  .tb-item { 
    justify-content: center;
    flex-direction: column;
    text-align: center;
    align-items: center;
  }

  .reviews-grid { grid-template-columns:1fr; }

  .ft-grid { grid-template-columns:1fr; }

  .fb-inner {
    flex-direction: column;
    text-align: center;
    gap: 12px;
  }

}

@media(max-width:480px) {

  .na-cart-text {
    display: none;
  }

  .na-cart-btn {
    width: 36px;
    padding: 0;
    justify-content: center;
  }

  .nav-actions {
    gap: 4px;
  }

  .book-showcase {
    width: 220px;
  }
  .r1 { width: 280px; height: 280px; }
  .r2 { width: 220px; height: 220px; }
  .r3 { width: 160px; height: 160px; }
  .bs-badge {
    position: relative;
    right: 0;
    bottom: 0;
    margin-top: 20px;
    justify-content: center;
  }
  .bs-label {
    margin-top: 10px;
  }

  .cats-grid { 
    grid-template-columns: repeat(2, 1fr); 
    gap: 12px;
  }

  .quotes-grid { grid-template-columns:1fr; }

  .hc-btns { flex-direction:column; }

  .btn-gold,.btn-ghost { justify-content:center; text-align:center; }

  .nl-card { padding:36px 24px; }

  .hc-stats { flex-wrap:wrap; gap:20px; }

  .hc-stat-sep { display:none; }

  .tb-inner {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .author-stats {
    gap: 24px;
  }

  .rv-card {
    padding: 24px 18px;
  }

  .ud-card {
    padding: 24px 16px;
  }

  .rm-lock-card {
    padding: 24px 20px;
  }

}



@keyframes fadeIn { from{opacity:0} to{opacity:1} }



/* ================================================================

   CURSOR FIX — interactive elements

   ================================================================ */

button,a,[role=button],.cat-card,.bk-card,.bs-row,.rv-card { cursor:pointer; }



/* ================================================================

   ADMIN ICON IN NAVBAR

   ================================================================ */

.admin-icon-btn {

  position:relative;

  color:var(--gold) !important;

  border:1px solid rgba(var(--gold-rgb),.3) !important;

  background:rgba(var(--gold-rgb),.08) !important;

  border-radius:var(--r-sm);

  animation:admin-pulse 3s ease-in-out infinite;

}

.admin-icon-btn:hover { background:rgba(var(--gold-rgb),.2) !important; box-shadow:0 0 18px rgba(var(--gold-rgb),.3); }

@keyframes admin-pulse { 0%,100%{box-shadow:0 0 0 0 rgba(var(--gold-rgb),.4)} 50%{box-shadow:0 0 0 6px rgba(var(--gold-rgb),0)} }



/* ================================================================

   SHARED ADMIN BACKDROP

   ================================================================ */

.admin-backdrop {

  position:fixed; inset:0; z-index:1500;

  background:rgba(0,0,0,.75); backdrop-filter:blur(8px);

  opacity:0; pointer-events:none;

  transition:opacity .4s var(--ease);

}

.admin-backdrop.active { opacity:1; pointer-events:all; }



/* ================================================================

   ADMIN LOGIN MODAL

   ================================================================ */

.admin-login-modal {

  position:fixed; top:50%; left:50%; transform:translate(-50%,-44%) scale(0.94);

  z-index:1600; width:min(440px,92vw);

  background:var(--bg2); border:1px solid rgba(var(--gold-rgb),.3);

  border-radius:var(--r-xl); padding:48px 40px;

  text-align:center;

  opacity:0; pointer-events:none;

  transition:all .4s var(--ease);

  box-shadow:0 32px 80px rgba(0,0,0,.7), 0 0 0 1px rgba(var(--gold-rgb),.1);

}

.admin-login-modal.open { opacity:1; pointer-events:all; transform:translate(-50%,-50%) scale(1); }

.alm-close {

  position:absolute; top:16px; right:16px;

  background:var(--surface); border:1px solid var(--border2); border-radius:var(--r-sm);

  width:32px; height:32px; color:var(--text3); font-size:.9rem;

  display:flex; align-items:center; justify-content:center;

  transition:all .2s;

}

.alm-close:hover { color:var(--gold); border-color:var(--border); }

.alm-icon { font-size:2.8rem; margin-bottom:16px; }

.alm-title { font-family:var(--font-title),serif; font-size:1.5rem; font-weight:700; margin-bottom:8px; }

.alm-sub { font-size:.88rem; color:var(--text3); margin-bottom:28px; }

.alm-field { display:flex; flex-direction:column; gap:6px; text-align:left; margin-bottom:16px; }

.alm-field label { font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--text3); }

.alm-field input {

  background:var(--surface); border:1px solid var(--border2);

  border-radius:var(--r-md); padding:13px 18px;

  color:var(--text); font-size:.95rem; font-family:inherit; outline:none;

  transition:border-color .25s, box-shadow .25s;

}

.alm-field input:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(var(--gold-rgb),.12); }

.alm-error {

  display:none; font-size:.82rem; color:#f87171;

  background:rgba(248,113,113,.1); border:1px solid rgba(248,113,113,.2);

  border-radius:var(--r-sm); padding:10px 14px; margin-bottom:16px; text-align:left;

}

.alm-submit { width:100%; justify-content:center; padding:15px; margin-bottom:16px; }

.alm-hint { font-size:.72rem; color:var(--text3); letter-spacing:.06em; }

@keyframes shake {

  0%,100%{transform:translateX(0)} 20%,60%{transform:translateX(-8px)} 40%,80%{transform:translateX(8px)}

}

.shake { animation:shake .5s var(--ease); }



/* ================================================================

   ADMIN PANEL (Full Screen)

   ================================================================ */

.admin-panel {

  position:fixed; inset:0; z-index:1600;

  background:var(--bg); display:flex; flex-direction:column;

  transform:translateY(20px); opacity:0; pointer-events:none;

  transition:all .45s var(--ease);

}

.admin-panel.open { transform:translateY(0); opacity:1; pointer-events:all; }



/* Admin Header */

.adm-head {

  display:flex; align-items:center; justify-content:space-between;

  padding:0 32px; height:64px;

  background:var(--bg2); border-bottom:1px solid var(--border);

  flex-shrink:0;

}

.adm-head-left { display:flex; align-items:center; gap:16px; }

.adm-logo { font-family:var(--font-title),serif; font-size:1.1rem; font-weight:700; color:var(--gold); letter-spacing:.1em; }

.adm-role {

  font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;

  color:var(--text3); background:rgba(var(--gold-rgb),.1); border:1px solid var(--border);

  padding:3px 10px; border-radius:var(--r-full);

}

.adm-head-right { display:flex; align-items:center; gap:10px; }

.adm-preview-btn {

  background:var(--surface); border:1px solid var(--border2);

  color:var(--text2); font-size:.82rem; padding:8px 16px;

  border-radius:var(--r-sm); transition:all .25s;

}

.adm-preview-btn:hover { border-color:var(--gold); color:var(--gold); }

.adm-logout {

  background:rgba(248,113,113,.1); border:1px solid rgba(248,113,113,.25);

  color:#f87171; font-size:.82rem; padding:8px 16px;

  border-radius:var(--r-sm); transition:all .25s;

}

.adm-logout:hover { background:rgba(248,113,113,.2); }

.adm-close {

  width:36px; height:36px; border-radius:var(--r-sm);

  background:var(--surface); border:1px solid var(--border2);

  color:var(--text3); font-size:1rem;

  display:flex; align-items:center; justify-content:center; transition:all .25s;

}

.adm-close:hover { color:var(--gold); border-color:var(--border); }



/* Admin Tabs */

.adm-tabs {

  display:flex; gap:4px; padding:12px 32px;

  background:var(--bg2); border-bottom:1px solid var(--border);

  flex-shrink:0; overflow-x:auto;

}

.adm-tab {

  background:none; border:1px solid transparent;

  color:var(--text3); font-size:.85rem; font-weight:600;

  padding:9px 20px; border-radius:var(--r-sm);

  transition:all .25s; white-space:nowrap;

}

.adm-tab:hover { color:var(--text); background:var(--surface); }

.adm-tab.active { color:var(--gold); background:rgba(var(--gold-rgb),.1); border-color:rgba(var(--gold-rgb),.25); }



/* Admin Body */

.adm-body { flex:1; overflow-y:auto; padding:32px; }

.adm-section { display:none; }

.adm-section.active { display:block; }

.adm-section-title { font-family:var(--font-title),serif; font-size:1.3rem; font-weight:700; color:var(--text); margin-bottom:24px; }

.adm-section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }

.adm-add-btn {

  background:linear-gradient(135deg,var(--gold-dk),var(--gold));

  color:var(--bg); font-size:.85rem; font-weight:800;

  padding:10px 22px; border-radius:var(--r-sm); border:none;

  letter-spacing:.04em; transition:all .25s;

}

.adm-add-btn:hover { box-shadow:var(--shadow-gold); transform:translateY(-1px); }



/* Stats grid */

.adm-stats-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:20px; margin-bottom:40px; }

.adm-stat-card {

  background:var(--surface); border:1px solid var(--border);

  border-radius:var(--r-lg); padding:28px 24px; text-align:center;

  transition:transform .3s, border-color .3s;

}

.adm-stat-card:hover { transform:translateY(-3px); border-color:rgba(var(--gold-rgb),.3); }

.gold-card { border-color:rgba(var(--gold-rgb),.3); background:rgba(var(--gold-rgb),.05); }

.adm-stat-icon { font-size:2rem; margin-bottom:12px; }

.adm-stat-val { font-family:var(--font-title),serif; font-size:1.8rem; font-weight:700; color:var(--gold); margin-bottom:4px; }

.adm-stat-lbl { font-size:.75rem; color:var(--text3); text-transform:uppercase; letter-spacing:.1em; }



/* Quick actions */

.adm-quick-actions { margin-top:12px; }

.adm-qat { font-size:.8rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--text3); margin-bottom:16px; }

.adm-qa-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:12px; }

.adm-qa-btn {

  background:var(--surface); border:1px solid var(--border);

  color:var(--text2); font-size:.88rem; font-weight:600;

  padding:14px 18px; border-radius:var(--r-md); text-align:left;

  transition:all .25s;

}

.adm-qa-btn:hover { border-color:rgba(var(--gold-rgb),.4); color:var(--gold); background:rgba(var(--gold-rgb),.06); transform:translateY(-2px); }



/* Admin Table */

.adm-table-wrap { overflow-x:auto; border-radius:var(--r-md); border:1px solid var(--border); }

.adm-table { width:100%; border-collapse:collapse; }

.adm-table th {

  background:rgba(var(--gold-rgb),.06); padding:13px 18px;

  text-align:left; font-size:.72rem; font-weight:800;

  letter-spacing:.12em; text-transform:uppercase; color:var(--gold);

  border-bottom:1px solid var(--border);

}

.adm-table td {

  padding:14px 18px; font-size:.88rem; color:var(--text2);

  border-bottom:1px solid rgba(255,255,255,.04);

}

.adm-table tr:last-child td { border-bottom:none; }

.adm-table tr:hover td { background:rgba(255,255,255,.02); }

.adm-gold { color:var(--gold); font-weight:700; }

.adm-badge {

  display:inline-block; font-size:.65rem; font-weight:800;

  letter-spacing:.1em; text-transform:uppercase;

  padding:3px 10px; border-radius:var(--r-full);

}

.adm-badge-green { background:rgba(74,222,128,.12); color:#4ade80; border:1px solid rgba(74,222,128,.25); }

.adm-badge-amber { background:rgba(251,191,36,.12); color:#fbbf24; border:1px solid rgba(251,191,36,.25); }

.adm-action-btn {

  background:var(--surface); border:1px solid var(--border2);

  color:var(--text2); font-size:.75rem; padding:5px 12px;

  border-radius:var(--r-sm); transition:all .2s; margin-right:6px;

}

.adm-action-btn:hover { border-color:var(--gold); color:var(--gold); }

.adm-action-del:hover { border-color:rgba(248,113,113,.4) !important; color:#f87171 !important; }



/* Settings */

.adm-settings-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:20px; }

.adm-setting-card {

  background:var(--surface); border:1px solid var(--border);

  border-radius:var(--r-md); padding:20px;

}

.adm-setting-card h4 { font-size:.8rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text3); margin-bottom:10px; }

.adm-input {

  width:100%; background:rgba(255,255,255,.05); border:1px solid var(--border2);

  border-radius:var(--r-sm); padding:10px 14px;

  color:var(--text); font-size:.9rem; font-family:inherit; outline:none;

  transition:border-color .25s;

}

.adm-input:focus { border-color:var(--gold); }



/* ================================================================

   WISHLIST PANEL

   ================================================================ */

.wish-panel {

  position:fixed; right:0; top:0; bottom:0; z-index:1200;

  width:min(380px,100vw); background:var(--bg2);

  border-left:1px solid var(--border);

  display:flex; flex-direction:column;

  transform:translateX(100%); transition:transform .4s var(--ease);

}

.wish-panel.open { transform:translateX(0); }

.wp-head {

  display:flex; align-items:center; justify-content:space-between;

  padding:24px 24px; border-bottom:1px solid var(--border);

}

.wp-head h3 { font-family:var(--font-title),serif; font-size:1rem; font-weight:700; }

.wp-head button { background:none; border:none; color:var(--text3); font-size:1.1rem; transition:color .2s; }

.wp-head button:hover { color:var(--gold); }

.wp-body { flex:1; overflow-y:auto; padding:16px 24px; }

.wish-item {

  display:flex; align-items:center; justify-content:space-between;

  padding:14px 0; border-bottom:1px solid var(--border2); gap:12px;

}

.wi-title { font-size:.9rem; color:var(--text); flex:1; }

.wi-btns { display:flex; gap:8px; flex-shrink:0; }

.wi-btns button {

  font-size:.75rem; padding:6px 12px; border-radius:var(--r-sm);

  background:rgba(var(--gold-rgb),.1); border:1px solid var(--border);

  color:var(--gold); transition:all .2s;

}

.wi-btns button:hover { background:var(--gold); color:var(--bg); }

.wi-remove { background:rgba(248,113,113,.08) !important; border-color:rgba(248,113,113,.2) !important; color:#f87171 !important; }

.wi-remove:hover { background:rgba(248,113,113,.2) !important; color:#fff !important; }



/* ================================================================

   THEME TOGGLER STYLES

   ================================================================ */

#themeToggle .sun-icon { display: none; }

#themeToggle .moon-icon { display: block; color: var(--text2); }

#themeToggle:hover .moon-icon { color: var(--gold); }



body.dark-theme #themeToggle .sun-icon { display: block; color: var(--gold); }

body.dark-theme #themeToggle .moon-icon { display: none; }

body.dark-theme #themeToggle:hover .sun-icon { color: var(--gold-lt); }



/* Remove Custom Cursor Glow */

.cursor-glow { display: none !important; }



/* Hand-Drawn Vector Star Details & Accents */

.sec-star {

  display: inline-block;

  color: var(--gold);

  margin: 0 6px;

  vertical-align: middle;

  transition: transform 0.4s var(--ease);

}

.sec-head:hover .sec-star {

  transform: scale(1.2) rotate(15deg);

}



/* Beautiful Spine Sleep Covers (Kindle Dashboard inspired) */

.bk-placeholder {

  position: relative;

  background: var(--bg2) !important;

  border-bottom: 2px solid var(--border);

  box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.05);

}

body.dark-theme .bk-placeholder {

  background: var(--bg3) !important;

}



.bk-pl-content {

  display: flex;

  flex-direction: column;

  align-items: center;

  justify-content: center;

  height: 100%;

  padding: 24px;

  text-align: center;

}



.bk-pl-icon {

  font-size: 2.5rem;

  color: var(--gold);

  margin-bottom: 12px;

  opacity: 0.9;

}



.bk-pl-name {

  font-family: var(--font-title) !important;

  font-size: 1.05rem !important;

  font-weight: 700 !important;

  color: var(--text) !important;

  line-height: 1.3 !important;

  letter-spacing: 0.02em !important;

  margin-bottom: 8px !important;

}



.bk-pl-author {

  font-family: var(--font-serif) !important;

  font-size: 0.8rem !important;

  font-style: italic;

  color: var(--text2) !important;

}



/* Redesign category icon wrapping */

.cat-icon-wrap {

  background: var(--surface) !important;

  border: 1px solid var(--border) !important;

  color: var(--gold) !important;

}

.cat-card {

  background: var(--bg3) !important;

  border: 1px solid var(--border) !important;

  box-shadow: var(--shadow-card);

}

.cat-card h3 {

  font-family: var(--font-title) !important;

  color: var(--text) !important;

}



/* Clean up newsletter section linear gradient */

.newsletter-section {

  background: var(--bg);

}

.nl-card {

  background: var(--bg2) !important;

  border: 1px solid var(--border) !important;

  box-shadow: var(--shadow-card) !important;

}

.nl-card::before {

  display: none;

}

.nl-title {

  font-family: var(--font-title) !important;

  color: var(--text) !important;

}

.nl-input {

  background: var(--bg) !important;

  border: 1px solid var(--border) !important;

  color: var(--text) !important;

}

.nl-input:focus {

  border-color: var(--gold) !important;

  box-shadow: 0 0 0 3px var(--gold-glow) !important;

}



/* Clean up footer styles */

.footer {

  background: var(--bg2) !important;

  border-top: 1px solid var(--border) !important;

  color: var(--text) !important;

}

.footer-top {

  border-bottom: 1px solid var(--border) !important;

}

.ft-logo {

  font-family: var(--font-title) !important;

  color: var(--gold) !important;

}

.ft-social {

  background: var(--bg3) !important;

  border: 1px solid var(--border) !important;

  color: var(--text2) !important;

}

.ft-social:hover {

  background: var(--gold) !important;

  color: var(--bg) !important;

  border-color: var(--gold) !important;

}

.ft-col-title {

  font-family: var(--font-title) !important;

  color: var(--text) !important;

}

.footer-bottom {

  background: var(--bg) !important;

  color: var(--text2) !important;

}

.footer-bottom a:hover {

  color: var(--gold) !important;

}



/* Clean up admin panel styling */

.admin-panel {

  background: var(--bg) !important;

  border: 1px solid var(--border) !important;

  color: var(--text) !important;

  box-shadow: var(--shadow-card) !important;

}

.adm-head {

  border-bottom: 1px solid var(--border) !important;

}

.adm-tab {

  background: var(--bg2) !important;

  color: var(--text2) !important;

  border: 1px solid var(--border) !important;

  border-bottom: none !important;

}

.adm-tab.active {

  background: var(--bg) !important;

  color: var(--gold) !important;

  border-top: 2px solid var(--gold) !important;

}

.adm-stat-card {

  background: var(--bg2) !important;

  border: 1px solid var(--border) !important;

  color: var(--text) !important;

}

.adm-stat-card.gold-card {

  border-color: var(--gold) !important;

  background: var(--gold-glow) !important;

}

.adm-stat-card.gold-card .adm-stat-val {

  color: var(--gold) !important;

}

.adm-table th {

  background: var(--bg2) !important;

  color: var(--text) !important;

  border-bottom: 1px solid var(--border) !important;

}

.adm-table td {

  border-bottom: 1px solid var(--border2) !important;

  color: var(--text2) !important;

}

.adm-table tr:hover td {

  background: var(--surface) !important;

}

.adm-input {

  background: var(--bg) !important;

  border: 1px solid var(--border) !important;

  color: var(--text) !important;

}



/* Drawer / panel overrides */

.cart-drawer, .wish-panel {

  background: var(--bg2) !important;

  border-left: 1px solid var(--border) !important;

}

.cd-head, .wp-head {

  border-bottom: 1px solid var(--border) !important;

}

.cd-item, .wish-item {

  border-bottom: 1px solid var(--border) !important;

}

.cdi-qty-btn {

  background: var(--bg3) !important;

  border: 1px solid var(--border) !important;

  color: var(--text) !important;

}

.cdi-qty-btn:hover {

  background: var(--gold) !important;

  color: var(--bg) !important;

}

.cd-foot {

  border-top: 1px solid var(--border) !important;

}



/* Scrolled Navbar and Search Bar theme adaptability */

.navbar.scrolled,
.navbar:has(.nav-menu.open) {

  background: rgba(var(--bg-rgb), 0.96) !important;

  backdrop-filter: blur(20px) !important;

  -webkit-backdrop-filter: blur(20px) !important;

  border-bottom: 1px solid var(--border) !important;

  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.05) !important;

}

body.dark-theme .navbar.scrolled,
body.dark-theme .navbar:has(.nav-menu.open) {

  background: rgba(var(--bg-rgb), 0.96) !important;

  box-shadow: 0 8px 45px rgba(0, 0, 0, 0.4) !important;

}

.search-bar {

  background: var(--bg2) !important;

  border-bottom: 1px solid var(--border) !important;

}



/* ================================================================

   CHECKOUT PAYMENT MODAL

   ================================================================ */

.checkout-modal {

  position: fixed;

  top: 50%;

  left: 50%;

  transform: translate(-50%, -44%) scale(0.94);

  z-index: 1600;

  width: min(480px, 92vw);

  background: var(--bg2);

  border: 1px solid rgba(var(--gold-rgb), .3);

  border-radius: var(--r-xl);

  padding: 40px 32px;

  text-align: center;

  opacity: 0;

  pointer-events: none;

  transition: all .4s var(--ease);

  box-shadow: var(--shadow-card);

}

.checkout-modal.open {

  opacity: 1;

  pointer-events: all;

  transform: translate(-50%, -50%) scale(1);

}

.chm-close {

  position: absolute;

  top: 16px;

  right: 16px;

  background: var(--surface);

  border: 1px solid var(--border2);

  border-radius: var(--r-sm);

  width: 32px;

  height: 32px;

  color: var(--text3);

  font-size: .9rem;

  display: flex;

  align-items: center;

  justify-content: center;

  transition: all .2s;

}

.chm-close:hover {

  color: var(--gold);

  border-color: var(--border);

}

.chm-icon {

  font-size: 2.5rem;

  margin-bottom: 12px;

}

.chm-title {

  font-family: var(--font-title), serif;

  font-size: 1.4rem;

  font-weight: 700;

  margin-bottom: 6px;

}

.chm-sub {

  font-size: .84rem;

  color: var(--text3);

  margin-bottom: 24px;

}



/* Payment Method Tabs */

.chm-methods {

  display: flex;

  gap: 8px;

  margin-bottom: 24px;

}

.chm-method-tab {

  flex: 1;

  background: var(--bg3);

  border: 1px solid var(--border);

  color: var(--text2);

  font-size: .82rem;

  font-weight: 700;

  padding: 12px;

  border-radius: var(--r-md);

  transition: all .25s;

}

.chm-method-tab.active {

  background: var(--gold-glow);

  border-color: var(--gold);

  color: var(--gold);

}

.chm-method-tab:hover:not(.active) {

  background: var(--surface);

  color: var(--text);

}



/* Content blocks */

.chm-content {

  text-align: left;

}

.chm-field {

  display: flex;

  flex-direction: column;

  gap: 6px;

  margin-bottom: 16px;

}

.chm-field label {

  font-size: .7rem;

  font-weight: 700;

  letter-spacing: .08em;

  text-transform: uppercase;

  color: var(--text3);

}

.chm-field input {

  background: var(--surface);

  border: 1px solid var(--border2);

  border-radius: var(--r-md);

  padding: 12px 16px;

  color: var(--text);

  font-size: .92rem;

  font-family: inherit;

  outline: none;

  transition: border-color .25s, box-shadow .25s;

}

.chm-field input:focus {

  border-color: var(--gold);

  box-shadow: 0 0 0 3px var(--gold-glow);

}

.chm-row {

  display: grid;

  grid-template-columns: 1fr 1fr;

  gap: 16px;

}



.chm-submit {

  width: 100%;

  justify-content: center;

  padding: 14px;

  margin-top: 10px;

  margin-bottom: 16px;

}

.chm-hint {

  font-size: .7rem;

  color: var(--text3);

  letter-spacing: .04em;

}



/* Amazon Pay styling */

.chm-amazon-info {

  font-size: .88rem;

  color: var(--text2);

  line-height: 1.6;

  margin-bottom: 24px;

  text-align: center;

}

.btn-amazon-pay {

  width: 100%;

  background: #fad978;

  border: 1px solid #a88734;

  border-radius: var(--r-md);

  padding: 14px;

  font-size: .95rem;

  font-weight: 500;

  color: #111;

  display: flex;

  align-items: center;

  justify-content: center;

  gap: 10px;

  transition: all .25s;

  font-family: var(--font-sans);

}

.btn-amazon-pay:hover {

  background: #f7ca4a;

  border-color: #846a29;

  box-shadow: 0 4px 15px rgba(247,202,74,0.25);

  transform: translateY(-1px);

}

.btn-amazon-pay .amazon-icon {

  font-size: 1.25rem;

}



/* ================================================================

   FLOATING WHATSAPP WIDGET

   ================================================================ */

.whatsapp-float {

  position: fixed;

  bottom: 28px;

  right: 28px;

  z-index: 1400;

  display: flex;

  align-items: center;

  gap: 8px;

  background: #25D366;

  color: #FFF;

  padding: 10px 14px;

  border-radius: var(--r-full);

  box-shadow: 0 8px 24px rgba(37,211,102,0.25);

  font-family: var(--font-sans);

  font-weight: 700;

  font-size: 0.82rem;

  letter-spacing: 0.02em;

  transition: all 0.35s var(--ease);

  text-decoration: none;

}

.whatsapp-icon {

  width: 20px;

  height: 20px;

  flex-shrink: 0;

}

.whatsapp-badge {

  max-width: 0;

  overflow: hidden;

  white-space: nowrap;

  opacity: 0;

  transition: max-width 0.4s var(--ease), opacity 0.3s var(--ease);

}

.whatsapp-float:hover {

  background: #20ba59;

  box-shadow: 0 12px 32px rgba(32,186,89,0.35);

  transform: translateY(-2px);

}

.whatsapp-float:hover .whatsapp-badge {

  max-width: 120px;

  opacity: 1;

}



/* ================================================================

   PROMOTIONAL DISCOUNT POPUP

   ================================================================ */

.promo-backdrop {

  position: fixed;

  inset: 0;

  z-index: 1700;

  background: rgba(0,0,0,0.65);

  backdrop-filter: blur(8px);

  opacity: 0;

  pointer-events: none;

  transition: opacity 0.4s var(--ease);

}

.promo-backdrop.active {

  opacity: 1;

  pointer-events: all;

}



.promo-modal {

  position: fixed;

  top: 50%;

  left: 50%;

  transform: translate(-50%, -44%) scale(0.94);

  z-index: 1800;

  width: min(440px, 92vw);

  background: var(--bg2);

  border: 1px solid rgba(var(--gold-rgb), 0.35);

  border-radius: var(--r-xl);

  padding: 44px 36px;

  text-align: center;

  opacity: 0;

  pointer-events: none;

  transition: all 0.4s var(--ease);

  box-shadow: var(--shadow-card), 0 24px 60px rgba(0,0,0,0.15);

}

.promo-modal.open {

  opacity: 1;

  pointer-events: all;

  transform: translate(-50%, -50%) scale(1);

}



.pm-close {

  position: absolute;

  top: 16px;

  right: 16px;

  background: var(--surface);

  border: 1px solid var(--border2);

  border-radius: var(--r-sm);

  width: 32px;

  height: 32px;

  color: var(--text3);

  font-size: .9rem;

  display: flex;

  align-items: center;

  justify-content: center;

  transition: all 0.2s;

}

.pm-close:hover {

  color: var(--gold);

  border-color: var(--border);

}



.pm-badge {

  font-family: var(--font-sans);

  font-size: 0.72rem;

  font-weight: 800;

  letter-spacing: 0.16em;

  color: var(--gold);

  margin-bottom: 12px;

  text-transform: uppercase;

}



.pm-title {

  font-family: var(--font-title), serif;

  font-size: 1.6rem;

  font-weight: 700;

  color: var(--text);

  line-height: 1.3;

  margin-bottom: 8px;

}



.pm-sub {

  font-size: 0.88rem;

  color: var(--text2);

  line-height: 1.5;

  margin-bottom: 24px;

}



.pm-field {

  display: flex;

  flex-direction: column;

  gap: 6px;

  text-align: left;

  margin-bottom: 16px;

}

.pm-field label {

  font-size: 0.72rem;

  font-weight: 700;

  letter-spacing: 0.08em;

  text-transform: uppercase;

  color: var(--text3);

}

.pm-field input {

  background: var(--surface);

  border: 1px solid var(--border2);

  border-radius: var(--r-md);

  padding: 12px 16px;

  color: var(--text);

  font-size: 0.92rem;

  font-family: inherit;

  outline: none;

  transition: border-color .25s, box-shadow .25s;

  width: 100%;

}

.pm-field input:focus {

  border-color: var(--gold);

  box-shadow: 0 0 0 3px var(--gold-glow);

}



.pm-submit {

  width: 100%;

  justify-content: center;

  padding: 14px;

  margin-top: 8px;

  margin-bottom: 16px;

}



.pm-success-icon {

  font-size: 3.5rem;

  margin-bottom: 16px;

  animation: pulse 1.5s ease-in-out infinite;

}



.pm-code-container {

  display: flex;

  align-items: center;

  justify-content: space-between;

  background: var(--bg3);

  border: 1px solid var(--border);

  border-radius: var(--r-md);

  padding: 10px 16px;

  margin: 18px 0;

  font-size: 1.15rem;

}

.pm-code-container code {

  font-family: 'Courier New', Courier, monospace;

  font-weight: 700;

  color: var(--gold);

  letter-spacing: 0.05em;

}

.pm-copy-btn {

  background: var(--gold-glow);

  border: 1px solid rgba(var(--gold-rgb), 0.3);

  color: var(--gold);

  font-size: 0.75rem;

  font-weight: 700;

  padding: 6px 14px;

  border-radius: var(--r-sm);

  display: flex;

  align-items: center;

  gap: 6px;

  transition: all 0.25s;

}

.pm-copy-btn:hover {

  background: var(--gold);

  color: var(--bg);

  border-color: var(--gold);

}



.pm-continue-btn {

  width: 100%;

  justify-content: center;

  padding: 14px;

  margin-bottom: 16px;

}



.pm-hint {

  font-size: 0.72rem;

  color: var(--text3);

  letter-spacing: 0.04em;

}



/* ================================================================

   CHECKOUT PROMO CODE FIELD

   ================================================================ */

.chm-promo-section {

  background: var(--surface);

  border: 1px solid var(--border2);

  border-radius: var(--r-md);

  padding: 14px 16px;

  margin-bottom: 18px;

}

.chm-field-promo {

  display: flex;

  gap: 10px;

}

.chm-field-promo input {

  flex: 1;

  background: var(--bg3);

  border: 1px solid var(--border2);

  border-radius: var(--r-sm);

  padding: 8px 12px;

  color: var(--text);

  font-size: 0.84rem;

  outline: none;

  font-family: inherit;

  transition: border-color 0.25s;

}

.chm-field-promo input:focus {

  border-color: var(--gold);

}

.btn-promo-apply {

  background: var(--surface2);

  border: 1px solid var(--border2);

  color: var(--text2);

  font-size: 0.8rem;

  font-weight: 700;

  padding: 8px 16px;

  border-radius: var(--r-sm);

  transition: all 0.25s;

}

.btn-promo-apply:hover {

  background: var(--gold-glow);

  color: var(--gold);

  border-color: var(--gold);

}

.chm-promo-feedback {

  font-size: 0.76rem;

  font-weight: 600;

  margin-top: 6px;

  display: none;

}

.chm-promo-feedback.success {

  color: #25D366;

  display: block;

}

.chm-promo-feedback.error {

  color: #f87171;

  display: block;

}



/* ================================================================

   ORDER CONFIRMATION MODAL

   ================================================================ */

.confirm-modal {

  position: fixed;

  top: 50%;

  left: 50%;

  transform: translate(-50%, -44%) scale(0.94);

  z-index: 1800;

  width: min(500px, 92vw);

  background: var(--bg2);

  border: 1px solid rgba(var(--gold-rgb), 0.35);

  border-radius: var(--r-xl);

  padding: 44px 36px;

  text-align: center;

  opacity: 0;

  pointer-events: none;

  transition: all 0.4s var(--ease);

  box-shadow: var(--shadow-card), 0 24px 60px rgba(0,0,0,0.18);

  max-height: 90vh;

  overflow-y: auto;

}

.confirm-modal.open {

  opacity: 1;

  pointer-events: all;

  transform: translate(-50%, -50%) scale(1);

}



.ocm-close {

  position: absolute;

  top: 16px;

  right: 16px;

  background: var(--surface);

  border: 1px solid var(--border2);

  border-radius: var(--r-sm);

  width: 32px;

  height: 32px;

  color: var(--text3);

  font-size: .9rem;

  display: flex;

  align-items: center;

  justify-content: center;

  transition: all 0.2s;

}

.ocm-close:hover {

  color: var(--gold);

  border-color: var(--border);

}



/* Premium Animated Checkmark */

.ocm-success-ring {

  width: 72px;

  height: 72px;

  margin: 0 auto 20px;

}

.ocm-checkmark {

  width: 72px;

  height: 72px;

  border-radius: 50%;

  display: block;

  stroke-width: 2.5;

  stroke: var(--gold);

  stroke-miterlimit: 10;

  box-shadow: inset 0 0 0 var(--gold);

  animation: fill .4s ease-in-out .4s forwards, scale-up .3s ease-in-out .9s both;

}

.ocm-checkmark-circle {

  stroke-dasharray: 166;

  stroke-dashoffset: 166;

  stroke-width: 2.5;

  stroke-miterlimit: 10;

  stroke: var(--gold);

  fill: none;

  animation: stroke .6s var(--ease) forwards;

}

.ocm-checkmark-check {

  transform-origin: 50% 50%;

  stroke-dasharray: 48;

  stroke-dashoffset: 48;

  stroke: var(--bg2);

  animation: stroke .3s var(--ease) .8s forwards;

}



@keyframes stroke {

  to { stroke-dashoffset: 0; }

}

@keyframes fill {

  to { box-shadow: inset 0 0 0 40px var(--gold); }

}

@keyframes scale-up {

  0%, 100% { transform: none; }

  50% { transform: scale3d(1.1, 1.1, 1); }

}



.ocm-title {

  font-family: var(--font-title), serif;

  font-size: 1.7rem;

  font-weight: 700;

  color: var(--text);

  margin-bottom: 8px;

}

.ocm-sub {

  font-size: 0.9rem;

  color: var(--text3);

  line-height: 1.4;

  margin-bottom: 28px;

}



.ocm-details {

  background: var(--bg3);

  border: 1px solid var(--border);

  border-radius: var(--r-md);

  padding: 18px 20px;

  margin-bottom: 20px;

  text-align: left;

  display: flex;

  flex-direction: column;

  gap: 12px;

}

.ocm-detail-row {

  display: flex;

  justify-content: space-between;

  font-size: 0.88rem;

  color: var(--text2);

}

.ocm-detail-row span {

  font-weight: 500;

}

.ocm-detail-row strong {

  color: var(--text);

}

.ocm-detail-row strong.gold {

  color: var(--gold);

  font-weight: 800;

}



/* Items Summary inside Confirmation Modal */

.ocm-items-summary-title {

  text-align: left;

  font-size: 0.72rem;

  font-weight: 800;

  letter-spacing: 0.08em;

  text-transform: uppercase;

  color: var(--text3);

  margin-bottom: 8px;

  padding-left: 4px;

}

.ocm-items-summary {

  max-height: 150px;

  overflow-y: auto;

  border: 1px solid var(--border2);

  border-radius: var(--r-md);

  padding: 4px 16px;

  margin-bottom: 24px;

  background: var(--surface);

  text-align: left;

}

.ocm-summary-item {

  display: flex;

  justify-content: space-between;

  align-items: center;

  padding: 10px 0;

  border-bottom: 1px solid var(--border2);

  font-size: 0.84rem;

}

.ocm-summary-item:last-child {

  border-bottom: none;

}

.ocm-si-info {

  display: flex;

  align-items: center;

  gap: 8px;

  color: var(--text);

  font-weight: 600;

}

.ocm-si-qty {

  font-size: 0.76rem;

  background: var(--surface2);

  color: var(--text2);

  padding: 2px 6px;

  border-radius: 4px;

}

.ocm-si-price {

  color: var(--text2);

  font-weight: 600;

}



.ocm-thank-you-msg {

  font-family: var(--font-serif);

  font-style: italic;

  font-size: 0.95rem;

  line-height: 1.6;

  color: var(--text2);

  border-top: 1px solid var(--border);

  padding-top: 20px;

  margin-bottom: 28px;

  position: relative;

}



.ocm-continue-btn {

  width: 100%;

  justify-content: center;

  padding: 14px;

}



/* ================================================================

   GOLD (ORO) LINE ART & FILLED SVG ICONS

   ================================================================ */

.icon-oro {

  display: inline-block;

  vertical-align: middle;

  width: 24px;

  height: 24px;

  color: var(--gold);

  fill: none;

  stroke: var(--gold);

  stroke-width: 2;

  stroke-linecap: round;

  stroke-linejoin: round;

  flex-shrink: 0;

  transition: transform 0.3s var(--ease), color 0.3s;

}

.icon-oro.filled {

  fill: var(--gold);

  stroke: none;

}

.icon-oro.lg {

  width: 32px;

  height: 32px;

  stroke-width: 1.8;

}

.icon-oro.xl {

  width: 44px;

  height: 44px;

  stroke-width: 1.5;

}

.icon-oro.sm {

  width: 16px;

  height: 16px;

  stroke-width: 2.2;

}

.icon-oro.xs {

  width: 13px;

  height: 13px;

  stroke-width: 2.5;

}



/* Subtle icon animations on hover if inside interactive elements */

.cat-card:hover .icon-oro {

  transform: scale(1.12) rotate(4deg);

}

.adm-tab:hover .icon-oro {

  transform: translateY(-1px);

}

.btn-gold:hover .icon-oro, .btn-gold-sm:hover .icon-oro {

  transform: translateX(2px);

}



/* ================================================================

   INTERACTIVE CHAPTER READER MODAL

   ================================================================ */

.reader-modal {

  position: fixed;

  inset: 0;

  background: var(--bg);

  z-index: 2000;

  display: flex;

  flex-direction: column;

  opacity: 0;

  visibility: hidden;

  transition: opacity 0.4s var(--ease), visibility 0.4s var(--ease);

}

.reader-modal.open {

  opacity: 1;

  visibility: visible;

}



/* Header */

.rm-header {

  height: 64px;

  border-bottom: 1px solid var(--border);

  padding: 0 24px;

  display: flex;

  align-items: center;

  justify-content: space-between;

  background: var(--bg2);

  flex-shrink: 0;

}

.rm-header-left {

  display: flex;

  align-items: center;

  gap: 16px;

}

.rm-logo-text {

  font-family: var(--font-title), serif;

  font-weight: 700;

  letter-spacing: 0.15em;

  color: var(--gold);

  font-size: 1.1rem;

}

.rm-book-title {

  font-size: 0.85rem;

  color: var(--text2);

  border-left: 1px solid var(--border);

  padding-left: 16px;

  font-weight: 500;

}

.rm-header-right {

  display: flex;

  align-items: center;

  gap: 16px;

}

.rm-font-controls {

  display: flex;

  background: var(--surface);

  border: 1px solid var(--border2);

  border-radius: var(--r-sm);

  padding: 2px;

}

.rm-font-btn {

  background: none;

  border: none;

  color: var(--text);

  padding: 6px 12px;

  font-size: 0.8rem;

  font-weight: 700;

  border-radius: 4px;

  transition: background 0.2s, color 0.2s;

}

.rm-font-btn:hover {

  background: var(--surface2);

}

.rm-close {

  background: none;

  border: none;

  color: var(--text2);

  font-size: 1.25rem;

  width: 36px;

  height: 36px;

  display: flex;

  align-items: center;

  justify-content: center;

  border-radius: 50%;

  transition: background 0.2s, color 0.2s;

}

.rm-close:hover {

  background: var(--surface);

  color: var(--text);

}



/* Modal layout container */

.rm-container {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow: hidden;
  position: relative;
}

.rm-workspace {
  display: flex;
  flex: 1;
  overflow: hidden;
}



/* Sidebar for chapters */

.rm-sidebar {

  width: 280px;

  border-right: 1px solid var(--border);

  background: var(--bg2);

  display: flex;

  flex-direction: column;

  padding: 24px 16px;

  gap: 12px;

  overflow-y: auto;

  flex-shrink: 0;

}

.rm-sidebar-title {

  font-family: var(--font-title), serif;

  font-size: 0.75rem;

  font-weight: 800;

  letter-spacing: 0.08em;

  text-transform: uppercase;

  color: var(--text3);

  margin-bottom: 8px;

  padding-left: 8px;

}

.rm-tab-btn {

  background: var(--bg);

  border: 1px solid var(--border2);

  border-radius: var(--r-md);

  padding: 14px 16px;

  display: flex;

  align-items: center;

  justify-content: space-between;

  text-align: left;

  transition: all 0.3s var(--ease);

}

.rm-tab-btn:hover {

  border-color: var(--gold);

  transform: translateY(-1px);

}

.rm-tab-btn.active {

  border-color: var(--gold);

  background: rgba(var(--gold-rgb), 0.04);

  box-shadow: 0 4px 12px rgba(var(--gold-rgb), 0.05);

}

.rm-tab-label {

  display: flex;

  flex-direction: column;

  gap: 4px;

}

.rm-tab-num {

  font-size: 0.72rem;

  font-weight: 700;

  text-transform: uppercase;

  letter-spacing: 0.04em;

  color: var(--text3);

}

.rm-tab-btn.active .rm-tab-num {

  color: var(--gold);

}

.rm-tab-name {

  font-size: 0.88rem;

  font-weight: 600;

  color: var(--text);

}

.rm-tab-status {

  display: flex;

  align-items: center;

  color: var(--text3);

}

.rm-tab-btn.active .rm-tab-status {

  color: var(--gold);

}



/* Content Pane and Paper background styling */

.rm-content-pane {
  flex: 1;
  overflow-y: auto;
  background: var(--bg3);
  position: relative;
  scroll-behavior: smooth;
  padding: 48px 24px;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
/* Scrollbar custom styles for content */
.rm-content-pane::-webkit-scrollbar {
  width: 8px;
}
.rm-content-pane::-webkit-scrollbar-track {
  background: transparent;
}
.rm-content-pane::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 4px;
}



.rm-paper {

  max-width: 680px;

  margin: 0 auto;

  background: #FAF8F5; /* serif editorial paper color in light mode */

  color: #1A1B1E;

  padding: 48px 56px;

  border-radius: var(--r-md);

  box-shadow: 0 10px 40px rgba(0,0,0,0.04);

  border: 1px solid rgba(0,0,0,0.03);

  transition: background 0.4s var(--ease), color 0.4s var(--ease);

}

/* Ensure elegant styling inside dark-theme */

body.dark-theme .rm-paper {

  background: #18191C; /* Darker serif slate */

  color: #ECECEB;

  box-shadow: 0 10px 50px rgba(0,0,0,0.5);

  border: 1px solid rgba(255,255,255,0.02);

}



.rm-chapter-meta {

  font-family: var(--font-sans);

  font-size: 0.75rem;

  font-weight: 800;

  letter-spacing: 0.1em;

  text-transform: uppercase;

  color: var(--gold);

  margin-bottom: 12px;

  text-align: center;

}

.rm-chapter-title {

  font-family: var(--font-title), serif;

  font-size: 2.2rem;

  font-weight: 700;

  text-align: center;

  color: inherit;

  margin-bottom: 40px;

  letter-spacing: -0.02em;

  line-height: 1.2;

}



.rm-chapter-text {

  font-family: var(--font-serif);

  font-size: var(--reader-font-size, 1.15rem);

  line-height: 1.75;

  text-align: justify;

}

.rm-chapter-text p {

  margin-bottom: 24px;

  text-indent: 24px;

}

.rm-chapter-text p:first-of-type {

  text-indent: 0;

}

/* Beautiful dropship capital letter for editorial feel */

.rm-chapter-text .drop-cap::first-letter {

  font-family: var(--font-title), serif;

  font-size: 3.8em;

  float: left;

  line-height: 0.8;

  margin-top: 4px;

  margin-right: 8px;

  color: var(--gold);

  font-weight: 700;

}



/* Beautiful blur cover overlay */

.locked-blur {

  filter: blur(12px);

  opacity: 0.22;

  user-select: none;

  pointer-events: none;

}



/* Frosted glass locked overlay card */

.rm-lock-overlay {

  position: absolute;

  inset: 0;

  background: rgba(var(--gold-rgb), 0.02);

  backdrop-filter: blur(4px);

  display: flex;

  align-items: center;

  justify-content: center;

  padding: 24px;

  z-index: 10;

}

.rm-lock-card {

  max-width: 440px;

  width: 100%;

  background: var(--bg);

  border: 1px solid var(--border);

  border-radius: var(--r-lg);

  padding: 36px 32px;

  text-align: center;

  position: relative;

  overflow: hidden;

  box-shadow: var(--shadow-card);

}

.rm-lc-glow {

  position: absolute;

  top: -50%;

  left: -50%;

  width: 200%;

  height: 200%;

  background: radial-gradient(circle, rgba(var(--gold-rgb), 0.08) 0%, transparent 60%);

  pointer-events: none;

}

.rm-lc-icon {

  width: 60px;

  height: 60px;

  background: rgba(var(--gold-rgb), 0.08);

  border-radius: 50%;

  display: flex;

  align-items: center;

  justify-content: center;

  margin: 0 auto 20px;

}

.rm-lc-title {

  font-family: var(--font-title), serif;

  font-size: 1.35rem;

  font-weight: 700;

  color: var(--text);

  margin-bottom: 12px;

}

.rm-lc-desc {

  font-size: 0.88rem;

  color: var(--text2);

  line-height: 1.5;

  margin-bottom: 24px;

}

.rm-lc-price {

  display: block;

  font-size: 2rem;

  font-weight: 800;

  color: var(--gold);

  margin-bottom: 20px;

  font-family: var(--font-sans);

}



/* Mobile responsive fixes */

@media (max-width: 768px) {

  .rm-header {

    padding: 0 16px;

  }

  .rm-book-title {

    display: none;

  }

  .rm-container {

    flex-direction: column;

  }

  .rm-sidebar {

    width: 100%;

    height: auto;

    border-right: none;

    border-bottom: 1px solid var(--border);

    flex-direction: row;

    overflow-x: auto;

    padding: 12px;

    gap: 8px;

  }

  .rm-sidebar-title {

    display: none;

  }

  .rm-tab-btn {

    padding: 8px 12px;

    flex-shrink: 0;

  }

  .rm-tab-name {

    font-size: 0.8rem;

  }

  .rm-content-pane {

    padding: 24px 12px;

  }

  .rm-paper {

    padding: 28px 24px;

  }

}








/* ================================================================
   GOLDEN LINES HOMEPAGE SHOWCASE SECTION
   ================================================================ */
.quotes-showcase-section {
  background: var(--bg2);
  position: relative;
  padding: 80px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.quotes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 40px;
}
.quote-card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 32px;
  position: relative;
  transition: all 0.4s var(--ease);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.quote-card:hover {
  transform: translateY(-5px);
  border-color: var(--gold);
  box-shadow: 0 10px 30px rgba(var(--gold-rgb), 0.05);
}
.qc-icon {
  font-size: 1.5rem;
  color: var(--gold);
  margin-bottom: 16px;
  line-height: 1;
}
.qc-text {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--text);
  margin: 0 0 20px 0;
  font-style: italic;
}
.qc-meta {
  border-top: 1px solid var(--border2);
  padding-top: 12px;
  margin-top: auto;
}
.qc-chapter {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gold);
}

/* ================================================================
   FLOATING PROMOTION BADGE
   ================================================================ */
.promo-float {
  position: fixed;
  bottom: 28px;
  left: 28px;
  z-index: 1400;
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg3);
  color: var(--text);
  padding: 10px 16px;
  border-radius: var(--r-full);
  border: 1px solid rgba(var(--gold-rgb), 0.35);
  box-shadow: var(--shadow-card), 0 8px 24px rgba(var(--gold-rgb), 0.15);
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.02em;
  transition: all 0.35s var(--ease);
  cursor: pointer;
  outline: none;
}
.promo-float-icon {
  font-size: 1.1rem;
  line-height: 1;
}
.promo-float-badge {
  color: var(--gold);
  white-space: nowrap;
}
.promo-float:hover {
  background: var(--bg2);
  border-color: var(--gold);
  box-shadow: var(--shadow-card), 0 12px 32px rgba(var(--gold-rgb), 0.25);
  transform: translateY(-2px) scale(1.03);
}

/* Subtle breathing / glowing animation */
@keyframes goldPulse {
  0% {
    box-shadow: var(--shadow-card), 0 0 0 0 rgba(var(--gold-rgb), 0.4);
  }
  70% {
    box-shadow: var(--shadow-card), 0 0 0 8px rgba(var(--gold-rgb), 0);
  }
  100% {
    box-shadow: var(--shadow-card), 0 0 0 0 rgba(var(--gold-rgb), 0);
  }
}
.promo-float {
  animation: goldPulse 3s infinite;
}

@media (max-width: 576px) {
  .promo-float {
    bottom: 20px;
    left: 20px;
    padding: 10px;
    border-radius: 50%;
    width: 44px;
    height: 44px;
    justify-content: center;
  }
  .promo-float-badge {
    display: none;
  }
}

/* ================================================================
   READER CORE INSIGHTS (QUOTES PREVIEW)
   ================================================================ */
.rm-quotes-container {
  display: flex;
  flex-direction: column;
  gap: 28px;
  margin-top: 16px;
}
.rm-quote-item {
  background: rgba(var(--gold-rgb), 0.015);
  border-left: 3px solid var(--gold);
  padding: 24px;
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  transition: background 0.3s;
}
.rm-quote-item:hover {
  background: rgba(var(--gold-rgb), 0.03);
}
.rm-quote-content {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  line-height: 1.65;
  color: inherit;
  margin-bottom: 12px;
  font-style: italic;
}
.rm-quote-tag {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gold);
}

@media (max-width: 992px) {
  .quotes-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .quotes-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* ══════════════════════════════════════════════
   CUSTOMER AUTH MODAL & INFINITE SCROLLING
   ══════════════════════════════════════════════ */
.auth-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--bg);
  z-index: 2100;
  opacity: 0;
  visibility: hidden;
  transition: all 0.5s cubic-bezier(.25, .8, .25, 1);
  overflow: hidden;
}

.auth-modal.open {
  opacity: 1;
  visibility: visible;
}

.auth-container {
  display: grid;
  grid-template-columns: 3.6fr 3.8fr 3.6fr;
  width: 100vw;
  height: 100vh;
  position: relative;
}

/* Image Scroll Zones */
.auth-scroll-zone {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  height: 100vh;
  overflow: hidden;
  padding: 16px;
  position: relative;
  background: var(--bg2);
}

.auth-scroll-zone::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, var(--bg) 0%, transparent 15%, transparent 85%, var(--bg) 100%);
  pointer-events: none;
  z-index: 2;
}

.auth-column {
  display: flex;
  flex-direction: column;
  height: 200%; /* Enough to house dynamic double items */
  overflow: hidden;
  position: relative;
}

/* Infinite Scroll Marquee Tracks */
.auth-scroll-track {
  display: flex;
  flex-direction: column;
  gap: 16px;
  animation-duration: 35s;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
}

/* Dynamic Alternating Speeds and Directions */
.auth-column:nth-child(1) .auth-scroll-track {
  animation-duration: 38s;
}
.auth-column:nth-child(2) .auth-scroll-track {
  animation-duration: 32s;
}
.auth-column:nth-child(3) .auth-scroll-track {
  animation-duration: 44s;
}

/* Alternating Scrolling */
.col-up .auth-scroll-track {
  animation-name: scrollUp;
}

.col-down .auth-scroll-track {
  animation-name: scrollDown;
}

.auth-column img {
  width: 100%;
  aspect-ratio: 2/3;
  object-fit: cover;
  border-radius: var(--r-md);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
  filter: grayscale(12%) contrast(96%) brightness(96%);
  transition: all 0.4s var(--ease);
}

.auth-column img:hover {
  filter: grayscale(0%) contrast(100%) brightness(100%);
  transform: scale(1.03);
}

@keyframes scrollUp {
  0% { transform: translateY(0); }
  100% { transform: translateY(-50%); }
}

@keyframes scrollDown {
  0% { transform: translateY(-50%); }
  100% { transform: translateY(0); }
}

/* Center Form Zone */
.auth-form-zone {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 40px 24px;
  background: var(--bg);
  position: relative;
  z-index: 10;
  box-shadow: 0 0 60px rgba(28,29,33,0.04);
  height: 100vh;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}

.auth-form-zone::-webkit-scrollbar {
  width: 5px;
}

.auth-form-zone::-webkit-scrollbar-track {
  background: transparent;
}

.auth-form-zone::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 3px;
}

body.dark-theme .auth-form-zone {
  background: var(--bg);
}

.auth-card {
  width: 100%;
  max-width: 460px; /* Increased from 420px */
  background: rgba(250, 248, 245, 0.85); /* Premium glassmorphism sand background */
  backdrop-filter: blur(25px) saturate(110%);
  -webkit-backdrop-filter: blur(25px) saturate(110%);
  border: 1px solid rgba(200, 90, 63, 0.16);
  border-radius: var(--r-lg);
  padding: 48px 40px; /* Increased from 42px 34px */
  box-shadow: 0 30px 70px rgba(28,29,33,0.06), 0 0 100px rgba(200,90,63,0.02);
  position: relative;
  transition: all 0.4s var(--ease);
  margin: auto; /* Vertically and horizontally centers when space permits, allows scrolling when it overflows! */
}

body.dark-theme .auth-card {
  background: rgba(26, 27, 30, 0.82); /* Dark theme premium glassmorphism */
  border-color: rgba(200, 90, 63, 0.22);
  box-shadow: 0 30px 70px rgba(0,0,0,0.22), 0 0 100px rgba(200,90,63,0.03);
}

.auth-close-btn {
  position: absolute;
  top: 24px;
  right: 24px;
  background: var(--surface);
  border: none;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  color: var(--text2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.95rem;
  transition: all 0.3s;
}

.auth-close-btn:hover {
  background: var(--surface2);
  color: var(--text);
  transform: rotate(90deg);
}

.auth-brand {
  text-align: center;
  margin-bottom: 32px;
}

.auth-brand h2 {
  font-family: var(--font-title);
  font-size: 2.5rem; /* Increased from 2.3rem */
  color: var(--text);
  letter-spacing: 0.05em;
  margin: 10px 0 6px;
}

.auth-brand p {
  font-size: 0.9rem; /* Increased from 0.85rem */
  color: var(--text2);
}

/* Tabs */
.auth-tabs {
  display: flex;
  border-bottom: 1px solid var(--border2);
  margin-bottom: 32px;
  gap: 16px;
}

.auth-tab {
  flex: 1;
  background: none;
  border: none;
  padding: 14px 0; /* Increased from 12px */
  font-size: 1.05rem; /* Increased from 0.98rem */
  font-weight: 700;
  color: var(--text3);
  position: relative;
  transition: color 0.3s;
  letter-spacing: 0.03em;
}

.auth-tab.active {
  color: var(--gold);
}

.auth-tab::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 2.5px;
  background: var(--gold);
  transform: scaleX(0);
  transition: transform 0.3s var(--ease);
}

.auth-tab.active::after {
  transform: scaleX(1);
}

/* Auth Fields */
.auth-field {
  position: relative;
  margin-bottom: 24px;
}

.auth-field input {
  width: 100%;
  padding: 17px 18px; /* Increased from 15px 16px */
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: var(--r-sm);
  font-family: var(--font-sans);
  font-size: 1.05rem; /* Increased from 0.98rem */
  color: var(--text);
  transition: all 0.3s var(--ease);
}

.auth-field input:focus {
  outline: none;
  border-color: var(--gold);
  background: var(--bg);
  box-shadow: 0 0 0 3px var(--gold-glow);
}

.auth-field label {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.98rem; /* Increased from 0.92rem */
  color: var(--text3);
  pointer-events: none;
  transition: all 0.25s var(--ease);
}

/* Floating Label Magic */
.auth-field input:focus ~ label,
.auth-field input:not(:placeholder-shown) ~ label {
  top: 0;
  transform: translateY(-50%) scale(0.85);
  left: 14px;
  padding: 0 6px;
  background: var(--bg3);
  color: var(--gold);
  font-weight: 700;
}

body.dark-theme .auth-field input:focus ~ label,
body.dark-theme .auth-field input:not(:placeholder-shown) ~ label {
  background: #1f2023; /* Matching dark theme card surface */
}

.auth-error-msg {
  color: #ef4444;
  font-size: 0.85rem;
  margin-bottom: 18px;
  min-height: 18px;
  display: none;
  font-weight: 500;
  text-align: center;
}

.auth-submit-btn {
  width: 100%;
  justify-content: center;
  padding: 17px; /* Increased from 15px */
  font-size: 1.05rem; /* Increased from 0.98rem */
}

.auth-footer {
  text-align: center;
  margin-top: 26px;
  font-size: 0.88rem; /* Increased from 0.82rem */
  color: var(--text3);
}

.auth-footer a {
  color: var(--gold);
  font-weight: 600;
  text-decoration: underline;
}

.auth-footer a:hover {
  color: var(--gold-dk);
}

/* ══════════════════════════════════════════════
   CUSTOMER PROFILE DASHBOARD MODAL
   ══════════════════════════════════════════════ */
.user-dashboard-modal {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: 2200;
  opacity: 0;
  visibility: hidden;
  transition: all 0.4s var(--ease);
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.user-dashboard-modal.open {
  opacity: 1;
  visibility: visible;
}

.user-dashboard-modal::before {
  content: '';
  position: absolute;
  top:0; left:0; width:100%; height:100%;
  background: rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 1;
}

.ud-card {
  width: 100%;
  max-width: 440px;
  height: 100%;
  background: var(--bg);
  border-left: 1px solid var(--border);
  box-shadow: -10px 0 40px rgba(0,0,0,0.06);
  display: flex;
  flex-direction: column;
  padding: 40px 32px;
  transform: translateX(100%);
  transition: transform 0.4s var(--ease);
  position: relative;
  z-index: 2;
}

.user-dashboard-modal.open .ud-card {
  transform: translateX(0);
}

.ud-close-btn {
  position: absolute;
  top: 24px;
  left: 24px;
  background: var(--surface);
  border: none;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  color: var(--text2);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.ud-close-btn:hover {
  background: var(--surface2);
  color: var(--text);
  transform: rotate(90deg);
}

.ud-header {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-top: 40px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--border2);
}

.ud-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--gold);
  color: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 800;
  box-shadow: var(--shadow-gold);
}

.ud-user-meta h3 {
  font-size: 1.25rem;
  color: var(--text);
  margin-bottom: 4px;
}

.ud-user-meta p {
  font-size: 0.88rem;
  color: var(--text3);
}

.ud-content {
  flex: 1;
  overflow-y: auto;
  padding: 28px 0;
  scrollbar-width: thin;
}

.ud-section {
  margin-bottom: 32px;
}

.ud-section h4 {
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
  font-weight: 800;
}

.ud-library-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.ud-lib-card {
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-radius: var(--r-md);
  padding: 18px 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
  box-shadow: var(--shadow-card);
  transition: all 0.3s;
}

.ud-lib-card:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
}

.ud-lib-icon {
  display: inline-flex;
  justify-content: center;
}

.ud-lib-title {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1.3;
}

.ud-lib-btn {
  width: 100%;
  padding: 8px 12px;
  font-size: 0.78rem;
}

.ud-orders-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ud-order-item {
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-radius: var(--r-sm);
  padding: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.ud-order-info div {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}

.ud-order-info span {
  font-size: 0.78rem;
  color: var(--text3);
}

.ud-order-total {
  font-family: var(--font-sans);
  font-weight: 800;
  color: var(--gold);
}

.ud-footer {
  padding-top: 20px;
  border-top: 1px solid var(--border2);
}

/* User Header Initials Icon */
.nav-avatar-btn {
  background: var(--gold);
  color: var(--bg);
  border: none;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.9rem;
  box-shadow: var(--shadow-gold);
  transition: all 0.3s var(--ease);
}

.nav-avatar-btn:hover {
  transform: scale(1.08);
}

/* Responsive Grid */
@media (max-width: 1200px) {
  .auth-container {
    grid-template-columns: 2fr 3fr 2fr;
  }
}

@media (max-width: 1024px) {
  .auth-container {
    grid-template-columns: 1fr;
  }
  .auth-scroll-zone {
    display: none;
  }
  .auth-form-zone {
    padding: 24px;
  }
}

/* ================================================================
   PREMIUM CUSTOM FILTER DROPDOWNS
   ================================================================ */
.fb-select-wrap {
  position: relative;
  flex: 1;
  min-width: 170px;
}

/* Visually hide native select, keeping accessibility active */
.fb-select.native-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  border: 0 !important;
}

.fb-custom-trigger {
  width: 100%;
  padding: 14px 36px 14px 0;
  font-size: 0.9rem;
  font-family: inherit;
  font-weight: 700;
  color: var(--text);
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  user-select: none;
  transition: color 0.3s var(--ease);
}

.fb-custom-trigger:hover,
.fb-custom-trigger.active {
  color: var(--gold);
}

.fb-custom-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-card), 0 12px 35px rgba(0, 0, 0, 0.08);
  z-index: 1001;
  padding: 8px;
  opacity: 0;
  transform: translateY(12px) scale(0.96);
  pointer-events: none;
  transition: opacity 0.28s var(--ease), transform 0.28s var(--ease);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

@media (max-width: 768px) {
  .filter-bar {
    flex-direction: column;
    align-items: stretch;
    border-radius: var(--r-lg);
    padding: 12px;
    gap: 12px;
  }
  .fb-select-wrap {
    padding: 0 16px;
    border-radius: var(--r-md);
    border: 1px solid var(--border);
  }
  .fb-select-wrap:not(:first-child)::before {
    display: none;
  }
  .fb-chevron {
    right: 16px;
  }
  .fb-custom-trigger {
    padding: 12px 24px 12px 0;
  }
  .fb-custom-dropdown {
    top: calc(100% + 6px);
  }
  .fb-find {
    padding: 14px 28px;
    border-radius: var(--r-md);
    justify-content: center;
  }
}

.fb-custom-dropdown.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.fb-dropdown-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 14px;
  border-radius: var(--r-sm);
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--text2);
  cursor: pointer;
  transition: all 0.24s var(--ease);
}

.fb-dropdown-item:hover {
  background: rgba(var(--gold-rgb), 0.06);
  color: var(--gold);
  transform: translateX(2px);
}

.fb-dropdown-item.selected {
  background: rgba(var(--gold-rgb), 0.1);
  color: var(--gold);
}

.fb-dropdown-item-check {
  width: 13px;
  height: 13px;
  color: var(--gold);
  opacity: 0;
  transition: opacity 0.2s var(--ease);
}

.fb-dropdown-item.selected .fb-dropdown-item-check {
  opacity: 1;
}

/* Arrow rotating on open */
.fb-chevron {
  transition: transform 0.3s var(--ease);
}
.fb-custom-trigger.active ~ .fb-chevron {
  transform: translateY(-50%) rotate(180deg);
  color: var(--gold);
}

/* ══════════════════════════════════════════════
   SOCIAL LOGINS STYLING
   ══════════════════════════════════════════════ */
.auth-separator {
  display: flex;
  align-items: center;
  text-align: center;
  margin: 22px 0;
  color: var(--text3);
  font-size: 0.76rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.auth-separator::before,
.auth-separator::after {
  content: '';
  flex: 1;
  border-bottom: 1px solid var(--border2);
}

.auth-separator:not(:empty)::before {
  margin-right: 12px;
}

.auth-separator:not(:empty)::after {
  margin-left: 12px;
}

.auth-social-buttons {
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
}

.btn-social {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: var(--r-sm);
  padding: 11px 10px;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--text2);
  cursor: pointer;
  transition: all 0.3s var(--ease);
  box-shadow: 0 2px 4px rgba(0,0,0,0.02);
}

.btn-social:hover {
  background: var(--surface2);
  border-color: var(--gold);
  color: var(--text);
  transform: translateY(-1px);
}

.btn-social svg {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
}

.btn-social.google:hover {
  box-shadow: 0 4px 12px rgba(66, 133, 244, 0.08);
}

.btn-social.apple {
  background: #111216;
  color: #FAF8F5;
  border-color: #222;
}

.btn-social.apple:hover {
  background: #000;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

.btn-social.github {
  background: #24292e;
  color: #fff;
  border-color: #333;
}

.btn-social.github:hover {
  background: #1c2024;
  box-shadow: 0 4px 12px rgba(36, 41, 46, 0.12);
}

/* ══════════════════════════════════════════════
   REGIONAL CHECKOUT PORTAL STYLING
   ══════════════════════════════════════════════ */
.chm-zone-tab.active {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
  color: var(--bg) !important;
  box-shadow: var(--shadow-gold);
}

.chm-instruction-box {
  background: rgba(var(--gold-rgb), 0.04);
  border: 1px dashed rgba(var(--gold-rgb), 0.3);
  border-radius: var(--r-md);
  padding: 14px 16px;
  margin-bottom: 20px;
  font-size: 0.8rem;
  line-height: 1.5;
  color: var(--text2);
}

.chm-instruction-box strong {
  color: var(--gold);
}

.chm-instruction-box p {
  margin-bottom: 6px;
}

.chm-instruction-box p:last-child {
  margin-bottom: 0;
}

 