/*
Theme Name:   LuvNoire Child
Theme URI:    https://luvnoire.de
Description:  LuvNoire – Astra Child Theme. Dark Luxury Wedding Stationery.
Author:       Evovance Studio
Template:     astra
Version:      1.0.0
Text Domain:  luvnoire-child
*/
/* Deaktiviert den Astra-Breiten-Zwang */
.site-content .ast-container {
    max-width: 100% !important;
    padding: 0 !important;
}
.ast-separate-container .ast-article-single {
    padding: 0 !important;
    background-color: transparent !important;
}
/* ─────────────────────────────────────────
   BRAND TOKENS
───────────────────────────────────────── */
:root {
  --ln-black:       #080808;
  --ln-black-soft:  #111111;
  --ln-black-card:  #141414;
  --ln-gold:        #D4A830;
  --ln-gold-dim:    rgba(212, 168, 48, 0.12);
  --ln-gold-mid:    rgba(212, 168, 48, 0.35);
  --ln-rose:        #c8956c;
  --ln-creme:       #f5f0e8;
  --ln-creme-muted: rgba(245, 240, 232, 0.55);
  --ln-border:      1px solid rgba(212, 168, 48, 0.15);

  --ln-font-display: 'Cinzel', serif;
  --ln-font-body:    'Cormorant Garamond', serif;
  --ln-font-ui:      'Raleway', sans-serif;

  --ln-transition: 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

/* ─────────────────────────────────────────
   GLOBAL BASE
───────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  background-color: var(--ln-black) !important;
  color: var(--ln-creme) !important;
  font-family: var(--ln-font-ui) !important;
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
}

/* Carbon texture overlay */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    repeating-linear-gradient(45deg,  rgba(255,255,255,0.01) 0px, rgba(255,255,255,0.01) 1px, transparent 1px, transparent 4px),
    repeating-linear-gradient(-45deg, rgba(255,255,255,0.01) 0px, rgba(255,255,255,0.01) 1px, transparent 1px, transparent 4px);
  background-size: 8px 8px;
  pointer-events: none;
  z-index: 0;
}
body::before { opacity: 0; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--ln-gold); text-decoration: none; transition: opacity var(--ln-transition); }
a:hover { opacity: 0.75; }

/* ─────────────────────────────────────────
   TYPOGRAPHY
───────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--ln-font-body) !important;
  font-weight: 300 !important;
  color: var(--ln-creme) !important;
  line-height: 1.1 !important;
}
h1 { font-size: clamp(44px, 6vw, 80px); }
h2 { font-size: clamp(32px, 4vw, 56px); }
h3 { font-size: clamp(22px, 3vw, 36px); }

p {
  font-family: var(--ln-font-ui) !important;
  color: var(--ln-creme-muted) !important;
  font-size: 14px;
  line-height: 1.9;
}

em, i { color: var(--ln-gold); font-style: italic; }

/* Section label */
.ln-label {
  font-family: var(--ln-font-display);
  font-size: 10px;
  letter-spacing: 6px;
  text-transform: uppercase;
  color: var(--ln-gold);
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}
.ln-label::before {
  content: '';
  width: 28px;
  height: 1px;
  background: var(--ln-gold);
  flex-shrink: 0;
}

/* ─────────────────────────────────────────
   ASTRA HEADER OVERRIDE
───────────────────────────────────────── */
#masthead,
.site-header,
.main-header-bar {
  background: rgba(8, 8, 8, 0.96) !important;
  border-bottom: var(--ln-border) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  min-height: 68px !important;
}

.site-title a {
  font-family: var(--ln-font-display) !important;
  font-size: 16px !important;
  letter-spacing: 5px !important;
  color: var(--ln-gold) !important;
  text-transform: uppercase !important;
}

/* Nav links */
.main-header-menu .menu-item > a {
  font-family: var(--ln-font-display) !important;
  font-size: 10px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--ln-creme) !important;
  opacity: 0.65;
  transition: opacity var(--ln-transition), color var(--ln-transition) !important;
}
.main-header-menu .menu-item > a:hover,
.main-header-menu .current-menu-item > a {
  opacity: 1 !important;
  color: var(--ln-gold) !important;
}

/* ─────────────────────────────────────────
   BUTTONS
───────────────────────────────────────── */
.ln-btn {
  display: inline-block;
  font-family: var(--ln-font-display);
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 15px 40px;
  background: linear-gradient(135deg, var(--ln-gold) 0%, #b8921f 100%);
  color: var(--ln-black) !important;
  border: none;
  border-radius: 0;
  transition: all var(--ln-transition);
  cursor: pointer;
}
.ln-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(212, 168, 48, 0.28);
  opacity: 1 !important;
}

