/*
Theme Name: CraveStore
Theme URI: https://mycravestore.com
Author: MyCraveStore
Description: Bold, sensual dark/light WordPress theme for adult novelty, lingerie & leather retail. Vibratex-inspired. Elementor Free compatible. Ecwid/Lightspeed ready. All visual assets sourced from Envato Elements (licensed separately — see ASSETS.md).
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: Private
Text Domain: cravestore
Tags: dark, light-mode, adult, lingerie, elementor, ecwid
*/

/*
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  ENVATO ELEMENTS ASSET MAP
  License all assets at elements.envato.com
  (included in your active subscription)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

  HERO BACKGROUND VIDEO (looping):
    "Falling Petals Red Rose on a Black Background"
    → https://elements.envato.com/falling-petals-red-rose-on-a-black-background-PX3XZMZ
    Usage: Hero section video background (muted, loop, autoplay)
    Save as: assets/video/hero-bg.mp4

  HERO OVERLAY / TEXTURE:
    "Black Leather Textures" (graphic pack)
    → https://elements.envato.com/black-leather-textures-562GHX4
    Usage: Subtle CSS overlay on hero section
    Save as: assets/img/leather-texture.jpg

  CATEGORY SECTION — LINGERIE PHOTO:
    "Tender Woman in Lingerie" (stock footage still)
    → https://elements.envato.com/tender-woman-in-lingerie-D7WZRX3
    Usage: Category card background — Lingerie
    Save as: assets/img/cat-lingerie.jpg

  CATEGORY SECTION — LEATHER PHOTO:
    "Macro Shot of Black Leather Texture" (stock footage still)
    → https://elements.envato.com/black-leather-fabric-macro-footage-concept-of-text-XNJRGWF
    Usage: Category card background — Leather & Accessories
    Save as: assets/img/cat-leather.jpg

  CATEGORY SECTION — NOVELTIES / DARK ABSTRACT:
    "Dark textured concrete wall with laser neon lights" (photo)
    → https://elements.envato.com/photos/dark+background  (search "laser neon dark")
    Usage: Category card background — Novelties
    Save as: assets/img/cat-novelties.jpg

  FEATURED BANNER BACKGROUND:
    "Luxury Leather Textures" (graphic)
    → https://elements.envato.com/luxury-leather-textures-CJEL8K
    Usage: Featured / New Arrivals banner background
    Save as: assets/img/featured-bg.jpg

  FOOTER / SECTION DIVIDER TEXTURE:
    "20 Black Leather Textures HQ" (graphic pack)
    → https://elements.envato.com/20-black-leather-textures-hq-7HDVD86
    Usage: Footer background texture
    Save as: assets/img/footer-texture.jpg

  AMBIENT BACKGROUND LOOP (optional — Elementor video widget):
    "Flying Romantic Dark Red Rose Flower Petals Falling"
    → https://elements.envato.com/flying-romantic-dark-red-rose-flower-petals-fallin-FSGMV23
    Usage: Elementor section video overlay — testimonials or featured section

━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
*/

/* ── DESIGN TOKENS ──────────────────────────────────────────── */
:root {
  --bg:           #080709;
  --bg-2:         #0f0e12;
  --bg-3:         #161419;
  --surface:      #1c1a22;
  --surface-2:    #232030;
  --border:       rgba(255,255,255,0.06);
  --border-gold:  rgba(201,169,110,0.2);
  --text:         #ede8e3;
  --text-muted:   #847d8a;
  --text-faint:   #3f3a47;
  --accent:       #c8365a;
  --accent-2:     #e04e73;
  --accent-glow:  rgba(200,54,90,0.2);
  --gold:         #c9a96e;
  --gold-light:   #e8c98a;
  --gold-glow:    rgba(201,169,110,0.15);
  --white:        #ffffff;
  --shadow:       0 12px 48px rgba(0,0,0,0.7);
  --shadow-sm:    0 3px 16px rgba(0,0,0,0.5);
  --radius:       3px;
  --radius-lg:    10px;
  --transition:   0.3s cubic-bezier(0.4,0,0.2,1);
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Jost', 'Helvetica Neue', sans-serif;
  --font-accent:  'Cormorant Garamond', Georgia, serif;
}

