@font-face {
  font-family: "AY Inter";
  src: url("/assets/fonts/inter-light.ttf") format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "AY Inter";
  src: url("/assets/fonts/inter-light-italic.ttf") format("truetype");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "AY Inter";
  src: url("/assets/fonts/inter-medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "AY Inter";
  src: url("/assets/fonts/inter-medium-italic.ttf") format("truetype");
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Phillia";
  src: url("/assets/fonts/phillia.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
:root {
  --ay-black: #050505;
  --ay-charcoal: #343132;
  --ay-white: #f7f6f3;
  --ay-ivory: #efebe5;
  --ay-stone: #d8d1c8;
  --ay-soft-stone: #ebe6df;
  --ay-warm-taupe: #b2a685;
  --ay-muted-gold: #9b7245;
  --ay-deep-brown: #432a1f;
  --ay-burgundy-brown: #5a1e0a;
  --ay-blue-grey: #9db5c1;
  --ay-line: rgba(52, 49, 50, 0.15);
  --font-body: "AY Inter", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-script: "Phillia", "Snell Roundhand", "Segoe Script", cursive;
  --container: min(1360px, calc(100vw - 72px));
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-weight: 300;
  color: var(--ay-charcoal);
  background: var(--ay-ivory);
  line-height: 1.65;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
::selection { background: rgba(157, 181, 193, 0.32); }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, textarea, select { font: inherit; }
.skip-link { position: absolute; top: 12px; left: 12px; transform: translateY(-160%); background: var(--ay-black); color: var(--ay-white); padding: 9px 13px; z-index: 999; }
.skip-link:focus { transform: translateY(0); }
.container { width: var(--container); margin: 0 auto; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(239, 235, 229, 0.92);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--ay-line);
}
.navbar { min-height: 82px; display: flex; align-items: center; justify-content: space-between; gap: 36px; }
.brand { width: clamp(250px, 26vw, 420px); flex: 0 1 auto; }
.brand img { width: 100%; height: auto; }
.nav-links { display: flex; align-items: center; gap: clamp(24px, 3.6vw, 58px); }
.nav-links a { font-size: 0.72rem; line-height: 1; letter-spacing: 0.29em; text-transform: uppercase; color: rgba(52,49,50,0.82); transition: color 240ms ease; }
.nav-links a:hover, .nav-links a[aria-current="page"] { color: var(--ay-black); }
.nav-toggle { display: none; width: 42px; height: 42px; border: 1px solid var(--ay-line); background: transparent; align-items: center; justify-content: center; gap: 6px; flex-direction: column; }
.nav-toggle span { width: 19px; height: 1px; background: var(--ay-charcoal); display: block; }
main { overflow: hidden; }
.section { padding: clamp(72px, 8.5vw, 128px) 0; }
.section-tight { padding: clamp(54px, 6.6vw, 98px) 0; }
.section-warm { background: var(--ay-soft-stone); }
.section-stone { background: #e2ddd5; }
.section-dark { background: var(--ay-charcoal); color: var(--ay-ivory); }
.section-brown { background: var(--ay-deep-brown); color: var(--ay-ivory); }
.stack-sm > * + * { margin-top: 12px; }
.stack-md > * + * { margin-top: 20px; }
.stack-lg > * + * { margin-top: 28px; }
.stack-xl > * + * { margin-top: 38px; }
.eyebrow { font-size: 0.74rem; letter-spacing: 0.33em; text-transform: uppercase; color: rgba(52,49,50,0.63); }
.section-dark .eyebrow, .section-brown .eyebrow { color: rgba(239,235,229,0.58); }
h1, h2, h3, p { margin: 0; }
h1, h2 { font-weight: 300; letter-spacing: -0.07em; line-height: 0.95; color: var(--ay-charcoal); }
h1 { font-size: clamp(4.2rem, 8.2vw, 8.8rem); max-width: 780px; }
h2 { font-size: clamp(2.9rem, 5.8vw, 6.4rem); max-width: 780px; }
h3 { font-weight: 500; font-size: 0.96rem; letter-spacing: 0.2em; text-transform: uppercase; line-height: 1.4; color: var(--ay-charcoal); }
.section-dark h2, .section-dark h3, .section-brown h2, .section-brown h3 { color: var(--ay-ivory); }
p { color: rgba(52,49,50,0.78); }
.section-dark p, .section-brown p { color: rgba(239,235,229,0.72); }
.lede { font-size: clamp(1rem, 1.25vw, 1.24rem); line-height: 1.72; color: rgba(52,49,50,0.72); max-width: 660px; }
.section-dark .lede, .section-brown .lede { color: rgba(239,235,229,0.76); }
.text-large { font-size: clamp(1.85rem, 3.2vw, 3.75rem); line-height: 1.12; letter-spacing: -0.045em; color: var(--ay-charcoal); max-width: 900px; }
.section-dark .text-large, .section-brown .text-large { color: var(--ay-ivory); }
.narrow { max-width: 650px; }
.script-note { font-family: var(--font-script); font-size: clamp(1.8rem, 3vw, 3.1rem); line-height: 1; color: var(--ay-muted-gold); }
.section-dark .script-note, .section-brown .script-note { color: #d9d0c4; }
.rule { display: block; width: 64px; height: 1px; background: var(--ay-muted-gold); }
.btn-row { display: flex; flex-wrap: wrap; gap: 16px; }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 15px 22px 14px; border: 1px solid var(--ay-charcoal); font-size: 0.72rem; letter-spacing: 0.26em; text-transform: uppercase; transition: background 240ms ease, color 240ms ease, border-color 240ms ease; }
.btn-primary { background: var(--ay-charcoal); color: var(--ay-ivory); }
.btn-primary:hover { background: var(--ay-black); border-color: var(--ay-black); }
.btn-secondary { background: transparent; color: var(--ay-charcoal); }
.btn-secondary:hover { background: var(--ay-charcoal); color: var(--ay-ivory); }
.section-dark .btn-secondary, .section-brown .btn-secondary { border-color: rgba(239,235,229,0.62); color: var(--ay-ivory); }
.section-dark .btn-secondary:hover, .section-brown .btn-secondary:hover { background: var(--ay-ivory); color: var(--ay-charcoal); }
.inline-link { display: inline-flex; align-items: center; width: fit-content; border-bottom: 1px solid currentColor; padding-bottom: 3px; font-size: 0.76rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ay-deep-brown); }
.section-dark .inline-link, .section-brown .inline-link { color: var(--ay-ivory); }
.hero { min-height: min(780px, calc(100vh - 82px)); display: grid; align-items: center; position: relative; padding: clamp(54px, 6vw, 88px) 0 clamp(66px, 7vw, 104px); }
.hero::after { content: ""; position: absolute; inset: auto -18vw 6vw auto; width: 44vw; height: 44vw; background: radial-gradient(circle, rgba(157,181,193,0.23), transparent 62%); pointer-events: none; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 0.96fr) minmax(340px, 0.72fr); align-items: center; gap: clamp(42px, 6vw, 92px); position: relative; z-index: 1; }
.hero-copy { padding-top: 8px; }
.hero-media { position: relative; min-height: 520px; display: grid; align-items: center; }
.hero-photo { width: min(100%, 500px); height: clamp(430px, 52vh, 610px); object-fit: cover; object-position: center 46%; margin-left: auto; box-shadow: 0 28px 56px rgba(52,49,50,0.07); filter: saturate(0.84) contrast(0.95); }
.hero-mark { position: absolute; left: -6%; top: 10%; width: min(58%, 340px); opacity: 0.055; transform: rotate(-6deg); pointer-events: none; }
.hero-caption { position: relative; left: auto; bottom: auto; max-width: 340px; margin: 18px 0 0 auto; background: transparent; padding: 16px 0 0 18px; border-left: 1px solid rgba(155,114,69,0.36); font-size: 0.9rem; color: rgba(52,49,50,0.68); }
.page-hero { padding: clamp(62px, 7.5vw, 116px) 0 clamp(48px, 5.6vw, 82px); }
.page-hero-grid { display: grid; grid-template-columns: minmax(0, 0.94fr) minmax(320px, 0.66fr); gap: clamp(38px, 5.8vw, 86px); align-items: end; }
.page-hero h1 { font-size: clamp(3.6rem, 6.4vw, 7.2rem); max-width: 820px; }
.page-hero-img { height: clamp(320px, 42vw, 560px); object-fit: cover; filter: saturate(0.86) contrast(0.95); }
.statement { position: relative; }
.statement .symbol-watermark { position: absolute; right: 4vw; top: -12%; width: min(38vw, 420px); opacity: 0.045; pointer-events: none; }
.statement-grid { display: grid; grid-template-columns: minmax(180px, 0.45fr) minmax(0, 1fr); gap: clamp(32px, 8vw, 120px); align-items: start; }
.split-heading { display: grid; grid-template-columns: minmax(0, 0.92fr) minmax(320px, 0.62fr); gap: clamp(34px, 5.8vw, 86px); align-items: end; margin-bottom: clamp(34px, 5vw, 66px); }
.editorial-pair { display: grid; grid-template-columns: minmax(320px, 0.76fr) minmax(0, 0.96fr); gap: clamp(38px, 6vw, 86px); align-items: center; }
.editorial-pair.reverse { grid-template-columns: minmax(0, 0.96fr) minmax(320px, 0.76fr); }
.editorial-image { margin: 0; position: relative; }
.editorial-image img { width: 100%; height: clamp(360px, 42vw, 610px); object-fit: cover; filter: saturate(0.82) contrast(0.96); }
.editorial-image.tall img { height: clamp(460px, 52vw, 680px); }
.editorial-image.offset { transform: translateY(22px); }
.material-strip { display: grid; grid-template-columns: repeat(4, 1fr); min-height: 116px; border: 1px solid var(--ay-line); margin-top: 34px; }
.material-strip img { width: 100%; height: 100%; object-fit: cover; }

.home-visual-section { background: linear-gradient(180deg, var(--ay-ivory) 0%, var(--ay-soft-stone) 100%); }
.home-image-grid { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.52fr); gap: clamp(18px, 2vw, 28px); align-items: stretch; }
.home-image-grid figure { margin: 0; position: relative; overflow: hidden; background: var(--ay-soft-stone); border: 1px solid var(--ay-line); }
.home-image-grid img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.84) contrast(0.96); transition: transform 900ms ease; }
.home-image-grid figure:hover img { transform: scale(1.015); }
.home-image-large { min-height: clamp(380px, 45vw, 640px); }
.home-image-stack { display: grid; gap: clamp(18px, 2vw, 28px); }
.home-image-stack figure { min-height: clamp(180px, 21vw, 306px); }
.home-image-grid figcaption { position: absolute; left: 0; right: 0; bottom: 0; padding: 18px 20px; background: linear-gradient(180deg, transparent, rgba(5,5,5,0.54)); color: rgba(247,246,243,0.86); font-size: 0.72rem; letter-spacing: 0.16em; line-height: 1.45; text-transform: uppercase; }
.context-list { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); border-top: 1px solid var(--ay-line); border-left: 1px solid var(--ay-line); }
.context-item { min-height: 250px; padding: clamp(22px, 2.6vw, 36px); border-right: 1px solid var(--ay-line); border-bottom: 1px solid var(--ay-line); display: flex; flex-direction: column; justify-content: space-between; gap: 24px; }
.context-number { font-size: 0.72rem; letter-spacing: 0.24em; color: rgba(52,49,50,0.48); }
.context-item:hover h3, .project-card:hover h3, .project-index a:hover h3 { color: var(--ay-deep-brown); }
.section-action { margin-top: clamp(28px, 4vw, 54px); }
.about-copy p { font-size: clamp(1rem, 1.12vw, 1.15rem); }
.offer-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); border-top: 1px solid var(--ay-line); border-left: 1px solid var(--ay-line); }
.offer-grid article { min-height: 180px; padding: clamp(22px, 2.5vw, 34px); border-right: 1px solid var(--ay-line); border-bottom: 1px solid var(--ay-line); display: grid; align-content: space-between; gap: 28px; }
.offer-grid span, .offer-list span, .project-index span { font-size: 0.72rem; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(52,49,50,0.48); }
.featured-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 16px; font-size: clamp(1.35rem, 2.2vw, 2.2rem); line-height: 1.2; color: var(--ay-charcoal); }
.testimonial { margin: 0; max-width: 940px; }
.testimonial blockquote { margin: 0; font-size: clamp(1.55rem, 2.7vw, 3.2rem); line-height: 1.2; letter-spacing: -0.035em; color: inherit; }
.testimonial figcaption { margin-top: 28px; font-size: 0.78rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(239,235,229,0.72); }
.testimonial figcaption span { color: rgba(239,235,229,0.5); }
.testimonial.compact { padding-top: 12px; border-top: 1px solid var(--ay-line); }
.section-dark .testimonial.compact { border-color: rgba(239,235,229,0.18); }
.testimonial.compact blockquote { font-size: clamp(1.05rem, 1.35vw, 1.32rem); line-height: 1.62; letter-spacing: 0; color: rgba(52,49,50,0.78); }
.testimonial.compact figcaption { color: rgba(52,49,50,0.7); }
.testimonial.compact figcaption span { color: rgba(52,49,50,0.52); }
.section-dark .testimonial.compact blockquote { color: rgba(239,235,229,0.78); }
.section-dark .testimonial.compact figcaption { color: rgba(239,235,229,0.72); }
.section-dark .testimonial.compact figcaption span { color: rgba(239,235,229,0.52); }
.service-grid { display: grid; grid-template-columns: minmax(280px, 0.62fr) minmax(0, 1fr); gap: clamp(38px, 6vw, 86px); align-items: start; }
.service-section { scroll-margin-top: 112px; }
.offer-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1px; background: var(--ay-line); border: 1px solid var(--ay-line); }
.offer-list article { background: var(--ay-ivory); min-height: 220px; padding: clamp(22px, 2.6vw, 36px); display: grid; align-content: start; gap: 18px; }
.section-warm .offer-list article { background: var(--ay-soft-stone); }
.section-dark .offer-list { background: rgba(239,235,229,0.18); border-color: rgba(239,235,229,0.18); }
.section-dark .offer-list article { background: rgba(5,5,5,0.14); }
.section-dark .offer-list span { color: rgba(239,235,229,0.46); }
.project-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: clamp(18px, 2.2vw, 30px); }
.project-card { display: grid; gap: 16px; align-content: start; }
.project-card img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; filter: saturate(0.82) contrast(0.96); border: 1px solid var(--ay-line); }
.project-card h3 { letter-spacing: 0.16em; }
.project-index { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); border-top: 1px solid var(--ay-line); border-left: 1px solid var(--ay-line); }
.project-index a, .project-index article { min-height: 150px; padding: clamp(22px, 2.4vw, 34px); border-right: 1px solid var(--ay-line); border-bottom: 1px solid var(--ay-line); display: grid; gap: 28px; align-content: space-between; }
.meta-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; color: rgba(52,49,50,0.62); }
.meta-list li { padding-left: 18px; position: relative; }
.meta-list li::before { content: ""; position: absolute; left: 0; top: 0.82em; width: 6px; height: 1px; background: currentColor; }
.section-dark .meta-list { color: rgba(239,235,229,0.64); }
.process { counter-reset: step; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(239,235,229,0.16); border: 1px solid rgba(239,235,229,0.16); }
.process article { counter-increment: step; padding: clamp(24px, 3vw, 40px); background: rgba(5,5,5,0.14); min-height: 235px; }
.process article::before { content: "0" counter(step); display: block; color: rgba(239,235,229,0.44); font-size: 0.76rem; letter-spacing: 0.24em; margin-bottom: 28px; }
.article-list { display: grid; gap: 1px; background: var(--ay-line); border: 1px solid var(--ay-line); }
.article-row { display: grid; grid-template-columns: minmax(220px, 0.34fr) minmax(0, 0.98fr) minmax(200px, 0.34fr); gap: clamp(24px, 4vw, 58px); align-items: center; background: var(--ay-ivory); padding: clamp(24px, 3.4vw, 46px); }
.article-row img { height: clamp(220px, 28vw, 360px); width: 100%; object-fit: cover; filter: saturate(0.78) contrast(0.98); }
.article-meta { font-size: 0.72rem; letter-spacing: 0.23em; text-transform: uppercase; color: rgba(52,49,50,0.56); }
.article-title { font-size: clamp(2.2rem, 3.9vw, 4.4rem); line-height: 1.02; letter-spacing: -0.055em; }
.contact-panel { display: grid; grid-template-columns: minmax(280px, 0.62fr) minmax(0, 0.98fr); gap: clamp(38px, 6vw, 84px); align-items: start; }
.contact-card { position: relative; padding: clamp(28px, 4vw, 54px); background: rgba(247,246,243,0.54); border: 1px solid var(--ay-line); overflow: hidden; }
.contact-card .contact-mark { position: absolute; right: -32px; bottom: -160px; width: 280px; opacity: 0.055; }
.contact-detail { border-top: 1px solid var(--ay-line); padding-top: 20px; }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.form-field { display: grid; gap: 8px; }
.form-field.full { grid-column: 1 / -1; }
label { font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(52,49,50,0.7); }
input, select, textarea { width: 100%; border: 1px solid var(--ay-line); background: rgba(247,246,243,0.72); color: var(--ay-charcoal); padding: 15px 14px; border-radius: 0; outline: none; }
textarea { min-height: 170px; resize: vertical; }
input:focus, select:focus, textarea:focus { border-color: rgba(67,42,31,0.72); box-shadow: 0 0 0 3px rgba(157,181,193,0.16); }
.honeypot { position: absolute; left: -9999px; }
.form-status { min-height: 24px; font-size: 0.92rem; color: rgba(52,49,50,0.72); }
.form-status[data-state="success"] { color: #33513f; }
.form-status[data-state="error"] { color: #7a2c1b; }
.site-footer { background: var(--ay-charcoal); color: var(--ay-ivory); padding: 66px 0 28px; overflow: hidden; }
.footer-grid { display: grid; grid-template-columns: minmax(260px, 1.15fr) repeat(3, minmax(150px, 0.72fr)); gap: clamp(28px, 4vw, 62px); align-items: start; }
.footer-mark { width: clamp(54px, 4.8vw, 72px); max-height: 92px; object-fit: contain; margin-bottom: 18px; }
.footer-logo { width: min(310px, 100%); height: auto; margin-bottom: 18px; }
.footer-title { font-size: 0.72rem; letter-spacing: 0.27em; text-transform: uppercase; color: rgba(239,235,229,0.52); margin-bottom: 18px; }
.footer-links { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; color: rgba(239,235,229,0.76); }
.footer-links a:hover { color: var(--ay-white); }
.footer-bottom { display: flex; justify-content: space-between; gap: 18px; margin-top: 50px; padding-top: 22px; border-top: 1px solid rgba(239,235,229,0.16); font-size: 0.78rem; color: rgba(239,235,229,0.52); }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity 900ms ease, transform 900ms ease; }
.reveal.is-visible { opacity: 1; transform: none; }
.site-footer img, .site-header img { max-width: 100%; height: auto; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
@media (max-width: 1040px) {
  .nav-toggle { display: inline-flex; }
  .nav-links { position: absolute; inset: 82px 0 auto 0; padding: 30px 28px 36px; background: rgba(239,235,229,0.98); border-bottom: 1px solid var(--ay-line); display: none; flex-direction: column; align-items: flex-start; gap: 22px; }
  .nav-links.is-open { display: flex; }
  .hero-grid, .page-hero-grid, .statement-grid, .split-heading, .editorial-pair, .editorial-pair.reverse, .contact-panel, .home-image-grid, .service-grid { grid-template-columns: 1fr; }
  .hero { min-height: auto; }
  .hero-media { min-height: auto; }
  .hero-photo { height: auto; aspect-ratio: 4 / 5; margin-left: 0; width: min(100%, 560px); }
  .hero-caption { margin-left: 0; }
  .home-image-stack { grid-template-columns: repeat(2, 1fr); }
  .context-list, .process, .offer-grid, .project-grid, .project-index { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 820px) {
  .footer-grid { grid-template-columns: 1fr; }
  .footer-logo { width: min(280px, 100%); }
}
@media (max-width: 680px) {
  :root { --container: min(100vw - 28px, 1360px); }
  .navbar { min-height: 74px; }
  .brand { width: min(270px, 72vw); }
  .nav-links { inset: 76px 0 auto 0; }
  h1 { font-size: clamp(3.25rem, 15.5vw, 5rem); }
  h2 { font-size: clamp(2.35rem, 11.5vw, 3.8rem); }
  .text-large { font-size: clamp(1.75rem, 8.5vw, 2.9rem); }
  .context-list, .process, .article-row, .form-grid, .footer-grid, .home-image-stack, .offer-grid, .offer-list, .project-grid, .project-index { grid-template-columns: 1fr; }
  .article-row { gap: 24px; }
  .editorial-image img { height: auto; min-height: 0; aspect-ratio: 4 / 5; }
  .home-image-large, .home-image-stack figure { min-height: 0; aspect-ratio: 4 / 5; }
  .home-image-large { aspect-ratio: 16 / 10; }
  .page-hero-img { height: auto; aspect-ratio: 4 / 5; }
  .hero { padding-top: 38px; }
  .footer-bottom { flex-direction: column; }
}


/* V6.3 homepage scale and unique Services/Projects refinements */
.hero { min-height: min(700px, calc(100vh - 82px)); padding: clamp(38px, 4.8vw, 68px) 0 clamp(46px, 5.5vw, 78px); }
.hero-grid { grid-template-columns: minmax(0, 0.9fr) minmax(330px, 0.68fr); gap: clamp(34px, 5vw, 76px); }
.hero-copy.stack-xl > * + * { margin-top: 26px; }
.hero h1 { font-size: clamp(3.5rem, 6.3vw, 6.9rem); max-width: 660px; line-height: 0.98; letter-spacing: -0.065em; }
.hero .lede { font-size: clamp(0.98rem, 1.08vw, 1.12rem); max-width: 600px; }
.hero-copy p:not(.lede) { max-width: 650px; }
.hero-media { min-height: 430px; }
.hero-photo { width: min(100%, 460px); height: clamp(350px, 44vh, 505px); }
.hero-caption { max-width: 310px; font-size: 0.84rem; margin-top: 14px; }

.page-hero-visual { padding-top: clamp(54px, 6.4vw, 96px); }
.service-visual-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: clamp(14px, 1.8vw, 24px); }
.service-visual-card { position: relative; min-height: 460px; overflow: hidden; border: 1px solid var(--ay-line); background: var(--ay-soft-stone); display: grid; align-content: end; padding: 26px; isolation: isolate; }
.service-visual-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,5,5,0.04) 0%, rgba(5,5,5,0.16) 48%, rgba(5,5,5,0.64) 100%); z-index: -1; }
.service-visual-card img { position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%; object-fit: cover; filter: saturate(0.82) contrast(0.96); transition: transform 600ms ease, filter 600ms ease; }
.service-visual-card:hover img { transform: scale(1.035); filter: saturate(0.9) contrast(1); }
.service-visual-card span { font-size: 0.72rem; letter-spacing: 0.24em; color: rgba(239,235,229,0.64); text-transform: uppercase; }
.service-visual-card h2 { font-size: clamp(1.55rem, 2.4vw, 2.65rem); letter-spacing: -0.045em; color: var(--ay-ivory); max-width: 290px; margin-top: 12px; }
.service-visual-card p { color: rgba(239,235,229,0.74); max-width: 315px; margin-top: 14px; font-size: 0.95rem; line-height: 1.55; }
.service-inline-image { margin: 0; overflow: hidden; border: 1px solid var(--ay-line); background: var(--ay-soft-stone); }
.service-inline-image img { width: 100%; height: clamp(280px, 32vw, 440px); object-fit: cover; filter: saturate(0.82) contrast(0.96); }
.section-dark .service-inline-image { border-color: rgba(239,235,229,0.18); }

