/**
 * Lordglass Dark Theme - v2 (Lordglass UI)
 * ==========================================
 * Version: 2.0.0
 * Last Updated: 2025-11-28
 * 
 * Dark Luxury theme using Lordglass palette:
 * - Onyx (#1D1C1C) for backgrounds
 * - Dusk (#393D3F) for surfaces/cards
 * - Velvet (#A4887E) for Rose Gold accents
 * - Canvas (#EAEAE1) for text
 * 
 * This file OVERRIDES the legacy orange header styles
 * from the old header CSS without deleting those files.
 */

/* ============================================
   IMPORT DESIGN TOKENS
   ============================================ */
@import url('./_variables.css');

:root {
    --header-height-desktop: 130px;
}

/* ============================================
   GOOGLE FONTS - Playfair Display & Manrope
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&family=Manrope:wght@400;500;600;700&display=swap');

/* ============================================
   BASE STYLES - Dark Theme Foundation
   ============================================ */

html,
html body,
html body.lordglass-page {
    background: #1D1C1C !important;
    background-color: #1D1C1C !important;
}

html {
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    scroll-behavior: smooth;
}

body,
body.lordglass-page {
    font-family: var(--font-body);
    line-height: var(--leading-normal);
    color: var(--text-primary);
    background: #1D1C1C !important;
    background-color: #1D1C1C !important;
    min-height: 100vh;
}

/* Focus styles for accessibility */
:focus-visible {
    outline: 2px solid var(--interactive-focus);
    outline-offset: 2px;
}

/* Selection styles */
::selection {
    background-color: var(--color-velvet-soft);
    color: var(--text-primary);
}

/* ============================================
   TYPOGRAPHY - Dark Theme
   ============================================ */

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-heading);
    color: var(--text-primary);
    line-height: var(--leading-tight);
    margin: 0;
}

h1,
h2 {
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--tracking-wide);
}

h3,
h4,
h5,
h6 {
    font-weight: var(--font-weight-medium);
    letter-spacing: var(--tracking-normal);
}

p {
    margin: 0 0 var(--space-4);
    color: var(--text-secondary);
}

a {
    color: var(--text-primary);
    text-decoration: none;
    transition: color var(--transition-base);
}

a:hover {
    color: var(--color-velvet);
}

/* ============================================
   PHASE 2: HEADER OVERRIDE STYLES
   ============================================
   
   These styles override the legacy orange gradient
   header with the new Dark Luxury Onyx theme.
   The old CSS files are preserved for safety.
*/

/* Main Header Container - Override orange to Onyx */
.lordglass-header {
    font-family: var(--font-body) !important;
    color: var(--header-text) !important;
    background: var(--header-bg) !important;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    border-bottom: 1px solid var(--color-border-subtle);
}

/* Primary Header Bar - Onyx background instead of orange gradient */
.lordglass-header__primary {
    background: var(--header-bg) !important;
    padding: var(--space-4) var(--space-container);
    border-bottom: 1px solid var(--color-border-subtle);
}

/* Topline layout */
.lordglass-header__topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-6);
    width: 100%;
    flex-wrap: nowrap;
}

/* Brand section */
.lordglass-header__brand {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    flex-shrink: 0;
}

/* Right side group - Language + Cart together */
.lordglass-header__right-group {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-shrink: 0;
}

.lordglass-header__language {
    flex-shrink: 0;
}

.lordglass-header__controls {
    flex-shrink: 0;
}

/* Logo - Velvet accent on hover */
.lordglass-header__logo {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    text-decoration: none;
    color: var(--header-text) !important;
    font-family: var(--font-heading);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--tracking-wider);
    text-transform: uppercase;
    transition: color var(--transition-base);
}

.lordglass-header__logo:hover {
    color: var(--header-accent) !important;
}

.lordglass-header__logo img {
    width: 44px;
    height: 44px;
    object-fit: contain;
}

.lordglass-header__logo-mark img {
    filter: brightness(1.1);
}

.lordglass-header__logo-text {
    display: inline-flex;
    align-items: center;
    gap: 0.18em;
    white-space: nowrap;
    font-size: var(--text-lg);
}

.lordglass-header__logo-text small {
    text-transform: lowercase;
    letter-spacing: var(--tracking-wider);
    color: var(--header-accent);
    position: relative;
    top: 1px;
}

/* Search Bar - Dusk surface background */
.lordglass-header__search {
    flex: 0 1 420px;
    max-width: 480px;
    display: flex;
    align-items: stretch;
    background: var(--bg-surface) !important;
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-full);
    overflow: hidden;
    transition: border-color var(--transition-base);
}

.lordglass-header__search:focus-within {
    border-color: var(--header-accent);
}

.lordglass-header__search input {
    flex: 1;
    border: none;
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-base);
    font-family: var(--font-body);
    color: var(--text-primary) !important;
    background: transparent !important;
    outline: none;
}

.lordglass-header__search input::placeholder {
    color: var(--text-muted);
}

.lordglass-header__search button {
    border: none;
    background: transparent;
    width: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    cursor: pointer;
    transition: color var(--transition-base);
}

.lordglass-header__search button:hover {
    color: var(--header-accent);
}

.lordglass-header__search button svg {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.6;
}

/* Search submit button - wider */
.lordglass-header__search-submit,
.lordglass-header__search button[type="submit"] {
    min-width: 120px;
    padding: 0 20px;
    gap: 8px;
}

/* Search submit button SVG - use HTML attributes, don't override */
.lordglass-header__search-submit svg,
.lordglass-header__search button[type="submit"] svg {
    width: auto;
    height: auto;
    stroke-width: 2.2;
}

/* Search close button */
.lordglass-header__search-close {
    display: none !important;
}

/* Language button */
.lordglass-header__language {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    border: 1px solid var(--color-border-subtle) !important;
    background: var(--bg-surface) !important;
    color: var(--header-text) !important;
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-lg);
    cursor: pointer;
    font-weight: var(--font-weight-medium);
    letter-spacing: var(--tracking-wide);
    min-height: 42px;
    transition: all var(--transition-base);
}

.lordglass-header__language:hover {
    border-color: var(--header-accent) !important;
    background: var(--bg-surface-hover) !important;
}

.lordglass-header__language-flag svg {
    width: 24px;
    height: 16px;
}

.lordglass-header__language svg:last-child {
    width: 16px;
    height: 16px;
    color: var(--text-muted);
}

/* Controls (cart, menu toggle) */
.lordglass-header__controls {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
}

.lordglass-header__actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

/* Cart link */
.lordglass-header__cart {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--header-text) !important;
    text-decoration: none;
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    transition: all var(--transition-base);
}

.lordglass-header__cart:hover {
    color: var(--header-accent) !important;
    background: var(--bg-surface);
}

.lordglass-header__cart svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.6;
}

/* Mobile toggle button */
.lordglass-header__toggle {
    border: none;
    background: transparent;
    color: var(--header-text) !important;
    display: none;
    flex-direction: column;
    gap: 4px;
    padding: var(--space-2);
    cursor: pointer;
    border-radius: var(--radius-md);
    transition: background var(--transition-base);
}

.lordglass-header__toggle:hover {
    background: var(--bg-surface);
}

.lordglass-header__toggle span {
    width: 20px;
    height: 2px;
    background: currentColor;
    display: block;
    border-radius: 2px;
    transition: transform var(--transition-base);
}

/* ============================================
   NAVIGATION ROW - Override orange to Onyx
   ============================================ */

.lordglass-header__nav-row {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--bg-surface) !important;
    padding: var(--space-2) var(--space-container);
    border-bottom: 1px solid var(--color-border-subtle);
}

/* All menu button */
.lordglass-header__nav-all {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    border: none;
    background: transparent;
    color: var(--header-text) !important;
    font-size: var(--text-sm);
    font-weight: var(--font-weight-semibold);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-base);
}

.lordglass-header__nav-all:hover {
    background: var(--bg-surface-hover);
    color: var(--header-accent) !important;
}

.lordglass-header__nav-all svg {
    width: 20px;
    height: 20px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.6;
}

/* Main navigation */
.lordglass-header__nav {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    flex: 1;
}

.lordglass-header__nav>a,
.lordglass-nav-link {
    color: var(--header-text) !important;
    font-size: var(--text-sm);
    font-weight: var(--font-weight-medium);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    transition: all var(--transition-base);
    white-space: nowrap;
    text-decoration: none;
}

.lordglass-header__nav>a:hover,
.lordglass-nav-link:hover {
    background: var(--bg-surface-hover);
    color: var(--header-accent) !important;
}

/* Navigation items with mega menu */
.lordglass-nav-item {
    position: relative;
}

/* Mega Menu - Dusk surface */
.lordglass-mega {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 600px;
    background: var(--bg-surface) !important;
    border: 1px solid var(--color-border-subtle);
    border-radius: 0 0 var(--radius-xl) var(--radius-xl);
    box-shadow: var(--shadow-xl);
    padding: var(--space-6);
    display: none;
    z-index: var(--z-dropdown);
}

.lordglass-nav-item:hover .lordglass-mega,
.lordglass-nav-item:focus-within .lordglass-mega {
    display: flex;
    gap: var(--space-8);
}

.lordglass-mega__column {
    flex: 1;
    min-width: 160px;
}

.lordglass-mega__heading {
    font-size: var(--text-xs);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-widest);
    color: var(--header-accent) !important;
    margin-bottom: var(--space-3);
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--color-border-subtle);
}

.lordglass-mega__column ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.lordglass-mega__column li {
    margin-bottom: var(--space-1);
}

.lordglass-mega__column a {
    display: block;
    color: var(--text-secondary) !important;
    font-size: var(--text-sm);
    padding: var(--space-2) 0;
    transition: color var(--transition-base);
}

.lordglass-mega__column a:hover {
    color: var(--header-accent) !important;
}

/* ============================================
   SUB HEADER - Override to Onyx
   ============================================ */

.lordglass-header__sub {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    background: var(--bg-page) !important;
    padding: var(--space-3) var(--space-container);
    border-bottom: 1px solid var(--color-border-subtle);
    flex-wrap: nowrap;
    white-space: nowrap;
}

/* Location */
.lordglass-header__location {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--text-secondary);
    font-size: var(--text-sm);
    flex-shrink: 0;
    white-space: nowrap;
}

