/* ─── RESET ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:#F8F5F0;color:#4A3828;font-family:'DM Sans',sans-serif;font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
button{font-family:'DM Sans',sans-serif;cursor:pointer;border:none;background:none}

/* ─── TOKENS ─── */
:root{
  --cream:#F8F5F0;--beige:#E8DCCB;--sand:#D4C2A8;--taupe:#9E8C7A;
  --caramel:#B8935A;--warm:#8B6B4A;--dark:#4A3828;--white:#FFFFFF;
  --nav-h:76px;
  --ease:cubic-bezier(0.25,0.46,0.45,0.94);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
}

/* ─── MATERIAL SWATCH ─── (signature element) */
.swatch-strip{
  display:flex;width:100%;height:14px;
}
.swatch-strip span{display:block;height:100%}
.sw1{width:18%;background:#F8F5F0}
.sw2{width:22%;background:#f0ece8}
.sw3{width:15%;background:#eeebe6}
.sw4{width:20%;background:#f1e9e2}
.sw5{width:13%;background:#eee6db}
.sw6{width:12%;background:#e8ddd3}
/* hairline above swatch */
.swatch-strip-wrap{border-top:1px solid var(--sand)}

/* ─── SCROLL REVEAL ─── */
.sr{opacity:0;transform:translateY(28px);transition:opacity 0.85s var(--ease-out),transform 0.85s var(--ease-out)}
.sr.in{opacity:1;transform:none}
.sr-l{opacity:0;transform:translateX(-28px);transition:opacity 0.85s var(--ease-out),transform 0.85s var(--ease-out)}
.sr-l.in{opacity:1;transform:none}
.sr-r{opacity:0;transform:translateX(28px);transition:opacity 0.85s var(--ease-out),transform 0.85s var(--ease-out)}
.sr-r.in{opacity:1;transform:none}
.sr-d2{transition-delay:0.12s}
.sr-d3{transition-delay:0.24s}
.sr-d4{transition-delay:0.36s}
.sr-d5{transition-delay:0.48s}

/* ─── NAV ─── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:900; background-color: rgb(248, 248, 248);
  backdrop-filter: blur(10px);
  height:var(--nav-h);display:flex;align-items:center;
  justify-content:space-between;padding:0 56px;
  transition:background 0.4s,box-shadow 0.4s;
}

.hero {
    height: 100vh;
    margin-top: 0px;
    background: url("your-image.jpg") center/cover no-repeat;
    position: relative;
}
.hero-content {
    padding: 0 24px 72px;
}

/* Dark overlay */
.hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6); /* adjust darkness here */
    z-index: 1;
}

/* Keep content above overlay */
.hero-content {
    position: relative;
    z-index: 2;
    color: white;
}

.nav.stuck{background:rgba(255, 255, 255, 0.96);box-shadow:0 1px 0 var(--sand);backdrop-filter:blur(120px)}
.nav-brand{
  font-family:'Cormorant',serif;font-weight:500;font-size:20px;
  letter-spacing:0.08em;color:var(--brown);
  transition:color 0.4s;white-space:nowrap;
}
.nav.stuck .nav-brand{color:var(--dark)}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none}
.nav-links a{
  font-size:11.5px;font-weight:400;letter-spacing:0.16em;
  text-transform:uppercase;color:rgba(52, 31, 7, 0.8);
  transition:color 0.2s;
}
.nav.stuck .nav-links a{color:var(--taupe)}
.nav-links a:hover{color:var(--caramel)!important}
.nav-book{
  font-size:11px;font-weight:500;letter-spacing:0.18em;
  text-transform:uppercase;background:var(--caramel);
  color:var(--white)!important;padding:10px 22px;
  border-radius:2px;transition:background 0.25s!important;
}
.nav-book:hover{background:var(--warm)!important}
.burger{display:none;flex-direction:column;gap:5px;padding:6px;cursor:pointer;z-index:901}
.burger span{display:block;width:22px;height:1.5px;background:var(--white);transition:background 0.4s}
.nav.stuck .burger span{background:var(--dark)}

/* ─── HERO ─── */
.hero{
  position:relative;height:90vh;min-height:660px;
  display:flex;align-items:flex-end;overflow:hidden;
}
.mirror {
  transform: scaleX(-1);
}
.hero-bg{
  position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(74,56,40,0.72) 0%,rgba(74,56,40,0.28) 60%,rgba(74,56,40,0.05) 100%),
    url('https://images.unsplash.com/photo-1600607687939-ce8a6c25118c?w=1920&q=85') center/cover no-repeat;
  transform:scale(1.06);
  animation:heroKenBurns 14s var(--ease) forwards;
}
@keyframes heroKenBurns{to{transform:scale(1)}}
.hero-content{
  position:relative;z-index:2;
  padding:0 56px 80px;
  max-width:820px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;font-weight:400;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--caramel);margin-bottom:24px;
  opacity:0;animation:fUp 0.8s var(--ease-out) 0.7s forwards;
}
.hero-eyebrow::before{content:'';width:36px;height:1px;background:var(--caramel)}
@keyframes fUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.hero-h1{
  font-family:'Cormorant',serif;font-weight:300;font-size:clamp(32px,7.5vw,90px);
  line-height:0.97;color:var(--white);letter-spacing:-0.01em;
  opacity:0;animation:fUp 1s var(--ease-out) 0.9s forwards;
}
.hero-h1 em{font-style:italic;color:var(--sand)}
.hero-sub{
  margin-top:28px;max-width:440px;font-size:12px;font-weight:300;
  color:rgba(255,255,255,0.72);line-height:1.8;
  opacity:0;animation:fUp 0.9s var(--ease-out) 1.1s forwards;
}
.hero-ctas{
  display:flex;gap:16px;flex-wrap:wrap;margin-top:44px;
  opacity:0;animation:fUp 0.9s var(--ease-out) 1.25s forwards;
}
.btn-solid{
  display:inline-flex;align-items:center;gap:12px;
  background-color: rgb(126, 102, 43); color:var(--white);opacity:0.60;
  font-size:12px;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;
  padding:15px 30px;border-radius:2px;
  transition:background 0.25s,transform 0.2s;
}
.btn-solid:hover{background:var(--warm);transform:translateY(-2px)}

.btn-solid2{
  display:inline-flex;align-items:center;gap:12px;
  background-color: rgb(47, 36, 8); color:var(--white);
  font-size:12px;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;
  padding:15px 30px;border-radius:2px;
  transition:background 0.25s,transform 0.2s;
}
.btn-solid2:hover{background:var(--dark);transform:translateY(-2px)}

.btn-outline-w{
  display:inline-flex;align-items:center;gap:12px;
  border:1px solid rgba(255,255,255,0.4);color:rgba(255,255,255,0.88);
  font-size:12px;font-weight:400;letter-spacing:0.16em;text-transform:uppercase;
  padding:14px 30px;border-radius:2px;
  transition:border-color 0.25s,background 0.25s;
}
.btn-outline-w:hover{border-color:var(--caramel);background:rgba(184,147,90,0.12)}
.hero-bottom{
  position:absolute;bottom:44px;right:56px;z-index:2;
  display:flex;gap:44px;
  opacity:0;animation:fUp 0.8s var(--ease-out) 1.45s forwards;
}
.hero-stat .n{
  font-family:'Cormorant',serif;font-size:42px;font-weight:300;
  color:var(--white);line-height:1;
}
.hero-stat .l{
  font-size:10px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;
  color:rgba(255,255,255,0.45);margin-top:6px;
}
.scroll-cue{
  position:absolute;left:56px;bottom:44px;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  opacity:0;animation:fUp 0.8s var(--ease-out) 1.55s forwards;
}
.scroll-cue span{font-size:9px;font-weight:400;letter-spacing:0.28em;text-transform:uppercase;color:rgba(255,255,255,0.45)}
.scroll-line{width:1px;height:44px;background:linear-gradient(to bottom,rgba(255,255,255,0.45),transparent);animation:scPulse 2.2s ease-in-out infinite 2s}
@keyframes scPulse{0%,100%{opacity:0.5}50%{opacity:1}}

/* ─── INTRO RIBBON ─── */
.ribbon{background:var(--dark);padding:52px 56px;display:grid;grid-template-columns:1fr 1px 2fr 1px 1fr;gap:48px;align-items:center}
.ribbon-div{background:rgba(255,255,255,0.08);height:56px;align-self:center}
.ribbon-stat .n{font-family:'Cormorant',serif;font-size:48px;font-weight:300;color:var(--caramel);line-height:1}
.ribbon-stat .l{font-size:10px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-top:7px}
.ribbon-text  {display:inline-flex;align-items:center;gap:14px;
  font-size:11px;font-weight:400;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--caramel);margin-bottom:24px;
  opacity:0;animation:fUp 0.8s var(--ease-out) 0.7s forwards;}

