/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behaviour:smooth;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{cursor:pointer;border:none;background:none;font:inherit;}

/* ── TOKENS ── */
:root{
  --bg:#f7f3ed;--bg-alt:#ede6db;
  --ink:#1c140c;--ink-mid:#4d3d2d;--ink-soft:#9a8570;
  --accent:#8b4513;--accent-hi:#a85520;
  --border:rgba(80,55,30,0.10);
  --display:"Georgia",serif;
  --body:"Helvetica",sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}

/* ── BODY ── */
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--body);font-weight:300;
  overflow-x:hidden;
  transition:background .5s,color .5s;
}

/* ── CUSTOM CURSOR ── */
@media(hover:hover){
  body{cursor:none;}
  .c-dot,.c-ring{
    position:fixed;pointer-events:none;z-index:9999;
    border-radius:50%;transform:translate(-50%,-50%);will-change:left,top;
  }
  .c-dot{width:7px;height:7px;background:var(--accent);transition:transform .12s var(--ease),background .4s;}
  .c-ring{
    width:36px;height:36px;
    border:1.5px solid color-mix(in srgb,var(--accent) 35%,transparent);
    transition:width .35s var(--ease),height .35s var(--ease),border-color .4s;
  }
  body.cursor-hover .c-dot{transform:translate(-50%,-50%) scale(2.8);}
  body.cursor-hover .c-ring{width:54px;height:54px;}
}

/* ── NAV ── */
.nav{
  position:fixed;inset:0 0 auto;z-index:300;
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(16px,2.5vw,26px) clamp(18px,5vw,60px);
  transition:background .4s,backdrop-filter .4s;
}
.nav.stuck{
  background:color-mix(in srgb,var(--bg) 85%,transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.nav-logo{
  font-family:var(--display);font-size:clamp(15px,1.4vw,18px);
  font-weight:400;letter-spacing:-.01em;color:var(--ink);
  display:flex;flex-direction:column;gap:4px;
}
.nav-brand{
  display:block;line-height:1;
}
.nav-dash{
  color:var(--accent);margin:0 2px;
}
.nav-accent{
  color:var(--accent);
}
.nav-tagline{
  font-family:var(--body);font-size:clamp(8px,0.8vw,10px);
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:300;
  line-height:1.2;
}
.nav-logo em{font-style:italic;color:var(--accent);}
.nav-links{display:flex;gap:clamp(18px,2.5vw,36px);list-style:none;}
.nav-links a{
  font-family:var(--body);font-size:11px;
  letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink-mid);transition:color .2s;
}
.nav-links a:hover{color:var(--accent);}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:4px;}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--ink);transition:.3s;}

/* Mobile overlay — lives outside <nav> to avoid stacking context issues */
/* Mobile overlay — hidden on desktop, shown only on mobile */
.nav-mobile-overlay{
  display:none !important;
}

@media(max-width:640px){
  .nav-desktop{display:none;}
  .nav-burger{display:flex;}

  .nav-mobile-overlay{
    display:none !important;
    list-style:none;
    position:fixed;
    inset:0;
    z-index:250;
    background:var(--bg);
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:12px;
    padding:20px 24px;
  }
  .nav-mobile-overlay.open{
    display:flex !important;
  }
  .nav-mobile-overlay li a{
    display:block;
    font-family:var(--body);
    font-size:20px;
    letter-spacing:.06em;
    text-transform:uppercase;
    background:var(--bg-alt);
    color:var(--ink);
    padding:14px 36px;
    border-radius:4px;
    border:1px solid var(--border);
    text-align:center;
    min-width:240px;
    transition:background .2s, color .2s;
  }
  .nav-mobile-overlay li a:hover{
    background:var(--accent);
    color:#fff;
    border-color:var(--accent);
  }
}