[data-theme="light"] {
  --bg:           #f7f4f1;
  --bg-2:         #eeebe7;
  --bg-3:         #e5e0da;
  --surface:      #ffffff;
  --surface-2:    #f2ede8;
  --border:       rgba(0,0,0,0.07);
  --border-gold:  rgba(154,118,64,0.2);
  --text:         #181016;
  --text-muted:   #665e6a;
  --text-faint:   #b0a8b4;
  --accent:       #b0243f;
  --accent-2:     #cc3558;
  --accent-glow:  rgba(176,36,63,0.12);
  --gold:         #9a7640;
  --gold-light:   #b89050;
  --gold-glow:    rgba(154,118,64,0.1);
  --shadow:       0 12px 48px rgba(0,0,0,0.1);
  --shadow-sm:    0 3px 16px rgba(0,0,0,0.07);
}

/* ── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-weight:300;
  line-height:1.75;
  letter-spacing:0.01em;
  transition:background var(--transition),color var(--transition);
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-2);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--gold)}
ul{list-style:none}

/* ── TYPOGRAPHY ─────────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-0.025em;
  color:var(--text);
}
h1{font-size:clamp(2.8rem,7vw,5.5rem)}
h2{font-size:clamp(2rem,4.5vw,3.8rem)}
h3{font-size:clamp(1.3rem,2.5vw,2rem)}
h4{font-size:1.2rem}

.eyebrow{
  font-family:var(--font-body);
  font-size:0.68rem;
  font-weight:600;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
}
.serif-italic{
  font-family:var(--font-accent);
  font-style:italic;
  font-weight:300;
  color:var(--accent-2);
}
p{margin-bottom:1.2em;color:var(--text-muted)}
p:last-child{margin-bottom:0}

/* ── LAYOUT ─────────────────────────────────────────────────── */
.container{width:100%;max-width:1260px;margin:0 auto;padding:0 clamp(1.5rem,5vw,4rem)}
.container--narrow{max-width:820px}
.container--wide{max-width:1480px}
section{padding:clamp(4rem,8vw,8rem) 0}

/* ── HEADER ─────────────────────────────────────────────────── */
#site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:0 clamp(1.5rem,5vw,4rem);
  height:70px;
  display:flex;align-items:center;justify-content:space-between;
  background:transparent;
  transition:background var(--transition),box-shadow var(--transition),backdrop-filter var(--transition);
}
#site-header.scrolled{
  background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:0 1px 0 var(--border);
}
.site-logo a{
  font-family:var(--font-display);
  font-size:1.55rem;
  font-weight:700;
  color:var(--text);
  letter-spacing:-0.03em;
}
.site-logo a em{color:var(--accent);font-style:normal}
.site-logo img{height:38px;width:auto}

#site-navigation{display:flex;align-items:center;gap:2.5rem}

.primary-menu{display:flex;align-items:center;gap:2rem}
.primary-menu li a{
  font-size:0.72rem;
  font-weight:500;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--text-muted);
  padding:0.2rem 0;
  position:relative;
  transition:color var(--transition);
}
.primary-menu li a::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:0;height:1px;background:var(--accent);
  transition:width var(--transition);
}
.primary-menu li a:hover,.primary-menu li.current-menu-item a{color:var(--text)}
.primary-menu li a:hover::after,.primary-menu li.current-menu-item a::after{width:100%}

.header-actions{display:flex;align-items:center;gap:1rem}

/* Dark/Light Toggle */
.theme-toggle-wrap{display:flex;align-items:center;gap:0.45rem}
.theme-toggle-wrap svg{width:13px;height:13px;stroke:var(--text-muted);fill:none;stroke-width:2;flex-shrink:0;transition:stroke var(--transition)}
.theme-toggle{
  width:42px;height:22px;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:100px;
  cursor:pointer;
  position:relative;
  transition:background var(--transition);
  flex-shrink:0;
}
.theme-toggle::before{
  content:'';position:absolute;top:3px;left:3px;
  width:14px;height:14px;border-radius:50%;
  background:var(--gold);
  transition:transform var(--transition),background var(--transition);
  box-shadow:0 1px 3px rgba(0,0,0,0.4);
}
[data-theme="light"] .theme-toggle::before{transform:translateX(20px);background:var(--accent)}

.menu-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.menu-toggle span{display:block;width:22px;height:1.5px;background:var(--text);transition:all var(--transition)}

