/* ==========================================================
   Aheer Curtains - Shared Stylesheet
   Modern, sleek, luxury aesthetic
   ========================================================== */

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

:root{
  --cream:#FAF7F2;
  --warm:#F0EAE0;
  --sand:#D4C5AF;
  --bronze:#8B6A3E;
  --dark:#1C1A17;
  --mid:#4A3F32;
  --accent:#C4923E;
  --soft:#E8DDC9;
  --line:rgba(28,26,23,0.08);
}

html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--cream);color:var(--dark);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased}

img{max-width:100%;display:block}
a{color:inherit}

/* ---------- NAVIGATION ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.1rem 4rem;display:flex;align-items:center;justify-content:space-between;background:rgba(250,247,242,0.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--sand);transition:all 0.3s}

.logo-wrap{display:flex;align-items:center;gap:0.7rem;text-decoration:none}

/* --- LOGO IMAGE -----------------------------------------------------
   Displays /images/logo.svg as a background image, sized to a fixed
   height with auto width so any aspect ratio (square icon, horizontal
   wordmark, stacked logo) renders correctly without distortion.
   The "A" placeholder character inside the span is hidden via
   text-indent so no HTML changes are required.
-------------------------------------------------------------------- */
.logo-img{
  display:inline-block;
  height:50px;             /* tweak this to make the logo bigger/smaller */
  width:auto;
  min-width:50px;
  max-width:240px;
  aspect-ratio:auto;
  background:url('../images/logo.svg') left center / contain no-repeat;
  /* hide the "A" placeholder character */
  text-indent:-9999px;
  overflow:hidden;
  white-space:nowrap;
  /* clear the old dark-square styling */
  border-radius:0;
  color:transparent;
}
/* In the dark footer, swap to a white version if you create one */
.footer-brand .logo-img{
  background-image:url('../images/logo.svg');
  /* If your logo is dark and disappears on the black footer, add a
     light version as images/logo-light.svg and uncomment:        */
  /* background-image:url('../images/logo-light.svg');             */
}

.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-text .brand{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:500;letter-spacing:0.04em;color:var(--dark)}
.logo-text .tag{font-size:0.6rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--mid);margin-top:3px}

/* If your logo SVG already contains the brand name "Aheer Curtains",
   uncomment the rule below to hide the duplicate text label.       */
/*
.logo-text{display:none}
*/

.nav-links{display:flex;gap:2.2rem;list-style:none;align-items:center}
.nav-links a{font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase;text-decoration:none;color:var(--mid);transition:color 0.3s;position:relative;padding:0.4rem 0}
.nav-links a:hover,.nav-links a.active{color:var(--accent)}
.nav-links a.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:1px;background:var(--accent)}

.nav-cta{font-size:0.78rem;letter-spacing:0.14em;text-transform:uppercase;padding:0.65rem 1.6rem;border:1px solid var(--bronze);color:var(--bronze);text-decoration:none;transition:all 0.3s}
.nav-cta:hover{background:var(--bronze);color:var(--cream)}

.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:0.5rem;color:var(--dark)}
.menu-toggle span{display:block;width:26px;height:2px;background:var(--dark);margin:5px 0;transition:all 0.3s}

/* ---------- HERO ---------- */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;padding-top:80px}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:5rem 4rem 5rem 5rem}
.hero-eyebrow{font-size:0.72rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.6rem,5vw,5.5rem);font-weight:300;line-height:1.08;color:var(--dark);margin-bottom:2rem}
.hero-title em{font-style:italic;color:var(--bronze)}
.hero-desc{font-size:0.98rem;font-weight:300;line-height:1.85;color:var(--mid);max-width:440px;margin-bottom:2.5rem}
.hero-btns{display:flex;gap:1.2rem;align-items:center;flex-wrap:wrap}

.btn-primary{padding:0.95rem 2.4rem;background:var(--dark);color:var(--cream);font-family:'Jost',sans-serif;font-size:0.78rem;letter-spacing:0.16em;text-transform:uppercase;text-decoration:none;transition:all 0.3s;display:inline-block;border:none;cursor:pointer}
.btn-primary:hover{background:var(--bronze)}