/* ── HERO ── */
.hero{
  min-height:100svh;
  border-bottom:1px solid var(--border);
  display:grid;
  grid-template-columns:55% 45%;
  padding:0 clamp(18px,5vw,60px);
  padding-top:clamp(68px,8vw,96px);
  position:relative;overflow:hidden;
  align-items:stretch;
}
.hero-left{
  display:flex;flex-direction:column;justify-content:center;
  padding-bottom:clamp(40px,7vw,90px);
  z-index:2;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--body);font-size:10px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--accent);
  margin-bottom:clamp(18px,2.5vw,32px);
}
.hero-tag::before{content:'';width:28px;height:1px;background:var(--accent);flex-shrink:0;}
.hero-h1{
  font-family:var(--display);
  font-size:clamp(38px,6vw,88px);
  font-weight:400;line-height:.98;letter-spacing:-.025em;
  color:var(--ink);margin-bottom:clamp(18px,2.5vw,32px);
}
.hero-h1 em{font-style:italic;color:var(--accent);}
.hero-desc{
  font-family:var(--body);
  font-size:clamp(14px,1.15vw,17px);
  line-height:1.78;color:var(--ink-mid);
  max-width:38ch;margin-bottom:clamp(28px,3.5vw,48px);
}
.hero-cta{
  align-self:flex-start;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--body);font-size:11px;letter-spacing:.13em;text-transform:uppercase;
  padding:14px 26px;
  background:var(--ink);color:var(--bg);
  transition:background .25s,color .25s;position:relative;overflow:hidden;
}
.hero-cta::after{
  content:'';position:absolute;inset:0;
  background:var(--accent);transform:translateX(-101%);
  transition:transform .35s var(--ease);z-index:0;
}
.hero-cta:hover::after{transform:translateX(0);}
.hero-cta span{position:relative;z-index:1;display:flex;align-items:center;gap:10px;}
.hero-cta svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .25s;}
.hero-cta:hover svg{transform:translateX(4px);}

.hero-right{
  position:relative;display:flex;align-items:flex-end;justify-content:center;
  overflow:visible;padding-bottom:0;
}
.hero-right img{
  height:min(90vh,720px);width:auto;
  object-fit:contain;object-position:bottom center;
  position:relative;z-index:1;
  filter:drop-shadow(0px 32px 48px rgba(0,0,0,0.16)) drop-shadow(0px 8px 20px rgba(0,0,0,0.10));
}
/* Subtle warm glow behind photo */
.hero-right::before{
  content:'';position:absolute;
  bottom:0;left:50%;transform:translateX(-50%);
  width:80%;height:60%;border-radius:50%;
  background:radial-gradient(ellipse at center bottom,color-mix(in srgb,var(--accent) 10%,transparent) 0%,transparent 70%);
  z-index:0;
}

.hero-scroll{
  position:absolute;bottom:clamp(20px,3vw,36px);left:clamp(18px,5vw,60px);
  display:flex;align-items:center;gap:12px;
  font-family:var(--body);font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-soft);
}
.hero-scroll-bar{
  width:36px;height:1px;background:var(--ink-soft);
  animation:scpulse 2.4s ease-in-out infinite;
}
@keyframes scpulse{0%,100%{opacity:.2}50%{opacity:.8}}


/* ── SECTION WRAPPER ── */
.wrap{padding:clamp(64px,9vw,130px) clamp(18px,5vw,60px);}
.wrap-alt{background:var(--bg-alt);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}