/* ── HERO ───────────────────────────────────────────────────── */
/*
  ASSET REQUIRED:
  Hero video → assets/video/hero-bg.mp4
  License: https://elements.envato.com/falling-petals-red-rose-on-a-black-background-PX3XZMZ
*/
.hero{
  min-height:100vh;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding-top:70px;
}
.hero__video-wrap{
  position:absolute;inset:0;overflow:hidden;
  pointer-events:none;
}
.hero__video-wrap video{
  width:100%;height:100%;
  object-fit:cover;
  opacity:0.18;
  mix-blend-mode:screen;
}
.hero__overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(135deg, rgba(200,54,90,0.12) 0%, transparent 50%),
    linear-gradient(to top, var(--bg) 0%, rgba(8,7,9,0.6) 40%, transparent 100%);
}
/*
  TEXTURE OVERLAY:
  Leather texture → assets/img/leather-texture.jpg
  License: https://elements.envato.com/black-leather-textures-562GHX4
*/
.hero__texture{
  position:absolute;inset:0;
  background-image:url('assets/img/leather-texture.jpg');
  background-size:cover;
  opacity:0.04;
  mix-blend-mode:overlay;
  pointer-events:none;
}
.hero__content{
  position:relative;z-index:2;
  max-width:680px;
}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:0.8rem;
  margin-bottom:1.8rem;
}
.hero__eyebrow::before{
  content:'';
  display:block;width:32px;height:1px;
  background:var(--gold);
}
.hero__title{
  font-size:clamp(3.2rem,8vw,6.5rem);
  font-weight:700;
  line-height:1.0;
  margin-bottom:1.8rem;
}
.hero__title em{
  font-style:italic;
  font-family:var(--font-accent);
  font-weight:300;
  color:var(--accent-2);
  display:block;
}
.hero__subtitle{
  font-size:1.05rem;
  color:var(--text-muted);
  max-width:460px;
  margin-bottom:2.5rem;
  line-height:1.8;
}
.hero__scroll{
  position:absolute;
  bottom:2.5rem;left:50%;transform:translateX(-50%);
  z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:0.5rem;
}
.hero__scroll span{
  font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--text-faint);
}
.hero__scroll-line{
  width:1px;height:40px;
  background:linear-gradient(to bottom,var(--gold),transparent);
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:0.6rem;
  padding:0.85rem 2rem;
  font-family:var(--font-body);
  font-size:0.72rem;font-weight:600;
  letter-spacing:0.16em;text-transform:uppercase;
  border:none;cursor:pointer;
  transition:all var(--transition);
  text-decoration:none;
  border-radius:var(--radius);
  position:relative;overflow:hidden;
}
.btn::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.08);opacity:0;transition:opacity var(--transition)}
.btn:hover::before{opacity:1}

.btn--primary{background:var(--accent);color:#fff;box-shadow:0 4px 24px var(--accent-glow)}
.btn--primary:hover{background:var(--accent-2);color:#fff;transform:translateY(-2px);box-shadow:0 8px 32px var(--accent-glow)}

.btn--gold{background:var(--gold);color:#0a090c;box-shadow:0 4px 20px var(--gold-glow)}
.btn--gold:hover{background:var(--gold-light);color:#0a090c;transform:translateY(-2px)}

.btn--outline{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn--outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}

.btn--ghost{background:transparent;color:var(--text-muted);padding-left:0;padding-right:0;letter-spacing:0.1em}
.btn--ghost:hover{color:var(--text)}
.btn--ghost svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}

.btn-group{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}

/* ── CATEGORY CARDS ─────────────────────────────────────────── */
/*
  ASSETS REQUIRED (one per category card):
  Lingerie  → assets/img/cat-lingerie.jpg  https://elements.envato.com/tender-woman-in-lingerie-D7WZRX3
  Leather   → assets/img/cat-leather.jpg   https://elements.envato.com/black-leather-fabric-macro-footage-concept-of-text-XNJRGWF
  Novelties → assets/img/cat-novelties.jpg https://elements.envato.com/photos/dark+background
  Gifts     → assets/img/cat-gifts.jpg     https://elements.envato.com/photos/black+background
*/
.category-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:2px;
  background:var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.category-card{
  position:relative;
  min-height:340px;
  overflow:hidden;
  cursor:pointer;
  background:var(--bg-3);
}
.category-card__bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform 0.7s ease,opacity 0.4s ease;
  opacity:0.4;
}
.category-card:hover .category-card__bg{transform:scale(1.06);opacity:0.55}

.category-card__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,7,9,0.92) 0%,rgba(8,7,9,0.3) 60%,transparent 100%);
}
.category-card:hover .category-card__overlay{
  background:linear-gradient(to top,rgba(8,7,9,0.95) 0%,rgba(200,54,90,0.15) 100%);
}
.category-card__content{
  position:absolute;bottom:0;left:0;right:0;
  padding:2rem;
  z-index:2;
}
.category-card__content::before{
  content:'';
  display:block;
  width:0;height:1px;
  background:linear-gradient(90deg,var(--accent),var(--gold));
  margin-bottom:1rem;
  transition:width 0.4s ease;
}
.category-card:hover .category-card__content::before{width:40px}

