/*
 * LED Lounge — Product Slider Styles
 * Brand: #0A0A0A · #00CFFF · #FF4DDB · #9D4EDD
 * Fonts: Montserrat (headings) · Inter (body)
 */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@600;700;800&family=Inter:wght@400;500;600&display=swap');

/* ── CSS Variables ─────────────────────────────────────── */
:root {
  --llr-cyan:       #00CFFF;
  --llr-pink:       #FF4DDB;
  --llr-purple:     #9D4EDD;
  --llr-gray:       #C8CCD0;
  --llr-bg:         #0A0A0A;
  --llr-surface:    #111118;
  --llr-surface2:   #18181f;
  --llr-border:     rgba(0,207,255,.14);
  --llr-text:       #F8F9FA;
  --llr-muted:      #8a8fa8;
  --llr-radius:     14px;
  --llr-radius-sm:  8px;
  --llr-shadow:     0 8px 40px rgba(0,0,0,.55);
  --llr-glow-cyan:  0 0 30px rgba(0,207,255,.35);
  --llr-glow-pink:  0 0 30px rgba(255,77,219,.35);
  --llr-transition: .22s cubic-bezier(.4,0,.2,1);
  --llr-card-w:     300px;
}

/* ── Wrapper ─────────────────────────────────────────────── */
.llr-slider-wrap,
.llr-cats-wrap {
  font-family: 'Inter', 'Segoe UI', sans-serif;
  color: var(--llr-text);
  margin: 48px 0;
  position: relative;
}

/* ── Section header ──────────────────────────────────────── */
.llr-slider-header {
  text-align: center;
  margin-bottom: 36px;
  position: relative;
}
.llr-slider-title {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  margin: 0 0 10px;
  background: linear-gradient(135deg, #fff 30%, var(--llr-cyan) 70%, var(--llr-purple) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -.02em;
}
.llr-slider-subtitle {
  font-size: 1rem;
  color: var(--llr-muted);
  margin: 0;
  font-weight: 400;
}
/* Decorative line under title */
.llr-slider-header::after {
  content: '';
  display: block;
  width: 60px;
  height: 3px;
  background: linear-gradient(90deg, var(--llr-cyan), var(--llr-pink));
  border-radius: 2px;
  margin: 18px auto 0;
}

/* ═══════════════════════════════════════════════════════════
   PRODUCT CARD
═══════════════════════════════════════════════════════════ */
.llr-product-card {
  background: var(--llr-surface);
  border: 1px solid var(--llr-border);
  border-radius: var(--llr-radius);
  overflow: hidden;
  transition: transform var(--llr-transition), box-shadow var(--llr-transition), border-color var(--llr-transition);
  width: var(--llr-card-w);
  flex-shrink: 0;
  position: relative;
  will-change: transform;
}
.llr-product-card:hover {
  transform: translateY(-6px);
  border-color: rgba(0,207,255,.35);
  box-shadow: var(--llr-shadow), var(--llr-glow-cyan);
}

/* ── Card media ──────────────────────────────────────────── */
.llr-card-media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
}
.llr-card-img {
  width: 100%; height: 100%;
  background-size: cover;
  background-position: center;
  transition: transform .55s cubic-bezier(.4,0,.2,1);
  position: relative;
}
.llr-card-img-hover {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity .4s ease;
}
.llr-product-card:hover .llr-card-img { transform: scale(1.06); }
.llr-product-card:hover .llr-card-img-hover { opacity: 1; }

/* Glow ring on hover */
.llr-card-glow-ring {
  position: absolute; inset: 0;
  border-radius: inherit;
  opacity: 0;
  background: radial-gradient(ellipse at 50% 110%, rgba(0,207,255,.25) 0%, transparent 65%);
  transition: opacity var(--llr-transition);
  pointer-events: none;
}
.llr-product-card:hover .llr-card-glow-ring { opacity: 1; }

/* Dark gradient overlay */
.llr-card-media::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(10,10,10,.75) 0%, transparent 55%);
  pointer-events: none;
}

/* Badge */
.llr-card-badge {
  position: absolute;
  top: 12px; left: 12px;
  z-index: 3;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 10px;
  border-radius: 20px;
}
.llr-badge-featured { background: rgba(0,207,255,.18); border: 1px solid rgba(0,207,255,.4); color: var(--llr-cyan); }
.llr-badge-new      { background: rgba(157,78,221,.18); border: 1px solid rgba(157,78,221,.4); color: var(--llr-purple); }
.llr-badge-low      { background: rgba(255,77,219,.18); border: 1px solid rgba(255,77,219,.4); color: var(--llr-pink); }