/* ── SECTION LABEL ── */
.s-label{
  font-family:var(--body);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.s-label::after{content:'';width:32px;height:1px;background:var(--accent);opacity:.5;}

/* ── SECTION HEADLINE ── */
.s-h2{
  font-family:var(--display);
  font-size:clamp(30px,4vw,58px);
  font-weight:400;line-height:1.06;letter-spacing:-.02em;color:var(--ink);
  margin-bottom:clamp(20px,2.5vw,36px);
}
.s-h2 em{font-style:italic;color:var(--accent);}

/* ── PROBLEM ── */
.problem-grid{
  display:grid;grid-template-columns:1fr 1.7fr;
  gap:clamp(36px,6vw,100px);align-items:start;
}
.problem-sticky{position:sticky;top:120px;}
.problem-body{
  font-family:var(--body);font-size:clamp(14px,1.1vw,17px);
  line-height:1.82;color:var(--ink-mid);font-weight:300;
}
.problem-body p{margin-bottom:20px;}
.problem-body strong{color:var(--ink);font-weight:500;}
.blockq{
  margin:clamp(24px,3.5vw,44px) 0;
  padding-left:22px;border-left:2px solid var(--accent);
  font-family:var(--display);font-size:clamp(18px,1.8vw,26px);
  font-style:italic;line-height:1.45;color:var(--ink);
}

/* ── PARALLAX ── */
.par-root{height:400vh;}
.par-stick{
  position:sticky;top:0;height:100svh;
  display:grid;
}
.panel{
  position:absolute;inset:0;
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,3vw,48px);
  align-items:center;
  padding:clamp(80px,10vw,120px) clamp(18px,5vw,60px) clamp(32px,4vw,60px);
  opacity:0;pointer-events:none;transition:opacity .55s var(--ease);
}
@media(max-width:640px){
  .panel{
    grid-template-columns:1fr;
    align-items:start;
    align-content:start;
    gap:clamp(20px,4vw,32px);
    padding-top:clamp(80px,14vw,110px);
    overflow-y:auto;
  }
  .panel .panel-inline-list{
    width:clamp(176px,60.5vw,242px);
    height:clamp(176px,60.5vw,242px);
    margin:0 auto;
  }
}
.panel.on{opacity:1;pointer-events:auto;}
.panel-h{
  font-family:var(--display);
  font-size:clamp(32px,4.5vw,66px);
  font-weight:400;line-height:1.04;letter-spacing:-.02em;
  color:var(--ink);
  margin-bottom:18px;
  text-shadow:0 1px 4px rgba(0,0,0,0.35),0 3px 16px rgba(0,0,0,0.20),0 0 1px rgba(0,0,0,0.15);
}
.panel-h em{
  font-style:italic;
  color:var(--accent);
  text-shadow:0 1px 4px rgba(0,0,0,0.35),0 3px 16px rgba(0,0,0,0.20),0 0 1px rgba(0,0,0,0.15);
}
.panel-p{
  font-family:var(--body);font-size:clamp(14px,1.1vw,17px);
  line-height:1.76;
  color:var(--ink-mid);
  max-width:38ch;font-weight:400;
  text-shadow:0 1px 3px rgba(0,0,0,0.28),0 2px 10px rgba(0,0,0,0.15);
}
/* ── PANEL INLINE LIST CIRCLE ── */
.panel-inline-list {
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  width:clamp(198px,19.8vw,264px);
  height:clamp(198px,19.8vw,264px);
  padding:clamp(18px,2.2vw,31px);
  border-radius:50%;
  box-sizing:border-box;
  background:transparent;
  overflow:hidden;
  justify-self:center;
  transition: transform 0.3s cubic-bezier(.22,1,.36,1);
}
.panel-inline-list::before {
  content:'';
  position:absolute;inset:0;
  border-radius:50%;
  background:var(--accent-hi);
  opacity:0.7;
  mix-blend-mode:overlay;
  z-index:0;
}
.panel-inline-list > * {
  position:relative;z-index:1;
}
.panel-inline-ttl {
  font-family:var(--display);font-size:clamp(9px,1vw,12px);letter-spacing:.16em;text-transform:uppercase;
  color:#ffffff;margin-bottom:8px;
}
.panel-inline-list ul {
  list-style:none;padding:0;margin:0;width:100%;
}
.panel-inline-list ul li {
  font-family:var(--body);font-size:clamp(10px,0.94vw,12px);line-height:1.55;
  color:#ffffff;padding:2px 0;
  border-bottom:none;
}
.panel-inline-list ul li:last-child{border:none;}
.par-dots{
  position:absolute;bottom:clamp(20px,3vw,40px);left:50%;
  transform:translateX(-50%);display:flex;gap:8px;
}
.par-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--ink-soft);opacity:.25;transition:all .4s var(--ease);
}
.par-dot.on{background:var(--accent);opacity:1;width:22px;border-radius:3px;}

/* ── SERVICES ── */
.svc-intro{max-width:56ch;margin-bottom:clamp(32px,4vw,56px);}
.svc-intro p{
  font-family:var(--body);font-size:clamp(14px,1.1vw,17px);
  line-height:1.78;color:var(--ink-mid);font-weight:300;
}
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  grid-auto-rows:minmax(360px, auto);
  align-items:stretch;
  border-top:1px solid var(--border);border-left:1px solid var(--border);
}
.svc-item{
  position:relative;
  border-right:1px solid var(--border);border-bottom:1px solid var(--border);
  transition:background .3s;
  display:flex;
  flex-direction:column;
}
.svc-item:not(.svc-card):hover{background:var(--bg-alt);}
.svc-n{
  font-family:var(--display);font-style:italic;font-size:13px;
  color:var(--accent);margin-bottom:18px;
}
.svc-name{
  font-family:var(--display);font-size:clamp(17px,1.5vw,21px);
  font-weight:400;line-height:1.2;color:var(--ink);margin-bottom:10px;
}
.svc-desc{
  font-family:var(--body);font-size:13px;line-height:1.75;
  color:var(--ink-mid);font-weight:300;
}

