/*
Theme Name: Lee Williams Music
Theme URI: https://leewilliams.live
Template: kadence
Author: Lee Williams
Description: Kadence child theme for Lee Williams Music. Bold dark music-forward design with green and blue palette.
Version: 1.4.7
Requires at least: 6.0
Tested up to: 6.7
WC requires at least: 8.0
License: GNU General Public License v2 or later
Text Domain: lwm
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --lwm-dark:        #050d10;
  --lwm-dark-2:      #0a1a20;
  --lwm-dark-3:      #0f2535;
  --lwm-green:       #00e676;
  --lwm-green-dim:   #00c15e;
  --lwm-blue:        #00b4d8;
  --lwm-blue-dim:    #0077a8;
  --lwm-white:       #f0fafa;
  --lwm-muted:       #7ab8c4;
  --lwm-border:      rgba(0,180,216,0.2);
  --lwm-radius:      6px;
  --lwm-radius-lg:   14px;
  --lwm-transition:  0.25s ease;
  --lwm-shadow:      0 4px 24px rgba(0,0,0,0.5);
  /* Centered midline layout */
  --lwm-content-max: 1100px;
  --lwm-content-pad: clamp(2rem, 6vw, 5rem);
  --lwm-section-pad-y: 4.5rem;
  --lwm-section-gap: 40px;
}

/* ============================================================
   GLOBAL BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--lwm-dark) !important;
  color: var(--lwm-white) !important;
  overflow-x: hidden;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

a { color: var(--lwm-blue); transition: color var(--lwm-transition); }
a:hover { color: var(--lwm-green); }

h1,h2,h3,h4,h5,h6 {
  font-family: 'Bebas Neue', sans-serif !important;
  letter-spacing: 0.04em;
  line-height: 1.1;
  text-transform: uppercase;
  color: var(--lwm-white);
}

p { color: var(--lwm-white); margin-bottom: 1.2rem; }

img { max-width: 100%; height: auto; }

/* ============================================================
   KADENCE GLOBAL OVERRIDES
   ============================================================ */
.site {
  background: var(--lwm-dark) !important;
}

.site-content {
  background: var(--lwm-dark) !important;
}

/* Content max width — allow full-width breakout for sections */
.wp-site-blocks { max-width: 100%; }
.kb-section-dir-row,
.kb-row-layout-wrap {
  max-width: 100%;
}

/* ============================================================
   HEADER
   ============================================================ */
#masthead,
.site-header,
.kadence-sticky-header {
  background: transparent !important;
  transition: all var(--lwm-transition) !important;
}

.kadence-sticky-header.kadence-fixed-header {
  background: rgba(5,13,16,0.95) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-bottom: 1px solid var(--lwm-border) !important;
}

/* Site title / logo */
.site-branding .site-title a,
.kadence-site-branding .site-title a {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.8rem !important;
  letter-spacing: 0.08em !important;
  color: var(--lwm-white) !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
}

/* Primary nav */
#site-navigation .nav-menu > li > a,
.kadence-navigation .menu > li > a {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--lwm-muted) !important;
  padding: 0.5rem 1rem !important;
  transition: color var(--lwm-transition) !important;
  position: relative;
}

#site-navigation .nav-menu > li > a:hover,
.kadence-navigation .menu > li > a:hover,
#site-navigation .nav-menu > li.current-menu-item > a {
  color: var(--lwm-white) !important;
}

/* Book Me CTA pill in nav */
#site-navigation .nav-menu > li.menu-item-book-me > a,
.kadence-navigation .menu > li.nav-cta > a {
  background: var(--lwm-green) !important;
  color: #fff !important;
  border-radius: var(--lwm-radius) !important;
  padding: 0.5rem 1.2rem !important;
}

/* ============================================================
   EDITABLE CUSTOM HEADER
   - Header image: Appearance > Customize > Header Image
   - Header HTML: Header Builder > add "HTML" element
   ============================================================ */

/* Custom header image — full-width banner above nav */
.lwm-custom-header {
  display: block;
  width: 100%;
  overflow: hidden;
  background: var(--lwm-dark-2);
  border-bottom: 1px solid var(--lwm-border);
}
.lwm-custom-header-link {
  display: block;
  line-height: 0;
}
.lwm-custom-header-img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* Kadence Header HTML — editable text in header (Header Builder > HTML) */
.header-html,
.header-html .header-html-inner {
  font-family: 'Space Mono', monospace !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--lwm-muted) !important;
}
.header-html a {
  color: var(--lwm-blue) !important;
  transition: color var(--lwm-transition);
}
.header-html a:hover {
  color: var(--lwm-green) !important;
}

/* Header top row (announcement bar) — matches site design */
.site-top-header-wrap {
  background: var(--lwm-dark-2) !important;
  border-bottom: 1px solid var(--lwm-border) !important;
}
.site-top-header-wrap,
.site-top-header-wrap * {
  color: var(--lwm-muted) !important;
}
.site-top-header-wrap a:hover {
  color: var(--lwm-green) !important;
}

/* ============================================================
   UTILITY CLASSES
   (apply via Advanced > CSS Classes in Kadence block settings)
   ============================================================ */
.lwm-section-label {
  display: inline-block;
  font-family: 'Space Mono', monospace !important;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--lwm-green);
  border-left: 3px solid var(--lwm-green);
  padding-left: 0.75rem;
  margin-bottom: 1rem;
}

.lwm-divider {
  width: 60px;
  height: 3px;
  background: linear-gradient(90deg, var(--lwm-green), var(--lwm-blue));
  margin: 1.5rem auto;
  border: none;
}

.lwm-divider-center { margin-left: auto; margin-right: auto; }

.lwm-text-green { color: var(--lwm-green) !important; }
.lwm-text-blue  { color: var(--lwm-blue) !important; }
.lwm-text-muted { color: var(--lwm-muted) !important; }
.lwm-text-outline {
  -webkit-text-stroke: 2px var(--lwm-green);
  color: transparent !important;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.kb-btn,
.kadence-button,
.wp-block-button__link {
  font-family: 'Bebas Neue', sans-serif !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  border-radius: var(--lwm-radius) !important;
  transition: all var(--lwm-transition) !important;
}

/* Primary green */
.lwm-btn-primary,
.lwm-btn-primary .kb-btn,
.lwm-btn-primary .wp-block-button__link {
  background: var(--lwm-green) !important;
  color: #fff !important;
  border: 2px solid var(--lwm-green) !important;
}

.lwm-btn-primary:hover .kb-btn,
.lwm-btn-primary .wp-block-button__link:hover {
  background: transparent !important;
  color: var(--lwm-green) !important;
}

/* Outline blue */
.lwm-btn-blue,
.lwm-btn-blue .kb-btn,
.lwm-btn-blue .wp-block-button__link {
  background: transparent !important;
  color: var(--lwm-blue) !important;
  border: 2px solid var(--lwm-blue) !important;
}

.lwm-btn-blue .kb-btn:hover,
.lwm-btn-blue .wp-block-button__link:hover {
  background: var(--lwm-blue) !important;
  color: var(--lwm-dark) !important;
}

/* Ghost */
.lwm-btn-ghost .kb-btn,
.lwm-btn-ghost .wp-block-button__link {
  background: transparent !important;
  color: var(--lwm-white) !important;
  border: 2px solid rgba(255,255,255,0.3) !important;
}

.lwm-btn-ghost .kb-btn:hover,
.lwm-btn-ghost .wp-block-button__link:hover {
  border-color: var(--lwm-green) !important;
  color: var(--lwm-green) !important;
}

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

.lwm-hero .kb-row-layout-wrap,
.lwm-hero .kb-row-layout-container {
  position: relative;
  z-index: 2;
  width: 100%;
}

/* Animated grid overlay */
.lwm-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,180,216,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,180,216,0.05) 1px, transparent 1px);
  background-size: 60px 60px;
  animation: lwmGrid 20s linear infinite;
  z-index: 1;
  pointer-events: none;
}

/* Blue glow bottom right */
.lwm-hero::after {
  content: '';
  position: absolute;
  bottom: -100px;
  right: -100px;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(0,77,128,0.35), transparent 70%);
  z-index: 0;
  pointer-events: none;
}

@keyframes lwmGrid {
  from { background-position: 0 0; }
  to   { background-position: 60px 60px; }
}

.lwm-hero-eyebrow {
  font-family: 'Space Mono', monospace !important;
  font-size: 0.8rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--lwm-green);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.lwm-hero-eyebrow::before {
  content: '';
  display: inline-block;
  width: 40px;
  height: 2px;
  background: var(--lwm-green);
  flex-shrink: 0;
}

.lwm-hero-title {
  font-size: clamp(3.5rem, 10vw, 8rem) !important;
  line-height: 0.95 !important;
  margin-bottom: 1.5rem !important;
}

.lwm-hero-title .lwm-outline {
  -webkit-text-stroke: 2px var(--lwm-green);
  color: transparent;
  display: block;
}

.lwm-hero-subtitle {
  font-size: 1.15rem !important;
  color: var(--lwm-muted) !important;
  max-width: 500px;
  margin-bottom: 2.5rem !important;
  line-height: 1.7 !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 400 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.lwm-instrument-tags {
  display: flex;
  gap: calc(0.75rem + 15px);
  flex-wrap: wrap;
  margin-top: 2rem;
}

.lwm-instrument-tag {
  font-family: 'Space Mono', monospace;
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--lwm-white);
  border: 1px solid var(--lwm-green);
  padding: 0.4rem 0.8rem;
  border-radius: 20px;
  background: rgba(0,230,118,0.05);
}

.lwm-scroll-indicator {
  display: none !important; /* Removed per request — not needed */
}

.lwm-scroll-line {
  width: 1px;
  height: 50px;
  background: linear-gradient(to bottom, var(--lwm-green), transparent);
  animation: lwmScrollBounce 2s ease-in-out infinite;
}

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

/* ============================================================
   TICKER
   ============================================================ */
.lwm-ticker-row .kb-row-layout-container,
.lwm-ticker-row .kb-row-column-wrap {
  max-width: none !important;
  padding: 0 !important;
}

.lwm-ticker {
  background: var(--lwm-green);
  overflow: hidden;
  padding: 0.6rem 0;
  width: 100%;
  margin-bottom: var(--lwm-section-gap);
}

.lwm-ticker-track {
  display: flex;
  white-space: nowrap;
  animation: lwmTicker 30s linear infinite;
}

.lwm-ticker-track span {
  display: inline-flex;
  align-items: center;
  gap: calc(1.5rem + 15px);
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--lwm-dark);
  padding-right: calc(3rem + 15px);
}

.lwm-ticker-track span::after { content: '♪'; }

@keyframes lwmTicker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ============================================================
   SECTION BACKGROUNDS (apply as CSS class on Kadence Row)
   ============================================================ */
.lwm-bg-dark   { background: var(--lwm-dark) !important; }
.lwm-bg-dark-2 { background: var(--lwm-dark-2) !important; }
.lwm-bg-dark-3 { background: var(--lwm-dark-3) !important; }

/* Glow accents */
.lwm-glow-green::before {
  content: '';
  position: absolute;
  top: -100px; right: -100px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(0,230,118,0.06), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.lwm-glow-blue::after {
  content: '';
  position: absolute;
  bottom: -200px; left: -200px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(0,180,216,0.05), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

/* ============================================================
   ALBUM CARDS
   ============================================================ */
.lwm-album-card {
  background: var(--lwm-dark-2);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius-lg);
  overflow: hidden;
  transition: transform var(--lwm-transition), box-shadow var(--lwm-transition);
}

.lwm-album-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 50px rgba(0,0,0,0.6), 0 0 0 1px var(--lwm-green);
}

.lwm-album-card img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.lwm-album-card:hover img { transform: scale(1.05); }

.lwm-album-card-body { padding: 1rem; }

.lwm-album-card-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.1rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  color: var(--lwm-white) !important;
  margin-bottom: 0.3rem !important;
}

.lwm-album-card-year {
  font-family: 'Space Mono', monospace;
  font-size: 0.7rem;
  color: var(--lwm-green);
  letter-spacing: 0.1em;
  margin-bottom: 0.75rem;
}

.lwm-album-links {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.lwm-album-link {
  font-family: 'Space Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--lwm-blue);
  border: 1px solid rgba(0,180,216,0.3);
  padding: 0.2rem 0.5rem;
  border-radius: 3px;
  text-decoration: none;
  transition: all var(--lwm-transition);
}

.lwm-album-link:hover {
  background: var(--lwm-blue);
  color: var(--lwm-dark);
  border-color: var(--lwm-blue);
}

/* ============================================================
   STREAM BUTTONS (platform links)
   ============================================================ */
.lwm-stream-btns {
  display: flex;
  flex-wrap: wrap;
  gap: calc(1.25rem + 15px);
  margin: 1.5rem 0;
}

.lwm-stream-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 1.2rem;
  background: var(--lwm-dark-3);
  color: var(--lwm-white);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius);
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  transition: all var(--lwm-transition);
}

.lwm-stream-btn:hover {
  border-color: var(--lwm-green);
  color: var(--lwm-green);
  background: rgba(0,230,118,0.05);
}

