:root{
  --noir:#080604;
  --char:#131008;
  --deep:#1c1510;
  --bark:#2c1e12;
  --mocha:#382415;
  --gold:#c9a96e;
  --gold2:#e2c99a;
  --gold3:#f0e4cc;
  --cream:#f7f0e4;
  --white:#fdfaf5;
  --stone:#7a6b5a;
  --mist:#c4b8a8;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Montserrat',sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--noir);color:var(--cream);font-family:var(--sans);font-weight:300;line-height:1.7;overflow-x:hidden}

/* ───── NAV ───── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 3.5rem;transition:all .4s}
nav.s{background:rgba(8,6,4,.94);backdrop-filter:blur(14px);border-bottom:1px solid rgba(201,169,110,.11)}
.logo{text-decoration:none;display:flex;flex-direction:column;line-height:1}
.logo-main{font-family:var(--serif);font-size:1.45rem;font-weight:500;letter-spacing:.14em;color:var(--gold2)}
.logo-sub{font-size:.5rem;font-weight:500;letter-spacing:.42em;text-transform:uppercase;color:var(--stone);margin-top:4px}
.nav-links{display:flex;gap:2.2rem;list-style:none;align-items:center}
.nav-links a{font-size:.6rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--mist);text-decoration:none;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transition:transform .3s}
.nav-links a:hover{color:var(--gold2)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-enq{color:var(--gold)!important;border:1px solid rgba(201,169,110,.45)!important;padding:.55rem 1.3rem!important;transition:all .3s!important}
.nav-enq:hover{background:var(--gold)!important;color:var(--noir)!important}
.nav-enq::after{display:none!important}

/* ───── HERO ───── */
#hero{position:relative;height:100vh;min-height:680px;display:flex;align-items:flex-end;overflow:hidden}
.hero-img{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1510812431401-41d2bd2722f3?w=1800&q=85') center/cover no-repeat}
.hero-img::after{content:'';position:absolute;inset:0;background:linear-gradient(110deg,rgba(8,6,4,.92) 38%,rgba(8,6,4,.5) 70%,rgba(8,6,4,.18) 100%)}
.hero-img::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(8,6,4,.72) 0%,transparent 55%)}
.hero-body{position:relative;z-index:2;padding:0 3.5rem 7rem;max-width:700px}
.eyebrow{display:flex;align-items:center;gap:.9rem;font-size:.58rem;font-weight:500;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:1.6rem}
.eyebrow::before{content:'';display:block;width:36px;height:1px;background:var(--gold);flex-shrink:0}
.hero-h1{font-family:var(--serif);font-weight:300;font-size:clamp(3rem,5.5vw,5.2rem);line-height:1.05;color:var(--white);margin-bottom:1.8rem;letter-spacing:-.01em}
.hero-h1 em{font-style:italic;color:var(--gold2)}
.hero-p{font-size:.82rem;color:var(--mist);max-width:460px;margin-bottom:2.8rem;line-height:1.95;letter-spacing:.04em}
.hero-btns{display:flex;gap:1.4rem;align-items:center;flex-wrap:wrap}
.btn-g{font-family:var(--sans);font-size:.6rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;text-decoration:none;color:var(--noir);background:var(--gold);padding:.95rem 2rem;display:inline-block;transition:all .3s;cursor:pointer;border:none}
.btn-g:hover{background:var(--gold2);box-shadow:0 10px 35px rgba(201,169,110,.25);transform:translateY(-2px)}
.btn-t{font-size:.6rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;text-decoration:none;color:var(--gold2);border-bottom:1px solid rgba(201,169,110,.4);padding-bottom:2px;transition:all .3s}
.btn-t:hover{color:var(--gold);border-color:var(--gold)}
.hero-scroll{position:absolute;bottom:2.8rem;right:3.5rem;z-index:2;display:flex;flex-direction:column;align-items:center;gap:.7rem;color:var(--stone);font-size:.5rem;letter-spacing:.32em;text-transform:uppercase}
.hero-line{width:1px;height:55px;background:linear-gradient(var(--gold),transparent);animation:lp 2s ease-in-out infinite}
@keyframes lp{0%,100%{opacity:.4}50%{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}
.hero-body{animation:fadeUp 1.1s ease forwards}

/* ───── SHARED ───── */
.sec{padding:6rem 3.5rem}
.label{display:flex;align-items:center;gap:.8rem;font-size:.56rem;font-weight:500;letter-spacing:.38em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.label::before{content:'';display:block;width:28px;height:1px;background:var(--gold);flex-shrink:0}
.h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.2rem,3.8vw,3.5rem);line-height:1.12;color:var(--white);margin-bottom:1.2rem}
.h2 em{font-style:italic;color:var(--gold2)}
.body-t{font-size:.78rem;color:var(--stone);line-height:2;letter-spacing:.04em}
.divider{width:52px;height:1px;background:linear-gradient(to right,var(--gold),transparent);margin:1.8rem 0}