/* ── PROCESS ── */
.proc-head{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,90px);align-items:end;margin-bottom:clamp(40px,5vw,70px);
}
.proc-intro{
  font-family:var(--body);font-size:clamp(14px,1.1vw,17px);
  line-height:1.8;color:var(--ink-mid);font-weight:300;
}
.steps{display:flex;flex-direction:column;}
.step{
  display:grid;grid-template-columns:52px 1fr 1.2fr;
  gap:clamp(16px,2.5vw,44px);align-items:start;
  padding:clamp(20px,2.5vw,36px) 0;
  border-bottom:1px solid var(--border);
  opacity:1;
}


.step:first-child{border-top:1px solid var(--border);}
.step.on{opacity:1;}
.step:hover{opacity:1;}
.step-n{
  font-family:var(--display);font-style:italic;
  font-size:clamp(26px,2.8vw,38px);color:var(--accent);
  line-height:1;opacity:.55;
}
.step-tag{
  font-family:var(--body);font-size:10px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--accent);display:block;margin-bottom:6px;
}
.step-title{
  font-family:var(--display);font-size:clamp(16px,1.4vw,20px);
  font-weight:400;color:var(--ink);
}
.step-desc{
  font-family:var(--body);font-size:13px;line-height:1.75;
  color:var(--ink-mid);font-weight:300;align-self:start;
  grid-column:3;
}

/* ── CASES ── */
.cases-list{border-top:1px solid var(--border);margin-top:clamp(32px,4vw,56px);}
.case-row{
  display:grid;grid-template-columns:90px 1fr auto 24px;
  gap:clamp(14px,2.5vw,36px);align-items:center;
  padding:clamp(18px,2.2vw,28px) 0;border-bottom:1px solid var(--border);
  position:relative;transition:background .25s;
}
.case-row::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;height:1.5px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;
  transition:transform .38s var(--ease);
}
.case-row:hover::after{transform:scaleX(1);}
.case-row:hover .case-name{color:var(--accent);}
.case-sector{
  font-family:var(--body);font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);
}
.case-name{
  font-family:var(--display);font-size:clamp(17px,1.6vw,22px);
  font-weight:400;color:var(--ink);transition:color .25s;
}
.case-tags{
  font-family:var(--body);font-size:12px;color:var(--ink-soft);
  line-height:1.6;text-align:right;
}
.case-arr{color:var(--ink-soft);font-size:17px;transition:transform .25s,color .25s;}
.case-row:hover .case-arr{transform:translateX(4px);color:var(--accent);}