.lwm-platform-spotify  { background: #1DB954 !important; color: #000 !important; border-color: #1DB954 !important; }
.lwm-platform-apple    { background: #fc3c44 !important; color: #fff !important; border-color: #fc3c44 !important; }
.lwm-platform-amazon   { background: #00A8E1 !important; color: #fff !important; border-color: #00A8E1 !important; }
.lwm-platform-youtube  { background: #FF0000 !important; color: #fff !important; border-color: #FF0000 !important; }
.lwm-platform-bandcamp { background: #1DA0C3 !important; color: #fff !important; border-color: #1DA0C3 !important; }

/* ============================================================
   SPOTIFY EMBED
   ============================================================ */
.lwm-spotify-embed {
  border-radius: var(--lwm-radius-lg);
  overflow: hidden;
  border: 1px solid var(--lwm-border);
  margin-top: 1.5rem;
}

.lwm-spotify-embed iframe { display: block; width: 100%; }

/* ============================================================
   YOUTUBE CARDS / EMBEDS
   ============================================================ */
.lwm-yt-card {
  background: var(--lwm-dark-2);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius-lg);
  overflow: hidden;
  transition: transform var(--lwm-transition), box-shadow var(--lwm-transition);
}

.lwm-yt-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 40px rgba(0,0,0,0.5);
}

.lwm-yt-embed {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}

.lwm-yt-embed iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  border: 0;
}

.lwm-yt-label {
  padding: 0.75rem 1rem;
  background: var(--lwm-dark-3);
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--lwm-white);
  border-top: 1px solid var(--lwm-border);
}

/* Filter bar */
.lwm-filter-bar {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 2.5rem;
}

.lwm-filter-btn {
  padding: 0.5rem 1.2rem;
  background: transparent;
  color: var(--lwm-muted);
  border: 1px solid var(--lwm-border);
  border-radius: 20px;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 0.9rem;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: all var(--lwm-transition);
}

.lwm-filter-btn:hover,
.lwm-filter-btn.active {
  background: var(--lwm-green);
  color: var(--lwm-dark);
  border-color: var(--lwm-green);
}

/* ============================================================
   BIO SECTION
   ============================================================ */
.lwm-bio-img {
  border-radius: var(--lwm-radius-lg);
  border: 1px solid var(--lwm-border);
  box-shadow: var(--lwm-shadow);
  width: 100%;
}

.lwm-stat-box {
  text-align: center;
  padding: 1.2rem;
  background: var(--lwm-dark-2);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius);
  min-width: 6rem;
  white-space: nowrap;
}

.lwm-stat-number {
  display: block;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 2.5rem;
  color: var(--lwm-green);
  line-height: 1;
  margin-bottom: 0.3rem;
  white-space: nowrap;
}

.lwm-stat-label {
  font-family: 'Space Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--lwm-muted);
  white-space: nowrap;
}

/* Bio buttons — flex container, right-aligned under stat boxes */
.lwm-bio-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: flex-end;
  margin-top: 0.5rem;
  width: fit-content;
  margin-left: auto;
}
@media (max-width: 768px) {
  .lwm-bio-btns {
    flex-direction: column;
    align-items: flex-end;
  }
}

/* ============================================================
   BOOKING / CONTACT FORM
   ============================================================ */
.lwm-form-field input,
.lwm-form-field textarea,
.lwm-form-field select,
.kb-field-wrap input,
.kb-field-wrap textarea,
.kb-field-wrap select,
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form textarea,
.wpcf7-form select {
  background: var(--lwm-dark-3) !important;
  color: var(--lwm-white) !important;
  border: 1px solid var(--lwm-border) !important;
  border-radius: var(--lwm-radius) !important;
  padding: 0.85rem 1rem !important;
  width: 100% !important;
  font-family: 'Inter', sans-serif !important;
}

.lwm-form-field input:focus,
.lwm-form-field textarea:focus,
.kb-field-wrap input:focus,
.kb-field-wrap textarea:focus,
.wpcf7-form input:focus,
.wpcf7-form textarea:focus {
  border-color: var(--lwm-green) !important;
  box-shadow: 0 0 0 3px rgba(0,230,118,0.1) !important;
  outline: none !important;
}

.lwm-form-field label,
.kb-field-wrap label,
.wpcf7-form label {
  font-family: 'Space Mono', monospace !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--lwm-muted) !important;
  margin-bottom: 0.4rem !important;
  display: block !important;
}

/* ============================================================
   SOCIAL ICONS
   ============================================================ */
.lwm-social-links {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-top: 1.5rem;
  justify-content: center;
}

.lwm-social-link {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius);
  color: var(--lwm-muted);
  font-size: 1rem;
  text-decoration: none;
  transition: all var(--lwm-transition);
  margin: 0 0.5rem;
}

.lwm-social-link:hover {
  border-color: var(--lwm-green);
  color: var(--lwm-green);
  background: rgba(0,230,118,0.06);
}

/* Kadence icon list override */
.kb-svg-icon-wrap { transition: all var(--lwm-transition) !important; }

/* ============================================================
   PAGE HERO BANNER (inner pages)
   ============================================================ */
.lwm-page-hero {
  padding: 9rem 0 4rem;
  background: var(--lwm-dark-2);
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--lwm-border);
}

.lwm-page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,180,216,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,180,216,0.04) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}

/* ============================================================
   WOOCOMMERCE
   ============================================================ */
.woocommerce-page,
.woocommerce {
  background: var(--lwm-dark) !important;
}

ul.products {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

ul.products li.product {
  background: var(--lwm-dark-2) !important;
  border: 1px solid var(--lwm-border) !important;
  border-radius: var(--lwm-radius-lg) !important;
  overflow: hidden !important;
  transition: transform var(--lwm-transition), box-shadow var(--lwm-transition) !important;
  margin: 0 !important;
}

ul.products li.product:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,0.5) !important;
}

ul.products li.product a img {
  width: 100% !important;
  height: 280px !important;
  object-fit: cover !important;
}

ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.3rem !important;
  text-transform: uppercase !important;
  color: var(--lwm-white) !important;
  padding: 1rem 1rem 0.25rem !important;
}

ul.products li.product .price {
  color: var(--lwm-green) !important;
  font-weight: 700 !important;
  padding: 0 1rem !important;
}

ul.products li.product .button {
  display: block !important;
  margin: 0.75rem 1rem 1rem !important;
  padding: 0.65rem 1rem !important;
  background: transparent !important;
  color: var(--lwm-blue) !important;
  border: 1px solid var(--lwm-blue) !important;
  border-radius: var(--lwm-radius) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 0.95rem !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  transition: all var(--lwm-transition) !important;
}

ul.products li.product .button:hover {
  background: var(--lwm-blue) !important;
  color: var(--lwm-dark) !important;
}

.woocommerce div.product .product_title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(2rem, 4vw, 3.5rem) !important;
  text-transform: uppercase !important;
  color: var(--lwm-white) !important;
}

.woocommerce div.product p.price {
  color: var(--lwm-green) !important;
  font-size: 2rem !important;
  font-weight: 700 !important;
}

/* Add to Cart only — does not affect WooPay, G Pay, or other express checkout */
.woocommerce button.single_add_to_cart_button {
  background: var(--lwm-green) !important;
  color: #fff !important;
  border: 2px solid var(--lwm-green) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.1rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  border-radius: var(--lwm-radius) !important;
  padding: 0.75rem 1.5rem !important;
  transition: all var(--lwm-transition) !important;
  text-align: center !important;
}

.woocommerce button.single_add_to_cart_button:hover {
  background: transparent !important;
  color: var(--lwm-green) !important;
}

.woocommerce table.shop_table {
  background: var(--lwm-dark-2) !important;
  border: 1px solid var(--lwm-border) !important;
  border-radius: var(--lwm-radius-lg) !important;
}

.woocommerce table.shop_table th {
  background: var(--lwm-dark-3) !important;
  color: var(--lwm-green) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  letter-spacing: 0.08em !important;
  border-color: var(--lwm-border) !important;
}

.woocommerce table.shop_table td {
  color: var(--lwm-white) !important;
  border-color: var(--lwm-border) !important;
}

/* ============================================================
   CART PAGE — LWM design, conversion-focused
   ============================================================ */

/* Cart page — full dark background */
body.woocommerce-cart,
body.lwm-cart-page {
  background: var(--lwm-dark) !important;
}
body.woocommerce-cart #primary,
body.woocommerce-cart .content-area,
body.lwm-cart-page #primary,
body.lwm-cart-page .content-area {
  background: transparent !important;
}

/* Kill the giant white banner & content box */
body.woocommerce-cart .entry-hero,
body.woocommerce-cart .page-hero-section,
body.lwm-cart-page .entry-hero,
body.lwm-cart-page .page-hero-section {
  display: none !important;
}
/* Remove duplicate "Cart" title in top left — keep only "Your cart" */
body.woocommerce-cart .entry .entry-header,
body.woocommerce-cart .entry-header,
body.woocommerce-cart article .entry-header,
body.lwm-cart-page .entry .entry-header,
body.lwm-cart-page .entry-header,
body.lwm-cart-page article .entry-header {
  display: none !important;
}
body.woocommerce-cart .entry,
body.woocommerce-cart .content-bg,
body.woocommerce-cart .entry-content-wrap,
body.woocommerce-cart article.entry,
body.lwm-cart-page .entry,
body.lwm-cart-page .content-bg,
body.lwm-cart-page .entry-content-wrap,
body.lwm-cart-page article.entry {
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
  border: none !important;
}
body.woocommerce-cart .entry-content,
body.woocommerce-cart .entry-content-wrap,
body.lwm-cart-page .entry-content,
body.lwm-cart-page .entry-content-wrap {
  background: transparent !important;
  padding: 0 !important;
}

/* Slim cart header — minimal, dark (replaces giant white banner) */
body.woocommerce-cart .lwm-cart-header,
body.lwm-cart-page .lwm-cart-header {
  padding: clamp(2rem, 5vw, 3rem) var(--lwm-content-pad) 1.5rem !important;
  text-align: center !important;
  background: transparent !important;
}
body.woocommerce-cart .lwm-cart-title,
body.lwm-cart-page .lwm-cart-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(1.8rem, 4vw, 2.5rem) !important;
  letter-spacing: 0.08em !important;
  color: var(--lwm-white) !important;
  margin: 0 !important;
}
body.woocommerce-cart .page-title,
body.lwm-cart-page .page-title,
body.woocommerce-cart h1.page-title,
body.lwm-cart-page h1.page-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(1.8rem, 4vw, 2.5rem) !important;
  letter-spacing: 0.08em !important;
  color: var(--lwm-white) !important;
  padding: clamp(2rem, 5vw, 3rem) var(--lwm-content-pad) 1.5rem !important;
  margin: 0 !important;
  border: none !important;
  background: transparent !important;
  text-align: center !important;
}
body.woocommerce-cart .entry-header,
body.lwm-cart-page .entry-header {
  background: transparent !important;
  border: none !important;
}

/* Cart layout — tighter padding for wider cart summary & totals */
body.woocommerce-cart .entry-content,
body.lwm-cart-page .entry-content {
  padding: 0 clamp(1rem, 3vw, 2rem) clamp(3rem, 6vw, 5rem) !important;
  max-width: var(--lwm-content-max) !important;
  margin: 0 auto !important;
}
body.woocommerce-cart .lwm-cart-header,
body.lwm-cart-page .lwm-cart-header {
  padding-left: clamp(1rem, 3vw, 2rem) !important;
  padding-right: clamp(1rem, 3vw, 2rem) !important;
}

/* Cart table — dark theme */
body.woocommerce-cart .woocommerce-cart-form,
body.lwm-cart-page .woocommerce-cart-form {
  background: var(--lwm-dark-2) !important;
  border: 1px solid var(--lwm-border) !important;
  border-radius: var(--lwm-radius-lg) !important;
  padding: 1.5rem !important;
  margin-bottom: 1.5rem !important;
}
body.woocommerce-cart .woocommerce-cart-form table.cart th,
body.lwm-cart-page .woocommerce-cart-form table.cart th {
  color: var(--lwm-green) !important;
  font-family: 'Bebas Neue', sans-serif !important;
}
body.woocommerce-cart .woocommerce-cart-form table.cart td,
body.woocommerce-cart .woocommerce-cart-form table.cart .product-name a,
body.lwm-cart-page .woocommerce-cart-form table.cart td,
body.lwm-cart-page .woocommerce-cart-form table.cart .product-name a {
  color: var(--lwm-white) !important;
}
body.woocommerce-cart .woocommerce-cart-form .product-name a:hover,
body.lwm-cart-page .woocommerce-cart-form .product-name a:hover {
  color: var(--lwm-green) !important;
}
body.woocommerce-cart .woocommerce-cart-form .price,
body.woocommerce-cart .woocommerce-cart-form .product-subtotal,
body.lwm-cart-page .woocommerce-cart-form .price,
body.lwm-cart-page .woocommerce-cart-form .product-subtotal {
  color: var(--lwm-green) !important;
  font-weight: 700 !important;
}
body.woocommerce-cart .woocommerce-cart-form .remove,
body.lwm-cart-page .woocommerce-cart-form .remove {
  color: var(--lwm-muted) !important;
  font-size: 1.5rem !important;
}
body.woocommerce-cart .woocommerce-cart-form .remove:hover,
body.lwm-cart-page .woocommerce-cart-form .remove:hover {
  color: #e74c3c !important;
}
body.woocommerce-cart .woocommerce-cart-form .quantity input,
body.lwm-cart-page .woocommerce-cart-form .quantity input {
  background: var(--lwm-dark-3) !important;
  border: 1px solid var(--lwm-border) !important;
  color: var(--lwm-white) !important;
  border-radius: var(--lwm-radius) !important;
}

/* Cart actions — Update cart, coupon */
body.woocommerce-cart .woocommerce-cart-form .actions .button,
body.lwm-cart-page .woocommerce-cart-form .actions .button {
  background: transparent !important;
  color: var(--lwm-blue) !important;
  border: 2px solid var(--lwm-blue) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  border-radius: var(--lwm-radius) !important;
}
body.woocommerce-cart .woocommerce-cart-form .actions .button:hover,
body.lwm-cart-page .woocommerce-cart-form .actions .button:hover {
  background: var(--lwm-blue) !important;
  color: var(--lwm-dark) !important;
}
body.woocommerce-cart .woocommerce-cart-form .coupon input,
body.lwm-cart-page .woocommerce-cart-form .coupon input {
  background: var(--lwm-dark-3) !important;
  border: 1px solid var(--lwm-border) !important;
  color: var(--lwm-white) !important;
  border-radius: var(--lwm-radius) !important;
}

