/* ============================================================
   PERFECT TRESSES — GLOBAL DESIGN SYSTEM
   ============================================================ */

/* 1. CUSTOM PROPERTIES */
:root {
  --cream:#F9F7F4;--cream-deep:#F2EDE7;--cream-mid:#EDE7DF;
  --stone:#D8D2C8;--stone-mid:#CFC7BD;--accent:#BFAFA3;
  --text:#2B2B2B;--text-mid:#4A4540;--text-lt:#8C857E;--white:#FFFFFF;
  --max-w:1200px;--pad-x:56px;--pad-x-mob:24px;--section-pad:120px;--nav-h:80px;
}

/* 2. RESET & BASE */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;}
body{background:var(--cream);color:var(--text);font-family:'Montserrat',sans-serif;font-weight:300;font-size:15px;line-height:1.78;overflow-x:hidden;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
ul,ol{list-style:none;}

/* 3. LAYOUT */
.inner,.section-inner,.nav-inner,.footer-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad-x);}
.section-pad{padding:var(--section-pad) 0;}
.section-pad-sm{padding:80px 0;}

/* 4. TYPOGRAPHY */
.eyebrow,.section-eyebrow{font-family:'Montserrat',sans-serif;font-size:0.57rem;font-weight:600;letter-spacing:0.32em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:18px;}
.section-title,h2.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,3.5vw,3rem);font-weight:300;line-height:1.08;color:var(--text);letter-spacing:-0.01em;}
.section-title em,h2.section-title em{font-family:'Playfair Display',serif;font-style:italic;font-weight:400;}
.lead{font-size:0.88rem;font-weight:300;line-height:1.9;color:var(--text-mid);}
blockquote{font-family:'Playfair Display',serif;font-size:1.1rem;font-style:italic;font-weight:400;color:var(--text-mid);line-height:1.85;border-left:1px solid var(--accent);padding-left:28px;margin:40px 0;}
.rule{width:40px;height:1px;background:var(--accent);margin:28px 0;}
.rule--centered{margin-left:auto;margin-right:auto;}

/* 5. NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(249,247,244,0.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--stone);}
.nav-inner{height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:300;letter-spacing:0.32em;text-transform:uppercase;color:var(--text);text-decoration:none;}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none;}
.nav-links a{font-size:0.57rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-lt);text-decoration:none;transition:color 0.2s;}
.nav-links a:hover{color:var(--text);}
.nav-book{font-family:'Montserrat',sans-serif;font-size:0.57rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--text);background:transparent;padding:11px 26px;border:1px solid var(--text);text-decoration:none;display:inline-block;transition:background 0.25s,color 0.25s;}
.nav-book:hover{background:var(--text);color:var(--cream);}

/* HAMBURGER */
.ham-btn{display:none;background:none;border:none;cursor:pointer;padding:6px;flex-direction:column;gap:5px;}
.ham-btn span{display:block;width:22px;height:1.5px;background:var(--text);transition:all 0.28s ease;transform-origin:center;}
.ham-btn.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.ham-btn.open span:nth-child(2){opacity:0;}
.ham-btn.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
.mobile-nav{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(249,247,244,0.99);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--stone);padding:20px 24px 32px;z-index:199;flex-direction:column;}
.mobile-nav.open{display:flex;}
.mobile-nav a{font-size:0.68rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-lt);text-decoration:none;padding:15px 0;border-bottom:1px solid var(--stone);transition:color 0.2s;}
.mobile-nav a:hover{color:var(--text);}
.mobile-nav a:last-child{border-bottom:none;}
.mobile-nav .nav-book-mobile{display:block;margin-top:20px;padding:14px;text-align:center;border:1px solid var(--text);color:var(--text);font-family:'Montserrat',sans-serif;font-size:0.57rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;text-decoration:none;transition:background 0.25s,color 0.25s;}
.mobile-nav .nav-book-mobile:hover{background:var(--text);color:var(--cream);}