/* ─── SECTION COMMON ─── */
.sec{padding:108px 56px}
.sec-eye{
  display:inline-flex;align-items:center;gap:14px;margin-bottom:1px;
  font-size:10.5px;font-weight:400;letter-spacing:0.3em;text-transform:uppercase;color:var(--dark);
}
.sec-eye::before{content:'';width:28px;height:1px;background:var(--caramel)}
.sec-h{font-family:'Cormorant',serif;font-weight:400;font-size:clamp(36px,4.2vw,62px);line-height:1.07;color:var(--dark)}
.sec-h em{font-style:italic;color:var(--caramel)}
.sec-lead{font-size:15.5px;font-weight:300;color:var(--dark);line-height:1.85;max-width:500px}
.btn-text{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:400;letter-spacing:0.2em;text-transform:uppercase;color:var(--caramel);
  transition:gap 0.25s;
}
.btn-text:hover{gap:18px}
.arrow-r{width:28px;height:1px;background:var(--caramel);display:inline-block;vertical-align:middle;position:relative;transition:width 0.25s}
.btn-text:hover .arrow-r{width:40px}
.arrow-r::after{content:'';position:absolute;right:0;top:-3px;border-top:3.5px solid transparent;border-bottom:3.5px solid transparent;border-left:6px solid var(--caramel)}