.lordglass-header__location svg {
    width: 20px;
    height: 20px;
    fill: none;
    stroke: var(--header-accent);
    stroke-width: 1.6;
}

.lordglass-header__location strong {
    color: var(--text-primary);
}

/* Call button */
.lordglass-header__call-buttons {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
}

.lordglass-header__call-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    border: 1px solid var(--color-border-subtle);
    background: var(--bg-surface) !important;
    color: var(--header-text) !important;
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: var(--text-sm);
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-base);
    white-space: nowrap;
    text-decoration: none;
}

.lordglass-header__call-btn:hover {
    border-color: var(--header-accent);
    background: var(--bg-surface-hover) !important;
    color: var(--header-text) !important;
    text-decoration: none;
}

.lordglass-header__call-btn svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: var(--header-accent);
    stroke-width: 1.6;
}

.lordglass-header__call-btn--whatsapp svg {
    stroke: #25D366;
}

.lordglass-header__call-btn--whatsapp:hover {
    border-color: #25D366;
}

/* Call Dropdown (legacy support) */
.lordglass-header__call {
    position: relative;
    flex-shrink: 0;
}

.lordglass-header__call-toggle {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    border: 1px solid var(--color-border-subtle);
    background: var(--bg-surface) !important;
    color: var(--header-text) !important;
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: var(--text-sm);
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-base);
    white-space: nowrap;
}

.lordglass-header__call-toggle:hover {
    border-color: var(--header-accent);
    background: var(--bg-surface-hover) !important;
}

.lordglass-header__call-toggle svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: var(--header-accent);
    stroke-width: 1.6;
}

.lordglass-header__call-menu {
    position: absolute;
    top: 100%;
    right: 0;
    min-width: 180px;
    background: var(--bg-surface);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    padding: var(--space-2);
    z-index: var(--z-dropdown);
}

.lordglass-header__call-menu[hidden] {
    display: none;
}

.lordglass-header__call-menu a {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--text-primary);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-sm);
    transition: background var(--transition-base);
    text-decoration: none;
}

.lordglass-header__call-menu a:hover {
    background: var(--bg-surface-hover);
}

.lordglass-header__call-menu svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: var(--header-accent);
    stroke-width: 1.6;
}

/* ============================================
   MOBILE MENU - Override to Dark Theme
   ============================================ */

.lordglass-menu {
    position: fixed;
    inset: 0;
    z-index: var(--z-modal);
    visibility: hidden;
    opacity: 0;
    transition: visibility 0s 0.3s, opacity var(--transition-slow);
}

.lordglass-menu[aria-hidden="false"] {
    visibility: visible;
    opacity: 1;
    transition: visibility 0s, opacity var(--transition-slow);
}

.lordglass-menu__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.7);
}

.lordglass-menu__panel {
    position: absolute;
    top: 0;
    left: 0;
    width: min(360px, 85vw);
    height: 100%;
    background: var(--bg-surface);
    transform: translateX(-100%);
    transition: transform var(--transition-slow);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.lordglass-menu[aria-hidden="false"] .lordglass-menu__panel {
    transform: translateX(0);
}

/* Mobile menu hero */
.lordglass-menu__hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4) var(--space-5);
    background: var(--bg-page);
    border-bottom: 1px solid var(--color-border-subtle);
}

.lordglass-menu__hero p {
    font-size: var(--text-xs);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: var(--tracking-widest);
    margin: 0;
}

.lordglass-menu__hero strong {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--text-primary);
    font-weight: var(--font-weight-semibold);
}

/* Close button */
.lordglass-menu__close {
    width: 32px;
    height: 32px;
    border: none;
    background: var(--bg-surface);
    border-radius: var(--radius-full);
    cursor: pointer;
    position: relative;
    transition: background var(--transition-base);
}

.lordglass-menu__close:hover {
    background: var(--bg-surface-hover);
}

.lordglass-menu__close span {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 16px;
    height: 2px;
    background: var(--text-primary);
    border-radius: 1px;
}

.lordglass-menu__close span:first-child {
    transform: translate(-50%, -50%) rotate(45deg);
}

.lordglass-menu__close span:last-child {
    transform: translate(-50%, -50%) rotate(-45deg);
}

/* Mobile menu scroll area */
.lordglass-menu__scroll {
    flex: 1;
    overflow-y: auto;
    padding: var(--space-4);
}

/* Accordion */
.lordglass-menu__accordion {
    margin-bottom: var(--space-2);
}

.lordglass-menu__accordion-trigger {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3) var(--space-4);
    border: none;
    background: var(--bg-page);
    color: var(--text-primary);
    font-size: var(--text-base);
    font-weight: var(--font-weight-medium);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background var(--transition-base);
}

.lordglass-menu__accordion-trigger:hover {
    background: var(--bg-surface-hover);
}

.lordglass-menu__accordion-trigger svg {
    width: 20px;
    height: 20px;
    color: var(--text-muted);
    transition: transform var(--transition-base);
}

.lordglass-menu__accordion-trigger[aria-expanded="true"] svg {
    transform: rotate(180deg);
}

.lordglass-menu__accordion-panel {
    padding: var(--space-3) var(--space-4);
}

.lordglass-menu__panel-columns {
    display: grid;
    gap: var(--space-4);
}

.lordglass-menu__panel-columns p {
    font-size: var(--text-xs);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-widest);
    color: var(--header-accent);
    margin-bottom: var(--space-2);
}

.lordglass-menu__panel-columns ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.lordglass-menu__panel-columns a {
    display: block;
    color: var(--text-secondary);
    font-size: var(--text-sm);
    padding: var(--space-2) 0;
    transition: color var(--transition-base);
}

.lordglass-menu__panel-columns a:hover {
    color: var(--header-accent);
}

/* Mobile CTA */
.lordglass-menu__cta {
    display: block;
    text-align: center;
    padding: var(--space-3) var(--space-4);
    margin: var(--space-4) 0;
    background: var(--color-velvet);
    color: var(--text-inverse) !important;
    font-weight: var(--font-weight-semibold);
    border-radius: var(--radius-md);
    transition: background var(--transition-base);
}

.lordglass-menu__cta:hover {
    background: var(--color-velvet-hover);
    color: var(--text-inverse) !important;
}

/* Mobile menu links */
.lordglass-menu__link {
    display: block;
    padding: var(--space-3) var(--space-4);
    color: var(--text-primary);
    font-size: var(--text-base);
    border-radius: var(--radius-md);
    transition: background var(--transition-base);
}

.lordglass-menu__link:hover {
    background: var(--bg-page);
}

/* Mobile menu bottom */
.lordglass-menu__bottom {
    padding: var(--space-4);
    background: var(--bg-page);
    border-top: 1px solid var(--color-border-subtle);
}

.lordglass-menu__bottom-link {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) 0;
    color: var(--text-primary);
    font-size: var(--text-sm);
    border-bottom: 1px solid var(--color-border-subtle);
}

.lordglass-menu__bottom-link:last-of-type {
    border-bottom: none;
}

.lordglass-menu__bottom-link svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: var(--header-accent);
    stroke-width: 1.6;
}

.lordglass-menu__bottom-link strong {
    color: var(--header-accent);
}

.lordglass-menu__bottom-hours {
    padding-top: var(--space-3);
    font-size: var(--text-sm);
    color: var(--text-muted);
}

.lordglass-menu__bottom-hours strong {
    display: block;
    color: var(--text-primary);
}

/* ============================================
   LAYOUT UTILITIES
   ============================================ */

.lg-container {
    width: 100%;
    max-width: var(--container-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--space-container);
    padding-right: var(--space-container);
}

.lg-section {
    padding-top: var(--space-section);
    padding-bottom: var(--space-section);
}

/* Full-bleed utility */
.lg-full-bleed {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
}

/* ============================================
   UTILITY CLASSES
   ============================================ */

.visually-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* Text alignment */
.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

/* Display */
.flex {
    display: flex;
}

.grid {
    display: grid;
}

.block {
    display: block;
}

.inline-flex {
    display: inline-flex;
}

/* Flex utilities */
.items-center {
    align-items: center;
}

.justify-center {
    justify-content: center;
}

.justify-between {
    justify-content: space-between;
}

.gap-2 {
    gap: var(--space-2);
}

.gap-4 {
    gap: var(--space-4);
}

.gap-6 {
    gap: var(--space-6);
}

.gap-8 {
    gap: var(--space-8);
}

/* ============================================
   RESPONSIVE - Mobile Header
   ============================================ */

@media (max-width: 992px) {

    /* Mobile Header Layout - Match Orange Screenshot */
    .lordglass-header__topline {
        flex-wrap: wrap;
        gap: var(--space-2);
    }

    /* Row 1: Logo (left) + Cart + Hamburger (right) */
    .lordglass-header__brand {
        order: 1;
        flex: 1;
    }

    .lordglass-header__right-group {
        order: 2;
        display: flex;
        align-items: center;
        gap: var(--space-4);
    }

    /* Hide language selector on mobile */
    .lordglass-header__language {
        display: none;
    }

    /* Hide cart text on mobile, show only icon */
    .lordglass-header__cart-text {
        display: none;
    }

    .lordglass-header__cart svg {
        width: 28px;
        height: 28px;
    }

    /* Show hamburger menu */
    .lordglass-header__toggle {
        display: flex;
    }

    /* Hide nav-all button on mobile */
    .lordglass-header__nav-all {
        display: none !important;
    }

    /* Row 2: Search bar full width */
    .lordglass-header__search {
        order: 3;
        flex: 1 1 100%;
        max-width: none;
        margin-top: 0;
    }

    /* Hide desktop nav row - will show horizontal scroll nav instead */
    .lordglass-header__nav-row {
        display: flex;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding: var(--space-2) var(--space-3);
    }

    .lordglass-header__nav-row::-webkit-scrollbar {
        display: none;
    }

    /* Mobile nav buttons closer together - show 4th button peek */
    .lordglass-header__nav {
        gap: var(--space-1);
        padding-right: 20%;
    }

    .lordglass-header__nav>a,
    .lordglass-nav-link {
        padding: var(--space-2) var(--space-2);
        font-size: 13px;
    }
}