/* 6. BUTTONS */
.btn-dark{font-family:'Montserrat',sans-serif;font-size:0.6rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--text);background:transparent;padding:14px 38px;border:1px solid var(--text);cursor:pointer;text-decoration:none;display:inline-block;transition:background 0.25s,color 0.25s;}
.btn-dark:hover{background:var(--text);color:var(--cream);}
.btn-outline{font-family:'Montserrat',sans-serif;font-size:0.6rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-mid);background:transparent;padding:12px 30px;border:1px solid var(--stone-mid);cursor:pointer;text-decoration:none;display:inline-block;transition:border-color 0.25s,color 0.25s;}
.btn-outline:hover{border-color:var(--text);color:var(--text);}
.btn-text{font-family:'Montserrat',sans-serif;font-size:0.6rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-lt);text-decoration:none;display:inline-block;position:relative;padding-bottom:2px;}
.btn-text::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent);transition:width 0.3s ease;}
.btn-text:hover{color:var(--text);}
.btn-text:hover::after{width:100%;}
.btn-hero-primary{font-family:'Montserrat',sans-serif;font-size:0.6rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--text);background:transparent;padding:15px 38px;border:1px solid var(--text);cursor:pointer;text-decoration:none;display:inline-block;transition:background 0.25s,color 0.25s;margin-bottom:16px;}
.btn-hero-primary:hover{background:var(--text);color:var(--cream);}
.btn-hero-secondary{font-family:'Montserrat',sans-serif;font-size:0.6rem;font-weight:300;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-lt);text-decoration:none;display:inline-block;position:relative;padding-bottom:2px;}
.btn-hero-secondary::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent);transition:width 0.3s ease;}
.btn-hero-secondary:hover{color:var(--text);}
.btn-hero-secondary:hover::after{width:100%;}

/* 7. KLARNA BAR */
.klarna-bar{background:var(--cream-mid);padding:22px var(--pad-x);text-align:center;border-top:1px solid var(--stone);border-bottom:1px solid var(--stone);}
.klarna-bar p{font-size:0.72rem;font-weight:300;letter-spacing:0.05em;color:var(--text-lt);margin:0;}
.klarna-bar strong{color:var(--text-mid);font-weight:500;}

/* 8. TESTIMONIALS */
.testi-card{padding:44px;background:var(--white);border:1px solid var(--stone);}
.testi-stars{font-size:0.72rem;letter-spacing:3px;color:#B8906A;margin-bottom:20px;display:block;}
.testi-card blockquote{font-family:'Playfair Display',serif;font-size:0.92rem;font-style:italic;font-weight:400;color:var(--text-mid);line-height:1.9;margin-bottom:24px;border-left:none;padding-left:0;}
.testi-name{font-size:0.57rem;font-weight:600;letter-spacing:0.24em;text-transform:uppercase;color:var(--accent);}

/* 9. FOOTER */
.site-footer{background:var(--text);color:var(--cream);padding:88px 0 44px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:64px;border-bottom:1px solid rgba(255,255,255,0.08);margin-bottom:40px;}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:300;letter-spacing:0.3em;text-transform:uppercase;color:var(--cream);text-decoration:none;display:block;margin-bottom:14px;}
.footer-tagline{font-size:0.75rem;font-weight:300;line-height:1.85;color:var(--stone);margin-bottom:28px;max-width:280px;}
.footer-social{display:flex;gap:20px;}
.footer-social a{font-size:0.57rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--stone);text-decoration:none;transition:color 0.2s;}
.footer-social a:hover{color:var(--cream);}
.footer-heading,.footer-col-title{font-size:0.57rem;font-weight:600;letter-spacing:0.28em;text-transform:uppercase;color:var(--stone-mid);margin-bottom:22px;}
.footer-links{list-style:none;}
.footer-links li{margin-bottom:11px;}
.footer-links a{font-size:0.75rem;font-weight:300;color:var(--stone);text-decoration:none;transition:color 0.2s;}
.footer-links a:hover{color:var(--cream);}
.footer-address{font-size:0.75rem;font-weight:300;line-height:1.95;color:var(--stone);}
.footer-address a{color:var(--stone);text-decoration:none;transition:color 0.2s;}
.footer-address a:hover{color:var(--cream);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;}
.footer-copy{font-size:0.6rem;font-weight:300;letter-spacing:0.1em;color:var(--accent);}

/* 10. MOBILE */
@media (max-width:900px){
  :root{--pad-x:24px;--section-pad:80px;}
  .nav-links,.nav-book{display:none;}
  .ham-btn{display:flex;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .klarna-bar{padding:22px 24px;}
  .testi-card{padding:32px 24px;}
}
@media (max-width:560px){
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;gap:14px;text-align:center;}
  .section-pad{padding:72px 0;}
  .section-pad-sm{padding:52px 0;}
}