/* ── CASE MODAL ── */
.case-modal-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,0.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;transition:opacity .4s var(--ease);
  display:flex;align-items:flex-end;justify-content:center;
}
.case-modal-overlay.open{opacity:1;pointer-events:auto;}
.case-modal{
  width:100%;max-width:900px;max-height:92vh;
  background:var(--bg);border-top:1px solid var(--border);
  border-radius:12px 12px 0 0;overflow-y:auto;
  transform:translateY(40px);transition:transform .45s var(--ease);
  padding:clamp(32px,5vw,64px) clamp(20px,5vw,64px) clamp(40px,6vw,80px);
  position:relative;
}
.case-modal-overlay.open .case-modal{transform:translateY(0);}
.case-modal-close{
  position:sticky;top:0;float:right;
  width:38px;height:38px;border-radius:50%;
  border:1px solid var(--border);background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;color:var(--ink-mid);cursor:pointer;
  transition:background .2s,color .2s;z-index:10;margin-bottom:-38px;
}
.case-modal-close:hover{background:var(--accent);color:#fff;}
.case-modal-sector{
  font-family:var(--body);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);margin-bottom:10px;
  display:flex;align-items:center;gap:10px;
}
.case-modal-sector::before{content:'';width:24px;height:1px;background:var(--accent);flex-shrink:0;}
.case-modal-title{
  font-family:var(--display);font-size:clamp(26px,4vw,52px);
  font-weight:400;line-height:1.06;letter-spacing:-.02em;color:var(--ink);
  margin-bottom:clamp(24px,3vw,40px);
}
.case-modal-title em{font-style:italic;color:var(--accent);}
.case-modal-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:clamp(28px,4vw,48px);}
.case-modal-tag{
  font-family:var(--body);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-mid);border:1px solid var(--border);padding:5px 12px;
}
.case-modal-images{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
  margin-bottom:clamp(28px,4vw,48px);
}
.case-img-placeholder{
  background:var(--bg-alt);border:1.5px dashed color-mix(in srgb,var(--accent) 35%,transparent);
  border-radius:4px;aspect-ratio:16/9;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;color:var(--ink-soft);transition:background .2s,border-color .2s;
}
.case-img-placeholder:hover{background:color-mix(in srgb,var(--accent) 6%,var(--bg-alt));border-color:var(--accent);}
.case-img-placeholder svg{width:28px;height:28px;stroke:currentColor;stroke-width:1.5;fill:none;opacity:.5;}
.case-img-placeholder span{font-family:var(--body);font-size:10px;letter-spacing:.14em;text-transform:uppercase;opacity:.6;}
.case-img-placeholder.wide{grid-column:1/-1;aspect-ratio:21/9;}
.case-modal-section{margin-bottom:clamp(24px,3vw,40px);}
.case-modal-section-label{
  font-family:var(--body);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);margin-bottom:12px;padding-bottom:10px;
  border-bottom:1px solid var(--border);
}
.case-modal-body{
  font-family:var(--body);font-size:clamp(14px,1.05vw,16px);
  line-height:1.82;color:var(--ink-mid);font-weight:300;
}
.case-modal-body p{margin-bottom:14px;}
.case-modal-body p:last-child{margin-bottom:0;}
.case-modal-body strong{color:var(--ink);font-weight:500;}
.case-modal-body ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px;}
.case-modal-body ul li{
  padding-left:18px;position:relative;
  font-family:var(--body);font-size:clamp(13px,1vw,15px);line-height:1.75;color:var(--ink-mid);font-weight:300;
}
.case-modal-body ul li::before{content:'—';position:absolute;left:0;color:var(--accent);font-size:11px;top:3px;}
.case-modal-pull{
  font-family:var(--display);font-size:clamp(18px,2vw,26px);
  font-style:italic;line-height:1.45;color:var(--ink);
  border-left:2px solid var(--accent);padding-left:22px;
  margin:clamp(24px,3vw,36px) 0;
}
@media(max-width:640px){
  .case-modal-images{grid-template-columns:1fr;}
  .case-img-placeholder.wide{aspect-ratio:16/9;}
}
/* ── TESTIMONIALS ── */
.testi-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2.5vw,28px);
  margin-top:clamp(32px,4vw,56px);
}
.testi-card{
  border:1px solid var(--border);
  padding:clamp(24px,3vw,40px);
  display:flex;flex-direction:column;gap:20px;
  transition:background .3s;
}
.testi-card:hover{background:var(--bg-alt);}
.testi-mark{
  font-family:var(--display);font-size:52px;line-height:.7;
  color:var(--accent);opacity:.35;font-style:italic;
  user-select:none;
}
.testi-quote{
  font-family:var(--display);font-size:clamp(15px,1.3vw,18px);
  font-style:italic;line-height:1.6;color:var(--ink);
  font-weight:400;flex:1;
}
.testi-divider{width:28px;height:1px;background:var(--accent);opacity:.5;}
.testi-author{display:flex;align-items:center;gap:14px;}
.testi-headshot{overflow:hidden;
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:var(--bg);border:1.5px dashed color-mix(in srgb,var(--accent) 35%,transparent);
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s;
}
.testi-headshot:hover{border-color:var(--accent);}
.testi-headshot svg{width:16px;height:16px;stroke:var(--ink-soft);stroke-width:1.5;fill:none;opacity:.5;}
.testi-author-text{display:flex;flex-direction:column;gap:4px;}
.testi-name{
  font-family:var(--body);font-size:13px;
  font-weight:500;color:var(--ink);
}
.testi-role{
  font-family:var(--body);font-size:11px;letter-spacing:.08em;
  color:var(--ink-soft);line-height:1.5;
}
@media(max-width:900px){.testi-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.testi-grid{grid-template-columns:1fr;}}
/* ── ABOUT ── */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(36px,7vw,100px);align-items:center;
}
.about-img-wrap{
  position:relative;overflow:hidden;
  background:var(--bg-alt);min-height:380px;
  display:flex;align-items:flex-end;justify-content:center;
  border-bottom:1px solid var(--border);
}
/* Warm grain texture overlay */
.about-img-wrap::after{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:.5;pointer-events:none;z-index:2;mix-blend-mode:multiply;
}
.about-img-wrap img{
  width:auto;height:clamp(320px,48vh,580px);
  object-fit:contain;object-position:bottom center;
  position:relative;z-index:1;
  filter:drop-shadow(0px 24px 40px rgba(0,0,0,0.18)) drop-shadow(0px 8px 16px rgba(0,0,0,0.12));
}
.about-body p{
  font-family:var(--body);font-size:clamp(14px,1.1vw,17px);
  line-height:1.82;color:var(--ink-mid);font-weight:300;
  margin-bottom:18px;
}
.about-body p strong{color:var(--ink);font-weight:500;}