.project-archive-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: clamp(18px, 2vw, 28px); }
.project-card-rich { min-height: 100%; }
.project-card-rich img { aspect-ratio: 5 / 4; }
.project-card-rich .article-meta { margin-top: 2px; }
.project-mini-details .project-index article { align-content: start; gap: 18px; }
.project-mini-details .project-index p { max-width: 520px; }
.project-detail-feature { scroll-margin-top: 112px; }

@media (max-width: 1180px) {
  .service-visual-grid, .project-archive-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .service-visual-card { min-height: 420px; }
}
@media (max-width: 1040px) {
  .hero h1 { max-width: 760px; }
  .hero-photo { height: auto; aspect-ratio: 4 / 5; }
}
@media (max-width: 680px) {
  .hero { padding-top: 34px; }
  .hero-copy.stack-xl > * + * { margin-top: 20px; }
  .hero h1 { font-size: clamp(2.75rem, 12.2vw, 4.35rem); line-height: 1; letter-spacing: -0.058em; max-width: 100%; }
  .hero .lede { font-size: 1rem; }
  .btn-row { gap: 10px; }
  .btn { width: 100%; padding-left: 16px; padding-right: 16px; }
  .service-visual-grid, .project-archive-grid { grid-template-columns: 1fr; }
  .service-visual-card { min-height: 360px; padding: 22px; }
  .service-inline-image img { height: auto; aspect-ratio: 4 / 5; }
  .project-card-rich img { aspect-ratio: 4 / 5; }
}


