/* =================================================================
   Noble Blinds Sydney — blinds, curtains & plantation shutters
   Style: clean editorial · ivory / ink / champagne
   ================================================================= */

:root{
  --ink:        #1a1a1a;
  --ink-soft:   #585858;
  --cream:      #f6f1e9;
  --cream-2:    #efe6d8;
  --champagne:  #1a1a1a;
  --champagne-d:#585858;
  --blush:      #e7d4c7;
  --line:       rgba(29,24,19,.16);
  --display: "Raleway", "Helvetica Neue", Arial, sans-serif;
  --sans: "Poppins", "Helvetica Neue", Arial, sans-serif;
  --pad: clamp(1.25rem, 5vw, 6rem);
  --maxw: 1280px;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

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

body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:#fff;
  line-height:1.7;
  letter-spacing:.01em;
  overflow-x:hidden;
  /* subtle paper grain */
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }

h1,h2,h3{ font-family:var(--display); font-weight:300; line-height:1.14; letter-spacing:.005em; }

/* ---------- type helpers ---------- */
.eyebrow,.section-label{
  font-family:var(--sans);
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.34em;
  font-weight:400;
  color:var(--champagne-d);
}
.section-label{ margin-bottom:1.1rem; }
.section-label--light{ color:var(--champagne-d); }
.muted{ color:var(--ink-soft); }

/* =================================================================
   TOP BAR + HEADER  (absolute group, floats over hero)
   ================================================================= */
.site-top{ position:absolute; inset:0 0 auto 0; z-index:100; }