/* Cart totals — conversion block */
body.woocommerce-cart .cart_totals,
body.lwm-cart-page .cart_totals {
  background: var(--lwm-dark-2) !important;
  border: 1px solid var(--lwm-border) !important;
  border-radius: var(--lwm-radius-lg) !important;
  padding: 1.5rem !important;
}
body.woocommerce-cart .cart_totals h2,
body.lwm-cart-page .cart_totals h2 {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.3rem !important;
  letter-spacing: 0.08em !important;
  color: var(--lwm-white) !important;
  margin-bottom: 1rem !important;
}
body.woocommerce-cart .cart_totals table th,
body.lwm-cart-page .cart_totals table th {
  color: var(--lwm-muted) !important;
  font-family: 'Space Mono', monospace !important;
}
body.woocommerce-cart .cart_totals table td,
body.lwm-cart-page .cart_totals table td {
  color: var(--lwm-white) !important;
}
body.woocommerce-cart .cart_totals .order-total th,
body.woocommerce-cart .cart_totals .order-total td,
body.lwm-cart-page .cart_totals .order-total th,
body.lwm-cart-page .cart_totals .order-total td {
  color: var(--lwm-green) !important;
  font-size: 1.25rem !important;
  font-weight: 700 !important;
}
body.woocommerce-cart .cart_totals .order-total td,
body.lwm-cart-page .cart_totals .order-total td {
  font-family: 'Bebas Neue', sans-serif !important;
}

/* Proceed to checkout — primary CTA */
body.woocommerce-cart .wc-proceed-to-checkout,
body.lwm-cart-page .wc-proceed-to-checkout {
  padding-top: 1rem !important;
  margin-top: 1rem !important;
  border-top: 1px solid var(--lwm-border) !important;
}
body.woocommerce-cart .wc-proceed-to-checkout .checkout-button,
body.lwm-cart-page .wc-proceed-to-checkout .checkout-button,
body.woocommerce-cart .wc-proceed-to-checkout a.button,
body.lwm-cart-page .wc-proceed-to-checkout a.button {
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  padding: 1rem 1.5rem !important;
  background: var(--lwm-green) !important;
  color: #fff !important;
  border: 2px solid var(--lwm-green) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.2rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  border-radius: var(--lwm-radius) !important;
  transition: all var(--lwm-transition) !important;
}
body.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover,
body.lwm-cart-page .wc-proceed-to-checkout .checkout-button:hover,
body.woocommerce-cart .wc-proceed-to-checkout a.button:hover,
body.lwm-cart-page .wc-proceed-to-checkout a.button:hover {
  background: transparent !important;
  color: var(--lwm-green) !important;
  transform: translateY(-2px) !important;
}
/* Trust badge below CTA */
body.woocommerce-cart .lwm-cart-trust,
body.lwm-cart-page .lwm-cart-trust {
  font-family: 'Space Mono', monospace !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--lwm-muted) !important;
  text-align: center !important;
  margin-top: 0.75rem !important;
}

/* Cross-sells — "You may also like" */
body.woocommerce-cart .cross-sells,
body.lwm-cart-page .cross-sells {
  margin-top: 2rem !important;
}
body.woocommerce-cart .cross-sells h2,
body.lwm-cart-page .cross-sells h2 {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.3rem !important;
  letter-spacing: 0.06em !important;
  color: var(--lwm-white) !important;
  margin-bottom: 1rem !important;
}
body.woocommerce-cart .cross-sells .product,
body.lwm-cart-page .cross-sells .product {
  background: var(--lwm-dark-2) !important;
  border: 1px solid var(--lwm-border) !important;
  border-radius: var(--lwm-radius-lg) !important;
}

/* Cart empty state */
body.woocommerce-cart .cart-empty,
body.lwm-cart-page .cart-empty {
  color: var(--lwm-muted) !important;
  font-family: 'Space Mono', monospace !important;
}
body.woocommerce-cart .return-to-shop .button,
body.lwm-cart-page .return-to-shop .button {
  background: var(--lwm-green) !important;
  color: #fff !important;
  border: 2px solid var(--lwm-green) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  border-radius: var(--lwm-radius) !important;
  text-align: center !important;
}

/* ============================================================
   CHECKOUT PAGE — matches cart, LWM design
   ============================================================ */

/* Same treatment as cart — kill white, dark background */
body.woocommerce-checkout,
body.lwm-checkout-page {
  background: var(--lwm-dark) !important;
}
body.woocommerce-checkout #primary,
body.woocommerce-checkout .content-area,
body.lwm-checkout-page #primary,
body.lwm-checkout-page .content-area {
  background: transparent !important;
}
body.woocommerce-checkout .entry-hero,
body.woocommerce-checkout .page-hero-section,
body.lwm-checkout-page .entry-hero,
body.lwm-checkout-page .page-hero-section {
  display: none !important;
}
body.woocommerce-checkout .entry .entry-header,
body.woocommerce-checkout .entry-header,
body.woocommerce-checkout article .entry-header,
body.lwm-checkout-page .entry .entry-header,
body.lwm-checkout-page .entry-header,
body.lwm-checkout-page article .entry-header {
  display: none !important;
}
body.woocommerce-checkout .entry,
body.woocommerce-checkout .content-bg,
body.woocommerce-checkout .entry-content-wrap,
body.woocommerce-checkout article.entry,
body.lwm-checkout-page .entry,
body.lwm-checkout-page .content-bg,
body.lwm-checkout-page .entry-content-wrap,
body.lwm-checkout-page article.entry {
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
  border: none !important;
}
body.woocommerce-checkout .entry-content,
body.woocommerce-checkout .entry-content-wrap,
body.lwm-checkout-page .entry-content,
body.lwm-checkout-page .entry-content-wrap {
  background: transparent !important;
  padding: 0 !important;
}

/* Slim checkout header */
body.woocommerce-checkout .lwm-checkout-header,
body.lwm-checkout-page .lwm-checkout-header {
  padding: clamp(2rem, 5vw, 3rem) clamp(1rem, 3vw, 2rem) 1.5rem !important;
  text-align: center !important;
  background: transparent !important;
}
body.woocommerce-checkout .lwm-checkout-title,
body.lwm-checkout-page .lwm-checkout-title {
  font-family: 'Inter', sans-serif !important;
  font-size: clamp(2.1rem, 4.5vw, 2.9rem) !important;
  letter-spacing: 0.08em !important;
  color: var(--lwm-white) !important;
  margin: 0 !important;
}

/* Checkout layout — tighter padding */
body.woocommerce-checkout .entry-content,
body.lwm-checkout-page .entry-content {
  padding: 0 clamp(1rem, 3vw, 2rem) clamp(3rem, 6vw, 5rem) !important;
  max-width: var(--lwm-content-max) !important;
  margin: 0 auto !important;
}

/* Checkout form — billing, shipping */
body.woocommerce-checkout form.checkout,
body.lwm-checkout-page form.checkout {
  color: var(--lwm-white) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1.1rem !important;
}
body.woocommerce-checkout #customer_details,
body.woocommerce-checkout .col2-set,
body.lwm-checkout-page #customer_details,
body.lwm-checkout-page .col2-set {
  background: var(--lwm-dark-2) !important;
  border: 1px solid var(--lwm-border) !important;
  border-radius: var(--lwm-radius-lg) !important;
  padding: 1.5rem !important;
  margin-bottom: 1.5rem !important;
  font-family: 'Inter', sans-serif !important;
}
body.woocommerce-checkout #customer_details .form-row label,
body.lwm-checkout-page #customer_details .form-row label {
  color: var(--lwm-white) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1.05rem !important;
}
/* Checkout left side section headings (CONTACT INFORMATION, BILLING DETAILS) */
body.woocommerce-checkout #customer_details h3,
body.woocommerce-checkout .woocommerce-billing-fields h3,
body.woocommerce-checkout .woocommerce-shipping-fields h3,
body.woocommerce-checkout .woocommerce-additional-fields h3,
body.lwm-checkout-page #customer_details h3,
body.lwm-checkout-page .woocommerce-billing-fields h3,
body.lwm-checkout-page .woocommerce-shipping-fields h3,
body.lwm-checkout-page .woocommerce-additional-fields h3 {
  color: var(--lwm-white) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1.35rem !important;
}
body.woocommerce-checkout #customer_details input,
body.woocommerce-checkout #customer_details select,
body.woocommerce-checkout #customer_details textarea,
body.lwm-checkout-page #customer_details input,
body.lwm-checkout-page #customer_details select,
body.lwm-checkout-page #customer_details textarea {
  background: var(--lwm-dark-3) !important;
  border: 1px solid var(--lwm-border) !important;
  color: var(--lwm-white) !important;
  border-radius: var(--lwm-radius) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1.1rem !important;
}
body.woocommerce-checkout #customer_details input:focus,
body.woocommerce-checkout #customer_details select:focus,
body.woocommerce-checkout #customer_details textarea:focus,
body.lwm-checkout-page #customer_details input:focus,
body.lwm-checkout-page #customer_details select:focus,
body.lwm-checkout-page #customer_details textarea:focus {
  border-color: var(--lwm-green) !important;
  outline: none !important;
}

/* Order review — "Your order" */
body.woocommerce-checkout #order_review_heading,
body.woocommerce-checkout #order_review,
body.lwm-checkout-page #order_review_heading,
body.lwm-checkout-page #order_review {
  color: var(--lwm-white) !important;
}
body.woocommerce-checkout #order_review_heading,
body.lwm-checkout-page #order_review_heading {
  font-family: 'Inter', sans-serif !important;
  font-size: 1.5rem !important;
  letter-spacing: 0.06em !important;
  margin-bottom: 1rem !important;
}
body.woocommerce-checkout #order_review,
body.lwm-checkout-page #order_review {
  background: var(--lwm-dark-2) !important;
  border: 1px solid var(--lwm-border) !important;
  border-radius: var(--lwm-radius-lg) !important;
  padding: 1.5rem !important;
}
body.woocommerce-checkout #order_review table th,
body.woocommerce-checkout #order_review table td,
body.lwm-checkout-page #order_review table th,
body.lwm-checkout-page #order_review table td {
  color: var(--lwm-white) !important;
  border-color: var(--lwm-border) !important;
}
body.woocommerce-checkout #order_review table th,
body.woocommerce-checkout #order_review table td,
body.lwm-checkout-page #order_review table th,
body.lwm-checkout-page #order_review table td {
  font-family: 'Inter', sans-serif !important;
  font-size: 1.15rem !important;
}
body.woocommerce-checkout #order_review .order-total th,
body.woocommerce-checkout #order_review .order-total td,
body.lwm-checkout-page #order_review .order-total th,
body.lwm-checkout-page #order_review .order-total td {
  color: var(--lwm-green) !important;
  font-weight: 700 !important;
}

/* Payment methods */
body.woocommerce-checkout #payment,
body.lwm-checkout-page #payment {
  background: transparent !important;
  border: none !important;
  padding-top: 1rem !important;
}
body.woocommerce-checkout #payment .payment_methods,
body.woocommerce-checkout #payment .wc_payment_method,
body.lwm-checkout-page #payment .payment_methods,
body.lwm-checkout-page #payment .wc_payment_method {
  color: var(--lwm-white) !important;
}
/* Card & PayPal payment method selection — black text on light bg */
body.woocommerce-checkout #payment .payment_methods > li > label,
body.woocommerce-checkout #payment .wc_payment_method > label,
body.lwm-checkout-page #payment .payment_methods > li > label,
body.lwm-checkout-page #payment .wc_payment_method > label {
  color: #000 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1.15rem !important;
}
body.woocommerce-checkout #payment .payment_method_paypal .about_paypal,
body.lwm-checkout-page #payment .payment_method_paypal .about_paypal {
  color: var(--lwm-muted) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1rem !important;
}
/* Payment fields (Card number, etc.) */
body.woocommerce-checkout #payment .form-row label,
body.woocommerce-checkout #payment input,
body.woocommerce-checkout #payment .payment_methods,
body.lwm-checkout-page #payment .form-row label,
body.lwm-checkout-page #payment input,
body.lwm-checkout-page #payment .payment_methods {
  font-family: 'Inter', sans-serif !important;
  font-size: 1.1rem !important;
}

/* Place order — primary CTA */
body.woocommerce-checkout #place_order,
body.lwm-checkout-page #place_order {
  width: 100% !important;
  padding: 1rem 1.5rem !important;
  background: var(--lwm-green) !important;
  color: #fff !important;
  border: 2px solid var(--lwm-green) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1.4rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  border-radius: var(--lwm-radius) !important;
  transition: all var(--lwm-transition) !important;
  cursor: pointer !important;
  text-align: center !important;
}
body.woocommerce-checkout #place_order:hover,
body.lwm-checkout-page #place_order:hover {
  background: transparent !important;
  color: var(--lwm-green) !important;
  transform: translateY(-2px) !important;
}
body.woocommerce-checkout .lwm-checkout-trust,
body.lwm-checkout-page .lwm-checkout-trust {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--lwm-muted) !important;
  text-align: center !important;
  margin-top: 0.75rem !important;
}

/* ============================================================
   BOOKING FORM
   ============================================================ */
.lwm-booking-form {
  max-width: 540px;
  margin: 0 auto;
  padding: 1.25rem 1.5rem;
  background: var(--lwm-dark-2);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius-lg);
}

.lwm-booking-field {
  margin-bottom: 0.75rem;
}

