/*
Theme Name: Lumina Salon
Theme URI: https://luminasalon.com
Author: WooSalonPro
Author URI: https://woosalonpro.com
Description: A premium beauty salon WordPress theme built for modern salons and spas. Designed to work seamlessly with WooSalonPro plugin. Features mobile-app experience, smooth animations, and stunning visual design.
Version: 12.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: lumina-salon
Tags: beauty, salon, spa, booking, woocommerce, elementor, full-width-template, custom-colors, custom-menu, featured-images, footer-widgets, sticky-post, threaded-comments
*/

/* ================================================================
   LUMINA SALON — DESIGN SYSTEM
   Aesthetic: Refined Luxury — dark velvet meets gold + blush rose
   Inspired by high-end Nigerian beauty culture
   ================================================================ */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,600&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,300&family=Playfair+Display:ital,wght@0,700;0,800;0,900;1,400;1,700&display=swap');

/* CRITICAL: preloader dark background — must load before components.css */
#ls-preloader{position:fixed!important;inset:0!important;background:#0a0908!important;z-index:999999!important;display:flex!important;align-items:center!important;justify-content:center!important}


/* ── CRITICAL: Preloader must be dark before any other CSS loads ── */
#ls-preloader {
    position: fixed !important;
    inset: 0 !important;
    background: #0a0908 !important;
    z-index: 999999 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-direction: column !important;
}