/* ───── INTRO STRIP ───── */
#intro-strip{background:var(--char);border-bottom:1px solid rgba(201,169,110,.08);display:grid;grid-template-columns:repeat(4,1fr)}
.strip-item{padding:2.2rem 2rem;border-right:1px solid rgba(201,169,110,.08);text-align:center;transition:background .3s}
.strip-item:last-child{border-right:none}
.strip-item:hover{background:var(--deep)}
.strip-val{font-family:var(--serif);font-size:2.7rem;font-weight:300;color:var(--gold);line-height:1;margin-bottom:.35rem}
.strip-lbl{font-size:.56rem;font-weight:500;letter-spacing:.26em;text-transform:uppercase;color:var(--stone)}

/* ───── PHILOSOPHY ───── */
#philosophy{display:grid;grid-template-columns:1fr 1fr;background:var(--char)}
.philo-img{position:relative;min-height:580px;overflow:hidden}
.philo-img img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.85) contrast(1.06)}
.philo-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent 55%,var(--char) 100%)}
.philo-text{padding:5rem 4rem;display:flex;flex-direction:column;justify-content:center;gap:0}
.philo-quote{font-family:var(--serif);font-size:1.42rem;font-style:italic;font-weight:300;color:var(--gold2);line-height:1.65;border-left:2px solid var(--gold);padding-left:1.4rem;margin-bottom:1.8rem}

/* ───── SERVICES ───── */
#services{background:var(--deep)}
.services-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3.5rem;gap:2rem;flex-wrap:wrap}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(201,169,110,.07)}
.svc{background:var(--char);padding:2.8rem 2.4rem;position:relative;overflow:hidden;transition:all .35s;border:1px solid transparent}
.svc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--gold),transparent);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.svc:hover{background:var(--bark);border-color:rgba(201,169,110,.18);transform:translateY(-3px)}
.svc:hover::after{transform:scaleX(1)}
.svc-n{font-family:var(--serif);font-size:3.5rem;font-weight:300;color:rgba(201,169,110,.1);line-height:1;margin-bottom:1.2rem}
.svc-ico{width:38px;height:38px;margin-bottom:1.3rem;opacity:.65}
.svc-ttl{font-family:var(--serif);font-size:1.45rem;font-weight:400;color:var(--gold2);margin-bottom:.8rem;line-height:1.3}
.svc-p{font-size:.7rem;color:var(--stone);line-height:2;margin-bottom:1.6rem;letter-spacing:.03em}
.svc-lnk{font-size:.56rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);text-decoration:none;display:flex;align-items:center;gap:.6rem;transition:gap .3s}
.svc-lnk:hover{gap:1.1rem}
.svc-lnk::after{content:'→'}

/* ───── PROCESS ───── */
#process{position:relative;overflow:hidden}
#process::before{content:'PROCESS';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--serif);font-size:17vw;font-weight:300;color:rgba(201,169,110,.022);white-space:nowrap;pointer-events:none;user-select:none}
.proc-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:2.5rem;margin-top:4rem;position:relative;z-index:1}
.proc-steps::before{content:'';position:absolute;top:30px;left:12%;right:12%;height:1px;background:linear-gradient(to right,transparent,rgba(201,169,110,.2),rgba(201,169,110,.2),transparent)}
.proc-step{display:flex;flex-direction:column;align-items:center;text-align:center}
.proc-circle{width:60px;height:60px;border-radius:50%;border:1px solid rgba(201,169,110,.3);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.15rem;color:var(--gold);background:var(--noir);position:relative;z-index:1;margin-bottom:1.8rem;transition:all .35s;flex-shrink:0}
.proc-step:hover .proc-circle{background:var(--gold);color:var(--noir);border-color:var(--gold);box-shadow:0 0 28px rgba(201,169,110,.28)}
.proc-ttl{font-family:var(--serif);font-size:1.2rem;font-weight:400;color:var(--gold2);margin-bottom:.6rem}
.proc-p{font-size:.68rem;color:var(--stone);line-height:1.9;letter-spacing:.03em}