.lwm-booking-field label {
  display: block;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--lwm-white);
  margin-bottom: 0.2rem;
  text-align: left;
}

.lwm-booking-field .required {
  color: var(--lwm-green);
}

.lwm-booking-form input[type="text"],
.lwm-booking-form input[type="email"],
.lwm-booking-form input[type="tel"],
.lwm-booking-form input[type="date"],
.lwm-booking-form textarea {
  width: 100%;
  padding: 0.5rem 0.75rem;
  background: var(--lwm-dark-3);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius);
  color: var(--lwm-white);
  font-family: inherit;
  font-size: 1rem;
  transition: border-color var(--lwm-transition);
}

.lwm-booking-form input:focus,
.lwm-booking-form textarea:focus {
  outline: none;
  border-color: var(--lwm-green);
  box-shadow: 0 0 0 3px rgba(0, 230, 118, 0.1);
}

.lwm-booking-form input::placeholder,
.lwm-booking-form textarea::placeholder {
  color: var(--lwm-muted);
  opacity: 0.8;
}

.lwm-booking-form textarea {
  resize: vertical;
  min-height: 90px;
}

.lwm-booking-submit {
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}

.lwm-booking-btn {
  width: 100%;
  padding: 0.75rem 1.25rem;
  background: var(--lwm-green);
  color: var(--lwm-dark);
  border: 2px solid var(--lwm-green);
  border-radius: var(--lwm-radius);
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.1rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--lwm-transition);
}

.lwm-booking-btn:hover:not(:disabled) {
  background: transparent;
  color: var(--lwm-green);
}

.lwm-booking-btn:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.lwm-booking-message {
  font-family: inherit;
  font-size: 0.95rem;
  padding: 0.5rem 0.75rem;
  border-radius: var(--lwm-radius);
  margin-top: 0.5rem;
}

.lwm-booking-message.lwm-booking-success {
  background: rgba(0, 230, 118, 0.12);
  border: 1px solid rgba(0, 230, 118, 0.3);
  color: var(--lwm-green);
}

.lwm-booking-message.lwm-booking-error {
  background: rgba(231, 76, 60, 0.12);
  border: 1px solid rgba(231, 76, 60, 0.4);
  color: #e74c3c;
}

/* ============================================================
   CONTACT FORM — same styling as booking form
   ============================================================ */
.lwm-contact-form-wrap {
  margin-top: 1.5rem;
}

.lwm-contact-form {
  max-width: 540px;
  margin: 0 auto;
  padding: 1.25rem 1.5rem;
  background: var(--lwm-dark-2);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius-lg);
}

.lwm-contact-field {
  margin-bottom: 0.75rem;
}

.lwm-contact-field label {
  display: block;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--lwm-white);
  margin-bottom: 0.2rem;
  text-align: left;
}

.lwm-contact-field .required {
  color: var(--lwm-green);
}

.lwm-contact-form input[type="text"],
.lwm-contact-form input[type="email"],
.lwm-contact-form textarea {
  width: 100%;
  padding: 0.5rem 0.75rem;
  background: var(--lwm-dark-3);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius);
  color: var(--lwm-white);
  font-family: inherit;
  font-size: 1rem;
  transition: border-color var(--lwm-transition);
}

.lwm-contact-form input:focus,
.lwm-contact-form textarea:focus {
  outline: none;
  border-color: var(--lwm-green);
  box-shadow: 0 0 0 3px rgba(0, 230, 118, 0.1);
}

.lwm-contact-form input::placeholder,
.lwm-contact-form textarea::placeholder {
  color: var(--lwm-muted);
  opacity: 0.8;
}

.lwm-contact-form textarea {
  resize: vertical;
  min-height: 90px;
}

.lwm-contact-submit {
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}

.lwm-contact-btn {
  width: 100%;
  padding: 0.75rem 1.25rem;
  background: var(--lwm-green);
  color: var(--lwm-dark);
  border: 2px solid var(--lwm-green);
  border-radius: var(--lwm-radius);
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.1rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--lwm-transition);
}

.lwm-contact-btn:hover:not(:disabled) {
  background: transparent;
  color: var(--lwm-green);
}

.lwm-contact-btn:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.lwm-contact-message {
  font-family: inherit;
  font-size: 0.95rem;
  padding: 0.5rem 0.75rem;
  border-radius: var(--lwm-radius);
  margin-top: 0.5rem;
}

.lwm-contact-message.lwm-contact-success {
  background: rgba(0, 230, 118, 0.12);
  border: 1px solid rgba(0, 230, 118, 0.3);
  color: var(--lwm-green);
}

.lwm-contact-message.lwm-contact-error {
  background: rgba(231, 76, 60, 0.12);
  border: 1px solid rgba(231, 76, 60, 0.4);
  color: #e74c3c;
}

/* ============================================================
   FOOTER
   ============================================================ */
#colophon,
.site-footer,
.kadence-footer {
  background: var(--lwm-dark-2) !important;
  border-top: 1px solid var(--lwm-border) !important;
}

.kadence-footer .footer-widget-area,
.footer-widget-area {
  background: var(--lwm-dark-2) !important;
}

.kadence-footer a,
.site-footer a {
  color: var(--lwm-muted) !important;
  font-size: 0.9rem !important;
  transition: color var(--lwm-transition) !important;
}

.kadence-footer a:hover,
.site-footer a:hover { color: var(--lwm-green) !important; }

.kadence-footer .widget-title,
.site-footer .widget-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--lwm-white) !important;
  margin-bottom: 1.2rem !important;
}

.site-info,
.kadence-footer-bottom {
  font-family: 'Space Mono', monospace !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--lwm-muted) !important;
  border-top: 1px solid var(--lwm-border) !important;
  background: var(--lwm-dark-2) !important;
}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lwm-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(5,13,16,0.97);
  align-items: center;
  justify-content: center;
}

.lwm-lightbox.open { display: flex; }

.lwm-lightbox img {
  max-width: 90vw;
  max-height: 90vh;
  border-radius: var(--lwm-radius);
  object-fit: contain;
}

.lwm-lightbox-close {
  position: absolute;
  top: 2rem; right: 2rem;
  background: none;
  border: 1px solid var(--lwm-border);
  color: var(--lwm-white);
  font-size: 1.5rem;
  width: 44px; height: 44px;
  border-radius: 50%;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--lwm-transition);
}

.lwm-lightbox-close:hover {
  border-color: var(--lwm-green);
  color: var(--lwm-green);
}

/* ============================================================
   FADE-UP ANIMATION
   ============================================================ */
.lwm-fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.lwm-fade-up.in-view {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   KADENCE ROW / COLUMN RESETS for dark theme
   ============================================================ */
.kb-row-layout-wrap { position: relative; }
.kb-row-layout-container > .kb-column-wrap { align-items: stretch; }

/* Section backgrounds — full width, content centered via midline rules above */

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .lwm-hero-title { font-size: clamp(3rem, 8vw, 6rem) !important; }
}

@media (max-width: 768px) {
  .lwm-instrument-tags { gap: 0.5rem; }
  .lwm-stream-btns { flex-direction: column; }
  .lwm-filter-bar  { gap: 0.4rem; }
}

@media (max-width: 480px) {
  .lwm-hero-title { font-size: clamp(3rem, 14vw, 5rem) !important; }
  .lwm-hero-subtitle { font-size: 1rem !important; }
}

/* Responsive: unified scale using design tokens */
@media (max-width: 1024px) {
  :root {
    --lwm-section-pad-y: 3.5rem;
    --lwm-section-gap: 40px;
  }
  .kb-row-layout-idout-now .kt-row-column-wrap,
  .kb-row-layout-idabout-lee .kt-row-column-wrap,
  .kb-row-layout-idbook-lee .kt-row-column-wrap {
    gap: 2.5rem !important;
  }
  .entry-content .kb-row-layout-wrap:first-of-type { margin-top: 60px !important; }
  .lwm-ticker-wrap { margin-bottom: var(--lwm-section-gap) !important; }
}

@media (max-width: 768px) {
  :root {
    --lwm-section-pad-y: 3rem;
    --lwm-section-gap: 40px;
  }
  .kb-row-layout-idout-now .kt-row-column-wrap,
  .kb-row-layout-idabout-lee .kt-row-column-wrap,
  .kb-row-layout-idbook-lee .kt-row-column-wrap {
    gap: 2rem !important;
  }
  .kb-row-layout-idabout-lee .kb-row-layout-wrap:has(.lwm-stat-box) .kt-row-column-wrap,
  .kb-row-layout-idabout-lee .kb-row-layout-idbio-stats .kt-row-column-wrap {
    flex-direction: column !important;
    align-items: center !important;
  }
  .entry-content .kb-row-layout-wrap:first-of-type { margin-top: 50px !important; }
  .lwm-ticker-wrap { margin-bottom: var(--lwm-section-gap) !important; }
}