.category-card h3{
  font-size:1.5rem;
  margin-bottom:0.4rem;
  transition:color var(--transition);
}
.category-card:hover h3{color:var(--gold-light)}

.category-card p{
  font-size:0.85rem;
  color:var(--text-faint);
  margin:0;
  max-height:0;overflow:hidden;
  transition:max-height 0.4s ease,color 0.3s ease;
}
.category-card:hover p{max-height:60px;color:var(--text-muted)}

.category-card__tag{
  position:absolute;top:1.5rem;right:1.5rem;
  font-size:0.6rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;
  background:var(--accent);color:#fff;
  padding:0.3rem 0.7rem;border-radius:2px;
  opacity:0;transform:translateY(-4px);
  transition:all var(--transition);
  z-index:2;
}
.category-card:hover .category-card__tag{opacity:1;transform:translateY(0)}

/* ── FEATURED BANNER ────────────────────────────────────────── */
/*
  ASSET REQUIRED:
  Featured background → assets/img/featured-bg.jpg
  License: https://elements.envato.com/luxury-leather-textures-CJEL8K
*/
.featured-banner{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:var(--surface);
  border:1px solid var(--border-gold);
  min-height:480px;
  display:grid;
  grid-template-columns:1fr 1fr;
}
.featured-banner__bg{
  position:absolute;inset:0;
  background-image:url('assets/img/featured-bg.jpg');
  background-size:cover;background-position:center;
  opacity:0.08;
}
.featured-banner__content{
  padding:clamp(3rem,5vw,4.5rem);
  display:flex;flex-direction:column;justify-content:center;
  position:relative;z-index:2;
}
.featured-banner__badge{
  display:inline-block;
  background:transparent;
  border:1px solid var(--gold);
  color:var(--gold);
  font-size:0.62rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;
  padding:0.3rem 0.8rem;border-radius:2px;
  margin-bottom:1.5rem;width:fit-content;
}
.featured-banner__image{
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.featured-banner__image img{
  width:100%;height:100%;
  object-fit:cover;
  opacity:0.6;
  transition:opacity 0.4s,transform 0.6s;
}
.featured-banner:hover .featured-banner__image img{opacity:0.75;transform:scale(1.03)}
.featured-banner__image::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,var(--surface) 0%,transparent 30%);
}

/* ── INFO STRIP ─────────────────────────────────────────────── */
.info-strip{
  background:var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.info-strip__grid{display:grid;grid-template-columns:repeat(4,1fr)}
.info-strip__item{
  display:flex;align-items:center;gap:1rem;
  padding:1.6rem 2rem;
  border-right:1px solid var(--border);
  transition:background var(--transition);
}
.info-strip__item:last-child{border-right:none}
.info-strip__item:hover{background:var(--surface-2)}
.info-strip__icon{width:34px;height:34px;flex-shrink:0;color:var(--gold)}
.info-strip__icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.5}
.info-strip__text strong{display:block;font-size:0.82rem;font-weight:600;color:var(--text);margin-bottom:0.1rem}
.info-strip__text span{font-size:0.73rem;color:var(--text-muted)}