/* V6.6 Wix-inspired project-detail pages */
.breadcrumb-link { display: inline-flex; width: fit-content; border-bottom: 1px solid rgba(52,49,50,0.32); padding-bottom: 3px; font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(52,49,50,0.68); }
.breadcrumb-link:hover { color: var(--ay-black); border-color: currentColor; }
.project-wix-hero { padding: clamp(52px, 7vw, 112px) 0 clamp(30px, 4.4vw, 68px); }
.project-wix-intro { display: grid; grid-template-columns: minmax(0, 0.82fr) minmax(340px, 0.64fr); gap: clamp(34px, 7vw, 112px); align-items: start; margin-top: clamp(28px, 4vw, 58px); }
.project-wix-intro h1 { max-width: 760px; font-size: clamp(3.8rem, 8vw, 8.6rem); line-height: 0.93; letter-spacing: -0.064em; }
.project-wix-copy { max-width: 620px; padding-top: clamp(4px, 1vw, 16px); }
.project-wix-copy .lede { font-size: clamp(1.02rem, 1.28vw, 1.24rem); color: rgba(52,49,50,0.78); }
.project-wix-copy p + p { margin-top: 18px; }
.project-wix-facts { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1px; margin-top: clamp(34px, 5vw, 72px); border-top: 1px solid var(--ay-line); border-bottom: 1px solid var(--ay-line); background: var(--ay-line); }
.project-wix-facts div { background: var(--ay-paper); padding: clamp(18px, 2.4vw, 30px); min-height: 112px; }
.project-wix-facts dt { margin-bottom: 12px; font-size: 0.66rem; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(52,49,50,0.48); }
.project-wix-facts dd { margin: 0; color: rgba(52,49,50,0.82); line-height: 1.55; }
.project-wix-gallery-section { padding: clamp(38px, 5vw, 84px) 0 clamp(64px, 8vw, 120px); }
.project-wix-gallery { display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); gap: clamp(18px, 2.8vw, 42px); align-items: start; }
.project-wix-image { margin: 0; background: var(--ay-soft-stone); overflow: hidden; border: 1px solid rgba(52,49,50,0.08); }
.project-wix-image img { display: block; width: 100%; height: 100%; object-fit: cover; filter: saturate(0.86) contrast(0.96); }
.project-wix-image--wide { grid-column: 1 / -1; }
.project-wix-image--wide img { aspect-ratio: 16 / 10; max-height: 760px; }
.project-wix-image--full { grid-column: 2 / 12; }
.project-wix-image--full img { aspect-ratio: 4 / 3; max-height: 820px; }
.project-wix-image--portrait { grid-column: span 6; }
.project-wix-image--portrait img { aspect-ratio: 4 / 5; min-height: 420px; }
.project-wix-image:nth-child(2n + 4).project-wix-image--portrait { margin-top: clamp(22px, 4vw, 72px); }
.project-nav-panel { display: flex; align-items: center; justify-content: space-between; gap: 18px; border-top: 1px solid var(--ay-line); border-bottom: 1px solid var(--ay-line); padding-top: 24px; padding-bottom: 24px; }
.project-archive-grid .project-card { transition: transform 240ms ease; }
.project-archive-grid .project-card:hover { transform: translateY(-4px); }