@media (max-width: 480px) {
  :root {
    --lwm-section-pad-y: 2.5rem;
    --lwm-section-gap: 40px;
  }
  .kb-row-layout-idout-now .kt-row-column-wrap,
  .kb-row-layout-idabout-lee .kt-row-column-wrap,
  .kb-row-layout-idbook-lee .kt-row-column-wrap {
    gap: 1.5rem !important;
  }
  .kb-row-layout-idabout-lee .lwm-section-label { margin-bottom: 0.75rem !important; }
  .kb-row-layout-idabout-lee h2 { margin-bottom: 0.75rem !important; }
  .kb-row-layout-idabout-lee .lwm-divider { margin: 0.75rem auto 1rem !important; }
  .kb-row-layout-idabout-lee .kb-column-id-about-text p { margin-bottom: 1rem !important; }
  .kb-row-layout-idabout-lee .kb-row-layout-wrap:has(.lwm-stat-box),
  .kb-row-layout-idabout-lee-stats {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .entry-content .kb-row-layout-wrap:first-of-type { margin-top: 40px !important; }
  .lwm-ticker-wrap { margin-bottom: var(--lwm-section-gap) !important; }
}

/* Nuke padding — no side padding anywhere */
body, #page, .site, #wrapper,
.content-container.site-container, #primary, .site-main,
.content-wrap, .entry-content-wrap, .entry-content {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Hero: full viewport — no left/transform (critical CSS handles full-width + left-align) */
.lwm-hero {
  width: 100vw !important;
  max-width: 100vw !important;
  position: relative !important;
}
/* Ticker: true full viewport — escape any parent constraint */
.lwm-ticker-wrap {
  width: 100vw !important;
  max-width: 100vw !important;
  position: relative !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-bottom: var(--lwm-section-gap) !important;
  box-sizing: border-box !important;
}
.lwm-ticker-wrap .lwm-ticker {
  width: 100% !important;
}
/* Ensure hero/ticker parents don't constrain or clip */
.entry-content, .entry-content-wrap, article.entry {
  max-width: none !important;
  overflow-x: visible !important;
}
.entry-content > div:has(> .lwm-ticker-wrap),
.entry-content > figure:has(> .lwm-ticker-wrap) {
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
}

/* ============================================================
   TARGETED FIXES — applied after seeing live site
   ============================================================ */

/* Remove Kadence content container white background + padding */
.entry-content,
.entry-content-wrap,
.wp-block-post-content,
.singular .entry-content {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  box-shadow: none !important;
}

/* Remove the white card box around page content */
.content-bg,
.site-content .content-bg,
.kadence-inner-column-inner,
.kb-blocks-editor-wrap {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  border-radius: 0 !important;
}

/* Kill all Kadence default content padding/margin */
.kadence-blocks-wrap,
.kb-section-dir-row,
.kb-row-layout-wrap {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Hero — full viewport, content left-aligned with padding */
.lwm-hero {
  min-height: 100vh !important;
  margin-top: 0 !important;
  padding-top: 0 !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
}

.lwm-hero .kb-row-layout-container {
  max-width: var(--lwm-content-max) !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: auto !important;
  padding: 80px var(--lwm-content-pad) var(--lwm-section-pad-y) !important;
  padding-left: var(--lwm-content-pad) !important;
  box-sizing: border-box !important;
}

.lwm-hero .kb-column-id-hero-content {
  max-width: 720px !important;
  margin-left: 0 !important;
  margin-right: auto !important;
  text-align: left !important;
}

/* Hero button row — left-aligned */
.lwm-hero .kb-row-layout-idhero-btns .kt-row-column-wrap {
  justify-content: flex-start !important;
  gap: 1rem !important;
}

/* ============================================================
   CENTERED MIDLINE LAYOUT
   All content aligned to a single vertical axis. Symmetric padding.
   ============================================================ */
.lwm-bg-dark,
.lwm-bg-dark-2,
.lwm-bg-dark-3,
.kb-row-layout-wrap.lwm-bg-dark,
.kb-row-layout-wrap.lwm-bg-dark-2,
.kb-row-layout-wrap.lwm-bg-dark-3 {
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  padding-top: var(--lwm-section-pad-y) !important;
  padding-bottom: var(--lwm-section-pad-y) !important;
}

/* Single centered content column — all sections share this */
.lwm-bg-dark .kb-row-layout-container,
.lwm-bg-dark-2 .kb-row-layout-container,
.lwm-bg-dark-3 .kb-row-layout-container,
.kb-row-layout-idout-now .kb-row-layout-container,
.kb-row-layout-idabout-lee .kb-row-layout-container,
.kb-row-layout-idbook-lee .kb-row-layout-container,
.kb-row-layout-iddiscog-header .kb-row-layout-container,
.kb-row-layout-iddiscog-albums .kb-row-layout-container,
.kb-row-layout-iddiscog-footer .kb-row-layout-container {
  max-width: var(--lwm-content-max) !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--lwm-content-pad) !important;
  padding-right: var(--lwm-content-pad) !important;
  box-sizing: border-box !important;
}
/* Book Lee — left column left-justified, padding on both columns */
.kb-row-layout-idbook-lee > .kt-row-column-wrap {
  gap: 3.5rem !important;
  justify-content: flex-start !important;
  padding-left: clamp(3rem, 8vw, 6rem) !important;
  padding-right: clamp(3rem, 8vw, 6rem) !important;
}
.kb-row-layout-idbook-lee .kb-column-id-book-info .lwm-divider {
  margin-left: 0 !important;
  margin-right: auto !important;
}
.kb-row-layout-idbook-lee .kb-column-id-book-info .lwm-social-links {
  justify-content: flex-start !important;
}
/* About Lee — image right, text left, standardized padding */
.kb-row-layout-idabout-lee > .kt-row-column-wrap {
  gap: 2.5rem !important;
  justify-content: flex-start !important;
  padding-left: var(--lwm-content-pad) !important;
  padding-right: var(--lwm-content-pad) !important;
}
.kb-row-layout-idabout-lee .kb-column-id-about-img {
  text-align: right !important;
  padding-right: clamp(2rem, 5vw, 3rem) !important;
}
.kb-row-layout-idabout-lee .kb-column-id-about-img img,
.kb-row-layout-idabout-lee .kb-column-id-about-img .lwm-bio-img,
.kb-row-layout-idabout-lee .kb-column-id-about-img figure.wp-block-image img {
  margin-left: auto !important;
  margin-right: 0 !important;
}
.kb-row-layout-idabout-lee .kb-column-id-about-text {
  text-align: left !important;
}
.kb-row-layout-idabout-lee .kb-column-id-about-text .lwm-divider {
  margin-left: 0 !important;
  margin-right: auto !important;
}
/* Latest Release — tighter gap (photo closer to right column) */
.kb-row-layout-idout-now .kt-row-column-wrap {
  gap: 1.5rem !important;
  justify-content: flex-start !important;
}
/* Stat boxes — left-aligned to match About Lee text block */
.kb-row-layout-idabout-lee .kb-row-layout-wrap:has(.lwm-stat-box) .kt-row-column-wrap,
.kb-row-layout-idabout-lee .kb-row-layout-idbio-stats .kt-row-column-wrap {
  justify-content: flex-start !important;
}
/* Discography albums row — centered */
.kb-row-layout-iddiscog-albums .kt-row-column-wrap {
  justify-content: center !important;
}
/* Out Now & About Lee: revert to Kadence default — image left, text right */
/* Out Now: internal vertical spacing (mirrors About Lee rhythm) */
.kb-row-layout-idout-now .lwm-section-label { margin-bottom: 1rem !important; }
.kb-row-layout-idout-now h2 { margin-top: 0 !important; margin-bottom: 1rem !important; }
.kb-row-layout-idout-now .kb-column-id-out-info p { margin-bottom: 1.2rem !important; }
.kb-row-layout-idout-now .lwm-stream-btns { margin-top: 1rem !important; margin-bottom: 0.5rem !important; }
.kb-row-layout-idout-now .lwm-spotify-embed { margin-top: 1.5rem !important; }
/* About Lee & Booking: use standardized section padding */
.kb-row-layout-idabout-lee.lwm-bg-dark,
.kb-row-layout-idabout-lee.kb-row-layout-wrap,
.kb-row-layout-idabout-lee .kb-row-layout-wrap,
.kb-row-layout-idbook-lee.kb-row-layout-wrap,
.kb-row-layout-idbook-lee .kb-row-layout-wrap {
  padding-top: var(--lwm-section-pad-y) !important;
  padding-bottom: var(--lwm-section-pad-y) !important;
}
/* About Lee: internal vertical spacing — mirror Out Now (label → heading → content → stats) */
.kb-row-layout-idabout-lee .lwm-section-label {
  margin-bottom: 1rem !important;
}
.kb-row-layout-idabout-lee h2 {
  margin-top: 0 !important;
  margin-bottom: 1rem !important;
}
.kb-row-layout-idabout-lee .lwm-divider {
  margin: 1rem 0 1.5rem !important;
  margin-left: 0 !important;
  margin-right: auto !important;
}
.kb-row-layout-idabout-lee .kb-column-id-about-text p {
  margin-bottom: 1.2rem !important;
}
/* About Lee: stat boxes (Kadence row) — top spacing; tighter gap to buttons below */
.kb-row-layout-idabout-lee .kb-row-layout-wrap:has(.lwm-stat-box),
.kb-row-layout-idabout-lee-stats {
  margin-top: 1.5rem !important;
  margin-bottom: 0.5rem !important;
}
/* About Lee: bio buttons — sit under stat boxes, reduced top padding */
.kb-row-layout-idabout-lee .kb-row-layout-idbio-btns {
  padding-top: 0.5rem !important;
}
/* Booking: mirror Out Now internal spacing */
.kb-row-layout-idbook-lee .lwm-section-label {
  margin-bottom: 1rem !important;
}
.kb-row-layout-idbook-lee h2 {
  margin-top: 0 !important;
  margin-bottom: 1rem !important;
}
.kb-row-layout-idbook-lee .lwm-divider {
  margin: 1rem 0 1.5rem !important;
}
.kb-row-layout-idbook-lee .kb-column-id-book-info p {
  margin-bottom: 1.2rem !important;
}

/* Standardized spacing between homepage sections. Use ~ not + (Kadence injects <style> between blocks) */
.entry-content .kb-row-layout-wrap ~ .kb-row-layout-wrap {
  margin-top: var(--lwm-section-gap) !important;
}
/* Tighter gap between About Lee (with buttons) and Book Lee — minimal spacing */
body.home .kb-row-layout-idabout-lee ~ .kb-row-layout-idbook-lee {
  margin-top: 0 !important;
  padding-top: 0.25rem !important;
}
/* Clear fixed header — first row (hero) needs top spacing */
.entry-content .kb-row-layout-wrap:first-of-type {
  padding-top: 0 !important;
}


/* Remove Spacer block between columns — hide at every level */
.kb-row-layout-idabout-lee .wp-block-kadence-spacer,
.kb-row-layout-idabout-lee .kt-block-spacer,
.kb-row-layout-idabout-lee [data-type="kadence/spacer"],
.kb-row-layout-idout-now .wp-block-kadence-spacer,
.kb-row-layout-idout-now .kt-block-spacer,
.kb-row-layout-idout-now [data-type="kadence/spacer"],
.kb-row-layout-idbook-lee .wp-block-kadence-spacer,
.kb-row-layout-idbook-lee .kt-block-spacer,
.kb-row-layout-idbook-lee [data-type="kadence/spacer"],
.kt-row-column-wrap .wp-block-kadence-spacer,
.kt-row-column-wrap .kt-block-spacer,
.kt-row-column-wrap > .wp-block-kadence-spacer,
.kt-row-column-wrap > .kt-block-spacer,
.kb-row-layout-wrap .wp-block-kadence-spacer,
.kb-row-layout-wrap .kt-block-spacer {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}
/* Also hide spacer's inner stripe/divider so it can't show through */
.kb-row-layout-idabout-lee .kt-divider-stripe,
.kb-row-layout-idabout-lee .kb-pattern-svg-divider,
.kt-block-spacer .kt-divider-stripe,
.kt-block-spacer .kb-pattern-svg-divider {
  display: none !important;
}
/* About Lee: same gap as Out Now (3.5rem) — container padding applied above */

/* Hide column divider — borders that create vertical bar */
.kb-row-layout-idabout-lee .kb-row-column-wrap,
.kb-row-layout-idout-now .kb-row-column-wrap,
.kb-row-layout-idbook-lee .kb-row-column-wrap {
  border-left: none !important;
  border-right: none !important;
}

/* Column content — centered within midline container */
.kb-row-layout-wrap .kb-row-column-wrap,
.kb-row-layout-wrap .kt-row-column-wrap {
  text-align: center !important;
}
/* Book Lee left column — left-aligned (override global center) */
.kb-row-layout-idbook-lee .kb-column-id-book-info {
  text-align: left !important;
}

/* Remove Kadence default page hero title padding */
.wp-site-blocks > header + * {
  margin-top: 0 !important;
}

/* Fix header — transparent always, no white bg */
#masthead {
  background-color: transparent !important;
  background: transparent !important;
}

/* Remove Kadence's default top margin on first block */
.entry-content > *:first-child,
.entry-content-wrap > *:first-child {
  margin-top: 0 !important;
}

/* Nav: hide Cart and Checkout */
.nav-menu .menu-item a[href*="/cart/"],
.nav-menu .menu-item a[href*="/checkout/"] {
  display: none !important;
}

/* Remove content column max-width constraint from Kadence default */
.content-area,
#primary {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
}

/* Fix Kadence single column layout removing sidebar gap */
.kadence-columns-1 .kb-row-column-wrap {
  max-width: 100% !important;
}

/* Ensure page background is dark everywhere */
#page,
#content,
.site-main,
main#main {
  background: var(--lwm-dark) !important;
}

/* ============================================================
   PRECISION FIXES — from live DOM inspection
   ============================================================ */

/* THE white box — Kadence applies bg directly to article */
article.content-bg,
.entry.content-bg,
.single-entry.content-bg {
  background: transparent !important;
  background-color: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* THE gap — content-area has 80px top/bottom margin */
.content-area {
  margin: 0 !important;
}

/* Remove side padding from site container on homepage */
.content-container.site-container {
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: 100% !important;
}

/* Remove content-wrap padding if any */
.content-wrap {
  padding: 0 !important;
}

/* Remove site-main constraints */
.site-main {
  padding: 0 !important;
  margin: 0 !important;
}

/* ============================================================
   FINAL FIX — from live DOM inspection March 2026
   Root cause: #wrapper.site had max-width:1280px + margin:0
   (not centered). All content was left-aligned and cut off.
   ============================================================ */

/* 1. UN-CAP — full width, no constraint */
#wrapper.site,
.wp-site-blocks,
#wrapper,
#inner-wrap,
.site {
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
}

/* 2. Full width all the way down */
#inner-wrap.wrap,
#primary.content-area,
.content-container.site-container,
#main.site-main,
.content-wrap,
.entry-content-wrap,
article.entry,
article.content-bg {
  max-width: 100% !important;
  width: 100% !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  border: none !important;
}

/* 3. Kadence rows — full width, inner content centered via rules above */
.kb-row-layout-wrap,
div[class*="kb-row-layout-id"] {
  width: 100% !important;
  max-width: 100% !important;
}

/* 5. Images inside Kadence columns — constrain properly */
.kb-row-layout-wrap img,
.kb-column-wrap img {
  max-width: 100% !important;
  height: auto !important;
  display: block !important;
}

/* 6. Remove leftover margin gap from content-area */
.content-area {
  margin: 0 !important;
  padding: 0 !important;
}

/* 7. Full dark background everywhere */
body, #page, #wrapper, .site, #inner-wrap {
  background: #050d10 !important;
}

/* ============================================================
   CENTERED LAYOUT — Latest Release, About Lee, Booking
   ============================================================ */

/* Latest Release — album art centered, badge at corner */
/* Photo shifts right (closer to text column) */
.kb-row-layout-idout-now .kb-column-id-out-art img,
.kb-row-layout-idout-now .kt-row-column-wrap > .kb-row-column-wrap:first-child img {
  max-width: 460px !important;
  width: 100% !important;
  height: auto !important;
  margin-left: auto !important;
  margin-right: 0 !important;
  display: block !important;
}
/* Left column: align photo to right edge (closer to text) */
.kb-row-layout-idout-now .kb-column-id-out-art {
  text-align: right !important;
}
.kb-row-layout-idout-now .lwm-album-art-wrap {
  margin-left: auto !important;
  margin-right: 0 !important;
  padding-right: calc(clamp(1.5rem, 4vw, 2.5rem) + 56px) !important;
}
/* Latest Release right column — left-align all */
.kb-row-layout-idout-now .kb-column-id-out-info {
  text-align: left !important;
}
.kb-row-layout-idout-now .lwm-stream-btns {
  justify-content: flex-start !important;
  flex-wrap: wrap !important;
  gap: 0.5rem !important;
}
.kb-row-layout-idout-now .lwm-spotify-embed {
  margin-left: 0 !important;
  margin-right: auto !important;
  width: 100% !important;
  max-width: 520px !important;
}
.kb-row-layout-idout-now .kb-column-id-out-info p {
  margin-left: 0 !important;
  margin-right: auto !important;
  max-width: 520px !important;
}
.kb-row-layout-idout-now .lwm-badge {
  position: absolute;
  top: 0;
  left: 0;
  background: var(--lwm-green);
  color: #fff;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  padding: 0.4rem 0.8rem;
  border-radius: var(--lwm-radius);
  text-transform: uppercase;
  z-index: 1;
}