.topbar{
  background:#111; color:#fff; text-align:center; overflow:hidden;
  padding:.62rem 1rem;
  font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; font-weight:300;
}
.topbar-track{ display:block; }
.topbar-text{ white-space:nowrap; }
.topbar-text + .topbar-text{ display:none; }
.topbar a{ color:#fff; border-bottom:1px solid rgba(255,255,255,.45); padding-bottom:1px; }
.topbar a:hover{ border-color:#fff; }

/* mobile: single line, auto left-scroll marquee */
@media (max-width:600px){
  .topbar{ text-align:left; padding-inline:0; }
  .topbar-track{ display:inline-flex; animation:marquee 16s linear infinite; }
  .topbar-text{ padding-right:2.5rem; }
  .topbar-text + .topbar-text{ display:inline-block; }
}
@media (prefers-reduced-motion:reduce){ .topbar-track{ animation:none; } }

.site-header{
  background:#fff; border-bottom:1px solid var(--line);
  padding:1.15rem var(--pad) 1rem;
}
.header-inner{
  position:relative;
  max-width:var(--maxw); margin-inline:auto;
  display:flex; flex-direction:column; align-items:center; gap:.95rem;
}
.brand{ display:inline-block; }
.brand-logo{ height:60px; width:auto; filter:brightness(0); }

.nav{ display:flex; align-items:center; justify-content:center; gap:2.6rem; flex-wrap:wrap; }
.nav a{
  font-size:.74rem; text-transform:uppercase; letter-spacing:.22em; font-weight:400;
  position:relative; padding:.3rem 0; color:var(--ink);
}
.nav a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:var(--champagne); transform:scaleX(0); transform-origin:right;
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
.nav a:hover::after{ transform:scaleX(1); transform-origin:left; }
.nav-cta{ color:var(--champagne-d); }

.nav-toggle{ display:none; position:absolute; right:0; top:50%; transform:translateY(-50%); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:99;
  background:#fff;
  display:flex; flex-direction:column; align-items:center; justify-content:flex-start;
  gap:.3rem; padding:8.5rem 1.25rem 3rem; overflow-y:auto; -webkit-overflow-scrolling:touch;
  opacity:0; visibility:hidden; transform:translateY(-12px);
  transition:opacity .4s ease, transform .4s ease, visibility .4s;
}
.drawer.open{ opacity:1; visibility:visible; transform:none; }
.drawer a{
  font-family:var(--display); font-size:1.85rem; color:var(--ink);
  padding:.6rem 1.5rem; text-align:center; width:100%; max-width:320px;
}
.drawer a:active{ color:var(--ink-soft); }
.drawer a:hover{ color:var(--champagne-d); font-style:italic; }

/* =================================================================
   PLACEHOLDER (image stand-in)
   ================================================================= */
.ph{
  position:relative; overflow:hidden;
  background:
    linear-gradient(135deg, var(--cream-2) 0%, var(--blush) 55%, var(--cream-2) 100%);
  border:1px solid var(--line);
}
.ph::before{
  content:""; position:absolute; inset:14px; border:1px solid rgba(255,255,255,.45);
}
.ph::after{
  content:"NOBLE BLINDS SYDNEY";
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--sans); font-size:.6rem; letter-spacing:.4em; text-transform:uppercase;
  color:rgba(29,24,19,.32);
}

/* =================================================================
   HERO
   ================================================================= */
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:8rem var(--pad) 4rem;
  color:#fff; isolation:isolate;
}
.hero-slider{ position:absolute; inset:0; z-index:-2; }
.hero-slide{
  position:absolute; inset:0;
  background-image:url('../assets/images/hero/hero1.png');
  background-size:cover; background-position:center;
  opacity:0; transition:opacity 1.6s ease-in-out;
}
.hero-slide.is-active{ opacity:1; }
.hero-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; display:none; }
@media (max-width:600px){
  .hero-slide{ display:none; }
  .hero-video{ display:block; }
}
.hero::after{   /* dark veil for legibility */
  content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(20,15,12,.55), rgba(20,15,12,.25) 45%, rgba(20,15,12,.6));
}
.hero-content{ max-width:880px; margin-inline:auto; width:100%; text-align:center; }
.hero .eyebrow{ color:var(--blush); margin-bottom:1.6rem; }
.hero-title{
  font-size:clamp(2.8rem, 8vw, 6.4rem);
  letter-spacing:-.02em;
}
.hero-title span{ display:block; }
.hero-title em{ color:#fff; }
.hero-sub{
  max-width:42ch; margin:1.8rem auto 0; font-size:1.05rem; color:rgba(255,255,255,.86);
}
.hero-content .btn{ margin-top:2.2rem; }
.hero-actions{ margin-top:2.6rem; display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.hero-tag{
  position:absolute; left:var(--pad); bottom:2rem;
  font-size:.68rem; letter-spacing:.3em; text-transform:uppercase; color:var(--blush);
  display:flex; align-items:center; gap:.8rem;
}
.hero-tag::before{ content:""; width:46px; height:1px; background:var(--blush); }

/* =================================================================
   BUTTONS
   ================================================================= */
.btn{
  display:inline-block; font-family:var(--sans); font-size:.74rem; font-weight:400;
  text-transform:uppercase; letter-spacing:.22em;
  padding:1.05em 2.2em; border:1px solid currentColor; cursor:pointer;
  transition:background .4s ease, color .4s ease, transform .4s ease;
}
.btn:hover{ transform:translateY(-2px); }
.btn--solid{ background:#fff; color:var(--ink); border-color:#fff; }
.btn--solid:hover{ background:transparent; color:#fff; }
.btn--ghost{ color:#fff; }
.btn--ghost:hover{ background:#fff; color:var(--ink); }
.btn--light{ background:var(--ink); border-color:var(--ink); color:#fff; }
.btn--light:hover{ background:transparent; color:var(--ink); }

/* =================================================================
   INTRO
   ================================================================= */
.intro{ padding:clamp(4rem,9vw,7rem) var(--pad) clamp(5rem,12vw,9rem); }
.intro-grid{
  max-width:var(--maxw); margin-inline:auto;
  display:grid; grid-template-columns:1fr auto; gap:clamp(2.5rem,6vw,6rem); align-items:center;
}
.intro-copy{ padding:0; }
.intro h2{ font-size:clamp(2.2rem,4.5vw,3.6rem); margin:.2rem 0 1.4rem; }
.lede{ font-size:1.08rem; color:var(--ink-soft); max-width:48ch; }
.intro-text{ margin-top:1.3rem; color:var(--ink-soft); max-width:52ch; }
.intro-note{ margin-top:2.2rem; font-size:.72rem; text-transform:uppercase; letter-spacing:.24em; color:var(--ink); }
.price-list{ list-style:none; display:flex; gap:3rem; margin-top:2.4rem; }
.price-list li{ display:flex; flex-direction:column; gap:.2rem; }
.price{ font-family:var(--display); font-size:2rem; color:var(--champagne-d); }
.price-label{ font-size:.7rem; text-transform:uppercase; letter-spacing:.22em; color:var(--ink-soft); }
.intro-figure{ width:clamp(240px,30vw,420px); aspect-ratio:1/1; border-radius:50%; overflow:hidden; margin:0; }
.intro-figure img{ width:100%; height:100%; object-fit:cover; object-position:center 35%; display:block; }
.ph--tall{ aspect-ratio:4/5; }

/* =================================================================
   STATEMENT
   ================================================================= */
.statement{
  background:#fff; color:var(--ink);
  border-bottom:1px solid var(--line);
  padding:clamp(2.6rem,6vw,4.5rem) var(--pad);
  text-align:center;
}
.statement p{
  max-width:var(--maxw); margin-inline:auto;
  font-family:var(--display); font-style:italic; font-weight:300;
  font-size:clamp(1.02rem,1.8vw,1.25rem); line-height:1.6;
}
.statement em{ color:var(--champagne); font-style:italic; }

/* =================================================================
   BLOCK HEADINGS
   ================================================================= */
.block-head{ max-width:var(--maxw); margin:0 auto clamp(2.5rem,5vw,4rem); text-align:center; }
.block-head h2{ font-size:clamp(2.2rem,5vw,3.8rem); }
.block-head .muted{ margin-top:1rem; }

/* =================================================================
   COLLECTION GALLERY
   ================================================================= */
.collection{ padding:clamp(5rem,12vw,9rem) var(--pad); }
.gallery{
  max-width:var(--maxw); margin-inline:auto;
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem;
}
.gallery-item{ overflow:hidden; border:1px solid var(--line); aspect-ratio:16/9; margin:0; }
.gallery-item img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.2s cubic-bezier(.22,1,.36,1); }
.gallery-item:hover img{ transform:scale(1.04); }
.gallery-item:has(figcaption){ aspect-ratio:auto; overflow:visible; border:none; align-self:start; }
.gallery-item:has(figcaption) img{ height:auto; aspect-ratio:16/9; border:1px solid var(--line); }
.gallery-item:has(figcaption):hover img{ transform:none; }
.gallery-item figcaption{ margin-top:.7rem; font-size:.74rem; text-transform:uppercase; letter-spacing:.14em; color:var(--ink); text-align:center; }

/* =================================================================
   DESIGNERS
   ================================================================= */
.designers{ padding:clamp(5rem,12vw,9rem) var(--pad); background:#fff; }
.designer-row{
  max-width:var(--maxw); margin-inline:auto;
  display:grid; grid-template-columns:repeat(5,1fr); gap:1.2rem;
}
.ph--logo{ aspect-ratio:3/2; }
.ph--logo::after{ font-size:.5rem; letter-spacing:.3em; }

/* =================================================================
   EXPERIENCE
   ================================================================= */
.experience{
  max-width:var(--maxw); margin-inline:auto;
  padding:clamp(5rem,12vw,9rem) var(--pad);
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem);
}
.exp-card{ position:relative; padding-top:2.4rem; border-top:1px solid var(--line); }
.exp-no{
  font-family:var(--display); font-size:1.1rem; color:var(--champagne);
  letter-spacing:.1em;
}
.exp-card h3{ font-size:clamp(1.7rem,3vw,2.4rem); margin:.6rem 0 1rem; }
.exp-card p{ color:var(--ink-soft); max-width:46ch; }

/* =================================================================
   CTA
   ================================================================= */
.cta{
  position:relative; color:var(--ink);
  padding:clamp(6rem,14vw,11rem) var(--pad); text-align:center;
  background:#fff; border-top:1px solid var(--line);
}
.cta-inner{ max-width:760px; margin-inline:auto; }
.cta h2{ font-size:clamp(2.4rem,6vw,4.4rem); margin:1rem 0 1.4rem; }
.cta h2 em{ color:var(--champagne); }
.cta-sub{ color:var(--ink-soft); max-width:46ch; margin:0 auto 2.4rem; }
.cta-contact{ margin-top:2.4rem; display:flex; gap:1rem; justify-content:center; align-items:center;
  font-size:.85rem; letter-spacing:.12em; color:var(--ink-soft); flex-wrap:wrap; }
.cta-contact a{ position:relative; }
.cta-contact a:hover{ color:var(--ink); }
.cta-contact .dot{ opacity:.5; }

/* =================================================================
   FOOTER
   ================================================================= */
.site-footer{ background:var(--ink); color:var(--cream); padding:clamp(3.5rem,8vw,5.5rem) var(--pad); }
.footer-inner{ max-width:var(--maxw); margin-inline:auto; text-align:center; display:flex; flex-direction:column; align-items:center; gap:1.2rem; }
.footer-logo{ height:54px; width:auto; filter:brightness(0) invert(1); opacity:.92; }
.footer-tag{ font-size:.72rem; text-transform:uppercase; letter-spacing:.3em; color:var(--blush); }
.footer-nav{ display:flex; gap:2rem; flex-wrap:wrap; justify-content:center; margin-top:.4rem; }
.footer-nav a{ font-size:.74rem; text-transform:uppercase; letter-spacing:.2em; color:rgba(246,241,233,.8); }
.footer-nav a:hover{ color:#fff; }
.footer-social{ display:flex; gap:1.8rem; flex-wrap:wrap; justify-content:center; margin-top:.6rem; }
.footer-social a{ display:inline-flex; align-items:center; gap:.55rem; font-size:.72rem; letter-spacing:.08em; color:rgba(246,241,233,.8); }
.footer-social a:hover{ color:#fff; }
.footer-social svg{ width:16px; height:16px; }
.copyright{ font-size:.7rem; letter-spacing:.1em; color:rgba(246,241,233,.45); margin-top:1rem; }

/* =================================================================
   SCROLL REVEAL
   ================================================================= */
.reveal{
  opacity:0; transform:translateY(26px);
  transition:opacity 1s cubic-bezier(.22,1,.36,1), transform 1s cubic-bezier(.22,1,.36,1);
  transition-delay:var(--d,0ms);
}
.reveal.is-visible{ opacity:1; transform:none; }

/* hero load animation regardless of observer */
.hero .reveal{ transition-duration:1.1s; }
.hero .reveal:nth-child(1){ --d:.1s; }
.hero-title .reveal:nth-child(1){ --d:.2s; }
.hero-title .reveal:nth-child(2){ --d:.35s; }
.hero-title .reveal:nth-child(3){ --d:.5s; }

@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width:900px){
  .intro-grid{ grid-template-columns:1fr; }
  .intro-copy{ padding-top:2.5rem; }
  .intro-figure{ order:-1; margin-inline:auto; }
  .experience{ grid-template-columns:1fr; }
  .designer-row{ grid-template-columns:repeat(3,1fr); }
}

@media (max-width:768px){
  .nav{ display:none; }
  .nav-toggle{
    display:flex; flex-direction:column; gap:6px; width:44px; height:44px;
    align-items:center; justify-content:center; cursor:pointer;
    background:#fff; border:1px solid var(--line); border-radius:50%;
    box-shadow:0 1px 4px rgba(0,0,0,.08);
  }
  .nav-toggle span{ display:block; width:20px; height:1.5px; background:var(--ink); transition:transform .35s ease, opacity .35s ease; }
  .nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(3.75px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] span:nth-child(2){ transform:translateY(-3.75px) rotate(-45deg); }
  .brand-logo{ height:50px; }
}

@media (max-width:720px){
  .gallery{ grid-template-columns:1fr 1fr; gap:1rem; }
  .gallery .ph:nth-child(2),.gallery .ph:nth-child(5){ transform:none; }
  .price-list{ gap:2rem; }
  .hero-tag{ display:none; }
}

@media (max-width:440px){
  .gallery{ grid-template-columns:1fr; }
  .designer-row{ grid-template-columns:repeat(2,1fr); }
  .hero-actions{ flex-direction:column; }
  .btn{ width:100%; text-align:center; }
}

/* =================================================================
   BUTTON — dark solid (for white sections)
   ================================================================= */
.btn--dark{ background:var(--ink); border-color:var(--ink); color:#fff; }
.btn--dark:hover{ background:transparent; color:var(--ink); }

/* =================================================================
   MARQUEE
   ================================================================= */
.marquee{ overflow:hidden; border-block:1px solid var(--line); padding:1.15rem 0; white-space:nowrap; }
.marquee-track{ display:inline-flex; width:max-content; animation:marquee 30s linear infinite; }
.marquee-track span{
  font-family:var(--display); font-weight:300;
  font-size:clamp(1.35rem,3vw,2.1rem); letter-spacing:.05em;
  text-transform:uppercase; color:var(--ink);
}
.marquee:hover .marquee-track{ animation-play-state:paused; }
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .marquee-track{ animation:none; } }

/* =================================================================
   AESTHETIC
   ================================================================= */
.aesthetic{ padding:clamp(5rem,12vw,9rem) var(--pad); border-top:1px solid var(--line); }
.treatments{
  max-width:820px; margin-inline:auto;
  display:flex; flex-direction:column; gap:.8rem;
}
.treatment{
  display:flex; flex-wrap:wrap; align-items:baseline; gap:.35rem 1.4rem;
  padding:1.05rem 1.4rem; border:1px solid var(--line);
}
.treatment h3{ font-size:1.12rem; margin:0; flex:0 0 auto; }
.treatment p{ color:var(--ink-soft); font-size:.9rem; margin:0; flex:1 1 260px; }
.treatment-tag{
  display:inline-block; flex:0 0 auto; padding:.3em 1em;
  font-size:.6rem; text-transform:uppercase; letter-spacing:.2em;
  border:1px solid var(--line); color:var(--ink);
}
.aesthetic-cta{ text-align:center; margin-top:clamp(2.5rem,5vw,3.5rem); }
.aesthetic-note{ margin-top:1rem; font-size:.78rem; color:var(--ink-soft); }

/* =================================================================
   REVIEWS
   ================================================================= */
.reviews{ padding:clamp(5rem,12vw,9rem) var(--pad); border-top:1px solid var(--line); }
.rating{ margin-top:.8rem; font-size:1.1rem; letter-spacing:.25em; color:var(--ink); }
.rating span{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); }
.reviews-carousel{ position:relative; max-width:var(--maxw); margin-inline:auto; padding:0 clamp(2.9rem,4vw,3.4rem); }
.review-grid{
  display:flex; gap:1.4rem; overflow-x:auto; scroll-behavior:smooth;
  scroll-snap-type:x mandatory; padding-bottom:.4rem;
  scrollbar-width:none; -ms-overflow-style:none;
}
.review-grid::-webkit-scrollbar{ display:none; }
.review{
  flex:0 0 clamp(280px,32%,380px); scroll-snap-align:start;
  padding:1.7rem 1.7rem; border:1px solid var(--line); display:flex; flex-direction:column; gap:.8rem;
}
.rev-arrow{
  position:absolute; top:50%; transform:translateY(-50%); z-index:3;
  width:44px; height:44px; border-radius:50%; border:1px solid var(--line);
  background:#fff; color:var(--ink); font-size:1.5rem; line-height:0; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .3s ease, color .3s ease, border-color .3s ease;
}
.rev-arrow:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }
.rev-prev{ left:0; }
.rev-next{ right:0; }
.review .stars{ color:var(--ink); letter-spacing:.18em; font-size:.8rem; }
.review blockquote{ font-family:var(--display); font-weight:300; font-size:1.04rem; line-height:1.5; color:var(--ink); }
.review figcaption{ margin-top:auto; font-size:.72rem; text-transform:uppercase; letter-spacing:.16em; color:var(--ink); }
.review figcaption span{ color:var(--ink-soft); }

/* =================================================================
   FAQ
   ================================================================= */
.faq{ padding:clamp(5rem,12vw,9rem) var(--pad); border-top:1px solid var(--line); }
.faq-list{ max-width:760px; margin-inline:auto; border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item summary{
  list-style:none; cursor:pointer; padding:1.4rem 2.4rem 1.4rem 0; position:relative;
  font-size:1.12rem; color:var(--ink);
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content:"+"; position:absolute; right:.2rem; top:1.3rem;
  font-size:1.3rem; font-weight:300;
}
.faq-item[open] summary::after{ content:"\2013"; }
.faq-item p{ padding:0 0 1.5rem; color:var(--ink-soft); max-width:60ch; }

/* =================================================================
   JOURNAL
   ================================================================= */
.journal{ padding:clamp(5rem,12vw,9rem) var(--pad); border-top:1px solid var(--line); }
.post-grid{
  max-width:var(--maxw); margin-inline:auto;
  display:grid; grid-template-columns:repeat(3,1fr); gap:2rem;
}
.post{ display:flex; flex-direction:column; }
.post-media{ display:block; overflow:hidden; aspect-ratio:3/2; border:1px solid var(--line); }
.post-media img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.2s cubic-bezier(.22,1,.36,1); }
.post-media:hover img{ transform:scale(1.05); }
.post-body{ padding-top:1.3rem; }
.post-meta{ font-size:.66rem; text-transform:uppercase; letter-spacing:.2em; color:var(--champagne-d); }
.post h3{ font-size:1.4rem; margin:.6rem 0 .7rem; line-height:1.22; }
.post h3 a:hover{ color:var(--ink-soft); }
.post-excerpt{ color:var(--ink-soft); font-size:.95rem; }
.post-link{
  display:inline-block; margin-top:1rem; font-size:.7rem; text-transform:uppercase; letter-spacing:.2em;
  border-bottom:1px solid var(--line); padding-bottom:2px;
}
.post-link:hover{ border-color:var(--ink); }

/* =================================================================
   WELCOME MODAL
   ================================================================= */
.modal{
  position:fixed; inset:0; z-index:200;
  display:flex; align-items:center; justify-content:center; padding:1.5rem;
  opacity:0; visibility:hidden; transition:opacity .45s ease, visibility .45s;
}
.modal.open{ opacity:1; visibility:visible; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(20,15,12,.55); backdrop-filter:blur(2px); }
.modal-box{
  position:relative; z-index:1; background:#fff; width:100%; max-width:440px;
  max-height:calc(100dvh - 3rem); overflow-y:auto;
  padding:clamp(2.4rem,5vw,3.4rem); text-align:center; border:1px solid var(--line);
  transform:translateY(14px) scale(.98); transition:transform .5s cubic-bezier(.22,1,.36,1);
}
.modal.open .modal-box{ transform:none; }
.modal-links{ display:flex; gap:1.5rem; justify-content:center; flex-wrap:wrap; margin-top:1.2rem; }
.modal-dismiss{
  background:none; border:none; cursor:pointer; padding:0;
  font-size:.72rem; letter-spacing:.08em; color:var(--ink-soft);
  text-decoration:underline; text-underline-offset:3px;
}
.modal-dismiss:hover{ color:var(--ink); }
.modal-eyebrow{ font-size:.66rem; text-transform:uppercase; letter-spacing:.3em; color:var(--champagne-d); }
.modal-title{ font-size:clamp(1.45rem,4vw,1.75rem); margin:.85rem 0 1rem; line-height:1.2; }
.modal-text{ color:var(--ink-soft); font-size:.95rem; margin-bottom:1.8rem; }

/* =================================================================
   ARTICLE (blog post page)
   ================================================================= */
.inner-page .site-top{ position:static; }
.article{ max-width:1080px; margin-inline:auto; padding:clamp(2.5rem,6vw,4.5rem) var(--pad) clamp(4rem,10vw,7rem); }
.article-head{ text-align:center; margin-bottom:2.6rem; max-width:760px; margin-inline:auto; }
.article-meta{ font-size:.66rem; text-transform:uppercase; letter-spacing:.2em; color:var(--champagne-d); }
.article-title{ font-size:clamp(2.2rem,5.5vw,3.6rem); margin:1rem 0 1.1rem; line-height:1.08; }
.article-sub{ color:var(--ink-soft); max-width:52ch; margin-inline:auto; }
.article-figure{ margin:0 0 2.6rem; }
.article-figure img{ width:100%; aspect-ratio:16/9; object-fit:cover; border:1px solid var(--line); display:block; }
.article-body{ font-size:1.06rem; line-height:1.85; max-width:760px; margin-inline:auto; }
.article-body h2{ font-size:clamp(1.5rem,3vw,2rem); margin:2.4rem 0 .8rem; }
.article-body p{ margin-bottom:1.25rem; color:var(--ink-soft); }
.article-body ul{ margin:0 0 1.25rem 1.3rem; color:var(--ink-soft); }
.article-body li{ margin-bottom:.5rem; }
.article-body strong{ color:var(--ink); font-weight:500; }
.article-back{ display:inline-block; margin-top:2.6rem; font-size:.7rem; text-transform:uppercase; letter-spacing:.2em; border-bottom:1px solid var(--line); padding-bottom:2px; }
.article-back:hover{ border-color:var(--ink); }

/* =================================================================
   CONTACT / ENQUIRY
   ================================================================= */
.contact{ padding:clamp(5rem,12vw,9rem) var(--pad); border-top:1px solid var(--line); }
.contact-grid{
  max-width:var(--maxw); margin-inline:auto;
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,6vw,5rem); align-items:start;
}
.contact-intro h2{ font-size:clamp(2.2rem,5vw,3.6rem); margin:.4rem 0 1.2rem; }
.contact-intro > p{ color:var(--ink-soft); max-width:42ch; }
.contact-details{ list-style:none; margin-top:2.4rem; display:flex; flex-direction:column; gap:0; }
.contact-details li{ display:flex; flex-direction:column; gap:.35rem; border-bottom:1px solid var(--line); padding:1rem 0; }
.contact-details span{ font-size:.66rem; text-transform:uppercase; letter-spacing:.2em; color:var(--ink-soft); }
.contact-details a:hover{ color:var(--ink-soft); }

.contact-form{ display:flex; flex-direction:column; gap:1.2rem; }
.field{ display:flex; flex-direction:column; gap:.5rem; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.field label{ font-size:.66rem; text-transform:uppercase; letter-spacing:.2em; color:var(--ink-soft); }
.field input,.field select,.field textarea{
  font-family:var(--sans); font-size:.95rem; color:var(--ink);
  padding:.85em 1em; border:1px solid var(--line); background:#fff; border-radius:0;
  transition:border-color .3s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--ink); }
.field textarea{ resize:vertical; }
.contact-form .btn{ margin-top:.6rem; align-self:start; cursor:pointer; }

/* ---- new sections: responsive ---- */
@media (max-width:900px){
  .review-grid{ grid-template-columns:1fr 1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .post-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .treatments{ grid-template-columns:1fr; }
  .review-grid{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
}

/* mobile: keep reviews / treatments / contact from being cut off */
@media (max-width:600px){
  /* reviews carousel: full-width card, arrows centered below */
  .reviews-carousel{ display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:1rem; padding:0; }
  .review-grid{ flex:0 0 100%; }
  .review{ flex:0 0 100%; padding:1.7rem 1.6rem; }
  .review blockquote{ font-size:1.08rem; }
  .rev-arrow{ order:1; position:static; transform:none; width:42px; height:42px; font-size:1.35rem; }
  /* aesthetic treatments: stack name / desc / tag */
  .treatment{ flex-direction:column; align-items:flex-start; gap:.35rem; padding:1rem 1.15rem; }
  .treatment p{ flex-basis:auto; }
  /* contact: wrap long email, no horizontal overflow */
  .contact-details a{ overflow-wrap:anywhere; }
  /* journal: one post per row */
  .post-grid{ grid-template-columns:1fr; }
}