/* ─── ABOUT ─── */
.about-g{display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:center}
.about-imgs{position:relative;height:580px}
.about-main{position:absolute;top:0;left:0;width:80%;height:95%;border-radius:3px;overflow:hidden;box-shadow:0 28px 72px rgba(74,56,40,0.16)}
.about-accent{position:absolute;bottom:0;right:0;width:46%;height:46%;border-radius:3px;overflow:hidden;box-shadow:0 18px 44px rgba(74,56,40,0.2);border:6px solid var(--cream)}
.about-badge{
  position:absolute;top:46%;left:64%;transform:translate(-50%,-50%);z-index:10;
  background:var(--caramel);padding:20px 28px;border-radius:3px;text-align:center;
  box-shadow:0 8px 32px rgba(0, 0, 0, 0.4);
}
.about-badge .n{font-family:'Cormorant',serif;font-size:38px;font-weight:300;color:var(--white);line-height:1}
.about-badge .l{font-size:9.5px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.8);margin-top:5px}
.about-copy{color:var(--dark);font-size:15px;line-height:1.9;margin-top:22px}
.about-copy p+p{margin-top:18px}
.about-vals{display:grid;grid-template-columns:2fr 2fr;gap:9px;margin-top:20px}
.about-val{display:flex;align-items:flex-start;gap:13px}
.val-dot{width:5px;height:5px;border-radius:50%;background:var(--caramel);flex-shrink:0;margin-top:9px}
.val-title{font-size:12.5px;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;color:var(--dark)}
.val-sub{font-size:12px;font-weight:300;color:var(--taupe);margin-top:2px}

/* ─── SERVICES ─── */
.services-bg{background:var(--cream)}
.services-top{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:end;margin-bottom:68px}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.svc-card{
  background:var(--beige);padding:4px 20px 12px;
  position:relative;overflow:hidden;
  transition:background 0.35s;cursor:default;
}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--caramel);transition:width 0.4s var(--ease)}
.svc-card:hover{background:var(--white)}
.svc-card:hover::after{width:100%}
/* Dark card */
.svc-dark{background:var(--dark)!important}
.svc-dark:hover{background:var(--dark)!important;opacity:0.92}
.svc-dark .svc-num,.svc-dark .svc-title,.svc-dark .svc-desc{color:var(--white)!important}
.svc-dark .svc-desc{opacity:0.89}
/* Caramel CTA card */
.svc-cta{background:var(--caramel)!important;display:flex;flex-direction:column;justify-content:flex-end}
.svc-cta:hover{background:var(--warm)!important}
.svc-cta .svc-title{color:var(--white);font-size:26px}
.svc-cta .svc-desc{color:rgba(255,255,255,0.78)}
.svc-num{font-family:'Cormorant',serif;font-size:13px;font-style:italic;color:var(--caramel);margin-bottom:28px}
.svc-icon{margin-bottom:22px;opacity:0.55}
.svc-icon svg{width:40px;height:40px}
.svc-title{font-family:'Cormorant',serif;font-size:23px;font-weight:400;color:var(--dark);margin-bottom:14px;line-height:1.2}
.svc-desc{font-size:13.5px;font-weight:300;color:var(--warm);line-height:1.85}
.svc-more{
  display:inline-flex;align-items:center;gap:9px;
  margin-top:30px;font-size:10.5px;font-weight:400;
  letter-spacing:0.2em;text-transform:uppercase;color:var(--caramel);
  transition:gap 0.25s;
}
.svc-card:hover .svc-more,.svc-dark .svc-more{gap:16px}
.svc-dark .svc-more{color:rgba(255,255,255,0.6)}
.svc-cta .svc-more{display:none}