.lwm-album-art-wrap {
  position: relative !important;
  display: inline-block !important;
  width: fit-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* About Lee — portrait centered */
.kb-row-layout-idabout-lee .kb-column-id-about-img img,
.kb-row-layout-idabout-lee .kb-column-id-about-img .lwm-bio-img,
.kb-row-layout-idabout-lee figure.wp-block-image img {
  max-width: 420px !important;
  width: 100% !important;
  height: auto !important;
  margin-left: auto !important;
  margin-right: auto !important;
  display: block !important;
}

/* Album cards — enforce uniform square sizing (fixes oversized YOLO BOPS etc) */
.lwm-album-card {
  display: flex !important;
  flex-direction: column !important;
}
.lwm-album-card img {
  width: 100% !important;
  aspect-ratio: 1 !important;
  object-fit: cover !important;
  min-height: 0 !important;
}

/* All Albums / Discography — LIVE uses .kt-row-column-wrap (no kb-row-layout-container) */
.kb-row-layout-iddiscog-header > .kt-row-column-wrap,
.kb-row-layout-iddiscog-footer > .kt-row-column-wrap {
  padding-left: var(--lwm-content-pad) !important;
  padding-right: var(--lwm-content-pad) !important;
}
/* Album row — LOCK 45px horizontal padding */
.kb-row-layout-iddiscog-albums > .kt-row-column-wrap {
  padding-left: 45px !important;
  padding-right: 45px !important;
  padding-top: 0 !important;
  padding-bottom: 1rem !important;
}
.kb-row-layout-iddiscog-header .kb-column-id-discog-h-col > div:first-child {
  margin-bottom: 3.5rem !important;
  text-align: center !important;
}
.kb-row-layout-iddiscog-header .lwm-divider-center {
  margin-left: auto !important;
  margin-right: auto !important;
}
/* Discog footer — less top spacing (tighter to album row), keep link margin */
.kb-row-layout-iddiscog-footer {
  padding-top: 0 !important;
}
.kb-row-layout-iddiscog-footer .kb-column-id-discog-f-col > div {
  margin-top: 1.5rem !important;
  text-align: center !important;
}

/* ============================================================
   STREAM PAGE (template-stream.php) — 2×3 grid, front page design
   ============================================================ */
.lwm-stream-page .entry,
.lwm-stream-page .content-bg {
  background: transparent !important;
  padding: 0 !important;
}

.lwm-stream-hero,
.lwm-youtube-hero {
  padding: clamp(4rem, 10vw, 7rem) var(--lwm-content-pad) 0.5rem;
  text-align: center;
}

.lwm-stream-hero-inner,
.lwm-youtube-hero-inner {
  max-width: var(--lwm-content-max);
  margin: 0 auto;
}

/* Section label: white vertical bar to left, green text, short green line below */
.lwm-stream-hero .lwm-section-label,
.lwm-youtube-hero .lwm-section-label {
  margin-bottom: 0.75rem;
  border-left: 3px solid rgba(255, 255, 255, 0.9);
  padding-left: 0.75rem;
  color: var(--lwm-green);
  position: relative;
}

.lwm-stream-hero .lwm-section-label::after,
.lwm-youtube-hero .lwm-section-label::after {
  content: '';
  display: block;
  width: 40px;
  height: 2px;
  background: var(--lwm-green);
  margin: 0.5rem auto 0;
}

.lwm-stream-title,
.lwm-youtube-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(2.5rem, 6vw, 5rem) !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.1;
  margin: 0 0 0.5rem;
  color: var(--lwm-white);
}

.lwm-stream-hero .lwm-divider,
.lwm-youtube-hero .lwm-divider {
  margin: 1rem auto 1.5rem;
  background: linear-gradient(90deg, var(--lwm-blue) 0%, var(--lwm-blue) 35%, var(--lwm-green) 35%, var(--lwm-green) 100%);
}

.lwm-stream-subtitle,
.lwm-youtube-subtitle {
  color: var(--lwm-muted) !important;
  font-size: 1.1rem;
  max-width: 540px;
  margin-left: auto;
  margin-right: auto;
  max-width: 540px;
  margin: 0 auto;
}

/* Album grid — 2 tidy rows × 3 columns, identical image sizes */
.lwm-stream-grid {
  padding: 0.5rem var(--lwm-content-pad) clamp(3rem, 6vw, 5rem);
}

.lwm-stream-grid-inner {
  max-width: var(--lwm-content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: repeat(2, auto);
  column-gap: 1.5rem;
  row-gap: 2.5rem;
  align-items: stretch;
}

.lwm-stream-card {
  background: var(--lwm-dark-2);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-width: 0;
  transition: transform var(--lwm-transition), box-shadow var(--lwm-transition);
}

.lwm-stream-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.4);
}

/* Identical album art — fixed square per card */
.lwm-stream-card-art {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  flex-shrink: 0;
  overflow: hidden;
  background: var(--lwm-dark-3);
}

.lwm-stream-card-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.lwm-stream-card .lwm-badge {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  font-family: 'Space Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: var(--lwm-green);
  color: #fff;
  padding: 0.3rem 0.55rem;
  border-radius: 4px;
}

.lwm-stream-card-body {
  padding: 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.lwm-stream-card-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(1.1rem, 2vw, 1.4rem) !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin: 0 0 0.25rem;
  color: var(--lwm-white);
  line-height: 1.15;
}

.lwm-stream-card-meta {
  font-family: 'Space Mono', monospace;
  font-size: 0.7rem;
  color: var(--lwm-blue);
  letter-spacing: 0.06em;
  margin-bottom: 1rem;
}

.lwm-stream-card-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: auto;
}

.lwm-stream-card-btns .lwm-stream-btn {
  padding: 0.5rem 0.75rem;
  font-size: 1rem;
}

.lwm-stream-card-btns .lwm-stream-btn i {
  font-size: 1rem;
}