.btn-secondary{font-size:0.78rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--mid);text-decoration:none;border-bottom:1px solid var(--sand);padding-bottom:3px;transition:all 0.3s}
.btn-secondary:hover{color:var(--accent);border-color:var(--accent)}

.btn-outline{padding:0.95rem 2.4rem;background:transparent;color:var(--bronze);border:1px solid var(--bronze);font-family:'Jost',sans-serif;font-size:0.78rem;letter-spacing:0.16em;text-transform:uppercase;text-decoration:none;transition:all 0.3s;display:inline-block;cursor:pointer}
.btn-outline:hover{background:var(--bronze);color:var(--cream)}

.hero-right{position:relative;overflow:hidden;background:var(--warm)}
.hero-fabric{width:100%;height:100%;background:linear-gradient(160deg,#C8B89A 0%,#A0876A 40%,#7A6350 70%,#5C4A38 100%);position:relative}
.hero-fabric::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(92deg,transparent,transparent 28px,rgba(255,255,255,0.04) 28px,rgba(255,255,255,0.04) 30px)}
.hero-fabric::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(180deg,transparent,transparent 40px,rgba(0,0,0,0.03) 40px,rgba(0,0,0,0.04) 42px)}
.hero-badge{position:absolute;bottom:3rem;left:3rem;background:var(--cream);padding:1.5rem 2rem;box-shadow:0 8px 30px rgba(0,0,0,0.08)}
.hero-badge .num{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;color:var(--dark)}
.hero-badge .lbl{font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--mid)}

/* ---------- PAGE HERO (sub-pages) ---------- */
.page-hero{padding:9rem 5rem 5rem;background:var(--warm);text-align:center;border-bottom:1px solid var(--sand)}
.page-hero .eyebrow{font-size:0.72rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.page-hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,4.5vw,4rem);font-weight:300;color:var(--dark);line-height:1.15;margin-bottom:1.2rem}
.page-hero h1 em{font-style:italic;color:var(--bronze)}
.page-hero p{font-size:1rem;font-weight:300;line-height:1.8;color:var(--mid);max-width:620px;margin:0 auto}
.breadcrumb{margin-top:2rem;font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--mid)}
.breadcrumb a{color:var(--mid);text-decoration:none;transition:color 0.3s}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{margin:0 0.7rem;color:var(--sand)}

/* ---------- MARQUEE ---------- */
.marquee-wrap{overflow:hidden;border-top:1px solid var(--sand);border-bottom:1px solid var(--sand);padding:1rem 0;background:var(--warm)}
.marquee-track{display:flex;gap:0;white-space:nowrap;animation:scroll 28s linear infinite}
.marquee-item{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-style:italic;color:var(--bronze);padding:0 2.5rem}
.marquee-dot{color:var(--sand)}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ---------- INTRO / SECTIONS ---------- */
.intro{padding:6rem 5rem;display:grid;grid-template-columns:1fr 1.5fr;gap:5rem;align-items:center}
.intro-left h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,3vw,3.2rem);font-weight:300;line-height:1.2;color:var(--dark)}
.intro-left h2 em{font-style:italic;color:var(--bronze)}
.intro-right p{font-size:0.97rem;font-weight:300;line-height:1.9;color:var(--mid);margin-bottom:1.5rem}
.stat-row{display:flex;gap:3rem;margin-top:2.5rem;padding-top:2.5rem;border-top:1px solid var(--sand);flex-wrap:wrap}
.stat .n{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;color:var(--dark)}
.stat .l{font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--mid)}

.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;flex-wrap:wrap;gap:1rem}
.section-tag{font-size:0.72rem;letter-spacing:0.24em;text-transform:uppercase;color:var(--accent);margin-bottom:0.5rem}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,2.7vw,3rem);font-weight:300;color:var(--dark);line-height:1.2}
.section-title em{font-style:italic;color:var(--bronze)}
.section-link{font-size:0.78rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--mid);text-decoration:none;border-bottom:1px solid var(--sand);padding-bottom:2px;transition:all 0.3s}
.section-link:hover{color:var(--accent);border-color:var(--accent)}