/* ─── PORTFOLIO ─── */
.port-bg{background:var(--white)}
.port-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:52px}
.port-filters{display:flex;gap:0;border-bottom:1px solid var(--beige)}
.pf-btn{
  font-size:11px;font-weight:400;letter-spacing:0.16em;text-transform:uppercase;
  padding:9px 18px;color:var(--taupe);
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color 0.2s,border-color 0.2s;
  border-top:none;border-left:none;border-right:none;
  background:none;font-family:'DM Sans',sans-serif;
}
.pf-btn:hover,.pf-btn.on{color:var(--caramel);border-bottom-color:var(--caramel)}
/* Mosaic grid */
.port-mosaic{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:auto;gap:16px}
.pm1{grid-column:span 7;grid-row:span 2;aspect-ratio:3.7/4}
.pm2{grid-column:span 5;aspect-ratio:4/3}
.pm3{grid-column:span 5;aspect-ratio:4/3}
.pm4{grid-column:span 4;aspect-ratio:3/4}
.pm5{grid-column:span 4;aspect-ratio:3/4}
.pm6{grid-column:span 4;aspect-ratio:3/4}
.proj{position:relative;border-radius:3px;overflow:hidden;cursor:pointer}
.proj img{transition:transform 0.75s var(--ease)}
.proj:hover img{transform:scale(1.06)}
.proj-over{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(74,56,40,0.9) 0%,rgba(74,56,40,0.2) 50%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px;
  opacity:0;transition:opacity 0.35s;
}
.proj:hover .proj-over{opacity:1}
.proj-cat{font-size:10px;font-weight:400;letter-spacing:0.24em;text-transform:uppercase;color:var(--white);margin-bottom:6px}
.proj-name{font-family:'Cormorant',serif;font-size:22px;font-weight:300;color:var(--white);line-height:1.2}
.proj-loc{font-size:12px;font-weight:300;color:rgba(255,255,255,0.55);margin-top:5px}
.proj-arr{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:14px;font-size:10.5px;font-weight:400;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--caramel);
}

/* ─── PROCESS ─── */
.process-bg{background:var(--dark)}
.process-bg .sec-h{color:var(--white)}
.process-bg .sec-eye{color:var(--caramel)}
.proc-intro{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;margin-bottom:72px}
.proc-sub{font-size:15px;font-weight:300;color:rgba(255,255,255,0.45);line-height:1.85}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.proc-step{
  background:rgba(255,255,255,0.04);padding:48px 36px 52px;
  position:relative;overflow:hidden;
  transition:background 0.3s;
}
.proc-step:hover{background:rgba(255,255,255,0.07)}
.proc-step::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:rgba(255,255,255,0.07);transition:background 0.3s}
.proc-step:hover::before{background:var(--caramel)}
.proc-phase{
  display:inline-block;font-size:10px;font-weight:400;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--caramel);margin-bottom:22px;
}
.proc-title{font-family:'Cormorant',serif;font-size:25px;font-weight:400;color:var(--white);margin-bottom:16px;line-height:1.2}
.proc-desc{font-size:13.5px;font-weight:300;color:rgba(255,255,255,0.48);line-height:1.85}
.proc-ghost{
  position:absolute;bottom:20px;right:24px;
  font-family:'Cormorant',serif;font-size:80px;font-weight:300;font-style:italic;
  color:rgba(255,255,255,0.03);line-height:1;pointer-events:none;
}