@media (max-width: 640px) {

    /* Sub header stays single row on mobile */
    /* Sub header stacks on mobile */
    .lordglass-header__sub {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: var(--space-3);
        flex-wrap: wrap;
        height: auto;
        padding-bottom: var(--space-3);
    }

    .lordglass-header__location {
        flex-shrink: 1;
        min-width: 0;
    }

    .lordglass-header__location>div {
        display: flex;
        flex-direction: column;
        line-height: 1.2;
    }

    .lordglass-header__call-buttons {
        flex-shrink: 0;
    }

    .lordglass-header__call-btn {
        padding: var(--space-2);
        font-size: var(--text-xs);
    }

    .lordglass-header__call-btn span {
        display: none;
    }
}

/* ============================================
   HERO SECTION - Dark Luxury Theme
   ============================================ */

.lordglass-hero {
    background: var(--color-bg-main);
    padding: 0;
    width: 100%;
}

/* Container */
.lordglass-container {
    width: 100%;
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 var(--space-4);
}

/* Hero Grid */
.lordglass-hero__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(2, minmax(200px, auto));
    gap: var(--space-3);
    padding: var(--space-4) 0;
}

@media (min-width: 992px) {
    .lordglass-hero__grid {
        height: calc(100dvh - 215px) !important;
        grid-template-rows: repeat(2, 1fr);
        padding-bottom: 0;
    }

    /* Force cards to fit the grid cells */
    .lordglass-hero__card,
    .lordglass-hero__card--hero {
        min-height: 0 !important;
        height: 100% !important;
    }
}

.lordglass-hero__grid--secondary {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: minmax(200px, auto);
    padding-top: 0;
}

/* Grid placement for cards */
.lordglass-hero__card--hero {
    grid-column: span 2;
    grid-row: span 2;
}

.lordglass-hero__card--black-friday {
    grid-column: span 1;
    grid-row: span 1;
}

.lordglass-hero__card--black-friday-2 {
    grid-column: span 1;
    grid-row: span 1;
}

.lordglass-hero__card--veranda {
    grid-column: span 1;
    grid-row: span 1;
}

.lordglass-hero__card--carport {
    grid-column: span 1;
    grid-row: span 1;
}

.lordglass-hero__card--advice {
    grid-column: span 1;
    grid-row: span 1;
}

.lordglass-hero__card--terrace {
    grid-column: span 1;
    grid-row: span 1;
}

/* Hero Card Base Styles */
.lordglass-hero__card {
    position: relative;
    display: block;
    overflow: hidden;
    border-radius: var(--radius-xl);
    text-decoration: none;
    background: var(--color-bg-surface);
    transition: transform var(--transition-base);
}

.lordglass-hero__card:hover {
    transform: scale(1.02);
}

/* Card Media (Image) */
.lordglass-hero__card__media {
    position: absolute;
    inset: 0;
    margin: 0;
}

.lordglass-hero__card__media picture {
    display: block;
    width: 100%;
    height: 100%;
}

.lordglass-hero__card__media img {
    display: block;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform var(--transition-slow), filter var(--transition-base);
}

.lordglass-hero__card:hover .lordglass-hero__card__media img {
    transform: scale(1.05);
    filter: brightness(1.1);
}

/* Dark overlay for text readability */
.lordglass-hero__card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top,
            rgba(0, 0, 0, 0.6) 0%,
            rgba(0, 0, 0, 0.2) 50%,
            transparent 100%);
    z-index: 1;
    pointer-events: none;
}

/* Card Content */
.lordglass-hero__card__body {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-6);
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.lordglass-hero__card__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: var(--font-weight-medium);
    text-transform: uppercase;
    letter-spacing: var(--tracking-widest);
    color: var(--color-velvet);
    margin: 0;
}

.lordglass-hero__card__title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 2vw, 1.75rem);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin: 0;
    line-height: var(--leading-tight);
}

/* Hero card (large) has bigger typography */
.lordglass-hero__card--hero .lordglass-hero__card__title {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
}

.lordglass-hero__card--hero .lordglass-hero__card__eyebrow {
    font-size: var(--text-sm);
}

/* Responsive Grid */
@media (max-width: 1200px) and (min-width: 769px) {
    .lordglass-hero__grid {
        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: auto;
    }

    .lordglass-hero__card--hero {
        grid-column: span 3;
        grid-row: span 1;
        min-height: 400px;
    }
}

@media (max-width: 768px) {
    .lordglass-hero__grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: auto;
    }

    .lordglass-hero__card--hero {
        grid-column: span 2;
        grid-row: span 1;
        min-height: 350px;
    }

    .lordglass-hero__card {
        min-height: 250px;
    }
}

@media (max-width: 640px) {
    .lordglass-hero__grid {
        grid-template-columns: 1fr;
        gap: var(--space-2);
    }

    .lordglass-hero__card--hero {
        grid-column: span 1;
        min-height: 300px;
    }

    .lordglass-hero__card {
        min-height: 200px;
    }

    .lordglass-hero__card__body {
        padding: var(--space-4);
    }
}

/* ============================================
   FEATURES BAR - Dark Luxury Theme
   ============================================ */

.lordglass-features {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
    gap: var(--space-4);
    background: var(--color-bg-surface);
    border-top: 1px solid var(--border-subtle);
    padding: var(--space-6) var(--space-4);
    margin-top: var(--space-4);
}

.lordglass-feature {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-4) var(--space-6);
    text-align: center;
    flex: 1 1 200px;
    max-width: 280px;
    position: relative;
}

/* Remove old glass morphism styles - clean design */
.lordglass-feature::before,
.lordglass-feature::after {
    display: none;
}

.lordglass-feature__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    color: var(--color-velvet);
    transition: transform var(--transition-base);
}

.lordglass-feature:hover .lordglass-feature__icon {
    transform: scale(1.1);
}

.lordglass-feature__icon svg {
    width: 40px;
    height: 40px;
}

.lordglass-feature__text {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: var(--font-weight-medium);
    color: var(--text-primary);
    line-height: var(--leading-normal);
}

/* Features Bar Responsive */
@media (max-width: 900px) {
    .lordglass-features {
        gap: var(--space-2);
        padding: var(--space-4) var(--space-2);
    }

    .lordglass-feature {
        flex: 1 1 150px;
        padding: var(--space-3) var(--space-4);
    }

    .lordglass-feature__icon {
        width: 48px;
        height: 48px;
    }

    .lordglass-feature__icon svg {
        width: 32px;
        height: 32px;
    }
}

@media (max-width: 640px) {
    .lordglass-features {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 8px !important;
        padding: 12px 8px !important;
    }

    .lordglass-feature {
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
        gap: 6px !important;
        padding: 10px 6px !important;
        flex: none !important;
    }

    .lordglass-feature__icon {
        width: 32px !important;
        height: 32px !important;
        flex-shrink: 0 !important;
    }

    .lordglass-feature__icon svg {
        width: 24px !important;
        height: 24px !important;
    }

    .lordglass-feature__text {
        font-size: 12px !important;
        line-height: 1.3 !important;
    }
}

/* ============================================
   PRODUCTS SECTION - Dark Luxury Theme
   ============================================ */

.lordglass-products {
    background: var(--color-bg-main);
    padding: var(--space-16) 0;
}

/* Section Header */
.lordglass-products__header {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: var(--space-4);
    margin-bottom: var(--space-8);
}

.lordglass-products__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin: 0;
    margin-right: auto;
}

/* Tabs */
.lordglass-tabs {
    display: flex !important;
    gap: var(--space-2);
    background: var(--color-bg-surface);
    padding: var(--space-1);
    border-radius: var(--radius-full);
    margin-left: auto !important;
}

.lordglass-tab {
    padding: var(--space-2) var(--space-5);
    border: none;
    background: transparent;
    color: var(--text-secondary);
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: var(--font-weight-medium);
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all var(--transition-base);
}

.lordglass-tab:hover {
    color: var(--text-primary);
}

.lordglass-tab.is-active {
    background: var(--color-velvet);
    color: var(--color-bg-main);
}

/* Products Grid */
.lordglass-products__grid {
    display: none;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
}

.lordglass-products__grid.is-active {
    display: grid;
}

/* Product Card */
.lordglass-card {
    position: relative;
    z-index: 0;
    /* ensure badge stacking stays within the card and not above the page header */
    background: var(--color-bg-surface);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-xl);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.lordglass-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

/* Card Badge */
.lordglass-card__badge {
    position: absolute;
    top: var(--space-3);
    left: var(--space-3);
    background: var(--color-velvet);
    color: var(--color-bg-main);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
    z-index: 2;
}

/* Card Image */
.lordglass-card__image {
    position: relative;
    display: block;
    aspect-ratio: 16 / 10;
    overflow: hidden;
}

.lordglass-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.lordglass-card:hover .lordglass-card__image img {
    transform: scale(1.05);
}

/* Card Content */
.lordglass-card__content {
    padding: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    flex: 1;
}

/* Card Header */
.lordglass-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-3);
}

.lordglass-card__title-link {
    text-decoration: none;
    color: inherit;
}

.lordglass-card__title {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin: 0;
    line-height: var(--leading-tight);
    transition: color var(--transition-base);
}

.lordglass-card__title-link:hover .lordglass-card__title {
    color: var(--color-velvet);
}

/* Price Badge */
.lordglass-card__price-badge {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    background: var(--color-bg-main);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-md);
    flex-shrink: 0;
}

.lordglass-card__price-badge svg {
    width: 16px;
    height: 16px;
    color: var(--color-velvet);
}

.lordglass-card__price-text {
    font-size: var(--text-xs);
    font-weight: var(--font-weight-semibold);
    color: var(--color-velvet);
}

/* Card Features */
.lordglass-card__features {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.lordglass-card__feature {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.lordglass-card__feature svg {
    width: 16px;
    height: 16px;
    color: var(--color-velvet);
    flex-shrink: 0;
}

.lordglass-card__badge-inclusief {
    background: var(--color-velvet-soft);
    color: var(--color-velvet);
    padding: 0.125rem 0.5rem;
    border-radius: var(--radius-sm);
    font-size: var(--text-xs);
    font-weight: var(--font-weight-medium);
    margin-left: var(--space-1);
}

/* Card Pricing */
.lordglass-card__pricing {
    display: flex;
    align-items: baseline;
    gap: var(--space-3);
    margin-top: auto;
}

.lordglass-card__old-price {
    font-size: var(--text-sm);
    color: var(--text-muted);
    text-decoration: line-through;
}

.lordglass-card__price {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-velvet);
}

/* Card Button */
.lordglass-card__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    background: var(--color-velvet);
    color: var(--color-bg-main);
    padding: var(--space-3) var(--space-5);
    border-radius: var(--radius-lg);
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: var(--font-weight-semibold);
    text-decoration: none;
    transition: all var(--transition-base);
}