/* ───── GALLERY ───── */
#cellars{background:var(--char)}
.gallery-grid{display:grid;grid-template-columns:1.45fr 1fr;grid-template-rows:340px 340px;gap:3px;margin-top:3.5rem}
.gitem{position:relative;overflow:hidden;cursor:pointer}
.gitem:first-child{grid-row:1/3}
.gitem img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s}
.gitem:hover img{transform:scale(1.04)}
.gitem-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,6,4,.92) 0%,rgba(8,6,4,.28) 55%,transparent 100%);transition:background .35s}
.gitem:hover .gitem-ov{background:linear-gradient(to top,rgba(8,6,4,.96) 0%,rgba(8,6,4,.55) 65%,rgba(8,6,4,.1) 100%)}
.gitem-c{position:absolute;bottom:0;left:0;right:0;padding:2.2rem}
.gitem-tag{font-size:.52rem;font-weight:500;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:.55rem}
.gitem-ttl{font-family:var(--serif);font-size:1.7rem;font-weight:300;color:var(--white);line-height:1.2;margin-bottom:.4rem}
.gitem:first-child .gitem-ttl{font-size:2.4rem}
.gitem-desc{font-size:.68rem;color:var(--mist);line-height:1.85;opacity:0;transform:translateY(8px);transition:all .35s;letter-spacing:.03em;max-width:360px}
.gitem:hover .gitem-desc{opacity:1;transform:translateY(0)}

/* ───── CLIMATE ───── */
#climate{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;background:var(--char)}
.climate-imgs{display:grid;grid-template-columns:1fr 1fr;gap:3px}
.clim-img img{width:100%;height:100%;object-fit:cover;display:block}
.specs-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(201,169,110,.08);border:1px solid rgba(201,169,110,.08);margin-top:2rem}
.spec{background:var(--noir);padding:1.8rem;transition:background .3s}
.spec:hover{background:var(--deep)}
.spec-val{font-family:var(--serif);font-size:2.3rem;font-weight:300;color:var(--gold);line-height:1;margin-bottom:.3rem}
.spec-lbl{font-size:.58rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--stone)}
.spec-note{font-size:.65rem;color:var(--stone);margin-top:.3rem;line-height:1.65}
.spec-full{grid-column:1/-1;background:var(--deep)}

/* ───── WHY US ───── */
#why{text-align:center;position:relative;overflow:hidden}
#why::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(201,169,110,.055) 0%,transparent 65%);pointer-events:none}
.why-intro{max-width:640px;margin:0 auto 4.5rem}
.diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;max-width:960px;margin:0 auto;position:relative;z-index:1}
.diff{padding:2rem 1.6rem}
.diff-ico{font-size:1.6rem;color:var(--gold);margin-bottom:1rem;opacity:.8}
.diff-ttl{font-family:var(--serif);font-size:1.1rem;font-weight:400;color:var(--gold2);margin-bottom:.7rem}
.diff-p{font-size:.68rem;color:var(--stone);line-height:1.9;letter-spacing:.03em}

/* ───── STORY ───── */
#story{display:grid;grid-template-columns:1fr 1fr}
.story-img{position:relative;min-height:560px;overflow:hidden}
.story-img img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.78) contrast(1.06) saturate(.9)}
.story-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent 60%,var(--deep) 100%)}
.story-text{background:var(--deep);padding:5rem 4rem;display:flex;flex-direction:column;justify-content:center}
.story-quote{font-family:var(--serif);font-size:clamp(1.5rem,2vw,2rem);font-weight:300;font-style:italic;color:var(--white);line-height:1.5;position:relative;padding-top:3rem;margin-bottom:1.5rem}
.story-quote::before{content:'\201C';position:absolute;top:-1.2rem;left:-.4rem;font-size:7rem;line-height:1;color:rgba(201,169,110,.14);font-family:var(--serif)}
.story-attr{font-size:.58rem;font-weight:500;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:2.2rem}