/* Category chip */
.llr-card-category {
  position: absolute;
  bottom: 12px; left: 12px;
  z-index: 3;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(255,255,255,.65);
  background: rgba(0,0,0,.4);
  padding: 3px 8px;
  border-radius: 4px;
  backdrop-filter: blur(4px);
}

/* Quick view button */
.llr-qv-btn {
  position: absolute;
  top: 12px; right: 12px;
  z-index: 3;
  width: 34px; height: 34px;
  border-radius: 50%;
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  opacity: 0;
  transform: scale(.85) translateY(-4px);
  transition: opacity var(--llr-transition), transform var(--llr-transition), background var(--llr-transition);
  backdrop-filter: blur(6px);
}
.llr-product-card:hover .llr-qv-btn {
  opacity: 1;
  transform: scale(1) translateY(0);
}
.llr-qv-btn:hover { background: var(--llr-cyan); border-color: var(--llr-cyan); color: #0a0a0a; }

/* ── Card body ───────────────────────────────────────────── */
.llr-card-body {
  padding: 18px 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.llr-card-title {
  margin: 0;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.3;
}
.llr-card-title a {
  color: var(--llr-text);
  text-decoration: none;
  transition: color var(--llr-transition);
}
.llr-card-title a:hover { color: var(--llr-cyan); }
.llr-card-desc {
  font-size: .8rem;
  color: var(--llr-muted);
  margin: 0;
  line-height: 1.5;
  flex: 1;
}
.llr-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 4px;
  flex-wrap: wrap;
}
.llr-card-price {
  display: flex;
  align-items: baseline;
  gap: 3px;
}
.llr-price-amount {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--llr-cyan);
}
.llr-price-unit {
  font-size: .75rem;
  color: var(--llr-muted);
}
/* WC price override inside card */
.llr-card-price .woocommerce-Price-amount { color: var(--llr-cyan); font-weight: 700; }

/* ── CTA buttons ─────────────────────────────────────────── */
.llr-card-cta {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .78rem;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 40px;
  text-decoration: none;
  transition: all var(--llr-transition);
  white-space: nowrap;
}
.llr-cta-primary {
  background: linear-gradient(135deg, var(--llr-cyan), var(--llr-purple));
  color: #fff;
  box-shadow: 0 4px 18px rgba(0,207,255,.25);
}
.llr-cta-primary:hover {
  box-shadow: 0 6px 24px rgba(0,207,255,.45);
  transform: translateY(-1px);
  color: #fff;
}
.llr-cta-outline {
  border: 1.5px solid var(--llr-cyan);
  color: var(--llr-cyan);
  background: transparent;
}
.llr-cta-outline:hover { background: rgba(0,207,255,.1); color: var(--llr-cyan); }
.llr-cta-ghost {
  color: var(--llr-muted);
  background: rgba(255,255,255,.05);
}
.llr-cta-ghost:hover { color: var(--llr-text); background: rgba(255,255,255,.1); }

/* ── Card style: neon ────────────────────────────────────── */
.llr-card-style-neon {
  background: transparent;
  border: 1px solid rgba(0,207,255,.25);
  box-shadow: inset 0 0 30px rgba(0,207,255,.04), 0 0 0 1px rgba(0,207,255,.1);
}
.llr-card-style-neon:hover {
  box-shadow: 0 0 0 1px var(--llr-cyan), 0 0 40px rgba(0,207,255,.2);
}
/* ── Card style: minimal ─────────────────────────────────── */
.llr-card-style-minimal {
  background: transparent;
  border: none;
  border-radius: 0;
}
.llr-card-style-minimal .llr-card-body { padding: 14px 0; }
.llr-card-style-minimal:hover { transform: translateY(-3px); box-shadow: none; }

/* ═══════════════════════════════════════════════════════════
   SLIDER LAYOUT
═══════════════════════════════════════════════════════════ */
.llr-slider-stage {
  position: relative;
  overflow: hidden;
}
.llr-slider-track {
  display: flex;
  gap: 24px;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
  will-change: transform;
  padding: 8px 4px 16px;  /* room for hover shadow */
}