.lordglass-card__button:hover {
    background: var(--color-velvet-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(164, 136, 126, 0.3);
}

.lordglass-card__button svg {
    width: 18px;
    height: 18px;
    transition: transform var(--transition-base);
}

.lordglass-card__button:hover svg {
    transform: translateX(4px);
}

/* Card Delivery */
.lordglass-card__delivery {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding-top: var(--space-3);
    border-top: 1px solid var(--border-subtle);
    font-size: var(--text-xs);
    color: var(--text-muted);
}

.lordglass-card__delivery svg {
    width: 14px;
    height: 14px;
    color: var(--color-velvet);
    flex-shrink: 0;
}

/* Products Grid Responsive */
@media (max-width: 1200px) {
    .lordglass-products__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .lordglass-products {
        padding: var(--space-10) 0;
    }

    .lordglass-products__header {
        flex-direction: column;
        align-items: stretch;
    }

    .lordglass-products__title {
        text-align: left;
    }

    .lordglass-tabs {
        width: auto !important;
        overflow-x: auto;
        align-self: flex-end !important;
        margin-left: auto !important;
    }

    .lordglass-products__grid {
        grid-template-columns: 1fr;
        gap: var(--space-4);
    }
}

@media (max-width: 480px) {
    .lordglass-card__header {
        flex-direction: column;
    }

    .lordglass-card__price-badge {
        align-self: flex-start;
    }

    .lordglass-card__pricing {
        flex-direction: column;
        gap: var(--space-1);
    }
}

/* ============================================
   FOOTER - Dark Luxury Theme
   ============================================ */

/* Support both footer class names */
.lordglass-footer,
.lg-premium-footer {
    background: var(--color-bg-surface);
    color: var(--text-primary);
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
    padding: clamp(2rem, 6vw, 4rem) clamp(1.5rem, 6vw, 4rem) 2rem;
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
}

/* Footer CTA Section */
.lordglass-footer__cta {
    background: var(--color-bg-main);
    border: 1px solid var(--color-velvet-soft);
    border-radius: var(--radius-2xl);
    padding: clamp(2rem, 5vw, 3.5rem);
    text-align: center;
    color: var(--text-secondary);
    width: min(100%, 1400px);
    margin-left: auto;
    margin-right: auto;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    position: relative;
    z-index: 2;
    transform: translateY(15%);
    margin-bottom: calc(-1 * var(--space-16, 4rem));
    box-shadow: 0 30px 70px rgba(0, 0, 0, 0.3);
}

.lordglass-footer__cta>* {
    padding-left: clamp(0.5rem, 2vw, 1.5rem);
    padding-right: clamp(0.5rem, 2vw, 1.5rem);
}

.lordglass-footer__cta-pill {
    display: inline-flex;
    align-self: center;
    padding: 0.4rem 1.25rem;
    border-radius: var(--radius-full);
    border: 1px solid var(--color-velvet);
    font-weight: var(--font-weight-semibold);
    color: var(--color-velvet);
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
}

.lordglass-footer__cta-title {
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    margin: 0;
    color: var(--text-primary);
    font-family: var(--font-heading);
    font-weight: var(--font-weight-semibold);
}

.lordglass-footer__cta-text {
    margin: 0 auto;
    max-width: 640px;
    color: var(--text-secondary);
    line-height: var(--leading-relaxed);
}

/* Footer CTA Form */
.lordglass-footer__cta-form {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-3);
}

.lordglass-footer__field {
    display: block;
    background: var(--color-bg-surface);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-full);
    padding: 0.3rem 1rem;
    transition: border-color var(--transition-base);
}

.lordglass-footer__field:focus-within {
    border-color: var(--color-velvet);
}

.lordglass-footer__field input,
.lordglass-footer__field select {
    width: 100%;
    border: none;
    background: transparent;
    padding: 0.65rem 0;
    font-size: var(--text-sm);
    color: var(--text-primary);
    outline: none;
    font-family: var(--font-body);
}

.lordglass-footer__field input::placeholder {
    color: var(--text-muted);
}

.lordglass-footer__field select {
    appearance: none;
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23A4887E' d='M6 8L2 4h8z'/%3E%3C/svg%3E");
    background-position: calc(100% - 12px) center;
    background-repeat: no-repeat;
}

.lordglass-footer__field select option {
    background: var(--color-bg-main);
    color: var(--text-primary);
}

.lordglass-footer__cta-submit {
    border: none;
    border-radius: var(--radius-full);
    background: var(--color-velvet);
    color: var(--color-bg-main);
    font-weight: var(--font-weight-semibold);
    cursor: pointer;
    transition: all var(--transition-base);
    padding: 0.85rem 2.5rem;
    font-size: var(--text-base);
    font-family: var(--font-body);
    box-shadow: none;
}

.lordglass-footer__cta-submit:hover {
    background: var(--color-velvet-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(164, 136, 126, 0.3);
}

/* Footer Body Section */
.lordglass-footer__body {
    background: var(--color-bg-main);
    border-radius: var(--radius-2xl);
    padding: clamp(2.25rem, 5vw, 3.5rem);
    padding-top: calc(var(--space-16, 4rem) + clamp(2.5rem, 5vw, 3.5rem));
    display: grid;
    gap: var(--space-8);
    width: min(100%, 1400px);
    margin-left: auto;
    margin-right: auto;
}

/* Footer Branding */
.lordglass-footer__branding {
    max-width: 320px;
    color: var(--text-secondary);
}

.lordglass-footer__logo {
    display: inline-flex;
    gap: var(--space-3);
    align-items: center;
    text-decoration: none;
    color: inherit;
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-4);
}

.lordglass-footer__logo img {
    width: 48px;
    height: 48px;
    object-fit: contain;
}

.lordglass-footer__logo-text {
    letter-spacing: var(--tracking-widest);
    color: var(--text-primary);
    font-family: var(--font-heading);
    font-size: var(--text-lg);
}

.lordglass-footer__logo small {
    display: block;
    font-size: var(--text-xs);
    color: var(--text-muted);
    font-weight: var(--font-weight-normal);
    letter-spacing: var(--tracking-wide);
}

.lordglass-footer__branding p {
    color: var(--text-secondary);
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
}

/* Footer Columns */
.lordglass-footer__columns {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-6);
}

.lordglass-footer__columns h3 {
    margin-bottom: var(--space-3);
    text-transform: capitalize;
    color: var(--text-primary);
    font-family: var(--font-heading);
    font-size: var(--text-base);
    font-weight: var(--font-weight-semibold);
}

.lordglass-footer__columns ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: var(--space-2);
}

.lordglass-footer__columns a {
    color: var(--text-secondary);
    text-decoration: none;
    font-size: var(--text-sm);
    transition: color var(--transition-base);
}

.lordglass-footer__columns a:hover {
    color: var(--color-velvet);
}

.lordglass-footer__columns p {
    color: var(--text-secondary);
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
}

/* Footer Social Links */
.lordglass-footer__social {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
}

.lordglass-footer__social a {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-full);
    border: 1px solid var(--color-velvet-soft);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: var(--text-primary);
    font-size: var(--text-xs);
    transition: all var(--transition-base);
}

.lordglass-footer__social a:hover {
    background: var(--color-velvet);
    border-color: var(--color-velvet);
    color: var(--color-bg-main);
    transform: translateY(-2px);
}

/* Footer Legal */
.lordglass-footer__legal {
    text-align: center;
    font-size: var(--text-sm);
    color: var(--text-muted);
    border-top: 1px solid var(--border-subtle);
    padding-top: var(--space-5);
    width: min(100%, 1400px);
    margin-left: auto;
    margin-right: auto;
}

/* Footer Responsive */
@media (max-width: 900px) {

    .lordglass-footer__cta,
    .lordglass-footer__body {
        width: 100%;
        border-radius: 0;
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }

    .lordglass-footer__cta-form {
        grid-template-columns: minmax(0, 1fr);
    }

    .lordglass-footer {
        padding: 0;
    }

    .lordglass-footer__cta,
    .lordglass-footer__body {
        padding-top: clamp(1rem, 3vw, 1.75rem);
        padding-bottom: clamp(1rem, 3vw, 1.75rem);
    }

    .lordglass-footer__body {
        padding-left: clamp(0.5rem, 3vw, 1rem);
        padding-right: clamp(0.5rem, 3vw, 1rem);
    }

    .lordglass-footer__cta-pill,
    .lordglass-footer__cta-title,
    .lordglass-footer__cta-text,
    .lordglass-footer__branding,
    .lordglass-footer__columns {
        padding-left: clamp(0.5rem, 3vw, 1rem);
        padding-right: clamp(0.5rem, 3vw, 1rem);
    }
}

/* Inline editing mode styles */
body.lg-inline-editing .lordglass-footer__social .lg-inline-placeholder {
    display: block;
    width: 100%;
    max-width: 100%;
    word-break: break-word;
    overflow-wrap: anywhere;
    font-size: var(--text-xs);
    line-height: 1.2;
    margin-top: var(--space-1);
}

/* ============================================
   LG-PREMIUM-FOOTER ALIASES
   Support for home_premium.html footer classes
   ============================================ */
.lg-premium-footer__cta {
    background: var(--color-bg-main);
    border: 1px solid var(--color-velvet-soft);
    border-radius: var(--radius-2xl);
    padding: clamp(1rem, 2.5vw, 1.75rem);
    text-align: center;
    color: var(--text-secondary);
    width: min(100%, 1400px);
    margin-left: auto;
    margin-right: auto;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    position: relative;
    z-index: 2;
    transform: translateY(15%);
    margin-bottom: calc(-1 * var(--space-16, 4rem));
    box-shadow: 0 30px 70px rgba(0, 0, 0, 0.3);
}

.lg-premium-footer__cta>* {
    padding-left: clamp(0.5rem, 2vw, 1.5rem);
    padding-right: clamp(0.5rem, 2vw, 1.5rem);
}