@media (max-width: 1040px) {
  .project-wix-intro { grid-template-columns: 1fr; gap: 26px; }
  .project-wix-intro h1 { font-size: clamp(3.4rem, 12vw, 7rem); }
  .project-wix-copy { max-width: 760px; }
  .project-wix-facts { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .project-wix-image--full { grid-column: 1 / -1; }
}
@media (max-width: 680px) {
  .project-wix-hero { padding-top: 40px; }
  .project-wix-intro { margin-top: 24px; }
  .project-wix-intro h1 { font-size: clamp(3rem, 15.5vw, 4.6rem); line-height: 0.96; letter-spacing: -0.058em; }
  .project-wix-facts { grid-template-columns: 1fr; }
  .project-wix-facts div { min-height: 0; }
  .project-wix-gallery { display: block; }
  .project-wix-image + .project-wix-image { margin-top: 22px; }
  .project-wix-image--wide img, .project-wix-image--full img, .project-wix-image--portrait img { aspect-ratio: auto; min-height: 0; max-height: none; height: auto; }
  .project-wix-image:nth-child(2n + 4).project-wix-image--portrait { margin-top: 22px; }
  .project-nav-panel { flex-direction: column; align-items: stretch; text-align: center; }
  .project-nav-panel .inline-link, .project-nav-panel .btn { width: 100%; justify-content: center; }
}


/* V6.7 project copy removal and client-reference project detail typography */
.project-only-archive { padding-top: clamp(38px, 5.5vw, 82px); }
.project-only-archive .project-archive-grid { margin-top: 0; }
.project-only-archive .project-card-rich { gap: 10px; }
.project-only-archive .project-card-rich h3 { font-size: 0.68rem; letter-spacing: 0.18em; line-height: 1.35; color: rgba(52,49,50,0.78); }

.project-detail-container { width: min(980px, calc(100vw - 72px)); margin: 0 auto; }
.project-wix-hero { padding: clamp(68px, 8vw, 118px) 0 clamp(28px, 3.8vw, 52px); }
.project-wix-intro { grid-template-columns: minmax(0, 0.58fr) minmax(250px, 0.34fr); gap: clamp(46px, 8vw, 112px); align-items: start; margin-top: 0; }
.project-wix-intro h1 { max-width: 100%; font-size: clamp(1.02rem, 1.08vw, 1.2rem); line-height: 1.25; letter-spacing: -0.03em; text-transform: uppercase; margin-bottom: clamp(28px, 3vw, 46px); }
.project-wix-copy { max-width: 520px; padding-top: 0; }
.project-wix-copy .lede { font-size: clamp(0.82rem, 0.92vw, 0.98rem); line-height: 1.85; color: rgba(52,49,50,0.86); }
.project-wix-copy .lede em { font-style: italic; }
.project-wix-copy p { font-size: clamp(0.82rem, 0.9vw, 0.95rem); line-height: 1.9; color: rgba(52,49,50,0.84); }
.project-wix-copy p + p { margin-top: 18px; }
.project-wix-facts { margin: clamp(48px, 5.4vw, 72px) 0 0; border: 0; background: transparent; display: grid; grid-template-columns: 1fr; gap: 6px; }
.project-wix-facts div { background: transparent; padding: 0; min-height: 0; }
.project-wix-facts dt { display: none; }
.project-wix-facts dd { margin: 0; font-size: clamp(0.82rem, 0.9vw, 0.95rem); line-height: 1.7; color: rgba(52,49,50,0.86); }
.project-wix-gallery-section { padding: clamp(28px, 4.5vw, 68px) 0 clamp(64px, 8vw, 118px); }
.project-wix-gallery { width: min(900px, calc(100vw - 72px)); margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: clamp(36px, 5vw, 72px); }
.project-wix-image, .project-wix-image--wide, .project-wix-image--full, .project-wix-image--portrait { grid-column: 1 / -1; margin: 0; border: 0; background: transparent; }
.project-wix-image img, .project-wix-image--wide img, .project-wix-image--full img, .project-wix-image--portrait img { width: 100%; height: auto; max-height: none; min-height: 0; aspect-ratio: auto; object-fit: contain; }
.project-wix-image:nth-child(2n + 4).project-wix-image--portrait { margin-top: 0; }

@media (max-width: 980px) {
  .project-wix-intro { grid-template-columns: 1fr; gap: 26px; }
  .project-wix-facts { margin-top: 4px; }
  .project-wix-intro h1 { font-size: clamp(1rem, 4.2vw, 1.24rem); margin-bottom: 22px; }
}
@media (max-width: 680px) {
  .project-detail-container, .project-wix-gallery { width: min(100% - 34px, 900px); }
  .project-wix-hero { padding-top: 44px; }
  .project-wix-copy .lede, .project-wix-copy p, .project-wix-facts dd { font-size: 0.88rem; line-height: 1.78; }
  .project-only-archive { padding-top: 30px; }
}


/* V6.8 client-layout feedback patch */
.service-feature-light { background: var(--ay-ivory); color: var(--ay-charcoal); }
.service-feature-light h2,
.service-feature-light h3 { color: var(--ay-charcoal); }
.service-feature-light p,
.service-feature-light .lede { color: rgba(52,49,50,0.74); }
.service-feature-light .eyebrow { color: rgba(52,49,50,0.55); }
.service-feature-light .offer-list article { background: var(--ay-ivory); }
.service-feature-light .testimonial blockquote { color: var(--ay-charcoal); }
.service-feature-light .testimonial figcaption { color: rgba(52,49,50,0.62); }

.editorial-wix { background: var(--ay-white); padding-top: clamp(48px, 5vw, 82px); }
.editorial-wix-title { font-size: clamp(1.35rem, 2.1vw, 2rem); letter-spacing: -0.03em; line-height: 1.15; max-width: none; margin-bottom: clamp(36px, 5vw, 66px); }
.editorial-card-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: clamp(32px, 5vw, 72px); max-width: 1140px; }
.editorial-card { display: block; position: relative; color: var(--ay-charcoal); }
.editorial-card img { width: 100%; aspect-ratio: 1 / 1.4; object-fit: cover; background: var(--ay-soft-stone); filter: saturate(0.9) contrast(0.96); margin-bottom: clamp(20px, 2.6vw, 34px); }
.editorial-card:nth-child(2) img { aspect-ratio: 1.55 / 1; }
.editorial-card h2 { font-family: var(--font-script); font-size: clamp(1.5rem, 2.1vw, 2.1rem); line-height: 1.02; letter-spacing: -0.018em; max-width: 470px; color: var(--ay-deep-brown); margin-bottom: 14px; }
.editorial-card p { max-width: 480px; font-size: clamp(1rem, 1.05vw, 1.18rem); line-height: 1.55; color: rgba(52,49,50,0.86); }
.editorial-dots { float: right; margin-top: -8px; font-size: 1.4rem; letter-spacing: 0.12em; color: var(--ay-deep-brown); }
.newsletter-section { background: var(--ay-white); padding-top: clamp(24px, 4vw, 56px); }
.newsletter-panel { display: grid; grid-template-columns: 220px minmax(0, 1fr); gap: clamp(28px, 5vw, 80px); align-items: center; background: #e2d9d1; padding: clamp(28px, 3.6vw, 46px) clamp(28px, 5vw, 72px); max-width: 1180px; }
.newsletter-title { font-size: clamp(1.15rem, 1.4vw, 1.45rem); line-height: 1.35; color: var(--ay-black); }
.newsletter-form { display: grid; grid-template-columns: minmax(0, 1fr) 220px; gap: 16px 34px; align-items: end; }
.newsletter-form label:first-child { grid-column: 1 / -1; font-size: 0.9rem; color: var(--ay-black); }
.newsletter-form input[type="email"] { grid-column: 1 / -1; border: 0; border-bottom: 1px solid rgba(52,49,50,0.34); background: transparent; min-height: 36px; outline: none; }
.newsletter-check { grid-column: 1; display: flex; gap: 12px; align-items: center; font-size: 0.82rem; color: var(--ay-black); }
.newsletter-check input { width: 16px; height: 16px; margin: 0; accent-color: var(--ay-muted-gold); }
.newsletter-form button { grid-column: 2; justify-self: stretch; border: 0; border-radius: 999px; background: #ad8d75; color: white; min-height: 48px; padding: 0 34px; font-size: 1.1rem; cursor: pointer; }
.editorial-post { background: var(--ay-white); }
.editorial-post-wrap { max-width: 860px; }
.editorial-post h1 { margin-top: 34px; font-family: var(--font-script); font-size: clamp(1.7rem, 2.3vw, 2.45rem); line-height: 1.05; letter-spacing: -0.018em; max-width: none; color: var(--ay-deep-brown); }
.post-meta { margin-top: 22px; font-size: 0.9rem; color: rgba(5,5,5,0.78); }
.post-hero-image { margin: 28px 0 24px; }
.post-hero-image img { width: 100%; height: auto; object-fit: cover; }
.post-body { margin-top: 28px; font-size: clamp(1rem, 1.06vw, 1.17rem); line-height: 1.55; color: var(--ay-black); }
.post-body p { color: var(--ay-black); }
.post-body p + p { margin-top: 14px; }

@media (max-width: 820px) {
  .editorial-card-grid { grid-template-columns: 1fr; }
  .editorial-card:nth-child(2) img { aspect-ratio: 1.35 / 1; }
  .newsletter-panel { grid-template-columns: 1fr; }
  .newsletter-form { grid-template-columns: 1fr; }
  .newsletter-form button, .newsletter-check { grid-column: 1; }
  .newsletter-form button { justify-self: start; min-width: 180px; }
}


/* V6.9 supplied copy + fullscreen project imagery */
.project-copy-heading { margin-bottom: clamp(24px, 4vw, 54px); }
.project-copy-heading h1 { font-size: clamp(1.45rem, 2.6vw, 2.55rem); line-height: 1.1; font-weight: 300; letter-spacing: -0.035em; }
.project-card-fullscreen { display: grid; gap: 10px; align-content: start; }
.project-card-fullscreen .project-title-link { display: inline-block; }
.project-image-button { appearance: none; -webkit-appearance: none; border: 0; padding: 0; margin: 0; background: transparent; color: inherit; font: inherit; text-align: inherit; cursor: zoom-in; width: 100%; display: block; }
.project-image-button img { display: block; width: 100%; }
.project-image-button:focus-visible { outline: 1px solid currentColor; outline-offset: 5px; }
.project-detail-image-button { cursor: zoom-in; }
.project-fullscreen-modal { position: fixed; inset: 0; z-index: 9999; background: rgba(13, 12, 12, 0.94); display: grid; place-items: center; padding: clamp(16px, 3vw, 42px); opacity: 0; pointer-events: none; transition: opacity 180ms ease; }
.project-fullscreen-modal.is-open { opacity: 1; pointer-events: auto; }
.project-fullscreen-modal img { max-width: min(96vw, 1500px); max-height: 92vh; width: auto; height: auto; object-fit: contain; box-shadow: 0 20px 80px rgba(0,0,0,0.42); }
.project-fullscreen-close { position: fixed; top: 18px; right: 20px; appearance: none; border: 1px solid rgba(239,235,229,0.45); background: rgba(239,235,229,0.08); color: #efebe5; width: 42px; height: 42px; border-radius: 999px; font-size: 26px; line-height: 1; cursor: pointer; }
.project-fullscreen-close:focus-visible { outline: 1px solid #efebe5; outline-offset: 4px; }
.service-request { width: fit-content; margin-top: 4px; }
@media (max-width: 720px) {
  .project-fullscreen-modal { padding: 12px; }
  .project-fullscreen-close { top: 12px; right: 12px; width: 38px; height: 38px; }
}


/* V6.10 correction pass: project archive links, homepage about/offer/press/testimonials, editorial script headings */
.project-archive-grid .project-image-link {
  display: block;
  cursor: pointer;
}
.project-archive-grid .project-image-link img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 360ms ease, opacity 260ms ease;
}
.project-archive-grid .project-image-link:hover img {
  transform: scale(1.018);
  opacity: 0.92;
}
.project-archive-grid .project-image-button:not(.project-detail-image-button) {
  cursor: pointer;
}

.home-about-deep {
  background: var(--ay-ivory);
}
.home-about-deep-inner {
  display: grid;
  grid-template-columns: minmax(280px, 0.92fr) minmax(0, 1.08fr);
  gap: clamp(34px, 6vw, 86px);
  align-items: start;
}
.home-about-portrait {
  margin: 0;
}
.home-about-portrait img {
  width: 100%;
  max-height: 760px;
  object-fit: cover;
  object-position: center;
}
.home-about-body h2 {
  font-size: clamp(2.4rem, 5vw, 5.7rem);
  max-width: 820px;
}
.home-about-body p {
  max-width: 820px;
  font-size: clamp(0.98rem, 1.05vw, 1.15rem);
  line-height: 1.76;
}
.home-offer-section {
  background: #f3f1ee;
}
.home-offer-grid {
  display: grid;
  grid-template-columns: minmax(180px, 0.36fr) minmax(0, 1fr);
  gap: clamp(28px, 7vw, 112px);
  align-items: start;
}
.home-offer-heading h2,
.featured-in-inner h2,
.client-say-heading {
  font-size: clamp(1.35rem, 1.8vw, 2.05rem);
  letter-spacing: 0.01em;
  line-height: 1.1;
  font-weight: 500;
  color: var(--ay-charcoal);
}
.home-offer-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.home-offer-list li {
  font-size: clamp(1.55rem, 2.75vw, 3.05rem);
  line-height: 1.38;
  letter-spacing: 0.12em;
  color: var(--ay-deep-brown);
}
.featured-in-section {
  background: var(--ay-white);
}
.featured-in-inner {
  display: grid;
  gap: clamp(28px, 5vw, 70px);
}
.press-logo-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(130px, 1fr));
  gap: clamp(20px, 4vw, 60px);
  align-items: center;
}
.press-logo-item {
  min-height: 86px;
  display: flex;
  align-items: center;
  justify-content: center;
  filter: grayscale(1);
  opacity: 0.82;
}
.press-logo-item img {
  max-width: 230px;
  max-height: 74px;
  object-fit: contain;
}
.press-logo-text {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(2rem, 4vw, 4.7rem);
  font-weight: 700;
  letter-spacing: -0.08em;
  text-transform: lowercase;
  color: var(--ay-charcoal);
}
.home-testimonials-section {
  background: #c9c4c0;
  color: var(--ay-charcoal);
}
.home-testimonials-section .container {
  max-width: min(1280px, calc(100vw - 72px));
}
.client-say-heading {
  color: var(--ay-white);
  text-align: center;
  margin-bottom: clamp(42px, 6vw, 86px);
}
.testimonial-showcase {
  display: grid;
  gap: clamp(72px, 10vw, 136px);
}
.testimonial-card {
  display: grid;
  grid-template-columns: minmax(260px, 0.9fr) minmax(320px, 1.1fr);
  gap: 0;
  align-items: center;
  max-width: 1080px;
  margin: 0 auto;
}
.testimonial-card-reverse {
  grid-template-columns: minmax(320px, 1.1fr) minmax(260px, 0.9fr);
}
.testimonial-card-reverse .testimonial-image-wrap { order: 2; }
.testimonial-card-reverse .testimonial-quote-card { order: 1; margin-right: -70px; margin-left: 0; position: relative; z-index: 2; }
.testimonial-image-wrap {
  overflow: hidden;
  border-radius: 999px 999px 0 0;
  background: #e9e7e4;
}
.testimonial-card-left .testimonial-image-wrap {
  border-radius: 0;
}
.testimonial-image-wrap img {
  width: 100%;
  min-height: 430px;
  max-height: 610px;
  object-fit: cover;
  filter: grayscale(1);
}
.testimonial-quote-card {
  margin: 0 0 0 -70px;
  padding: clamp(30px, 4.5vw, 58px);
  background: var(--ay-white);
  position: relative;
  z-index: 2;
  box-shadow: 0 22px 70px rgba(52,49,50,0.08);
}
.testimonial-quote-card blockquote {
  margin: 0;
  color: var(--ay-deep-brown);
  font-size: clamp(0.98rem, 1.05vw, 1.16rem);
  line-height: 1.62;
}
.quote-rule {
  display: block;
  width: 44px;
  height: 1px;
  background: var(--ay-deep-brown);
  margin: 32px 0 24px;
}
.testimonial-quote-card figcaption {
  color: var(--ay-deep-brown);
  font-size: 0.93rem;
  line-height: 1.7;
}
.testimonial-quote-card figcaption span {
  color: rgba(67,42,31,0.75);
}

.editorial-card h2.editorial-script-title,
.editorial-post h1.editorial-script-title {
  font-family: var(--font-script);
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0.02em;
  color: var(--ay-deep-brown);
}
.editorial-card h2.editorial-script-title {
  font-size: clamp(2.35rem, 5vw, 5.4rem);
  line-height: 0.78;
  margin-top: 28px;
}
.editorial-post h1.editorial-script-title {
  font-size: clamp(3.2rem, 7.8vw, 8.8rem);
  line-height: 0.78;
  max-width: 1020px;
  letter-spacing: 0.01em;
}
.editorial-card p {
  margin-top: 20px;
}

@media (max-width: 980px) {
  .home-about-deep-inner,
  .home-offer-grid,
  .testimonial-card,
  .testimonial-card-reverse {
    grid-template-columns: 1fr;
  }
  .testimonial-card-reverse .testimonial-image-wrap,
  .testimonial-card-reverse .testimonial-quote-card { order: initial; }
  .testimonial-quote-card,
  .testimonial-card-reverse .testimonial-quote-card {
    margin: -32px 18px 0;
  }
  .press-logo-grid {
    grid-template-columns: repeat(2, minmax(120px, 1fr));
  }
  .home-offer-list li {
    letter-spacing: 0.07em;
  }
}
@media (max-width: 640px) {
  .press-logo-grid {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
  .press-logo-item {
    min-height: 64px;
  }
  .testimonial-image-wrap img {
    min-height: 340px;
  }
  .editorial-card h2.editorial-script-title {
    font-size: clamp(2.1rem, 14vw, 4.6rem);
  }
}


/* V6.11 layout correction pass: homepage preview squares, Wix-like project archive, service quote marks */
.home-latest-projects .project-grid {
  grid-template-columns: repeat(3, minmax(0, 270px));
  gap: clamp(18px, 2.2vw, 30px);
  justify-content: center;
  align-items: start;
  margin-top: clamp(26px, 3.4vw, 46px);
}
.home-latest-projects .project-card {
  gap: 10px;
}
.home-latest-projects .project-card img {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  object-position: center;
}
.home-latest-projects .project-card .article-meta {
  font-size: 0.66rem;
  letter-spacing: 0.18em;
}
.home-latest-projects .project-card h3 {
  font-size: clamp(1.05rem, 1.25vw, 1.28rem);
  line-height: 1.16;
}

.project-only-archive {
  padding-top: clamp(44px, 6vw, 86px);
}
.project-only-archive .container {
  width: min(1040px, calc(100vw - 72px));
}
.project-only-archive .project-copy-heading {
  margin-bottom: clamp(54px, 7vw, 90px);
}
.project-only-archive .project-copy-heading h1 {
  font-size: clamp(1.75rem, 2.25vw, 2.35rem);
  line-height: 1.1;
  letter-spacing: -0.035em;
}
.project-only-archive .project-archive-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(70px, 7vw, 112px) clamp(54px, 5.5vw, 78px);
  max-width: 960px;
  margin: 0 auto;
}
.project-only-archive .project-card-rich {
  display: grid;
  gap: 18px;
  align-content: start;
  transform: none;
}
.project-only-archive .project-card-rich:hover {
  transform: none;
}
.project-only-archive .project-card-rich img,
.project-only-archive .project-image-link img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  object-position: center;
  border: 0;
  filter: saturate(0.9) contrast(0.96);
}
.project-only-archive .project-image-link:hover img {
  transform: none;
  opacity: 0.94;
}
.project-only-archive .project-card-rich h3 {
  font-family: var(--font-script);
  font-size: clamp(1.2rem, 1.45vw, 1.55rem);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  color: var(--ay-deep-brown);
}