/* Arrows */
.llr-slider-arrow {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  z-index: 10;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(10,10,10,.85);
  border: 1px solid var(--llr-border);
  color: var(--llr-cyan);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all var(--llr-transition);
  backdrop-filter: blur(8px);
}
.llr-arrow-prev { left: -16px; }
.llr-arrow-next { right: -16px; }
.llr-slider-arrow:hover {
  background: var(--llr-cyan);
  color: #0a0a0a;
  border-color: var(--llr-cyan);
  box-shadow: var(--llr-glow-cyan);
}
.llr-slider-arrow.disabled { opacity: .35; pointer-events: none; }

/* Dots */
.llr-slider-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 20px;
}
.llr-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,.2);
  cursor: pointer;
  transition: all var(--llr-transition);
}
.llr-dot.active {
  width: 22px;
  border-radius: 3px;
  background: var(--llr-cyan);
}

/* ═══════════════════════════════════════════════════════════
   GRID LAYOUT
═══════════════════════════════════════════════════════════ */
.llr-product-grid {
  display: grid;
  gap: 24px;
}
.llr-product-grid .llr-product-card { width: 100%; }
.llr-grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.llr-grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.llr-grid-cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ═══════════════════════════════════════════════════════════
   CATEGORY CARDS
═══════════════════════════════════════════════════════════ */
.llr-cats-stage { position: relative; overflow: hidden; }
.llr-cats-track {
  display: flex;
  gap: 18px;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
  padding: 6px 4px 12px;
}
.llr-cats-track.llr-grid-cols-2,
.llr-cats-track.llr-grid-cols-3,
.llr-cats-track.llr-grid-cols-4 {
  display: grid;
  gap: 18px;
}
.llr-cat-card {
  flex-shrink: 0;
  width: 220px;
  border-radius: var(--llr-radius);
  overflow: hidden;
  text-decoration: none;
  color: var(--llr-text);
  border: 1px solid var(--llr-border);
  background: var(--llr-surface);
  transition: transform var(--llr-transition), border-color var(--llr-transition), box-shadow var(--llr-transition);
  position: relative;
  display: block;
}
.llr-cats-track.llr-grid-cols-2 .llr-cat-card,
.llr-cats-track.llr-grid-cols-3 .llr-cat-card,
.llr-cats-track.llr-grid-cols-4 .llr-cat-card { width: 100%; }
.llr-cat-card:hover {
  transform: translateY(-5px);
  border-color: rgba(157,78,221,.45);
  box-shadow: 0 12px 40px rgba(0,0,0,.45), 0 0 30px rgba(157,78,221,.2);
}
.llr-cat-img {
  aspect-ratio: 16/9;
  background-size: cover;
  background-position: center;
  position: relative;
  transition: transform .55s ease;
}
.llr-cat-card:hover .llr-cat-img { transform: scale(1.05); }
.llr-cat-glow {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(10,10,10,.8) 0%, transparent 60%);
}
.llr-cat-info {
  padding: 14px 16px 10px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.llr-cat-name {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: .95rem;
}
.llr-cat-count { font-size: .75rem; color: var(--llr-muted); }
.llr-cat-arrow {
  position: absolute;
  bottom: 14px; right: 16px;
  color: var(--llr-purple);
  font-size: 1.1rem;
  opacity: 0;
  transform: translateX(-4px);
  transition: all var(--llr-transition);
}
.llr-cat-card:hover .llr-cat-arrow { opacity: 1; transform: translateX(0); }

/* ═══════════════════════════════════════════════════════════
   HERO SECTION
═══════════════════════════════════════════════════════════ */
.llr-hero {
  position: relative;
  min-height: 85vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  background: var(--llr-bg);
  margin: 0;
}

/* Background image slides */
.llr-hero-bg { position: absolute; inset: 0; z-index: 0; }
.llr-hero-bg-slide {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.2s ease;
  transform: scale(1.04);
  animation: llr-ken-burns 8s ease-in-out infinite alternate;
}
.llr-hero-bg-slide.active { opacity: 1; }
@keyframes llr-ken-burns { from { transform: scale(1); } to { transform: scale(1.08); } }
.llr-hero-overlay {
  position: absolute; inset: 0;
  background: var(--llr-bg);
}

/* Particles */
.llr-hero-particles {
  position: absolute; inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}
.llr-particle {
  position: absolute;
  width: 2px; height: 2px;
  border-radius: 50%;
  animation: llr-float linear infinite;
}
@keyframes llr-float {
  0%   { transform: translateY(100vh) scale(0); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translateY(-10vh) scale(1); opacity: 0; }
}

/* Content */
.llr-hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 60px 24px 120px;
  max-width: 800px;
  width: 100%;
}
.llr-hero-logo-mark {
  display: flex;
  justify-content: center;
  margin-bottom: 24px;
  opacity: .7;
}
.llr-hero-headline {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: clamp(2.4rem, 6vw, 4.5rem);
  line-height: 1.1;
  margin: 0 0 18px;
  letter-spacing: -.03em;
  color: #fff;
}
.llr-hero-headline span {
  background: linear-gradient(135deg, var(--llr-cyan), var(--llr-pink));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.llr-hero-subline {
  font-size: clamp(1rem, 2vw, 1.2rem);
  color: rgba(255,255,255,.65);
  margin: 0 0 36px;
  font-weight: 400;
}
.llr-hero-ctas {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}
.llr-btn-hero {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 50px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: .95rem;
  text-decoration: none;
  letter-spacing: .02em;
  transition: all var(--llr-transition);
}
.llr-btn-hero-primary {
  background: linear-gradient(135deg, var(--llr-cyan), var(--llr-purple));
  color: #fff;
  box-shadow: 0 8px 32px rgba(0,207,255,.3);
}
.llr-btn-hero-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(0,207,255,.5);
  color: #fff;
}
.llr-btn-hero-outline {
  background: transparent;
  color: #fff;
  border: 2px solid rgba(255,255,255,.3);
}
.llr-btn-hero-outline:hover {
  border-color: rgba(255,255,255,.6);
  background: rgba(255,255,255,.07);
  color: #fff;
}
/* Scroll indicator */
.llr-hero-scroll {
  position: absolute;
  bottom: 28px; left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: rgba(255,255,255,.35);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.llr-hero-scroll-line {
  width: 1px; height: 40px;
  background: linear-gradient(to bottom, rgba(255,255,255,.35), transparent);
  animation: llr-scroll-pulse 2s ease-in-out infinite;
}
@keyframes llr-scroll-pulse {
  0%,100%{ transform:scaleY(1); opacity:.5; }
  50%    { transform:scaleY(.7); opacity:1; }
}

/* Product chips at hero bottom */
.llr-hero-products {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 3;
  display: flex;
  justify-content: center;
  gap: 12px;
  padding: 16px 24px;
  background: linear-gradient(to top, rgba(10,10,10,.9) 0%, transparent 100%);
  flex-wrap: wrap;
}
.llr-hero-product-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px 8px 8px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 40px;
  text-decoration: none;
  color: var(--llr-text);
  transition: all var(--llr-transition);
  backdrop-filter: blur(8px);
}
.llr-hero-product-chip:hover {
  background: rgba(0,207,255,.12);
  border-color: rgba(0,207,255,.3);
  color: var(--llr-text);
}
.llr-hero-chip-img {
  width: 32px; height: 32px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
}
.llr-hero-chip-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
  line-height: 1.2;
}
.llr-hero-chip-info span { font-size: .8rem; font-weight: 500; }
.llr-hero-chip-info small { font-size: .72rem; color: var(--llr-cyan); }
.llr-hero-chip-info small .woocommerce-Price-amount { color: var(--llr-cyan); }