/* Tablet — 2 columns */
@media (max-width: 900px) {
  .lwm-stream-grid-inner {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile — 1 column */
@media (max-width: 580px) {
  .lwm-stream-grid-inner {
    grid-template-columns: 1fr;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ============================================================
   GALLERY PAGE (template-gallery.php) — matches home page design
   ============================================================ */
.lwm-gallery-page .entry,
.lwm-gallery-page .content-bg,
.lwm-gallery-page .entry-content-wrap,
.lwm-gallery-page .entry-content,
.lwm-gallery-page .lwm-gallery-inner {
  background: transparent !important;
  padding: 0 !important;
}

/* Eliminate white box — force dark on all gallery content wrappers */
.lwm-gallery-page .lwm-gallery-content .entry-content-wrap,
.lwm-gallery-page .lwm-gallery-content .entry-content,
.lwm-gallery-page article .entry-content-wrap,
body.page-template-template-gallery .entry-content-wrap,
body.page-template-template-gallery .content-bg {
  background: transparent !important;
  background-color: transparent !important;
}

/* Force center layout — override Kadence sidebar/grid when gallery template is used */
body.page-template-template-gallery #primary,
body.page-template-template-gallery .content-container,
body.page-template-template-gallery .content-area {
  display: block !important;
  max-width: 100% !important;
}

body.page-template-template-gallery .content-container.site-container {
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Center the entire gallery page content area */
body.page-template-template-gallery #inner-wrap,
body.page-template-template-gallery .wrap,
body.page-template-template-gallery main#inner-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

body.page-template-template-gallery .lwm-gallery-page,
body.page-template-template-gallery main.lwm-gallery-page {
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

body.page-template-template-gallery .lwm-gallery-page article {
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.lwm-gallery-hero {
  padding: clamp(4rem, 10vw, 7rem) var(--lwm-content-pad) 0.5rem;
  text-align: center;
}

.lwm-gallery-hero-inner {
  max-width: var(--lwm-content-max);
  margin: 0 auto;
}

.lwm-gallery-hero .lwm-section-label {
  margin-bottom: 0.75rem;
}

.lwm-gallery-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(2.5rem, 6vw, 5rem) !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.1;
  margin: 0 0 0.5rem;
}

.lwm-gallery-hero .lwm-divider {
  margin: 1rem auto 1.5rem;
}

.lwm-gallery-subtitle {
  color: var(--lwm-muted) !important;
  font-size: 1.1rem;
  max-width: 540px;
  margin: 0 auto;
}

.lwm-gallery-content {
  padding: 0.5rem var(--lwm-content-pad) clamp(4rem, 8vw, 6rem);
  width: 100%;
}

/* Centering wrapper — forces gallery to center regardless of parent layout */
.lwm-gallery-center {
  width: 100%;
  max-width: 100%;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.lwm-gallery-inner {
  max-width: var(--lwm-content-max);
  width: 100%;
  flex-shrink: 0;
}

.lwm-gallery-page .entry-content {
  text-align: center;
  width: 100%;
}

/* Center gallery block within content */
.lwm-gallery-page .entry-content-wrap {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* WordPress gallery block — no white bg, centered, dark theme styling */
.lwm-gallery-page .wp-block-gallery,
.lwm-gallery-page .wp-block-gallery.wp-block-gallery,
.lwm-gallery-page [class*="wp-block-gallery"] {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  --wp--style--block-gap: 1rem;
  gap: 1rem;
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: var(--lwm-content-max);
  width: 100%;
  background: transparent !important;
}

/* Override any Kadence/theme white background on gallery page blocks */
.lwm-gallery-page .wp-block-gallery figure,
.lwm-gallery-page .wp-block-image,
.lwm-gallery-page [class*="wp-block-"] {
  background: transparent !important;
}

.lwm-gallery-page .wp-block-gallery .wp-block-image,
.lwm-gallery-page .wp-block-gallery figure,
.lwm-gallery-page .blocks-gallery-grid .wp-block-image {
  margin: 0 !important;
}

.lwm-gallery-page .wp-block-gallery img,
.lwm-gallery-page .wp-block-image img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  border-radius: var(--lwm-radius);
  border: 1px solid var(--lwm-border);
  transition: border-color var(--lwm-transition), box-shadow var(--lwm-transition);
}

.lwm-gallery-page .wp-block-gallery img:hover,
.lwm-gallery-page .wp-block-image img:hover {
  border-color: var(--lwm-green);
  box-shadow: 0 0 0 2px rgba(0,230,118,0.3);
}

.lwm-gallery-page .wp-block-gallery figcaption,
.lwm-gallery-page .wp-block-image figcaption {
  font-family: 'Space Mono', monospace;
  font-size: 0.75rem;
  color: var(--lwm-muted);
  text-align: center;
  margin-top: 0.5rem;
}

/* Ensure gallery figures (nested structure) display */
.lwm-gallery-page .wp-block-gallery figure,
.lwm-gallery-page .wp-block-gallery .wp-block-image {
  display: block !important;
}

/* Single images in gallery content */
.lwm-gallery-page .wp-block-image {
  margin-bottom: 1.5rem;
}

.lwm-gallery-page p,
.lwm-gallery-page .entry-content p {
  color: var(--lwm-muted) !important;
}

.lwm-gallery-page h2,
.lwm-gallery-page h3 {
  color: var(--lwm-white) !important;
  margin-top: 2.5rem;
  margin-bottom: 1rem;
}

/* ============================================================
   YOUTUBE PAGE (template-youtube.php) — video grid / playlist
   ============================================================ */
.lwm-youtube-page .entry,
.lwm-youtube-page .content-bg,
.lwm-youtube-page .lwm-youtube-inner {
  background: transparent !important;
  padding: 0 !important;
}


.lwm-youtube-content {
  padding: 0.5rem var(--lwm-content-pad) clamp(4rem, 8vw, 6rem);
  width: 100%;
}

.lwm-youtube-center {
  width: 100%;
  max-width: 100%;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.lwm-youtube-inner {
  max-width: var(--lwm-content-max);
  width: 100%;
}

/* Video grid — responsive card layout */
.lwm-youtube-page .lwm-yt-grid,
.lwm-yt-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
  width: 100%;
}

/* Ensure grid cards don't get forced to full width by parent */
.lwm-youtube-page .lwm-yt-grid .lwm-yt-card,
.lwm-youtube-page .lwm-yt-grid .lwm-yt-card-page {
  min-width: 0;
}

.lwm-yt-card-page {
  background: var(--lwm-dark-2);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius-lg);
  overflow: hidden;
  transition: transform var(--lwm-transition), box-shadow var(--lwm-transition);
}

.lwm-yt-card-page:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 40px rgba(0,0,0,0.5);
}

.lwm-yt-card-page .lwm-yt-embed {
  background: #000;
}

.lwm-yt-card-body {
  padding: 1rem 1.25rem;
  background: var(--lwm-dark-3);
  border-top: 1px solid var(--lwm-border);
}

.lwm-yt-card-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.1rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.2;
  color: var(--lwm-white);
  margin: 0 0 0.35rem;
}

.lwm-yt-card-meta {
  font-family: 'Space Mono', monospace;
  font-size: 0.75rem;
  color: var(--lwm-muted);
  margin: 0;
}

.lwm-yt-playlist-fallback {
  max-width: 900px;
  margin: 0 auto;
}

.lwm-yt-playlist-note {
  font-size: 0.9rem;
  color: var(--lwm-muted);
  margin: 0;
}

.lwm-yt-empty {
  text-align: center;
  padding: 4rem 2rem;
  background: var(--lwm-dark-2);
  border: 1px dashed var(--lwm-border);
  border-radius: var(--lwm-radius-lg);
}

.lwm-yt-empty-text {
  color: var(--lwm-muted);
  margin: 0;
}

/* Force grid on YouTube template (beat Kadence overrides) */
body.page-template-template-youtube .lwm-yt-grid,
body.lwm-youtube-page .lwm-yt-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
}

/* ============================================================
   CONTACT PAGE (template-contact.php) — matches site design
   ============================================================ */
.lwm-contact-page .entry,
.lwm-contact-page .content-bg,
.lwm-contact-page .entry-content-wrap,
.lwm-contact-page .entry-content,
.lwm-contact-page .lwm-contact-inner {
  background: transparent !important;
  padding: 0 !important;
}

.lwm-contact-hero,
.lwm-book-lee-hero {
  padding: clamp(4rem, 10vw, 7rem) var(--lwm-content-pad) 0.5rem;
  text-align: center;
}

.lwm-contact-hero-inner,
.lwm-book-lee-hero-inner {
  max-width: var(--lwm-content-max);
  margin: 0 auto;
}

.lwm-contact-hero .lwm-section-label,
.lwm-book-lee-hero .lwm-section-label {
  margin-bottom: 0.75rem;
}

.lwm-contact-title,
.lwm-book-lee-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(2.5rem, 6vw, 5rem) !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.1;
  margin: 0 0 0.5rem;
}

.lwm-contact-hero .lwm-divider,
.lwm-book-lee-hero .lwm-divider {
  margin: 1rem auto 1.5rem;
}

.lwm-contact-subtitle,
.lwm-book-lee-subtitle {
  color: var(--lwm-muted) !important;
  font-size: 1.1rem;
  max-width: 540px;
  margin: 0 auto;
}

.lwm-contact-content,
.lwm-book-lee-content {
  padding: 0.5rem var(--lwm-content-pad) clamp(4rem, 8vw, 6rem);
  width: 100%;
}

/* Social bar — bottom of contact section */
.lwm-contact-social-wrap {
  display: flex;
  justify-content: center;
  padding: 2.5rem 0 1rem;
  width: 100%;
}

.lwm-contact-social-wrap .lwm-social-links {
  justify-content: center;
}

.lwm-contact-center,
.lwm-book-lee-center {
  width: 100%;
  max-width: 100%;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.lwm-contact-inner,
.lwm-book-lee-form-wrap {
  max-width: var(--lwm-content-max);
  width: 100%;
}

.lwm-contact-page .entry-content {
  text-align: left;
  width: 100%;
}

.lwm-contact-page p,
.lwm-contact-page .entry-content p {
  color: var(--lwm-muted) !important;
}

.lwm-contact-page h2,
.lwm-contact-page h3,
.lwm-contact-page .entry-content h2,
.lwm-contact-page .entry-content h3 {
  color: var(--lwm-white) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  margin-top: 2rem;
  margin-bottom: 1rem;
}

/* Contact Us form section heading — green */
.lwm-contact-page .entry-content h2:nth-of-type(2),
.lwm-contact-page .entry-content h2:last-of-type {
  color: var(--lwm-green) !important;
}

/* Contact Form 7 — submit button */
.lwm-contact-page .wpcf7-form input[type="submit"],
.lwm-contact-page .wpcf7-submit {
  background: var(--lwm-green) !important;
  color: #fff !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.1rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  border: 2px solid var(--lwm-green) !important;
  border-radius: var(--lwm-radius) !important;
  padding: 0.85rem 2rem !important;
  cursor: pointer !important;
  transition: all var(--lwm-transition) !important;
}

.lwm-contact-page .wpcf7-form input[type="submit"]:hover,
.lwm-contact-page .wpcf7-submit:hover {
  background: transparent !important;
  color: var(--lwm-green) !important;
}

/* Contact page — spacing for form p tags */
.lwm-contact-page .wpcf7-form p {
  margin-bottom: 1.25rem !important;
}

/* Force dark backgrounds on Contact template */
body.page-template-template-contact .entry-content-wrap,
body.page-template-template-contact .content-bg {
  background: transparent !important;
}

/* ============================================================
   SHOP ARCHIVE (custom categories: Physical CDs + Digital)
   ============================================================ */
.lwm-shop-page .entry,
.lwm-shop-page .content-bg {
  background: transparent !important;
  padding: 0 !important;
}

.lwm-shop-hero {
  padding: clamp(4rem, 10vw, 7rem) var(--lwm-content-pad) 0.5rem;
  text-align: center;
}

.lwm-shop-hero-inner {
  max-width: var(--lwm-content-max);
  margin: 0 auto;
}

.lwm-shop-hero .lwm-section-label {
  margin-bottom: 0.75rem;
}

.lwm-shop-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(2.5rem, 6vw, 5rem) !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.1;
  margin: 0 0 0.5rem;
}

.lwm-shop-hero .lwm-divider {
  margin: 1rem auto 1.5rem;
}

.lwm-shop-subtitle {
  color: var(--lwm-muted) !important;
  font-size: 1.1rem;
  max-width: 540px;
  margin: 0 auto;
}

/* Category sections */
.lwm-shop-category {
  padding: clamp(3rem, 6vw, 5rem) var(--lwm-content-pad);
}

.lwm-shop-category-inner {
  max-width: var(--lwm-content-max);
  margin: 0 auto;
}

.lwm-shop-category-header {
  margin-bottom: 2rem;
}

.lwm-shop-category-header .lwm-section-label {
  margin-bottom: 0.5rem;
}

.lwm-shop-category-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(2rem, 4vw, 3rem) !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin: 0 0 0.5rem;
  color: var(--lwm-white);
}

.lwm-shop-category-header .lwm-divider {
  margin: 0.75rem 0 0.5rem;
}

.lwm-shop-category-subtitle {
  font-family: 'Space Mono', monospace;
  font-size: 0.85rem;
  color: var(--lwm-muted);
  margin: 0;
}

/* Product grid — square images (like Stream page) */
.lwm-shop-page .lwm-shop-grid {
  display: grid !important;
  gap: 1.5rem;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Physical CDs: 3 across */
.lwm-shop-page .lwm-shop-grid-physical {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* Digital: keeps same base grid (inherits from media queries below) */
.lwm-shop-page .lwm-shop-grid-digital {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.lwm-shop-page .lwm-shop-grid .product {
  display: flex !important;
  flex-direction: column !important;
  margin: 0 !important;
}

/* Square product images (matches Stream page album art) */
.lwm-shop-page .lwm-shop-grid .product a img,
.lwm-shop-page .lwm-shop-grid .product .woocommerce-loop-product__link img {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 1 !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
}

.lwm-shop-page .lwm-shop-grid .product .woocommerce-loop-product__link {
  display: block !important;
  overflow: hidden !important;
  border-radius: var(--lwm-radius-lg) var(--lwm-radius-lg) 0 0;
  aspect-ratio: 1;
  background: var(--lwm-dark-3);
}

.lwm-shop-page .lwm-shop-grid .product .woocommerce-loop-product__link img {
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 1 !important;
}

/* Product card body */
.lwm-shop-page .lwm-shop-grid .product .woocommerce-loop-product__title {
  padding: 1rem 1rem 0.25rem !important;
}

.lwm-shop-page .lwm-shop-grid .product .price {
  padding: 0 1rem !important;
  margin-top: 0.25rem !important;
}

.lwm-shop-page .lwm-shop-grid .product .button {
  margin: 0.75rem 1rem 1rem !important;
}

@media (max-width: 900px) {
  .lwm-shop-page .lwm-shop-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 580px) {
  .lwm-shop-page .lwm-shop-grid {
    grid-template-columns: 1fr;
    max-width: 320px;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* ============================================================
   SINGLE PRODUCT — Redesign: elegant, large image, full-width buttons
   ============================================================ */
.lwm-single-product-page .entry,
.lwm-single-product-page .content-bg {
  background: transparent !important;
  padding: 0 !important;
}

.lwm-product-hero {
  padding: clamp(4rem, 10vw, 7rem) var(--lwm-content-pad) 0.5rem;
  text-align: center;
}

.lwm-product-hero-inner {
  max-width: var(--lwm-content-max);
  margin: 0 auto;
}

.lwm-product-hero .lwm-section-label {
  margin-bottom: 0.75rem;
}

.lwm-product-hero-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(2.5rem, 6vw, 5rem) !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.1;
  margin: 0 0 0.5rem;
  color: var(--lwm-white);
}

.lwm-product-hero .lwm-divider {
  margin: 1rem auto 1.5rem;
}

.lwm-product-hero-subtitle {
  color: var(--lwm-muted) !important;
  font-size: 1.1rem;
}

.lwm-product-content {
  padding: clamp(3rem, 6vw, 5rem) var(--lwm-content-pad);
}

.lwm-product-content-inner {
  max-width: 1280px;
  margin: 0 auto;
}

/* Breadcrumbs — readable, legible */
.lwm-single-product-page .woocommerce-breadcrumb {
  font-family: 'Space Mono', monospace !important;
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--lwm-muted) !important;
  padding: 0 0 2rem;
  margin: 0 !important;
}

.lwm-single-product-page .woocommerce-breadcrumb a {
  color: var(--lwm-blue) !important;
  font-weight: 500;
}

.lwm-single-product-page .woocommerce-breadcrumb a:hover {
  color: var(--lwm-green) !important;
}

/* Two columns — large gallery (65%) | summary (35%) */
.lwm-single-product-page .lwm-product-layout {
  display: grid;
  grid-template-columns: 1.5fr 0.9fr;
  gap: clamp(2.5rem, 5vw, 4rem);
  align-items: start;
}

/* Gallery — large image, rounded corners, lightbox-ready */
.lwm-single-product-page .woocommerce-product-gallery {
  position: relative;
  border-radius: var(--lwm-radius-lg);
  overflow: hidden;
  border: 1px solid var(--lwm-border);
  background: var(--lwm-dark-3);
  box-shadow: var(--lwm-shadow);
}

/* Disable default zoom icon overlay — we use lightbox instead */
.lwm-single-product-page .woocommerce-product-gallery__trigger {
  display: none !important;
}

.lwm-single-product-page .woocommerce-product-gallery__wrapper,
.lwm-single-product-page .woocommerce-product-gallery__image {
  aspect-ratio: 1 !important;
  border-radius: var(--lwm-radius-lg);
}

.lwm-single-product-page .woocommerce-product-gallery img,
.lwm-single-product-page .woocommerce-product-gallery .wp-post-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.lwm-single-product-page .onsale {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 10;
  background: var(--lwm-green) !important;
  color: #fff !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.08em;
  padding: 0.35rem 0.75rem;
  border-radius: 8px;
}

/* Summary — purchase block */
.lwm-single-product-page .summary.entry-summary {
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.lwm-single-product-page .summary .product_title {
  display: none !important;
}

.lwm-single-product-page .summary .price {
  color: var(--lwm-green) !important;
  font-size: 2rem !important;
  font-weight: 700 !important;
  margin: 0 !important;
}

.lwm-single-product-page .summary .woocommerce-product-details__short-description,
.lwm-single-product-page .summary .woocommerce-product-details__short-description p {
  color: var(--lwm-muted) !important;
  font-size: 1rem;
  margin-bottom: 0 !important;
}

/* Form cart — full-width layout */
.lwm-single-product-page .summary .form.cart {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 1rem !important;
  margin: 0 !important;
}

.lwm-single-product-page .summary .form.cart .quantity {
  margin: 0 !important;
  max-width: 6rem;
}

.lwm-single-product-page .summary .quantity input {
  background: var(--lwm-dark-3) !important;
  border: 1px solid var(--lwm-border) !important;
  color: var(--lwm-white) !important;
  font-family: 'Space Mono', monospace !important;
  padding: 0.6rem 0.75rem;
  width: 100%;
  text-align: center;
  border-radius: var(--lwm-radius);
}

/* Add to Cart — full width, green CTA */
.lwm-single-product-page .summary button.single_add_to_cart_button {
  width: 100% !important;
  background: var(--lwm-green) !important;
  color: #fff !important;
  border: 2px solid var(--lwm-green) !important;
  text-align: center !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.15rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  padding: 1rem 1.5rem !important;
  border-radius: var(--lwm-radius) !important;
  transition: all var(--lwm-transition) !important;
}

.lwm-single-product-page .summary button.single_add_to_cart_button:hover {
  background: transparent !important;
  color: var(--lwm-green) !important;
}

/* Express checkout (WooPay, G Pay) — full width */
.lwm-single-product-page .summary .wcpay-payment-request-button-wrapper,
.lwm-single-product-page .summary [id*="wcpay-payment-request"],
.lwm-single-product-page .summary .wc-block-components-payment-method-icons,
.lwm-single-product-page .summary [class*="payment-request-button"],
.lwm-single-product-page .summary .wc-block-components-express-payment,
.lwm-single-product-page .summary .payment_request_button {
  width: 100% !important;
}

.lwm-single-product-page .summary .wcpay-payment-request-button-wrapper iframe,
.lwm-single-product-page .summary [class*="payment-request"] iframe,
.lwm-single-product-page .summary [id*="wcpay"] iframe {
  width: 100% !important;
  min-height: 48px !important;
}

.lwm-single-product-page .summary .variations label {
  font-family: 'Space Mono', monospace !important;
  color: var(--lwm-muted);
}

.lwm-single-product-page .summary .variations select {
  background: var(--lwm-dark-3) !important;
  border: 1px solid var(--lwm-border) !important;
  color: var(--lwm-white);
  border-radius: var(--lwm-radius);
  padding: 0.5rem 0.75rem;
  width: 100%;
}

.lwm-single-product-page .summary .product_meta {
  margin-top: 0;
  padding-top: 1.5rem;
  border-top: 1px solid var(--lwm-border);
}

.lwm-single-product-page .summary .product_meta,
.lwm-single-product-page .summary .product_meta a {
  color: var(--lwm-muted) !important;
  font-family: 'Space Mono', monospace !important;
  font-size: 0.9rem;
}

.lwm-single-product-page .summary .product_meta a:hover {
  color: var(--lwm-green) !important;
}

/* Summary links — readable */
.lwm-single-product-page .summary a:not(.single_add_to_cart_button) {
  color: var(--lwm-blue) !important;
}

.lwm-single-product-page .summary a:not(.single_add_to_cart_button):hover {
  color: var(--lwm-green) !important;
}

/* Tabs */
.lwm-single-product-page .woocommerce-tabs {
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid var(--lwm-border);
}

.lwm-single-product-page .woocommerce-tabs ul.tabs {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 1.5rem !important;
  display: flex;
  gap: 1.5rem;
  border-bottom: 1px solid var(--lwm-border);
}

.lwm-single-product-page .woocommerce-tabs ul.tabs li {
  margin: 0 !important;
}

.lwm-single-product-page .woocommerce-tabs ul.tabs li a {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1rem !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--lwm-muted) !important;
  padding: 0.75rem 0;
}

.lwm-single-product-page .woocommerce-tabs ul.tabs li.active a {
  color: var(--lwm-green) !important;
  border-bottom: 3px solid var(--lwm-green);
}

.lwm-single-product-page .woocommerce-Tabs-panel {
  color: var(--lwm-muted);
}

.lwm-single-product-page .woocommerce-Tabs-panel h2 {
  display: none;
}

/* ============================================================
   RELATED PRODUCTS — Horizontal scroll carousel
   ============================================================ */
.lwm-related-carousel {
  margin-top: 2.5rem;
  padding: 0 var(--lwm-content-pad);
}

.lwm-related-carousel__title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.5rem !important;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 1.5rem !important;
  color: var(--lwm-white);
}

.lwm-related-carousel__wrap {
  position: relative;
  max-width: var(--lwm-content-max);
  margin: 0 auto;
}

.lwm-related-carousel__prev,
.lwm-related-carousel__next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--lwm-dark-3);
  border: 1px solid var(--lwm-border);
  color: var(--lwm-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color var(--lwm-transition), border-color var(--lwm-transition);
}

.lwm-related-carousel__prev:hover,
.lwm-related-carousel__next:hover {
  color: var(--lwm-green);
  border-color: var(--lwm-green);
}

.lwm-related-carousel__prev {
  left: -24px;
}

.lwm-related-carousel__next {
  right: -24px;
}

.lwm-related-carousel__track {
  display: flex;
  gap: 1.5rem;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 0.5rem 0 1rem;
}

.lwm-related-carousel__track::-webkit-scrollbar {
  display: none;
}

.lwm-related-carousel__slide {
  flex: 0 0 260px;
  scroll-snap-align: start;
  background: var(--lwm-dark-2);
  border: 1px solid var(--lwm-border);
  border-radius: var(--lwm-radius-lg);
  overflow: hidden;
}

.lwm-related-carousel__img-wrap {
  display: block;
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--lwm-dark-3);
}

.lwm-related-carousel__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.lwm-related-carousel__info {
  padding: 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.lwm-related-carousel__name {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.1rem !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin: 0 !important;
  color: var(--lwm-white);
  line-height: 1.2;
}

.lwm-related-carousel__price {
  color: var(--lwm-green);
  font-weight: 700;
}

.lwm-related-carousel__price del {
  color: var(--lwm-muted);
}

/* Add to cart — simple link, color change only on hover */
.lwm-related-carousel__btn {
  display: inline-block;
  margin-top: 0.25rem;
  font-family: 'Space Mono', monospace !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--lwm-blue);
  transition: color var(--lwm-transition);
}

.lwm-related-carousel__btn:hover {
  color: var(--lwm-green);
}

@media (max-width: 900px) {
  .lwm-single-product-page .lwm-product-layout {
    grid-template-columns: 1fr;
  }
  .lwm-single-product-page .woocommerce-product-gallery {
    max-width: 520px;
    margin: 0 auto;
  }
  .lwm-related-carousel__slide {
    flex: 0 0 220px;
  }
}

@media (max-width: 580px) {
  .lwm-related-carousel__slide {
    flex: 0 0 180px;
  }
}

/* Upsells — prevent global hover transform if present */
.lwm-single-product-page .upsells.products .product:hover {
  transform: none !important;
}

/* ============================================================
   SINGLE PRODUCT — TARGETED FIXES
   All selectors use main.lwm-single-product-page because
   that class lives on <main>, not <body>.
   ============================================================ */

/* 1. Kill teal hero */
main.lwm-single-product-page .lwm-product-hero,
main.lwm-single-product-page .lwm-product-hero.lwm-bg-dark-3,
main.lwm-single-product-page .lwm-bg-dark-3 {
  background: var(--lwm-dark) !important;
  background-color: var(--lwm-dark) !important;
}

/* 2. Gallery — capped square, green glow */
main.lwm-single-product-page .woocommerce-product-gallery {
  width: 100% !important;
  max-width: 480px !important;
  aspect-ratio: 1 / 1 !important;
  overflow: hidden !important;
  border: 1px solid var(--lwm-green) !important;
  box-shadow: 0 0 40px rgba(0,230,118,0.12), 0 0 80px rgba(0,230,118,0.05) !important;
  background: var(--lwm-dark-2) !important;
  border-radius: var(--lwm-radius-lg) !important;
  position: relative !important;
}

main.lwm-single-product-page .woocommerce-product-gallery .woocommerce-product-gallery__wrapper,
main.lwm-single-product-page .woocommerce-product-gallery .flex-viewport,
main.lwm-single-product-page .woocommerce-product-gallery .woocommerce-product-gallery__image,
main.lwm-single-product-page .woocommerce-product-gallery ol,
main.lwm-single-product-page .woocommerce-product-gallery li {
  width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
}

main.lwm-single-product-page .woocommerce-product-gallery img,
main.lwm-single-product-page .woocommerce-product-gallery .wp-post-image {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
}

/* 3. Summary column — kill Kadence's float: right that collapses it to 173px */
main.lwm-single-product-page .summary.entry-summary {
  float: none !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

/* 4. PURCHASE BLOCK — styled container matching the original mockup
   form.cart = top of box (border top/left/right)
   wcpay wrapper = bottom of box (border left/right/bottom)
   ──────────────────────────────────────────────────────────── */
main.lwm-single-product-page .summary form.cart {
  float: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  padding: 1.75rem !important;
  background: var(--lwm-dark-2) !important;
  border: 1px solid var(--lwm-border) !important;
  border-bottom: none !important;
  border-radius: var(--lwm-radius) var(--lwm-radius) 0 0 !important;
  margin: 0 !important;
}

/* 5. QTY row — "Qty" label left + small input right, NOT full-width stacked */
main.lwm-single-product-page .summary form.cart .quantity,
main.lwm-single-product-page .summary form.cart div.quantity {
  float: none !important;
  width: auto !important;
  max-width: 100% !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 0 !important;
}

main.lwm-single-product-page .summary form.cart .quantity::before {
  content: 'Qty' !important;
  font-family: 'Space Mono', monospace !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--lwm-muted) !important;
  flex-shrink: 0 !important;
  width: 36px !important;
}

main.lwm-single-product-page .summary form.cart .quantity input.qty {
  width: 80px !important;
  max-width: 80px !important;
  height: 44px !important;
  float: none !important;
  background: var(--lwm-dark-3) !important;
  border: 1px solid var(--lwm-border) !important;
  border-radius: var(--lwm-radius) !important;
  color: var(--lwm-white) !important;
  font-family: 'Space Mono', monospace !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  text-align: center !important;
  padding: 0.25rem !important;
  box-sizing: border-box !important;
  -moz-appearance: textfield !important;
  appearance: textfield !important;
}

/* Kill number spinners and autofill/password-manager triggers on qty input */
main.lwm-single-product-page .quantity input.qty::-webkit-inner-spin-button,
main.lwm-single-product-page .quantity input.qty::-webkit-outer-spin-button {
  -webkit-appearance: none !important;
  appearance: none !important;
  margin: 0 !important;
  display: none !important;
}
main.lwm-single-product-page .quantity input.qty::-webkit-contacts-auto-fill-button,
main.lwm-single-product-page .quantity input.qty::-webkit-credentials-auto-fill-button,
main.lwm-single-product-page .quantity input.qty::-webkit-strong-password-auto-fill-button,
main.lwm-single-product-page .quantity input.qty::-webkit-caps-lock-indicator {
  visibility: hidden !important;
  display: none !important;
  pointer-events: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
}

/* 6. ADD TO CART button */
main.lwm-single-product-page .summary button.single_add_to_cart_button,
main.lwm-single-product-page .summary form.cart button[type="submit"] {
  float: none !important;
  width: 100% !important;
  height: 52px !important;
  box-sizing: border-box !important;
  background: var(--lwm-green) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--lwm-radius) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.15rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  gap: 10px !important;
  line-height: 1 !important;
  overflow: visible !important;
  visibility: visible !important;
  opacity: 1 !important;
  transition: background 0.2s, transform 0.1s !important;
}