.services-page .testimonial.compact blockquote,
.service-feature .testimonial.compact blockquote,
.services-page blockquote,
.service-feature blockquote {
  quotes: "“" "”" "‘" "’";
}

@media (max-width: 920px) {
  .home-latest-projects .project-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .project-only-archive .container {
    width: min(100% - 44px, 1040px);
  }
  .project-only-archive .project-archive-grid {
    gap: 54px 28px;
  }
}
@media (max-width: 680px) {
  .home-latest-projects .project-grid,
  .project-only-archive .project-archive-grid {
    grid-template-columns: 1fr;
  }
  .home-latest-projects .project-grid {
    max-width: 360px;
    margin-left: auto;
    margin-right: auto;
  }
  .project-only-archive .project-archive-grid {
    max-width: 520px;
  }
}

/* V6.12 swipeable testimonials + editorial typography correction */
.home-testimonials-section {
  overflow: hidden;
}
.testimonial-carousel {
  position: relative;
  max-width: 1120px;
  margin: 0 auto;
}
.testimonial-track {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.testimonial-track::-webkit-scrollbar {
  display: none;
}
.testimonial-slide {
  flex: 0 0 100%;
  min-width: 100%;
  scroll-snap-align: center;
  padding: 0 clamp(24px, 5vw, 72px);
}
.testimonial-carousel .testimonial-card {
  max-width: 980px;
  margin: 0 auto;
}
.testimonial-carousel-button {
  position: absolute;
  top: 50%;
  z-index: 3;
  width: 42px;
  height: 42px;
  transform: translateY(-50%);
  border: 0;
  background: transparent;
  color: var(--ay-white);
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
  opacity: 0.86;
}
.testimonial-carousel-button:hover,
.testimonial-carousel-button:focus-visible {
  opacity: 1;
}
.testimonial-carousel-prev {
  left: -12px;
}
.testimonial-carousel-next {
  right: -12px;
}
.testimonial-carousel-dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: clamp(24px, 4vw, 42px);
}
.testimonial-carousel-dots button {
  width: 10px;
  height: 10px;
  padding: 0;
  border: 1px solid var(--ay-white);
  border-radius: 999px;
  background: transparent;
  color: transparent;
  cursor: pointer;
}
.testimonial-carousel-dots button.is-active {
  background: var(--ay-white);
}
.testimonial-carousel .testimonial-image-wrap img {
  min-height: 420px;
}
.testimonial-card-left .testimonial-image-wrap img {
  object-position: center;
}