/* ═══════════════════════════════════════════════════════════
   QUICK VIEW MODAL
═══════════════════════════════════════════════════════════ */
.llr-qv-overlay {
  position: fixed; inset: 0;
  z-index: 99999;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: llr-fade-in .2s ease;
}
@keyframes llr-fade-in { from { opacity:0; } to { opacity:1; } }
.llr-qv-modal {
  background: var(--llr-surface);
  border: 1px solid var(--llr-border);
  border-radius: 18px;
  max-width: 860px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  box-shadow: 0 30px 80px rgba(0,0,0,.7), 0 0 0 1px rgba(0,207,255,.12);
  animation: llr-slide-up .3s cubic-bezier(.4,0,.2,1);
}
@keyframes llr-slide-up { from { transform:translateY(24px); opacity:0; } to { transform:translateY(0); opacity:1; } }
.llr-qv-close {
  position: absolute;
  top: 16px; right: 16px;
  z-index: 10;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.15);
  color: var(--llr-text);
  font-size: 1.2rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--llr-transition);
}
.llr-qv-close:hover { background: var(--llr-pink); border-color: var(--llr-pink); }

/* QV inner layout */
.llr-qv-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.llr-qv-gallery {
  padding: 24px;
  border-right: 1px solid var(--llr-border);
}
.llr-qv-main-img {
  aspect-ratio: 1;
  border-radius: 12px;
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
  margin-bottom: 12px;
}
.llr-qv-glow {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 110%, rgba(0,207,255,.2) 0%, transparent 65%);
}
.llr-qv-thumbs { display: flex; gap: 8px; flex-wrap: wrap; }
.llr-qv-thumb {
  width: 58px; height: 58px;
  border-radius: 8px;
  background-size: cover;
  background-position: center;
  cursor: pointer;
  border: 2px solid transparent;
  transition: border-color var(--llr-transition);
}
.llr-qv-thumb.active,
.llr-qv-thumb:hover { border-color: var(--llr-cyan); }