/* ---------- COLLECTIONS / CARDS ---------- */
.collections{padding:2rem 5rem 6rem}
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.card{cursor:pointer;position:relative;overflow:hidden;text-decoration:none;color:inherit;display:block}
.card-img{aspect-ratio:3/4;position:relative;overflow:hidden;background:var(--warm)}
.card-swatch{width:100%;height:100%;transition:transform 0.6s ease;position:relative}
.card:hover .card-swatch{transform:scale(1.04)}

.swatch-linen{background:linear-gradient(135deg,#E8DDD0 0%,#D4C4B0 50%,#C0AE98 100%)}
.swatch-velvet{background:linear-gradient(135deg,#5C4A38 0%,#3A2A1C 50%,#251812 100%)}
.swatch-sheer{background:linear-gradient(135deg,#F2EEE8 0%,#E8E2D8 50%,#DDD6C8 100%)}
.swatch-roller{background:linear-gradient(135deg,#A99877 0%,#8B7A5E 50%,#6B5B42 100%)}
.swatch-roman{background:linear-gradient(135deg,#C9B79A 0%,#A89070 50%,#7E6648 100%)}
.swatch-venetian{background:linear-gradient(180deg,#D4C4A8 0%,#D4C4A8 8%,#A89070 9%,#A89070 14%,#D4C4A8 15%,#D4C4A8 23%,#A89070 24%,#A89070 29%,#D4C4A8 30%,#D4C4A8 38%,#A89070 39%,#A89070 44%,#D4C4A8 45%,#D4C4A8 53%,#A89070 54%,#A89070 59%,#D4C4A8 60%,#D4C4A8 68%,#A89070 69%,#A89070 74%,#D4C4A8 75%,#D4C4A8 83%,#A89070 84%,#A89070 89%,#D4C4A8 90%)}
.swatch-motorised{background:linear-gradient(135deg,#2A2520 0%,#1C1A17 50%,#0F0E0C 100%)}
.swatch-shutter{background:linear-gradient(180deg,#F5EDE0 0%,#F5EDE0 12%,#D4C4A8 13%,#D4C4A8 18%,#F5EDE0 19%,#F5EDE0 30%,#D4C4A8 31%,#D4C4A8 36%,#F5EDE0 37%,#F5EDE0 48%,#D4C4A8 49%,#D4C4A8 54%,#F5EDE0 55%,#F5EDE0 66%,#D4C4A8 67%,#D4C4A8 72%,#F5EDE0 73%,#F5EDE0 84%,#D4C4A8 85%,#D4C4A8 90%,#F5EDE0 91%)}
.swatch-blockout{background:linear-gradient(135deg,#3A332A 0%,#251F18 50%,#15110C 100%)}

.card-swatch::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(92deg,transparent,transparent 22px,rgba(255,255,255,0.05) 22px,rgba(255,255,255,0.05) 24px)}

.card-tag{position:absolute;top:1rem;left:1rem;background:var(--cream);font-size:0.65rem;letter-spacing:0.16em;text-transform:uppercase;padding:0.4rem 0.85rem;color:var(--mid);z-index:2}
.card-body{padding:1.2rem 0}
.card-name{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;color:var(--dark);margin-bottom:0.3rem}
.card-desc{font-size:0.85rem;color:var(--mid);font-weight:300;line-height:1.6}

/* ---------- PROCESS ---------- */
.process{padding:6rem 5rem;background:var(--dark);color:var(--cream)}
.process .section-tag{color:var(--accent)}
.process .section-title{color:var(--cream)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:4rem}
.step{padding:2.5rem 2rem;border:1px solid rgba(255,255,255,0.1);transition:all 0.3s}
.step:hover{border-color:var(--accent);transform:translateY(-4px)}
.step-num{font-family:'Cormorant Garamond',serif;font-size:3.5rem;font-weight:300;color:rgba(196,146,62,0.4);line-height:1;margin-bottom:1.5rem}
.step h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;margin-bottom:1rem;color:var(--cream)}
.step p{font-size:0.85rem;font-weight:300;line-height:1.8;color:rgba(250,247,242,0.65)}

/* ---------- TESTIMONIALS ---------- */
.testimonials{padding:6rem 5rem;background:var(--warm)}
.testimonials .section-tag{color:var(--accent)}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3.5rem}
.test-card{background:var(--cream);padding:2.5rem;border-bottom:3px solid var(--sand);transition:all 0.3s}
.test-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.stars{color:var(--accent);font-size:0.9rem;letter-spacing:2px;margin-bottom:1.2rem}
.test-card blockquote{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-style:italic;font-weight:300;line-height:1.7;color:var(--dark);margin-bottom:1.5rem}
.test-author{font-size:0.75rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--mid)}
.test-author span{display:block;color:var(--accent);margin-top:0.3rem;font-size:0.7rem}

/* ---------- CTA BANNER ---------- */
.cta-banner{padding:7rem 5rem;text-align:center;background:var(--cream);border-top:1px solid var(--sand)}
.cta-banner h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,4vw,4rem);font-weight:300;color:var(--dark);line-height:1.2;margin-bottom:1.5rem}
.cta-banner h2 em{font-style:italic;color:var(--bronze)}
.cta-banner p{font-size:0.97rem;font-weight:300;line-height:1.8;color:var(--mid);max-width:540px;margin:0 auto 3rem}
.cta-btns{display:flex;gap:1.2rem;justify-content:center;align-items:center;flex-wrap:wrap}

/* ---------- FOOTER ---------- */
footer{background:var(--dark);color:var(--cream);padding:5rem 5rem 2rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:4rem;margin-bottom:4rem}
.footer-brand .logo-wrap{margin-bottom:1.4rem}
.footer-brand .logo-text .brand{color:var(--cream)}
.footer-brand .logo-text .tag{color:rgba(250,247,242,0.5)}
.footer-brand p{font-size:0.87rem;font-weight:300;line-height:1.85;color:rgba(250,247,242,0.6);max-width:280px}
.footer-col h4{font-size:0.72rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(250,247,242,0.45);margin-bottom:1.5rem}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:0.7rem}
.footer-col ul li a{font-size:0.87rem;font-weight:300;color:rgba(250,247,242,0.72);text-decoration:none;transition:color 0.3s}
.footer-col ul li a:hover{color:var(--accent)}
.footer-col p{font-size:0.87rem;font-weight:300;color:rgba(250,247,242,0.72);margin-bottom:0.6rem;line-height:1.6}
.footer-col p a{color:rgba(250,247,242,0.72);text-decoration:none}
.footer-col p a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:0.78rem;color:rgba(250,247,242,0.4)}

/* ---------- FORMS ---------- */
.form-section{padding:6rem 5rem;display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;max-width:1400px;margin:0 auto}
.form-info h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,2.8vw,2.6rem);font-weight:300;color:var(--dark);line-height:1.2;margin-bottom:1.5rem}
.form-info h2 em{font-style:italic;color:var(--bronze)}
.form-info p{font-size:0.97rem;font-weight:300;line-height:1.85;color:var(--mid);margin-bottom:2rem}

.contact-block{padding:1.5rem 0;border-top:1px solid var(--sand)}
.contact-block .lbl{font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent);margin-bottom:0.5rem}
.contact-block .val{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--dark)}
.contact-block .val a{color:var(--dark);text-decoration:none;transition:color 0.3s}
.contact-block .val a:hover{color:var(--accent)}
.contact-block .sub{font-size:0.85rem;font-weight:300;color:var(--mid);margin-top:0.4rem}

.form-card{background:var(--warm);padding:3rem;border-top:3px solid var(--bronze)}
.form-card h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:400;color:var(--dark);margin-bottom:0.5rem}
.form-card .sub{font-size:0.88rem;font-weight:300;color:var(--mid);margin-bottom:2rem}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{margin-bottom:1rem;display:flex;flex-direction:column}
.form-group label{font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--mid);margin-bottom:0.5rem;font-weight:400}
.form-group label .req{color:var(--accent);margin-left:2px}
.form-group input,.form-group select,.form-group textarea{font-family:'Jost',sans-serif;font-size:0.95rem;font-weight:300;padding:0.85rem 1rem;border:1px solid var(--sand);background:var(--cream);color:var(--dark);transition:all 0.3s;width:100%}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--bronze);background:#fff}
.form-group textarea{resize:vertical;min-height:120px;font-family:'Jost',sans-serif}
.form-group select{cursor:pointer}

.honeypot{position:absolute;left:-9999px;top:-9999px;height:0;width:0;visibility:hidden}

.form-checkboxes{display:grid;grid-template-columns:1fr 1fr;gap:0.6rem;margin-bottom:1rem}
.form-check{display:flex;align-items:center;gap:0.6rem;font-size:0.88rem;font-weight:300;color:var(--mid);cursor:pointer}
.form-check input{width:auto;margin:0}

.captcha-row{display:flex;align-items:center;gap:1rem;background:var(--cream);padding:1rem;border:1px solid var(--sand);margin-bottom:1.2rem}
.captcha-row label{margin:0;font-size:0.78rem;color:var(--dark);font-weight:400;letter-spacing:0.05em;text-transform:none}
.captcha-row input{width:80px;padding:0.5rem 0.7rem}

.form-submit{width:100%;margin-top:0.5rem}

.form-msg{padding:1rem;margin-top:1rem;font-size:0.88rem;font-weight:300;display:none}
.form-msg.success{background:#E5EFE0;color:#2F5424;border-left:3px solid #4A7E3A;display:block}
.form-msg.error{background:#F5E2E0;color:#7A2F26;border-left:3px solid #B84838;display:block}

.privacy-note{font-size:0.78rem;font-weight:300;color:var(--mid);line-height:1.6;margin-top:1rem}

/* ---------- SERVICES PAGE ---------- */
.services-detail{padding:5rem}
.service-block{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;margin-bottom:6rem}
.service-block.reverse{direction:rtl}
.service-block.reverse > *{direction:ltr}
.service-block:last-child{margin-bottom:0}
.service-visual{aspect-ratio:4/3;position:relative;overflow:hidden}
.service-visual::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(92deg,transparent,transparent 22px,rgba(255,255,255,0.05) 22px,rgba(255,255,255,0.05) 24px)}
.service-text .num{font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;color:var(--accent);margin-bottom:0.8rem;letter-spacing:0.05em}
.service-text h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,2.8vw,2.8rem);font-weight:300;color:var(--dark);margin-bottom:1.5rem;line-height:1.2}
.service-text h2 em{font-style:italic;color:var(--bronze)}
.service-text p{font-size:0.97rem;font-weight:300;line-height:1.85;color:var(--mid);margin-bottom:1rem}
.service-features{list-style:none;margin-top:1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:0.8rem}
.service-features li{font-size:0.88rem;font-weight:300;color:var(--mid);padding-left:1.4rem;position:relative;line-height:1.5}
.service-features li::before{content:'â—†';position:absolute;left:0;top:0;color:var(--accent);font-size:0.7rem}

/* ---------- GALLERY PAGE ---------- */
.gallery-controls{padding:3rem 5rem 1rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.gallery-filters{display:flex;gap:0.6rem;flex-wrap:wrap}
.gallery-filter{font-family:'Jost',sans-serif;font-size:0.75rem;letter-spacing:0.14em;text-transform:uppercase;padding:0.55rem 1.2rem;background:transparent;border:1px solid var(--sand);color:var(--mid);cursor:pointer;transition:all 0.3s}
.gallery-filter:hover,.gallery-filter.active{background:var(--dark);color:var(--cream);border-color:var(--dark)}
.gallery-count{font-size:0.78rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--mid)}
.gallery-grid{padding:2rem 5rem 6rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.gallery-item{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:1;background:var(--warm)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(28,26,23,0.85) 100%);display:flex;align-items:flex-end;padding:1.5rem;opacity:0;transition:opacity 0.3s}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay .suburb{color:var(--cream);font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase}
.gallery-overlay .suburb span{display:block;font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-style:italic;color:var(--accent);text-transform:none;letter-spacing:0;margin-top:0.3rem}

.lightbox{position:fixed;inset:0;background:rgba(28,26,23,0.96);z-index:200;display:none;align-items:center;justify-content:center;padding:2rem}
.lightbox.active{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain}
.lightbox-close{position:absolute;top:2rem;right:2rem;background:none;border:none;color:var(--cream);font-size:2rem;cursor:pointer;line-height:1}
.lightbox-info{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);color:var(--cream);text-align:center;font-size:0.85rem;letter-spacing:0.14em;text-transform:uppercase}
.lightbox-info span{display:block;font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-style:italic;color:var(--accent);text-transform:none;letter-spacing:0;margin-top:0.3rem}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:1px solid rgba(255,255,255,0.3);color:var(--cream);width:50px;height:50px;cursor:pointer;font-size:1.5rem;transition:all 0.3s}
.lightbox-nav:hover{background:rgba(255,255,255,0.1);border-color:var(--accent)}
.lightbox-prev{left:2rem}
.lightbox-next{right:2rem}