.editorial-card h2.editorial-script-title,
.editorial-post h1.editorial-script-title {
  font-family: var(--font-body);
  font-weight: 300;
  text-transform: uppercase;
  letter-spacing: -0.018em;
  color: var(--ay-deep-brown);
}
.editorial-card h2.editorial-script-title {
  font-size: clamp(1.28rem, 1.65vw, 1.75rem);
  line-height: 1.08;
  max-width: 460px;
  margin-top: clamp(18px, 2.2vw, 28px);
  margin-bottom: 14px;
}
.editorial-post h1.editorial-script-title {
  font-size: clamp(2.1rem, 4vw, 4.25rem);
  line-height: 1.05;
  max-width: 900px;
  letter-spacing: -0.02em;
}
.editorial-card p {
  margin-top: 10px;
}

@media (max-width: 980px) {
  .testimonial-carousel-button {
    display: none;
  }
  .testimonial-slide {
    padding: 0 8px;
  }
}
@media (max-width: 640px) {
  .testimonial-carousel .testimonial-image-wrap img {
    min-height: 330px;
  }
  .editorial-card h2.editorial-script-title {
    font-size: clamp(1.35rem, 7vw, 2.35rem);
    line-height: 1.05;
  }
  .editorial-post h1.editorial-script-title {
    font-size: clamp(2rem, 10vw, 3.4rem);
  }
}