/* ── MARQUEE ────────────────────────────────────────────────── */
.marquee-strip{background:var(--accent);padding:0.75rem 0;overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-flex;animation:marquee 25s linear infinite}
.marquee-item{
  font-size:0.68rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;
  color:rgba(255,255,255,0.9);padding:0 2rem;
}
.marquee-item::before{content:'✦';margin-right:2rem;opacity:0.5}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── SECTION HEADER ─────────────────────────────────────────── */
.section-header{margin-bottom:clamp(2.5rem,5vw,4rem)}
.section-header--center{text-align:center}
.section-header--center .section-divider{margin:1rem auto 0}
.section-header h2{margin:0.5rem 0 0.8rem}
.section-divider{
  width:40px;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--gold));
  margin-top:1rem;
}

/* ── TESTIMONIALS ───────────────────────────────────────────── */
.testimonials{background:var(--bg-2)}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.testimonial-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:2rem;position:relative;
  transition:border-color var(--transition),transform var(--transition);
}
.testimonial-card:hover{border-color:var(--border-gold);transform:translateY(-3px)}
.testimonial-card::before{
  content:'"';
  position:absolute;top:1rem;right:1.5rem;
  font-family:var(--font-display);font-size:4.5rem;line-height:1;
  color:var(--accent);opacity:0.1;
}
.testimonial-card__stars{display:flex;gap:2px;margin-bottom:1rem}
.testimonial-card__stars span{color:var(--gold);font-size:0.85rem}
.testimonial-card__text{
  font-family:var(--font-accent);font-style:italic;font-size:1.05rem;
  color:var(--text);margin-bottom:1.2rem;line-height:1.65;
}
.testimonial-card__author{
  font-size:0.72rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--text-faint);
}

/* ── SHOP (Ecwid) ───────────────────────────────────────────── */
#ecwid-shop-wrapper{
  min-height:400px;
  background:var(--bg-2);
  border-radius:var(--radius-lg);
  padding:2rem;
  border:1px solid var(--border);
}

/* ── AGE GATE ───────────────────────────────────────────────── */
#age-gate-overlay{
  position:fixed;inset:0;background:#000;
  z-index:99999;
  display:flex;align-items:center;justify-content:center;
  padding:2rem;
}
.age-gate{max-width:520px;width:100%;text-align:center}
.age-gate__logo{margin:0 auto 2.5rem}
.age-gate__logo span{
  font-family:var(--font-display);font-size:2rem;font-weight:700;
  color:var(--text);letter-spacing:-0.03em;
}
.age-gate__logo span em{color:var(--accent);font-style:normal}
.age-gate__divider{width:40px;height:1px;background:var(--gold);margin:0 auto 2rem}
.age-gate h2{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:0.8rem}
.age-gate p{font-size:0.92rem;color:var(--text-muted);margin-bottom:2.5rem;max-width:380px;margin-left:auto;margin-right:auto}
.age-gate__buttons{display:flex;gap:1rem;justify-content:center;margin-bottom:1.5rem}
.age-gate__note{font-size:0.7rem;color:var(--text-faint);letter-spacing:0.04em}

/* ── FOOTER ─────────────────────────────────────────────────── */
/*
  ASSET REQUIRED (optional texture):
  Footer texture → assets/img/footer-texture.jpg
  License: https://elements.envato.com/20-black-leather-textures-hq-7HDVD86
*/
#site-footer{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  padding:clamp(3rem,6vw,5rem) 0 2rem;
  position:relative;overflow:hidden;
}
#site-footer::before{
  content:'';position:absolute;inset:0;
  /* Footer texture set via Customizer — injected inline by PHP */
  background-size:cover;
  opacity:0.03;pointer-events:none;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;margin-bottom:3rem;
  position:relative;z-index:1;
}
.footer-brand__logo{
  font-family:var(--font-display);font-size:1.4rem;font-weight:700;
  color:var(--text);display:block;margin-bottom:0.9rem;letter-spacing:-0.02em;
}
.footer-brand__logo em{color:var(--accent);font-style:normal}
.footer-brand p{font-size:0.85rem;max-width:270px;margin-bottom:1.5rem}
.footer-social{display:flex;gap:0.6rem}
.footer-social a{
  width:34px;height:34px;border:1px solid var(--border);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);transition:all var(--transition);
}
.footer-social a:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.footer-social svg{width:15px;height:15px;fill:currentColor}
.footer-col h4{
  font-size:0.68rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--text-muted);margin-bottom:1.2rem;
}
.footer-col ul li{margin-bottom:0.65rem}
.footer-col ul li a{font-size:0.85rem;color:var(--text-faint);transition:color var(--transition)}
.footer-col ul li a:hover{color:var(--text)}
.footer-bottom{
  padding-top:2rem;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1rem;
  position:relative;z-index:1;
}
.footer-bottom p{font-size:0.75rem;color:var(--text-faint);margin:0}
.footer-bottom a{color:var(--text-faint)}
.footer-bottom a:hover{color:var(--accent)}