.gallery-empty{padding:5rem 5rem;text-align:center;color:var(--mid)}
.gallery-empty h3{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:300;margin-bottom:1rem}
.gallery-empty p{font-size:0.95rem;font-weight:300;line-height:1.8;max-width:520px;margin:0 auto}

/* ---------- ABOUT ---------- */
.about-story{padding:6rem 5rem;display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;align-items:start}
.about-image{aspect-ratio:3/4;background:linear-gradient(160deg,#C8B89A 0%,#A0876A 50%,#5C4A38 100%);position:relative;overflow:hidden}
.about-image::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(92deg,transparent,transparent 22px,rgba(255,255,255,0.04) 22px,rgba(255,255,255,0.04) 24px)}
.about-content h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3vw,2.8rem);font-weight:300;color:var(--dark);line-height:1.2;margin-bottom:2rem}
.about-content h2 em{font-style:italic;color:var(--bronze)}
.about-content p{font-size:0.97rem;font-weight:300;line-height:1.9;color:var(--mid);margin-bottom:1.4rem}
.about-content .signature{margin-top:2rem;font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-style:italic;color:var(--bronze)}

.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;padding:5rem 5rem 6rem}
.value-card{padding:2.5rem;background:var(--warm);border-top:3px solid var(--bronze);transition:all 0.3s}
.value-card:hover{transform:translateY(-4px)}
.value-card .num{font-family:'Cormorant Garamond',serif;font-size:2rem;font-style:italic;color:var(--accent);margin-bottom:1rem}
.value-card h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--dark);margin-bottom:0.8rem}
.value-card p{font-size:0.9rem;font-weight:300;line-height:1.8;color:var(--mid)}

