@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Inter:wght@400;500;600;700;800&display=swap');
:root{
  --ink:#151515;
  --ink-soft:#58544d;
  --muted:#8b877e;
  --paper:#f3f2ef;
  --line:rgba(21,21,21,.12);
  --dark:#071211;
  --font:'Inter',Arial,Helvetica,sans-serif;
  --display:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --strict:'Inter',Arial,Helvetica,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--font);overflow:hidden}
a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}img{max-width:100%}

.cursor-follower{position:fixed;left:0;top:0;width:34px;height:34px;border:1.25px solid rgba(255,255,255,.62);border-radius:50%;pointer-events:none;z-index:9999;opacity:0;transform:translate3d(-50%,-50%,0);transition:opacity .22s ease,width .18s ease,height .18s ease,border-color .18s ease,background .18s ease;will-change:transform;mix-blend-mode:difference}.cursor-follower.is-visible{opacity:1}.cursor-follower.is-active{width:58px;height:58px;background:rgba(255,255,255,.08)}.cursor-follower.is-down{width:26px;height:26px}

.site-header{position:fixed;left:0;right:0;top:0;z-index:800;display:grid;grid-template-columns:minmax(0,1fr) clamp(250px,16vw,340px) minmax(0,1fr);align-items:center;padding:26px clamp(24px,2.4vw,52px);color:var(--ink);transition:color .5s ease,background .5s ease,backdrop-filter .5s ease,box-shadow .5s ease;background:rgba(243,242,239,.78);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(0,0,0,.05)}
.site-header.on-light,.site-header.panel-open{color:var(--ink);background:rgba(243,242,239,.92);backdrop-filter:blur(18px);box-shadow:0 1px 0 rgba(0,0,0,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;width:100%;gap:clamp(16px,1.35vw,30px);font-family:var(--strict);font-size:clamp(15px,1vw,18px);font-weight:700;text-transform:uppercase;letter-spacing:.065em}
.nav a,.lang-switch{position:relative;white-space:nowrap;text-shadow:none}
.site-header.on-light .nav a,.site-header.panel-open .nav a,.site-header.on-light .lang-switch,.site-header.panel-open .lang-switch{text-shadow:none}
.nav-left{padding-right:clamp(34px,4vw,90px)}
.nav-right{padding-left:clamp(34px,4vw,90px)}
.nav a:after,.lang-switch a:after{content:"";position:absolute;left:0;right:100%;bottom:-8px;height:1px;background:currentColor;transition:right .3s ease}
.nav a:hover:after,.lang-switch a:hover:after{right:0}
.brand-center{display:block;width:clamp(250px,16vw,340px);line-height:0;justify-self:center}
.brand-center img{width:100%;height:auto;filter:drop-shadow(0 1px 0 rgba(255,255,255,.65));transition:filter .5s ease,opacity .5s ease}
.site-header.on-light .brand-center img,.site-header.panel-open .brand-center img{filter:drop-shadow(0 1px 0 rgba(255,255,255,.65))}
.lang-switch{display:flex;align-items:center;gap:10px;font-weight:700}.lang-switch span{opacity:.45}.lang-switch .is-current{opacity:.55}
.talk-link{padding:0}
.menu-toggle{display:none;background:transparent;border:0;width:38px;height:24px;position:relative;color:inherit}.menu-toggle span{display:block;height:1px;background:currentColor;margin:8px 0}

.site-shell{position:relative;height:100svh}
.project-stack{height:100svh;overflow-y:auto;scroll-snap-type:y mandatory;scrollbar-width:none;overscroll-behavior:contain;scroll-behavior:smooth}.project-stack::-webkit-scrollbar{display:none}
.project-slide{position:relative;height:100svh;scroll-snap-align:start;scroll-snap-stop:always;overflow:hidden;background:#111;color:#fff}
.project-slide picture,.project-slide img{width:100%;height:100%;display:block}.project-slide img{object-fit:cover;object-position:center;transform:scale(1.03);transition:transform 1.8s cubic-bezier(.22,.74,.16,1)}.project-slide.is-active img{transform:scale(1)}
.shade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.18),rgba(0,0,0,.05) 40%,rgba(0,0,0,.44));pointer-events:none}
.slide-copy{position:absolute;z-index:2;width:calc(100vw - clamp(46px,6vw,120px));display:grid;gap:18px}
.slide-copy-center{left:clamp(22px,3vw,60px);right:clamp(22px,3vw,60px);top:57%;transform:translateY(-50%);justify-items:start;text-align:left}
.slide-copy-left{left:clamp(22px,3vw,60px);bottom:clamp(112px,12vw,160px);max-width:min(820px,82vw)}
.slide-copy-right{right:clamp(22px,3vw,60px);bottom:clamp(112px,12vw,160px);max-width:min(760px,76vw);text-align:right;justify-items:end;margin-left:auto}
.project-location{font-family:var(--strict);font-weight:600;font-size:clamp(12px,.95vw,15px);text-transform:uppercase;letter-spacing:.19em;margin:0;text-shadow:0 10px 30px rgba(0,0,0,.25)}
.slide-copy h1,.slide-copy h2{margin:0;color:#fff;text-transform:uppercase;text-wrap:balance;text-shadow:0 18px 70px rgba(0,0,0,.28)}
.slide-copy h1{font-family:var(--strict);font-weight:800;letter-spacing:-.03em;line-height:.9}
.slide-copy h1 span{display:block;font-size:clamp(42px,5.3vw,94px);max-width:none;opacity:.86;-webkit-text-stroke:.55px rgba(255,255,255,.34)}
.slide-copy h2{font-family:var(--strict);font-weight:800;letter-spacing:-.03em;line-height:.92;font-size:clamp(36px,4.5vw,78px)}
.pill{border:0;background:rgba(255,255,255,.9);color:#171717;border-radius:999px;padding:13px 34px;font-family:var(--font);font-weight:650;text-transform:uppercase;font-size:13px;letter-spacing:.08em;cursor:pointer;transition:transform .25s ease,background .25s ease;width:max-content}.pill:hover{transform:translateY(-2px);background:#fff}
.slide-meta{position:absolute;left:28px;right:28px;bottom:22px;z-index:2;display:flex;justify-content:space-between;gap:20px;font-size:13px;text-transform:uppercase;letter-spacing:.05em;text-shadow:0 1px 18px rgba(0,0,0,.35)}

.intro-loader{position:fixed;inset:0;background:var(--dark);z-index:950;display:grid;place-items:center;align-content:center;animation:loaderOut 3.35s ease forwards;color:#fff;pointer-events:none;text-align:center;padding:22px}
.loader-mark{display:grid;justify-items:center;gap:20px}
.loader-mark img{width:min(520px,72vw);opacity:0;animation:loaderLogo 1.5s ease .15s forwards}
.loader-subtitle{margin:26px 0 0;font-size:clamp(16px,1.5vw,24px);letter-spacing:.16em;text-transform:uppercase;opacity:0;animation:loaderLogo 1.55s ease .45s forwards}
@keyframes loaderLogo{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes loaderOut{0%,72%{opacity:1;visibility:visible}100%{opacity:0;visibility:hidden}}

.hover-preview{position:fixed;top:84px;left:50%;width:min(1000px,calc(100% - 64px));height:310px;z-index:600;transform:translate(-50%,-30px);opacity:0;pointer-events:none;transition:opacity .35s ease,transform .7s cubic-bezier(.16,.84,.2,1);overflow:hidden;background:#111;color:#fff;box-shadow:0 30px 90px rgba(0,0,0,.24)}.hover-preview.is-visible{opacity:1;transform:translate(-50%,0)}
.hover-preview-bg{position:absolute;inset:0;background:url('assets/project-courtyard.jpg') center/cover;filter:brightness(.7);transform:scale(1.08);transition:transform .85s ease}.hover-preview.is-visible .hover-preview-bg{transform:scale(1)}
.hover-preview-content{position:absolute;left:42px;right:42px;bottom:34px}.hover-preview-content span{display:block;font-family:var(--font);font-weight:700;text-transform:uppercase;letter-spacing:.14em;margin-bottom:10px}.hover-preview-content strong{font-size:clamp(26px,3.8vw,66px);text-transform:uppercase;line-height:.88;font-family:var(--strict);font-weight:800;letter-spacing:-.03em}

.side-panel{position:fixed;inset:0;z-index:500;background:var(--paper);display:grid;grid-template-columns:46% 54%;transform:translate3d(100%,0,0);transition:transform 1.95s cubic-bezier(.68,0,.18,1);visibility:hidden;color:var(--ink)}
.side-panel.is-open{transform:translate3d(0,0,0);visibility:visible}
.side-panel .panel-visual,.side-panel .panel-content{min-height:100svh}
.panel-visual{position:relative;overflow:hidden;background:#111}.panel-visual:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.18),rgba(0,0,0,.02))}
.panel-visual img{display:block;width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.065);transition:transform 2.05s cubic-bezier(.68,0,.18,1)}.side-panel.is-open .panel-visual img{transform:scale(1)}
.panel-content{padding:136px clamp(30px,4.6vw,84px) 56px;overflow:auto}
.panel-content-centered{display:flex;flex-direction:column;justify-content:center}
.panel-kicker{font-family:var(--strict);font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);font-size:13px;margin:0 0 22px}
.panel-content h2,.project-modal h2{font-family:var(--strict);font-weight:800;font-size:clamp(44px,5vw,92px);line-height:.88;letter-spacing:-.035em;text-transform:uppercase;margin:0 0 30px}
.panel-text{font-size:19px;line-height:1.72;max-width:760px;color:var(--ink-soft)}
.panel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-top:1px solid var(--line);border-left:1px solid var(--line)}
.panel-card{min-height:210px;padding:28px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:grid;align-content:space-between;gap:16px;transition:background .25s ease}.panel-card:hover{background:#ebe9e3}.panel-card span{font-size:13px;color:var(--muted)}.panel-card strong{display:block;font-family:var(--strict);font-weight:800;font-size:34px;line-height:.92;letter-spacing:-.03em;text-transform:uppercase}.panel-card em{font-style:normal;color:var(--muted);line-height:1.5}
.service-detail{margin-top:30px;padding:26px 0;border-top:1px solid var(--line)}.service-detail h3{font-size:24px;text-transform:uppercase;margin:0 0 10px;font-family:var(--strict);letter-spacing:-.02em}.service-detail p{margin:0;max-width:760px;line-height:1.72;color:var(--ink-soft)}
.price-list,.process-list{display:grid;gap:0;border-top:1px solid var(--line);max-width:960px}.price-list article,.process-list li{display:grid;grid-template-columns:220px 1fr;gap:26px;padding:24px 0;border-bottom:1px solid var(--line)}.price-list strong{font-family:var(--strict);font-weight:800;font-size:34px;text-transform:uppercase;letter-spacing:-.03em}.price-list span,.process-list strong{text-transform:uppercase;font-weight:800}.price-list p,.process-list span{margin:0;color:var(--muted);line-height:1.58}.process-list{list-style:none;padding:0;margin:0}
.contact-lines{display:grid;gap:14px;font-family:var(--strict);font-weight:700;font-size:clamp(24px,3vw,44px);margin-bottom:34px}.contact-form{display:grid;gap:12px;max-width:680px}.contact-form input,.contact-form textarea{width:100%;border:0;border-bottom:1px solid var(--line);background:transparent;padding:18px 0;color:#111}.contact-form textarea{min-height:120px;resize:vertical}
.panel-end-cta{margin-top:42px;padding-top:30px;border-top:1px solid var(--line);display:grid;gap:18px}.panel-end-cta p{margin:0;font-size:18px;line-height:1.68;color:var(--ink-soft);max-width:720px}.panel-cta{display:inline-flex;align-items:center;justify-content:center;width:max-content;margin-top:0;background:#171717;color:#fff;border-radius:999px;padding:15px 28px;text-transform:uppercase;letter-spacing:.08em;font-size:13px}
.panel-footer{margin-top:58px;border-top:1px solid var(--line);padding-top:24px;color:#666;font-size:13px;line-height:1.55}.panel-footer-large{margin-top:68px}.panel-footer p{margin:0 0 14px}.panel-footer div{display:flex;gap:22px;flex-wrap:wrap;text-transform:uppercase;color:#111}
.project-modal{position:fixed;left:0;right:0;top:96px;bottom:0;z-index:650;background:var(--paper);transform:translateY(100%);transition:transform .85s cubic-bezier(.16,.84,.2,1);visibility:hidden;overflow:auto}.project-modal.is-open{transform:translateY(0);visibility:visible}
.project-close{position:absolute;right:28px;top:26px;border:0;background:transparent;text-transform:uppercase;font-size:12px;letter-spacing:.09em;cursor:pointer;z-index:4}
.project-modal-inner{padding:120px 48px 60px;max-width:1500px;margin:auto}.project-modal p{font-size:18px;line-height:1.7;max-width:760px;color:#555}
.project-gallery{margin-top:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.project-gallery img{height:360px;width:100%;object-fit:cover;background:#ddd}
.mobile-menu{position:fixed;inset:0;background:#0c0c0c;color:#fff;z-index:450;display:grid;place-content:center;gap:22px;text-align:center;transform:translateY(-100%);transition:transform .5s ease}.mobile-menu.is-open{transform:translateY(0)}.mobile-menu a{text-transform:uppercase;font-size:28px;font-family:var(--strict);font-weight:800;letter-spacing:-.03em}

@media (max-width:1280px){
  .nav{font-size:14px;gap:16px}
  .site-header{position:fixed;left:0;right:0;top:0;z-index:800;display:grid;grid-template-columns:minmax(0,1fr) clamp(250px,16vw,340px) minmax(0,1fr);align-items:center;padding:26px clamp(24px,2.4vw,52px);color:var(--ink);transition:color .5s ease,background .5s ease,backdrop-filter .5s ease,box-shadow .5s ease;background:rgba(243,242,239,.78);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(0,0,0,.05)}
}
@media (max-width:1180px){
  body{overflow:auto}
  .nav{display:none}
  .site-header{position:fixed;left:0;right:0;top:0;z-index:800;display:grid;grid-template-columns:minmax(0,1fr) clamp(250px,16vw,340px) minmax(0,1fr);align-items:center;padding:26px clamp(24px,2.4vw,52px);color:var(--ink);transition:color .5s ease,background .5s ease,backdrop-filter .5s ease,box-shadow .5s ease;background:rgba(243,242,239,.78);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(0,0,0,.05)}
  .brand-center{grid-column:1;width:178px}
  .menu-toggle{display:block;justify-self:end}
  .side-panel{grid-template-columns:1fr}
  .panel-visual{height:34vh}.panel-content{padding:94px 24px 44px}
  .panel-grid,.project-gallery{grid-template-columns:1fr}
  .project-gallery img{height:auto}
  .project-slide{min-height:100svh}
  .slide-copy-center,.slide-copy-left,.slide-copy-right{left:24px;right:24px;bottom:auto;top:56%;transform:translateY(-50%);max-width:none;justify-items:start;text-align:left}
  .slide-copy-right{margin-left:0}
  .slide-meta{display:grid}
  .project-stack{scroll-snap-type:y proximity}
  .hover-preview{display:none}
}
@media (max-width:720px){
  .site-header{position:fixed;left:0;right:0;top:0;z-index:800;display:grid;grid-template-columns:minmax(0,1fr) clamp(250px,16vw,340px) minmax(0,1fr);align-items:center;padding:26px clamp(24px,2.4vw,52px);color:var(--ink);transition:color .5s ease,background .5s ease,backdrop-filter .5s ease,box-shadow .5s ease;background:rgba(243,242,239,.78);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(0,0,0,.05)}
  .brand-center{width:142px}
  .slide-copy h1 span{font-size:clamp(34px,10vw,52px)}
  .slide-copy h2{font-size:clamp(32px,10vw,50px)}
  .project-location{font-size:11px;letter-spacing:.14em}
  .slide-meta{font-size:10px;left:18px;right:18px}
  .pill{font-size:12px;padding:11px 24px}
  .loader-subtitle{font-size:13px;letter-spacing:.1em}
  .panel-content h2,.project-modal h2{font-size:clamp(34px,11vw,60px)}
  .price-list article,.process-list li{grid-template-columns:1fr}
  .contact-lines{font-size:25px}
  .cursor-follower{display:none}
}
@media (prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}.intro-loader{display:none}}

/* v2.7: force exact central axis for first hero text */
.hero-slide .slide-copy-center{
  left:50%!important;
  right:auto!important;
  top:55%!important;
  width:min(1480px,92vw)!important;
  max-width:min(1480px,92vw)!important;
  transform:translate(-50%,-50%)!important;
  justify-items:center!important;
  align-items:center!important;
  text-align:center!important;
  margin:0!important;
}
.hero-slide .slide-copy-center .project-location,
.hero-slide .slide-copy-center h1,
.hero-slide .slide-copy-center h1 span,
.hero-slide .slide-copy-center .pill{
  text-align:center!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.hero-slide .slide-copy-center h1{
  display:grid!important;
  justify-items:center!important;
  width:100%!important;
}
.hero-slide .slide-copy-center h1 span{
  width:100%!important;
  text-align:center!important;
}

/* v2.8: final hero centering on the image */
.hero-slide .slide-copy-center{
  position:absolute!important;
  left:50%!important;
  top:55%!important;
  right:auto!important;
  width:100vw!important;
  max-width:100vw!important;
  transform:translate(-50%,-50%)!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  padding-left:clamp(20px,3vw,60px)!important;
  padding-right:clamp(20px,3vw,60px)!important;
  margin:0!important;
}
.hero-slide .slide-copy-center .project-location,
.hero-slide .slide-copy-center h1,
.hero-slide .slide-copy-center .pill{
  margin-left:auto!important;
  margin-right:auto!important;
  text-align:center!important;
}
.hero-slide .slide-copy-center h1{
  width:100%!important;
  display:block!important;
  text-align:center!important;
}
.hero-slide .slide-copy-center h1 span{
  display:block!important;
  width:auto!important;
  max-width:none!important;
  margin-left:auto!important;
  margin-right:auto!important;
  text-align:center!important;
}

/* v2.8: project modal starts below fixed header so navigation always works */
.project-modal{
  top:96px!important;
  bottom:0!important;
  left:0!important;
  right:0!important;
  z-index:650!important;
}
.project-modal-inner{padding-top:60px!important}
.project-close{top:18px!important}
.site-header{z-index:900!important}

/* v2.9: native-feeling project scroll and project object overview */
.project-stack{
  scroll-snap-type:y mandatory!important;
  scroll-behavior:smooth!important;
}
.project-slide{
  scroll-snap-stop:normal!important;
}

/* project overview / object cards */
.project-modal-inner{
  max-width:1700px!important;
}
.project-gallery{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:16px!important;
}
.project-card{
  position:relative;
  display:block;
  min-height:360px;
  overflow:hidden;
  background:#111;
  color:#fff;
  cursor:pointer;
  border:0;
  padding:0;
  text-align:left;
}
.project-card img{
  width:100%!important;
  height:100%!important;
  min-height:360px;
  display:block;
  object-fit:cover;
  transform:scale(1.02);
  transition:transform .8s cubic-bezier(.16,.84,.2,1), filter .8s cubic-bezier(.16,.84,.2,1);
}
.project-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,.62));
  opacity:.78;
  transition:opacity .45s ease;
}
.project-card:hover img{
  transform:scale(1.075);
  filter:brightness(.72);
}
.project-card:hover::after{
  opacity:1;
}
.project-card-copy{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  z-index:2;
  transform:translateY(18px);
  opacity:.0;
  transition:opacity .45s ease, transform .45s cubic-bezier(.16,.84,.2,1);
}
.project-card:hover .project-card-copy{
  transform:translateY(0);
  opacity:1;
}
.project-card-copy span{
  display:block;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.16em;
  opacity:.78;
  margin-bottom:8px;
}
.project-card-copy strong{
  display:block;
  font-family:var(--strict);
  font-size:clamp(25px,2.2vw,42px);
  line-height:.92;
  letter-spacing:-.03em;
  text-transform:uppercase;
}
.project-back{
  display:none;
  border:0;
  background:transparent;
  color:var(--ink);
  text-transform:uppercase;
  letter-spacing:.1em;
  font-weight:700;
  font-size:12px;
  padding:0;
  margin-bottom:24px;
  cursor:pointer;
}
.project-modal.is-detail .project-back{
  display:inline-flex;
}
.project-detail-grid{
  margin-top:40px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.project-detail-grid img{
  width:100%;
  height:520px;
  object-fit:cover;
  background:#ddd;
}
@media (max-width:980px){
  .project-gallery{grid-template-columns:1fr!important}
  .project-card,.project-card img{min-height:310px}
  .project-card-copy{opacity:1;transform:none}
  .project-detail-grid{grid-template-columns:1fr}
  .project-detail-grid img{height:auto}
}

/* v3.0: stronger Back to objects button */
.project-back{
  display:none;
  position:sticky;
  top:0;
  z-index:20;
  width:max-content;
  align-items:center;
  gap:12px;
  border:1px solid rgba(21,21,21,.22)!important;
  background:#171717!important;
  color:#fff!important;
  border-radius:999px;
  padding:14px 24px!important;
  margin:0 0 32px!important;
  text-transform:uppercase;
  letter-spacing:.09em;
  font-weight:800;
  font-size:13px!important;
  box-shadow:0 18px 44px rgba(0,0,0,.18);
  transition:transform .25s ease, background .25s ease, box-shadow .25s ease;
}
.project-back::before{
  content:"←";
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:26px;
  height:26px;
  border-radius:50%;
  background:rgba(255,255,255,.14);
  font-size:18px;
  line-height:1;
}
.project-back:hover{
  transform:translateY(-2px);
  background:#000!important;
  box-shadow:0 22px 54px rgba(0,0,0,.25);
}
.project-modal.is-detail .project-back{
  display:inline-flex!important;
}
.project-modal.is-detail .project-back{
  animation:backPulse 2.4s ease-in-out infinite;
}
@keyframes backPulse{
  0%,100%{box-shadow:0 18px 44px rgba(0,0,0,.18)}
  50%{box-shadow:0 18px 44px rgba(0,0,0,.18),0 0 0 8px rgba(0,0,0,.055)}
}
@media (max-width:720px){
  .project-back{
    top:8px;
    padding:12px 18px!important;
    font-size:12px!important;
  }
}

/* v3.1: iPhone / mobile navigation and panels fix */
@media (max-width:1180px){
  body.has-panel{
    overflow:hidden;
  }

  .site-header{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    min-height:96px!important;
    padding:18px 22px!important;
    color:var(--ink)!important;
    background:rgba(243,242,239,.96)!important;
    backdrop-filter:blur(18px)!important;
    z-index:1400!important;
  }

  .brand-center{
    position:absolute!important;
    left:50%!important;
    top:50%!important;
    transform:translate(-50%,-50%)!important;
    width:clamp(156px,42vw,210px)!important;
    max-width:58vw!important;
    grid-column:auto!important;
    justify-self:center!important;
  }

  .brand-center img{
    display:block!important;
    width:100%!important;
    height:auto!important;
    object-fit:contain!important;
    object-position:center!important;
  }

  .menu-toggle{
    display:block!important;
    position:absolute!important;
    right:clamp(24px,8vw,58px)!important;
    top:50%!important;
    transform:translateY(-50%)!important;
    z-index:1450!important;
    width:44px!important;
    height:34px!important;
    padding:0!important;
  }

  .menu-toggle span{
    height:1.5px!important;
    margin:9px 0!important;
    background:var(--ink)!important;
  }

  .mobile-menu{
    z-index:1350!important;
    padding-top:118px!important;
    background:rgba(243,242,239,.98)!important;
    color:var(--ink)!important;
    align-content:start!important;
    justify-content:center!important;
    overflow:auto!important;
    gap:18px!important;
  }

  .mobile-menu a{
    font-size:clamp(25px,7.2vw,42px)!important;
    color:var(--ink)!important;
  }

  .side-panel{
    z-index:900!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    -webkit-overflow-scrolling:touch!important;
    display:block!important;
    height:100svh!important;
    padding-top:96px!important;
  }

  .side-panel .panel-visual{
    height:36svh!important;
    min-height:260px!important;
    max-height:390px!important;
  }

  .side-panel .panel-content{
    min-height:auto!important;
    overflow:visible!important;
    padding:42px 22px 54px!important;
  }

  .panel-grid{
    grid-template-columns:1fr!important;
  }

  .panel-card{
    min-height:150px!important;
    padding:24px 20px!important;
  }

  .panel-card strong{
    font-size:clamp(27px,8vw,42px)!important;
  }

  .price-list article,
  .process-list li{
    grid-template-columns:1fr!important;
  }

  .contact-lines{
    font-size:clamp(22px,7vw,34px)!important;
    overflow-wrap:anywhere!important;
  }

  .project-modal{
    top:96px!important;
    z-index:910!important;
  }

  .project-modal-inner{
    padding:42px 22px 60px!important;
  }

  .project-close{
    top:14px!important;
    right:22px!important;
  }
}

@media (max-width:720px){
  .site-header{
    min-height:100px!important;
  }

  .brand-center{
    width:clamp(150px,44vw,190px)!important;
    max-width:56vw!important;
  }

  .menu-toggle{
    right:clamp(26px,10vw,60px)!important;
  }

  .side-panel{
    padding-top:100px!important;
  }

  .project-modal{
    top:100px!important;
  }
}

/* v3.2: price cards reuse service layout and long labels fit better */
.price-panel-grid .panel-card strong,
.services-panel-grid .panel-card strong{
  overflow-wrap:anywhere;
}
.price-panel-grid .panel-card strong{
  font-size:clamp(28px,2.2vw,34px);
}
@media (max-width:1180px){
  .price-panel-grid .panel-card strong,
  .services-panel-grid .panel-card strong{
    font-size:clamp(24px,7vw,38px)!important;
  }
}