.ln-btn-ghost {
  display: inline-block;
  font-family: var(--ln-font-display);
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  padding: 15px 40px;
  background: transparent;
  color: var(--ln-creme) !important;
  border: 1px solid var(--ln-gold-mid);
  border-radius: 0;
  transition: all var(--ln-transition);
  cursor: pointer;
}
.ln-btn-ghost:hover {
  background: var(--ln-gold-dim);
  border-color: var(--ln-gold);
  opacity: 1 !important;
}

/* ─────────────────────────────────────────
   WOOCOMMERCE OVERRIDES
───────────────────────────────────────── */
.woocommerce,
.woocommerce-page {
  background: var(--ln-black) !important;
}

.woocommerce-breadcrumb { display: none !important; }

.woocommerce .price,
.woocommerce span.price {
  font-family: var(--ln-font-body) !important;
  color: var(--ln-gold) !important;
  font-size: 32px !important;
  font-weight: 300 !important;
}

/* Buttons */
.woocommerce .single_add_to_cart_button,
.woocommerce button.button,
.woocommerce a.button {
  background: linear-gradient(135deg, var(--ln-gold) 0%, #b8921f 100%) !important;
  color: var(--ln-black) !important;
  font-family: var(--ln-font-display) !important;
  font-size: 10px !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  border-radius: 0 !important;
  padding: 16px 40px !important;
  border: none !important;
  transition: all var(--ln-transition) !important;
}
.woocommerce .single_add_to_cart_button:hover,
.woocommerce button.button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 40px rgba(212, 168, 48, 0.28) !important;
}

/* Hide quantity selector – Atelier feel */
.woocommerce .quantity { display: none !important; }

/* Product cards */
.woocommerce ul.products li.product {
  background: var(--ln-black-card) !important;
  border: var(--ln-border) !important;
  padding: 32px 24px !important;
  transition: border-color var(--ln-transition) !important;
}
.woocommerce ul.products li.product:hover {
  border-color: var(--ln-gold-mid) !important;
}

/* Form fields */
.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce textarea,
.woocommerce select {
  background: var(--ln-black-soft) !important;
  border: var(--ln-border) !important;
  color: var(--ln-creme) !important;
  border-radius: 0 !important;
  font-family: var(--ln-font-ui) !important;
  padding: 14px 16px !important;
}
.woocommerce input:focus,
.woocommerce textarea:focus {
  border-color: var(--ln-gold) !important;
  outline: none !important;
  box-shadow: 0 0 0 1px var(--ln-gold) !important;
}

/* ─────────────────────────────────────────
   SCROLL FADE-IN (triggered via JS)
───────────────────────────────────────── */
.ln-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}
.ln-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.ln-reveal-delay-1 { transition-delay: 0.1s; }
.ln-reveal-delay-2 { transition-delay: 0.2s; }
.ln-reveal-delay-3 { transition-delay: 0.3s; }
.ln-reveal-delay-4 { transition-delay: 0.4s; }

/* ─────────────────────────────────────────
   UTILITY
───────────────────────────────────────── */
.ln-section { padding: 100px 60px; position: relative; }
.ln-container { max-width: 1280px; margin: 0 auto; }
.ln-gold  { color: var(--ln-gold)  !important; }
.ln-muted { color: var(--ln-creme-muted) !important; }

.ln-divider {
  display: flex;
  align-items: center;
  gap: 24px;
  margin: 80px 0;
}
.ln-divider-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(212,168,48,0.3));
}
.ln-divider-line.rev {
  background: linear-gradient(90deg, rgba(212,168,48,0.3), transparent);
}
.ln-divider-icon {
  font-family: var(--ln-font-display);
  font-size: 15px;
  letter-spacing: 5px;
  color: var(--ln-gold);
  text-transform: uppercase;
}

/* Corner frame decoration */
.ln-corner-frame { position: relative; }
.ln-corner-frame::before,
.ln-corner-frame::after {
  content: '';
  position: absolute;
  width: 22px; height: 22px;
}
.ln-corner-frame::before { top: 0;    left: 0;  border-top: 1px solid var(--ln-gold); border-left: 1px solid var(--ln-gold); }
.ln-corner-frame::after  { bottom: 0; right: 0; border-bottom: 1px solid var(--ln-gold); border-right: 1px solid var(--ln-gold); }

/* Footer */
#colophon, .site-footer {
  background: var(--ln-black) !important;
  border-top: var(--ln-border) !important;
}
.site-footer .ast-footer-copyright {
  font-family: var(--ln-font-ui) !important;
  font-size: 10px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--ln-creme-muted) !important;
}

@media (max-width: 768px) {
  .ln-section { padding: 60px 24px; }
}
/* Startseite: Carbon-Overlay aus (klarer Background) */
body.home::before{
  content: none !important;
  display: none !important;
}

/* Falls irgendwo ein Home-Overlay per ::after existiert: ebenfalls aus */
body.home::after{
  content: none !important;
  display: none !important;
}