/* ── CONTACT ── */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(36px,7vw,100px);
}
.contact-lede{
  font-family:var(--display);
  font-size:clamp(26px,3.2vw,48px);
  font-weight:400;line-height:1.12;color:var(--ink);margin-bottom:28px;
}
.contact-lede em{font-style:italic;color:var(--accent);}
.contact-email-lbl{
  font-family:var(--body);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:5px;
}
.contact-email{
  font-family:var(--display);font-size:clamp(15px,1.3vw,19px);
  color:var(--accent);transition:color .25s;
}
.contact-email:hover{color:var(--ink);}
.contact-loc{
  font-family:var(--body);font-size:13px;color:var(--ink-soft);
  line-height:1.7;margin-top:28px;padding-top:28px;
  border-top:1px solid var(--border);
}
.form{display:flex;flex-direction:column;gap:22px;}
.field{display:flex;flex-direction:column;gap:6px;}
.field label{
  font-family:var(--body);font-size:10px;
  letter-spacing:.15em;text-transform:uppercase;color:var(--ink-soft);
}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:14px;font-weight:300;
  background:transparent;color:var(--ink);
  border:none;border-bottom:1.5px solid var(--border);
  padding:9px 0;outline:none;width:100%;
  transition:border-color .25s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);}
.field select{-webkit-appearance:none;appearance:none;}
.field select option{background:var(--bg);color:var(--ink);}
.field textarea{resize:none;height:68px;}
.btn{
  align-self:flex-start;
  font-family:var(--body);font-size:11px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--bg);background:var(--ink);padding:14px 26px;
  display:inline-flex;align-items:center;gap:10px;
  transition:background .25s;position:relative;overflow:hidden;
}
.btn::after{
  content:'';position:absolute;inset:0;background:var(--accent);
  transform:translateX(-101%);transition:transform .35s var(--ease);z-index:0;
}
.btn:hover::after{transform:translateX(0);}
.btn span{position:relative;z-index:1;display:flex;align-items:center;gap:10px;}

/* ── FOOTER ── */
footer{
  border-top:1px solid var(--border);
  padding:clamp(20px,2.5vw,30px) clamp(18px,5vw,60px);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;
}
.f-copy{font-family:var(--body);font-size:11px;color:var(--ink-soft);letter-spacing:.04em;}
.f-links{display:flex;gap:24px;list-style:none;align-items:center;}
.f-links li{display:flex;align-items:center;}
.f-links a{
  font-family:var(--body);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);transition:color .2s;
  display:inline-flex;align-items:center;gap:7px;
}
.f-links a:hover{color:var(--accent);}


