/*
Theme Name: Lumiere Beauty Studio
Theme URI: https://example.com/lumiere
Author: Custom Build
Author URI: https://example.com
Description: An elegant beauty / PMU / skincare studio theme with a fixed left sidebar, vertical navigation, full-bleed imagery and a soft blush palette. Sections for Services, About, Gallery, Reviews, FAQ, Policies and Contact.
Version: 1.1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: lumiere
Tags: one-page, beauty, spa, salon, responsive, custom-colors, custom-menu, featured-images
*/

/* ============================================================
   1. TOKENS
   ============================================================ */
:root{
  --color-bg:#ffffff;
  --color-ink:#2b2521;
  --color-muted:#8c8178;
  --color-line:#ece2da;
  --color-cream:#f1e8e2;       /* sidebar */
  --color-blush:#f7eae4;       /* soft pink panels */
  --color-blush-2:#f3ddd5;
  --color-accent:#c9a79b;      /* mauve rose */
  --color-accent-dark:#b58a7c;
  --font-display:"Cormorant Garamond", Georgia, serif;
  --font-script:"Pinyon Script", "Cormorant Garamond", cursive;
  --font-body:"Montserrat", "Helvetica Neue", Arial, sans-serif;
  --side-w:210px;
  --rail-w:48px;
  --space:clamp(4rem, 9vh, 8rem);
  --shadow:0 24px 60px rgba(43,37,33,.14);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ============================================================
   2. BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  padding-left:var(--side-w);
  background:var(--color-bg);
  color:var(--color-ink);
  font-family:var(--font-body);
  font-size:15px;line-height:1.8;font-weight:300;letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.1;margin:0 0 .35em;letter-spacing:.04em}