.lg-premium-footer__cta-pill {
    display: inline-flex;
    align-self: center;
    padding: 0.4rem 1.25rem;
    border-radius: var(--radius-full);
    border: 1px solid var(--color-velvet);
    font-weight: var(--font-weight-semibold);
    color: var(--color-velvet);
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
}

.lg-premium-footer__cta-title {
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    margin: 0;
    color: var(--text-primary);
    font-family: var(--font-heading);
    font-weight: var(--font-weight-semibold);
}

.lg-premium-footer__cta-text {
    margin: 0 auto;
    max-width: 640px;
    color: var(--text-secondary);
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
}

.lg-premium-footer__cta-form {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--space-3);
    width: 100%;
}

.lg-premium-footer__field {
    position: relative;
    background: var(--color-bg-surface);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: var(--space-3) var(--space-4);
    transition: border-color var(--transition-base);
}

.lg-premium-footer__field:focus-within {
    border-color: var(--color-velvet);
}

.lg-premium-footer__field input,
.lg-premium-footer__field select {
    width: 100%;
    background: transparent;
    border: none;
    outline: none;
    color: var(--text-primary);
    font-size: var(--text-base);
}

.lg-premium-footer__field input::placeholder {
    color: var(--text-muted);
}

.lg-premium-footer__field select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23EAEAE1' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0 center;
    padding-right: var(--space-4);
}

.lg-premium-footer__field select option {
    background: var(--color-bg-main);
    color: var(--text-primary);
}

.lg-premium-footer__cta-submit {
    background: var(--color-velvet);
    color: var(--color-bg-main);
    border: none;
    border-radius: var(--radius-lg);
    padding: var(--space-3) var(--space-6);
    font-weight: var(--font-weight-semibold);
    font-size: var(--text-base);
    cursor: pointer;
    transition: all var(--transition-base);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
}

.lg-premium-footer__cta-submit:hover {
    background: var(--color-velvet-hover);
    transform: translateY(-2px);
}

.lg-premium-footer__body {
    background: var(--color-bg-main);
    display: grid;
    grid-template-columns: minmax(0, 300px) 1fr;
    gap: var(--space-8);
    align-items: start;
    width: min(100%, 1400px);
    margin-left: auto;
    margin-right: auto;
    padding: var(--space-12) var(--space-8) var(--space-8);
    padding-top: 200px;
}

.lg-premium-footer__branding {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.lg-premium-footer__logo {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
    color: var(--text-primary);
}

.lg-premium-footer__logo img {
    width: 48px;
    height: 48px;
    object-fit: contain;
    filter: brightness(1.1);
}

.lg-premium-footer__logo-text {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--tracking-wide);
}

.lg-premium-footer__logo small {
    display: block;
    font-size: var(--text-xs);
    color: var(--text-secondary);
    font-weight: var(--font-weight-normal);
    letter-spacing: var(--tracking-wide);
}

.lg-premium-footer__branding p {
    color: var(--text-secondary);
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
}

.lg-premium-footer__columns {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-6);
}

.lg-premium-footer__columns h3 {
    margin-bottom: var(--space-3);
    text-transform: capitalize;
    color: var(--text-primary);
    font-family: var(--font-heading);
    font-size: var(--text-base);
    font-weight: var(--font-weight-semibold);
}

.lg-premium-footer__columns ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: var(--space-2);
}

.lg-premium-footer__columns a {
    color: var(--text-secondary);
    text-decoration: none;
    font-size: var(--text-sm);
    transition: color var(--transition-base);
}

.lg-premium-footer__columns a:hover {
    color: var(--color-velvet);
}

.lg-premium-footer__columns p {
    color: var(--text-secondary);
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
}

.lg-premium-footer__social {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
}

.lg-premium-footer__social a {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-full);
    border: 1px solid var(--color-velvet-soft);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: var(--text-primary);
    font-size: var(--text-xs);
    transition: all var(--transition-base);
}

.lg-premium-footer__social a:hover {
    background: var(--color-velvet);
    border-color: var(--color-velvet);
    color: var(--color-bg-main);
    transform: translateY(-2px);
}

.lg-premium-footer__legal {
    text-align: center;
    font-size: var(--text-sm);
    color: var(--text-muted);
    border-top: 1px solid var(--border-subtle);
    padding-top: var(--space-5);
    width: min(100%, 1400px);
    margin-left: auto;
    margin-right: auto;
}

@media (max-width: 900px) {

    .lg-premium-footer__cta,
    .lg-premium-footer__body {
        width: 100%;
        border-radius: 0;
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }

    .lg-premium-footer__cta-form {
        grid-template-columns: minmax(0, 1fr);
    }

    .lg-premium-footer {
        padding: 0;
    }

    .lg-premium-footer__cta,
    .lg-premium-footer__body {
        padding-top: clamp(1rem, 3vw, 1.75rem);
        padding-bottom: clamp(1rem, 3vw, 1.75rem);
    }

    .lg-premium-footer__body {
        padding-left: clamp(0.5rem, 3vw, 1rem);
        padding-right: clamp(0.5rem, 3vw, 1rem);
    }

    .lg-premium-footer__cta-pill,
    .lg-premium-footer__cta-title,
    .lg-premium-footer__cta-text,
    .lg-premium-footer__branding,
    .lg-premium-footer__columns {
        padding-left: clamp(0.5rem, 3vw, 1rem);
        padding-right: clamp(0.5rem, 3vw, 1rem);
    }
}

/* ============================================
   CONFIGURATOR CARDS - Dark Luxury Theme
   ============================================ */

.lordglass-configurator {
    background: var(--color-bg-main);
    padding: var(--space-12) 0;
}

.lordglass-configurator__cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--space-6);
}

.lordglass-config-card {
    background: var(--color-bg-surface);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-xl);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    position: relative;
}

.lordglass-config-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

.lordglass-config-card__badge {
    position: absolute;
    top: var(--space-3);
    left: var(--space-3);
    background: var(--color-velvet);
    color: var(--color-bg-main);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
    z-index: 2;
}

.lordglass-config-card__media {
    margin: 0;
    aspect-ratio: 16 / 10;
    overflow: hidden;
}

.lordglass-config-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.lordglass-config-card:hover .lordglass-config-card__media img {
    transform: scale(1.05);
}

.lordglass-config-card__body {
    padding: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    flex: 1;
}

.lordglass-config-card__title-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-3);
}

.lordglass-config-card__title {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin: 0;
}

.lordglass-config-card__range {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    background: var(--color-bg-main);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-md);
    flex-shrink: 0;
}

.lordglass-config-card__range svg {
    width: 16px;
    height: 16px;
    color: var(--color-velvet);
}

.lordglass-config-card__range span {
    font-size: var(--text-xs);
    font-weight: var(--font-weight-semibold);
    color: var(--color-velvet);
}

.lordglass-config-card__features {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.lordglass-config-card__features li {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.lordglass-config-card__features li::before {
    content: '✓';
    color: var(--color-velvet);
    font-weight: var(--font-weight-bold);
    flex-shrink: 0;
}

.lordglass-config-card__pill {
    background: var(--color-velvet-soft);
    color: var(--color-velvet);
    padding: 0.125rem 0.5rem;
    border-radius: var(--radius-sm);
    font-size: var(--text-xs);
    font-weight: var(--font-weight-medium);
    margin-left: var(--space-1);
}

.lordglass-config-card__pricing {
    display: flex;
    align-items: baseline;
    gap: var(--space-3);
    margin-top: auto;
}

.lordglass-config-card__old-price {
    font-size: var(--text-sm);
    color: var(--text-muted);
    text-decoration: line-through;
}

.lordglass-config-card__price {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-velvet);
}

.lordglass-config-card__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    background: var(--color-velvet);
    color: var(--color-bg-main);
    padding: var(--space-3) var(--space-5);
    border-radius: var(--radius-lg);
    font-size: var(--text-sm);
    font-weight: var(--font-weight-semibold);
    transition: all var(--transition-base);
}

.lordglass-config-card:hover .lordglass-config-card__cta {
    background: var(--color-velvet-hover);
}

.lordglass-config-card__cta svg {
    width: 18px;
    height: 18px;
    transition: transform var(--transition-base);
}

.lordglass-config-card:hover .lordglass-config-card__cta svg {
    transform: translateX(4px);
}

.lordglass-config-card__delivery {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding-top: var(--space-3);
    border-top: 1px solid var(--border-subtle);
    font-size: var(--text-xs);
    color: var(--text-muted);
}

.lordglass-config-card__delivery svg {
    width: 14px;
    height: 14px;
    color: var(--color-velvet);
    flex-shrink: 0;
}

/* Configurator Cards Responsive */
@media (max-width: 768px) {
    .lordglass-configurator__cards {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   CATALOG PAGE STYLES
   ============================================ */

.lordglass-catalog {
    padding-top: 80px;
    /* Account for fixed header */
    min-height: 100vh;
}

/* Catalog Container */
.lordglass-catalog__container {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 var(--space-6);
}

/* Catalog Header Section */
.lordglass-catalog__header {
    padding: var(--space-12) 0 var(--space-8);
    background: linear-gradient(180deg,
            var(--color-onyx) 0%,
            var(--color-dusk) 100%);
    border-bottom: 1px solid rgba(164, 136, 126, 0.2);
}

/* Breadcrumb Navigation */
.lordglass-catalog__breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-4);
    font-size: var(--text-sm);
}

.lordglass-catalog__breadcrumb-link {
    color: var(--color-canvas);
    text-decoration: none;
    opacity: 0.7;
    transition: opacity 0.2s ease;
}

.lordglass-catalog__breadcrumb-link:hover {
    opacity: 1;
    color: var(--color-velvet);
}

.lordglass-catalog__breadcrumb-sep {
    color: var(--color-canvas);
    opacity: 0.4;
}

.lordglass-catalog__breadcrumb-current {
    color: var(--color-canvas);
    opacity: 0.9;
}

/* Catalog Title */
.lordglass-catalog__title {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 600;
    color: var(--color-canvas);
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin: 0 0 var(--space-4);
}

.lordglass-catalog__subtitle {
    font-size: var(--text-lg);
    color: var(--color-canvas);
    opacity: 0.75;
    max-width: 600px;
    line-height: 1.6;
    margin: 0;
}

/* Product Grid in Catalog */
.lordglass-catalog .lordglass-products {
    padding: var(--space-12) 0;
    background-color: var(--color-onyx);
}

