/*
Theme Name: Velori Hair Care
Theme URI: https://www.velorihair.com.au/
Author: ChatGPT
Author URI: https://openai.com/
Description: A premium dark-only WordPress/WooCommerce theme for Velori Hair Care, designed for luxury hair care, salon retail, wholesale and direct-to-salon supply. Includes customizer controls, sample images and responsive ecommerce sections.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: velori-hair-care
Tags: custom-logo, custom-menu, featured-images, theme-options, e-commerce, one-column, two-columns, dark, responsive-layout
*/

*, *::before, *::after { box-sizing: border-box; }
html { color-scheme: dark !important; background: var(--velori-bg) !important; scroll-behavior: smooth; }
body {
    margin: 0;
    background: radial-gradient(circle at 70% 18%, rgba(201,157,82,.14), transparent 36%), linear-gradient(180deg, #090806 0%, var(--velori-bg) 48%, #030302 100%) !important;
    color: var(--velori-text) !important;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 16px;
    line-height: 1.58;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}
@media (prefers-color-scheme: light) {
    html, body, .site { background: var(--velori-bg) !important; color: var(--velori-text) !important; }
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; }
.screen-reader-text { border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute !important; width: 1px; word-wrap: normal !important; }

.velori-page-wrap { min-height: 100vh; background-image: linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.014) 1px, transparent 1px); background-size: 64px 64px; }
.velori-container { width: min(1400px, calc(100% - 48px)); margin: 0 auto; }
.velori-narrow { width: min(980px, calc(100% - 48px)); margin: 0 auto; }