/* ── CSS Custom Properties ── */
:root {
    /* Core palette */
    --ls-black:       #0a0908;
    --ls-dark:        #111010;
    --ls-dark-2:      #1a1917;
    --ls-dark-3:      #242220;
    --ls-gold:        #c9a84c;
    --ls-gold-light:  #e8c97a;
    --ls-gold-pale:   #f5e8c4;
    --ls-rose:        #d4768a;
    --ls-rose-light:  #e8a0b0;
    --ls-rose-pale:   #fce8ed;
    --ls-cream:       #faf8f5;
    --ls-white:       #ffffff;

    /* UI Colors */
    --ls-text-dark:   #0a0908;
    --ls-text-body:   #3d3a38;
    --ls-text-muted:  #7a736e;
    --ls-text-light:  #b5aba4;
    --ls-border:      #e8e2da;
    --ls-border-dark: #2a2826;

    /* Gradients */
    --ls-grad-gold:   linear-gradient(135deg, #c9a84c, #e8c97a, #c9a84c);
    --ls-grad-dark:   linear-gradient(160deg, #0a0908 0%, #1a1917 50%, #111010 100%);
    --ls-grad-hero:   linear-gradient(160deg, #0d0b0a 0%, #1f1b18 40%, #2a2219 100%);
    --ls-grad-rose:   linear-gradient(135deg, #d4768a, #e8a0b0);

    /* Typography */
    --ls-font-display: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
    --ls-font-heading: 'Playfair Display', 'Cormorant Garamond', Georgia, serif;
    --ls-font-body:    'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;

    /* Spacing */
    --ls-gap-xs:   8px;
    --ls-gap-sm:   16px;
    --ls-gap-md:   24px;
    --ls-gap-lg:   40px;
    --ls-gap-xl:   64px;
    --ls-gap-2xl:  96px;
    --ls-gap-3xl:  128px;

    /* Layout */
    --ls-container:      1280px;
    --ls-container-wide: 1440px;
    --ls-header-h:       80px;
    --ls-header-h-mob:   64px;

    /* Effects */
    --ls-radius-sm:  6px;
    --ls-radius:     12px;
    --ls-radius-lg:  20px;
    --ls-radius-xl:  32px;
    --ls-radius-pill:100px;
    --ls-shadow-sm:  0 2px 12px rgba(0,0,0,.06);
    --ls-shadow:     0 8px 32px rgba(0,0,0,.10);
    --ls-shadow-lg:  0 16px 56px rgba(0,0,0,.14);
    --ls-shadow-gold:0 8px 32px rgba(201,168,76,.25);

    /* Transitions */
    --ls-ease:       cubic-bezier(.25,.46,.45,.94);
    --ls-ease-out:   cubic-bezier(0,.55,.45,1);
    --ls-spring:     cubic-bezier(.34,1.56,.64,1);
    --ls-dur-fast:   150ms;
    --ls-dur:        300ms;
    --ls-dur-slow:   500ms;
}

/* ── Base Reset ── */
*, *::before, *::after { box-sizing: border-box; }

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    font-size: 16px;
}

body {
    margin: 0;
    background: #0a0908; /* dark prevents white flash on load */
    color: var(--ls-text-body);
    font-family: var(--ls-font-body);
    font-size: 1rem;
    line-height: 1.65;
    font-weight: 400;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Mobile app feel */
body {
    -webkit-tap-highlight-color: transparent;
    touch-action: pan-y;
}

/* ── Typography ── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--ls-font-heading);
    color: var(--ls-text-dark);
    margin: 0 0 .5em;
    line-height: 1.15;
    font-weight: 700;
    letter-spacing: -.02em;
}

h1 { font-size: clamp(2.2rem, 6vw, 4.5rem); font-weight: 800; }
h2 { font-size: clamp(1.75rem, 4vw, 3rem);  font-weight: 700; }
h3 { font-size: clamp(1.35rem, 2.5vw, 2rem); }
h4 { font-size: clamp(1.1rem, 2vw, 1.5rem); }
h5 { font-size: 1.15rem; }
h6 { font-size: 1rem; }

p { margin: 0 0 1.2em; }
p:last-child { margin-bottom: 0; }

a {
    color: var(--ls-gold);
    text-decoration: none;
    transition: color var(--ls-dur-fast) var(--ls-ease);
}
a:hover { color: var(--ls-gold-light); }

img, video { max-width: 100%; height: auto; display: block; }
ul, ol { padding-left: 1.5em; margin: 0 0 1em; }
li { margin-bottom: .4em; }
blockquote {
    border-left: 3px solid var(--ls-gold);
    margin: 1.5em 0;
    padding: 1em 1.5em;
    font-style: italic;
    font-family: var(--ls-font-display);
    font-size: 1.15rem;
    color: var(--ls-text-dark);
}

/* ── Layout Utilities ── */
.ls-container {
    max-width: var(--ls-container);
    margin: 0 auto;
    padding: 0 clamp(20px, 5vw, 60px);
}
.ls-container--wide { max-width: var(--ls-container-wide); }
.ls-container--narrow { max-width: 800px; }

.ls-section {
    padding: clamp(60px, 10vh, 120px) 0;
}
.ls-section--sm { padding: clamp(40px, 6vh, 72px) 0; }
.ls-section--lg { padding: clamp(80px, 14vh, 160px) 0; }

.ls-grid { display: grid; gap: var(--ls-gap-lg); }
.ls-grid--2 { grid-template-columns: repeat(2, 1fr); }
.ls-grid--3 { grid-template-columns: repeat(3, 1fr); }
.ls-grid--4 { grid-template-columns: repeat(4, 1fr); }

.ls-flex { display: flex; align-items: center; gap: var(--ls-gap-md); }
.ls-flex--between { justify-content: space-between; }
.ls-flex--center  { justify-content: center; }

/* ── Buttons ── */
.ls-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 32px;
    border-radius: var(--ls-radius-pill);
    font-family: var(--ls-font-body);
    font-size: .9rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    cursor: pointer;
    border: none;
    transition: all var(--ls-dur) var(--ls-ease);
    text-decoration: none;
    white-space: nowrap;
    -webkit-tap-highlight-color: transparent;
}
.ls-btn--gold {
    background: var(--ls-grad-gold);
    color: var(--ls-black);
    box-shadow: var(--ls-shadow-gold);
}
.ls-btn--gold:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 40px rgba(201,168,76,.4);
    color: var(--ls-black);
}
.ls-btn--dark {
    background: var(--ls-dark);
    color: var(--ls-gold);
    border: 1px solid var(--ls-border-dark);
}
.ls-btn--dark:hover { background: var(--ls-dark-3); color: var(--ls-gold-light); transform: translateY(-2px); }
.ls-btn--outline {
    background: transparent;
    color: var(--ls-gold);
    border: 1.5px solid var(--ls-gold);
}
.ls-btn--outline:hover { background: var(--ls-gold); color: var(--ls-black); }
.ls-btn--white {
    background: var(--ls-white);
    color: var(--ls-dark);
}
.ls-btn--white:hover { background: var(--ls-cream); transform: translateY(-2px); }
.ls-btn--rose {
    background: var(--ls-grad-rose);
    color: var(--ls-white);
    box-shadow: 0 8px 24px rgba(212,118,138,.3);
}
.ls-btn--rose:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(212,118,138,.4); color: var(--ls-white); }
.ls-btn--lg { padding: 18px 44px; font-size: 1rem; }
.ls-btn--sm { padding: 10px 22px; font-size: .8rem; }
.ls-btn--icon { padding: 12px; border-radius: 50%; aspect-ratio: 1; }
.ls-btn:active { transform: scale(.97) !important; }

/* ── Section Labels ── */
.ls-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--ls-font-body);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-bottom: 16px;
}
.ls-eyebrow::before, .ls-eyebrow::after {
    content: '';
    display: block;
    width: 24px;
    height: 1px;
    background: var(--ls-gold);
    opacity: .6;
}