.lordglass-catalog .lordglass-products__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
}

.lordglass-catalog .lordglass-products__grid[data-cols="2"] {
    grid-template-columns: repeat(2, 1fr);
}

.lordglass-catalog .lordglass-products__grid[data-cols="4"] {
    grid-template-columns: repeat(4, 1fr);
}

/* Card Description for Catalog */
.lordglass-card__description {
    font-size: var(--text-sm);
    color: var(--color-canvas);
    opacity: 0.75;
    line-height: 1.6;
    margin-bottom: var(--space-4);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Empty State */
.lordglass-catalog__empty {
    text-align: center;
    padding: var(--space-16) var(--space-8);
    background: var(--color-dusk);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(164, 136, 126, 0.2);
}

.lordglass-catalog__empty-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--space-6);
    color: var(--color-velvet);
    opacity: 0.6;
}

.lordglass-catalog__empty-text {
    font-size: var(--text-lg);
    color: var(--color-canvas);
    opacity: 0.7;
    margin: 0 0 var(--space-6);
}

/* Catalog Responsive */
@media (max-width: 1024px) {
    .lordglass-catalog .lordglass-products__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-6);
    }

    .lordglass-catalog .lordglass-products__grid[data-cols="4"] {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .lordglass-catalog__container {
        padding: 0 var(--space-4);
    }

    .lordglass-catalog__header {
        padding: var(--space-8) 0 var(--space-6);
    }

    .lordglass-catalog .lordglass-products {
        padding: var(--space-8) 0;
    }

    .lordglass-catalog .lordglass-products__grid,
    .lordglass-catalog .lordglass-products__grid[data-cols="2"],
    .lordglass-catalog .lordglass-products__grid[data-cols="4"] {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }
}

/* Visually Hidden (for screen readers) */
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ============================================
   PRODUCT DETAIL PAGE (PDP) STYLES
   ============================================ */

.lordglass-pdp {
    padding-top: 80px;
    min-height: 100vh;
    background-color: var(--color-onyx);
}

/* PDP Container */
.lordglass-pdp__container {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 var(--space-6);
}

/* Breadcrumb */
.lordglass-pdp__breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-6) 0;
    font-size: var(--text-sm);
}

.lordglass-pdp__breadcrumb-link {
    color: var(--color-canvas);
    text-decoration: none;
    opacity: 0.7;
    transition: all 0.2s ease;
}

.lordglass-pdp__breadcrumb-link:hover {
    opacity: 1;
    color: var(--color-velvet);
}

.lordglass-pdp__breadcrumb-sep {
    color: var(--color-canvas);
    opacity: 0.4;
}

.lordglass-pdp__breadcrumb-current {
    color: var(--color-canvas);
    opacity: 0.9;
}

/* Main Product Grid */
.lordglass-pdp__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    padding-bottom: var(--space-12);
}

/* Gallery Section */
.lordglass-pdp__gallery {
    position: sticky;
    top: 100px;
    align-self: start;
}

.lordglass-pdp__gallery-main {
    width: 100%;
    aspect-ratio: 4/3;
    border-radius: var(--radius-xl);
    overflow: hidden;
    background: var(--color-dusk);
    border: 1px solid rgba(164, 136, 126, 0.2);
    margin-bottom: var(--space-4);
}

.lordglass-pdp__gallery-main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.lordglass-pdp__gallery-main:hover img {
    transform: scale(1.02);
}

.lordglass-pdp__gallery-thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: var(--space-3);
}

.lordglass-pdp__gallery-thumb {
    aspect-ratio: 1;
    border-radius: var(--radius-md);
    overflow: hidden;
    cursor: pointer;
    border: 2px solid transparent;
    background: var(--color-dusk);
    padding: 0;
    transition: all 0.2s ease;
}

.lordglass-pdp__gallery-thumb:hover,
.lordglass-pdp__gallery-thumb:focus {
    border-color: var(--color-velvet);
    transform: scale(1.05);
}

.lordglass-pdp__gallery-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Upload Area (Edit Mode) */
.lordglass-pdp__upload-area {
    margin-top: var(--space-4);
    padding: var(--space-8);
    border: 2px dashed rgba(164, 136, 126, 0.4);
    border-radius: var(--radius-lg);
    text-align: center;
    cursor: pointer;
    transition: all 0.2s ease;
    color: var(--color-canvas);
    opacity: 0.7;
}

.lordglass-pdp__upload-area:hover {
    border-color: var(--color-velvet);
    opacity: 1;
}

.lordglass-pdp__upload-area svg {
    margin-bottom: var(--space-2);
}

/* Product Info Section */
.lordglass-pdp__info {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.lordglass-pdp__title {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 4vw, 3.5rem);
    font-weight: 600;
    color: var(--color-canvas);
    letter-spacing: -0.02em;
    line-height: 1.1;
    margin: 0;
}

.lordglass-pdp__subtitle {
    font-size: var(--text-lg);
    color: var(--color-canvas);
    opacity: 0.75;
    line-height: 1.6;
    margin: 0;
}

/* Price Box */
.lordglass-pdp__price-box {
    display: flex;
    align-items: baseline;
    gap: var(--space-3);
    padding: var(--space-4) 0;
    border-top: 1px solid rgba(164, 136, 126, 0.2);
    border-bottom: 1px solid rgba(164, 136, 126, 0.2);
}

.lordglass-pdp__price-label {
    font-size: var(--text-sm);
    color: var(--color-canvas);
    opacity: 0.6;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.lordglass-pdp__price {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 3vw, 2.5rem);
    font-weight: 600;
    color: var(--color-velvet);
    letter-spacing: -0.02em;
}

/* Short Description */
.lordglass-pdp__desc {
    font-size: var(--text-base);
    color: var(--color-canvas);
    opacity: 0.8;
    line-height: 1.7;
}

/* Features List */
.lordglass-pdp__features {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.lordglass-pdp__feature {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--text-sm);
    color: var(--color-canvas);
    opacity: 0.85;
}

.lordglass-pdp__feature svg {
    width: 18px;
    height: 18px;
    color: var(--color-velvet);
    flex-shrink: 0;
}

/* Actions / Buy Box */
.lordglass-pdp__actions {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    padding-top: var(--space-4);
}

/* Button Styles */
.lordglass-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-lg);
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    border: none;
    transition: all 0.3s ease;
}

.lordglass-btn--primary {
    background: var(--color-velvet);
    color: #fff;
}

.lordglass-btn--primary:hover {
    background: #8a7268;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(164, 136, 126, 0.4);
}

.lordglass-btn--secondary {
    background: transparent;
    color: var(--color-canvas);
    border: 1px solid rgba(234, 234, 225, 0.3);
}

.lordglass-btn--secondary:hover {
    background: rgba(234, 234, 225, 0.1);
    border-color: var(--color-canvas);
}

.lordglass-btn--lg {
    padding: var(--space-4) var(--space-8);
    font-size: var(--text-base);
}

.lordglass-btn--full {
    width: 100%;
}

/* Trust Badge */
.lordglass-pdp__trust {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    font-size: var(--text-xs);
    color: var(--color-canvas);
    opacity: 0.6;
}

.lordglass-pdp__trust svg {
    color: var(--color-velvet);
}

/* Details Section */
.lordglass-pdp__details {
    padding: var(--space-12) 0;
    background: var(--color-dusk);
    border-top: 1px solid rgba(164, 136, 126, 0.2);
}

.lordglass-pdp__details-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-8);
}

.lordglass-pdp__section {
    background: var(--color-onyx);
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    border: 1px solid rgba(164, 136, 126, 0.15);
}

.lordglass-pdp__section--full {
    grid-column: 1 / -1;
}

.lordglass-pdp__section-title {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--color-canvas);
    margin: 0 0 var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid rgba(164, 136, 126, 0.2);
}

.lordglass-pdp__section-content {
    font-size: var(--text-base);
    color: var(--color-canvas);
    opacity: 0.85;
    line-height: 1.7;
}

.lordglass-pdp__section-content ul {
    padding-left: var(--space-4);
}

.lordglass-pdp__section-content li {
    margin-bottom: var(--space-2);
}

/* Edit Mode Banner */
.lordglass-pdp__edit-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(135deg, #28a745, #20c997);
    color: white;
    padding: var(--space-3) var(--space-4);
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--space-4);
    z-index: 10000;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.lordglass-pdp__edit-banner-text {
    font-size: var(--text-sm);
}

.lordglass-pdp__edit-banner-actions {
    display: flex;
    gap: var(--space-2);
}

/* Admin Button */
.lordglass-pdp__admin-btn {
    position: fixed;
    bottom: var(--space-6);
    right: var(--space-6);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    background: var(--color-velvet);
    color: #fff;
    border-radius: 999px;
    text-decoration: none;
    font-size: var(--text-sm);
    font-weight: 600;
    z-index: 9999;
    box-shadow: 0 8px 24px rgba(164, 136, 126, 0.4);
    transition: all 0.3s ease;
}

.lordglass-pdp__admin-btn:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(164, 136, 126, 0.5);
}

/* Loading Spinner */
.lordglass-pdp__loading {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(29, 28, 28, 0.8);
    z-index: 10001;
    justify-content: center;
    align-items: center;
}

.lordglass-pdp__loading.active {
    display: flex;
}

.lordglass-pdp__spinner {
    width: 50px;
    height: 50px;
    border: 3px solid rgba(164, 136, 126, 0.3);
    border-top-color: var(--color-velvet);
    border-radius: 50%;
    animation: pdp-spin 1s linear infinite;
}

@keyframes pdp-spin {
    to {
        transform: rotate(360deg);
    }
}

/* Message Toast */
.lordglass-pdp__message {
    position: fixed;
    top: 100px;
    right: var(--space-6);
    padding: var(--space-4) var(--space-6);
    border-radius: var(--radius-lg);
    font-size: var(--text-sm);
    font-weight: 600;
    z-index: 10002;
    animation: slideInRight 0.3s ease;
}

.lordglass-pdp__message--success {
    background: #28a745;
    color: white;
}

.lordglass-pdp__message--error {
    background: #dc3545;
    color: white;
}

@keyframes slideInRight {
    from {
        transform: translateX(100%);
        opacity: 0;
    }

    to {
        transform: translateX(0);
        opacity: 1;
    }
}