main.lwm-single-product-page .summary button.single_add_to_cart_button::before {
  content: '🛒' !important;
  font-size: 1rem !important;
  line-height: 1 !important;
}

main.lwm-single-product-page .summary button.single_add_to_cart_button:hover,
main.lwm-single-product-page .summary form.cart button[type="submit"]:hover {
  background: #00e85c !important;
  transform: translateY(-1px) !important;
}

/* 7. Payment wrapper — bottom half of purchase box.
   Button alignment: paste snippet from ADDITIONAL_CSS_BUTTON_ALIGNMENT.txt into Customizer > Additional CSS. */
main.lwm-single-product-page .wcpay-express-checkout-wrapper {
  float: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
  background: var(--lwm-dark-2) !important;
  border: 1px solid var(--lwm-border) !important;
  border-top: none !important;
  border-radius: 0 0 var(--lwm-radius) var(--lwm-radius) !important;
  padding: 1rem 1.75rem 1.25rem !important;
  margin: 0 !important;
}

main.lwm-single-product-page .wcpay-express-checkout-wrapper::before {
  content: 'or pay with' !important;
  display: block !important;
  font-family: 'Space Mono', monospace !important;
  font-size: 0.6rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--lwm-muted) !important;
  text-align: center !important;
  padding-bottom: 0.25rem !important;
}

main.lwm-single-product-page .wcpay-express-checkout-wrapper wc-order-attribution-inputs {
  display: none !important;
}

main.lwm-single-product-page .wcpay-express-checkout-wrapper::after {
  content: '🔒 Secure checkout' !important;
  display: block !important;
  font-family: 'Space Mono', monospace !important;
  font-size: 0.6rem !important;
  letter-spacing: 0.08em !important;
  color: #555555 !important;
  text-align: center !important;
  text-transform: uppercase !important;
  padding-top: 0.5rem !important;
}

/* Hide PayPal BNPL messaging — clutters the design */
main.lwm-single-product-page .ppcp-messages {
  display: none !important;
}

/* 8. Track listing — "Track Listing" heading (first p or explicit class) */
main.lwm-single-product-page .woocommerce-Tabs-panel--description p:first-of-type,
main.lwm-single-product-page .woocommerce-Tabs-panel--description .lwm-track-listing-heading {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.5rem !important;
  letter-spacing: 0.06em !important;
  color: var(--lwm-white) !important;
  border-left: 3px solid var(--lwm-green) !important;
  padding-left: 0.75rem !important;
  margin-bottom: 1.25rem !important;
  text-transform: uppercase !important;
}

/* Track listing — <ol> format */
main.lwm-single-product-page .woocommerce-Tabs-panel--description ol,
main.lwm-single-product-page .lwm-track-listing ol {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  border: 1px solid var(--lwm-border) !important;
  border-radius: var(--lwm-radius) !important;
  overflow: hidden !important;
  counter-reset: track-counter !important;
}

main.lwm-single-product-page .woocommerce-Tabs-panel--description ol li,
main.lwm-single-product-page .lwm-track-listing ol li {
  list-style: none !important;
  display: flex !important;
  align-items: center !important;
  gap: 1rem !important;
  padding: 0.9rem 1.25rem !important;
  border-bottom: 1px solid var(--lwm-border) !important;
  border-right: 1px solid var(--lwm-border) !important;
  background: var(--lwm-dark) !important;
  color: var(--lwm-white) !important;
  font-size: 0.95rem !important;
  counter-increment: track-counter !important;
  transition: background var(--lwm-transition) !important;
}

main.lwm-single-product-page .woocommerce-Tabs-panel--description ol li:hover,
main.lwm-single-product-page .lwm-track-listing ol li:hover {
  background: var(--lwm-dark-2) !important;
}

main.lwm-single-product-page .woocommerce-Tabs-panel--description ol li:nth-child(even),
main.lwm-single-product-page .lwm-track-listing ol li:nth-child(even) {
  border-right: none !important;
}

main.lwm-single-product-page .woocommerce-Tabs-panel--description ol li::before,
main.lwm-single-product-page .lwm-track-listing ol li::before {
  content: counter(track-counter, decimal-leading-zero) !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 1.4rem !important;
  color: var(--lwm-green) !important;
  opacity: 0.7 !important;
  min-width: 28px !important;
  line-height: 1 !important;
}

/* Track listing — plain <p> format (legacy, only direct-child p when no ol) */
main.lwm-single-product-page .woocommerce-Tabs-panel--description > p:not(:first-of-type) {
  padding: 0.7rem 1.25rem !important;
  border-bottom: 1px solid var(--lwm-border) !important;
  color: var(--lwm-white) !important;
  font-size: 0.95rem !important;
  margin: 0 !important;
  background: var(--lwm-dark) !important;
  transition: background var(--lwm-transition) !important;
}

main.lwm-single-product-page .woocommerce-Tabs-panel--description > p:not(:first-of-type):hover {
  background: var(--lwm-dark-2) !important;
}

/* Product description — wrap controls gap between intro and track grid */
main.lwm-single-product-page .lwm-product-description-wrap {
  display: flex !important;
  flex-direction: column !important;
  gap: 1rem !important;
}

main.lwm-single-product-page .lwm-product-description-wrap > * {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* Intro text before track listing */
main.lwm-single-product-page .lwm-product-description-intro p,
main.lwm-single-product-page .lwm-product-description-intro span {
  display: block !important;
  color: var(--lwm-muted) !important;
  margin-bottom: 0.75rem !important;
}

main.lwm-single-product-page .lwm-product-description-intro p:last-child,
main.lwm-single-product-page .lwm-product-description-intro span:last-child {
  margin-bottom: 0 !important;
}

/* Kill block editor spacing inside intro (fixes Abstractions gap) */
main.lwm-single-product-page .lwm-product-description-intro [class*="wp-block"] {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* Hide empty intro wrapper (e.g. when product has only tracks) */
main.lwm-single-product-page .lwm-product-description-wrap .lwm-product-description-intro:empty {
  display: none !important;
}