/* V6.13 final visual correction pass: linked Featured In, bigger home image, project label font */
.home-offer-section { display: none !important; }
.featured-in-section {
  background: #ffffff;
  padding: clamp(46px, 6vw, 82px) 0 clamp(50px, 6.5vw, 86px);
}
.featured-in-inner {
  display: grid;
  gap: clamp(34px, 5vw, 64px);
  text-align: center;
}
.featured-in-inner h2 {
  font-family: var(--font-body);
  font-size: clamp(1.08rem, 1.35vw, 1.45rem);
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--ay-charcoal);
  text-align: center;
}
.press-logo-grid.press-logo-grid-linked {
  width: min(1040px, calc(100vw - 72px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: clamp(34px, 6vw, 92px);
  align-items: center;
}
.press-logo-link {
  min-height: 78px;
  opacity: 0.9;
  filter: grayscale(1);
  transition: opacity 180ms ease, transform 180ms ease;
}
.press-logo-link:hover,
.press-logo-link:focus-visible {
  opacity: 1;
  transform: translateY(-2px);
}
.press-logo-link img {
  width: 100%;
  max-width: 220px;
  max-height: 82px;
  object-fit: contain;
  margin: 0 auto;
}

.hero-grid {
  grid-template-columns: minmax(0, 0.9fr) minmax(410px, 0.78fr);
}
.hero-media {
  min-height: clamp(500px, 62vh, 720px);
}
.hero-photo {
  width: min(100%, 560px);
  height: clamp(430px, 58vh, 660px);
}
.hero-caption {
  max-width: 360px;
}

.project-only-archive .project-card-rich h3,
.project-only-archive .project-title-link h3 {
  font-family: var(--font-script);
  font-size: clamp(1.03rem, 1.15vw, 1.22rem);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: rgba(67,42,31,0.88);
}

@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-media { min-height: auto; }
  .hero-photo { width: min(100%, 620px); height: auto; aspect-ratio: 4 / 5; margin-left: 0; }
  .press-logo-grid.press-logo-grid-linked { grid-template-columns: repeat(2, minmax(120px, 1fr)); width: min(100% - 44px, 760px); }
}
@media (max-width: 560px) {
  .press-logo-grid.press-logo-grid-linked { grid-template-columns: 1fr 1fr; gap: 24px 28px; }
  .press-logo-link img { max-width: 150px; max-height: 62px; }
}


/* V6.14 correction pass: centred/bigger Featured In, finished editorial post pages, enforced editorial title type */
.featured-in-section {
  text-align: center;
}
.featured-in-inner {
  width: min(1320px, calc(100vw - 64px));
  margin-left: auto;
  margin-right: auto;
  justify-items: center;
  text-align: center;
}
.featured-in-inner h2 {
  width: 100%;
  text-align: center !important;
  justify-self: center;
  margin-left: auto;
  margin-right: auto;
}
.press-logo-grid.press-logo-grid-linked {
  width: min(1220px, calc(100vw - 72px));
  justify-content: center;
  justify-items: center;
  gap: clamp(42px, 6.5vw, 104px);
}
.press-logo-link {
  width: 100%;
  min-height: 104px;
}
.press-logo-link img {
  max-width: 300px;
  max-height: 104px;
}
.press-logo-link:nth-child(3) img {
  max-width: 340px;
  max-height: 98px;
}
.press-logo-link:nth-child(4) img {
  max-width: 250px;
  max-height: 102px;
}
.editorial-card h2.editorial-script-title,
.editorial-post h1.editorial-script-title {
  font-family: var(--font-body) !important;
  font-weight: 300 !important;
  text-transform: uppercase !important;
  letter-spacing: -0.018em !important;
  color: var(--ay-deep-brown) !important;
}
.editorial-card h2.editorial-script-title {
  font-size: clamp(1.2rem, 1.5vw, 1.62rem) !important;
  line-height: 1.08 !important;
  margin-top: clamp(16px, 2vw, 26px) !important;
}
.editorial-post h1.editorial-script-title {
  font-size: clamp(1.34rem, 1.65vw, 1.95rem) !important;
  line-height: 1.16 !important;
  max-width: 760px !important;
  margin-top: 28px !important;
}
.editorial-post-wrap {
  max-width: 780px;
}
.editorial-post .post-meta {
  font-size: 0.78rem;
  margin-top: 16px;
}
.editorial-post .post-body {
  font-size: clamp(0.93rem, 0.98vw, 1.04rem);
  line-height: 1.62;
  max-width: 720px;
}
.editorial-post .post-body p + p {
  margin-top: 16px;
}
.post-social {
  display: flex;
  gap: 26px;
  align-items: center;
  margin-top: 28px;
  padding-top: 18px;
  border-top: 1px solid rgba(52,49,50,0.22);
}
.post-social a {
  font-size: 0.96rem;
  color: var(--ay-deep-brown);
}
.recent-posts-section {
  padding-top: clamp(52px, 7vw, 92px);
  padding-bottom: clamp(40px, 6vw, 76px);
  background: var(--ay-white);
}
.recent-posts-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  margin-bottom: 22px;
  color: var(--ay-deep-brown);
  font-size: 0.92rem;
}
.recent-post-card {
  display: inline-grid;
  width: min(260px, 72vw);
  color: var(--ay-deep-brown);
  gap: 12px;
}
.recent-post-card img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  filter: saturate(0.9) contrast(0.96);
}
.recent-post-card span {
  font-family: var(--font-script);
  font-size: clamp(1rem, 1.3vw, 1.24rem);
  line-height: 1.05;
  text-transform: uppercase;
}
.comments-section {
  padding-top: 0;
  padding-bottom: clamp(60px, 8vw, 120px);
  background: var(--ay-white);
}
.comments-box {
  max-width: 780px;
  border-top: 1px solid rgba(52,49,50,0.22);
  padding-top: 18px;
  color: rgba(52,49,50,0.66);
  font-size: 0.9rem;
}
.comments-title {
  color: var(--ay-deep-brown);
  text-transform: uppercase;
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  margin-bottom: 28px;
}
@media (max-width: 980px) {
  .press-logo-grid.press-logo-grid-linked { grid-template-columns: repeat(2, minmax(150px, 1fr)); }
  .press-logo-link img { max-width: 260px; }
}
@media (max-width: 560px) {
  .featured-in-inner { width: min(100% - 36px, 1320px); }
  .press-logo-grid.press-logo-grid-linked { width: 100%; grid-template-columns: 1fr 1fr; gap: 28px 24px; }
  .press-logo-link { min-height: 82px; }
  .press-logo-link img { max-width: 160px; max-height: 74px; }
  .press-logo-link:nth-child(3) img { max-width: 190px; }
  .press-logo-link:nth-child(4) img { max-width: 150px; }
  .editorial-post h1.editorial-script-title { font-size: clamp(1.32rem, 7vw, 2rem) !important; }
}


/* V6.15 correction: simpler Projects typography */
.project-copy-heading h1,
.project-only-archive .project-card-rich h3,
.project-only-archive .project-title-link h3,
.project-card h3,
.project-title-link h3 {
  font-family: var(--font-body) !important;
  font-weight: 300 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: rgba(52,49,50,0.86) !important;
}
.project-copy-heading h1 {
  font-size: clamp(1.5rem, 2.2vw, 2.35rem) !important;
  line-height: 1.12 !important;
  letter-spacing: -0.02em !important;
  text-transform: none !important;
}
.project-only-archive .project-card-rich h3,
.project-only-archive .project-title-link h3 {
  font-size: clamp(0.82rem, 0.9vw, 0.98rem) !important;
  line-height: 1.35 !important;
}
@media (max-width: 560px) {
  .project-copy-heading h1 { font-size: clamp(1.35rem, 7vw, 1.9rem) !important; }
  .project-only-archive .project-card-rich h3,
  .project-only-archive .project-title-link h3 { font-size: 0.82rem !important; }
}