/* ---------- FAQ ---------- */
.faq-wrap{padding:5rem 5rem 6rem;max-width:920px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--sand)}
.faq-question{padding:1.8rem 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;color:var(--dark);transition:color 0.3s;list-style:none}
.faq-question:hover{color:var(--bronze)}
.faq-question::-webkit-details-marker{display:none}
.faq-question .icon{font-size:1.5rem;color:var(--accent);transition:transform 0.3s;font-weight:300}
.faq-item[open] .faq-question .icon{transform:rotate(45deg)}
.faq-answer{padding:0 0 1.8rem;font-size:0.97rem;font-weight:300;line-height:1.85;color:var(--mid)}
.faq-answer p{margin-bottom:0.8rem}
.faq-answer p:last-child{margin-bottom:0}

/* ---------- SERVICE AREAS ---------- */
.areas-intro{padding:5rem 5rem 3rem;text-align:center;max-width:780px;margin:0 auto}
.areas-intro p{font-size:1rem;font-weight:300;line-height:1.85;color:var(--mid)}

.areas-grid{padding:3rem 5rem 6rem;display:grid;grid-template-columns:repeat(4,1fr);gap:3rem}
.area-region h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:400;color:var(--bronze);margin-bottom:1.2rem;padding-bottom:0.8rem;border-bottom:1px solid var(--sand)}
.area-region ul{list-style:none}
.area-region ul li{font-size:0.9rem;font-weight:300;color:var(--mid);padding:0.4rem 0;border-bottom:1px solid rgba(28,26,23,0.04)}