/* ─── TESTIMONIALS ─── */
.test-bg{background:var(--cream)}
.test-wrap{max-width:900px;margin:0 auto;text-align:center}
.test-wrap .sec-eye{justify-content:center}
.test-wrap .sec-eye::before{display:none}
.test-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:60px;text-align:left}
.tc{
  background:var(--white);border-radius:3px;padding:40px 36px 44px;
  box-shadow:0 2px 20px rgba(74,56,40,0.05);
  transition:box-shadow 0.3s,transform 0.3s;position:relative;
}
.tc:hover{box-shadow:0 12px 44px rgba(74,56,40,0.10);transform:translateY(-4px)}
.tc.feat{background:var(--dark)}
.tc-stars{display:flex;gap:3px;color:var(--caramel);font-size:12px;margin-bottom:20px}
.tc-q{font-family:'Cormorant',serif;font-size:52px;color:var(--caramel);line-height:0.7;margin-bottom:18px;opacity:0.55;font-style:italic}
.tc.feat .tc-q{color:var(--sand)}
.tc-text{font-family:'Cormorant',serif;font-style:italic;font-size:17.5px;color:var(--dark);line-height:1.65;margin-bottom:28px}
.tc.feat .tc-text{color:rgba(255,255,255,0.88)}
.tc-div{width:28px;height:1px;background:var(--caramel);margin-bottom:16px}
.tc-name{font-size:12.5px;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--dark)}
.tc.feat .tc-name{color:var(--white)}
.tc-role{font-size:12px;font-weight:300;color:var(--taupe);margin-top:3px}
.tc.feat .tc-role{color:rgba(255,255,255,0.42)}

/* ─── CONTACT ─── */
.contact-g{display:grid;grid-template-columns:1fr 1.5fr;gap:0;min-height:700px}
.contact-left{background:var(--dark);padding:250px 60px;display:flex;flex-direction:column;justify-content:space-between}
.contact-left .sec-h{color:var(--white);font-size:clamp(32px,3.5vw,54px)}
.contact-left .sec-h em{color:var(--caramel)}
.contact-left .sec-eye{color:var(--caramel)}
.c-details{display:flex;flex-direction:column;gap:28px;margin-top:16px}
.c-lbl{font-size:9.5px;font-weight:400;letter-spacing:0.26em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:5px}
.c-val{font-size:15px;font-weight:300;color:rgba(255,255,255,0.78);line-height:1.6}
.c-val a:hover{color:var(--caramel)}
.c-social{display:flex;gap:12px;margin-top:40px}

.c-soc{
  width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,0.15);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.45);transition:all 0.2s;
}


.c-soc:hover{border-color:var(--caramel);color:var(--caramel)}
.c-soc svg{width:15px;height:15px}
.contact-right{background:var(--white);padding:90px 64px}
.form-title{font-family:'Cormorant',serif;font-size:30px;font-weight:400;color:var(--dark);margin-bottom:3px}
.form-sub{font-size:14px;font-weight:300;color:var(--taupe);margin-bottom:24px;line-height:1.7}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.f-field{display:flex;flex-direction:column;gap:7px;margin-bottom:22px}
.f-field.full{grid-column:1/-1}
.f-lbl{font-size:9.5px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:var(--taupe)}
.f-in,.f-sel,.f-ta{
  background:var(--cream);border:1px solid var(--sand);border-radius:2px;
  padding:8px 16px;font-family:'DM Sans',sans-serif;font-size:14px;
  font-weight:300;color:var(--dark);outline:none;
  transition:border-color 0.25s,background 0.25s;width:100%;
}
.f-in:focus,.f-sel:focus,.f-ta:focus{border-color:var(--caramel);background:var(--white)}
.f-ta{min-height:110px;resize:vertical}
.f-sel{appearance:none;cursor:pointer}
.f-submit{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--caramel);color:var(--white);
  font-size:11.5px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;
  padding:16px 34px;border-radius:2px;margin-top:6px;
  transition:background 0.25s,transform 0.2s;font-family:'DM Sans',sans-serif;
}
.f-submit:hover{background:var(--warm);transform:translateY(-2px)}
.f-submit svg{width:16px;height:16px}

