/* ============ FONTS ============ */
@font-face{font-family:'Cormorant';src:url('../fonts/cormorant-latin.woff2') format('woff2');font-weight:400 600;font-display:swap;}
@font-face{font-family:'Jost';src:url('../fonts/jost-latin.woff2') format('woff2');font-weight:300 600;font-display:swap;}

/* ============ TOKENS ============ */
:root{
  --ink:#28323d;          /* deep slate (from logo) */
  --ink-soft:#3d4a59;     /* slate for dark sections */
  --slate:#4b5c71;        /* logo slate blue-gray */
  --paper:#ffffff;        /* main background */
  --mist:#eef2f6;         /* cool light-gray alt sections */
  --orange:#e47f41;       /* logo orange accent */
  --orange-deep:#cf6a2c;
  --line:rgba(40,50,61,.14);
  --serif:'Cormorant',Georgia,serif;
  --sans:'Jost',system-ui,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.65;font-weight:300;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}

h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.05;letter-spacing:.005em}
h1{font-size:clamp(2.6rem,6vw,5.2rem)}
h2{font-size:clamp(2rem,4vw,3.4rem)}
em{font-style:italic}
.kicker{display:inline-block;font-family:var(--sans);font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;font-weight:400;color:var(--orange-deep);margin-bottom:1.1rem}
.kicker.light{color:var(--orange)}