.areas-cta{background:var(--warm);padding:5rem;text-align:center}
.areas-cta h3{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:300;color:var(--dark);margin-bottom:1rem}
.areas-cta h3 em{font-style:italic;color:var(--bronze)}
.areas-cta p{font-size:0.95rem;font-weight:300;color:var(--mid);max-width:500px;margin:0 auto 2rem}

/* ---------- TESTIMONIALS PAGE ---------- */
.testimonials-page{padding:5rem 5rem 6rem}
.testimonials-page .test-grid{grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:0}
.review-cta{background:var(--dark);color:var(--cream);padding:5rem;text-align:center}
.review-cta h3{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:300;color:var(--cream);margin-bottom:1rem}
.review-cta h3 em{font-style:italic;color:var(--accent)}
.review-cta p{font-size:0.95rem;font-weight:300;color:rgba(250,247,242,0.7);max-width:500px;margin:0 auto 2rem}

/* ---------- ANIMATIONS ---------- */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.hero-eyebrow,.page-hero .eyebrow{animation:fadeUp 0.8s ease both}
.hero-title,.page-hero h1{animation:fadeUp 0.8s 0.15s ease both}
.hero-desc,.page-hero p{animation:fadeUp 0.8s 0.3s ease both}
.hero-btns{animation:fadeUp 0.8s 0.45s ease both}