/* ───── CTA ───── */
#cta{padding:6rem 3.5rem;background:linear-gradient(135deg,var(--deep) 0%,var(--bark) 50%,var(--deep) 100%);text-align:center;position:relative;overflow:hidden;border-top:1px solid rgba(201,169,110,.1);border-bottom:1px solid rgba(201,169,110,.1)}
#cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(201,169,110,.09) 0%,transparent 65%)}
.cta-h{font-family:var(--serif);font-size:clamp(2.4rem,4.5vw,3.8rem);font-weight:300;color:var(--white);margin-bottom:1.2rem;position:relative;z-index:1}
.cta-h em{font-style:italic;color:var(--gold2)}
.cta-sub{font-size:.75rem;color:var(--mist);margin-bottom:2.8rem;position:relative;z-index:1;letter-spacing:.06em}
.cta-btns{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ───── CONTACT ───── */
#contact{display:grid;grid-template-columns:1fr 1.15fr;gap:6rem;align-items:start}
.cinfo{margin-bottom:2rem}
.cinfo-lbl{font-size:.52rem;font-weight:500;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:.35rem}
.cinfo-val{font-family:var(--serif);font-size:1.05rem;font-weight:300;color:var(--white)}
.cinfo-val a{color:var(--white);text-decoration:none;transition:color .3s}
.cinfo-val a:hover{color:var(--gold2)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:1.2rem}
.fgrp{display:flex;flex-direction:column;gap:.45rem}
.fgrp.full{grid-column:1/-1}
label{font-size:.54rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--stone)}
input,select,textarea{background:rgba(255,255,255,.03);border:1px solid rgba(201,169,110,.14);color:var(--cream);font-family:var(--sans);font-size:.76rem;font-weight:300;padding:.85rem 1rem;outline:none;transition:border-color .3s,background .3s;width:100%}
input:focus,select:focus,textarea:focus{border-color:rgba(201,169,110,.45);background:rgba(201,169,110,.025)}
select option{background:var(--deep)}
textarea{resize:vertical;min-height:110px}

/* ───── FOOTER ───── */
footer{padding:3.5rem 3.5rem 2.5rem;background:var(--noir);border-top:1px solid rgba(201,169,110,.09)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3.5rem;margin-bottom:3rem}
.footer-brand-name{font-family:var(--serif);font-size:1.7rem;font-weight:500;letter-spacing:.12em;color:var(--gold2)}
.footer-brand-sub{font-size:.52rem;font-weight:500;letter-spacing:.38em;text-transform:uppercase;color:var(--stone);margin-top:4px}
.footer-tagline{font-size:.68rem;color:var(--stone);line-height:1.9;margin-top:1rem;max-width:230px}
.fc-title{font-size:.54rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.3rem}
.fc-links{list-style:none;display:flex;flex-direction:column;gap:.8rem}
.fc-links a{font-size:.7rem;font-weight:300;color:var(--stone);text-decoration:none;letter-spacing:.05em;transition:color .3s}
.fc-links a:hover{color:var(--gold2)}
.footer-bot{display:flex;justify-content:space-between;align-items:center;padding-top:1.8rem;border-top:1px solid rgba(201,169,110,.07);flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:.58rem;color:var(--bark);letter-spacing:.08em}
.footer-soc{display:flex;gap:1.4rem}
.footer-soc a{font-size:.58rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);text-decoration:none;transition:color .3s}
.footer-soc a:hover{color:var(--gold)}

/* ───── REVEAL ───── */
.r{opacity:0;transform:translateY(26px);transition:opacity .75s ease,transform .75s ease}
.r.v{opacity:1;transform:translateY(0)}
.rd1{transition-delay:.12s}.rd2{transition-delay:.24s}.rd3{transition-delay:.36s}.rd4{transition-delay:.48s}

/* ───── RESPONSIVE ───── */
@media(max-width:1100px){
  nav{padding:0 2rem}
  .sec{padding:5rem 2rem}
  .hero-body{padding:0 2rem 5.5rem}
  #philosophy{grid-template-columns:1fr}
  .philo-img{min-height:360px}
  .philo-img::after{display:none}
  .svc-grid{grid-template-columns:1fr 1fr}
  .proc-steps{grid-template-columns:1fr 1fr}
  .proc-steps::before{display:none}
  .gallery-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .gitem:first-child{grid-row:auto;height:420px}
  .gitem{height:300px}
  #climate{grid-template-columns:1fr;gap:3.5rem}
  #story{grid-template-columns:1fr}
  .story-img{min-height:320px}
  .story-img::after{display:none}
  .diff-grid{grid-template-columns:1fr 1fr}
  #contact{grid-template-columns:1fr;gap:3.5rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
  #intro-strip{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  nav{padding:0 1.4rem}
  .nav-links{display:none}
  .sec{padding:4rem 1.4rem}
  .hero-body{padding:0 1.4rem 4.5rem}
  .hero-h1{font-size:2.6rem}
  .frow{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .diff-grid{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .cta-btns{flex-direction:column;align-items:center}
}