/* ─── FOOTER ─── */
.footer{background:#2C1F14;padding:72px 56px 36px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:56px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,0.07)}
.foot-brand{font-family:'Cormorant',serif;font-size:24px;font-weight:400;color:var(--white);margin-bottom:14px;letter-spacing:0.04em}
.foot-tag{font-size:13px;font-weight:300;color:rgba(255,255,255,0.38);line-height:1.8;max-width:250px;margin-bottom:28px}
.foot-soc{display:flex;gap:10px}
.foot-ch{font-size:10px;font-weight:400;letter-spacing:0.28em;text-transform:uppercase;color:var(--caramel);margin-bottom:20px}
.foot-ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-ul a{font-size:13.5px;font-weight:300;color:rgba(255,255,255,0.46);transition:color 0.2s}
.foot-ul a:hover{color:var(--caramel)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;flex-wrap:wrap;gap:12px}
.foot-copy{font-size:11.5px;font-weight:300;color:rgba(255,255,255,0.24)}
.foot-links{display:flex;gap:24px}
.foot-links a{font-size:11.5px;font-weight:300;color:rgba(255,255,255,0.26);transition:color 0.2s}
.foot-links a:hover{color:var(--caramel)}

.to-top{
  position: fixed;
  bottom: 30px;
  right: 30px;

  width: 50px;
  height: 50px;
  border: none;
  border-radius: 50%;

  background: rgba(80, 50, 25, 0.8);
  backdrop-filter: blur(10px);
  color: #fff;

  font-size: 18px;
  cursor: pointer;

  opacity: 0;
  transform: translateY(20px);
  transition: all 0.4s ease;

  box-shadow: 0 10px 25px rgba(0,0,0,0.2);
  z-index: 999;
}

/* hover effect */
.to-top:hover{
  transform: translateY(0) scale(1.1);
  background: rgba(120, 80, 40, 0.9);
}

/* show button */
.to-top.show{
  opacity: 1;
  transform: translateY(0);
}

/* ─── MOBILE ─── */
.mob-nav{position:fixed;inset:0;background:#261603;z-index:898;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;opacity:0;pointer-events:none;transition:opacity 0.35s}
.mob-nav.open{opacity:0.78; pointer-events:all}
.mob-nav a{font-family:'Cormorant',serif;font-size:34px;font-weight:300;color:rgba(0, 0, 0, 0.72);transition:color 0.2s}
.mob-nav a:hover{color:var(--dark)}


/* Width of scrollbar */
::-webkit-scrollbar {
  width: 10px;
}

/* Track (background) */
::-webkit-scrollbar-track {
  background: #f5f5f5;
}

/* Scroll thumb (the moving part) */
::-webkit-scrollbar-thumb {
  background: #7a5c3e;   /* warm brown for luxury feel */
  border-radius: 20px;
  border: 2px solid #f5f5f5;
}

/* Hover effect */
::-webkit-scrollbar-thumb:hover {
  background: #5a3f2a;
}

/* Full screen loader */
#loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
}

/* spinning circle */
.spinner {
  width: 50px;
  height: 50px;
  border: 5px solid #eee;
  border-top: 5px solid #7a5c3e; /* luxury brown */
  border-radius: 50%;
  animation: spin 2s linear infinite;
}

/* animation */
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}


@media(max-width:1100px){
  .svc-grid{grid-template-columns:repeat(1,1fr)}
  .foot-top{grid-template-columns:1fr 1fr;gap:40px}
  .port-mosaic .pm4,.port-mosaic .pm5,.port-mosaic .pm6{grid-column:span 4}
  .ribbon{grid-template-columns:1fr;gap:32px;padding:92px 40px}
  .ribbon-div{display:none}
  .proc-grid{grid-template-columns:1fr 1fr}
  .test-cards{grid-template-columns:1fr 1fr}
}