.llr-qv-details { padding: 28px 28px 28px 24px; }
.llr-qv-cat {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--llr-purple);
  font-weight: 600;
  display: block;
  margin-bottom: 8px;
}
.llr-qv-title {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 1.4rem;
  margin: 0 0 14px;
  color: var(--llr-text);
  line-height: 1.25;
}
.llr-qv-price {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--llr-cyan);
  margin-bottom: 18px;
  display: flex;
  align-items: baseline;
  gap: 4px;
}
.llr-qv-price small { font-size: .7em; color: var(--llr-muted); }
.llr-qv-price .woocommerce-Price-amount { color: var(--llr-cyan); }
.llr-qv-desc {
  font-size: .88rem;
  color: var(--llr-muted);
  line-height: 1.65;
  margin-bottom: 20px;
  border-top: 1px solid var(--llr-border);
  padding-top: 16px;
}
.llr-qv-desc p { margin: 0 0 8px; }
.llr-qv-specs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 22px;
}
.llr-qv-spec {
  background: rgba(255,255,255,.04);
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.llr-qv-spec span { font-size: .72rem; color: var(--llr-muted); text-transform: uppercase; letter-spacing: .05em; }
.llr-qv-spec strong { font-size: .9rem; color: var(--llr-text); }
.llr-qv-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.llr-qv-book-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 24px;
  background: linear-gradient(135deg, var(--llr-cyan), var(--llr-purple));
  color: #fff; font-weight: 700; font-family: 'Montserrat',sans-serif;
  border-radius: 50px; text-decoration: none; font-size: .9rem;
  transition: all var(--llr-transition);
  box-shadow: 0 6px 24px rgba(0,207,255,.25);
  flex: 1;
  justify-content: center;
}
.llr-qv-book-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(0,207,255,.4); color: #fff; }
.llr-qv-quote-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 13px 20px;
  border: 1.5px solid rgba(255,255,255,.2);
  color: var(--llr-text); text-decoration: none; font-size: .88rem;
  border-radius: 50px;
  transition: all var(--llr-transition);
}
.llr-qv-quote-btn:hover { border-color: var(--llr-pink); color: var(--llr-pink); }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  :root { --llr-card-w: 260px; }
  .llr-grid-cols-4 { grid-template-columns: repeat(3,1fr); }
}
@media (max-width: 768px) {
  :root { --llr-card-w: 240px; }
  .llr-grid-cols-3,
  .llr-grid-cols-4 { grid-template-columns: repeat(2,1fr); }
  .llr-qv-inner { grid-template-columns: 1fr; }
  .llr-qv-gallery { border-right: none; border-bottom: 1px solid var(--llr-border); }
  .llr-hero-products { display: none; }
  .llr-hero-headline { font-size: 2.2rem; }
  .llr-arrow-prev { left: 0; }
  .llr-arrow-next { right: 0; }
}
@media (max-width: 480px) {
  :root { --llr-card-w: 80vw; }
  .llr-grid-cols-2,
  .llr-grid-cols-3,
  .llr-grid-cols-4 { grid-template-columns: 1fr; }
  .llr-hero { min-height: 70vh; }
  .llr-hero-ctas { flex-direction: column; align-items: center; }
}
