/*
Theme Name: LESTHETIQUE
Description: Premium Fashion & Beauty WordPress Theme
Version: 1.0
*/

/* Import Fonts */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&display=swap');

/* Reset & Base */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
    line-height: 1.6;
    color: #fff;
    padding-top: 70px;
    background: #050505; /* deeper black for moodier aesthetic */
    overflow-x: hidden;
}

/* Header */
.main-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    background: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(25px) saturate(120%);
    -webkit-backdrop-filter: blur(25px) saturate(120%);
    /* remove harsh bottom border in favor of a softer shadow + subtle hairline */
    border-bottom: none;
    box-shadow: 0 8px 20px rgba(0,0,0,0.28);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* --- Contact page white-theme overrides --- */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600&display=swap');
/* Fallback Futura-like web font from Google Fonts (Montserrat). If you prefer a licensed
    Futura from Adobe Fonts provide the kit and I can wire it instead. */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;700&display=swap');
/* Local webfont: Schnyder (you placed the OTF at assets/fonts/Schnyder-M-Demi.otf) */
@font-face {
    font-family: 'Schnyder-M-Demi';
    /* Correct relative path from style.css location */
    src: url('assets/fonts/Schnyder-M-Demi.otf') format('opentype');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
body.contact-page-white .contact-luxury-message {
    font-family: 'Schnyder-M-Demi', 'Playfair Display', serif;
    /* large editorial display: responsive between ~32px and ~84px */
    font-size: clamp(32px, 6.6vw, 62px);
    color: #111;
    text-align: center;
    margin: 36px auto 0 auto;
    max-width: 1200px;
    font-weight: 400; /* toned down from very bold */
    letter-spacing: 0.0px; /* tighter for display face */
    line-height: 1.02; /* slightly more breathable */
    hyphens: auto;
    word-break: break-word;
}
/* Contact Page Luxury Styles */
body.contact-page-white .contact-page {
    background: #fff;
    color: #222;
    font-family: 'Inter', serif;
}

/* Local Futura: use the user-provided TTF placed at assets/fons/Futura-Medium.ttf
   This makes Futura available to font stacks that prefer it. If you later add
   woff/woff2 versions, we can expand the src for better compression/browser support. */
@font-face {
    font-family: 'Futura';
    /* correct path to the TTF placed in the theme's assets/fonts folder */
    src: url('assets/fonts/Futura-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

body.contact-page-white .contact-hero {
    position: relative;
    width: 100vw;
    min-height: 420px;
    overflow: hidden;
    margin-bottom: 0;
}
body.contact-page-white .contact-hero-bg {
    position: relative;
    width: 100vw;
    height: 420px;
    overflow: hidden;
}
body.contact-page-white .contact-hero-img {
    width: 100vw;
    height: 420px;
    object-fit: cover;
    filter: grayscale(0.08) brightness(0.96);
    display: block;
}
body.contact-page-white .contact-hero-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 420px;
    background: linear-gradient(180deg,rgba(255,255,255,0.82) 0%,rgba(255,255,255,0.98) 100%);
    pointer-events: none;
}
body.contact-page-white .contact-hero-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    z-index: 2;
    text-align: center;
    width: 100vw;
}
body.contact-page-white .contact-hero-title {
    font-size: 3.2rem;
    font-weight: 300;
    letter-spacing: 2px;
    color: #222;
    margin-bottom: 18px;
    text-shadow: 0 8px 32px rgba(20,20,24,0.09);
}
body.contact-page-white .contact-hero-desc {
    font-size: 1.22rem;
    color: #444;
    max-width: 520px;
    margin: 0 auto 18px;
    font-weight: 400;
}

body.contact-page-white .contact-info {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 64px;
    margin: 64px 0 48px 0;
}
body.contact-page-white .contact-info-block {
    min-width: 220px;
    text-align: left;
}
body.contact-page-white .contact-info-label {
    font-size: 1.12rem;
    color: #222;
    font-weight: 500;
    margin-bottom: 8px;
    display: block;
    letter-spacing: 1px;
}
body.contact-page-white .contact-info-value {
    color: #666;
    line-height: 1.7;
    font-size: 1.02rem;
    display: block;
}
body.contact-page-white .contact-info-value a {
    color: #222;
    text-decoration: none;
    border-bottom: 1px solid #222;
    transition: color 180ms;
}
body.contact-page-white .contact-info-value a:hover {
    color: #111;
}

body.contact-page-white .contact-main {
    display: flex;
    flex-wrap: wrap;
    gap: 64px;
    justify-content: center;
    align-items: flex-start;
    background: #fff;
    padding: 0 0 64px 0;
    max-width: 1200px;
    margin: 0 auto 0 auto;
}
body.contact-page-white .contact-main-map {
    flex: 1 1 420px;
    min-width: 320px;
    max-width: 520px;
}
body.contact-page-white .contact-main-iframe {
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(20,20,24,0.09);
    margin-bottom: 18px;
    width: 100%;
    min-height: 340px;
    border: 0;
}
body.contact-page-white .contact-main-map-caption {
    text-align: center;
    color: #888;
    font-size: 0.98rem;
}
body.contact-page-white .contact-main-map-caption a {
    color: #222;
    text-decoration: underline;
}
body.contact-page-white .contact-main-form {
    flex: 1 1 420px;
    min-width: 320px;
    max-width: 520px;
}
body.contact-page-white .contact-form {
    background: #fafafa;
    border-radius: 18px;
    box-shadow: 0 8px 32px rgba(20,20,24,0.07);
    padding: 38px 32px;
}
body.contact-page-white .contact-form-title {
    font-size: 1.35rem;
    font-weight: 400;
    color: #222;
    margin-bottom: 18px;
    letter-spacing: 1px;
}
body.contact-page-white .contact-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin-bottom: 18px;
}
body.contact-page-white .contact-form label {
    font-size: 0.98rem;
    color: #222;
    display: block;
    margin-bottom: 18px;
    font-weight: 400;
}
body.contact-page-white .contact-form input,
body.contact-page-white .contact-form textarea {
    margin-top: 6px;
    padding: 12px 14px;
    border-radius: 8px;
    border: 1px solid #e6e6e6;
    background: #fff;
    color: #222;
    font-size: 1rem;
    width: 100%;
}
body.contact-page-white .contact-form textarea { resize: vertical; }
body.contact-page-white .contact-form-consent {
    font-size: 0.95rem;
    color: #666;
    margin-bottom: 18px;
    display: block;
}
body.contact-page-white .contact-form-btn {
    background: #222;
    color: #fff;
    padding: 14px 34px;
    border-radius: 28px;
    font-weight: 600;
    font-size: 1.08rem;
    border: 0;
    box-shadow: 0 8px 30px rgba(0,0,0,0.10);
    transition: background 180ms;
    cursor: pointer;
}
body.contact-page-white .contact-form-btn:hover { background: #111; }

body.contact-page-white .contact-faq {
    max-width: 700px;
    margin: 0 auto 64px auto;
}
body.contact-page-white .contact-faq-title {
    font-size: 1.18rem;
    font-weight: 400;
    color: #222;
    margin-bottom: 24px;
    text-align: center;
    letter-spacing: 1px;
}
body.contact-page-white .contact-faq-list {
    background: #fafafa;
    border-radius: 18px;
    box-shadow: 0 4px 18px rgba(20,20,24,0.04);
    padding: 18px 0;
}
body.contact-page-white .contact-faq-list details { margin-bottom: 10px; }
body.contact-page-white .contact-faq-list summary {
    font-size: 1.08rem;
    color: #222;
    cursor: pointer;
    padding: 14px 32px;
    font-weight: 400;
    transition: color 180ms;
}
body.contact-page-white .contact-faq-list summary:hover { color: #111; }
body.contact-page-white .contact-faq-list div {
    color: #444;
    padding: 10px 32px;
    font-size: 1.01rem;
}

@media (max-width: 900px) {
    body.contact-page-white .contact-info { gap: 32px; }
    body.contact-page-white .contact-main { gap: 32px; }
}
@media (max-width: 600px) {
    body.contact-page-white .contact-hero-title { font-size: 2.1rem; }
    body.contact-page-white .contact-hero-content { padding: 0 12px; }
    body.contact-page-white .contact-info { flex-direction: column; gap: 18px; margin: 32px 0 24px 0; }
    body.contact-page-white .contact-main { flex-direction: column; gap: 18px; padding: 0 0 32px 0; }
    body.contact-page-white .contact-main-map, body.contact-page-white .contact-main-form { max-width: 100%; }
    body.contact-page-white .contact-form { padding: 18px 8px; }
    body.contact-page-white .contact-faq { margin: 0 auto 32px auto; }
    body.contact-page-white .contact-luxury-message { font-size: 1.15rem; font-weight: 700; margin-top: 28px; padding: 0 18px; }
}
/* Applied when the page template adds 'contact-page-white' via body_class() */
body.contact-page-white {
    background: #ffffff !important;
    color: #111 !important;
    /* keep space for fixed header */
    padding-top: 70px;
}

body.contact-page-white .main-header {
    background: #ffffff !important;
    color: #111 !important;
    /* remove hard line for white header too — use soft shadow */
    border-bottom: none !important;
    /* NO shadow or border on the contact page per request */
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

body.contact-page-white .nav-link { color: #111 !important; }
body.contact-page-white .site-title { color: #111 !important; }
body.contact-page-white .logo-link { color: #111 !important; }
body.contact-page-white .mobile-menu { background: #fff; color: #111; }
body.contact-page-white .mobile-menu .nav-link { color: #111; }

/* Contact page content should be light / white */
body.contact-page-white .contact-intro .contact-card { background: #fff; color: #111; border:1px solid #efefef; box-shadow:none; }
body.contact-page-white .contact-section { background: #ffffff; }
body.contact-page-white .map-box { border:1px solid #efefef; box-shadow:none; background:#f8f8f8; }
body.contact-page-white .map-caption { background: transparent; color:#666; }
body.contact-page-white .contact-form-card { background: #fff; color:#111; border:1px solid #e6e6e6; box-shadow: 0 8px 30px rgba(20,20,24,0.03); }

/* Header show/hide helpers used by the JS */
/* use !important so runtime class toggles reliably override other header rules */
.main-header.nav-hidden { transform: translateY(-110%) !important; transition: transform 220ms ease !important; }
.main-header.nav-visible { transform: translateY(0) !important; transition: transform 260ms cubic-bezier(0.4, 0, 0.2, 1) !important; }

/* subtle hairline separator controlled by pseudo element so it's easier to tweak than borders */
.main-header::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    pointer-events: none;
    background: linear-gradient(90deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
}

/* invert hairline on white pages so it reads as a soft gray line */
body.contact-page-white .main-header::after {
    /* hide the pseudo hairline on the contact page so header is flat */
    display: none !important;
}

/* ensure form inputs readable on white background */
body.contact-page-white .contact-form input, body.contact-page-white .contact-form select, body.contact-page-white .contact-form textarea { background: #fff; color: #111; border-color: #ddd; }


/* Ensure header stays fixed above other content even if other elements create stacking contexts */
.main-header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1500 !important;
    will-change: transform;
    /* allow transforms from helper classes to work (do not force transform:none) */
}

/* Account for WordPress admin bar (logged-in users) so header doesn't sit under it */
body.admin-bar .main-header {
    top: 32px !important; /* default admin bar height */
}

/* Add equivalent padding so page content doesn't hide behind the fixed header when admin bar present */
body.admin-bar {
    padding-top: calc(70px + 32px);
}

/* Responsive: when header height changes on small screens, adjust admin-bar offset */
@media (max-width: 768px) {
    body.admin-bar .main-header { top: 32px !important; }
    body.admin-bar { padding-top: calc(60px + 32px); }
}

.nav-container {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    padding: 0 50px;
    height: 70px;
    max-width: 1440px;
    margin: 0 auto;
    position: relative;
}

.nav-section {
    display: flex;
    align-items: center;
    gap: 40px;
}

.nav-section.left-menu {
    justify-self: start;
}

.nav-section.right-menu {
    justify-self: end;
}

.logo {
    position: relative;
    grid-column: 2;
    justify-self: center;
    /* ensure precise centering regardless of left/right menu widths */
    width: max-content;
    text-align: center;
    z-index: 1601; /* sit above the nav items */
}

.nav-link {
    text-decoration: none;
    color: #e6e6e6;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    transition: all 0.3s ease;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    position: relative;
}

.nav-link:hover {
    opacity: 0.7;
}

.nav-link::after {
    content: '';
    position: absolute;
    width: 0;
    height: 1px;
    bottom: -2px;
    left: 0;
    background-color: #ffffff;
    transition: width 0.3s ease;
}

.nav-link:hover::after {
    width: 100%;
}

.site-title {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #ffffff;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

.logo-link {
    text-decoration: none;
    transition: opacity 0.3s ease;
}

.logo-link, .site-title { display: inline-block; }

.logo-link:hover {
    opacity: 0.7;
}

/* accent link color */
.nav-link.accent, .hero-cta, .about-cta, .newsletter-btn {
    color: #0a0a0a;
}

.hero-cta, .about-cta {
    background: #fff;
    color: #000;
}

/* Mobile Menu */
.mobile-menu-toggle {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 20px;
    height: 14px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 1001;
    position: relative;
}

.mobile-menu-toggle span {
    display: block;
    height: 1px;
    width: 100%;
    background-color: #ffffff;
    transition: all 0.3s ease;
    transform-origin: center;
}

.mobile-menu-toggle.active span:nth-child(1) {
    transform: rotate(45deg) translate(4px, 4px);
}

.mobile-menu-toggle.active span:nth-child(2) {
    transform: rotate(-45deg) translate(4px, -4px);
}

.mobile-menu {
    position: fixed;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100vh;
    background: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(35px) saturate(140%);
    -webkit-backdrop-filter: blur(35px) saturate(140%);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    transition: left 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 999;
}

.mobile-menu.active {
    left: 0;
}

.mobile-menu .nav-link {
    font-size: 16px;
    margin: 20px 0;
    padding: 10px 0;
    text-align: center;
    font-weight: 500;
    letter-spacing: 1.5px;
    color: #ffffff;
}

.mobile-menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(5px);
    z-index: 998;
    opacity: 0;
    visibility: hidden;
    /* animate visibility, opacity and background color smoothly */
    transition: background-color 220ms ease, opacity 260ms ease, visibility 260ms;
}

.mobile-menu-overlay.active {
    opacity: 1;
    visibility: visible;
    /* stronger dim when menu is open */
    background-color: rgba(0,0,0,0.6);
}

/* Off-canvas/menu button tweaks (supports desktop + mobile) */
#menuToggle.menu-toggle {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: transparent;
    border: 0;
    color: #e6e6e6;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    cursor: pointer;
    padding: 6px 10px;
}
#menuToggle .menu-label { font-size: 12px; }
#menuToggle .burger { display: inline-flex; flex-direction: column; gap: 4px; width: 18px; }
#menuToggle .burger span { display: block; height: 2px; background: #fff; border-radius: 2px; }

/* Off-canvas overlay (re-usable) */
.offcanvas-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0); z-index: 998; opacity: 0; visibility: hidden; transition: opacity 220ms ease, visibility 220ms, background-color 220ms; }
.offcanvas-overlay.visible { opacity: 1; visibility: visible; background-color: rgba(0,0,0,0.55); }

/* Off-canvas panel */
.offcanvas { position: fixed; top: 0; right: -100%; width: 100%; height: 100vh; background: #ffffff; color: #111; z-index: 999; transition: right 520ms cubic-bezier(0.22,0.9,0.36,1); display: flex; flex-direction: column; align-items: flex-start; padding: 28px 20px; overflow-y: auto; -webkit-backdrop-filter: blur(18px) saturate(120%); backdrop-filter: blur(18px) saturate(120%); }
.offcanvas.open { right: 0; }

.offcanvas .offcanvas-close { background: transparent; border: 0; font-size: 28px; line-height: 1; color: #111; position: absolute; top: 12px; right: 12px; cursor: pointer; }
.offcanvas-nav { display: flex; flex-direction: column; gap: 8px; margin-top: 36px; width: 100%; }
.offcanvas .nav-link { color: #111; text-decoration: none; font-size: 16px; padding: 8px 6px; display: block; }

@media (min-width: 769px) {
    .offcanvas { width: 360px; right: -360px; background: #ffffff; color: #111; box-shadow: -10px 0 40px rgba(0,0,0,0.18); padding: 30px; border-left: 1px solid rgba(0,0,0,0.04); }
    .offcanvas.open { right: 0; }
}

/* Align offcanvas under header and ensure overlay doesn't cover header */
.offcanvas { top: 0; height: 100vh; }
.offcanvas-overlay { top: 0; height: 100vh; }

/* When the header is white (contact page) or the menu is opened, make the
   menu label and burger bars darker so they remain visible on light backgrounds. */
/* Make only the menu label text dark on light headers / when menu is open */
body.contact-page-white #menuToggle .menu-label,
.main-header.menu-open #menuToggle .menu-label,
#menuToggle[aria-expanded="true"] .menu-label {
    color: #111;
}

/* Keep the burger bars dark on light headers / when menu is open */
body.contact-page-white #menuToggle .burger span,
.main-header.menu-open #menuToggle .burger span,
#menuToggle[aria-expanded="true"] .burger span {
    background: #111;
}

/* Also ensure the burger X (when expanded) is visible and dark on light backgrounds */
#menuToggle[aria-expanded="true"] .burger span:nth-child(1),
#menuToggle[aria-expanded="true"] .burger span:nth-child(2) {
    background: #111;
}

/* Align offcanvas under header for larger viewports so the sidebar sits below the fixed header */
@media (min-width: 769px) {
    .offcanvas { top: 72px; height: calc(100vh - 72px); }
    .offcanvas-overlay { top: 72px; height: calc(100vh - 72px); }
}

/* Desktop/tablet: fancier right-side off-canvas panel (keeps mobile unchanged) */
@media (min-width: 769px) {
    .offcanvas {
        width: 420px; /* comfortable reading column */
        /* keep off-screen by default; toggle .open to slide in */
        right: -100%;
        /* solid white panel for desktop */
        background: #ffffff;
        color: #111;
        padding: 36px 28px;
        box-shadow: -28px 40px 100px rgba(0,0,0,0.45);
        border-top-left-radius: 14px;
        border-bottom-left-radius: 14px;
        overflow-y: auto;
        -webkit-backdrop-filter: blur(20px) saturate(120%);
        backdrop-filter: blur(20px) saturate(120%);
        border-left: 1px solid rgba(255,255,255,0.06);
        transition: right 520ms cubic-bezier(0.22,0.9,0.36,1), box-shadow 520ms ease;
    }

    .offcanvas .offcanvas-close { color: #111; }

    .offcanvas .offcanvas-header { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:18px; }
    .offcanvas .offcanvas-left { display:flex; flex-direction:column; gap:8px; }

    .offcanvas-nav { margin-top: 8px; }
    .offcanvas-nav .nav-link {
        color: #111;
        font-size: 16px;
        font-weight: 700;
        padding: 12px 10px;
        border-radius: 8px;
        position: relative;
        transition: color 220ms ease, transform 220ms ease, opacity 260ms ease;
        display:block;
        opacity: 0;
        transform: translateX(14px);
    }

    /* change hover indicator to a thin grey underline instead of the orange side bar
       (applies to desktop off-canvas panel and mobile panel links) */
    .offcanvas-nav .nav-link::before { display: none; }
    .offcanvas-nav .nav-link::after {
        content: '';
        position: absolute;
        left: 0;
        right: 0;
        height: 1px;
        bottom: 6px;
        background-color: #bdbdbd;
        width: 0;
        transition: width 200ms ease, background-color 200ms ease;
    }
    .offcanvas-nav .nav-link:hover::after { width: 100%; background-color: #9b9b9b; }
    .offcanvas-nav .nav-link:hover { color: #000; transform: none; }

    /* mobile panel links should use the same thin underline on hover */
    .mobile-menu .nav-link { position: relative; }
    .mobile-menu .nav-link::after {
        content: '';
        position: absolute;
        left: 0;
        right: 0;
        height: 1px;
        bottom: 6px;
        background-color: rgba(0,0,0,0.12);
        width: 0;
        transition: width 200ms ease, background-color 200ms ease;
    }
    .mobile-menu .nav-link:hover::after { width: 100%; background-color: rgba(0,0,0,0.18); }

    /* subtle separators between groups */
    .offcanvas-nav .nav-link + .nav-link { margin-top: 6px; }

    /* reveal nav links when panel opens (staggered) */
    .offcanvas.open .offcanvas-nav .nav-link { opacity: 1; transform: none; }
    .offcanvas.open .offcanvas-nav .nav-link:nth-child(1) { transition-delay: 0ms; }
    .offcanvas.open .offcanvas-nav .nav-link:nth-child(2) { transition-delay: 60ms; }
    .offcanvas.open .offcanvas-nav .nav-link:nth-child(3) { transition-delay: 120ms; }
    .offcanvas.open .offcanvas-nav .nav-link:nth-child(4) { transition-delay: 180ms; }
    .offcanvas.open .offcanvas-nav .nav-link:nth-child(5) { transition-delay: 240ms; }
    .offcanvas.open .offcanvas-nav .nav-link:nth-child(6) { transition-delay: 300ms; }

    /* compact social / utility row at bottom of panel */
    .offcanvas .offcanvas-footer { margin-top: 24px; display:flex; gap:12px; align-items:center; }
    .offcanvas .offcanvas-footer .small-note { color:#666; font-size:0.92rem; }
}

/* legal / social quick links at the bottom of the nav */
    /* horizontal rule with side insets so the line doesn't touch the panel edges */
    .offcanvas-sep { border: 0; height: 1px; background: linear-gradient(90deg, rgba(0,0,0,0.04), rgba(0,0,0,0.06)); margin: 18px 28px; width: calc(100% - 56px); border-radius: 2px; }
    /* prefer local Futura first, then Montserrat as a fallback */
    .offcanvas-legal { display:flex; flex-direction:column; gap:10px; margin-top:8px; padding: 0 8px 12px 8px; font-family: 'Futura', 'Montserrat', serif; }
    /* legal links: prefer Futura; remove the forced !important so Futura can win when available */
    .offcanvas-legal .legal-link { color: #9b9b9b; text-decoration: none; font-family: 'Futura', 'Montserrat', serif; font-size: 0.95rem; transition: color 160ms ease; }
    .offcanvas-legal .legal-link:hover { color: #111; }

/* Burger to X animation (uses aria-expanded on the toggle) */
#menuToggle .burger span { transition: transform 260ms cubic-bezier(0.22,1,.36,1), opacity 200ms ease; transform-origin: center; }
#menuToggle[aria-expanded="true"] .burger span:nth-child(1) { transform: rotate(45deg) translate(3px, 3px); }
#menuToggle[aria-expanded="true"] .burger span:nth-child(2) { transform: rotate(-45deg) translate(3px, -3px); }

/* Slight scale on open to emphasize action */
#menuToggle[aria-expanded="true"] { transform: scale(0.995); }

/* Hide burger icon on small screens (per request). Keep the 'Menu' label visible/clickable. */
@media (max-width: 768px) {
    /* Show the burger on mobile (user requested visible burger) */
    #menuToggle .burger { display: inline-flex; }
    /* adjust spacing so label sits nicely */
    #menuToggle.menu-toggle { padding-left: 8px; padding-right: 8px; }
}

/* On the contact page we prefer a light overlay so the menu reads on white */
body.contact-page-white .mobile-menu-overlay.active {
    background-color: rgba(255,255,255,0.94);
}

/* For users who prefer a more solid mask when the sidebar is shown on larger screens,
   slightly darken the overlay and add a subtle blur to the page behind the menu. */
@media (min-width: 769px) {
    .mobile-menu-overlay.active {
        background-color: rgba(0,0,0,0.55);
        backdrop-filter: blur(3px);
    }
}

/* Make the menu panel itself whitish when opened so the menu reads clearly */
.mobile-menu.active {
    background: rgba(255,255,255,0.96);
    color: #111;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.mobile-menu.active .nav-link {
    color: #111;
}

/* Ensure contact page keeps a solid white menu panel */
body.contact-page-white .mobile-menu.active {
    background: #ffffff !important;
    color: #111;
}

/* Desktop / tablet: present the menu as a right-side white off-canvas sidebar */
@media (min-width: 769px) {
    .mobile-menu {
        /* make it an off-canvas right sidebar */
        left: auto;
        right: -360px;
        width: 360px;
        height: 100vh;
        padding: 28px 20px;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        border-left: 1px solid rgba(0,0,0,0.04);
        box-shadow: 0 20px 50px rgba(0,0,0,0.45);
        background: rgba(255,255,255,0.96);
        color: #111;
        transition: right 320ms cubic-bezier(0.4,0,0.2,1);
        z-index: 2100;
    }

    .mobile-menu.active { right: 0; }

    .mobile-menu .nav-link {
        color: #111;
        text-align: left;
        width: 100%;
        padding: 12px 8px;
        margin: 6px 0;
        font-size: 15px;
        font-weight: 600;
    }

    /* make overlay slightly darker for larger screens so sidebar reads on top */
    .mobile-menu-overlay.active { background-color: rgba(0,0,0,0.6); }
}

/* Hero Section */
.hero-section {
    position: relative;
    height: 100vh;
    width: 100%;
    overflow: hidden;
    margin-top: -70px;
}

/* Hero slider (two images) */
.hero-slider { position: relative; width: 100%; height: 100%; overflow: hidden; }
.hero-slider .slides { display: flex; width: 100%; height: 100%; transition: transform 1400ms cubic-bezier(0.2,0.9,0.2,1); }

/* swing easing used for snap animations (applied via JS by toggling .swing) */
.hero-slider .slides.swing { transition: transform 1800ms cubic-bezier(.22,1.3,.36,1); }
.hero-slider .slide { flex: 0 0 100%; height: 100%; position: relative; }
.hero-slider .slide img.hero-video { width: 100%; height: 100%; object-fit: cover; display: block; }

/* enable native vertical scroll while we handle horizontal swipe */
.hero-slider .slides { touch-action: pan-y; }

/* when user is dragging, disable transition so movement tracks pointer */
.hero-slider.grabbing .slides { transition: none !important; }

/* cursor affordance */
.hero-slider .slides { cursor: grab; }
.hero-slider.grabbing .slides, .hero-slider.grabbing { cursor: grabbing; }

/* arrows */
.slider-arrow { position: absolute; top: 50%; transform: translateY(-50%); width:36px; height:36px; border-radius:8px; background:rgba(0,0,0,0.45); color:#fff; border:0; display:inline-flex; align-items:center; justify-content:center; font-size:20px; line-height:1; cursor:pointer; z-index:40; }
.slider-arrow.prev { left: 18px; }
.slider-arrow.next { right: 18px; }
.slider-arrow:hover { background: rgba(0,0,0,0.6); transform: translateY(-50%) scale(1.03); }

/* dots */
/* center pagination removed - using compact control */
.slider-dots { display:none !important; }

/* compact bottom-right control: < ••• > */
.slider-compact {
    position: absolute;
    right: 14px;
    bottom: 14px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border-radius: 999px;
    background: rgba(0,0,0,0.16);
    border: 1px solid rgba(255,255,255,0.04);
    z-index: 45;
    /* keep it visually light */
    backdrop-filter: blur(4px);
}
.slider-compact button { background: transparent; border: 0; color: #fff; font-weight: 600; font-size: 14px; padding: 4px 6px; cursor: pointer; display:inline-flex; align-items:center; justify-content:center; opacity:0.95; }
.compact-dots { display:flex; gap:8px; align-items:center; }
.compact-dot { width:8px; height:8px; border-radius:50%; background: transparent; border: 1px solid rgba(255,255,255,0.26); transition: transform 160ms ease, background 160ms ease, border-color 160ms ease; }
.compact-dot.active { background: #fff; border-color: rgba(255,255,255,0.95); transform: scale(1.15); box-shadow: 0 6px 16px rgba(0,0,0,0.45); }

@media (max-width: 720px) {
    .slider-compact { right: 10px; bottom: 10px; padding: 6px 8px; }
    .slider-compact button { font-size: 13px; }
}

/* overlay hero content should sit above slides */
.hero-slider .hero-content { position: absolute; top: 50%; left:50%; transform: translate(-50%,-50%); z-index:30; text-align:center; color:#fff; padding:0 20px; }


.hero-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.8);
}

.hero-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    color: #fff;
    z-index: 2;
    width: 100%;
    padding: 0 20px;
}

/* Hero image fallback & overlay */
.hero-section { position: relative; height: 88vh; min-height:560px; display:block; }
.hero-section .hero-video { width:100%; height:100%; object-fit:cover; display:block; }
.hero-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.65) 60%);
    z-index: 1;
}
/* Allow pointer events to reach the slides below the overlay */
.hero-section::before { pointer-events: none; }

/* Prevent images from being dragged by browser default behavior which interferes with pointer dragging */
.hero-slider .slide img, .hero-slider img { -webkit-user-drag: none; user-select: none; }
.hero-content{ z-index:3; max-width:1100px; margin:0 auto; padding:0 24px; }
.hero-title{ font-size:3.8rem; line-height:1; color:#fff; text-shadow:0 6px 30px rgba(0,0,0,0.6); }
.hero-subtitle{ color:#d6d6d6; letter-spacing:2px; }
.hero-cta{ background:#ffffff; color:#000; padding:14px 34px; border-radius:28px; display:inline-block; box-shadow:0 8px 30px rgba(0,0,0,0.45); border:0; transition:transform 220ms ease, box-shadow 220ms; }
.hero-cta:hover{ transform:translateY(-3px); box-shadow:0 14px 38px rgba(0,0,0,0.6); }

.hero-title {
    font-family: Futura, 'Futura PT', 'Trebuchet MS', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
    font-size: 2.6rem;
    font-weight: 500;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 0.6rem;
    line-height: 1.05;
    opacity: 0;
    transform: translateY(18px);
    animation: fadeInUp 1s ease 0.5s forwards;
}

.hero-subtitle {
    font-size: 1.2rem;
    font-weight: 300;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 2rem;
    opacity: 0;
    transform: translateY(30px);
    animation: fadeInUp 1s ease 0.8s forwards;
}

.hero-cta {
    display: inline-block;
    padding: 15px 40px;
    border: 1px solid #fff;
    color: #fff;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 0.9rem;
    transition: all 0.3s ease;
    opacity: 0;
    transform: translateY(30px);
    animation: fadeInUp 1s ease 1.1s forwards;
}

.hero-cta:hover {
    background: #fff;
    color: #000;
}

@keyframes fadeInUp {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Collections Grid */
.collections-section {
    padding: 100px 50px;
    background: #000;
}

.section-header {
    text-align: center;
    margin-bottom: 60px;
}

.section-title {
    font-size: 2.5rem;
    font-weight: 300;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.section-subtitle {
    font-size: 1rem;
    color: #ccc;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.collections-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    gap: 30px;
    max-width: 1400px;
    margin: 0 auto;
}

.collection-item {
    position: relative;
    height: 600px;
    overflow: hidden;
    cursor: pointer;
}

.collection-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease, filter 260ms ease;
    display:block;
}

.collection-item:hover .collection-image {
    transform: scale(1.05);
}

.collection-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 40px;
    background: linear-gradient(180deg, rgba(0,0,0,0.0) 0%, rgba(0,0,0,0.85) 90%);
    color: #fff;
    transform: translateY(20px);
    opacity: 0;
    transition: transform 360ms cubic-bezier(.2,.9,.2,1), opacity 320ms ease;
}

.collection-item:hover .collection-overlay {
    transform: translateY(0);
    opacity: 1;
}

.collection-item:hover .collection-image{ transform: scale(1.06); filter:brightness(0.9) contrast(1.02); }

/* when items are scrolled into view (mobile) reveal overlay like hover */
.collection-item.in-view .collection-overlay { transform: translateY(0); opacity: 1; }
.collection-item.in-view .collection-image { transform: scale(1.06); filter:brightness(0.92) contrast(1.02); }

.collection-name {
    font-size: 1.5rem;
    font-weight: 400;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 0.5rem;
}

.collection-desc {
    font-size: 0.9rem;
    color: #ccc;
    letter-spacing: 1px;
}

/* Featured Products */
.featured-section {
    padding: 100px 50px;
    background: #0a0a0a;
}

.products-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 40px;
    max-width: 1200px;
    margin: 0 auto;
}

.product-card {
    background: linear-gradient(180deg, #0b0b0b 0%, #0f0f0f 100%);
    padding: 30px;
    text-align: center;
    transition: transform 0.3s ease;
}

.product-card:hover{ transform: translateY(-8px); box-shadow:0 20px 50px rgba(0,0,0,0.6); }

.product-image { width:100%; height:320px; object-fit:cover; border-radius:6px; display:block; margin-bottom:18px; }

.product-name{ color:#f4f4f4; }
.product-price{ color:#cfcfcf; }

.product-card:hover {
    transform: translateY(-10px);
}

.product-image {
    width: 100%;
    height: 400px;
    object-fit: cover;
    margin-bottom: 20px;
}

.product-name {
    font-size: 1.1rem;
    font-weight: 400;
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-bottom: 10px;
}

.product-price {
    font-size: 1rem;
    color: #ccc;
    letter-spacing: 1px;
}

/* About Preview */
.about-preview {
    padding: 100px 50px;
    background: linear-gradient(180deg,#050505 0%, #0a0a0a 100%);
}

.about-content {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
}

.about-text {
    font-size: 1.1rem;
    line-height: 1.8;
    color: #ccc;
    margin-bottom: 40px;
}

.about-cta {
    display: inline-block;
    padding: 15px 40px;
    border: 1px solid #fff;
    color: #fff;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 0.9rem;
    transition: all 0.3s ease;
}

.about-cta:hover {
    background: #fff;
    color: #000;
}

/* Newsletter */
.newsletter-section {
    padding: 80px 50px;
    background: linear-gradient(180deg,#060606 0%, #0b0b0b 100%);
    text-align: center;
}

.newsletter-form {
    max-width: 620px;
    margin: 18px auto 0;
    display: flex;
    gap: 12px;
    align-items:center;
    justify-content:center;
}

.newsletter-input {
    flex: 1;
    padding: 14px 18px;
    border: 1px solid rgba(255,255,255,0.06);
    background: rgba(255,255,255,0.02);
    color: #e9e9e9;
    font-size: 1rem;
    border-radius:6px;
}

.newsletter-input::placeholder{ color: #9b9b9b; }

.newsletter-btn{ background:#fff;color:#000;border-radius:6px;padding:12px 20px;border:0;font-weight:600;box-shadow:0 8px 30px rgba(0,0,0,0.45); }
.newsletter-btn:hover{ transform:translateY(-3px); }
.pricing-section{ padding:70px 50px; background:linear-gradient(180deg,#070707 0%, #050505 100%); }
.pricing-section .products-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:24px; max-width:1100px; margin:0 auto; }
.price-list li{ display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px dashed rgba(255,255,255,0.03); }
.price-list li:last-child{ border-bottom:0; }
.price-list .service{ color:#d0d0d0; }

/* About & CTA refinements */
.about-cta{ background:#fff;color:#000;padding:12px 26px;border-radius:26px;box-shadow:0 10px 30px rgba(0,0,0,0.45); }
.about-cta:hover{ transform:translateY(-3px); }

/* Footer tweaks */
.main-footer{ background:#050505; }

/* Responsive refinements */
@media (max-width: 768px) {
    .hero-title{ font-size:2.4rem; }
    .hero-section{ height:72vh; min-height:420px; }
    .product-image{ height:260px; }
    .pricing-section{ padding:40px 18px; }
    .newsletter-form{ flex-direction:column; }
    .newsletter-btn{ width:100%; }
}

/* Pricing page specific styles */
.pricing-nav{ display:flex; gap:12px; justify-content:center; margin:22px 0 28px; }
.pricing-nav-link{ color:#bfbfbf; padding:8px 14px; border-radius:20px; background:rgba(255,255,255,0.02); text-decoration:none; transition:background 180ms ease, color 180ms ease; }
.pricing-nav-link:hover, .pricing-nav-link:focus{ background:rgba(255,255,255,0.04); color:#fff; }

.pricing-block{ max-width:1100px; margin:0 auto 10px; }
.pricing-table{ width:100%; border-collapse:collapse; margin-top:8px; background:rgba(255,255,255,0.01); border-radius:6px; overflow:hidden; }
.pricing-table thead th{ text-align:left; padding:14px 18px; background:rgba(255,255,255,0.02); color:#dfdfdf; font-weight:600; }
.pricing-table tbody td{ padding:14px 18px; border-top:1px solid rgba(255,255,255,0.03); color:#cfcfcf; }
.pricing-table tbody tr:hover td{ background:rgba(255,255,255,0.01); }

@media (max-width:720px){
    .pricing-table thead{ display:none; }
    .pricing-table, .pricing-table tbody, .pricing-table tr, .pricing-table td{ display:block; width:100%; }
    .pricing-table td{ padding:12px 10px; border-top:0; }
    .pricing-table td:before{ content: attr(data-label); display:block; font-weight:600; color:#dcdcdc; margin-bottom:6px; }
}

/* Make pricing card links look like blocks */
.pricing-link { text-decoration: none; color: inherit; display: block; }
.pricing-link .product-card { height: 100%; }

/* Pricing panels layout (category list + panels) */
.pricing-layout {
    display: flex;
    gap: 28px;
    max-width: 1100px;
    margin: 18px auto 40px;
    align-items: flex-start;
}

.pricing-categories {
    width: 240px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.pricing-cat {
    background: rgba(255,255,255,0.02);
    color: #cfcfcf;
    padding: 12px 16px;
    border-radius: 10px;
    cursor: pointer;
    border: 1px solid transparent;
    transition: all 180ms ease;
    text-align: left;
    font-weight: 600;
}

.pricing-cat:hover { background: rgba(255,255,255,0.035); }

.pricing-cat.active {
    background: linear-gradient(90deg, #ffffff 0%, #e6e6e6 100%);
    color: #000;
    box-shadow: 0 10px 30px rgba(0,0,0,0.45);
    border-color: rgba(255,255,255,0.06);
    transform: translateX(2px);
}

.pricing-panels {
    flex: 1 1 auto;
    min-height: 160px;
    background: linear-gradient(180deg, rgba(255,255,255,0.018) 0%, rgba(255,255,255,0.01) 100%);
    padding: 20px;
    border-radius: 12px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.6);
}

.pricing-panel { display: none; opacity: 0; transform: translateY(8px); transition: opacity 260ms ease, transform 260ms ease; }
.pricing-panel.active { display: block; opacity: 1; transform: none; }

.service-list { list-style: none; padding: 0; margin: 0; }
.service-item { display: grid; justify-content: space-between; padding: 14px 12px; border-bottom: 1px dashed rgba(255,255,255,0.03); color: #dcdcdc; align-items:center; }
.service-item:last-child { border-bottom: 0; }

/* Panel header and service row layout similar to provided reference logic */
.pricing-panel .panel-title {
    text-align: center;
    font-size: 2rem;
    font-weight: 400;
    margin: 18px 0 28px;
    color: #f7f7f7;
    letter-spacing: 1px;
}

.service-item { 
    display: grid;
    grid-template-columns: 1fr 44px 110px; /* left content | calendar icon | price */
    gap: 14px;
    align-items: center;
    padding: 16px 12px;
    transition: background 220ms cubic-bezier(.2,.9,.2,1), transform 220ms ease, box-shadow 220ms ease;
}

.service-item .price {
    justify-self: end;
    color: #fff;
    font-weight: 700;
    font-size: 1.05rem;
}

.service-item .service-left { display:block; }
.service-item .service-left .service-name { display:block; font-weight:700; color:#fff; letter-spacing:0.6px; }
.service-item .service-left .service-meta { display:block; font-size:0.9rem; color:#bdbdbd; margin-top:6px; }

/* allow optional multiple price columns on wide screens */
.service-item.prices-3 { grid-template-columns: 1fr 90px 90px 90px; }
.service-item.prices-2 { grid-template-columns: 1fr 100px 100px; }

@media (max-width: 768px) {
    .pricing-panel .panel-title { font-size:1.6rem; margin-bottom:16px; }
    .service-item { grid-template-columns: 1fr 44px 96px; padding:14px 8px; }
}

/* Book button / calendar icon */
.book-btn {
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:42px;
    height:42px;
    border-radius:10px;
    background: linear-gradient(135deg, rgba(255,255,255,0.025), rgba(255,255,255,0.02));
    color: #fff;
    text-decoration: none;
    transition: transform 180ms ease, background 180ms ease, box-shadow 180ms ease;
    border: 1px solid rgba(255,255,255,0.03);
}
.book-btn:hover{ transform:translateY(-4px); background: linear-gradient(135deg, rgba(255,255,255,0.12), rgba(255,255,255,0.06)); box-shadow:0 12px 30px rgba(0,0,0,0.55); }

.service-item:hover{ background: rgba(255,255,255,0.02); transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,0.45); }

/* small, subtle animation when panel becomes active */
.pricing-panel.active .service-item{ animation: appearRow 260ms ease both; }
@keyframes appearRow { from { opacity: 0.0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

/* Make the category column sticky on large screens so users can quickly switch */
@media (min-width: 1000px) {
    .pricing-categories { position: sticky; top: 110px; align-self: flex-start; }
}

/* Small detail: slightly larger price for cosmetic/plastic list items */
.proc-list .from { font-weight:700; color:#fff; }

@media (max-width: 768px) {
    .pricing-layout { flex-direction: column; gap: 18px; margin: 12px 18px 28px; }
    .pricing-categories { width: 100%; flex-direction: row; overflow-x: auto; padding-bottom: 6px; }
    .pricing-cat { white-space: nowrap; flex: 0 0 auto; }
    .pricing-panels { padding: 12px; }
}

.newsletter-input::placeholder {
    color: #666;
}

.newsletter-btn {
    padding: 15px 30px;
    background: #fff;
    color: #000;
    border: none;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 0.9rem;
    cursor: pointer;
    transition: all 0.3s ease;
}

.newsletter-btn:hover {
    background: #ccc;
}

/* Footer */
.main-footer {
    background: #000;
    padding: 60px 50px 30px;
    border-top: 1px solid #222;
}

.footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 50px;
    max-width: 1200px;
    margin: 0 auto 50px;
}

.footer-section h3 {
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.footer-links {
    list-style: none;
}

.footer-links a {
    color: #ccc;
    text-decoration: none;
    font-size: 0.9rem;
    display: block;
    margin-bottom: 10px;
    transition: color 0.3s ease;
}

.footer-links a:hover {
    color: #fff;
}

.footer-bottom {
    text-align: center;
    padding-top: 30px;
    border-top: 1px solid #222;
    color: #666;
    font-size: 0.9rem;
}

/* Footer specifics */
.footer-section h3{ font-size:0.95rem; color:#f3f3f3; margin-bottom:10px; letter-spacing:1px; text-transform:uppercase; }
.footer-section p, .footer-section li, .footer-section a { color:#bdbdbd; font-size:0.95rem; }
.footer-section .footer-links { list-style:none; padding:0; margin:0; }
.footer-section .footer-links li{ margin-bottom:8px; }
.footer-section .footer-links a{ color:#bdbdbd; text-decoration:none; transition:color 160ms ease; }
.footer-section .footer-links a:hover{ color:#fff; }

/* Opening hours & status badge */
.hours-list { margin: 0; padding: 0; }
.hours-list li { padding: 6px 0; }
.hours-list li.today { background: rgba(255,255,255,0.02); border-radius: 6px; padding: 8px; }
.open-badge { display:inline-block; width:10px; height:10px; border-radius:50%; box-shadow:0 2px 6px rgba(0,0,0,0.2); }
.open-badge.open { background: linear-gradient(180deg,#4cd964,#28a745); }
.open-badge.closed { background: linear-gradient(180deg,#e74c3c,#c0392b); }
.footer-section .hours-list .day { min-width:110px; display:inline-block; }
.footer-section .hours-list .range { min-width:90px; text-align:right; display:inline-block; }

/* Contact page: open status and inline booking CTA */
.open-status { margin-top:8px; display:inline-flex; gap:8px; align-items:center; font-weight:600; color: #6b6b6b; }
.open-status .open-text { font-size:0.98rem; color:#666; }
.contact-book-btn { display:inline-block; margin-bottom:12px; background:linear-gradient(90deg,#111,#333); color:#fff; padding:10px 18px; border-radius:24px; text-decoration:none; font-weight:700; box-shadow:0 10px 30px rgba(0,0,0,0.45); }
.contact-book-btn:hover{ transform:translateY(-3px); }

/* Mobile scroll-to-top control (only show on small screens) */
.scroll-to-top.mobile-scroll{ position: fixed; right: 18px; bottom: 18px; width:44px; height:44px; border-radius:10px; background: #111; color:#fff; display:inline-flex; align-items:center; justify-content:center; font-size:20px; z-index:1200; opacity:0; visibility:hidden; transform:translateY(6px); transition: opacity 220ms ease, transform 220ms ease, visibility 220ms; box-shadow:0 10px 30px rgba(0,0,0,0.45); }
.scroll-to-top.mobile-scroll.visible{ opacity:1; visibility:visible; transform:none; }
@media (min-width: 769px){ .scroll-to-top.mobile-scroll{ display:none !important; } }

/* Footer logo sizing */
.footer-logo { display:block; height:36px; width:auto; }

/* make footer sections more consistent and avoid inline clashing */
.main-footer .footer-content { display:grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap:40px; max-width:1200px; margin: 0 auto; padding: 40px 24px; align-items:start; }
.main-footer .footer-section { min-width:0; /* prevents grid blowout */ }
.main-footer .footer-bottom { padding-top:24px; margin-top:16px; border-top:1px solid rgba(255,255,255,0.05); }

/* Better spacing for footer elements to prevent overlapping */
.main-footer h3, .main-footer h4 { margin-bottom:16px; }
.main-footer p, .main-footer address { margin-bottom:12px; line-height:1.6; }
.hours-list { margin:0; padding:0; list-style:none; }
.hours-list li { margin-bottom:8px; }

/* Newsletter form should stack vertically to prevent overflow */
.newsletter-form { display:flex; flex-direction:column; gap:10px; }
.newsletter-input { width:100%; }
.newsletter-btn { width:100%; }

/* Responsive footer adjustments */
@media (max-width: 768px) {
    .main-footer .footer-content { grid-template-columns: 1fr; gap:32px; padding: 32px 20px; }
}

.social-links .social-link { color:#fff; display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:8px; background:rgba(255,255,255,0.03); transition:transform 160ms ease, background 160ms ease; }
.social-links .social-link:hover{ transform:translateY(-3px); background:rgba(255,255,255,0.06); }

.footer-bottom { color:#9b9b9b; }
.footer-bottom .small-link { color:#9b9b9b; text-decoration:none; }
.footer-bottom .small-link:hover{ color:#fff; }

/* Desktop back-to-top button */
.scroll-to-top.desktop-scroll { display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:6px; background:#fff; color:#000; border:0; cursor:pointer; box-shadow:0 8px 24px rgba(0,0,0,0.45); }
.scroll-to-top.desktop-scroll svg{ width:14px;height:14px; }
.scroll-to-top.desktop-scroll:hover{ transform:translateY(-3px); }

/* show only on desktop */
@media (max-width:768px){ .scroll-to-top.desktop-scroll{ display:none !important; } }


/* small refinements for headings */
.section-title { color:#f7f7f7; }
.section-subtitle { color:#bdbdbd; }

/* L'ESTHETIQUE sliding banner */
.esthetique-banner-wrapper {
    width: 100%;
    overflow: hidden;
    background: #000;
    border-top: 1px solid rgba(255,255,255,0.02);
    border-bottom: 1px solid rgba(255,255,255,0.02);
}
.esthetique-banner {
    display: block;
    color: #fff;
    background: #000;
    padding: 48px 24px;
    /* Use the Schnyder display face for a bold editorial banner
       responsive sizing: min 48px, fluid via vw, max 140px */
    font-family: 'Schnyder-M-Demi', 'Playfair Display', serif;
    /* slightly larger: nudge up the min/vw/max for a bit more presence */
    font-size: clamp(80px, 15vw, 280px);
    font-weight: 600;
    letter-spacing: 9px;
    text-transform: uppercase;
    white-space: nowrap;
    will-change: transform;
    transform: translateX(0);
    transition: transform 0.12s linear;
}

@media (max-width: 768px) {
    .esthetique-banner { font-size: 2.2rem; padding: 30px 18px; letter-spacing:2px; }
}

/* reduce hero title weight for elegant look */
.hero-title { font-weight:300; letter-spacing:3px; color:#fff; }

/* Responsive */
@media (max-width: 1024px) {
    .nav-container {
        padding: 0 30px;
    }
    
    .nav-section {
        gap: 30px;
    }
    
    .hero-title {
        font-size: 3rem;
    }
    
    .collections-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    /* hide left-side links on small screens (they appear in the off-canvas menu)
       but keep the right menu visible so the Menu toggle remains accessible */
    .nav-section.left-menu { display: none; }
    .nav-section.right-menu { display: flex; }
    
    /* ensure both legacy mobile toggle and the new .menu-toggle are visible */
    .mobile-menu-toggle,
    .menu-toggle { display: flex; }
    
    .nav-container {
        padding: 0 20px;
        justify-content: space-between;
        height: 60px;
    }
    
    .logo {
        position: static;
        transform: none;
        margin: 0 auto;
    }
    
    body {
        padding-top: 60px;
    }
    
    .hero-section {
        margin-top: -60px;
    }
    /* Scroll-to-top button (mobile) - prettier */
    .scroll-to-top {
        position: fixed;
        right: 16px;
        bottom: 18px;
        width: 48px;
        height: 48px;
        border-radius: 50%;
        background: linear-gradient(135deg, rgba(255,255,255,0.95), rgba(230,230,230,0.95));
        color: #000000;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border: 0;
        box-shadow: 0 8px 24px rgba(0,0,0,0.45);
        opacity: 0;
        transform: translateY(14px) scale(0.98);
        visibility: hidden;
        transition: opacity 260ms cubic-bezier(.2,.8,.2,1), transform 260ms cubic-bezier(.2,.8,.2,1), visibility 260ms;
        z-index: 1600;
        cursor: pointer;
        backdrop-filter: blur(6px);
    }

    .scroll-to-top svg { display: block; color: #111; width: 18px; height: 18px; }

    .scroll-to-top.visible {
        opacity: 1;
        transform: translateY(0) scale(1);
        visibility: visible;
    }

    .scroll-to-top:hover {
        transform: translateY(-4px) scale(1.05);
        box-shadow: 0 12px 30px rgba(0,0,0,0.5);
    }

    /* subtle float animation when visible */
    .scroll-to-top.visible { animation: floatUp 2.8s ease-in-out infinite; }
    @keyframes floatUp {
        0% { transform: translateY(0) scale(1); }
        50% { transform: translateY(-4px) scale(1.01); }
        100% { transform: translateY(0) scale(1); }
    }
    .hero-title {
        font-size: 2.5rem;
    }
    
    .collections-section,
    .featured-section,
    .about-preview {
        padding: 60px 20px;
    }
    
    .newsletter-form {
        flex-direction: column;
    }

    /* Mobile: hide the 'Menu' label and show only the burger; place offcanvas under header */
    #menuToggle .menu-label { display: none; }

    /* Header becomes white while menu is open (mobile) */
    .main-header.menu-open {
        background: #ffffff !important;
        color: #111 !important;
        box-shadow: none !important;
    }
    .main-header.menu-open .nav-link { color: #111 !important; }
    .main-header.menu-open .site-title { color: #111 !important; }

    /* Offcanvas slides in under the header on mobile (leave header visible)
       use header height 60px in mobile breakpoint */
    .offcanvas { top: 60px; height: calc(100vh - 60px); }
    .offcanvas-overlay { top: 60px; height: calc(100vh - 60px); }

    /* Make the X visible on white header */
    #menuToggle[aria-expanded="true"] { color: #111; }
    #menuToggle[aria-expanded="true"] .burger span { background: #111; }
}

/* Make header white while off-canvas menu is open (all viewports) */
.main-header.menu-open {
    background: #ffffff !important;
    color: #111 !important;
    box-shadow: none !important;
}
.main-header.menu-open .nav-link,
.main-header.menu-open .site-title,
.main-header.menu-open .logo-link { color: #111 !important; }

.newsletter-toast {
    position: fixed;
    bottom: 25px;
    right: 25px;
    padding: 16px 22px;
    background: #4caf50;
    color: #fff;
    font-family: system-ui, sans-serif;
    border-radius: 10px;
    font-size: 15px;
    box-shadow: 0 8px 25px rgba(0,0,0,0.18);
    opacity: 0;
    transform: translateY(20px);
    transition: all .35s ease;
    z-index: 99999;
}
.newsletter-toast.error {
    background: #e53935;
}
.newsletter-toast.visible {
    opacity: 1;
    transform: translateY(0);
}


@media (min-width: 769px) {
    /* hide on larger screens */
    .scroll-to-top { display: none !important; }
}

@media (max-width: 480px) {
    .nav-container {
        padding: 0 15px;
    }
    
    .hero-title {
        font-size: 2rem;
    }
    
    .collections-grid {
        grid-template-columns: 1fr;
    }
    
    .collection-item {
        height: 400px;
    }
}

/* Contact page enhancements */
.contact-intro.grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 1200px;
    margin: 0 auto 28px;
}
.contact-card { background: #0b0b0b; padding: 26px; border-radius: 10px; text-align: center; }
.contact-card h3 { font-size: 1.05rem; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; }

.contact-card .muted { color: #bfbfbf; line-height:1.6; }

.contact-section { padding: 60px 20px; background: linear-gradient(180deg,#050505 0%, #0a0a0a 100%); }
.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px;
    max-width: 1200px;
    margin: 0 auto;
    align-items: start;
}
.map-box { border-radius: 10px; overflow: hidden; border: 1px solid rgba(255,255,255,0.04); box-shadow: 0 10px 30px rgba(0,0,0,0.6); }
.map-iframe { width: 100%; height: 420px; border: 0; display: block; }
.map-caption { padding: 12px 16px; color: #cfcfcf; background: rgba(0,0,0,0.35); text-align: center; }

.contact-form-card { background: #fff; color: #111; padding: 28px; border-radius: 10px; border: 1px solid #e6e6e6; box-shadow: 0 8px 30px rgba(20,20,24,0.06); }
.contact-form-card h2 { margin-top: 0; margin-bottom: 12px; font-weight: 600; }
.contact-form label { display:block; margin-bottom:8px; font-weight:600; font-size:0.9rem; }
.contact-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.contact-form input[type="text"], .contact-form input[type="email"], .contact-form input[type="tel"], .contact-form select, .contact-form textarea { width:100%; padding: 12px 14px; border: 1px solid #ddd; border-radius:6px; background: #fff; color:#111; font-size:0.95rem; }
.contact-form textarea { resize: vertical; }
.contact-form .consent { display:block; margin-top:8px; color:#6b6b6b; font-size:0.9rem; }
.btn-primary { background:#111; color:#fff; padding:12px 20px; border-radius:8px; border:0; cursor:pointer; font-weight:700; }
.btn-primary:hover { background:#000; transform: translateY(-2px); }
.muted.small { color:#666; margin:0; font-size:0.9rem; }

@media (max-width: 900px) {
    .contact-grid { grid-template-columns: 1fr; }
    .contact-intro.grid-3 { grid-template-columns: 1fr; }
    .map-iframe { height: 300px; }
}

/* ---------- Privacy Policy Page Styles ---------- */
body.page-template-privacy-page, body.page-template-page-privacy-policy, body.privacy-page { background:#050505; color:#cfcfcf; }
.privacy-hero { background:linear-gradient(180deg,#050505 0%, #000 100%); padding:110px 24px 70px; text-align:center; position:relative; overflow:hidden; }
.privacy-hero::after { content:""; position:absolute; inset:0; background:radial-gradient(circle at 50% 30%, rgba(255,255,255,0.06), rgba(0,0,0,0.6) 60%); opacity:0.35; pointer-events:none; }
.privacy-title { font-family:'Schnyder-M-Demi','Playfair Display',serif; font-size:clamp(2.8rem,6vw,4.6rem); font-weight:600; letter-spacing:4px; color:#fff; line-height:1; margin:0 0 22px; text-transform:uppercase; }
.privacy-subhead { color:#d2d2d2; font-size:1.15rem; max-width:840px; margin:0 auto; line-height:1.6; }

.privacy-wrapper { max-width:1000px; margin:0 auto; padding:70px 28px 80px; }
.privacy-toc { display:flex; flex-wrap:wrap; gap:10px; margin:-18px 0 50px; }
.privacy-toc a { flex:0 1 auto; background:rgba(255,255,255,0.05); color:#bfbfbf; padding:10px 14px; border-radius:30px; font-size:0.8rem; letter-spacing:1px; text-decoration:none; text-transform:uppercase; font-weight:600; transition:background 160ms ease, color 160ms ease, transform 160ms ease; }
.privacy-toc a:hover, .privacy-toc a:focus { background:rgba(255,255,255,0.12); color:#fff; transform:translateY(-3px); }

.privacy-section { margin-bottom:70px; background:linear-gradient(180deg,#070707 0%, #050505 100%); padding:38px 32px 42px; border:1px solid rgba(255,255,255,0.04); border-radius:14px; box-shadow:0 14px 44px -10px rgba(0,0,0,0.6); position:relative; overflow:hidden; }
.privacy-section::before { content:""; position:absolute; inset:0; background:linear-gradient(120deg,rgba(255,255,255,0.04),transparent 60%); pointer-events:none; }
.privacy-section h2, .privacy-section-title { font-family:'Schnyder-M-Demi','Playfair Display',serif; font-size:clamp(2.2rem,4.2vw,3rem); margin:0 0 26px; color:#fff; letter-spacing:3px; font-weight:600; text-transform:uppercase; line-height:1.05; }
.privacy-section h3 { font-size:1.15rem; margin:34px 0 14px; color:#f4f4f4; font-weight:600; letter-spacing:0.5px; }
.privacy-section h4 { font-size:1rem; margin:26px 0 12px; color:#e0e0e0; font-weight:600; letter-spacing:0.5px; }
.privacy-section p, .privacy-section li { color:#cfcfcf; line-height:1.75; font-size:0.95rem; }
.privacy-section ul { margin:14px 0 14px 26px; padding:0; }
.privacy-section li { margin-bottom:8px; }
.privacy-section a { color:#fff; text-decoration:underline; text-underline-offset:3px; }
.privacy-section a:hover { text-decoration:none; }

.privacy-note { background:#0a0a0a; border-left:4px solid #fff; padding:24px 26px; border-radius:10px; margin-top:40px; box-shadow:0 10px 30px rgba(0,0,0,0.55); }
.privacy-note h3 { margin-top:0; }
.privacy-updated { text-align:center; color:#8d8d8d; font-size:0.8rem; margin-top:40px; padding-top:28px; border-top:1px solid rgba(255,255,255,0.06); letter-spacing:1px; text-transform:uppercase; }

@media (max-width: 840px) {
    .privacy-title { font-size:clamp(2.4rem,8vw,3.6rem); letter-spacing:3px; }
    .privacy-wrapper { padding:60px 20px 70px; }
    .privacy-section { padding:30px 24px 34px; margin-bottom:56px; }
        .privacy-section h2, .privacy-section-title { font-size:clamp(1.9rem,6vw,2.4rem); letter-spacing:2px; }
    .privacy-section h3 { font-size:1.05rem; }
    .privacy-toc a { font-size:0.72rem; padding:9px 12px; }
}

@media (max-width: 520px) {
    .privacy-toc { flex-direction:column; }
    .privacy-toc a { width:100%; text-align:center; }
}
