:root{
  --bg:#ffffff;
  --ink:#0a0a0a;
  --muted:#777;
  --line:#e8e8e8;
  --beige:#f3f0ea;
  --max:1200px;

  --sans: "Montserrat","Avenir Next","Segoe UI",sans-serif;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  --r: 14px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);letter-spacing:-0.01em}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(var(--max), 92vw); margin:0 auto}

.muted{color:var(--muted);line-height:1.7}
.small{font-size:13px}
.mono{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--muted)}
.lead{font-size:18px;line-height:1.65;margin:0 0 10px}

.title{margin:0;font-size:clamp(24px,3vw,42px);letter-spacing:-0.03em}
.huge{margin:0 0 10px;font-size:clamp(34px,4.5vw,60px);letter-spacing:-0.04em;line-height:0.95}

.topbar{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}

.brand{font-weight:800;letter-spacing:-0.02em}
.brand__name{font-weight:400}
.brand__surname{font-weight:800}

.nav{display:flex;gap:18px;align-items:center}
.nav a{color:var(--muted)}
.nav a:hover{color:var(--ink)}
.nav .is-current{color:var(--ink);font-weight:700}

.menuBtn{display:none;border:1px solid var(--line);background:transparent;padding:10px 12px;border-radius:999px;cursor:pointer}
.mobileNav{display:none;padding:10px 4vw 16px;border-top:1px solid var(--line)}
.mobileNav a{display:block;padding:10px 0;color:var(--muted)}
.mobileNav.is-open{display:block}