/* ── PAGE CONTENT ───────────────────────────────────────────── */
.page-content{padding-top:calc(70px + 3rem);padding-bottom:5rem;min-height:70vh}
.entry-title{
  font-size:clamp(2rem,5vw,4rem);
  margin-bottom:2rem;padding-bottom:1.5rem;
  border-bottom:1px solid var(--border);
}
.entry-content{font-size:1.05rem;line-height:1.85;max-width:780px}

/* ── BREADCRUMBS ────────────────────────────────────────────── */
.breadcrumb{display:flex;align-items:center;gap:0.5rem;font-size:0.75rem;color:var(--text-faint);margin-bottom:2rem}
.breadcrumb a{color:var(--text-faint)}
.breadcrumb a:hover{color:var(--text)}
.breadcrumb__sep{opacity:0.4}

/* ── REVEAL ANIMATIONS ──────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:0.1s}
.reveal-delay-2{transition-delay:0.2s}
.reveal-delay-3{transition-delay:0.3s}
.reveal-delay-4{transition-delay:0.4s}

/* ── ELEMENTOR BRIDGE ───────────────────────────────────────── */
.elementor-widget-heading .elementor-heading-title{font-family:var(--font-display);letter-spacing:-0.025em}
.elementor-widget-text-editor{color:var(--text-muted);font-family:var(--font-body)}
.elementor-section,.e-con{transition:background var(--transition)}
.elementor-button,.elementor-button-wrapper .elementor-button{
  font-family:var(--font-body) !important;
  font-size:0.72rem !important;
  letter-spacing:0.16em !important;
  text-transform:uppercase !important;
  border-radius:var(--radius) !important;
}
.elementor-widget-video .elementor-wrapper{border-radius:var(--radius-lg);overflow:hidden}
/* Allow Elementor Video widget backgrounds */
.elementor-background-video-container{opacity:0.25}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
  .featured-banner{grid-template-columns:1fr}
  .featured-banner__image{min-height:280px}
  .info-strip__grid{grid-template-columns:repeat(2,1fr)}
  .info-strip__item:nth-child(2){border-right:none}
  .info-strip__item:nth-child(3){border-right:1px solid var(--border)}
  .category-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .primary-menu{display:none}
  .primary-menu.open{
    display:flex;flex-direction:column;
    position:fixed;top:70px;left:0;right:0;
    background:var(--bg);padding:2rem;gap:1.5rem;
    border-bottom:1px solid var(--border);z-index:999;
  }
  .menu-toggle{display:flex}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .category-grid{grid-template-columns:1fr}
  .category-card{min-height:260px}
  .age-gate__buttons{flex-direction:column;align-items:center}
}
@media(max-width:480px){
  .info-strip__grid{grid-template-columns:1fr}
  .info-strip__item{border-right:none;border-bottom:1px solid var(--border)}
  .info-strip__item:last-child{border-bottom:none}
  .info-strip__item:nth-child(3){border-right:none}
  .footer-bottom{flex-direction:column;text-align:center}
}

/* ── ELEMENTOR FULL WIDTH FIXES ──────────────────────────────── */
/* Hide WordPress page title when Elementor is building the page */
.elementor-page .entry-title,
.elementor-page .page-header,
.elementor-page h1.entry-title {
  display: none !important;
}

/* Remove default page padding that constrains Elementor */
.elementor-page .page-content,
.elementor-page .entry-content {
  padding: 0 !important;
  max-width: none !important;
}

/* Force Elementor sections to go truly full width */
.elementor-section.elementor-section-full_width {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Ensure inner containers respect 1400px max */
.elementor-section .elementor-container {
  max-width: 1400px !important;
}

/* Remove top padding gap caused by page title area */
.elementor-page #main-content {
  padding-top: 0 !important;
}

/* Fix Elementor canvas blank template — remove body padding */
body.elementor-template-canvas {
  padding: 0 !important;
}