@media(max-width:860px){
  .mob-nav{position:fixed;inset:0;background:#1c1002;z-index:898;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;opacity:0;pointer-events:none;transition:opacity 0.35s}
 .mob-nav.open{opacity:0.88; pointer-events:all}
 .mob-nav a{font-family:'Cormorant',serif;font-size:34px;font-weight:300;color:rgba(255, 255, 255, 0.72);transition:color 0.2s}
 .mob-nav a:hover{color:var(--caramel)}
  .nav{padding:0 24px}
  .nav-links{display:none}
  .burger{display:flex}
  .burger span {
  background: var(--dark);}
  .sec{padding:20px 20px}
  .hero-h1{
  font-family:'Cormorant',serif;font-weight:500;font-size:clamp(52px,7.5vw,70px);
  line-height:0.97;color:var(--white);letter-spacing:-0.01em;
  opacity:0;animation:fUp 1s var(--ease-out) 0.9s forwards;}
 .hero-h1 em{font-style:italic;color:var(--sand)}
  .hero-content{padding:140px 80px 80px}
  .about-g{grid-template-columns:1fr;gap:52px}
  .about-imgs{height:600px}
  .services-top{grid-template-columns:1fr}
  .port-top{flex-direction:column;align-items:flex-start;gap:24px}
  .port-mosaic{grid-template-columns:1fr 1fr;gap:10px}
  .pm1{grid-column:span 2;aspect-ratio:12/9}
  .pm2,.pm3,.pm4,.pm5,.pm6{grid-column:span 1;aspect-ratio:4/3}
  .proc-intro{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr}
  .test-cards{grid-template-columns:1fr}
  .contact-g{grid-template-columns:1fr}
  .contact-right{padding:60px 28px}
  .contact-left{padding:60px 28px}
  .f-row{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .foot-links{flex-wrap:wrap;gap:14px}
  .hero-bottom{right:24px;gap:24px}
  .scroll-cue{left:24px}
  .ribbon{padding:52px 24px}
  .footer{padding:60px 24px 32px}
  .svc-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:2px}
  .svc-card{
  background:var(--beige);padding:1px 40px 12px;
  position:relative;overflow:hidden;
  transition:background 0.35s;cursor:default;}
  .svc-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--dark);transition:width 0.4s var(--ease)}
  .svc-card:hover{background:var(--white)}
  .svc-card:hover::after{width:100%}
  /* Dark card */
  .svc-dark{background:var(--dark)!important}
  .svc-dark:hover{background:var(--dark)!important;opacity:0.92}
  .svc-dark .svc-num,.svc-dark .svc-title,.svc-dark .svc-desc{color:var(--white)!important}
  .svc-dark .svc-desc{opacity:0.99}
  /* Caramel CTA card */
  .svc-cta{background:var(--caramel)!important;display:flex;flex-direction:column;justify-content:flex-end}
  .svc-cta:hover{background:var(--warm)!important}
  .svc-cta .svc-title{color:var(--white);font-size:26px}
  .svc-cta .svc-desc{color:rgba(0, 0, 0, 0.78)}
  .svc-num{font-family:'Cormorant',serif;font-size:13px;font-style:italic;color:var(--caramel);margin-bottom:28px}
  .svc-icon{margin-bottom:1px;opacity:0.55}
  .svc-icon svg{width:40px;height:40px}
  .svc-title{font-family:'Cormorant',serif;font-size:23px;font-weight:400;color:var(--dark);margin-bottom:14px;line-height:1.2}
  .svc-desc{font-size:0.1px;font-weight:30;color:var(--warm);line-height:1.0}
  .svc-more{
  display:inline-flex;align-items:center;gap:2px;
  margin-top:1px;font-size:10.5px;font-weight:400;
  letter-spacing:0.2em;text-transform:uppercase;color:var(--caramel);
  transition:gap 0.25s;}
  .svc-card:hover .svc-more,.svc-dark .svc-more{gap:16px}
  .svc-dark .svc-more{color:rgba(255,255,255,0.6)}
  .svc-cta .svc-more{display:none}
}

@media(max-width:860px){

  .nav-links{
    position: fixed;
    top: 0;
    right: 0;
    height: 100vh;
    width: 50%; /* HALF SCREEN */
    background: rgba(255, 255, 255, 0.85); /* almost see-through */
    backdrop-filter: blur(20px);

    flex-direction: column;
    align-items: flex-start;
    padding: 100px 32px;

    gap: 24px;

    transform: translateX(100%);
    transition: transform 0.4s ease;
    z-index: 1000;
  }

  .nav-links.active{
    transform: translateX(0);
  }
}

@media(max-width:560px){
  .hero-bottom{display:none}
  .about-imgs{height:290px}
  .about-badge{padding:14px 18px}
  .about-badge .n{font-size:28px}
  .about-vals{grid-template-columns:1fr}
  .tc{padding:18px 24px 32px}
}

@media(max-width:860px){
  .hero-content{
    padding:90px;
  }
}