/* ── Cards ── */
.ls-card {
    background: var(--ls-white);
    border-radius: var(--ls-radius-lg);
    overflow: hidden;
    box-shadow: var(--ls-shadow-sm);
    transition: transform var(--ls-dur) var(--ls-ease), box-shadow var(--ls-dur) var(--ls-ease);
}
.ls-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--ls-shadow-lg);
}
.ls-card--dark {
    background: var(--ls-dark-2);
    border: 1px solid var(--ls-border-dark);
    color: var(--ls-cream);
}

/* ── Dividers ── */
.ls-divider {
    width: 48px; height: 2px;
    background: var(--ls-grad-gold);
    border-radius: 2px;
    margin: 16px 0;
}
.ls-divider--center { margin-left: auto; margin-right: auto; }

/* ── Badges ── */
.ls-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: var(--ls-radius-pill);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.ls-badge--gold { background: var(--ls-gold-pale); color: #8a6a20; }
.ls-badge--rose { background: var(--ls-rose-pale); color: #8a3a50; }
.ls-badge--dark { background: var(--ls-dark-3); color: var(--ls-gold); }

/* ── Form Elements ── */
.ls-input {
    display: block; width: 100%;
    padding: 14px 18px;
    border: 1.5px solid var(--ls-border);
    border-radius: var(--ls-radius);
    font-family: var(--ls-font-body);
    font-size: 1rem;
    color: var(--ls-text-dark);
    background: var(--ls-white);
    transition: border-color var(--ls-dur-fast), box-shadow var(--ls-dur-fast);
    outline: none;
    -webkit-appearance: none;
}
.ls-input:focus {
    border-color: var(--ls-gold);
    box-shadow: 0 0 0 3px rgba(201,168,76,.12);
}
.ls-input::placeholder { color: var(--ls-text-light); }
.ls-label {
    display: block;
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--ls-text-muted);
    margin-bottom: 6px;
}
.ls-form-group { margin-bottom: 20px; }

/* ── Scroll animations (Intersection Observer) ── */
.ls-reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity .7s var(--ls-ease), transform .7s var(--ls-ease);
}
.ls-reveal.revealed {
    opacity: 1;
    transform: translateY(0);
}
.ls-reveal--delay-1 { transition-delay: .1s; }
.ls-reveal--delay-2 { transition-delay: .2s; }
.ls-reveal--delay-3 { transition-delay: .3s; }
.ls-reveal--delay-4 { transition-delay: .4s; }
.ls-reveal--left  { transform: translateX(-30px); }
.ls-reveal--right { transform: translateX(30px); }
.ls-reveal--left.revealed, .ls-reveal--right.revealed { transform: translateX(0); }

/* ── Skip link (a11y) ── */
.skip-link {
    position: absolute;
    top: -40px;
    left: 16px;
    background: var(--ls-gold);
    color: var(--ls-black);
    padding: 8px 16px;
    border-radius: 0 0 8px 8px;
    font-weight: 700;
    z-index: 9999;
    transition: top var(--ls-dur-fast);
}
.skip-link:focus { top: 0; }

/* ── Screen reader ── */
.sr-only {
    position: absolute; width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ── WordPress Core Alignments ── */
.alignleft  { float: left; margin-right: 1.5em; margin-bottom: 1em; }
.alignright { float: right; margin-left: 1.5em; margin-bottom: 1em; }
.aligncenter { display: block; margin: 0 auto 1em; }
.alignwide  { margin-left: calc(-1 * clamp(20px,5vw,60px)); margin-right: calc(-1 * clamp(20px,5vw,60px)); }
.alignfull  { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); width: 100vw; }

.wp-caption { max-width: 100%; margin-bottom: 1.5em; }
.wp-caption-text { font-size: .85rem; color: var(--ls-text-muted); margin-top: .5em; text-align: center; }
.sticky { /* WordPress sticky post */ }
.gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 8px; }

/* ── WooCommerce base ── */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
    border-radius: var(--ls-radius);
    padding: 14px 18px;
    margin-bottom: 20px;
    font-weight: 500;
}
.woocommerce-message { background: #f0faf0; border-left: 3px solid #22c55e; }
.woocommerce-error   { background: #fff0f0; border-left: 3px solid #ef4444; }
.woocommerce-info    { background: var(--ls-gold-pale); border-left: 3px solid var(--ls-gold); }
