@font-face { font-family: "Industry"; src: url("../fonts/industry-light.woff") format("woff"); font-style: normal; font-weight: 100; font-display: swap; }
@font-face { font-family: "Industry"; src: url("../fonts/industry-book.woff") format("woff"); font-style: normal; font-weight: 300; font-display: swap; }
@font-face { font-family: "Industry"; src: url("../fonts/industry-demi.woff") format("woff"); font-style: normal; font-weight: 400; font-display: swap; }
@font-face { font-family: "Industry"; src: url("../fonts/industry-medium.woff") format("woff"); font-style: normal; font-weight: 500; font-display: swap; }

:root {
	--ink: #1d211e;
	--paper: #f4f1ea;
	--sand: #d9d0c0;
	--accent: #9c6b45;
	--white: #fff;
	--header: 88px;
	--serif: "Mulish", sans-serif;
	--sans: "Mulish", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink); font: 300 16px/1.7 var(--sans); -webkit-font-smoothing: antialiased; }
body, button, input, textarea, select, option { font-family: "Mulish", sans-serif; }
body.nav-open { overflow: hidden; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { font-family: var(--serif); font-weight: 300; line-height: 1.08; letter-spacing: -.025em; }
h1 { font-size: clamp(3.5rem, 9vw, 8.5rem); }
h2 { font-size: clamp(2.3rem, 5vw, 5rem); }
.shell { width: min(100% - 40px, 1320px); margin-inline: auto; }
.skip-link { position: fixed; z-index: 1000; top: 8px; left: 8px; padding: 10px 16px; background: var(--white); transform: translateY(-150%); }
.skip-link:focus { transform: none; }
.screen-reader-text { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.eyebrow { margin-bottom: 18px; font-size: .73rem; font-weight: 600; letter-spacing: .16em; line-height: 1.4; text-transform: uppercase; }
.button { display: inline-flex; align-items: center; gap: 36px; min-height: 52px; padding: 0 22px; border: 1px solid currentColor; font-size: .78rem; font-weight: 600; letter-spacing: .09em; text-transform: uppercase; transition: background .25s, color .25s, gap .25s; }
.button:hover, .button:focus-visible { gap: 48px; background: var(--ink); color: var(--white); }
.button--light:hover, .button--light:focus-visible { background: var(--white); color: var(--ink); }
.text-link { display: inline-flex; gap: 20px; align-items: center; padding-block: 8px; border-bottom: 1px solid currentColor; font-size: .78rem; font-weight: 600; letter-spacing: .09em; text-transform: uppercase; }
.text-link span { transition: transform .25s; }
.text-link:hover span { transform: translateX(6px); }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

.site-header { position: fixed; z-index: 100; inset: 0 0 auto; color: var(--white); transition: background .3s, color .3s, box-shadow .3s; }
.site-header.is-scrolled, body:not(.home) .site-header { background: rgba(244, 241, 234, .94); color: var(--ink); box-shadow: 0 1px 0 rgba(29, 33, 30, .12); backdrop-filter: blur(14px); }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; min-height: var(--header); }
.brand { display: inline-flex; align-items: center; }
.brand__logo { display: block; width: 118px; height: 62px; object-fit: contain; object-position: left center; transition: filter .3s; }
.site-header.is-scrolled .brand__logo, body:not(.home) .site-header .brand__logo { filter: invert(1); }
.brand__mark { display: grid; width: 42px; height: 42px; place-items: center; border: 1px solid currentColor; font-family: var(--serif); font-size: 1.6rem; }
.brand__name { font-size: 1.05rem; font-weight: 600; letter-spacing: .18em; line-height: 1.1; }
.brand__name small { display: block; margin-top: 5px; font-size: .48rem; font-weight: 500; letter-spacing: .12em; }
.custom-logo { max-width: 180px; max-height: 60px; width: auto; }
.site-nav__list { display: flex; align-items: center; gap: clamp(20px, 2.8vw, 44px); margin: 0; padding: 0; list-style: none; }
.site-nav a { position: relative; font-size: .74rem; font-weight: 600; letter-spacing: .11em; text-transform: uppercase; }
.site-nav a::after { position: absolute; inset: auto 0 -8px; height: 1px; background: currentColor; content: ""; transform: scaleX(0); transform-origin: right; transition: transform .25s; }
.site-nav a:hover::after, .site-nav .current-menu-item a::after { transform: scaleX(1); transform-origin: left; }
.nav-toggle { display: none; width: 44px; height: 44px; padding: 10px; border: 0; background: transparent; color: inherit; }
.nav-toggle span:not(.screen-reader-text) { display: block; height: 1px; margin: 6px 0; background: currentColor; }

.home-hero { position: relative; height: 100svh; min-height: 620px; overflow: hidden; background: var(--ink); color: var(--white); cursor: grab; touch-action: pan-x; }
.home-hero:active { cursor: grabbing; }
.home-hero::after { position: absolute; z-index: 1; inset: 0; pointer-events: none; content: ""; background: repeating-linear-gradient(90deg, transparent 0, transparent calc(7.142857% - 1px), rgba(255,255,255,.16) calc(7.142857% - 1px), rgba(255,255,255,.16) 7.142857%); }
.home-hero__track { width: 100%; height: 100%; transition: transform 1s cubic-bezier(.77, 0, .18, 1); will-change: transform; }
.home-hero__slide { position: relative; flex: 0 0 100%; width: 100%; height: 100%; overflow: hidden; }
.home-hero__image-link, .home-hero__slide picture, .home-hero__slide img { display: block; width: 100%; height: 100%; object-fit: cover; }
.home-hero__slide img { transform: scale(1.04); transition: transform 7s ease-out; }
.home-hero__slide.is-active img { transform: scale(1.1); }
.home-hero__shade { position: absolute; inset: 0; background: rgba(0, 0, 0, .35); }
.project-hero__shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(8, 11, 9, .2), rgba(8, 11, 9, .04) 70%), linear-gradient(0deg, rgba(8, 11, 9, .27), transparent 55%); }
.home-hero__content { position: absolute; z-index: 2; inset: 0; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding-top: 13vh; padding-left: 20.5%; }
.home-hero__content h1 { max-width: 720px; margin-bottom: 18px; font-size: clamp(2.3rem, 3vw, 4rem); font-weight: 300; letter-spacing: .01em; text-transform: uppercase; }
.home-hero__content .button { min-height: auto; padding: 0 0 0 32px; border: 0; color: #d7a51e; font-size: .9rem; letter-spacing: .35em; }
.home-hero__content .button::before { position: absolute; left: 0; width: 21px; height: 1px; background: currentColor; content: ""; }
.home-hero__content .button:hover { gap: 36px; background: transparent; color: #f2c443; }
.home-hero__fallback { background: linear-gradient(135deg, #202720, #685747); }
.home-hero__controls { position: absolute; z-index: 3; top: 50%; right: 36px; bottom: auto; left: auto; width: auto; display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 13px; transform: translateY(-50%); }
.home-hero__controls button { border: 0; background: transparent; color: inherit; cursor: pointer; font-size: 1.1rem; }
.home-hero__controls span { min-width: 70px; text-align: center; font-size: .7rem; letter-spacing: .1em; }
.home-hero__progress { width: 2px; height: 120px; overflow: hidden; background: rgba(255,255,255,.35); }
.home-hero__progress span { display: block; min-width: 0; width: 100%; height: 12.5%; background: var(--white); transition: width 1s cubic-bezier(.77, 0, .18, 1), height 1s cubic-bezier(.77, 0, .18, 1); }
@keyframes heroZoom { from { transform: scale(1.03); } to { transform: scale(1.09); } }

.intro-section { padding-block: clamp(90px, 13vw, 190px); }
.intro-section h2 { max-width: 1120px; margin-bottom: 45px; }
.intro-section--page { padding-top: 30px; }
.projects-section { padding-block: 90px 140px; background: #e8e3d9; }
.section-heading { display: flex; align-items: end; justify-content: space-between; gap: 40px; margin-bottom: 60px; }
.section-heading h2 { margin-bottom: 0; }
.project-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 70px 28px; }
.project-grid--archive { padding-bottom: 130px; }
.project-card:nth-child(3n+2) { margin-top: 90px; }
.project-card__image { position: relative; display: block; overflow: hidden; aspect-ratio: 4 / 3; background: var(--sand); }
.project-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s ease, filter .4s; }
.project-card__image span { position: absolute; right: 18px; bottom: 18px; padding: 12px 16px; background: var(--paper); font-size: .69rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; opacity: 0; transform: translateY(8px); transition: opacity .25s, transform .25s; }
.project-card__image:hover img { transform: scale(1.035); filter: brightness(.82); }
.project-card__image:hover span { opacity: 1; transform: none; }
.project-card__meta { display: flex; justify-content: space-between; gap: 20px; padding-top: 18px; }
.project-card__meta h2 { margin-bottom: 5px; font-size: clamp(1.7rem, 3vw, 2.7rem); }
.project-card__meta p { margin: 0; color: #64675f; font-size: .78rem; }
.testimonials-section { padding-block: clamp(90px, 11vw, 150px); background: var(--ink); color: var(--white); }
.testimonial-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.testimonial-card { display: flex; min-height: 360px; flex-direction: column; padding: clamp(28px, 3.5vw, 48px); border: 1px solid rgba(255,255,255,.16); background: rgba(255,255,255,.035); }
.testimonial-card__rating { color: #d7a51e; font-size: .82rem; letter-spacing: .2em; }
.testimonial-card blockquote { flex: 1; margin: 38px 0 45px; }
.testimonial-card blockquote p { margin: 0; font-size: clamp(1.25rem, 2vw, 1.8rem); line-height: 1.55; }
.testimonial-card__client { display: flex; align-items: center; gap: 15px; }
.testimonial-card__client img { width: 52px; height: 52px; border-radius: 50%; object-fit: cover; filter: saturate(.8); }
.testimonial-card__client strong, .testimonial-card__client span { display: block; }
.testimonial-card__client strong { font-size: .85rem; font-weight: 600; }
.testimonial-card__client span { margin-top: 3px; color: #aeb2aa; font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; }

.page-hero { padding-top: calc(var(--header) + 100px); }
.page-hero--compact { min-height: 55vh; display: flex; align-items: flex-end; padding-bottom: 75px; background: #dcd4c6; }
.page-hero h1 { margin: 0; }
.subnav { display: flex; gap: 36px; padding-block: 32px; border-bottom: 1px solid rgba(29, 33, 30, .18); }
.subnav a { padding-bottom: 6px; font-size: .76rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; }
.subnav .is-active { border-bottom: 1px solid; }
.prose { max-width: 820px; padding-block: 70px 120px; }
.prose > *:first-child { margin-top: 0; }
.prose p { margin-bottom: 1.5em; }
.prose--large { padding: 0; font-family: var(--serif); font-size: clamp(1.6rem, 2.4vw, 2.5rem); line-height: 1.35; }
.about-layout { display: grid; grid-template-columns: .9fr 1.1fr; gap: 80px; align-items: start; padding-block: 100px 140px; }
.about-layout > img { width: 100%; }
.service-list { padding-bottom: 130px; }
.service-row { display: grid; grid-template-columns: .8fr 1.2fr; gap: 9vw; align-items: center; padding-block: 70px; border-top: 1px solid rgba(29, 33, 30, .18); }
.service-row:nth-child(even) .service-row__content { order: 2; }
.service-row h2 { margin-bottom: 25px; }
.service-row .prose { padding: 0; }
.service-row__image { overflow: hidden; aspect-ratio: 7 / 5; }
.service-row__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s; }
.service-row:hover img { transform: scale(1.03); }
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 60px 24px; padding-bottom: 140px; }
.team-card img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; filter: saturate(.75); transition: filter .3s; }
.team-card:hover img { filter: saturate(1); }
.team-card h2 { margin: 18px 0 4px; font-size: 2rem; }
.team-card p { color: #66685f; font-size: .8rem; }

.project-hero { position: relative; height: 88svh; min-height: 650px; color: var(--white); }
.project-hero > img { width: 100%; height: 100%; object-fit: cover; }
.project-hero__content { position: absolute; z-index: 2; inset: var(--header) 0 0; display: flex; flex-direction: column; justify-content: flex-end; padding-bottom: 70px; }
.project-hero__content h1 { max-width: 1100px; margin: 40px 0 0; }
.back-link { align-self: flex-start; font-size: .75rem; letter-spacing: .08em; text-transform: uppercase; }
.project-intro { display: grid; grid-template-columns: 1.4fr .6fr; gap: 10vw; padding-block: 80px 120px; }
.project-intro .prose { padding: 0; font-size: 1.1rem; }
.project-facts { margin: 0; }
.project-facts div { display: grid; grid-template-columns: 1fr 1.5fr; gap: 20px; padding: 15px 0; border-bottom: 1px solid rgba(29, 33, 30, .16); }
.project-facts dt { font-size: .7rem; letter-spacing: .09em; text-transform: uppercase; }
.project-facts dd { margin: 0; }
.project-gallery { display: grid; gap: 24px; padding-bottom: 130px; }
.project-gallery figure { margin: 0; }
.project-gallery img { width: 100%; }
.before-after { padding-bottom: 130px; }
.before-after__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.before-after figure { position: relative; margin: 0; }
.before-after img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.before-after figcaption { position: absolute; bottom: 12px; left: 12px; padding: 8px 12px; background: var(--paper); font-size: .7rem; text-transform: uppercase; }

.contact-hero { padding-block: calc(var(--header) + 100px) 100px; background: var(--ink); color: var(--white); }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10vw; align-items: start; }
.contact-grid h1 { font-size: clamp(3.5rem, 7vw, 7rem); }
.contact-grid address { margin: 50px 0 20px; font-style: normal; }
.contact-form input:not([type=submit]), .contact-form textarea, .contact-form select { width: 100%; padding: 15px 0; border: 0; border-bottom: 1px solid rgba(255,255,255,.4); border-radius: 0; outline: 0; background: transparent; color: var(--white); }
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--white); }
.contact-form input[type=submit], .contact-form button[type=submit] { min-height: 52px; padding: 0 28px; border: 1px solid var(--white); background: transparent; color: var(--white); cursor: pointer; }
.map-embed iframe { display: block; width: 100%; height: 520px; border: 0; filter: grayscale(1) contrast(.9); }
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 50px 24px; padding-block: 100px; }
.post-card img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.post-card .eyebrow { margin: 20px 0 8px; }
.post-card h2 { font-size: 2rem; }
.post-featured { margin-top: -30px; }

.cta { padding-block: clamp(90px, 12vw, 160px); background: var(--accent); color: var(--white); }
.cta__inner { display: flex; flex-direction: column; align-items: flex-start; }
.cta h2 { max-width: 900px; margin-bottom: 45px; }
.site-footer { padding: 90px 0 25px; background: #151815; color: #d9dbd5; }
.site-footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 8vw; padding-bottom: 80px; }
.site-footer p { max-width: 440px; color: #9da19a; }
.site-footer address { font-style: normal; }
.site-footer__grid > div:last-child a { display: block; margin-bottom: 8px; }
.brand--footer { margin-bottom: 24px; color: var(--white); }
.site-footer__bottom { display: flex; justify-content: space-between; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.14); font-size: .72rem; }
.site-footer__bottom p { margin: 0; }
.floating-actions { position: fixed; z-index: 110; inset: auto 0 18px; pointer-events: none; }
.floating-action { position: absolute; bottom: 0; display: grid; width: 54px; height: 54px; place-items: center; border: 3px solid var(--white); border-radius: 50%; color: var(--white); box-shadow: 0 6px 20px rgba(0,0,0,.28); pointer-events: auto; transition: transform .25s, box-shadow .25s; }
.floating-action:hover { transform: translateY(-4px); box-shadow: 0 10px 26px rgba(0,0,0,.35); }
.floating-action svg { width: 27px; height: 27px; fill: currentColor; }
.floating-action--call { left: 18px; background: #c52222; }
.floating-action--whatsapp { right: 18px; background: #55c53f; }

@media (min-width: 901px) {
	body.home .site-header { inset: 0; height: 0; background: transparent; box-shadow: none; color: var(--white); pointer-events: none; }
	body.home .site-header__inner { width: 100%; min-height: 0; margin: 0; }
	body.home .brand { position: fixed; z-index: 102; top: 18px; left: 22px; pointer-events: auto; }
	body.home .brand__logo, body.home .site-header.is-scrolled .brand__logo { width: 128px; height: 138px; filter: none; object-position: left top; }
	body.home .site-nav { position: fixed; z-index: 102; top: 10.5vh; right: 10.5vw; pointer-events: auto; }
	body.home .site-nav__list { display: block; }
	body.home .site-nav li { margin-bottom: 13px; }
	body.home .site-nav a { font-size: 1rem; font-weight: 300; letter-spacing: .03em; }
	body.home .site-nav a::after { bottom: -3px; }
}

/* Portfolio archive */
.portfolio-intro { padding-block: clamp(90px, 12vw, 170px); }
.portfolio-intro h2 { max-width: 1050px; margin: 0; font-size: clamp(2.2rem, 4.6vw, 4.8rem); }
.portfolio-list { padding-bottom: 120px; }
.portfolio-row { margin-bottom: clamp(80px, 12vw, 170px); }
.portfolio-row__image { position: relative; display: block; width: min(88vw, 1480px); height: min(68vh, 760px); overflow: hidden; background: var(--sand); }
.portfolio-row:nth-child(even) .portfolio-row__image { margin-left: auto; }
.portfolio-row__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s cubic-bezier(.19,1,.22,1), filter .5s; }
.portfolio-row__image:hover img { transform: scale(1.035); filter: brightness(.78); }
.portfolio-row__view { position: absolute; right: 28px; bottom: 28px; padding: 13px 17px; background: var(--paper); font-size: .7rem; font-weight: 400; letter-spacing: .11em; text-transform: uppercase; opacity: 0; transform: translateY(10px); transition: opacity .3s, transform .3s; }
.portfolio-row__image:hover .portfolio-row__view { opacity: 1; transform: none; }
.portfolio-row__content { display: grid; grid-template-columns: 70px 1fr 70px; align-items: end; gap: 25px; padding-top: 26px; }
.portfolio-row__number { align-self: start; padding-top: 9px; color: #74776f; font-size: .72rem; letter-spacing: .1em; }
.portfolio-row__content .eyebrow { margin-bottom: 10px; color: #74776f; }
.portfolio-row__content h2 { margin: 0; font-size: clamp(2.4rem, 5vw, 5.5rem); }
.portfolio-row__arrow { display: grid; width: 58px; height: 58px; place-items: center; border: 1px solid rgba(29,33,30,.3); font-size: 1.2rem; transition: background .25s, color .25s, transform .25s; }
.portfolio-row__arrow:hover { background: var(--ink); color: var(--white); transform: translateX(5px); }

/* Team */
.leadership-list { padding-bottom: 120px; }
.leader-card { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr); align-items: center; gap: clamp(45px, 8vw, 130px); margin-bottom: clamp(80px, 11vw, 150px); }
.leader-card:nth-child(even) { grid-template-columns: minmax(280px, .65fr) minmax(0, 1.35fr); }
.leader-card:nth-child(even) .leader-card__image { order: 2; }
.leader-card__image { overflow: hidden; aspect-ratio: 7 / 5; background: var(--sand); }
.leader-card__image img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.78); transition: transform .8s cubic-bezier(.19,1,.22,1), filter .4s; }
.leader-card:hover img { transform: scale(1.025); filter: saturate(1); }
.leader-card__content { display: grid; grid-template-columns: 40px 1fr; gap: 22px; align-items: start; }
.leader-card__content > span { padding-top: 10px; color: #777a72; font-size: .72rem; letter-spacing: .1em; }
.leader-card h2 { margin-bottom: 12px; font-size: clamp(2.7rem, 5vw, 5.5rem); }
.leader-card p, .team-card p { color: var(--accent); font-size: .72rem; font-weight: 400; letter-spacing: .11em; text-transform: uppercase; }
.team-grid--studio { padding-top: 30px; border-top: 1px solid rgba(29,33,30,.18); }
.team-card { position: relative; }
.team-card img { aspect-ratio: 7 / 8; }
.team-card h2 { font-size: clamp(1.7rem, 2.5vw, 2.5rem); }

/* Footer */
.site-footer { padding-top: 0; }
.site-footer__lead { padding-block: clamp(80px, 11vw, 145px); border-bottom: 1px solid rgba(255,255,255,.14); }
.site-footer__lead > a { display: flex; align-items: center; justify-content: space-between; gap: 40px; font-size: clamp(2.7rem, 6vw, 6.6rem); font-weight: 100; line-height: 1.05; letter-spacing: -.03em; }
.site-footer__lead > a span:last-child { font-size: .55em; transition: transform .35s; }
.site-footer__lead > a:hover span:last-child { transform: translateX(12px); }
.site-footer__grid { grid-template-columns: 1.4fr .7fr 1fr 1fr; gap: clamp(35px, 6vw, 90px); padding-block: 80px; }
.site-footer__brand { padding-right: 30px; }
.brand--footer .brand__logo { width: 105px; height: 105px; filter: none; }
.site-footer__links a { display: block; width: max-content; margin-bottom: 9px; color: #d9dbd5; transition: color .2s, transform .2s; }
.site-footer__links a:hover { color: var(--white); transform: translateX(4px); }
.site-footer__links li { margin: 0; padding: 0; list-style: none; }
.site-footer address { color: #9da19a; }
.team-bio { margin-top: 18px; color: #66685f; font-size: .92rem; }
.team-bio p:last-child { margin-bottom: 0; }
.contact-description { max-width: 560px; margin-top: 24px; }
.contact-grid .text-link { margin: 8px 18px 0 0; }
.scroll-to-top { position: absolute; right: 22px; bottom: 70px; display: grid; width: 46px; height: 46px; padding: 0; place-items: center; border: 1px solid rgba(255,255,255,.65); border-radius: 50%; background: rgba(21,24,21,.88); color: var(--white); box-shadow: 0 6px 20px rgba(0,0,0,.2); cursor: pointer; opacity: 0; pointer-events: none; transform: translateY(10px); transition: opacity .25s, transform .25s, background .25s; }
.scroll-to-top.is-visible { opacity: 1; pointer-events: auto; transform: none; }
.scroll-to-top:hover, .scroll-to-top:focus-visible { background: var(--accent); }
.scroll-to-top svg { width: 24px; height: 24px; fill: currentColor; }

@media (max-width: 900px) {
	:root { --header: 72px; }
	.nav-toggle { position: absolute; z-index: 102; top: 14px; right: 14px; display: block; color: currentColor; }
	.nav-toggle span:not(.screen-reader-text) { height: 2px; }
	.site-nav { position: fixed; inset: 0; display: grid; place-items: center; background: var(--ink); color: var(--white); opacity: 0; visibility: hidden; transition: opacity .3s, visibility .3s; }
	.site-nav.is-open { opacity: 1; visibility: visible; }
	.site-nav__list { flex-direction: column; gap: 24px; }
	.site-nav a { font: 500 clamp(2rem, 8vw, 4rem)/1.1 var(--serif); letter-spacing: -.02em; text-transform: none; }
	.nav-open .nav-toggle { color: var(--white); }
	.home-hero::after { background-size: 25% 100%; }
	.home-hero__content { padding: var(--header) 28px 92px; justify-content: flex-end; }
	.home-hero__content h1 { margin-bottom: 12px; }
	.home-hero__controls { top: auto; right: 14px; bottom: 22px; flex-direction: row; transform: none; }
	.home-hero__progress { width: 100px; height: 2px; }
	.home-hero__progress span { width: 12.5%; height: 100%; }
	.home-hero__controls [data-slide-count] { display: none; }
	.project-grid, .about-layout, .project-intro, .contact-grid { grid-template-columns: 1fr; }
	.testimonial-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.project-card:nth-child(3n+2) { margin-top: 0; }
	.team-grid, .post-grid { grid-template-columns: repeat(2, 1fr); }
	.service-row { gap: 40px; }
	.project-intro { gap: 50px; }
	.leader-card, .leader-card:nth-child(even) { grid-template-columns: 1fr; gap: 32px; }
	.leader-card:nth-child(even) .leader-card__image { order: initial; }
	.site-footer__grid { grid-template-columns: 1fr 1fr; }
	.site-footer__grid > div:first-child { grid-column: 1 / -1; }
}

@media (max-width: 640px) {
	.shell { width: min(100% - 28px, 1320px); }
	.home-hero__content h1 { font-size: clamp(2.3rem, 11vw, 3.5rem); }
	.intro-section h2 { font-size: clamp(2rem, 10vw, 3rem); }
	.section-heading { align-items: flex-start; flex-direction: column; }
	.project-grid, .team-grid, .post-grid, .service-row, .before-after__grid, .testimonial-grid { grid-template-columns: 1fr; }
	.service-row:nth-child(even) .service-row__content { order: initial; }
	.service-row__content { order: 2; }
	.page-hero--compact { min-height: 48vh; padding-bottom: 45px; }
	.about-layout { gap: 45px; padding-block: 70px 100px; }
	.team-grid { gap: 40px; }
	.portfolio-row__image { width: 100%; height: 58vh; min-height: 420px; }
	.portfolio-row__content { grid-template-columns: 35px 1fr; gap: 12px; }
	.portfolio-row__arrow { display: none; }
	.leader-card__content { grid-template-columns: 30px 1fr; gap: 12px; }
	.site-footer__lead > a { align-items: flex-end; }
	.site-footer__grid { grid-template-columns: 1fr; }
	.site-footer__grid > div:first-child { grid-column: auto; }
	.site-footer__bottom { flex-direction: column; gap: 8px; }
	.floating-actions { bottom: 12px; }
	.floating-action { width: 48px; height: 48px; border-width: 2px; }
	.floating-action--call { left: 12px; }
	.floating-action--whatsapp { right: 12px; }
	.scroll-to-top { right: 13px; bottom: 62px; width: 42px; height: 42px; }
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
	.reveal { opacity: 1; transform: none; }
}