/* ============ BUTTONS ============ */
.btn{display:inline-block;font-family:var(--sans);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;padding:1.05em 2.1em;border:1px solid transparent;transition:.45s var(--ease);cursor:pointer}
.btn-solid{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-solid:hover{background:var(--orange-deep);border-color:var(--orange-deep)}
.btn-ghost{border-color:rgba(255,255,255,.55);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn.full{width:100%;text-align:center;border:none}

/* ============ HEADER ============ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;transition:.5s var(--ease)}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:24px;max-width:1280px;margin:0 auto;padding:22px 40px;transition:.5s var(--ease)}
.brand{display:flex;align-items:center;line-height:1}
.brand-logo{height:50px;width:auto;display:block;transition:height .5s var(--ease)}
/* white logo over the dark hero, full-colour logo on the solid white header */
.brand-logo--dark{display:none}
.site-header.solid .brand-logo--light{display:none}
.site-header.solid .brand-logo--dark{display:block}
.nav{display:flex;gap:34px}
.nav a{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.88);position:relative;padding:4px 0;transition:color .4s}
.nav a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--orange);transition:width .4s var(--ease)}
.nav a:hover{color:#fff}.nav a:hover::after{width:100%}
.header-cta{display:flex;align-items:center;gap:22px}
.phone{font-size:.82rem;letter-spacing:.06em;color:#fff}
.burger{display:none;background:none;border:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:#fff;transition:.3s}

/* scrolled state */
.site-header.solid{background:var(--paper);box-shadow:0 1px 0 var(--line)}
.site-header.solid .bar{padding-top:12px;padding-bottom:12px}
.site-header.solid .brand-logo{height:42px}
.site-header.solid .nav a{color:var(--ink-soft)}
.site-header.solid .phone{color:var(--ink)}
.site-header.solid .burger span{background:var(--ink)}

/* ============ HERO ============ */
.hero{position:relative;height:100svh;min-height:620px;display:flex;align-items:center;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(105deg,rgba(24,31,39,.82) 0%,rgba(24,31,39,.45) 45%,rgba(24,31,39,.28) 100%)}
.hero-inner{position:relative;z-index:2;max-width:1280px;width:100%;margin:0 auto;padding:0 40px;color:#fff}
.eyebrow{font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;color:var(--orange);margin-bottom:1.6rem}
.hero h1{color:#fff;margin-bottom:1.6rem;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero h1 em{color:var(--mist)}
.hero-lead{max-width:30em;font-size:1.12rem;color:rgba(255,255,255,.86);margin-bottom:2.4rem;font-weight:300}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.scroll-cue{position:absolute;left:50%;bottom:34px;transform:translateX(-50%);z-index:2;width:26px;height:42px;border:1px solid rgba(255,255,255,.5);border-radius:14px}
.scroll-cue span{position:absolute;left:50%;top:9px;width:3px;height:8px;background:#fff;border-radius:2px;transform:translateX(-50%);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{opacity:0;top:9px}40%{opacity:1}100%{opacity:0;top:24px}}

/* ============ INTRO ============ */
.intro{padding:clamp(80px,12vw,150px) 0;text-align:center;background:var(--paper)}
.intro-statement{font-family:var(--serif);font-size:clamp(1.6rem,3.4vw,2.7rem);line-height:1.32;font-weight:400;max-width:18em;margin:0 auto;color:var(--ink-soft)}
.intro-statement em{color:var(--orange-deep)}

/* ============ SECTION HEAD ============ */
.section-head{max-width:42em;margin-bottom:60px}
.section-head h2{margin-bottom:.4em}
.section-head.light .kicker{color:var(--orange)}
.section-lead{color:rgba(255,255,255,.7);font-size:1.05rem;max-width:34em}

/* ============ SERVICES ============ */
.services{padding:clamp(70px,9vw,120px) 0;background:var(--mist)}
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.service-img{aspect-ratio:3/4;background-size:cover;background-position:center;margin-bottom:22px;filter:grayscale(.15);transition:.7s var(--ease)}
.service:hover .service-img{filter:grayscale(0);transform:translateY(-6px)}
.service h3{font-size:1.5rem;margin-bottom:.5em}
.service p{font-size:.92rem;color:var(--ink-soft)}

/* ============ 360 EXPLORE ============ */
.explore{padding:clamp(80px,10vw,130px) 0;background:var(--ink);color:#fff}
.explore .section-head{margin:0 auto 48px;text-align:center}
.explore h2{color:#fff}
/* scroll-driven panorama: a tall track with a sticky full-height viewport */
.pano-scroll{position:relative;height:240vh}
.pano-sticky{position:sticky;top:0;height:100vh;min-height:520px;overflow:hidden;background:#10161c;display:flex;align-items:center;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.pano-sticky img{height:100%;width:auto;max-width:none;object-fit:cover;will-change:transform;pointer-events:none;user-select:none}
.pano-hint{position:absolute;left:50%;bottom:34px;transform:translateX(-50%);display:flex;align-items:center;gap:10px;padding:11px 20px;background:rgba(24,31,39,.62);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:40px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;transition:opacity .5s}
.pano-hint svg{animation:bob 1.8s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(-2px)}50%{transform:translateY(3px)}}
.pano-hint.hide{opacity:0}
.pano-tag{position:absolute;top:28px;left:28px;z-index:2;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.9);padding:8px 14px;border:1px solid rgba(255,255,255,.25);background:rgba(24,31,39,.45);backdrop-filter:blur(6px)}
.pano-progress{position:absolute;left:0;right:0;bottom:0;height:3px;background:rgba(255,255,255,.12)}
.pano-progress span{display:block;height:100%;width:0;background:var(--orange);transition:width .1s linear}
.explore-note{text-align:center;max-width:40em;margin:46px auto 0;color:rgba(255,255,255,.55);font-size:.92rem}

/* ============ PORTFOLIO ============ */
.portfolio{padding:clamp(70px,9vw,120px) 0 0;background:var(--paper)}
.masonry{column-count:3;column-gap:18px;padding:0 32px;max-width:1320px;margin:50px auto 0}
.tile{position:relative;break-inside:avoid;margin-bottom:18px;overflow:hidden}
.tile img{width:100%;transition:1.1s var(--ease);filter:grayscale(.1)}
.tile:hover img{transform:scale(1.05);filter:grayscale(0)}
.tile figcaption{position:absolute;left:0;bottom:0;right:0;padding:24px 22px 18px;color:#fff;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;background:linear-gradient(transparent,rgba(15,12,10,.8));opacity:0;transform:translateY(8px);transition:.5s var(--ease)}
.tile:hover figcaption{opacity:1;transform:none}

/* ============ AWARDS ============ */
.awards{padding:clamp(70px,9vw,110px) 0;background:var(--paper);text-align:center}
.awards-lead{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.2rem);color:var(--ink-soft);margin-bottom:48px}
.award-row{display:flex;justify-content:center;gap:clamp(30px,7vw,90px);flex-wrap:wrap}
.award{display:flex;flex-direction:column;align-items:center;gap:14px;max-width:14em}
.award-num{font-family:var(--serif);font-size:2.6rem;color:var(--orange);line-height:1}
.award-txt{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);line-height:1.7}
.award-txt em{color:var(--orange-deep);font-style:normal}

/* ============ PROCESS ============ */
.process{padding:clamp(70px,9vw,120px) 0;background:var(--ink-soft);color:#fff}
.process .section-head h2{color:#fff}
.process .kicker{color:var(--orange)}
.steps{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;counter-reset:s}
.steps li{border-top:1px solid rgba(255,255,255,.18);padding-top:22px}
.step-no{font-family:var(--serif);font-size:1.1rem;color:var(--orange);letter-spacing:.1em}
.steps h4{font-size:1.45rem;margin:.5em 0 .4em}
.steps p{font-size:.9rem;color:rgba(255,255,255,.65)}

/* ============ CTA ============ */
.cta{padding:clamp(70px,9vw,120px) 0;background:var(--orange);color:#fff;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;inset:0;background:url('../images/cabinetry.jpg') center/cover;opacity:.12;mix-blend-mode:luminosity}
.cta-inner{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,90px);align-items:center}
.cta h2{color:#fff;margin-bottom:.5em}
.cta-copy p{color:rgba(255,255,255,.85);max-width:26em;margin-bottom:2rem}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.contact-list li{font-size:.92rem;color:rgba(255,255,255,.9);border-top:1px solid rgba(255,255,255,.25);padding-top:14px}
.contact-list strong{display:block;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:3px;font-weight:400}
.cta-form{background:var(--paper);color:var(--ink);padding:clamp(28px,4vw,44px);display:flex;flex-direction:column;gap:16px}
.cta-form label{display:flex;flex-direction:column;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);gap:7px}
.cta-form input,.cta-form select,.cta-form textarea{font-family:var(--sans);font-size:.95rem;padding:12px 14px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:0;resize:vertical}
.cta-form input:focus,.cta-form select:focus,.cta-form textarea:focus{outline:none;border-color:var(--orange)}

/* ============ FOOTER ============ */
.site-footer{background:var(--ink);color:rgba(255,255,255,.7);padding:64px 0 40px}
.foot-grid{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.foot-logo{display:inline-block}
.foot-logo img{height:54px;width:auto;display:block}
.foot-tag{font-size:.85rem;margin-top:14px}
.foot-links{display:flex;gap:26px}
.foot-links a{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;transition:color .3s}
.foot-links a:hover{color:var(--orange)}
.foot-fine{width:100%;font-size:.72rem;color:rgba(255,255,255,.4);border-top:1px solid rgba(255,255,255,.1);padding-top:24px;margin-top:10px}

/* ============ REVEAL ANIM ============ */
/* Only hide when JS is active, so content is never stuck invisible without it */
html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
html.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html.js .reveal{opacity:1;transform:none;transition:none}
}

/* ============ RESPONSIVE ============ */
@media(max-width:1000px){
  .service-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .steps{grid-template-columns:repeat(2,1fr)}
  .masonry{column-count:2}
}
@media(max-width:760px){
  .wrap{padding:0 22px}
  .nav,.header-cta .phone{display:none}
  .site-header .bar{padding:16px 22px}
  .burger{display:flex}
  .nav.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--paper);padding:10px 22px 22px;box-shadow:0 20px 40px rgba(0,0,0,.12)}
  .nav.open a{color:var(--ink);padding:14px 0;border-bottom:1px solid var(--line)}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{text-align:center}
  .service-grid{grid-template-columns:1fr}
  .masonry{column-count:1;padding:0 22px}
  .cta-inner{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
}