/* ── FADE-IN ── */
.fu{opacity:0;transform:translateY(22px);transition:opacity .85s var(--ease),transform .85s var(--ease);}
.fu.in{opacity:1;transform:none;}
.fu.d1{transition-delay:.07s;}.fu.d2{transition-delay:.14s;}
.fu.d3{transition-delay:.21s;}.fu.d4{transition-delay:.28s;}

/* ── RESPONSIVE ── */
@media(max-width:1060px){
  .hero{grid-template-columns:1fr;padding-top:clamp(80px,12vw,110px);}
  .hero-right{grid-row:1;height:52vw;min-height:200px;align-items:flex-end;}
  .hero-right img{height:100%;}
  .hero-left{grid-row:2;padding-bottom:clamp(32px,5vw,60px);}
  .hero-scroll{position:static;margin-top:auto;padding-bottom:clamp(24px,4vw,40px);}
  .problem-grid{grid-template-columns:1fr;}
  .problem-sticky{position:static;}
  .panel{grid-template-columns:1fr;}
  .proc-head{grid-template-columns:1fr;gap:20px;}
  .about-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .svc-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:600px){
  .svc-grid{grid-template-columns:1fr;}
  .step{grid-template-columns:40px 1fr;}
  .step-desc{grid-column:2;}
  .case-row{grid-template-columns:1fr auto;grid-template-rows:auto auto;}
  .case-sector{grid-column:1/3;}
  .case-tags{display:none;}
  .hero-right{height:65vw;}
}

  to   { opacity:1; transform:none; }
}


/* ── SERVICE CARD FLIP ── */
.svc-card {
  cursor:pointer;
  display:flex;
  flex-direction:column;
  height:100%;
}
.svc-card:hover { background:color-mix(in srgb,var(--accent) 3%,var(--bg)); }
.svc-front, .svc-back {
  position:absolute; inset:0;
  padding:clamp(24px,3vw,44px) clamp(18px,2.2vw,32px);
  display:flex; flex-direction:column;
  transition:opacity .35s ease, transform .35s ease;
  will-change:opacity, transform;
}
.svc-front {
  opacity:1; pointer-events:auto;
  transform:translateY(0);
}
.svc-back {
  opacity:0; pointer-events:none;
  transform:translateY(8px);
  background:color-mix(in srgb,var(--accent) 8%,var(--bg-alt));
  border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);
}
.svc-card.flipped .svc-front {
  opacity:0; pointer-events:none;
  transform:translateY(-8px);
}
.svc-card.flipped .svc-back {
  opacity:1; pointer-events:auto;
  transform:translateY(0);
}
.svc-hint {
  display:block;
  font-family:var(--body);font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);margin-top:auto;padding-top:16px;
  opacity:.7;transition:opacity .2s;
}
.svc-card:hover .svc-hint { opacity:1; }
.svc-tip-tag {
  font-family:var(--body);font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);margin-bottom:16px;font-weight:500;
}
.svc-tip-text {
  font-family:var(--body);font-size:13px;line-height:1.78;
  color:var(--ink-mid);font-weight:300;flex:1;
}








/* ── PANEL PHOTO BACKGROUNDS ── */
.panel-photo {
  position:absolute;
  inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 40%;
  z-index:0;
  pointer-events:none;
  filter:
    grayscale(15%)
    sepia(20%)
    hue-rotate(var(--panel-hue, 0deg))
    saturate(0.80)
    brightness(0.68);
}
/* Gradient overlay — left side readable, right side reveals image */
.panel::after {
  content:'';
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--bg) 92%, transparent) 0%,
      color-mix(in srgb, var(--bg) 72%, transparent) 38%,
      color-mix(in srgb, var(--bg) 20%, transparent) 62%,
      transparent 100%
    );
  pointer-events:none;
}
/* s-label inside panels — stronger colour + shadow for readability */
.panel .s-label{
  color:var(--accent);
  text-shadow:0 1px 3px rgba(0,0,0,0.25),0 2px 8px rgba(0,0,0,0.12);
}
/* All panel content above photo + overlay */
.panel > div {
  position:relative;
  z-index:2;
}