.fade-in{opacity:0;transform:translateY(20px);transition:all 0.7s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ---------- RESPONSIVE ---------- */
@media (max-width:1024px){
  nav{padding:1rem 2rem}
  .nav-links{gap:1.5rem}
  .hero{grid-template-columns:1fr}
  .hero-right{min-height:400px}
  .hero-left{padding:3rem 2rem}
  .intro,.about-story,.form-section{grid-template-columns:1fr;gap:3rem;padding:4rem 2rem}
  .collections,.process,.testimonials,.cta-banner{padding:4rem 2rem}
  .page-hero{padding:8rem 2rem 4rem}
  .cards-grid,.test-grid,.steps,.values-grid,.gallery-grid{grid-template-columns:repeat(2,1fr)}
  .areas-grid{grid-template-columns:repeat(2,1fr);padding:3rem 2rem 5rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
  .services-detail{padding:4rem 2rem}
  .service-block{grid-template-columns:1fr;gap:2.5rem;margin-bottom:4rem}
  .service-block.reverse{direction:ltr}
  .gallery-controls{padding:3rem 2rem 1rem}
  .gallery-grid{padding:2rem 2rem 4rem}
  .faq-wrap,.areas-intro{padding:4rem 2rem}
  .areas-cta,.review-cta{padding:4rem 2rem}
}

@media (max-width:768px){
  nav{padding:1rem 1.5rem}
  .nav-links,.nav-cta{display:none}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;padding:2rem;border-bottom:1px solid var(--sand);gap:1.5rem;align-items:flex-start}
  .nav-links.open + .nav-cta{display:inline-block;position:absolute;top:100%;left:2rem;right:2rem;text-align:center;margin-top:200px}
  .menu-toggle{display:block}
  footer{padding:4rem 1.5rem 2rem}
  .footer-grid{grid-template-columns:1fr;gap:2.5rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .cards-grid,.test-grid,.steps,.values-grid,.gallery-grid,.areas-grid{grid-template-columns:1fr}
  .form-row,.form-checkboxes{grid-template-columns:1fr}
  .form-card{padding:2rem 1.5rem}
  .hero-left{padding:2rem 1.5rem}
  .hero-badge{bottom:1.5rem;left:1.5rem;padding:1rem 1.5rem}
  .hero-badge .num{font-size:2rem}
  .stat-row{gap:1.5rem}
}