/* Editable Elements */
[data-edit-mode="true"] .editable {
    cursor: pointer;
    transition: outline 0.2s ease;
}

[data-edit-mode="true"] .editable:hover {
    outline: 2px dashed var(--color-velvet);
    outline-offset: 4px;
}

/* PDP Responsive */
@media (max-width: 1024px) {
    .lordglass-pdp__grid {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    .lordglass-pdp__gallery {
        position: static;
    }

    .lordglass-pdp__details-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .lordglass-pdp__container {
        padding: 0 var(--space-4);
    }

    .lordglass-pdp__title {
        font-size: 1.75rem;
    }

    .lordglass-pdp__price {
        font-size: 1.75rem;
    }

    .lordglass-pdp__section {
        padding: var(--space-6);
    }

    .lordglass-pdp__edit-banner {
        flex-direction: column;
        gap: var(--space-2);
        padding: var(--space-2);
    }
}

/* ============================================
   STANDARD PAGE STYLES
   ============================================ */

.lordglass-page {
    padding-top: 80px;
    min-height: 100vh;
    background-color: var(--color-onyx);
}

/* Page Header */
.lordglass-page__header {
    padding: var(--space-12) 0 var(--space-8);
    background: linear-gradient(180deg,
            var(--color-onyx) 0%,
            var(--color-dusk) 100%);
    border-bottom: 1px solid rgba(164, 136, 126, 0.2);
    text-align: center;
}

.lordglass-page__title {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 600;
    color: var(--color-canvas);
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin: 0 0 var(--space-4);
}

.lordglass-page__subtitle {
    font-size: var(--text-lg);
    color: var(--color-canvas);
    opacity: 0.75;
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.6;
}

/* Page Content */
.lordglass-page__content {
    padding: var(--space-12) 0;
}

/* Page Grid (2-column) */
.lordglass-page__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-8);
    margin-bottom: var(--space-12);
}

/* Page Section */
.lordglass-page__section {
    background: var(--color-dusk);
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    border: 1px solid rgba(164, 136, 126, 0.15);
}

.lordglass-page__section--centered {
    max-width: 600px;
    margin: 0 auto var(--space-8);
    text-align: center;
}

.lordglass-page__section-title {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--color-canvas);
    margin: 0 0 var(--space-6);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid rgba(164, 136, 126, 0.2);
}

/* Contact Card */
.lordglass-contact-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.lordglass-contact-card__item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
}

.lordglass-contact-card__icon {
    width: 24px;
    height: 24px;
    color: var(--color-velvet);
    flex-shrink: 0;
    margin-top: 2px;
}

.lordglass-contact-card__label {
    display: block;
    font-size: var(--text-xs);
    color: var(--color-canvas);
    opacity: 0.6;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: var(--space-1);
}

.lordglass-contact-card__value {
    font-size: var(--text-base);
    color: var(--color-velvet);
    text-decoration: none;
    transition: opacity 0.2s ease;
}

.lordglass-contact-card__value:hover {
    opacity: 0.8;
}

.lordglass-contact-card__address {
    font-size: var(--text-base);
    color: var(--color-canvas);
    font-style: normal;
    line-height: 1.6;
    opacity: 0.85;
}

/* Opening Hours */
.lordglass-hours {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.lordglass-hours__row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-3) 0;
    border-bottom: 1px solid rgba(164, 136, 126, 0.1);
}

.lordglass-hours__row:last-child {
    border-bottom: none;
}

.lordglass-hours__day {
    font-size: var(--text-base);
    color: var(--color-canvas);
    opacity: 0.85;
}

.lordglass-hours__time {
    font-size: var(--text-base);
    color: var(--color-velvet);
    font-weight: 500;
}

/* Page CTA */
.lordglass-page__cta {
    text-align: center;
    padding-top: var(--space-8);
}

/* ============================================
   FORM STYLES
   ============================================ */

.lordglass-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}

.lordglass-form__group {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.lordglass-form__label {
    font-size: var(--text-sm);
    color: var(--color-canvas);
    font-weight: 500;
}

.lordglass-form__label--required::after {
    content: " *";
    color: var(--color-velvet);
}

.lordglass-form__input,
.lordglass-form__textarea,
.lordglass-form__select {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    background: var(--color-onyx);
    border: 1px solid rgba(164, 136, 126, 0.3);
    border-radius: var(--radius-md);
    color: var(--color-canvas);
    font-family: var(--font-body);
    font-size: var(--text-base);
    transition: all 0.2s ease;
}

.lordglass-form__input::placeholder,
.lordglass-form__textarea::placeholder {
    color: var(--color-canvas);
    opacity: 0.4;
}

.lordglass-form__input:focus,
.lordglass-form__textarea:focus,
.lordglass-form__select:focus {
    outline: none;
    border-color: var(--color-velvet);
    box-shadow: 0 0 0 3px rgba(164, 136, 126, 0.2);
}

.lordglass-form__textarea {
    min-height: 150px;
    resize: vertical;
}

.lordglass-form__select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23EAEAE1' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-4) center;
    padding-right: var(--space-10);
}

.lordglass-form__checkbox {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
}

.lordglass-form__checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--color-velvet);
    cursor: pointer;
    flex-shrink: 0;
    margin-top: 2px;
}

.lordglass-form__checkbox-label {
    font-size: var(--text-sm);
    color: var(--color-canvas);
    opacity: 0.85;
    line-height: 1.5;
}

.lordglass-form__error {
    font-size: var(--text-xs);
    color: #dc3545;
    margin-top: var(--space-1);
}

.lordglass-form__help {
    font-size: var(--text-xs);
    color: var(--color-canvas);
    opacity: 0.6;
    margin-top: var(--space-1);
}

.lordglass-form__actions {
    padding-top: var(--space-4);
}

/* ============================================
   PROSE / TYPOGRAPHY FOR TEXT CONTENT
   ============================================ */

.lordglass-prose {
    color: var(--color-canvas);
    font-size: var(--text-base);
    line-height: 1.8;
}

.lordglass-prose h2 {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    font-weight: 600;
    color: var(--color-canvas);
    margin: var(--space-8) 0 var(--space-4);
}

.lordglass-prose h3 {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--color-canvas);
    margin: var(--space-6) 0 var(--space-3);
}

.lordglass-prose h4 {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-canvas);
    margin: var(--space-4) 0 var(--space-2);
}

.lordglass-prose p {
    margin: 0 0 var(--space-4);
    opacity: 0.85;
}

.lordglass-prose a {
    color: var(--color-velvet);
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: opacity 0.2s ease;
}

.lordglass-prose a:hover {
    opacity: 0.8;
}

.lordglass-prose ul,
.lordglass-prose ol {
    margin: 0 0 var(--space-4);
    padding-left: var(--space-6);
}

.lordglass-prose li {
    margin-bottom: var(--space-2);
    opacity: 0.85;
}

.lordglass-prose blockquote {
    margin: var(--space-6) 0;
    padding: var(--space-4) var(--space-6);
    border-left: 3px solid var(--color-velvet);
    background: rgba(164, 136, 126, 0.1);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    font-style: italic;
    opacity: 0.9;
}

.lordglass-prose img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    margin: var(--space-6) 0;
}

.lordglass-prose table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--space-6) 0;
}

.lordglass-prose th,
.lordglass-prose td {
    padding: var(--space-3) var(--space-4);
    border: 1px solid rgba(164, 136, 126, 0.2);
    text-align: left;
}

.lordglass-prose th {
    background: var(--color-dusk);
    font-weight: 600;
}

.lordglass-prose code {
    background: var(--color-dusk);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    font-family: monospace;
    font-size: 0.9em;
}

.lordglass-prose pre {
    background: var(--color-dusk);
    padding: var(--space-4);
    border-radius: var(--radius-md);
    overflow-x: auto;
    margin: var(--space-6) 0;
}

.lordglass-prose pre code {
    background: none;
    padding: 0;
}

/* Page Responsive */
@media (max-width: 768px) {
    .lordglass-page__grid {
        grid-template-columns: 1fr;
    }

    .lordglass-page__header {
        padding: var(--space-8) 0 var(--space-6);
    }

    .lordglass-page__content {
        padding: var(--space-8) 0;
    }

    .lordglass-page__section {
        padding: var(--space-6);
    }
}

/* ============================================
   PRINT STYLES
   ============================================ */

@media print {

    .lordglass-header,
    .lordglass-menu,
    .lordglass-footer {
        display: none !important;
    }

    body {
        color: #000;
        background: #fff;
    }
}

/* ============================================
   STEELLOOK PRODUCT PAGES - DARK LUXURY
   Replaces inline styles from steellook templates
   ============================================ */

/* Page-level Dark Overrides for Steellook */
.lg-page--product,
.steellook {
    background: var(--color-onyx) !important;
    color: var(--color-canvas) !important;
}

.lg-page--product #main,
.steellook #main {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    background: var(--color-onyx);
}

/* Shell Container */
.lg-shell {
    width: min(100%, 1480px);
    margin: 0 auto;
    padding: clamp(1rem, 3vw, 2.5rem);
}

/* Product Section */
.product-section {
    padding-top: clamp(1rem, 2vw, 2rem);
}

/* Product Layout - 2 Column Grid */
.product-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr);
    gap: clamp(1.5rem, 3vw, 3.5rem);
    align-items: flex-start;
    width: min(100%, 1200px);
    margin: 0 auto;
    justify-content: center;
}

.product-media-column {
    position: sticky;
    top: calc(var(--lg-premium-body-offset, 80px) + 12px);
    align-self: flex-start;
    height: fit-content;
}

.stack {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

/* Steellook Panels - Dark Theme */
.media-panel,
.info-panel,
.form-panel,
.options-panel,
.summary-panel,
.utility-panel {
    background: var(--color-dusk);
    border-radius: var(--radius-xl);
    padding: clamp(1.25rem, 3vw, 2rem);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(164, 136, 126, 0.15);
}

/* Media Panel */
.media-main {
    border-radius: calc(var(--radius-xl) - 8px);
    overflow: hidden;
}

.media-main img {
    width: 100%;
    display: block;
}

/* Thumbnail Gallery */
.thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 0.85rem;
    margin-top: 1rem;
}

.thumb {
    border-radius: var(--radius-lg);
    min-height: 78px;
    border: 2px solid transparent;
    overflow: hidden;
    cursor: pointer;
    transition: border-color 0.2s ease;
}

.thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.thumb:hover,
.thumb.is-active {
    border-color: var(--color-velvet);
}

.thumb--placeholder {
    background: rgba(164, 136, 126, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-velvet);
    font-size: 1.5rem;
    font-weight: 600;
}

/* Product Info Panel */
.product-pill {
    display: inline-block;
    padding: 6px 16px;
    background: var(--color-velvet);
    color: var(--color-onyx);
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--space-3);
}

.info-panel h1 {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    font-weight: 600;
    color: var(--color-canvas);
    margin: 0 0 var(--space-4);
}

/* Price Row */
.price-row {
    display: flex;
    align-items: baseline;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}

.price-current {
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--color-velvet);
}

.price-old {
    font-size: var(--text-lg);
    color: var(--color-canvas);
    opacity: 0.5;
    text-decoration: line-through;
}

/* Badge List */
.badge-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.badge-list span {
    padding: 6px 12px;
    background: rgba(164, 136, 126, 0.15);
    border: 1px solid rgba(164, 136, 126, 0.25);
    border-radius: var(--radius-md);
    font-size: var(--text-xs);
    color: var(--color-canvas);
}

/* Form Panel - Configurator Fields */
.form-panel h2 {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-canvas);
    margin-bottom: var(--space-4);
}

.form-grid {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.field {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.field label {
    font-weight: 600;
    color: var(--color-canvas);
    font-size: var(--text-sm);
}

.field input[type="number"],
.field select {
    width: 100%;
    padding: 12px 16px;
    background: var(--color-onyx);
    border: 1px solid rgba(164, 136, 126, 0.3);
    border-radius: var(--radius-md);
    color: var(--color-canvas);
    font-size: var(--text-base);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.field input[type="number"]:focus,
.field select:focus {
    outline: none;
    border-color: var(--color-velvet);
    box-shadow: 0 0 0 3px rgba(164, 136, 126, 0.15);
}

/* Glass Picker */
.glass-picker {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
}

.glass-card {
    position: relative;
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--color-onyx);
    border: 2px solid rgba(164, 136, 126, 0.2);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease;
    flex: 1;
    min-width: 140px;
}

.glass-card:hover {
    border-color: rgba(164, 136, 126, 0.4);
}

.glass-card.is-active {
    border-color: var(--color-velvet);
    background: rgba(164, 136, 126, 0.1);
}

.glass-card input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.glass-card__check {
    position: absolute;
    top: -8px;
    right: -8px;
    width: 24px;
    height: 24px;
    background: var(--color-velvet);
    border-radius: 50%;
    display: none;
    align-items: center;
    justify-content: center;
    color: var(--color-onyx);
}

.glass-card__check svg {
    width: 14px;
    height: 14px;
}

.glass-card.is-active .glass-card__check {
    display: flex;
}

.glass-card__label {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-canvas);
}

/* Color Picker */
.color-picker {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.color-dot {
    position: relative;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    cursor: pointer;
    border: 3px solid transparent;
    transition: border-color 0.2s ease, transform 0.2s ease;
}

.color-dot:hover {
    transform: scale(1.1);
}

.color-dot.is-active {
    border-color: var(--color-velvet);
}

.color-dot input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.color-dot__check {
    position: absolute;
    top: -4px;
    right: -4px;
    width: 20px;
    height: 20px;
    background: var(--color-velvet);
    border-radius: 50%;
    display: none;
    align-items: center;
    justify-content: center;
    color: var(--color-onyx);
}

.color-dot.is-active .color-dot__check {
    display: flex;
}

.color-swatch {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

/* Options Panel */
.options-panel h2 {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-canvas);
    margin-bottom: var(--space-4);
}

.options-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

/* Option Card - Dark Theme */
.option-card {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--space-3);
    align-items: center;
    padding: var(--space-4);
    background: var(--color-onyx);
    border: 2px solid rgba(164, 136, 126, 0.15);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease;
}

.option-card:hover {
    border-color: rgba(164, 136, 126, 0.35);
}

.option-card.is-selected {
    border-color: var(--color-velvet);
    background: rgba(164, 136, 126, 0.08);
}

.option-card.is-highlight {
    border-color: var(--color-velvet);
}

.option-card__check {
    position: absolute;
    top: -10px;
    right: -10px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: var(--color-velvet);
    color: var(--color-onyx);
    display: none;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(164, 136, 126, 0.3);
}

.option-card__check svg {
    width: 14px;
    height: 14px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
}

.option-card.is-selected .option-card__check {
    display: inline-flex;
}

.option-card__media {
    width: 70px;
    height: 70px;
    border-radius: var(--radius-md);
    overflow: hidden;
    flex-shrink: 0;
}

.option-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.option-card__body {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.option-card__body h4 {
    margin: 0;
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--color-canvas);
}

.option-card__subtitle {
    color: var(--color-canvas);
    opacity: 0.6;
    font-size: var(--text-sm);
}

.option-card__header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.option-card__info-wrap {
    position: relative;
    display: inline-flex;
}

.option-card__info {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--color-velvet);
    color: var(--color-onyx);
    font-weight: 600;
    font-size: 0.8rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    cursor: pointer;
    transition: opacity 0.2s ease;
}

.option-card__info:hover {
    opacity: 0.8;
}

.option-card__popover {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: clamp(220px, 25vw, 300px);
    background: var(--color-dusk);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(164, 136, 126, 0.2);
    color: var(--color-canvas);
    font-size: var(--text-sm);
    display: none;
    z-index: 20;
}

.option-card__popover::after {
    content: "";
    position: absolute;
    top: -8px;
    right: 14px;
    width: 14px;
    height: 14px;
    background: var(--color-dusk);
    border-left: 1px solid rgba(164, 136, 126, 0.2);
    border-top: 1px solid rgba(164, 136, 126, 0.2);
    transform: rotate(45deg);
}

.option-card.is-info-open .option-card__popover {
    display: block;
}

.option-card__popover-close {
    position: absolute;
    top: 8px;
    right: 10px;
    border: none;
    background: transparent;
    font-size: 1.2rem;
    color: var(--color-canvas);
    opacity: 0.6;
    cursor: pointer;
    line-height: 1;
}

.option-card__popover-close:hover {
    opacity: 1;
}

.option-card__badge {
    background: var(--color-velvet);
    color: var(--color-onyx);
    font-size: var(--text-xs);
    padding: 4px 10px;
    border-radius: var(--radius-sm);
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.option-card__price {
    font-weight: 700;
    font-size: var(--text-base);
    color: var(--color-velvet);
}

.option-card__meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}

/* Summary Panel */
.summary-panel h2 {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-canvas);
    margin-bottom: var(--space-4);
}

.summary-panel ul {
    list-style: none;
    margin: 0 0 var(--space-4);
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.summary-panel li {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-sm);
    color: var(--color-canvas);
    opacity: 0.85;
}

.summary-total {
    display: flex;
    justify-content: space-between;
    padding-top: var(--space-4);
    border-top: 1px solid rgba(164, 136, 126, 0.2);
    margin-top: var(--space-4);
}

.summary-total strong {
    font-size: var(--text-xl);
    color: var(--color-canvas);
}

.summary-price--accent {
    color: var(--color-velvet);
    font-weight: 700;
}

/* Buy Button */
.buy-button {
    width: 100%;
    border: none;
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    background: var(--color-velvet);
    color: var(--color-onyx);
    font-weight: 600;
    font-size: var(--text-base);
    cursor: pointer;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.buy-button:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

/* Service Note */
.service-note {
    display: flex;
    gap: var(--space-2);
    align-items: center;
    color: var(--color-velvet);
    font-size: var(--text-sm);
    margin-top: var(--space-3);
}

/* Guarantee Card */
.guarantee-card {
    border-color: rgba(164, 136, 126, 0.3);
}

/* Home Hero Footer (Steellook Features) */
.home-hero__footer {
    position: relative;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: clamp(0.5rem, 1.5vw, 0.8rem);
    width: min(1000px, 92vw);
    margin: clamp(1rem, 3vw, 1.5rem) auto;
    padding: 0;
    list-style: none;
}

.home-hero__footer--premium .footer-feature {
    position: relative;
    display: flex;
    align-items: center;
    gap: clamp(0.35rem, 1vw, 0.6rem);
    padding: clamp(0.5rem, 1.2vw, 0.75rem) clamp(0.6rem, 1.5vw, 1rem);
    border-radius: clamp(0.7rem, 1.5vw, 1rem);
    background: var(--color-dusk);
    border: 1px solid rgba(164, 136, 126, 0.25);
    overflow: hidden;
    isolation: isolate;
    color: var(--color-canvas);
}

.home-hero__footer--premium .footer-feature__icon {
    position: relative;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: center;
    width: clamp(1.3rem, 2.5vw, 1.7rem);
    height: clamp(1.3rem, 2.5vw, 1.7rem);
    color: var(--color-velvet);
}

.home-hero__footer--premium .footer-feature__icon svg {
    width: 100%;
    height: 100%;
    stroke: currentColor;
}

.home-hero__footer--premium .footer-feature__text {
    position: relative;
    z-index: 3;
    font-size: clamp(0.7rem, 1.3vw, 0.85rem);
    font-weight: 600;
    color: var(--color-canvas);
    white-space: nowrap;
}

/* FAQ Details in Option Cards */
[data-faq-item] {
    display: block;
    padding: var(--space-3) var(--space-4);
    cursor: pointer;
}

[data-faq-item] summary {
    display: block;
    font-weight: 600;
    color: var(--color-canvas);
    margin-bottom: var(--space-2);
}

[data-faq-item] summary::marker,
[data-faq-item] summary::-webkit-details-marker {
    display: none;
}

/* Steellook Responsive */
@media (max-width: 1080px) {
    .product-layout {
        grid-template-columns: 1fr;
    }

    .product-media-column {
        position: static;
        top: auto;
        height: auto;
    }
}

@media (max-width: 820px) {
    .home-hero__footer {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
        width: min(540px, 94vw);
    }

    .home-hero__footer--premium .footer-feature {
        padding: 0.5rem 0.75rem;
    }
}

@media (max-width: 640px) {
    .option-card {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .option-card__media {
        margin: 0 auto;
    }

    .option-card__meta {
        align-items: center;
    }
}