/* ── CONTACT MODAL ── */
.contact-overlay{
  position:fixed;inset:0;z-index:300;
  background:rgba(0,0,0,0.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;transition:opacity .4s var(--ease);
  display:flex;align-items:flex-end;justify-content:center;
}
.contact-overlay.open{opacity:1;pointer-events:auto;}
.contact-modal{
  width:100%;max-width:680px;max-height:92vh;
  background:var(--bg);border-top:1px solid var(--border);
  border-radius:12px 12px 0 0;overflow-y:auto;
  transform:translateY(40px);transition:transform .45s var(--ease);
  padding:clamp(32px,5vw,64px) clamp(24px,5vw,64px) clamp(40px,6vw,80px);
  position:relative;
}
.contact-overlay.open .contact-modal{transform:translateY(0);}
.contact-modal-close{
  position:sticky;top:0;float:right;
  width:38px;height:38px;border-radius:50%;
  border:1px solid var(--border);background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;color:var(--ink-mid);cursor:pointer;
  transition:background .2s,color .2s;z-index:10;margin-bottom:-38px;
}
.contact-modal-close:hover{background:var(--accent);color:#fff;}
.contact-modal-sector{
  font-family:var(--body);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);margin-bottom:10px;
  display:flex;align-items:center;gap:10px;
}
.contact-modal-sector::before{content:'';width:24px;height:1px;background:var(--accent);flex-shrink:0;}
.contact-modal-title{
  font-family:var(--display);font-size:clamp(26px,3.5vw,44px);
  font-weight:400;line-height:1.06;letter-spacing:-.02em;color:var(--ink);
  margin-bottom:8px;
}
.contact-modal-title em{font-style:italic;color:var(--accent);}
.contact-modal-sub{
  font-family:var(--body);font-size:clamp(13px,1vw,15px);
  line-height:1.75;color:var(--ink-mid);font-weight:300;
  margin-bottom:clamp(28px,3.5vw,44px);
}
.contact-form{display:flex;flex-direction:column;gap:20px;}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:540px){.cf-row{grid-template-columns:1fr;}}
.cf-field{display:flex;flex-direction:column;gap:7px;}
.cf-field label{
  font-family:var(--body);font-size:10px;letter-spacing:.15em;
  text-transform:uppercase;color:var(--ink-mid);
}
.cf-field input,
.cf-field select,
.cf-field textarea{
  font-family:var(--body);font-size:14px;font-weight:300;
  color:var(--ink);background:transparent;
  border:none;border-bottom:1px solid var(--border);
  padding:10px 0;outline:none;width:100%;
  transition:border-color .2s;appearance:none;
  -webkit-appearance:none;
}
.cf-field select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239a8570' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 4px center;
  padding-right:20px;cursor:pointer;
}
.cf-field input:focus,
.cf-field select:focus,
.cf-field textarea:focus{border-bottom-color:var(--accent);}
.cf-field input::placeholder,
.cf-field textarea::placeholder{color:var(--ink-soft);}
.cf-field textarea{resize:vertical;min-height:100px;line-height:1.7;}
.cf-submit{
  align-self:flex-start;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--body);font-size:11px;letter-spacing:.13em;text-transform:uppercase;
  padding:14px 28px;margin-top:8px;
  background:var(--ink);color:var(--bg);
  border:none;cursor:pointer;
  transition:background .25s,color .25s;position:relative;overflow:hidden;
}
.cf-submit::after{
  content:'';position:absolute;inset:0;
  background:var(--accent);transform:translateX(-101%);
  transition:transform .35s var(--ease);z-index:0;
}
.cf-submit:hover::after{transform:translateX(0);}
.cf-submit span{position:relative;z-index:1;display:flex;align-items:center;gap:10px;}
.cf-submit svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .25s;}
.cf-submit:hover svg{transform:translateX(4px);}
.cf-success{
  display:none;text-align:center;
  padding:clamp(32px,5vw,56px) 0;
}
.cf-success-icon{
  width:52px;height:52px;border-radius:50%;
  background:color-mix(in srgb,var(--accent) 12%,transparent);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;
}
.cf-success-icon svg{width:22px;height:22px;stroke:var(--accent);stroke-width:2;fill:none;}
.cf-success h3{
  font-family:var(--display);font-size:clamp(20px,2vw,28px);
  font-weight:400;color:var(--ink);margin-bottom:10px;
}
.cf-success p{
  font-family:var(--body);font-size:14px;line-height:1.75;
  color:var(--ink-mid);font-weight:300;max-width:34ch;margin:0 auto;
}