h1{font-size:clamp(3rem,7vw,6rem)}
h2{font-size:clamp(2.4rem,5vw,4rem);text-transform:uppercase;letter-spacing:.08em}
h3{font-size:clamp(1.3rem,2.2vw,1.7rem)}
p{margin:0 0 1.2em}
.script{font-family:var(--font-script);font-size:clamp(2rem,3.6vw,3rem);color:var(--color-accent-dark);line-height:1;display:block;margin-bottom:-.25em;text-transform:none;letter-spacing:.01em}
.muted{color:var(--color-muted)}
.center{text-align:center}
.container{width:100%;max-width:1180px;margin-inline:auto;padding-inline:clamp(1.5rem,5vw,4rem)}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--font-body);font-size:.7rem;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;
  padding:1rem 2.2rem;border:1px solid var(--color-ink);
  background:var(--color-ink);color:#fff;cursor:pointer;transition:all .3s var(--ease);
}
.btn:hover{background:var(--color-accent-dark);border-color:var(--color-accent-dark);color:#fff}
.btn--ghost{background:transparent;color:var(--color-ink)}
.btn--ghost:hover{background:var(--color-ink);color:#fff}
.btn--light{background:#fff;color:var(--color-ink);border-color:#fff}
.btn--light:hover{background:var(--color-blush);border-color:var(--color-blush);color:var(--color-ink)}

/* ============================================================
   3. LEFT SIDEBAR
   ============================================================ */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;width:var(--side-w);z-index:90;
  background:var(--color-cream);border-right:1px solid var(--color-line);
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  padding:2rem 1.2rem;
}
.sidebar .brand{font-family:var(--font-script);font-size:1.9rem;color:var(--color-ink);text-align:center;line-height:.95}
.sidebar .brand small{display:block;font-family:var(--font-body);font-size:.5rem;font-weight:600;letter-spacing:.42em;text-transform:uppercase;color:var(--color-muted);margin-top:.5rem}
.sidebar .brand img{max-height:74px;width:auto;margin:0 auto}
.side-nav{display:flex;flex-direction:column;gap:1.15rem;text-align:center}
.side-nav a{font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--color-ink)}
.side-nav a:hover{color:var(--color-accent-dark)}
.side-social{display:flex;gap:1rem}
.side-social a{color:var(--color-ink)}
.side-social a:hover{color:var(--color-accent-dark)}
.side-social svg{width:17px;height:17px;fill:currentColor}

/* ============================================================
   4. RIGHT VERTICAL ACTION RAIL
   ============================================================ */
.rail{position:fixed;top:50%;right:0;transform:translateY(-50%);z-index:90;display:flex;flex-direction:column;align-items:stretch}
.rail .tab{
  writing-mode:vertical-rl;
  background:var(--color-blush);color:var(--color-ink);
  font-size:.6rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  padding:1.4rem .55rem;border-bottom:1px solid rgba(255,255,255,.6);
  display:flex;align-items:center;justify-content:center;transition:background .25s,color .25s;
}
.rail .tab:hover{background:var(--color-accent-dark);color:#fff}
.rail .tab--ink{background:var(--color-ink);color:#fff}
.rail .tab--ink:hover{background:var(--color-accent-dark)}
.rail .rail-social{display:flex;flex-direction:column}
.rail .rail-social a{width:var(--rail-w);height:42px;display:flex;align-items:center;justify-content:center;background:var(--color-cream);color:var(--color-ink)}
.rail .rail-social a:hover{background:var(--color-accent-dark);color:#fff}
.rail .rail-social svg{width:15px;height:15px;fill:currentColor}

/* mobile top bar + menu (hidden on desktop) */
.mobile-bar,.mobile-menu{display:none}

/* ============================================================
   5. HERO
   ============================================================ */
.hero{
  min-height:100vh;display:flex;align-items:flex-end;justify-content:center;
  text-align:center;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(180deg,rgba(43,37,33,.05),rgba(43,37,33,.45)),
             var(--hero-img,linear-gradient(135deg,#f0d9cf,#d8b3a4 60%,#c49a8b));
  background-size:cover;background-position:center;
}
.hero-inner{padding-bottom:14vh}
.hero h1{margin:0;text-shadow:0 2px 40px rgba(0,0,0,.25);font-weight:500}
.hero .sub{font-family:var(--font-body);font-size:clamp(1rem,2vw,1.5rem);font-weight:300;letter-spacing:.42em;text-transform:uppercase;margin:.4rem 0 2rem}
.scroll-cue{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;color:#fff;opacity:.85;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.scroll-cue::after{content:"";width:1px;height:42px;background:#fff;animation:cue 1.9s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============================================================
   6. SPLIT SECTION (text + image) — used by Philosophy / About
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;min-height:88vh;align-items:stretch}
.split--rev .split-text{order:2}
.split--rev .split-img{order:1}
.split-text{display:flex;flex-direction:column;justify-content:center;padding:var(--space) clamp(2rem,6vw,6rem);background:var(--color-blush)}
.split-text.is-cream{background:var(--color-cream)}
.split-text p{color:var(--color-muted);max-width:46ch}
.split-img{background-size:cover;background-position:center;background-color:var(--color-blush-2);min-height:50vh;position:relative}
.split-img .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-script);font-size:2rem;color:#fff;background:linear-gradient(135deg,#e9c9bd,#c49a8b)}
.split-text .badge{margin-top:1.5rem;display:inline-flex;align-items:baseline;gap:.6rem}
.split-text .badge strong{font-family:var(--font-display);font-size:2.6rem;color:var(--color-accent-dark);line-height:1}
.split-text .badge span{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--color-muted)}
.split-text .name{font-family:var(--font-script);font-size:1.8rem;color:var(--color-accent-dark);margin-top:1rem}

/* ============================================================
   7. SERVICES
   ============================================================ */
.services{padding:var(--space) 0}
.section-head{text-align:center;max-width:640px;margin:0 auto clamp(2.5rem,5vw,4rem)}
.section-head p{color:var(--color-muted)}
.svc-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:1.2rem 1.6rem;margin-bottom:3rem;border-bottom:1px solid var(--color-line);padding-bottom:1.1rem}
.svc-tab{background:none;border:0;cursor:pointer;font-family:var(--font-body);font-size:.68rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--color-muted);padding:.4rem .2rem .55rem;position:relative}
.svc-tab::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--color-accent-dark);transform:scaleX(0);transition:transform .3s var(--ease)}
.svc-tab.active{color:var(--color-ink)}
.svc-tab.active::after{transform:scaleX(1)}
.svc-panel{display:none;animation:fade .5s var(--ease)}
.svc-panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.4rem}
.svc-card{border:1px solid var(--color-line);padding:2rem 1.8rem;background:#fff;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.svc-card .num{font-family:var(--font-script);font-size:1.6rem;color:var(--color-accent-dark)}
.svc-card h3{margin:.2rem 0 .35rem;text-transform:none}
.svc-card .meta{font-size:.62rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--color-accent-dark);margin-bottom:.8rem}
.svc-card p{font-size:.9rem;color:var(--color-muted);margin:0}
/* price menu */
.svc-menu{max-width:780px;margin:0 auto}
.svc-row{display:flex;align-items:baseline;gap:.9rem;padding:1rem 0;border-bottom:1px solid var(--color-line)}
.svc-row-info{flex:0 1 auto;min-width:0}
.svc-row .nm{font-size:1.02rem;color:var(--color-ink);font-weight:400}
.svc-row .mt{display:block;font-size:.7rem;letter-spacing:.06em;color:var(--color-muted);margin-top:.15rem}
.svc-row .dots{flex:1 1 auto;border-bottom:1px dotted var(--color-line);transform:translateY(-4px);min-width:1.5rem}
.svc-row .pr{flex:0 0 auto;font-family:var(--font-display);font-size:1.4rem;font-weight:500;color:var(--color-accent-dark);white-space:nowrap}
@media(max-width:540px){.svc-row .dots{display:none}.svc-row .nm{font-size:.95rem}.svc-row .pr{font-size:1.2rem}}