.velori-topbar { text-align: center; padding: 9px 18px; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--velori-gold-light); background: #070604; border-bottom: 1px solid rgba(201,157,82,.14); }
.velori-header { z-index: 50; background: rgba(5,5,4,.86); backdrop-filter: blur(20px); border-bottom: 1px solid rgba(201,157,82,.16); }
.velori-sticky-header .velori-header { position: sticky; top: 0; }
.admin-bar.velori-sticky-header .velori-header { top: 32px; }
.velori-header-inner { width: min(1480px, calc(100% - 44px)); margin: 0 auto; min-height: 82px; display: grid; grid-template-columns: 240px 1fr 190px; align-items: center; gap: 24px; }
.velori-logo { display: inline-flex; align-items: center; gap: 12px; min-width: 0; }
.velori-logo-mark { width: 38px; height: 38px; display: grid; place-items: center; border: 1px solid rgba(201,157,82,.45); color: var(--velori-gold-light); background: radial-gradient(circle, rgba(201,157,82,.14), transparent 70%); font-family: Georgia, serif; font-size: 24px; line-height: 1; }
.velori-logo-text { display: flex; flex-direction: column; line-height: 1; }
.velori-logo-main { font-family: Georgia, 'Times New Roman', serif; font-size: 34px; letter-spacing: .18em; color: var(--velori-gold-light); }
.velori-logo-sub { margin-top: 6px; font-size: 10px; letter-spacing: .32em; color: var(--velori-muted); text-transform: uppercase; }
.custom-logo-link img { max-height: 64px; width: auto; }
.velori-nav { justify-self: center; }
.velori-menu, .velori-nav .menu { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: clamp(16px, 2vw, 38px); }
.velori-menu a, .velori-nav .menu a { display: inline-flex; align-items: center; min-height: 44px; font-size: 12px; letter-spacing: .17em; text-transform: uppercase; color: rgba(244,234,216,.88); transition: color .2s ease, transform .2s ease; }
.velori-menu a:hover, .velori-nav .menu a:hover { color: var(--velori-gold-light); transform: translateY(-1px); }
.velori-actions { justify-self: end; display: flex; align-items: center; justify-content: flex-end; gap: 16px; }
.velori-icon-link, .velori-menu-toggle { position: relative; border: 0; background: transparent; padding: 8px; color: var(--velori-text); opacity: .92; }
.velori-icon-link svg, .velori-menu-toggle svg { width: 22px; height: 22px; stroke-width: 1.7; }
.velori-cart-count { position: absolute; top: 1px; right: -2px; min-width: 17px; height: 17px; padding: 0 4px; border-radius: 999px; display: grid; place-items: center; background: var(--velori-gold); color: #090704; font-size: 10px; font-weight: 800; }
.velori-menu-toggle { display: none; }

.velori-hero { position: relative; min-height: 660px; display: grid; align-items: center; overflow: hidden; border-bottom: 1px solid rgba(201,157,82,.18); }
.velori-hero::before { content: ''; position: absolute; inset: 0; background-image: var(--velori-hero-image); background-size: cover; background-position: center; opacity: .9; }
.velori-hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(5,5,4,.94) 0%, rgba(5,5,4,.7) 36%, rgba(5,5,4,.16) 78%, rgba(5,5,4,.55) 100%), linear-gradient(0deg, rgba(5,5,4,.95), transparent 35%, transparent 68%, rgba(5,5,4,.45)); }
.velori-hero-content { position: relative; z-index: 2; width: min(1480px, calc(100% - 48px)); margin: 0 auto; padding: 92px 0 76px; }
.velori-hero-copy { max-width: 560px; }
.velori-kicker { font-size: 12px; letter-spacing: .28em; text-transform: uppercase; color: var(--velori-gold-light); margin-bottom: 18px; }
.velori-hero h1, .velori-section-title, .velori-display-title { margin: 0; font-family: Georgia, 'Times New Roman', serif; font-weight: 400; color: var(--velori-text); letter-spacing: .085em; text-transform: uppercase; line-height: 1.12; }
.velori-hero h1 { font-size: clamp(46px, 7vw, 88px); max-width: 640px; text-shadow: 0 16px 40px rgba(0,0,0,.45); }
.velori-hero p { max-width: 470px; margin: 24px 0 0; color: rgba(244,234,216,.78); font-size: 17px; }
.velori-button-row { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.velori-btn { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 0 30px; border: 1px solid rgba(201,157,82,.58); background: rgba(201,157,82,.12); color: var(--velori-gold-light); font-size: 12px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; transition: transform .2s ease, background .2s ease, border-color .2s ease; }
.velori-btn:hover { transform: translateY(-2px); border-color: var(--velori-gold-light); background: rgba(201,157,82,.2); }
.velori-btn-primary { background: linear-gradient(135deg, var(--velori-gold-light), var(--velori-gold)); color: #100c07; border-color: transparent; box-shadow: 0 14px 32px rgba(201,157,82,.18); }
.velori-btn-primary:hover { background: linear-gradient(135deg, #fff0bd, var(--velori-gold)); }
.velori-hero-badges { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; margin-top: 42px; max-width: 620px; }
.velori-badge { display: grid; justify-items: center; gap: 9px; text-align: center; color: rgba(244,234,216,.78); font-size: 10px; line-height: 1.25; letter-spacing: .12em; text-transform: uppercase; }
.velori-badge-icon { width: 34px; height: 34px; border: 1px solid rgba(201,157,82,.35); border-radius: 999px; display: grid; place-items: center; color: var(--velori-gold-light); background: rgba(201,157,82,.05); }

.velori-section { padding: 78px 0; }
.velori-section-tight { padding: 42px 0; }
.velori-section-head { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 24px; }
.velori-section-title { font-size: clamp(26px, 3vw, 42px); }
.velori-view-link { font-size: 11px; letter-spacing: .18em; color: var(--velori-gold-light); text-transform: uppercase; }
.velori-view-link:hover { text-decoration: underline; text-underline-offset: 5px; }

.velori-collections { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); border: 1px solid rgba(201,157,82,.18); }
.velori-collection-card { position: relative; min-height: 198px; padding: 34px 28px; overflow: hidden; border-right: 1px solid rgba(201,157,82,.18); background: #090806; isolation: isolate; }
.velori-collection-card:last-child { border-right: 0; }
.velori-collection-card::before { content: ''; position: absolute; inset: 0; background-image: var(--card-image); background-size: cover; background-position: center; opacity: .72; z-index: -2; transition: transform .38s ease, opacity .25s ease; }
.velori-collection-card::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(5,5,4,.88), rgba(5,5,4,.2)); z-index: -1; }
.velori-collection-card:hover::before { transform: scale(1.04); opacity: .9; }
.velori-collection-card h3 { margin: 0 0 5px; font-family: Georgia, serif; color: var(--velori-text); text-transform: uppercase; font-size: 19px; letter-spacing: .12em; font-weight: 400; }
.velori-collection-card p { margin: 0 0 20px; color: rgba(244,234,216,.7); font-size: 13px; }
.velori-mini-link { color: var(--velori-gold-light); font-size: 11px; letter-spacing: .16em; font-weight: 700; text-transform: uppercase; }

.velori-products { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 0; border: 1px solid rgba(201,157,82,.17); background: rgba(255,255,255,.015); }
.velori-product-card { min-width: 0; background: rgba(13,13,10,.82); border-right: 1px solid rgba(201,157,82,.17); display: flex; flex-direction: column; }
.velori-product-card:last-child { border-right: 0; }
.velori-product-media { min-height: 270px; padding: 24px; display: grid; place-items: center; background: radial-gradient(circle at 50% 45%, rgba(201,157,82,.13), transparent 58%), #090806; }
.velori-product-media img { max-height: 245px; width: auto; object-fit: contain; transition: transform .25s ease, filter .25s ease; }
.velori-product-card:hover .velori-product-media img { transform: translateY(-5px) scale(1.02); filter: drop-shadow(0 20px 30px rgba(201,157,82,.08)); }
.velori-product-info { padding: 22px 22px 24px; display: grid; gap: 8px; flex: 1; }
.velori-product-info h3 { margin: 0; font-size: 15px; letter-spacing: .02em; font-weight: 500; color: var(--velori-text); }
.velori-product-info p { margin: 0; color: var(--velori-muted); font-size: 12px; }
.velori-product-rating { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--velori-muted); }
.velori-stars { color: var(--velori-gold-light); letter-spacing: .08em; font-size: 12px; }
.velori-product-info strong { color: var(--velori-text); font-size: 15px; margin-top: 2px; }
.velori-card-button { margin-top: 10px; min-height: 42px; display: grid; place-items: center; background: linear-gradient(135deg, var(--velori-gold-light), var(--velori-gold)); color: #090704 !important; font-size: 11px; letter-spacing: .16em; font-weight: 800; text-transform: uppercase; }
.velori-card-button:hover { filter: brightness(1.07); }

.velori-split { display: grid; grid-template-columns: 1.08fr .92fr; gap: 82px; align-items: center; }
.velori-image-frame { border: 1px solid rgba(201,157,82,.22); background: #090806; padding: 0; box-shadow: 0 32px 80px rgba(0,0,0,.28); overflow: hidden; }
.velori-image-frame img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.velori-copy p { color: rgba(244,234,216,.76); max-width: 640px; }
.velori-icon-grid { margin: 28px 0 34px; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; }
.velori-feature-icon { text-align: center; color: rgba(244,234,216,.72); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; line-height: 1.2; }
.velori-feature-icon span { display: grid; place-items: center; width: 34px; height: 34px; margin: 0 auto 10px; border: 1px solid rgba(201,157,82,.35); border-radius: 999px; color: var(--velori-gold-light); background: rgba(201,157,82,.07); }

.velori-salon { position: relative; overflow: hidden; border-top: 1px solid rgba(201,157,82,.18); border-bottom: 1px solid rgba(201,157,82,.18); background: radial-gradient(circle at 82% 20%, rgba(201,157,82,.16), transparent 38%), linear-gradient(135deg, rgba(20,18,14,.98), rgba(6,6,5,.96)); }
.velori-salon::before { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(201,157,82,.05) 0 1px, transparent 1px), linear-gradient(0deg, rgba(201,157,82,.04) 0 1px, transparent 1px); background-size: 72px 72px; opacity: .4; }
.velori-salon-inner { position: relative; display: grid; grid-template-columns: .9fr 1.1fr; gap: 58px; align-items: center; }
.velori-salon-card { border: 1px solid rgba(201,157,82,.24); padding: 38px; background: rgba(5,5,4,.48); backdrop-filter: blur(14px); }
.velori-metrics { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.velori-metric { min-height: 140px; padding: 26px 20px; border: 1px solid rgba(201,157,82,.18); display: grid; align-content: center; text-align: center; color: var(--velori-gold-light); font-family: Georgia, serif; letter-spacing: .12em; text-transform: uppercase; background: rgba(0,0,0,.18); }

.velori-crown { min-height: 430px; position: relative; display: grid; align-items: center; overflow: hidden; border-top: 1px solid rgba(201,157,82,.17); border-bottom: 1px solid rgba(201,157,82,.17); }
.velori-crown::before { content: ''; position: absolute; inset: 0; background-image: var(--crown-image); background-size: cover; background-position: center; opacity: .88; }
.velori-crown::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(5,5,4,.18), rgba(5,5,4,.82) 52%, rgba(5,5,4,.92)); }
.velori-crown-content { position: relative; z-index: 2; margin-left: auto; max-width: 620px; padding: 88px 0; }

.velori-testimonials { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0; border-top: 1px solid rgba(201,157,82,.18); border-bottom: 1px solid rgba(201,157,82,.18); }
.velori-testimonial { padding: 34px 30px; border-right: 1px solid rgba(201,157,82,.18); color: rgba(244,234,216,.78); }
.velori-testimonial:last-child { border-right: 0; }
.velori-testimonial p { margin: 16px 0 16px; }
.velori-testimonial cite { color: var(--velori-gold-light); font-style: normal; font-size: 12px; letter-spacing: .08em; }

.velori-gallery { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 0; border: 1px solid rgba(201,157,82,.18); }
.velori-gallery a { position: relative; aspect-ratio: 1 / 1; overflow: hidden; border-right: 1px solid rgba(201,157,82,.18); background: #090806; }
.velori-gallery a:last-child { border-right: 0; }
.velori-gallery img { width: 100%; height: 100%; object-fit: cover; transition: transform .38s ease, opacity .25s ease; opacity: .86; }
.velori-gallery a:hover img { transform: scale(1.06); opacity: 1; }

.velori-footer { padding: 44px 0 22px; border-top: 1px solid rgba(201,157,82,.18); background: #050504; }
.velori-footer-grid { display: grid; grid-template-columns: 1.25fr repeat(3, .72fr) 1.1fr; gap: 36px; }
.velori-footer h3, .velori-footer h4 { margin: 0 0 18px; font-size: 12px; letter-spacing: .18em; color: var(--velori-gold-light); text-transform: uppercase; }
.velori-footer p, .velori-footer a { color: rgba(244,234,216,.68); font-size: 13px; }
.velori-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.velori-socials { display: flex; align-items: center; gap: 14px; margin-top: 20px; }
.velori-socials a { width: 34px; height: 34px; display: grid; place-items: center; border: 1px solid rgba(201,157,82,.22); color: var(--velori-gold-light); }
.velori-newsletter-form { display: flex; border: 1px solid rgba(201,157,82,.28); background: rgba(255,255,255,.02); }
.velori-newsletter-form input { min-width: 0; flex: 1; border: 0; background: transparent; padding: 0 16px; min-height: 48px; color: var(--velori-text); }
.velori-newsletter-form button { width: 54px; border: 0; background: var(--velori-gold); color: #090704; font-weight: 900; }
.velori-footer-bottom { margin-top: 38px; padding-top: 18px; border-top: 1px solid rgba(201,157,82,.12); display: flex; align-items: center; justify-content: space-between; gap: 18px; color: rgba(244,234,216,.45); font-size: 12px; }
.velori-payments { display: flex; align-items: center; gap: 9px; }
.velori-payment-pill { border: 1px solid rgba(201,157,82,.22); padding: 4px 8px; color: rgba(244,234,216,.7); font-size: 11px; border-radius: 2px; }

.velori-page-content { padding: 70px 0 100px; }
.velori-page-content article { width: min(980px, calc(100% - 48px)); margin: 0 auto; }
.velori-page-content h1 { font-family: Georgia, serif; font-weight: 400; letter-spacing: .08em; text-transform: uppercase; color: var(--velori-gold-light); }
.velori-page-content a { color: var(--velori-gold-light); }
.velori-page-content input, .velori-page-content textarea, .velori-page-content select,
.woocommerce input, .woocommerce textarea, .woocommerce select { background: #0d0c0a !important; color: var(--velori-text) !important; border: 1px solid rgba(201,157,82,.24) !important; border-radius: 0 !important; }
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button, .woocommerce #respond input#submit { background: linear-gradient(135deg, var(--velori-gold-light), var(--velori-gold)) !important; color: #090704 !important; border-radius: 0 !important; font-weight: 800 !important; letter-spacing: .1em; text-transform: uppercase; }
.woocommerce div.product .product_title, .woocommerce-loop-product__title { color: var(--velori-text) !important; font-family: Georgia, serif; letter-spacing: .06em; }
.woocommerce ul.products li.product, .woocommerce-page ul.products li.product { background: rgba(13,13,10,.82); border: 1px solid rgba(201,157,82,.18); padding: 18px !important; }
.woocommerce .price { color: var(--velori-gold-light) !important; }
.woocommerce-message, .woocommerce-info, .woocommerce-error { background: #0d0c0a !important; color: var(--velori-text) !important; border-top-color: var(--velori-gold) !important; }

@media (max-width: 1180px) {
    .velori-header-inner { grid-template-columns: 220px 1fr 155px; }
    .velori-menu, .velori-nav .menu { gap: 18px; }
    .velori-products { overflow-x: auto; scroll-snap-type: x mandatory; }
    .velori-product-card { min-width: 250px; scroll-snap-align: start; }
    .velori-collections { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .velori-collection-card { border-bottom: 1px solid rgba(201,157,82,.18); }
    .velori-split { gap: 42px; }
    .velori-footer-grid { grid-template-columns: 1.2fr 1fr 1fr; }
}

@media (max-width: 920px) {
    .admin-bar.velori-sticky-header .velori-header { top: 0; }
    .velori-header-inner { min-height: 72px; grid-template-columns: 1fr auto; width: min(100% - 32px, 1480px); }
    .velori-logo-main { font-size: 28px; }
    .velori-nav { position: fixed; inset: 0 0 auto 0; top: calc(var(--topbar-height, 0px) + 72px); transform: translateY(-120%); transition: transform .24s ease; background: rgba(5,5,4,.97); border-bottom: 1px solid rgba(201,157,82,.2); padding: 24px; justify-self: stretch; }
    .velori-nav.is-open { transform: translateY(0); }
    .velori-menu, .velori-nav .menu { display: grid; gap: 0; }
    .velori-menu a, .velori-nav .menu a { min-height: 54px; border-bottom: 1px solid rgba(201,157,82,.12); }
    .velori-actions { gap: 8px; }
    .velori-menu-toggle { display: inline-flex; }
    .velori-hero { min-height: 720px; }
    .velori-hero::before { background-position: 61% center; opacity: .68; }
    .velori-hero::after { background: linear-gradient(180deg, rgba(5,5,4,.72), rgba(5,5,4,.85) 44%, rgba(5,5,4,.97)); }
    .velori-hero-content { padding: 82px 0 48px; }
    .velori-hero-copy { max-width: 100%; }
    .velori-hero h1 { font-size: clamp(38px, 12vw, 64px); }
    .velori-hero-badges { grid-template-columns: repeat(2, minmax(0, 1fr)); max-width: 500px; }
    .velori-collections { grid-template-columns: 1fr; }
    .velori-collection-card { border-right: 0; }
    .velori-split, .velori-salon-inner { grid-template-columns: 1fr; }
    .velori-icon-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .velori-metrics { grid-template-columns: 1fr; }
    .velori-crown::after { background: linear-gradient(180deg, rgba(5,5,4,.35), rgba(5,5,4,.95)); }
    .velori-crown-content { margin-left: 0; padding: 260px 0 54px; }
    .velori-testimonials { grid-template-columns: 1fr; }
    .velori-testimonial { border-right: 0; border-bottom: 1px solid rgba(201,157,82,.18); }
    .velori-gallery { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .velori-footer-grid { grid-template-columns: 1fr; }
    .velori-footer-bottom { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 560px) {
    .velori-container, .velori-narrow, .velori-hero-content { width: min(100% - 28px, 1400px); }
    .velori-topbar { font-size: 9px; letter-spacing: .14em; padding: 8px 10px; }
    .velori-header-inner { width: min(100% - 22px, 1480px); }
    .velori-logo-mark { width: 32px; height: 32px; font-size: 20px; }
    .velori-logo-main { font-size: 22px; letter-spacing: .14em; }
    .velori-logo-sub { font-size: 8px; }
    .velori-icon-link { padding: 6px; }
    .velori-icon-link svg { width: 20px; height: 20px; }
    .velori-hero { min-height: 690px; }
    .velori-hero h1 { letter-spacing: .06em; }
    .velori-hero p { font-size: 15px; }
    .velori-button-row { display: grid; grid-template-columns: 1fr; }
    .velori-btn { width: 100%; min-height: 50px; padding: 0 18px; }
    .velori-hero-badges { gap: 12px; }
    .velori-section { padding: 56px 0; }
    .velori-section-head { align-items: flex-start; flex-direction: column; }
    .velori-product-card { min-width: 78vw; }
    .velori-product-media { min-height: 240px; }
    .velori-gallery { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .velori-salon-card { padding: 28px 22px; }
}
