
:root{
  --mouse-x:50%;
  --mouse-y:50%;
  --bg:#171411;
  --bg2:#211c17;
  --cream:#f4eadb;
  --muted:#c7b49b;
  --taupe:#8a7765;
  --gold:#c4a36f;
  --line:rgba(244,234,219,.16);
  --card:rgba(255,255,255,.055);
  --glass:rgba(255,255,255,.08);
  --shadow:0 30px 80px rgba(0,0,0,.35);
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Inter", Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--cream);
  background:
    radial-gradient(circle at 20% 0%, rgba(196,163,111,.15), transparent 35%),
    linear-gradient(180deg,#171411 0%,#211c17 45%,#171411 100%);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed; inset:0;
  background:
    radial-gradient(circle at 15% 20%, rgba(196,163,111,.055), transparent 28%),
    radial-gradient(circle at 85% 10%, rgba(244,234,219,.035), transparent 25%),
    url("../images/cad-blueprint-bg.svg") center top / 1250px auto repeat-y;
  opacity:.28;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.82), rgba(0,0,0,.62) 42%, rgba(0,0,0,.36) 78%, rgba(0,0,0,.16) 100%);
  pointer-events:none;
  z-index:-2;
}
body::after{
  content:"";
  position:fixed; inset:0;
  background:
    radial-gradient(240px circle at var(--mouse-x) var(--mouse-y), rgba(244,234,219,.075), rgba(196,163,111,.035) 30%, transparent 68%),
    linear-gradient(105deg, transparent 0 35%, rgba(244,234,219,.012) 35.2% 35.5%, transparent 35.7% 100%),
    linear-gradient(90deg, transparent 0 12%, rgba(196,163,111,.018) 12.1% 12.2%, transparent 12.3% 100%);
  pointer-events:none;
  z-index:-1;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1180px, calc(100% - 40px)); margin-inline:auto}
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  backdrop-filter:blur(18px);
  background:linear-gradient(to bottom, rgba(23,20,17,.86), rgba(23,20,17,.42));
  border-bottom:1px solid var(--line);
}
.nav-inner{height:76px; display:flex; align-items:center; justify-content:space-between; gap:22px}
.brand{font-family:var(--serif); font-size:28px; letter-spacing:.04em}
.brand span{display:block; font-family:var(--sans); font-size:10px; letter-spacing:.34em; text-transform:uppercase; color:var(--muted); margin-top:-5px}
.nav-links{display:flex; gap:22px; align-items:center; font-size:13px; color:#e9dcc8}
.nav-links a{opacity:.82; transition:.25s}
.nav-links a:hover,.nav-links a.active{opacity:1;color:var(--gold)}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:13px 18px; border:1px solid var(--line); border-radius:999px;
  background:rgba(255,255,255,.055); color:var(--cream);
  font-size:13px; letter-spacing:.02em; transition:.25s; cursor:pointer;
}
.btn:hover{transform:translateY(-2px); background:rgba(196,163,111,.15); border-color:rgba(196,163,111,.55)}
.btn.gold{background:var(--gold); color:#19130e; border-color:var(--gold); font-weight:700}
.mobile-toggle{display:none}
.hero{
  min-height:100vh; padding-top:110px; display:grid; align-items:center; position:relative;
}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:54px; align-items:center}
.kicker{color:var(--gold); text-transform:uppercase; letter-spacing:.32em; font-size:12px; margin-bottom:20px}
h1,h2,h3{font-family:var(--serif); margin:0; line-height:.94; font-weight:500}
h1{font-size:clamp(62px, 8.5vw, 132px); letter-spacing:-.055em}
h2{font-size:clamp(44px, 6vw, 90px); letter-spacing:-.045em}
h3{font-size:clamp(28px,3vw,44px); letter-spacing:-.025em}
p{color:#d7c8b7; line-height:1.75; font-size:16px}
.lead{font-size:clamp(18px,2vw,24px); color:#efe4d3; max-width:720px}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap; margin-top:32px}
.stat-row{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:42px}
.stat{padding:18px; border:1px solid var(--line); background:var(--card); border-radius:20px}
.stat strong{font-family:var(--serif); font-size:34px; color:var(--cream); display:block}
.stat span{font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.16em}
.hero-visual{position:relative; min-height:650px}
.stack-card{
  position:absolute; overflow:hidden; border-radius:34px; box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.14); background:#30281f;
}
.stack-card img{height:100%; width:100%; object-fit:cover}
.stack-card.large{inset:40px 0 80px 80px}
.stack-card.small{width:42%; aspect-ratio:4/5; left:0; bottom:20px}
.stack-card.profile{width:38%; aspect-ratio:4/5; right:6%; top:0; border-radius:28px}
.float-note{
  position:absolute; right:0; bottom:20px; width:260px;
  padding:20px; border-radius:22px; background:rgba(23,20,17,.72);
  backdrop-filter:blur(16px); border:1px solid var(--line);
}
section{padding:110px 0; position:relative}
.section-head{display:flex; justify-content:space-between; gap:40px; align-items:flex-end; margin-bottom:48px}
.section-head p{max-width:470px; margin:0}
.scrollytelling{padding:0}
.sticky-wrap{height:430vh; position:relative}
.sticky-scene{
  position:sticky; top:0; height:100vh; overflow:hidden; display:grid; align-items:center;
}
.scene-bg{position:absolute; inset:0; opacity:.55}
.scene-bg img{width:100%; height:100%; object-fit:cover; filter:brightness(.5) saturate(.88)}
.scene-bg::after{content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(23,20,17,.96),rgba(23,20,17,.48),rgba(23,20,17,.88))}
.scene-content{position:relative; z-index:2; display:grid; grid-template-columns:.85fr 1.15fr; gap:48px; align-items:center}
.pin-copy{max-width:430px}
.pin-copy h2{margin-bottom:24px}
.pin-board{position:relative; height:min(70vh,650px); border-radius:36px; border:1px solid var(--line); overflow:hidden; background:rgba(255,255,255,.04); box-shadow:var(--shadow)}
.pin-layer{position:absolute; inset:0; transition:.4s; will-change:transform,opacity}
.pin-layer img{width:100%; height:100%; object-fit:cover}
.pin-layer.plan{mix-blend-mode:screen; opacity:.62; transform:scale(1.08)}
.pin-layer.render{clip-path:inset(0 100% 0 0)}
.pin-layer.final{clip-path:inset(0 100% 0 0)}
.pin-label{
  position:absolute; left:22px; bottom:22px; z-index:5; padding:12px 16px; border-radius:999px;
  background:rgba(0,0,0,.52); border:1px solid rgba(255,255,255,.15); font-size:12px; color:#f4eadb; letter-spacing:.18em; text-transform:uppercase;
}
.grid{display:grid; gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{
  border:1px solid var(--line); background:var(--card); border-radius:28px; overflow:hidden; transition:.35s; position:relative;
}
.card:hover{transform:translateY(-6px); border-color:rgba(196,163,111,.5)}
.card-img{height:300px; overflow:hidden; background:#2a241f}
.card-img img{height:100%; width:100%; object-fit:cover; transition:.7s}
.card:hover .card-img img{transform:scale(1.06)}
.card-body{padding:24px}
.card-body p{margin-bottom:0}
.taglist{display:flex; flex-wrap:wrap; gap:8px; margin:18px 0 0}
.tag{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:#efe2ce; border:1px solid var(--line); border-radius:999px; padding:8px 10px; background:rgba(255,255,255,.04)}
.split-feature{display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:stretch}
.compare-card{position:relative; min-height:470px; border-radius:34px; overflow:hidden; border:1px solid var(--line); background:#211c17}
.compare-card img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
.compare-card .after{clip-path:inset(0 0 0 50%); border-left:2px solid var(--gold)}
.compare-card::after{content:"RENDER  /  REALITY"; position:absolute; left:22px; bottom:22px; padding:10px 14px; background:rgba(0,0,0,.48); border:1px solid var(--line); border-radius:999px; font-size:11px; letter-spacing:.22em}
.text-panel{padding:42px; border-radius:34px; border:1px solid var(--line); background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.025))}
.timeline{position:relative; display:grid; gap:18px}
.timeline::before{content:""; position:absolute; left:18px; top:0; bottom:0; width:1px; background:var(--line)}
.time-item{position:relative; padding:20px 20px 20px 58px; border:1px solid var(--line); background:var(--card); border-radius:24px}
.time-item::before{content:""; position:absolute; left:10px; top:28px; width:17px; height:17px; border-radius:50%; background:var(--gold)}
.process{counter-reset:step; display:grid; grid-template-columns:repeat(5,1fr); gap:12px}
.process-item{counter-increment:step; padding:22px; min-height:150px; border:1px solid var(--line); background:var(--card); border-radius:24px}
.process-item::before{content:"0" counter(step); display:block; color:var(--gold); font-family:var(--serif); font-size:34px; margin-bottom:18px}
.marquee{overflow:hidden; border-block:1px solid var(--line); padding:26px 0; white-space:nowrap; color:rgba(244,234,219,.42); font-family:var(--serif); font-size:54px}
.marquee span{display:inline-block; animation:marquee 34s linear infinite}
@keyframes marquee{to{transform:translateX(-50%)}}
.page-hero{padding-top:150px; padding-bottom:80px}
.page-hero h1{font-size:clamp(56px,7vw,104px)}
.filters{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:34px}
.filter{border:1px solid var(--line); background:var(--card); color:var(--cream); padding:11px 15px; border-radius:999px; cursor:pointer}
.filter.active{background:var(--gold); color:#18120d}
.gallery-item{display:block}
.drawing-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:22px}
.drawing-grid .card-img{height:380px}
.contact-panel{
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
  padding:34px; border-radius:34px; border:1px solid var(--line); background:rgba(255,255,255,.06)
}
.input{width:100%; padding:15px 16px; border-radius:14px; border:1px solid var(--line); background:rgba(255,255,255,.06); color:var(--cream); margin-bottom:12px}
textarea.input{min-height:140px; resize:vertical}
.footer{padding:44px 0; border-top:1px solid var(--line); color:var(--muted)}
.footer-inner{display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap}
.reveal{opacity:0; transform:translateY(34px); transition:opacity .75s ease, transform .75s ease}
.reveal.in{opacity:1; transform:none}
@media(max-width:900px){
  .nav-inner{height:auto; padding:16px 0; align-items:flex-start}
  .mobile-toggle{display:inline-flex}
  .nav-links{display:none; flex-direction:column; align-items:flex-start; width:100%; padding:18px 0}
  .nav-links.open{display:flex}
  .nav-inner{flex-wrap:wrap}
  .hero-grid,.scene-content,.split-feature,.grid-2,.grid-3,.contact-panel,.drawing-grid{grid-template-columns:1fr}
  .hero-visual{min-height:520px}
  .stack-card.large{inset:20px 0 90px 40px}
  .section-head{display:block}
  .process{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .container{width:min(100% - 28px,1180px)}
  section{padding:76px 0}
  .stat-row,.process{grid-template-columns:1fr}
  .hero-visual{min-height:420px}
  .stack-card.profile{display:none}
  .float-note{left:0; right:auto}
  .card-img{height:240px}
  .sticky-wrap{height:auto}
  .sticky-scene{position:relative; height:auto; padding:90px 0}
  .pin-board{height:430px}
  .pin-layer.render,.pin-layer.final{clip-path:none; opacity:.78}
}


/* Homepage v6 refinements */
.scroll-compare .after{
  clip-path:inset(0 100% 0 0);
  transition:clip-path .22s linear;
}
.scroll-compare::before{
  content:"";
  position:absolute;
  top:0; bottom:0;
  left:var(--reveal-x, 0%);
  width:2px;
  background:linear-gradient(to bottom, transparent, var(--gold), transparent);
  z-index:4;
  opacity:.85;
  transition:left .22s linear;
}
.scroll-compare::after{
  content:"PLAN / WORKING VISUAL / FINAL VIEW";
}
.cta-compact{
  grid-template-columns:1.35fr .65fr;
  align-items:center;
  padding:28px 32px;
}
.cta-compact h2{
  font-size:clamp(36px, 4.8vw, 68px);
}
.cta-compact p{
  margin-top:0;
}
@media(max-width:900px){
  .cta-compact{grid-template-columns:1fr; padding:26px;}
}


/* Homepage v7 before/after draggable compare */
.before-after-card{
  position:relative;
  min-height:470px;
  overflow:hidden;
  user-select:none;
  -webkit-user-select:none;
}
.before-after-card .before-img,
.before-after-card .after-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.before-after-card .after-wrap{
  position:absolute;
  inset:0;
  overflow:hidden;
}
.before-after-card::after{
  content:"BEFORE / AFTER";
  position:absolute;
  left:22px;
  bottom:22px;
  padding:10px 14px;
  background:rgba(0,0,0,.48);
  border:1px solid var(--line);
  border-radius:999px;
  font-size:11px;
  letter-spacing:.22em;
}
.compare-handle{
  position:absolute;
  top:0;
  bottom:0;
  width:2px;
  background:rgba(255,255,255,.95);
  box-shadow:0 0 0 1px rgba(0,0,0,.12);
  z-index:4;
  transform:translateX(-1px);
}
.compare-handle span{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:42px;
  height:42px;
  border-radius:50%;
  background:rgba(23,20,17,.84);
  border:1px solid rgba(255,255,255,.4);
  box-shadow:0 10px 25px rgba(0,0,0,.25);
}
.compare-handle span::before,
.compare-handle span::after{
  content:"";
  position:absolute;
  top:50%;
  width:8px;
  height:8px;
  border-top:2px solid #fff;
  border-right:2px solid #fff;
}
.compare-handle span::before{
  left:12px;
  transform:translateY(-50%) rotate(-135deg);
}
.compare-handle span::after{
  right:12px;
  transform:translateY(-50%) rotate(45deg);
}
.compare-label{
  position:absolute;
  top:18px;
  z-index:4;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(23,20,17,.65);
  border:1px solid rgba(255,255,255,.16);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.compare-label.ba-before{ left:18px; }
.compare-label.ba-after{ right:18px; }
.compare-range{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor:ew-resize;
  z-index:5;
}
@media(max-width:560px){
  .before-after-card{min-height:350px;}
}


/* v8 before-after fixes */
.before-after-card .after-wrap{
  clip-path:inset(0 50% 0 0);
}
.compare-label.ba-before,
.compare-label.ba-after{
  clip-path:none !important;
  border-left:0 !important;
  z-index:8;
  opacity:1;
}
.before-after-card .compare-label.ba-after{
  right:18px;
  left:auto;
}
.before-after-card .compare-label.ba-before{
  left:18px;
  right:auto;
}


/* Homepage v10 subtle hero image motion */
.hero-visual .stack-card.large{
  animation:heroFloatLarge 7.5s ease-in-out infinite;
}
.hero-visual .stack-card.small{
  animation:heroFloatSmall 6.8s ease-in-out infinite;
}
.hero-visual .stack-card.profile{
  animation:heroFloatProfile 8.2s ease-in-out infinite;
}
@keyframes heroFloatLarge{
  0%,100%{ translate:0 0; rotate:0deg; }
  50%{ translate:0 -10px; rotate:-.25deg; }
}
@keyframes heroFloatSmall{
  0%,100%{ translate:0 0; rotate:0deg; }
  50%{ translate:0 8px; rotate:.35deg; }
}
@keyframes heroFloatProfile{
  0%,100%{ translate:0 0; rotate:0deg; }
  50%{ translate:0 -7px; rotate:.3deg; }
}
.hero-visual .stack-card{
  will-change:translate, rotate;
}
@media (prefers-reduced-motion: reduce){
  .hero-visual .stack-card.large,
  .hero-visual .stack-card.small,
  .hero-visual .stack-card.profile{
    animation:none;
  }
}


/* Expertise v13 refinements */
.grid-4{
  grid-template-columns:repeat(4,1fr);
}
.kitchen-clean-grid .card-img,
.service-grid .card-img,
.detailing-grid .card-img{
  height:260px;
}
.technical-img img{
  object-fit:cover;
  object-position:center top;
  background:#f4efe7;
}
.detailing-grid .card-body,
.service-grid .card-body{
  min-height:156px;
}
@media(max-width:1100px){
  .grid-4{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:620px){
  .grid-4{grid-template-columns:1fr;}
  .kitchen-clean-grid .card-img,
  .service-grid .card-img,
  .detailing-grid .card-img{height:240px;}
}


/* Expertise v14 Furniture Detailing redesign */
.detailing-showcase{
  display:grid;
  grid-template-columns:380px minmax(0, 1fr);
  gap:28px;
  align-items:start;
}
.detailing-sidebar{
  position:sticky;
  top:110px;
  padding:22px;
  border:1px solid var(--line);
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  backdrop-filter:blur(8px);
}
.detailing-sidebar-head h3{
  margin:6px 0 10px;
  font-size:clamp(26px, 3vw, 38px);
}
.detailing-sidebar-head p{
  color:var(--muted);
  margin:0 0 18px;
}
.detail-tabs{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.detail-tab{
  display:grid;
  grid-template-columns:56px 1fr;
  align-items:center;
  gap:12px;
  width:100%;
  text-align:left;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
  color:var(--text);
  cursor:pointer;
  transition:all .22s ease;
}
.detail-tab .num{
  font-family:"Cormorant Garamond", serif;
  font-size:28px;
  line-height:1;
  color:var(--gold);
}
.detail-tab .label{
  font-size:15px;
  line-height:1.35;
}
.detail-tab:hover,
.detail-tab.is-active{
  border-color:rgba(196,163,111,.4);
  background:rgba(196,163,111,.08);
  transform:translateX(4px);
}
.detailing-stage{
  min-width:0;
}
.detail-panel{
  display:none;
  border:1px solid var(--line);
  border-radius:30px;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
  backdrop-filter:blur(8px);
}
.detail-panel.is-active{
  display:block;
}
.detail-media{
  background:#f2ede5;
  border-bottom:1px solid var(--line);
}
.detail-media img{
  width:100%;
  height:min(58vw, 620px);
  object-fit:contain;
  object-position:center;
  display:block;
}
.detail-copy{
  padding:28px 28px 30px;
}
.detail-copy h3{
  margin:8px 0 12px;
  font-size:clamp(34px, 4vw, 56px);
}
.detail-copy p{
  max-width:72ch;
  color:var(--muted);
}
@media(max-width:1100px){
  .detailing-showcase{
    grid-template-columns:1fr;
  }
  .detailing-sidebar{
    position:static;
  }
  .detail-media img{
    height:420px;
  }
}
@media(max-width:720px){
  .detail-tab{
    grid-template-columns:42px 1fr;
    padding:12px 14px;
  }
  .detail-tab .num{
    font-size:22px;
  }
  .detail-copy{
    padding:22px;
  }
  .detail-copy h3{
    font-size:42px;
  }
  .detail-media img{
    height:300px;
  }
}


/* Works v15 project-based structure */
.works-project-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:24px;
}
.work-project-card{
  display:grid;
  grid-template-columns:44% 1fr;
  min-height:360px;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:34px;
  background:linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
  transition:.35s ease;
}
.work-project-card:hover{
  transform:translateY(-6px);
  border-color:rgba(196,163,111,.55);
}
.work-project-media{
  position:relative;
  min-height:100%;
  background:#2a241f;
  overflow:hidden;
}
.work-project-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:.7s ease;
}
.work-project-card:hover .work-project-media img{
  transform:scale(1.06);
}
.work-number{
  position:absolute;
  left:18px;
  top:18px;
  font-family:var(--serif);
  font-size:44px;
  color:rgba(244,234,219,.85);
  line-height:1;
  z-index:3;
}
.work-number.small{
  position:static;
  display:block;
  color:var(--gold);
  font-size:34px;
  margin-bottom:10px;
}
.work-project-copy{
  padding:30px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.work-project-copy h3{
  margin:8px 0 14px;
}
.work-link{
  margin-top:22px;
  color:var(--gold);
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.project-hero-cover{
  border-radius:34px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  height:min(62vh, 620px);
}
.project-hero-cover img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.project-compare-list{
  display:grid;
  gap:34px;
}
.project-compare-item{
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) minmax(280px, .85fr);
  gap:28px;
  align-items:stretch;
}
.project-ba{
  min-height:520px;
}
.project-compare-copy{
  padding:34px;
  border:1px solid var(--line);
  border-radius:30px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.project-compare-copy h3{
  margin-bottom:16px;
}
.project-compare-copy p{
  max-width:48ch;
}
@media(max-width:1100px){
  .works-project-grid{grid-template-columns:1fr;}
  .project-compare-item{grid-template-columns:1fr;}
}
@media(max-width:720px){
  .work-project-card{grid-template-columns:1fr;}
  .work-project-media{min-height:260px;}
  .project-ba{min-height:360px;}
}


/* v16 project page refinements */
.compare-showcase{
  display:grid;
  gap:22px;
}
.compare-main{
  border:1px solid var(--line);
  border-radius:34px;
  overflow:hidden;
  background:rgba(255,255,255,.035);
}
.compare-slide{
  display:none;
}
.compare-slide.is-active{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:0;
}
.compact-ba{
  min-height:min(62vh, 620px);
  border-radius:0;
  border:0;
}
.compare-slide-caption{
  padding:38px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-left:1px solid var(--line);
}
.compare-thumb-grid{
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:12px;
}
.compare-thumb{
  padding:0;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:rgba(255,255,255,.045);
  color:var(--cream);
  cursor:pointer;
  text-align:left;
  transition:.25s ease;
}
.compare-thumb img{
  width:100%;
  height:92px;
  object-fit:cover;
}
.compare-thumb span{
  display:inline-block;
  padding:10px 10px 0;
  color:var(--gold);
  font-family:var(--serif);
  font-size:24px;
}
.compare-thumb strong{
  display:block;
  padding:0 10px 12px;
  font-size:13px;
  line-height:1.25;
}
.compare-thumb.is-active,
.compare-thumb:hover{
  transform:translateY(-3px);
  border-color:rgba(196,163,111,.55);
  background:rgba(196,163,111,.08);
}
.curated-gallery-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:24px;
}
.gallery-tile{
  position:relative;
  min-height:440px;
  border:1px solid var(--line);
  border-radius:34px;
  overflow:hidden;
  background:#211c17;
}
.gallery-tile img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:.7s ease;
}
.gallery-tile:hover img{
  transform:scale(1.04);
}
.gallery-tile-copy{
  position:absolute;
  left:0; right:0; bottom:0;
  padding:28px;
  background:linear-gradient(to top, rgba(23,20,17,.92), rgba(23,20,17,.08));
}
.tech-sheet-list{
  display:grid;
  gap:24px;
}
.tech-sheet{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:0;
  border:1px solid var(--line);
  border-radius:34px;
  overflow:hidden;
  background:linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.tech-sheet:nth-child(even){
  grid-template-columns:.9fr 1.1fr;
}
.tech-sheet:nth-child(even) .tech-sheet-image{
  order:2;
}
.tech-sheet-image{
  background:#f4efe7;
  min-height:420px;
}
.tech-sheet-image img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
}
.tech-sheet-copy{
  padding:38px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
@media(max-width:1100px){
  .compare-slide.is-active,
  .tech-sheet,
  .tech-sheet:nth-child(even){
    grid-template-columns:1fr;
  }
  .tech-sheet:nth-child(even) .tech-sheet-image{
    order:0;
  }
  .compare-thumb-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
  .curated-gallery-grid{
    grid-template-columns:1fr;
  }
}
@media(max-width:620px){
  .compare-thumb-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .compact-ba{
    min-height:360px;
  }
  .tech-sheet-image{
    min-height:300px;
  }
}


/* v17 unified project viewers + drag cursor */
.before-after-card{cursor:none}.drag-cursor{position:absolute;width:64px;height:64px;border-radius:50%;left:var(--drag-x,50%);top:var(--drag-y,50%);transform:translate(-50%,-50%) scale(.92);display:flex;align-items:center;justify-content:center;background:rgba(23,20,17,.72);border:1px solid rgba(244,234,219,.42);color:var(--cream);font-size:11px;font-weight:700;letter-spacing:.18em;pointer-events:none;z-index:9;opacity:0;transition:opacity .18s ease,transform .18s ease;backdrop-filter:blur(8px)}.before-after-card:hover .drag-cursor{opacity:1;transform:translate(-50%,-50%) scale(1)}
.gallery-showcase{display:grid;gap:22px}.gallery-main{border:1px solid var(--line);border-radius:34px;overflow:hidden;background:rgba(255,255,255,.035)}.gallery-slide{display:none}.gallery-slide.is-active{display:grid;grid-template-columns:1.2fr .8fr}.gallery-main-image{position:relative;min-height:min(62vh,620px);background:#f4efe7;display:flex;align-items:center;justify-content:center;overflow:hidden}.gallery-main-image img{width:100%;height:100%;max-height:min(62vh,620px);object-fit:contain;display:block}.gallery-arrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.34);background:rgba(23,20,17,.72);color:var(--cream);font-size:34px;line-height:1;cursor:pointer;z-index:4;transition:.22s ease}.gallery-arrow:hover{background:rgba(196,163,111,.86);color:#171411}.gallery-arrow.prev{left:18px}.gallery-arrow.next{right:18px}.gallery-slide-caption{padding:38px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid var(--line)}.gallery-thumb-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.gallery-thumb{padding:0;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:rgba(255,255,255,.045);color:var(--cream);cursor:pointer;text-align:left;transition:.25s ease}.gallery-thumb img{width:100%;height:92px;object-fit:cover;background:#f4efe7}.gallery-thumb span{display:inline-block;padding:10px 10px 0;color:var(--gold);font-family:var(--serif);font-size:24px}.gallery-thumb strong{display:block;padding:0 10px 12px;font-size:13px;line-height:1.25}.gallery-thumb.is-active,.gallery-thumb:hover{transform:translateY(-3px);border-color:rgba(196,163,111,.55);background:rgba(196,163,111,.08)}@media(max-width:1100px){.gallery-slide.is-active{grid-template-columns:1fr}.gallery-slide-caption{border-left:0;border-top:1px solid var(--line)}.gallery-thumb-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:620px){.drag-cursor{display:none}.before-after-card{cursor:ew-resize}.gallery-thumb-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.gallery-main-image{min-height:360px}}


/* v20 finished portfolio refinements */
.gallery-slide-caption p,
.compare-slide-caption p,
.work-project-copy p{
  color:#d9cbb7;
}
.project-detail-hero .lead{
  max-width:760px;
}
.gallery-thumb strong,
.compare-thumb strong{
  text-transform:none;
}
.gallery-main-image{
  background:#f7f1e8;
}