/* ============================================================
   8. GALLERY
   ============================================================ */
.gallery{padding:var(--space) 0;background:var(--color-blush)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.gallery-grid figure{margin:0;aspect-ratio:1;overflow:hidden;background:var(--color-blush-2);position:relative}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery-grid figure:hover img{transform:scale(1.07)}
.gallery-grid .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-script);font-size:1.3rem;background:linear-gradient(135deg,#e9c9bd,#cfa294)}

/* ============================================================
   9. REVIEWS
   ============================================================ */
.reviews{padding:var(--space) 0;background:var(--color-ink);color:#fff;text-align:center}
.reviews .script{color:var(--color-accent)}
.reviews h2{color:#fff}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.t-card{border:1px solid rgba(255,255,255,.14);padding:2.2rem 1.8rem;text-align:left}
.stars{color:var(--color-accent);letter-spacing:.2em;margin-bottom:1rem}
.t-card p{font-family:var(--font-display);font-style:italic;font-size:1.15rem;line-height:1.5;color:#f3e9e3}
.t-card .who{font-size:.66rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--color-accent);margin-top:1.2rem}

/* ============================================================
   10. FAQ
   ============================================================ */
.faq{padding:var(--space) 0}
.faq-list{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--color-line)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-family:var(--font-display);font-size:1.3rem;color:var(--color-ink)}
.faq-q .ic{font-size:1.4rem;color:var(--color-accent-dark);transition:transform .3s var(--ease)}
.faq-item.open .faq-q .ic{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a p{color:var(--color-muted);padding:0 0 1.5rem}

/* ============================================================
   11. POLICIES
   ============================================================ */
.policies{padding:var(--space) 0;background:var(--color-cream)}
.policy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:2.5rem}
.policy-card{background:#fff;padding:2rem 1.8rem;border:1px solid var(--color-line)}
.policy-card h3{text-transform:none;font-size:1.3rem;margin-bottom:.6rem}
.policy-card p{color:var(--color-muted);font-size:.9rem;margin:0}

/* ============================================================
   12. CONTACT
   ============================================================ */
.contact{padding:var(--space) 0;background:var(--color-blush)}
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4rem)}
.info-row{display:flex;gap:1rem;padding:1.1rem 0;border-bottom:1px solid var(--color-line)}
.info-row .label{font-size:.62rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--color-accent-dark);min-width:84px}
.contact-form{background:#fff;padding:clamp(1.6rem,4vw,2.6rem);box-shadow:var(--shadow)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.64rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--color-muted);margin-bottom:.5rem}
.field input,.field select,.field textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--color-line);font-family:var(--font-body);font-size:.9rem;color:var(--color-ink);background:#fff;transition:border-color .25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--color-accent-dark)}
.field textarea{resize:vertical;min-height:120px}
.form-note{font-size:.78rem;color:var(--color-muted);margin-top:1rem}
.form-msg{padding:.9rem 1.1rem;margin-bottom:1.2rem;font-size:.88rem}
.form-msg.ok{background:#e9f3ec;color:#2f6b43}
.form-msg.err{background:#fbeaea;color:#9c3030}

/* ============================================================
   13. FOOTER
   ============================================================ */
.site-footer{background:var(--color-ink);color:#cfc4bb;padding:clamp(2.5rem,5vw,4rem) 0 2rem;text-align:center}
.site-footer .brand{font-family:var(--font-script);font-size:2rem;color:#fff}
.footer-nav{display:flex;flex-wrap:wrap;gap:1.4rem;justify-content:center;margin:1.5rem 0}
.footer-nav a{font-size:.66rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#cfc4bb}
.footer-nav a:hover{color:var(--color-accent)}
.site-footer .socials{display:flex;gap:.8rem;justify-content:center;margin:1.2rem 0}
.site-footer .socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}
.site-footer .socials a:hover{background:var(--color-accent-dark);border-color:var(--color-accent-dark)}
.site-footer .socials svg{width:16px;height:16px;fill:currentColor}
.copyright{font-size:.7rem;color:#8c8076;margin-top:1.2rem}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* generic pages */
.page-hero{padding:8rem 0 3rem;background:var(--color-blush);text-align:center}
.page-content{padding:var(--space) 0}
.page-content .container{max-width:760px}

/* ============================================================
   14. RESPONSIVE
   ============================================================ */
@media(max-width:900px){
  :root{--side-w:0px}
  body{padding-left:0;padding-top:64px}
  .sidebar{display:none}
  .rail{display:none}
  .split{grid-template-columns:1fr}
  .split--rev .split-text{order:1}
  .split--rev .split-img{order:2}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .t-grid,.policy-grid,.contact-grid{grid-template-columns:1fr}

  /* mobile top bar */
  .mobile-bar{
    display:flex;position:fixed;top:0;left:0;right:0;height:64px;z-index:100;
    background:var(--color-cream);border-bottom:1px solid var(--color-line);
    align-items:center;justify-content:space-between;padding:0 1.2rem;
  }
  .mobile-bar .brand{font-family:var(--font-script);font-size:1.5rem;color:var(--color-ink)}
  .nav-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.4rem}
  .nav-toggle span{width:26px;height:2px;background:var(--color-ink);display:block;transition:.3s}
  .mobile-menu{
    display:flex;
    position:fixed;inset:64px 0 0 auto;width:min(82vw,340px);background:var(--color-cream);
    transform:translateX(110%);transition:transform .4s var(--ease);z-index:99;
    display:flex;flex-direction:column;gap:1.4rem;padding:2.5rem 2rem;box-shadow:var(--shadow);
  }
  .mobile-menu.open{transform:translateX(0)}
  .mobile-menu a{font-size:.85rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--color-ink)}
  .mobile-menu a.btn{color:#fff;margin-top:.6rem}
  .mobile-menu a.btn:hover{color:#fff}
  body.nav-open{overflow:hidden}
}