/* V6.16 correction: larger homepage project boxes and Featured In logo widgets */
.home-latest-projects .project-grid {
  grid-template-columns: repeat(3, minmax(0, 330px)) !important;
  gap: clamp(22px, 2.8vw, 36px) !important;
  justify-content: center !important;
}
.home-latest-projects .project-card img {
  aspect-ratio: 1 / 1 !important;
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
  object-position: center !important;
}
.home-latest-projects .project-card h3 {
  font-size: clamp(1.05rem, 1.18vw, 1.26rem) !important;
  letter-spacing: 0.08em !important;
}
.featured-in-section {
  padding: clamp(58px, 7vw, 96px) 0 clamp(62px, 7.5vw, 104px) !important;
}
.featured-in-inner {
  width: min(1480px, calc(100vw - 64px)) !important;
  justify-items: center !important;
  text-align: center !important;
}
.featured-in-inner h2 {
  text-align: center !important;
  justify-self: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: clamp(18px, 2.6vw, 34px) !important;
}
.press-logo-grid.press-logo-grid-linked {
  width: min(1360px, calc(100vw - 72px)) !important;
  grid-template-columns: repeat(4, minmax(210px, 1fr)) !important;
  gap: clamp(56px, 7vw, 118px) !important;
  align-items: center !important;
  justify-content: center !important;
  justify-items: center !important;
}
.press-logo-link {
  min-height: 142px !important;
  display: grid !important;
  place-items: center !important;
}
.press-logo-link img {
  width: 100% !important;
  max-width: 360px !important;
  max-height: 126px !important;
  object-fit: contain !important;
}
.press-logo-link:nth-child(3) img {
  max-width: 430px !important;
  max-height: 122px !important;
}
.press-logo-link:nth-child(4) img {
  max-width: 330px !important;
  max-height: 124px !important;
}
@media (max-width: 980px) {
  .home-latest-projects .project-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 20px !important;
  }
  .press-logo-grid.press-logo-grid-linked {
    grid-template-columns: repeat(2, minmax(160px, 1fr)) !important;
    width: min(860px, calc(100vw - 44px)) !important;
    gap: 36px 50px !important;
  }
  .press-logo-link { min-height: 118px !important; }
  .press-logo-link img { max-width: 270px !important; max-height: 102px !important; }
  .press-logo-link:nth-child(3) img { max-width: 330px !important; }
  .press-logo-link:nth-child(4) img { max-width: 260px !important; }
}
@media (max-width: 700px) {
  .home-latest-projects .project-grid {
    grid-template-columns: 1fr !important;
    width: min(100%, 390px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
@media (max-width: 560px) {
  .featured-in-section { padding: 46px 0 54px !important; }
  .press-logo-grid.press-logo-grid-linked {
    grid-template-columns: 1fr 1fr !important;
    width: 100% !important;
    gap: 26px 22px !important;
  }
  .press-logo-link { min-height: 92px !important; }
  .press-logo-link img { max-width: 185px !important; max-height: 78px !important; }
  .press-logo-link:nth-child(3) img { max-width: 220px !important; }
  .press-logo-link:nth-child(4) img { max-width: 180px !important; }
}


/* V6.18 correction: Featured In logos scaled up again, links preserved, spacing balanced */
.featured-in-section {
  text-align: center !important;
  padding: clamp(64px, 7vw, 104px) 0 clamp(70px, 8vw, 116px) !important;
}
.featured-in-inner {
  width: min(1720px, calc(100vw - 36px)) !important;
  margin-inline: auto !important;
  display: grid !important;
  justify-items: center !important;
  text-align: center !important;
}
.featured-in-inner h2 {
  width: 100% !important;
  text-align: center !important;
  justify-self: center !important;
  margin-inline: auto !important;
  margin-bottom: clamp(26px, 3vw, 42px) !important;
}
.press-logo-grid.press-logo-grid-linked {
  width: min(1620px, calc(100vw - 44px)) !important;
  margin-inline: auto !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(260px, 1fr)) !important;
  gap: clamp(40px, 4.2vw, 82px) !important;
  align-items: center !important;
  justify-content: center !important;
  justify-items: center !important;
}
.press-logo-link {
  width: 100% !important;
  min-height: 212px !important;
  display: grid !important;
  place-items: center !important;
}
.press-logo-link img {
  width: 100% !important;
  max-width: 500px !important;
  max-height: 184px !important;
  object-fit: contain !important;
}
.press-logo-link:nth-child(1) img { max-width: 450px !important; max-height: 148px !important; }
.press-logo-link:nth-child(2) img { max-width: 390px !important; max-height: 188px !important; }
.press-logo-link:nth-child(3) img { max-width: 570px !important; max-height: 170px !important; }
.press-logo-link:nth-child(4) img { max-width: 440px !important; max-height: 180px !important; }
@media (max-width: 980px) {
  .press-logo-grid.press-logo-grid-linked {
    grid-template-columns: repeat(2, minmax(220px, 1fr)) !important;
    width: min(980px, calc(100vw - 36px)) !important;
    gap: 34px 42px !important;
  }
  .press-logo-link { min-height: 156px !important; }
  .press-logo-link img { max-width: 360px !important; max-height: 132px !important; }
  .press-logo-link:nth-child(3) img { max-width: 420px !important; max-height: 126px !important; }
}
@media (max-width: 560px) {
  .featured-in-section { padding: 48px 0 58px !important; }
  .press-logo-grid.press-logo-grid-linked {
    grid-template-columns: repeat(2, minmax(130px, 1fr)) !important;
    width: 100% !important;
    gap: 24px 18px !important;
  }
  .press-logo-link { min-height: 112px !important; }
  .press-logo-link img { max-width: 220px !important; max-height: 92px !important; }
  .press-logo-link:nth-child(3) img { max-width: 250px !important; max-height: 84px !important; }
}

/* V6.20 correction: preserve V6.19 page/copy exactly and scale Featured In logos only */
.featured-in-section {
  text-align: center !important;
}
.featured-in-inner,
.featured-in-inner h2,
.press-logo-grid.press-logo-grid-linked {
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}
.press-logo-grid.press-logo-grid-linked {
  width: min(1760px, calc(100vw - 36px)) !important;
  grid-template-columns: repeat(4, minmax(260px, 1fr)) !important;
  gap: clamp(32px, 3.6vw, 72px) !important;
  overflow: visible !important;
}
.press-logo-link {
  min-height: 248px !important;
  overflow: visible !important;
}
.press-logo-link img {
  transform: scale(1.3) !important;
  transform-origin: center !important;
  width: 100% !important;
  max-width: 500px !important;
  max-height: 184px !important;
  object-fit: contain !important;
}
.press-logo-link:nth-child(1) img { max-width: 450px !important; max-height: 148px !important; }
.press-logo-link:nth-child(2) img { max-width: 390px !important; max-height: 188px !important; }
.press-logo-link:nth-child(3) img { max-width: 570px !important; max-height: 170px !important; }
.press-logo-link:nth-child(4) img { max-width: 440px !important; max-height: 180px !important; }
@media (max-width: 980px) {
  .press-logo-grid.press-logo-grid-linked {
    grid-template-columns: repeat(2, minmax(220px, 1fr)) !important;
    width: min(980px, calc(100vw - 36px)) !important;
    gap: 42px 48px !important;
  }
  .press-logo-link { min-height: 180px !important; }
  .press-logo-link img { transform: scale(1.18) !important; }
}
@media (max-width: 560px) {
  .press-logo-grid.press-logo-grid-linked {
    grid-template-columns: repeat(2, minmax(130px, 1fr)) !important;
    gap: 28px 20px !important;
  }
  .press-logo-link { min-height: 122px !important; }
  .press-logo-link img { transform: scale(1.08) !important; }
}

/* V6.21 correction: About testimonials exactly match homepage carousel + slightly larger Selected Project Context images */
@media (min-width: 981px) {
  .home-latest-projects .project-grid {
    grid-template-columns: repeat(3, minmax(0, 350px)) !important;
  }
}
@media (max-width: 980px) and (min-width: 701px) {
  .home-latest-projects .project-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 700px) {
  .home-latest-projects .project-grid {
    grid-template-columns: 1fr !important;
    width: min(100%, 410px) !important;
  }
}