.hero{position:relative;min-height:62vh;border-bottom:1px solid var(--line)}
.hero__media{position:absolute;inset:0;background-size:cover;background-position:center}
.hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.38))}
.hero__text{position:relative;min-height:62vh;display:flex;align-items:flex-end;padding:42px 0}
.hero__kicker{font-size:clamp(22px,5vw,76px);color:#fff;opacity:.95;font-weight:500}
.hero__title h1{margin:6px 0 0;font-size:clamp(34px,6vw,96px);line-height:.95;letter-spacing:-0.03em;color:#fff;font-weight:800}
.hero__cta{margin-top:14px}

.section{padding:54px 0}
.section--beige{background:var(--beige);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

.btn{border:1px solid rgba(10,10,10,.28);background:transparent;padding:12px 14px;border-radius:999px;cursor:pointer;font-weight:700;display:inline-flex;align-items:center;gap:8px}
.btn:hover{border-color:rgba(10,10,10,.5)}
.btn--link{border:none;padding:0;border-radius:0;font-weight:800}
.btn--solid{background:#111318;color:#fff;border-color:#111318}
.btn--solid:hover{background:#232730;border-color:#232730}
.btn--ghostLight{border-color:rgba(255,255,255,.56);color:#fff;background:rgba(255,255,255,.06);backdrop-filter:blur(6px)}
.btn--ghostLight:hover{border-color:rgba(255,255,255,.84);background:rgba(255,255,255,.12)}

.twoCol{display:grid;grid-template-columns:1fr .9fr;gap:22px;align-items:start}
.panel{border:1px solid var(--line);border-radius:var(--r);padding:18px;background:#fff}

/* Home page */
.homePage{
  background:
    radial-gradient(1100px 420px at 0% 0%, rgba(18,39,58,.12), transparent 70%),
    radial-gradient(950px 380px at 100% 0%, rgba(190,142,90,.18), transparent 72%),
    #f5f2ec;
  font-family:var(--sans);
}
.homePage .topbar{background:rgba(245,242,236,.86);border-bottom:1px solid rgba(16,18,22,.12)}
.homePage .brand{font-weight:700;letter-spacing:-0.01em}
.homePage .brand__surname{font-weight:800}
.homePage .nav a{color:#666a71}

.homeHero{position:relative;overflow:hidden;min-height:84vh;padding:120px 0 74px;border-bottom:1px solid rgba(16,18,22,.1)}
.homeHero__media{position:absolute;inset:0;background:url("assets/cover.jpg") center/cover no-repeat;transform:scale(1.06)}
.homeHero__veil{position:absolute;inset:0;background:
  linear-gradient(108deg,rgba(7,11,16,.78) 16%,rgba(7,11,16,.34) 52%,rgba(7,11,16,.68) 100%),
  radial-gradient(650px 360px at 86% 75%,rgba(219,161,105,.22),transparent 65%);
}
.homeHero__inner{position:relative;min-height:62vh;display:grid;grid-template-columns:1.2fr .8fr;gap:42px;align-items:end}
.homeKicker{margin:0 0 16px;font-size:11px;letter-spacing:.24em;color:rgba(255,255,255,.74);font-weight:700}
.homeKicker--dark{color:#7d8189}
.homeHero h1{margin:0;font-family:var(--sans);font-weight:400;line-height:.95;font-size:clamp(44px,7vw,102px);color:#fff;max-width:14ch}
.homeHero h1 span{display:block;opacity:.86}
.homeLead{margin:18px 0 0;max-width:46ch;color:rgba(255,255,255,.86);font-size:17px;line-height:1.7}
.homeHero__actions{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}
.homeHero__right{display:flex;justify-content:flex-end}
.homeBadge{width:min(360px,100%);padding:22px;border:1px solid rgba(255,255,255,.28);border-radius:18px;background:rgba(255,255,255,.08);backdrop-filter:blur(8px);color:#fff}
.homeBadge__title{font-size:11px;letter-spacing:.2em;color:rgba(255,255,255,.74)}
.homeBadge__name{display:inline-block;margin-top:8px;font-family:var(--sans);font-size:30px;line-height:1.08}
.homeBadge p{margin:14px 0 0;color:rgba(255,255,255,.82);line-height:1.6;font-size:14px}

.homeStats{background:#101318;color:#f2f4f5;border-bottom:1px solid rgba(255,255,255,.08)}
.homeStats__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:24px 0}
.homeStat{padding:10px 10px 10px 2px}
.homeStat__value{margin:0;font-family:var(--sans);font-size:clamp(34px,4vw,54px);line-height:1}
.homeStat__label{margin:6px 0 0;color:rgba(242,244,245,.74);line-height:1.5;font-size:14px;max-width:26ch}

.homeServices{background:#f5f2ec}
.homeServices__grid{display:grid;grid-template-columns:1fr 1.08fr;gap:32px;align-items:start}
.homeServices__intro h2{margin:0 0 16px;font-family:var(--sans);font-size:clamp(36px,4.4vw,64px);line-height:1.02;max-width:13ch}
.homeServices__intro .muted{max-width:52ch}
.homeServices__list{display:grid;gap:12px}
.homeService{border:1px solid rgba(16,18,22,.13);background:rgba(255,255,255,.62);border-radius:16px;padding:20px}
.homeService h3{margin:0 0 8px;font-size:24px;letter-spacing:-.01em}
.homeService p{margin:0;color:#545860;line-height:1.6}

.homeFeatured{background:#fff;border-top:1px solid rgba(16,18,22,.08);border-bottom:1px solid rgba(16,18,22,.08)}
.homeFeatured__head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding-bottom:20px}
.homeFeatured__head h2{margin:0;font-family:var(--sans);font-size:clamp(34px,4vw,58px);line-height:1}
.homeFeatured__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.homeProjectCard{display:block}
.homeProjectCard img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:16px;border:1px solid rgba(16,18,22,.1);transition:transform .45s ease,filter .45s ease}
.homeProjectCard__meta{padding:12px 2px 0}
.homeProjectCard__title{margin:0;font-weight:800;letter-spacing:.01em}
.homeProjectCard__type{margin:6px 0 0;color:#727780;font-size:12px;text-transform:uppercase;letter-spacing:.12em}
.homeProjectCard:hover img{transform:translateY(-4px) scale(1.01);filter:contrast(1.04)}

.homeCta{padding-top:26px;padding-bottom:74px;background:linear-gradient(180deg,#f5f2ec 0%,#efe9df 100%)}
.homeCta__panel{position:relative;overflow:hidden;border-radius:22px;padding:36px;border:1px solid rgba(16,18,22,.14);background:#13161b;color:#fff}
.homeCta__panel::after{content:"";position:absolute;inset:auto -60px -120px auto;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(221,167,111,.4),rgba(221,167,111,0) 70%)}
.homeCta__panel h2{margin:8px 0 22px;font-family:var(--sans);font-size:clamp(30px,3.8vw,54px);line-height:1.05;max-width:20ch}
.footer--home{background:#f5f2ec;border-top:1px solid rgba(16,18,22,.1)}

@keyframes homeReveal{
  from{opacity:0;transform:translateY(26px)}
  to{opacity:1;transform:translateY(0)}
}
.homePage [data-reveal],
.homePageAlt [data-reveal]{
  opacity:0;
  animation:homeReveal .8s cubic-bezier(.22,.61,.36,1) forwards;
  animation-delay:var(--reveal-delay,0ms);
}

/* Alternative home (variant 2) */
.homePageAlt{
  background:#f1eee7;
  font-family:var(--sans);
  color:#101318;
}
.homePageAlt .topbar{
  background:rgba(241,238,231,.92);
  border-bottom:1px solid rgba(16,19,24,.14);
}
.altHero{
  border-bottom:1px solid rgba(16,19,24,.12);
  padding:112px 0 64px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.58),rgba(255,255,255,0)),
    radial-gradient(1100px 420px at 100% 0%,rgba(160,114,65,.2),transparent 72%);
}
.altHero__inner{max-width:900px}
.altHero__kicker{
  margin:0 0 18px;
  font-size:11px;
  letter-spacing:.24em;
  color:#6b7078;
  font-weight:700;
}
.altHero h1{
  margin:0;
  max-width:16ch;
  font-family:var(--sans);
  font-size:clamp(42px,6vw,84px);
  line-height:.95;
  letter-spacing:-.015em;
}
.altHero__lead{
  margin:18px 0 0;
  max-width:52ch;
  color:#4f535b;
  line-height:1.7;
}
.altHero__actions{
  margin-top:22px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.altMetrics{
  border-bottom:1px solid rgba(16,19,24,.1);
  background:#11151b;
  color:#f1f2f4;
}
.altMetrics__grid{
  padding:22px 0;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.altMetric__value{
  margin:0;
  font-family:var(--sans);
  font-size:clamp(34px,4vw,52px);
}
.altMetric__label{
  margin:6px 0 0;
  color:rgba(241,242,244,.72);
  font-size:13px;
  line-height:1.5;
}
.altProjects{
  background:#f1eee7;
}
.altProjects__head{
  padding-bottom:18px;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
}
.altProjects__head h2{
  margin:0;
  font-family:var(--sans);
  font-size:clamp(30px,4vw,56px);
}
.altProjects__grid{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr;
  gap:16px;
}
.altProjectCard{
  border:1px solid rgba(16,19,24,.12);
  border-radius:16px;
  overflow:hidden;
  background:#fff;
}
.altProjectCard img{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  transition:transform .4s ease;
}
.altProjectCard--wide img{
  aspect-ratio:5/4;
}
.altProjectCard__info{
  padding:12px 14px;
}
.altProjectCard__title{
  margin:0;
  font-weight:800;
}
.altProjectCard__meta{
  margin:4px 0 0;
  color:#6c7178;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.altProjectCard:hover img{
  transform:scale(1.03);
}
.altMethod{
  background:#fff;
  border-top:1px solid rgba(16,19,24,.1);
  border-bottom:1px solid rgba(16,19,24,.1);
}
.altMethod__head h2{
  margin:0 0 18px;
  font-family:var(--sans);
  font-size:clamp(30px,3.8vw,50px);
}
.altMethod__steps{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.altStep{
  border:1px solid rgba(16,19,24,.12);
  border-radius:14px;
  padding:20px;
}
.altStep__num{
  margin:0 0 8px;
  font-size:12px;
  letter-spacing:.16em;
  color:#8e949f;
}
.altStep h3{
  margin:0;
  font-size:24px;
}
.altStep p{
  margin:10px 0 0;
  color:#535861;
  line-height:1.6;
}
.altCall{
  background:linear-gradient(180deg,#f1eee7,#ece7dd);
}
.altCall__panel{
  border:1px solid rgba(16,19,24,.14);
  border-radius:20px;
  background:#101318;
  color:#fff;
  padding:30px;
}
.altCall__panel p{
  margin:0;
  color:rgba(255,255,255,.72);
  letter-spacing:.16em;
  font-size:11px;
}
.altCall__panel h2{
  margin:12px 0 18px;
  max-width:18ch;
  font-family:var(--sans);
  font-size:clamp(30px,4vw,52px);
  line-height:1.02;
}
.altCall__links{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.altCall__links a{
  border:1px solid rgba(255,255,255,.26);
  border-radius:999px;
  padding:10px 14px;
}

/* Catalog page */
.catalogPage{
  background:linear-gradient(180deg,#f5f2ec 0%,#f9f8f5 30%,#f5f2ec 100%);
  font-family:var(--sans);
}
.catalogPage .topbar{
  background:rgba(245,242,236,.9);
  border-bottom:1px solid rgba(16,18,22,.12);
}
.catalogHero{
  padding:86px 0 18px;
}
.catalogHero__inner h1{
  margin:10px 0 0;
  font-family:var(--sans);
  font-size:clamp(36px,5vw,70px);
  line-height:.98;
}
.catalogHero__inner p{
  margin:12px 0 0;
  max-width:58ch;
  color:#5f646d;
  line-height:1.7;
}
.projectsHeader--catalog{
  border-bottom:1px solid rgba(16,18,22,.14);
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
}
.catalogPage .tabs{
  gap:22px;
}
.catalogPage .tab{
  font-size:15px;
  color:#8d9199;
}
.catalogPage .tab.is-active{
  color:#14181f;
}
.projectsGrid--catalog{
  grid-template-columns:repeat(3,1fr);
  gap:24px 20px;
}
.catalogPage .projectCard{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(16,18,22,.12);
  background:#fff;
}
.catalogPage .projectCard img{
  height:auto;
  aspect-ratio:4/5;
  transition:transform .45s ease,filter .45s ease;
}
.catalogPage .projectCard__info{
  text-align:left;
  padding:14px;
}
.catalogPage .projectCard__title{
  letter-spacing:0;
}
.catalogPage .projectCard__type{
  margin-top:4px;
  font-size:11px;
  color:#6f747e;
}
.catalogPage .projectCard:hover img{
  transform:scale(1.03);
  filter:contrast(1.04);
}
.projectsEmpty{
  margin:8px 0 0;
  color:#656a73;
  padding:12px 2px;
}

/* Project page */
.projectShowcasePage{
  background:#ececec;
  font-family:var(--sans);
}
.projectShowcasePage .topbar{
  background:rgba(236,236,236,.94);
  border-bottom:1px solid rgba(16,18,22,.14);
}
.projectTopbar__actions{
  display:flex;
  align-items:center;
  gap:12px;
}
.projectEditorial{
  display:grid;
  grid-template-columns:minmax(360px,46%) 1fr;
  min-height:calc(100vh - 72px);
}
.projectEditorial__left{
  border-right:1px solid rgba(16,18,22,.14);
  background:#ececec;
}
.projectEditorial__leftInner{
  position:sticky;
  top:72px;
  max-height:calc(100vh - 72px);
  overflow:auto;
  padding:52px clamp(26px,4vw,56px) 58px;
}
.projectEditorial__kicker{
  margin:0;
  font-size:14px;
  font-weight:700;
  letter-spacing:.09em;
  text-transform:uppercase;
  color:#1b1d23;
}
.projectEditorial__title{
  margin:14px 0 0;
  font-family:var(--sans);
  font-size:clamp(42px,6vw,78px);
  line-height:.95;
  letter-spacing:-.01em;
  text-transform:uppercase;
}
.projectEditorial__accent{
  width:120px;
  height:6px;
  margin-top:18px;
  background:#c59b6b;
}
.projectEditorial__tagline{
  margin:14px 0 0;
  font-size:31px;
  line-height:.98;
  letter-spacing:-.01em;
}
.projectEditorial__crumbs{
  margin-top:20px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  font-size:14px;
  color:#666b72;
}
.projectEditorial__crumbs a{
  color:#595e66;
}
.projectEditorial__facts{
  list-style:none;
  margin:30px 0 0;
  padding:0;
}
.projectEditorial__facts li{
  display:grid;
  grid-template-columns:minmax(140px,170px) 1fr;
  gap:14px;
  border-top:1px solid rgba(16,18,22,.1);
  padding:10px 0;
}
.projectEditorial__factLabel{
  position:relative;
  font-weight:700;
  padding-left:16px;
}
.projectEditorial__factLabel::before{
  content:"-";
  position:absolute;
  left:0;
  color:#bd9666;
}
.projectEditorial__factValue{
  color:#2f333b;
}
.projectEditorial__section{
  margin-top:34px;
}
.projectEditorial__sectionTitle{
  margin:0 0 14px;
  font-size:38px;
  font-family:var(--sans);
  letter-spacing:-.01em;
  text-transform:uppercase;
}
.projectEditorial__text{
  display:grid;
  gap:12px;
}
.projectEditorial__text .muted{
  margin:0;
  color:#484d56;
}
.projectEditorial__plans{
  display:grid;
  gap:14px;
}
.projectEditorial__plan{
  border:1px solid rgba(16,18,22,.12);
  border-radius:16px;
  background:#fff;
  padding:14px;
}
.projectEditorial__planTitle{
  margin:0 0 12px;
  font-size:18px;
  letter-spacing:-.01em;
}
.projectEditorial__planList{
  display:grid;
  gap:8px;
}
.projectEditorial__planRow{
  display:flex;
  justify-content:space-between;
  gap:14px;
  border-top:1px solid rgba(16,18,22,.1);
  padding-top:8px;
  color:#4f545e;
  font-size:14px;
}
.projectEditorial__section--cta{
  padding-top:4px;
}
.projectEditorial__right{
  background:#e9e9e9;
}
.projectEditorial__visuals{
  display:grid;
  gap:10px;
}
.projectEditorial__visual{
  margin:0;
  border-bottom:1px solid rgba(16,18,22,.14);
}
.projectEditorial__visual img{
  width:100%;
  display:block;
  object-fit:cover;
}
.projectEditorial__visual--wide img{
  aspect-ratio:16/10;
  min-height:360px;
}
.projectEditorial__visual--standard img{
  aspect-ratio:16/10;
}

/* Tabs / Filters */
.projectsHeader{border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:34px}
.tabs{display:flex;gap:28px;align-items:flex-end}
.tab{border:none;background:transparent;padding:0;cursor:pointer;font-size:16px;color:#b0b0b0;font-weight:500}
.tab.is-active{color:var(--ink)}

/* Grid like screenshot */
.projectsGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:34px 26px}
.projectCard{display:block;color:var(--ink)}
.projectCard img{width:100%;height:220px;object-fit:cover;background:#f2f2f2}
.projectCard__info{text-align:center;padding:18px 6px 0}
.projectCard__title{font-weight:800;letter-spacing:.02em;font-size:16px}
.projectCard__type{margin-top:8px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* About blocks */
.about{max-width:860px}
.facts{margin-top:18px;display:grid;gap:10px;border-top:1px solid rgba(10,10,10,.10);padding-top:14px}
.fact{display:flex;gap:12px}
.fact__k{width:110px;color:var(--muted);font-size:13px}
.fact__v{font-size:14px;font-weight:600}

/* Contact + footer */
.footer{border-top:1px solid var(--line)}
.footer__inner{display:flex;justify-content:space-between;gap:16px;padding:18px 0 38px}
.footerGrid{display:grid;grid-template-columns:1fr .7fr 1fr;gap:18px;align-items:start}
.contact__row{margin-bottom:10px}
.contact a{font-weight:700}
.form{display:grid;gap:10px}
.form input,.form textarea{border:1px solid var(--line);border-radius:12px;padding:12px 12px;font:inherit;outline:none}
.form input:focus,.form textarea:focus{border-color:rgba(10,10,10,.35)}

/* Project page */
.projectPage{padding-bottom:40px}
.projectHero__head{padding:28px 0 12px}
.projectBanner img{width:100%;border-radius:var(--r);aspect-ratio:16/9;object-fit:cover;border:1px solid var(--line)}
.projectMeta{margin-top:14px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.meta__k{font-size:12px;color:var(--muted)}
.meta__v{font-size:14px;font-weight:600}
.projectText{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:22px}
.projectMosaic{margin-top:22px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.projectMosaic img{border-radius:var(--r);border:1px solid var(--line);aspect-ratio:4/3;object-fit:cover}
.projectMosaic img:nth-child(1){grid-column:span 2;aspect-ratio:16/9}
.projectMosaic img:nth-child(4){grid-column:span 2;aspect-ratio:16/9}

/* Responsive */
@media (max-width:1100px){.projectsGrid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:900px){
  .projectsGrid{grid-template-columns:repeat(2,1fr)}
  .footerGrid{grid-template-columns:1fr}
  .projectEditorial{grid-template-columns:1fr}
  .projectEditorial__left{border-right:none;border-bottom:1px solid rgba(16,18,22,.14)}
  .projectEditorial__leftInner{position:static;top:auto;max-height:none;overflow:visible;padding:34px 5vw 40px}
  .projectEditorial__facts li{grid-template-columns:1fr;gap:5px}
  .projectEditorial__visual--wide img{min-height:260px}
  .twoCol{grid-template-columns:1fr}
}
@media (max-width:720px){
  .nav{display:none}
  .menuBtn{display:inline-block}
  .projectsGrid{grid-template-columns:1fr}
  .footer__inner{flex-direction:column}
}

@media (max-width:1120px){
  .homeHero__inner{grid-template-columns:1fr}
  .homeHero__right{justify-content:flex-start}
  .homeServices__grid{grid-template-columns:1fr}
  .homeFeatured__grid{grid-template-columns:1fr 1fr}
  .homeFeatured__grid .homeProjectCard:last-child{grid-column:span 2}
  .altProjects__grid{grid-template-columns:1fr 1fr}
  .altProjectCard--wide{grid-column:span 2}
  .projectsGrid--catalog{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .homeStats__grid{grid-template-columns:1fr}
  .homeStat{padding:4px 2px}
  .homeFeatured__head{flex-direction:column;align-items:flex-start}
  .altMetrics__grid{grid-template-columns:1fr}
  .altMethod__steps{grid-template-columns:1fr}
  .projectsHeader--catalog{flex-direction:column;align-items:flex-start}
  .projectEditorial__sectionTitle{font-size:30px}
}
@media (max-width:720px){
  .homeHero{padding:104px 0 56px}
  .homeHero h1{font-size:clamp(38px,12vw,62px)}
  .homeLead{font-size:16px}
  .homeHero__actions{flex-direction:column;align-items:stretch}
  .homeHero__actions .btn{justify-content:center}
  .homeBadge{padding:18px}
  .homeFeatured__grid{grid-template-columns:1fr}
  .homeFeatured__grid .homeProjectCard:last-child{grid-column:auto}
  .homeService h3{font-size:22px}
  .homeCta__panel{padding:24px}
  .altHero{padding:98px 0 48px}
  .altHero__actions{flex-direction:column;align-items:stretch}
  .altHero__actions .btn{justify-content:center}
  .altProjects__grid{grid-template-columns:1fr}
  .altProjectCard--wide{grid-column:auto}
  .altCall__panel{padding:22px}
  .projectsGrid--catalog{grid-template-columns:1fr}
  .projectTopbar__actions .btn{display:none}
  .projectTopbar__actions{margin-left:auto}
  .projectEditorial__kicker{font-size:12px}
  .projectEditorial__title{font-size:clamp(34px,12vw,56px)}
  .projectEditorial__tagline{font-size:24px}
  .projectEditorial__sectionTitle{font-size:28px}
  .projectEditorial__planTitle{font-size:16px}
  .projectEditorial__visual--wide img{min-height:220px}
}
@media (prefers-reduced-motion:reduce){
  .homePage [data-reveal],
  .homePageAlt [data-reveal]{opacity:1;animation:none}
  .homeProjectCard img{transition:none}
  .altProjectCard img{transition:none}
}

/* Cinematic long-scroll homepage */
.homeCinematic{
  --cinema-ink:#121417;
  --cinema-muted:#6d7279;
  --cinema-soft:#f3f3f0;
  --cinema-space:clamp(96px,12vw,210px);
  background:#ffffff;
  color:var(--cinema-ink);
  font-family:var(--sans);
}
.homeCinematic .container,
.homeCinematic .cinemaSectionWrap,
.homeCinematic .cinemaProject,
.homeCinematic .cinemaPortfolio,
.homeCinematic .cinemaFooter__inner,
.homeCinematic .cinemaElements{
  width:min(1240px,90vw);
  margin:0 auto;
}
.homeCinematic .sectionGap{
  padding-top:var(--cinema-space);
  padding-bottom:var(--cinema-space);
}

.cinemaHero{
  --hero-progress:0;
  position:relative;
  min-height:100vh;
  min-height:100svh;
  overflow:hidden;
  background:#060709;
}
.cinemaHero::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(255,255,255,calc(var(--hero-progress) * 0.94));
  pointer-events:none;
}
.cinemaHero__media{
  position:absolute;
  inset:-12vh 0 -8vh;
}
.cinemaHero__shade{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg,rgba(8,10,14,.35) 0%,rgba(8,10,14,.55) 70%,rgba(8,10,14,.76) 100%),
    radial-gradient(880px 560px at 50% 65%,rgba(189,142,88,.28),rgba(189,142,88,0) 70%);
}
.cinemaHero .parallaxMedia__img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 35%;
  transform:translate3d(0,0,0) scale(1.08);
  filter:brightness(calc(0.9 - var(--hero-progress) * 0.34)) saturate(calc(1 - var(--hero-progress) * 0.4));
  will-change:transform,filter;
}
.cinemaHero__topline{
  position:fixed;
  top:0;
  left:0;
  right:0;
  width:min(var(--max), 92vw);
  margin:0 auto;
  z-index:24;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding-top:calc(14px + env(safe-area-inset-top));
  padding-bottom:14px;
  border-bottom:1px solid transparent;
  background:transparent;
  transition:
    background-color .35s ease,
    border-color .35s ease,
    box-shadow .35s ease;
}
.cinemaHero__topline.is-contrast{
  background:transparent;
  border-bottom-color:transparent;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.cinemaBrand{
  font-size:15px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.94);
  font-weight:700;
}
.cinemaQuickNav{
  display:flex;
  gap:22px;
}
.cinemaQuickNav a{
  color:rgba(255,255,255,.74);
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.cinemaQuickNav a:hover{
  color:#fff;
}
.cinemaHero__topline.is-contrast .cinemaBrand{
  color:#161a20;
}
.cinemaHero__topline.is-contrast .cinemaQuickNav a{
  color:rgba(22,26,32,.72);
}
.cinemaHero__topline.is-contrast .cinemaQuickNav a:hover{
  color:#161a20;
}
.cinemaHero__center{
  position:relative;
  z-index:2;
  min-height:calc(100vh - 60px);
  min-height:calc(100svh - 60px);
  display:grid;
  place-items:center;
  text-align:center;
  padding-bottom:9vh;
}
.cinemaHero__center h1{
  margin:0;
  color:#fff;
  font-size:clamp(44px,9vw,132px);
  font-weight:700;
  line-height:.92;
  letter-spacing:-.045em;
  transform:translateY(calc(var(--hero-progress) * 50px));
  opacity:calc(1 - var(--hero-progress) * 1.25);
}
.cinemaHero__scroll{
  position:absolute;
  left:50%;
  bottom:20px;
  transform:translateX(-50%);
  z-index:2;
  color:rgba(255,255,255,.62);
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
}

.cinemaManifesto{
  background:#ffffff;
}
.cinemaSectionWrap{
  display:grid;
  grid-template-columns:0.95fr 1.05fr;
  gap:clamp(28px,7vw,120px);
  align-items:center;
}
.manifestoVisual{
  margin:0;
  min-height:420px;
  overflow:hidden;
}
.manifestoVisual img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(1) contrast(1.2) brightness(.92);
}
.manifestoContent h2{
  margin:0;
  font-size:clamp(44px,7.4vw,112px);
  line-height:.86;
  letter-spacing:-.05em;
  font-family:var(--sans);
  font-weight:800;
}
.manifestoContent p{
  margin:28px 0 0;
  max-width:52ch;
  color:var(--cinema-muted);
  line-height:1.78;
  font-size:15px;
}

.cinemaElements{
  display:grid;
  gap:86px;
}
.cinemaSectionHeader{
  display:flex;
  justify-content:center;
  text-align:center;
}
.cinemaSectionHeader p,
.cinemaSectionHeader h2{
  margin:0;
  font-size:clamp(22px,3.4vw,42px);
  line-height:1;
  letter-spacing:-.02em;
  font-weight:700;
}
.cinemaSectionHeader--left{
  justify-content:flex-start;
  text-align:left;
}
.cinemaElements__grid{
  display:grid;
  gap:74px;
}
.elementCard{
  display:grid;
  grid-template-columns:1.45fr .55fr;
  gap:24px;
  align-items:end;
}
.elementCard--matter{
  grid-template-columns:.62fr 1.38fr;
  align-items:start;
}
.elementCard__visual{
  margin:0;
  overflow:hidden;
}
.elementCard__visual--wide{
  min-height:480px;
}
.elementCard__visual--macro{
  min-height:420px;
}
.elementCard__visual img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.elementCard__text{
  margin:0;
  color:var(--cinema-muted);
  font-size:14px;
  line-height:1.8;
  letter-spacing:.01em;
  max-width:34ch;
}

.cinemaProject{
  display:grid;
  gap:40px;
}
.cinemaProject__head h2{
  margin:8px 0 0;
  font-size:clamp(42px,7.2vw,104px);
  letter-spacing:-.05em;
  line-height:.86;
}
.cinemaProject__kicker{
  margin:0;
  color:#808690;
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-weight:700;
}
.cinemaProject__lead{
  margin:14px 0 0;
  color:#777c84;
  font-size:16px;
}
.projectFrame{
  margin:0;
  overflow:hidden;
}
.projectFrame img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.projectFrame--wide{
  min-height:60vh;
  min-height:60svh;
}
.projectSplit{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:28px;
}
.projectFrame--tall{
  min-height:560px;
}
.projectData{
  border-top:1px solid #d6d9dd;
  padding-top:14px;
  align-self:start;
}
.projectData dl{
  margin:0;
  display:grid;
  gap:8px;
}
.projectData dl div{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:12px;
  border-bottom:1px solid #eceef1;
  padding:10px 0;
}
.projectData dt{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#9096a0;
}
.projectData dd{
  margin:0;
  font-size:14px;
  font-weight:700;
  color:#1f232b;
}
.projectData p{
  margin:18px 0 0;
  max-width:48ch;
  color:#666c74;
  line-height:1.8;
  font-size:15px;
}
.cinemaTextLink{
  width:fit-content;
  color:#1f232b;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:11px;
  font-weight:700;
}

.cinemaPortfolio{
  display:grid;
  gap:34px;
}
.portfolioTop{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
  align-items:stretch;
}
.portfolioStack{
  display:grid;
  gap:18px;
}
.portfolioBottom{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.portfolioCard{
  display:block;
}
.portfolioCard img{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  filter:contrast(1.02);
}
.portfolioCard--large img{
  aspect-ratio:16/11;
}
.portfolioCard p{
  margin:11px 0 0;
  color:#5f646d;
  font-size:11px;
  letter-spacing:.09em;
  text-transform:uppercase;
}

.cinemaRigor{
  background:var(--cinema-soft);
}
.cinemaSectionWrap--rigor{
  grid-template-columns:1fr;
  gap:30px;
}
.rigorHead h2{
  margin:0;
  font-size:clamp(40px,6.8vw,94px);
  line-height:.89;
  letter-spacing:-.045em;
}
.rigorVisual{
  margin:0;
  min-height:58vh;
  min-height:58svh;
  overflow:hidden;
}
.rigorVisual img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(1) contrast(1.12);
}
.rigorColumns{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.rigorColumns p{
  margin:0;
  color:#555b63;
  font-size:15px;
  line-height:1.84;
  max-width:42ch;
}

.cinemaFooter{
  background:#ffffff;
  padding:64px 0 44px;
}
.cinemaFooter__inner{
  display:flex;
  justify-content:space-between;
  gap:28px;
  align-items:flex-start;
}
.cinemaFooter__brand{
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-weight:700;
}
.cinemaFooter__contacts{
  display:grid;
  justify-items:end;
  gap:8px;
}
.cinemaFooter__contacts a,
.cinemaFooter__contacts p{
  margin:0;
  color:#6f747b;
  font-size:13px;
  line-height:1.45;
}
.cinemaFooter__socials{
  display:flex;
  gap:14px;
  margin-top:6px;
}
.cinemaFooter__socials a{
  color:#31353c;
  font-size:12px;
}

.homeCinematic [data-reveal]{
  opacity:1;
  transform:none;
}
.homeCinematic.motion-ready [data-reveal]{
  opacity:0;
  transform:translate3d(0,28px,0);
  transition:
    opacity .85s cubic-bezier(.22,.61,.36,1),
    transform .85s cubic-bezier(.22,.61,.36,1);
  transition-delay:var(--reveal-delay,0ms);
}
.homeCinematic.motion-ready [data-reveal].is-visible{
  opacity:1;
  transform:translate3d(0,0,0);
}
.parallaxMedia{
  position:relative;
  overflow:hidden;
}
.parallaxMedia__img{
  transform:translate3d(0,0,0) scale(1.08);
  will-change:transform;
}

@media (max-width:1120px){
  .cinemaSectionWrap{grid-template-columns:1fr}
  .manifestoVisual{min-height:360px}
  .elementCard,
  .elementCard--matter{grid-template-columns:1fr;gap:18px}
  .elementCard__visual--wide{min-height:380px}
  .elementCard__visual--macro{min-height:340px}
  .projectSplit{grid-template-columns:1fr}
  .projectFrame--tall{min-height:460px}
  .portfolioTop{grid-template-columns:1fr}
  .portfolioBottom{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .homeCinematic .sectionGap{padding-top:82px;padding-bottom:82px}
  .cinemaHero__topline{padding-top:calc(10px + env(safe-area-inset-top));padding-bottom:10px}
  .cinemaQuickNav{display:none}
  .cinemaHero__center h1{font-size:clamp(38px,14vw,68px)}
  .cinemaHero__scroll{bottom:16px}
  .manifestoContent p{font-size:14px;margin-top:20px}
  .cinemaElements{gap:58px}
  .cinemaElements__grid{gap:52px}
  .projectFrame--wide{min-height:42vh;min-height:42svh}
  .projectFrame--tall{min-height:360px}
  .projectData dl div{grid-template-columns:1fr;gap:4px}
  .portfolioBottom{grid-template-columns:1fr}
  .rigorVisual{min-height:42vh;min-height:42svh}
  .rigorColumns{grid-template-columns:1fr;gap:16px}
  .cinemaFooter{padding-top:42px}
  .cinemaFooter__inner{flex-direction:column;gap:22px}
  .cinemaFooter__contacts{justify-items:start}
}
@media (prefers-reduced-motion:reduce){
  .homeCinematic.motion-ready [data-reveal]{opacity:1;transform:none;transition:none}
  .parallaxMedia__img{transform:none !important}
  .cinemaHero__center h1{transform:none;opacity:1}
}

/* Home page (reference layout) */
.homeReference{
  --ref-max:100%;
  --ref-fluid:100vw;
  --ref-grid-columns:8;
  --ref-grid-step:calc(var(--ref-fluid) / var(--ref-grid-columns));
  --home-method-gap:16px;
  --ref-line:rgba(17,20,24,.11);
  margin:0;
  background-color:#f3f3f2;
  background-image:none;
  color:#121417;
  font-family:var(--sans);
}
.homeReference a{
  color:inherit;
}
.homeRefTopbar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:60;
  background:rgba(243,243,242,.92);
  border-bottom:1px solid var(--ref-line);
}
.homeRefTopbar__inner{
  width:var(--ref-max);
  margin:0 auto;
  min-height:72px;
  padding:0 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.homeRefBrand{
  font-size:42px;
  font-size:clamp(28px,calc(var(--ref-fluid) * 0.021),43px);
  line-height:1;
  letter-spacing:-.02em;
  font-weight:500;
}
.homeRefNav{
  display:flex;
  align-items:center;
  gap:34px;
}
.homeRefNav a{
  font-size:34px;
  font-size:clamp(20px,calc(var(--ref-fluid) * 0.0122),36px);
  line-height:1;
  letter-spacing:-.01em;
  font-weight:500;
}
.homeRefMenuBtn{
  display:none;
  border:1px solid rgba(17,20,24,.26);
  border-radius:999px;
  background:transparent;
  padding:10px 14px;
  font:inherit;
  font-size:14px;
  line-height:1;
  cursor:pointer;
}
.homeRefMobileNav{
  display:none;
  width:var(--ref-max);
  margin:0 auto;
  padding:10px 22px 16px;
  border-top:1px solid var(--ref-line);
}
.homeRefMobileNav a{
  display:block;
  padding:9px 0;
  font-size:16px;
}
.homeRefMobileNav.is-open{
  display:block;
}

.homeRefMain{
  padding-top:72px;
}
.homeRefHero{
  position:relative;
  width:var(--ref-max);
  margin:0 auto;
  height:clamp(380px,62vh,680px);
  border:1px solid var(--ref-line);
  overflow:hidden;
  background:#d9d6d0;
}
.homeRefHero::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.02) 0%,rgba(0,0,0,.04) 52%,rgba(0,0,0,.28) 100%);
}
.homeRefHero img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 58%;
  filter:contrast(1.06) saturate(.95) brightness(.96);
}
.homeRefHero h1{
  position:absolute;
  left:clamp(8px,calc(var(--ref-fluid) * 0.018),24px);
  bottom:0;
  z-index:1;
  margin:0;
  font-size:clamp(52px,calc(var(--ref-fluid) * 0.06),120px);
  line-height:.83;
  letter-spacing:-.05em;
  font-weight:500;
  color:rgba(224,224,219,.95);
  text-transform:uppercase;
  pointer-events:none;
}

.homeRefPhilosophy{
  width:var(--ref-max);
  margin:0 auto;
  padding:82px 22px 104px;
  display:grid;
  grid-template-columns:minmax(220px,1.25fr) minmax(200px,.9fr) minmax(200px,.9fr);
  column-gap:56px;
  row-gap:34px;
  background-image:none;
}
.homeRefPhilosophy__title{
  margin:0;
  margin-left:180px;
  font-size:clamp(38px,calc(var(--ref-fluid) * 0.043),80px);
  line-height:.9;
  letter-spacing:-.04em;
  font-weight:500;
  text-transform:uppercase;
}
.homeRefPhilosophy__text{
  margin:0;
  max-width:20ch;
  font-size:clamp(16px,calc(var(--ref-fluid) * 0.0105),22px);
  line-height:1.33;
  letter-spacing:-.016em;
}
@media (min-width:1181px){
  .homeRefPhilosophy__text{
    margin-left:80px;
  }
  .homeRefPhilosophy__text + .homeRefPhilosophy__text{
    margin-left:-100px;
  }
}
.homeRefPhilosophy__cta{
  grid-column:2/4;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:16px 0 17px;
  border-top:1px solid var(--ref-line);
  border-bottom:none;
  font-size:clamp(16px,calc(var(--ref-fluid) * 0.0102),20px);
  line-height:1;
  letter-spacing:-.01em;
  text-transform:uppercase;
}
.homeRefPhilosophy__cta:hover{
  opacity:.7;
}
.homeRefPhilosophy__cta--compact{
  grid-column:auto;
  padding:12px 0 13px;
  font-size:13px;
}
@media (min-width:1181px){
  .homeRefPhilosophy > .homeRefPhilosophy__cta:not(.homeRefPhilosophy__cta--compact){
    justify-content:flex-end;
    gap:14px;
    padding-left:0;
  }
}

.homeRefMethod,
.homeRefShowcase,
.homeRefFinal,
.homeRefFooter__inner{
  width:var(--ref-max);
  margin:0 auto;
  padding-left:22px;
  padding-right:22px;
}
.homeRefMethod{
  padding-bottom:92px;
  background-image:none;
}
.homeRefMethod__inner h2,
.homeRefShowcase__head h2{
  margin:0;
  font-size:clamp(36px,calc(var(--ref-fluid) * 0.046),84px);
  line-height:.92;
  letter-spacing:-.04em;
  font-weight:500;
  text-transform:uppercase;
}
.homeRefMethod__grid{
  margin-top:20px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:var(--home-method-gap);
}
.homeRefMethodCard{
  border:1px solid var(--ref-line);
  background:rgba(255,255,255,.24);
  padding:18px;
}
.homeRefMethodCard__num{
  margin:0;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(18,20,23,.52);
}
.homeRefMethodCard h3{
  margin:12px 0 0;
  font-size:24px;
  line-height:1;
  font-weight:500;
  letter-spacing:-.02em;
  text-transform:uppercase;
}
.homeRefMethodCard p{
  margin:12px 0 0;
  color:rgba(18,20,23,.72);
  font-size:15px;
  line-height:1.4;
}

.homeRefShowcase{
  padding-top:120px;
  padding-bottom:92px;
}
.homeRefShowcase__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
}
.homeRefShowcase__grid{
  margin-top:20px;
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(290px,320px);
  gap:14px;
  overflow-x:auto;
  overflow-y:hidden;
  padding:2px 0 16px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.homeRefShowcase__grid::-webkit-scrollbar{
  height:8px;
}
.homeRefShowcase__grid::-webkit-scrollbar-thumb{
  background:rgba(18,20,23,.26);
}
.homeRefShowcase__grid::-webkit-scrollbar-track{
  background:rgba(18,20,23,.08);
}
.homeRefShowcaseCard{
  display:flex;
  flex-direction:column;
  height:100%;
  border:1px solid var(--ref-line);
  background:#f3f3f2;
  scroll-snap-align:start;
}
.homeRefShowcaseCard__media{
  padding:4px;
  border-bottom:1px solid var(--ref-line);
}
.homeRefShowcaseCard img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  filter:none;
}
.homeRefShowcaseCard__info{
  padding:10px 10px 12px;
  display:flex;
  flex-direction:column;
  flex:1;
  gap:8px;
}
.homeRefShowcaseCard__title{
  margin:0;
  font-size:clamp(34px,2.6vw,68px);
  line-height:.9;
  letter-spacing:-.05em;
  font-weight:500;
  text-transform:uppercase;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.homeRefShowcaseCard__meta{
  margin:0;
  font-size:13px;
  line-height:1.2;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.homeRefShowcaseCard__description{
  margin:0;
  font-size:12px;
  line-height:1.34;
  color:rgba(18,20,23,.78);
  min-height:2.68em;
}
.homeRefShowcaseCard__cta{
  margin-top:auto;
  padding-top:10px;
  border-top:1px solid var(--ref-line);
  font-size:14px;
  line-height:1;
  letter-spacing:.01em;
  text-transform:uppercase;
}

.homeRefFinal{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  min-height:clamp(340px,42vw,620px);
  padding-top:0;
  padding-bottom:0;
  border-top:1px solid var(--ref-line);
  border-bottom:1px solid var(--ref-line);
}
.homeRefFinal__image{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:-2;
  filter:contrast(1.04) saturate(1.03);
}
.homeRefFinal__overlay{
  position:absolute;
  inset:0;
  z-index:-1;
  background:linear-gradient(
    180deg,
    rgba(17,27,18,.16) 0%,
    rgba(17,27,18,.54) 100%
  );
}
.homeRefFinal__inner{
  min-height:clamp(340px,42vw,620px);
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:24px;
  padding:26px 22px;
}
.homeRefFinal p{
  margin:0;
  font-size:clamp(34px,calc(var(--ref-fluid) * 0.042),80px);
  line-height:.9;
  letter-spacing:-.04em;
  text-transform:uppercase;
  max-width:16ch;
  color:#f1f6f0;
}
.homeRefFinal a{
  border-bottom:1px solid rgba(241,246,240,.64);
  padding-bottom:6px;
  font-size:14px;
  line-height:1;
  letter-spacing:.09em;
  text-transform:uppercase;
  color:#f1f6f0;
}
.homeRefFinal a:hover{
  border-bottom-color:#ffffff;
  color:#ffffff;
  opacity:1;
}
.homeRefFooter{
  background:#0a0f13;
  color:#e8eeea;
  border-top:1px solid rgba(232,238,234,.14);
}
.homeRefFooter a{
  color:inherit;
}
.homeRefFooter__inner{
  padding-top:34px;
  padding-bottom:30px;
  display:grid;
  grid-template-columns:minmax(260px,1.05fr) minmax(0,2.3fr);
  gap:30px 56px;
}
.homeRefFooter__brand{
  display:inline-block;
  font-size:clamp(28px,2.3vw,40px);
  line-height:.92;
  letter-spacing:-.03em;
  text-transform:uppercase;
}
.homeRefFooter__tagline{
  margin:14px 0 0;
  max-width:34ch;
  color:rgba(232,238,234,.78);
  font-size:clamp(15px,1.12vw,20px);
  line-height:1.35;
}
.homeRefFooter__about h3{
  margin:24px 0 0;
  font-size:clamp(22px,2.2vw,34px);
  line-height:1;
  letter-spacing:-.02em;
  text-transform:uppercase;
}
.homeRefFooter__contactLink{
  display:block;
  width:max-content;
  margin-top:12px;
  color:#ffffff;
  font-size:clamp(18px,1.8vw,30px);
  line-height:1.06;
  letter-spacing:-.015em;
}
.homeRefFooter__contactLink--phone{
  font-size:clamp(28px,3.1vw,46px);
  font-weight:600;
}
.homeRefFooter__columns{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:26px;
}
.homeRefFooter__col{
  display:grid;
  align-content:start;
  gap:10px;
}
.homeRefFooter__col h4{
  margin:0 0 4px;
  font-size:clamp(24px,2vw,34px);
  line-height:1;
  letter-spacing:-.02em;
}
.homeRefFooter__col a{
  font-size:clamp(16px,1.3vw,30px);
  line-height:1.22;
  color:rgba(232,238,234,.86);
}
.homeRefFooter__col a:hover,
.homeRefFooter__contactLink:hover{
  color:#ffffff;
}
.homeRefFooter__bottom{
  width:var(--ref-max);
  margin:0 auto;
  padding:16px 22px 22px;
  border-top:1px solid rgba(232,238,234,.14);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.homeRefFooter__bottom p,
.homeRefFooter__bottom a{
  margin:0;
  color:rgba(232,238,234,.72);
  font-size:13px;
}
.homeRefFooter__bottom a:hover{
  color:#ffffff;
}

@media (max-width:1180px){
  .homeRefTopbar__inner,
  .homeRefPhilosophy,
  .homeRefMethod,
  .homeRefShowcase,
  .homeRefFinal,
  .homeRefFooter__inner{
    padding-left:16px;
    padding-right:16px;
  }
  .homeRefPhilosophy{
    grid-template-columns:1fr 1fr;
    row-gap:28px;
  }
  .homeRefPhilosophy__title{
    grid-column:1/3;
    max-width:8ch;
  }
  .homeRefPhilosophy__cta{
    grid-column:1/3;
  }
  .homeRefShowcase__head{
    flex-direction:column;
    align-items:flex-start;
  }
  .homeRefFooter__inner{
    grid-template-columns:1fr;
    gap:28px;
  }
  .homeRefFooter__bottom{
    padding-left:16px;
    padding-right:16px;
  }
}
@media (max-width:880px){
  .homeRefNav{
    display:none;
  }
  .homeRefMenuBtn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
  .homeRefHero{
    height:clamp(350px,66vw,560px);
  }
  .homeRefHero h1{
    bottom:0;
    font-size:clamp(46px,10.2vw,98px);
  }
  .homeRefPhilosophy{
    padding-top:70px;
    row-gap:28px;
  }
  .homeRefMethod__grid{
    grid-template-columns:1fr 1fr;
  }
  .homeRefMethod{
    background-image:none;
  }
  .homeRefShowcase__grid{
    grid-auto-columns:minmax(270px,300px);
  }
  .homeRefShowcase{
    padding-top:92px;
  }
  .homeRefFinal__inner{
    align-items:center;
  }
  .homeRefFooter__columns{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:640px){
  .homeRefTopbar__inner{
    min-height:64px;
  }
  .homeRefBrand{
    font-size:clamp(22px,7vw,34px);
  }
  .homeRefMain{
    padding-top:64px;
  }
  .homeRefHero{
    height:64vh;
    min-height:340px;
  }
  .homeRefHero h1{
    left:8px;
    bottom:0;
    font-size:clamp(42px,14vw,78px);
  }
  .homeRefPhilosophy{
    grid-template-columns:1fr;
    padding-top:56px;
    padding-bottom:78px;
  }
  .homeRefPhilosophy__title,
  .homeRefPhilosophy__cta{
    grid-column:auto;
  }
  .homeRefPhilosophy__text{
    max-width:28ch;
  }
  .homeRefMethod{
    padding-bottom:66px;
    background-image:none;
  }
  .homeRefMethod__grid{
    grid-template-columns:1fr;
  }
  .homeRefShowcase{
    padding-top:74px;
    padding-bottom:66px;
  }
  .homeRefShowcase__grid{
    grid-auto-columns:minmax(240px,86vw);
  }
  .homeRefFinal{
    min-height:clamp(260px,68vw,380px);
    padding-top:0;
    padding-bottom:0;
  }
  .homeRefFinal__inner{
    min-height:clamp(260px,68vw,380px);
    gap:16px;
  }
  .homeRefFooter__columns{
    grid-template-columns:1fr;
    gap:20px;
  }
  .homeRefFooter__contactLink{
    margin-top:10px;
  }
  .homeRefFooter__contactLink--phone{
    font-size:clamp(24px,11vw,38px);
  }
  .homeRefFooter__bottom{
    flex-direction:column;
    align-items:flex-start;
    padding-bottom:18px;
  }
}

/* Reference style: inner pages */
.refInnerPage .homeRefTopbar{
  background:rgba(243,243,242,.94);
}
.refInnerPage .homeRefNav a{
  opacity:.72;
}
.refInnerPage .homeRefNav a:hover,
.refInnerPage .homeRefNav a.is-current{
  opacity:1;
}
.refInnerPage .homeRefNav a.is-current{
  text-decoration:underline;
  text-underline-offset:.2em;
  text-decoration-thickness:1px;
}

.refPageMain{
  padding-top:72px;
}
.refPageIntro,
.refProjectsSection__inner,
.refAboutSection__inner,
.refContactSection__inner,
.refFooter__inner{
  width:var(--ref-max);
  margin:0 auto;
  padding-left:22px;
  padding-right:22px;
}
.refPageIntro{
  padding-top:42px;
  padding-bottom:34px;
  border-bottom:1px solid var(--ref-line);
}
.refPageKicker{
  margin:0;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(18,20,23,.58);
}
.refPageIntro h1{
  margin:14px 0 0;
  font-size:clamp(42px,5.2vw,92px);
  line-height:.9;
  letter-spacing:-.045em;
  font-weight:500;
  text-transform:uppercase;
}
.refPageIntro p{
  margin:16px 0 0;
  max-width:56ch;
  color:rgba(18,20,23,.72);
  font-size:clamp(16px,1.15vw,21px);
  line-height:1.42;
}

.refInlineLink{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-bottom:1px solid var(--ref-line);
  padding-bottom:6px;
  font-size:14px;
  line-height:1;
  letter-spacing:.09em;
  text-transform:uppercase;
}
.refInlineLink--large{
  margin-top:8px;
  font-size:16px;
}
.refInlineLink:hover{
  opacity:.65;
}

.refProjectsSection{
  padding:28px 0 92px;
}
.refProjectsToolbar{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  padding-bottom:18px;
  margin-bottom:24px;
  border-bottom:1px solid var(--ref-line);
}
.refProjectsPage .tabs{
  gap:22px;
}
.refProjectsPage .tab{
  font-size:15px;
  color:rgba(18,20,23,.5);
  letter-spacing:.04em;
  text-transform:uppercase;
}
.refProjectsPage .tab.is-active{
  color:#121417;
}
.refProjectsPage .projectsGrid{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.refProjectsPage .projectCard{
  display:flex;
  flex-direction:column;
  height:100%;
  border:1px solid var(--ref-line);
  background:#f3f3f2;
  color:#121417;
}
.refProjectsPage .projectCard__media{
  padding:4px;
  border-bottom:1px solid var(--ref-line);
}
.refProjectsPage .projectCard img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  filter:none;
}
.refProjectsPage .projectCard__info{
  text-align:left;
  padding:10px 10px 12px;
  display:flex;
  flex-direction:column;
  flex:1;
  gap:8px;
}
.refProjectsPage .projectCard__title{
  margin:0;
  font-size:clamp(34px,2.4vw,64px);
  line-height:.9;
  letter-spacing:-.05em;
  font-weight:500;
  text-transform:uppercase;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.refProjectsPage .projectCard__meta{
  margin:0;
  font-size:13px;
  line-height:1.2;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.refProjectsPage .projectCard__description{
  margin:0;
  font-size:12px;
  line-height:1.34;
  color:rgba(18,20,23,.78);
  min-height:2.68em;
}
.refProjectsPage .projectCard__cta{
  margin-top:auto;
  padding-top:10px;
  border-top:1px solid var(--ref-line);
  font-size:14px;
  line-height:1;
  letter-spacing:.01em;
  text-transform:uppercase;
}

.refAboutSection{
  padding:34px 0 96px;
}
.refAboutSection__inner h2{
  margin:0;
  font-size:clamp(36px,4.8vw,84px);
  line-height:.92;
  letter-spacing:-.04em;
  text-transform:uppercase;
  font-weight:500;
}
.refAboutColumns{
  margin-top:20px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:30px;
}
.refAboutColumns p{
  margin:0;
  max-width:34ch;
  color:rgba(18,20,23,.74);
  font-size:clamp(16px,1.1vw,20px);
  line-height:1.45;
}
.refAboutFacts{
  margin-top:28px;
  border-top:1px solid var(--ref-line);
}
.refAboutFact{
  display:grid;
  grid-template-columns:minmax(130px,200px) 1fr;
  gap:14px;
  padding:12px 0;
  border-bottom:1px solid var(--ref-line);
  font-size:14px;
}
.refAboutFact span:first-child{
  color:rgba(18,20,23,.56);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:11px;
}

.refContactSection{
  padding:30px 0 90px;
}
.refContactSection__inner{
  display:grid;
  grid-template-columns:minmax(260px,.85fr) minmax(300px,1.15fr);
  gap:32px;
  align-items:start;
}
.refContactInfo{
  border-top:1px solid var(--ref-line);
}
.refContactRow{
  display:grid;
  grid-template-columns:minmax(80px,110px) 1fr;
  gap:10px;
  padding:14px 0;
  border-bottom:1px solid var(--ref-line);
}
.refContactRow span{
  color:rgba(18,20,23,.56);
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.refContactRow a{
  font-size:15px;
}
.refContactForm{
  padding:18px;
  border:1px solid var(--ref-line);
  background:rgba(255,255,255,.24);
}
.refFormLabel{
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(18,20,23,.56);
}
.refContactForm input,
.refContactForm textarea{
  border:1px solid rgba(18,20,23,.18);
  border-radius:0;
  background:rgba(255,255,255,.7);
  padding:12px;
}
.refContactForm input:focus,
.refContactForm textarea:focus{
  border-color:rgba(18,20,23,.45);
}
.refPrimaryBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid #121417;
  background:#121417;
  color:#f4f4f2;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:12px;
  line-height:1;
  padding:14px 18px;
}
.refPrimaryBtn:hover{
  background:#2a2f37;
  border-color:#2a2f37;
}
.refFormNote{
  color:rgba(18,20,23,.56);
  font-size:12px;
}

.refProjectMain{
  width:var(--ref-max);
  margin:72px auto 0;
  border-top:1px solid var(--ref-line);
  min-height:calc(100vh - 72px);
}
.refProjectPage .projectEditorial{
  grid-template-columns:minmax(340px,44%) 1fr;
  background:transparent;
}
.refProjectPage .projectEditorial__left{
  border-right:1px solid var(--ref-line);
  background:transparent;
}
.refProjectPage .projectEditorial__leftInner{
  top:72px;
  max-height:calc(100vh - 72px);
  overflow:auto;
  padding:34px 22px 46px;
}
.refProjectPage .projectEditorial__kicker{
  color:rgba(18,20,23,.58);
  font-size:11px;
  letter-spacing:.12em;
}
.refProjectPage .projectEditorial__title{
  margin-top:10px;
  font-size:clamp(36px,4.4vw,74px);
  line-height:.92;
  font-family:var(--sans);
  font-weight:500;
}
.refProjectPage .projectEditorial__tagline{
  margin-top:12px;
  font-size:clamp(20px,2.2vw,38px);
  line-height:1;
}
.refProjectPage .projectEditorial__crumbs{
  margin-top:18px;
  color:rgba(18,20,23,.52);
}
.refProjectPage .projectEditorial__crumbs a{
  color:inherit;
}
.refProjectPage .projectEditorial__facts{
  margin-top:24px;
}
.refProjectPage .projectEditorial__facts li{
  border-top:1px solid var(--ref-line);
  grid-template-columns:minmax(130px,170px) 1fr;
}
.refProjectPage .projectEditorial__factLabel{
  padding-left:0;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(18,20,23,.54);
}
.refProjectPage .projectEditorial__factLabel::before{
  display:none;
}
.refProjectPage .projectEditorial__factValue{
  color:#121417;
  font-size:14px;
}
.refProjectPage .projectEditorial__section{
  margin-top:26px;
}
.refProjectPage .projectEditorial__sectionTitle{
  margin-bottom:10px;
  font-size:18px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-family:var(--sans);
  font-weight:600;
}
.refProjectPage .projectEditorial__text{
  gap:10px;
}
.refProjectPage .projectEditorial__text .muted{
  color:rgba(18,20,23,.74);
  line-height:1.45;
}
.refProjectPage .projectEditorial__plan{
  border:1px solid var(--ref-line);
  border-radius:0;
  background:rgba(255,255,255,.28);
}
.refProjectPage .projectEditorial__planTitle{
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.refProjectPage .projectEditorial__planRow{
  border-top:1px solid var(--ref-line);
  font-size:13px;
  color:rgba(18,20,23,.76);
}
.refProjectPage .projectEditorial__right{
  background:transparent;
}
.refProjectPage .projectEditorial__visual{
  border-bottom:1px solid var(--ref-line);
}
.refProjectPage .projectEditorial__visual--wide img,
.refProjectPage .projectEditorial__visual--standard img{
  aspect-ratio:16/10;
  min-height:260px;
}

.refFooter{
  border-top:1px solid var(--ref-line);
}
.refFooter__inner{
  padding-top:14px;
  padding-bottom:30px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.refFooter__inner p,
.refFooter__inner a{
  margin:0;
  font-size:13px;
  color:rgba(18,20,23,.62);
}

@media (max-width:1120px){
  .refPageIntro,
  .refProjectsSection__inner,
  .refAboutSection__inner,
  .refContactSection__inner,
  .refFooter__inner{
    padding-left:16px;
    padding-right:16px;
  }
  .refProjectsPage .projectsGrid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .refProjectMain{
    width:var(--ref-max);
  }
}
@media (max-width:900px){
  .refProjectsToolbar{
    flex-direction:column;
    align-items:flex-start;
  }
  .refAboutColumns,
  .refContactSection__inner{
    grid-template-columns:1fr;
    gap:18px;
  }
  .refProjectPage .projectEditorial{
    grid-template-columns:1fr;
  }
  .refProjectPage .projectEditorial__left{
    border-right:none;
    border-bottom:1px solid var(--ref-line);
  }
  .refProjectPage .projectEditorial__leftInner{
    position:static;
    top:auto;
    max-height:none;
    overflow:visible;
    padding:26px 16px 34px;
  }
}
@media (max-width:640px){
  .refPageMain{
    padding-top:64px;
  }
  .refPageIntro h1{
    font-size:clamp(34px,12.2vw,52px);
  }
  .refProjectsPage .projectsGrid{
    grid-template-columns:1fr;
  }
  .refAboutFact,
  .refContactRow{
    grid-template-columns:1fr;
    gap:6px;
  }
  .refFooter__inner{
    flex-direction:column;
    align-items:flex-start;
  }
}
