:root {
    --navy: #082d4d;
    --navy-deep: #03243d;
    --blue: #126b8a;
    --aqua: #1fa7c2;
    --teal: #4cb49a;
    --teal-text: #16766b;
    --mint: #a7dccb;
    --green: #527a5e;
    --sand: #c8a97e;
    --cream: #f7f4ed;
    --ink: #18252c;
    --white: #fff;
    --line: rgba(8, 45, 77, .14);
    --head: "Montserrat", Arial, sans-serif;
    --body: "DM Sans", Arial, sans-serif;
    --editorial: "Source Serif 4", Georgia, serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--cream); font-family: var(--body); font-size: 16px; line-height: 1.55; }
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { color: inherit; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible, [tabindex]:focus-visible { outline: 3px solid #f2c14e; outline-offset: 3px; }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { color: var(--navy); font-family: var(--head); line-height: 1.07; letter-spacing: -.045em; }
h1 { font-size: clamp(3.25rem, 7.6vw, 7.9rem); }
h2 { font-size: clamp(2.35rem, 4.6vw, 5rem); }
h3 { font-size: 1.35rem; }
em { color: var(--teal); font-style: normal; }
.skip-link { position: fixed; z-index: 100; left: 1rem; top: -5rem; padding: .7rem 1rem; background: var(--white); color: var(--navy); font-weight: 700; }
.skip-link:focus { top: 1rem; }
.sr-only { position: absolute !important; width: 1px !important; height: 1px !important; padding: 0 !important; margin: -1px !important; overflow: hidden !important; clip: rect(0, 0, 0, 0) !important; white-space: nowrap !important; border: 0 !important; }
.eyebrow, .footer-label, .mega-label { display: block; color: var(--teal-text); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
.big-index { color: var(--teal-text); font-family: var(--head); font-size: .75rem; font-weight: 700; }
.button { display: inline-flex; align-items: center; justify-content: space-between; gap: 2.5rem; min-width: 220px; padding: 1rem 1.2rem; border: 0; font-family: var(--head); font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.button span { font-size: 1rem; }
.button-light { background: var(--white); color: var(--navy); }
.button-dark { background: var(--navy); color: var(--white); }
.text-link { display: inline-flex; gap: 1rem; align-items: center; padding-bottom: .35rem; border-bottom: 1px solid currentColor; color: var(--navy); font-family: var(--head); font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.text-link.light { color: var(--white); }

.site-header { position: relative; z-index: 50; display: flex; height: 84px; align-items: stretch; border-bottom: 1px solid rgba(255,255,255,.22); background: var(--navy-deep); color: var(--white); }
.brand { display: flex; width: 220px; align-items: center; justify-content: center; border-right: 1px solid rgba(255,255,255,.18); }
.brand-logo { display: block; width: 132px; height: auto; }
.site-nav { display: flex; flex: 1; align-items: stretch; justify-content: flex-end; }
.nav-list { display: flex; align-items: stretch; margin: 0; padding: 0; list-style: none; }
.nav-list > li { display: flex; }
.nav-list > li > a, .nav-list > li > button { display: flex; align-items: center; gap: .5rem; padding: 0 1.2rem; border: 0; background: none; color: white; cursor: pointer; font-family: var(--head); font-size: .66rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.nav-list button span { color: var(--teal); font-size: 1rem; font-weight: 400; }
.nav-cta { display: flex; width: 190px; align-items: center; justify-content: space-between; margin-left: 1rem; padding: 0 1.5rem; background: var(--teal); color: var(--navy-deep); font-family: var(--head); font-size: .66rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.menu-toggle { display: none; }
.mega-menu { visibility: hidden; position: absolute; z-index: 10; top: 84px; right: 0; left: 0; display: grid; grid-template-columns: 1fr 2.1fr; min-height: 380px; background: var(--white); color: var(--ink); box-shadow: 0 22px 40px rgba(3,36,61,.18); opacity: 0; transform: translateY(-8px); transition: .2s ease; }
.has-mega:hover .mega-menu, .has-mega.open .mega-menu { visibility: visible; opacity: 1; transform: none; }
.mega-intro { position: relative; overflow: hidden; padding: 3rem 4vw; background: var(--navy); color: var(--white); }
.mega-intro .eyebrow, .site-footer .footer-label, .home-hero .eyebrow, .page-hero .eyebrow, .method-section .eyebrow, .service-method-section .eyebrow, .edition-story-dark .eyebrow, .edition-dispatch .eyebrow, .edition-colophon .eyebrow, .magazine-lead .eyebrow, .issue-shelf .eyebrow, .magazine-related .eyebrow, .home-news .eyebrow, .contact-band .eyebrow, .service-photo .eyebrow, .service-knowledge-panel .eyebrow, .city-photo .eyebrow, .city-land-use-card .eyebrow, .related-services .eyebrow, .process-strip .eyebrow, .industry-cycle .eyebrow, .industry-cta .eyebrow, .product-architecture .eyebrow, .product-cta .eyebrow, .about-hero .eyebrow, .about-system-grid aside .eyebrow, .about-values .eyebrow { color: var(--mint); }
.mega-intro::after { position: absolute; width: 380px; height: 380px; right: -180px; bottom: -230px; border: 1px solid rgba(76,180,154,.5); border-radius: 50%; box-shadow: 0 0 0 45px rgba(76,180,154,.06), 0 0 0 90px rgba(76,180,154,.04); content: ""; }
.mega-intro h2 { margin: 1.2rem 0 2rem; color: white; font-size: clamp(1.8rem, 3vw, 3.2rem); }
.mega-intro a { color: var(--mint); font-family: var(--head); font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.mega-intro i { margin-left: 1rem; font-style: normal; }
.mega-columns { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2.5rem; align-content: start; padding: 3rem 5vw; }
.service-links { grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.mega-columns > div { display: grid; align-content: start; gap: 0; }
.mega-columns a { display: flex; flex-direction: column; padding: 1rem 0; border-bottom: 1px solid var(--line); }
.mega-columns b { color: var(--navy); font-family: var(--head); font-size: .83rem; }
.mega-columns small { margin-top: .25rem; color: #67767d; font-size: .72rem; }
.city-links, .industry-links { grid-template-columns: repeat(3, 1fr); }
.product-links { grid-template-columns: repeat(3, 1fr); gap: 0 2rem; }
.product-links a { padding: .8rem 0; }

.home-hero, .page-hero { position: relative; overflow: hidden; background: var(--navy); color: var(--white); }
.home-hero { min-height: calc(100vh - 84px); padding: clamp(5rem, 10vw, 9rem) 8vw 6rem; background: radial-gradient(circle at 82% 48%, #126b8a 0, #064063 24%, var(--navy) 48%, var(--navy-deep) 77%); }
.home-hero::after, .page-hero::after { position: absolute; inset: 0; opacity: .08; background-image: repeating-radial-gradient(ellipse at 80% 50%, transparent 0, transparent 28px, white 29px, transparent 30px); content: ""; pointer-events: none; }
.home-hero .hero-copy { position: relative; z-index: 2; max-width: 920px; }
.home-hero h1 { margin: 1rem 0 2rem; color: var(--white); }
.home-hero .hero-copy > p { max-width: 560px; color: rgba(255,255,255,.75); font-size: 1.12rem; }
.hero-actions { display: flex; gap: 2rem; align-items: center; margin-top: 2.7rem; }
.hero-note { position: absolute; z-index: 2; right: 4vw; bottom: 3rem; display: flex; flex-direction: column; padding-left: 1.2rem; border-left: 1px solid var(--teal); font-size: .7rem; letter-spacing: .06em; }
.hero-note span, .hero-note small { color: rgba(255,255,255,.58); }
.hero-ping { position: absolute; z-index: 2; right: 10vw; top: 40%; display: flex; gap: 1rem; align-items: center; color: rgba(255,255,255,.7); font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; }
.hero-ping i { width: 8px; height: 8px; border-radius: 50%; background: var(--teal); box-shadow: 0 0 0 14px rgba(76,180,154,.12), 0 0 0 28px rgba(76,180,154,.07); }
.sonar { position: absolute; right: -8vw; top: 8%; width: min(60vw, 800px); height: min(60vw, 800px); border: 1px solid rgba(167,220,203,.14); border-radius: 50%; }
.sonar-two { transform: scale(.75); }.sonar-three { transform: scale(.48); }

.intro-block { display: grid; grid-template-columns: 1fr 2.2fr; gap: 5vw; padding: 9rem 8vw; background: var(--white); }
.intro-block > div:first-child { display: flex; justify-content: space-between; border-top: 1px solid var(--line); padding-top: 1rem; }
.intro-block h2 { max-width: 850px; margin-bottom: 2rem; }
.intro-block p { max-width: 620px; margin-bottom: 2rem; color: #58666c; font-size: 1.06rem; }
.system-definition { display: flex; flex-wrap: wrap; gap: .55rem; margin: -.5rem 0 2rem; }
.system-definition span { padding: .55rem .72rem; border: 1px solid var(--line); color: var(--navy); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.services-section, .insights-section, .directory { padding: 8rem 8vw; }
.services-section { background: var(--cream); }
.section-heading { display: grid; grid-template-columns: 2fr 1fr; gap: 6vw; align-items: end; margin-bottom: 4rem; }
.section-heading h2 { margin: .9rem 0 0; }
.section-heading p { max-width: 450px; color: #607078; }
.service-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1rem; }
.service-card { position: relative; overflow: hidden; display: flex; min-height: 420px; flex-direction: column; grid-column: span 2; padding: 2rem; border: 1px solid color-mix(in srgb, var(--tone, var(--navy)) 28%, transparent); background: linear-gradient(145deg, color-mix(in srgb, var(--tone, var(--navy)) 9%, var(--white)) 0, var(--white) 58%); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.service-card:nth-child(1), .service-card:nth-child(2) { grid-column: span 3; min-height: 490px; }
.service-card:hover { border-color: color-mix(in srgb, var(--tone, var(--navy)) 55%, transparent); transform: translateY(-6px); box-shadow: 0 18px 40px rgba(8,45,77,.12); }
.service-card::before { position: absolute; top: 0; right: 0; left: 0; height: 6px; background: var(--tone, var(--navy)); content: ""; }
.service-card::after { position: absolute; right: -120px; top: -120px; width: 260px; height: 260px; border: 1px solid currentColor; border-radius: 50%; opacity: .18; box-shadow: 0 0 0 25px currentColor, 0 0 0 52px currentColor; content: ""; }
.service-card .card-number { align-self: flex-end; color: var(--tone, var(--teal)); font-family: var(--head); font-size: .65rem; font-weight: 700; }
.service-card .service-symbol { display: grid; width: 58px; height: 58px; place-items: center; margin: auto 0 2rem; border: 1px solid currentColor; border-radius: 50%; background: color-mix(in srgb, var(--tone, var(--navy)) 10%, transparent); opacity: .9; }
.service-card .service-symbol svg { width: 30px; height: 30px; fill: none; stroke: currentColor; stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; }
.service-card h3 { margin: .8rem 0 1rem; font-size: clamp(1.65rem, 2.3vw, 2.7rem); }
.service-card p { max-width: 410px; color: #627178; }
.service-card b { display: flex; justify-content: space-between; margin-top: auto; padding-top: 1.5rem; border-top: 1px solid var(--line); color: var(--navy); font-family: var(--head); font-size: .66rem; letter-spacing: .08em; text-transform: uppercase; }
.service-card i { font-size: 1rem; font-style: normal; }.tone-green { --tone: #5e8d69; }.tone-tropical { --tone: #187968; }.tone-sand { --tone: #d09b55; }.tone-aqua { --tone: #169fb9; }.tone-slate { --tone: #657f88; }.tone-navy { --tone: var(--navy); }
.service-variant, .service-system-section, .service-expertise-section, .service-method-section, .service-hero, .offering-section, .related-services, .city-service-photo, .city-service-intro, .city-service-capabilities { --tone-active: var(--tone, var(--teal)); }
.service-card[class*="tone-"] { color: var(--tone, var(--navy)); }
.photo-story { display: grid; grid-template-columns: 1.4fr 1fr; grid-template-rows: repeat(2, 300px); gap: 1rem; padding: 0 8vw 8rem; background: var(--white); }
.photo-story figure { position: relative; overflow: hidden; margin: 0; background: var(--navy); }
.photo-story-main { grid-row: 1 / 3; }
.photo-story img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.78); transition: transform .5s ease, filter .3s ease; }
.photo-story figure:hover img { transform: scale(1.025); filter: saturate(1); }
.photo-story figure::after { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(3,36,61,.75)); content: ""; }
.photo-story figcaption { position: absolute; z-index: 2; right: 1.5rem; bottom: 1.3rem; left: 1.5rem; display: flex; justify-content: space-between; color: var(--white); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.photo-story figcaption span { color: var(--mint); }

.method-section { display: grid; grid-template-columns: 1fr 1fr; min-height: 760px; background: var(--navy-deep); color: white; }
.method-visual { position: relative; overflow: hidden; display: grid; place-items: center; min-height: 640px; background: radial-gradient(circle, #126b8a 0, #064366 38%, var(--navy-deep) 68%); }
.method-visual span { position: relative; z-index: 2; color: white; font-family: var(--head); font-size: clamp(2.5rem, 5vw, 5.5rem); font-weight: 700; line-height: 1.05; letter-spacing: -.05em; }
.rings { position: absolute; width: 50%; aspect-ratio: 1; border: 1px solid rgba(167,220,203,.3); border-radius: 50%; box-shadow: 0 0 0 65px rgba(167,220,203,.06), 0 0 0 130px rgba(167,220,203,.04), 0 0 0 195px rgba(167,220,203,.025); }
.method-copy { padding: 7rem 7vw; }
.method-copy h2 { margin: 1rem 0 3rem; color: var(--white); font-size: clamp(2.2rem, 4vw, 4.6rem); }
.method-copy ol { margin: 0; padding: 0; list-style: none; }
.method-copy li { display: grid; grid-template-columns: 3rem 1fr; gap: 1rem; padding: 1.5rem 0; border-top: 1px solid rgba(255,255,255,.16); }
.method-copy li b { color: var(--teal); font-family: var(--head); font-size: .7rem; }
.method-copy h3 { margin-bottom: .55rem; color: white; font-size: 1.1rem; }
.method-copy p { margin: 0; color: rgba(255,255,255,.6); font-size: .9rem; }

.insights-section { background: var(--white); }
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.post-card { display: block; }
.post-art { position: relative; overflow: hidden; display: flex; aspect-ratio: 1.25; align-items: flex-end; padding: 1.5rem; background: var(--navy); color: var(--white); }
.post-art::before, .post-art::after { position: absolute; border-radius: 50%; content: ""; }
.post-art::before { width: 80%; height: 80%; top: 10%; right: -30%; border: 1px solid rgba(255,255,255,.24); box-shadow: 0 0 0 28px rgba(255,255,255,.05), 0 0 0 56px rgba(255,255,255,.035); }
.post-art::after { width: 8px; height: 8px; top: 47%; right: 19%; background: var(--teal); box-shadow: 0 0 0 12px rgba(76,180,154,.13); }
.post-2 .post-art { background: var(--green); }.post-3 .post-art { background: var(--sand); }
.post-art span { font-family: var(--head); font-size: 2.5rem; font-weight: 700; opacity: .7; }
.post-art.has-image { background-position: center; background-size: cover; }
.post-art.has-image::before { inset: 0; width: auto; height: auto; border: 0; border-radius: 0; background: linear-gradient(180deg, transparent 35%, rgba(4,31,50,.82)); box-shadow: none; }
.post-art.has-image::after { display: none; }
.post-art.has-image span { z-index: 1; text-shadow: 0 2px 14px rgba(0,0,0,.35); }
.post-card > div:last-child { padding: 1.5rem 0; }
.post-card h3 { margin: .9rem 0; font-size: 1.45rem; }
.post-card p { color: #647278; font-size: .9rem; }

/* Orca Pings Magazine */
.digital-edition { overflow: clip; background: #f1ede3; }
.edition-page { position: relative; min-height: calc(100vh - 84px); scroll-margin-top: 0; }
.edition-progress { position: fixed; z-index: 61; top: 0; right: 0; left: 0; height: 3px; pointer-events: none; }
.edition-progress span { display: block; width: 0; height: 100%; background: var(--teal); }
.edition-nav { position: fixed; z-index: 45; top: 50%; right: .55rem; display: flex; flex-direction: column; gap: .15rem; transform: translateY(-50%); }
.edition-nav a { position: relative; display: flex; width: 24px; height: 24px; align-items: center; justify-content: center; color: transparent; transition: .2s ease; }
.edition-nav a::before { width: 9px; height: 9px; border: 1px solid rgba(76,180,154,.75); border-radius: 50%; background: rgba(3,36,61,.55); content: ""; }
.edition-nav a span { position: absolute; right: 1rem; padding: .25rem .45rem; background: var(--navy-deep); color: var(--white); font-size: .55rem; letter-spacing: .08em; opacity: 0; pointer-events: none; text-transform: uppercase; transform: translateX(-4px); transition: .2s ease; white-space: nowrap; }
.edition-nav a:hover span { opacity: 1; transform: none; }
.edition-nav a.active::before { background: var(--teal); transform: scale(1.35); }
.edition-cover { overflow: hidden; display: flex; min-height: calc(100vh - 84px); flex-direction: column; justify-content: space-between; padding: 3rem 5vw; color: var(--white); }
.edition-cover > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(1.08) contrast(1.02); }
.edition-cover-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(3,36,61,.92) 0, rgba(3,36,61,.48) 48%, rgba(3,36,61,.08) 80%), linear-gradient(0deg, rgba(3,36,61,.6), transparent 45%); }
.edition-cover-top, .edition-cover-title, .edition-cover-bottom { position: relative; z-index: 2; }
.edition-cover-top, .edition-cover-bottom { display: flex; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.55); padding-top: .7rem; font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.edition-cover-top { border-top: 0; border-bottom: 1px solid rgba(255,255,255,.55); padding-top: 0; padding-bottom: .7rem; }
.edition-cover-title { max-width: 900px; margin: auto 0; }
.edition-cover-title > span { color: var(--mint); font-family: var(--head); font-size: .7rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
.edition-cover-title h1 { margin: 1rem 0 1.8rem; color: var(--white); font-family: var(--editorial); font-size: clamp(5rem, 11vw, 12rem); font-weight: 600; line-height: .74; letter-spacing: -.075em; }
.edition-cover-title h1 em { color: var(--teal); font-family: var(--editorial); font-style: italic; font-weight: 400; }
.edition-cover-title p { max-width: 520px; color: rgba(255,255,255,.82); font-family: var(--editorial); font-size: 1.25rem; line-height: 1.55; }
.edition-cover-bottom a { color: var(--mint); }
.paint-stroke { position: absolute; z-index: 1; height: 90px; background: var(--teal); opacity: .85; pointer-events: none; transform: rotate(-5deg); }
.paint-stroke::before, .paint-stroke::after { position: absolute; inset: 0; background: inherit; content: ""; clip-path: polygon(0 15%, 9% 0, 23% 10%, 38% 0, 55% 9%, 72% 2%, 88% 13%, 100% 5%, 97% 78%, 84% 91%, 68% 79%, 51% 94%, 33% 82%, 14% 96%, 0 81%); }
.paint-stroke::after { opacity: .45; transform: translateY(18px) scaleY(.45); }
.paint-stroke-cover { right: -8vw; bottom: 22%; width: 48vw; }
.paint-stroke-green { z-index: 3; right: 35%; bottom: 14%; width: 38vw; background: var(--green); }
.paint-stroke-end { top: 20%; right: -10vw; width: 60vw; }
.edition-story { overflow: hidden; background: #fffdf8; }
.edition-card { position: relative; min-height: calc(100vh - 84px); background: inherit; perspective: 1800px; }
.edition-card-face { position: absolute; inset: 0; min-height: calc(100vh - 84px); transition: opacity .42s ease, transform .55s cubic-bezier(.2,.8,.2,1); }
.edition-card-front { display: grid; grid-template-columns: 1.15fr 1fr; opacity: 1; transform: translateX(0); }
.edition-card-back { overflow: hidden; background: #fffdf8; opacity: 0; pointer-events: none; transform: translateX(4rem); }
.edition-story.is-reading .edition-card-front { opacity: 0; pointer-events: none; transform: translateX(-4rem); }
.edition-story.is-reading .edition-card-back { opacity: 1; pointer-events: auto; transform: translateX(0); }
.edition-article-face[hidden] { display: none; }
.edition-card-front > figure { overflow: hidden; min-height: calc(100vh - 84px); margin: 0; background: var(--navy); }
.edition-card-front > figure img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s ease; }
.edition-story:hover .edition-card-front > figure img { transform: scale(1.015); }
.edition-story-copy { box-sizing: border-box; display: flex; min-height: calc(100vh - 84px); flex-direction: column; justify-content: flex-start; padding: clamp(3.25rem, 7vh, 6rem) 7vw; }
.edition-folio { display: block; margin-bottom: clamp(2rem, 8vh, 5rem); padding-bottom: .7rem; border-bottom: 1px solid var(--navy); color: var(--navy); font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; }
.edition-story-copy .eyebrow { margin-top: 0; }
.edition-story-copy h2 { margin: .75rem 0 1rem; font-family: var(--editorial); font-size: clamp(2.35rem, 3.65vw, 4.35rem); font-weight: 600; line-height: .96; letter-spacing: -.055em; }
.edition-story-copy p { color: #52625e; font-family: var(--editorial); font-size: .95rem; line-height: 1.5; }
.edition-story-copy .edition-deck { color: var(--navy); font-size: clamp(1.02rem, 1.18vw, 1.28rem); line-height: 1.35; }
.edition-story-copy footer { display: flex; justify-content: space-between; gap: 1rem; margin-top: auto; padding-top: 1rem; border-top: 1px solid var(--line); color: #65736e; font-size: .62rem; letter-spacing: .08em; text-transform: uppercase; }
.edition-story-copy footer a { color: var(--navy); font-family: var(--head); font-size: .58rem; font-weight: 700; }
.edition-action { border: 0; background: transparent; color: var(--navy); cursor: pointer; font-family: var(--head); font-size: .58rem; font-weight: 700; letter-spacing: .08em; padding: 0; text-transform: uppercase; }
.edition-action span { color: var(--teal); }
.edition-article-face { display: flex; height: calc(100vh - 84px); flex-direction: column; padding: 3rem 5vw 2.5rem; }
.edition-article-face header, .edition-article-face footer { display: flex; align-items: center; justify-content: space-between; gap: 1rem; border-bottom: 1px solid var(--line); color: #65736e; font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.edition-article-face header { padding-bottom: .8rem; }
.edition-article-face footer { margin-top: 1.2rem; padding-top: .8rem; border-top: 1px solid var(--line); border-bottom: 0; }
.edition-article-face footer a, .edition-article-face footer button { color: var(--navy); }
.edition-article-face h2 { max-width: 980px; margin: 1.1rem 0 .8rem; font-family: var(--editorial); font-size: clamp(2.2rem, 4vw, 4.9rem); font-weight: 600; line-height: .94; letter-spacing: -.055em; }
.edition-article-lead { max-width: 920px; margin: 0 0 1.3rem; color: var(--navy); font-family: var(--editorial); font-size: clamp(1.05rem, 1.6vw, 1.55rem); line-height: 1.38; }
.edition-brochure { overflow: hidden; flex: 1; column-count: 3; column-gap: 2rem; column-rule: 1px solid var(--line); color: #394a49; font-family: var(--editorial); font-size: clamp(.82rem, .92vw, 1rem); line-height: 1.48; }
.edition-brochure h2, .edition-brochure h3 { margin: 0 0 .55rem; break-after: avoid; color: var(--navy); font-family: var(--editorial); font-size: 1.35rem; line-height: 1.05; }
.edition-brochure p, .edition-brochure ul, .edition-brochure ol, .edition-brochure blockquote { margin: 0 0 .8rem; break-inside: avoid; }
.edition-brochure img { display: block; width: 100%; height: auto; max-height: 240px; object-fit: cover; margin-bottom: .35rem; break-inside: avoid; }
.edition-brochure ul, .edition-brochure ol { padding-left: 1.1rem; }
.edition-brochure a { color: #087b83; text-decoration: underline; text-underline-offset: .18em; }
.edition-story-dark .edition-action, .edition-story-dark .edition-story-copy footer a { color: var(--white); }
.edition-story-split { grid-template-columns: 1fr 1.25fr; background: #e7dcc1; }
.edition-story-split .edition-card-front { grid-template-columns: 1fr 1.25fr; }
.edition-story-split figure { grid-column: 2; grid-row: 1; }
.edition-story-split .edition-story-copy { grid-column: 1; grid-row: 1; }
.edition-story-dark { background: var(--navy-deep); color: var(--white); }
.edition-story-dark h2, .edition-story-dark .edition-deck, .edition-story-dark .edition-folio, .edition-story-dark footer a { color: var(--white); }
.edition-story-dark .edition-folio, .edition-story-dark footer { border-color: rgba(255,255,255,.25); }
.edition-story-dark p, .edition-story-dark footer { color: rgba(255,255,255,.62); }
.edition-story-dark .edition-card-back { background: var(--navy-deep); }
.edition-story-dark .edition-article-face header, .edition-story-dark .edition-article-face footer, .edition-story-dark .edition-brochure { border-color: rgba(255,255,255,.22); column-rule-color: rgba(255,255,255,.18); color: rgba(255,255,255,.72); }
.edition-story-dark .edition-article-face h2, .edition-story-dark .edition-article-lead, .edition-story-dark .edition-brochure h2, .edition-story-dark .edition-brochure h3, .edition-story-dark .edition-article-face footer a { color: var(--white); }
.edition-story-image-right figure { grid-column: 2; grid-row: 1; }
.edition-story-image-right .edition-story-copy { grid-column: 1; grid-row: 1; }
.edition-story-image-left { background: #e7dcc1; }
.edition-dispatch { display: grid; grid-template-columns: .85fr 1.5fr 1fr; grid-template-rows: 1fr 1fr; gap: 1rem; padding: 1rem; background: var(--navy-deep); color: var(--white); }
.dispatch-intro { display: flex; flex-direction: column; justify-content: flex-end; padding: 4rem 3vw; }
.dispatch-intro h2 { margin: 1rem 0; color: var(--white); font-family: var(--editorial); font-size: clamp(3rem, 5vw, 6.5rem); font-weight: 500; line-height: .88; }
.dispatch-intro h2 em { font-family: var(--editorial); font-style: italic; font-weight: 400; }
.dispatch-intro p { color: rgba(255,255,255,.65); font-family: var(--editorial); line-height: 1.65; }
.edition-dispatch figure { position: relative; overflow: hidden; margin: 0; }
.edition-dispatch figure img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.08); transition: transform .7s ease; }
.edition-dispatch figure:hover img { transform: scale(1.025); }
.dispatch-main { grid-row: 1 / 3; grid-column: 2; }
.edition-dispatch figcaption { position: absolute; right: 0; bottom: 0; left: 0; display: flex; justify-content: space-between; padding: 1rem; background: linear-gradient(0deg, rgba(3,36,61,.82), transparent); color: var(--white); font-size: .65rem; }
.edition-dispatch figcaption b { font-family: var(--head); font-size: .62rem; letter-spacing: .08em; text-transform: uppercase; }
.edition-field-note { display: grid; grid-template-columns: 1.3fr 1fr; background: var(--green); color: var(--white); }
.edition-field-note > img { width: 100%; height: 100%; min-height: calc(100vh - 84px); object-fit: cover; filter: saturate(1.1); }
.edition-field-note > div { position: relative; overflow: hidden; display: flex; flex-direction: column; justify-content: center; padding: 6rem 6vw; }
.edition-field-note > div::before { position: absolute; right: -180px; bottom: -180px; width: 440px; height: 440px; border: 1px solid rgba(255,255,255,.25); border-radius: 50%; box-shadow: 0 0 0 55px rgba(255,255,255,.035), 0 0 0 110px rgba(255,255,255,.025); content: ""; }
.edition-field-note h2 { margin: 1rem 0 2rem; color: var(--white); font-family: var(--editorial); font-size: clamp(3.2rem, 5vw, 6rem); font-weight: 500; line-height: .94; }
.edition-field-note h2 em { color: var(--mint); font-family: var(--editorial); font-style: italic; font-weight: 400; }
.edition-field-note p { color: rgba(255,255,255,.72); font-family: var(--editorial); font-size: 1.1rem; line-height: 1.7; }
.field-note-mark { margin-top: 4rem; color: var(--mint); font-family: var(--editorial); font-size: 2.5rem; font-style: italic; line-height: 1; }
.edition-colophon { overflow: hidden; display: flex; min-height: 80vh; flex-direction: column; justify-content: center; padding: 8rem 12vw; background: var(--navy-deep); color: var(--white); }
.edition-colophon h2 { position: relative; z-index: 2; margin: 1rem 0 2rem; color: var(--white); font-family: var(--editorial); font-size: clamp(5rem, 10vw, 11rem); font-weight: 500; line-height: .76; }
.edition-colophon h2 em { color: var(--mint); font-family: var(--editorial); font-style: italic; font-weight: 400; }
.edition-colophon p, .edition-colophon a, .edition-colophon .eyebrow { position: relative; z-index: 2; }
.edition-colophon p { max-width: 560px; color: rgba(255,255,255,.65); font-family: var(--editorial); font-size: 1.15rem; }
.edition-colophon a { width: fit-content; margin-top: 2rem; padding-bottom: .5rem; border-bottom: 1px solid var(--mint); color: var(--mint); font-family: var(--head); font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.magazine-masthead { display: grid; grid-template-columns: .8fr 2fr 1.15fr; gap: 5vw; align-items: end; padding: 5rem 8vw 3rem; border-bottom: 1px solid var(--navy); background: #f1ede3; }
.magazine-masthead > div:first-child { align-self: start; display: flex; flex-direction: column; gap: .4rem; color: #69736f; font-size: .7rem; letter-spacing: .05em; text-transform: uppercase; }
.magazine-volume { color: var(--navy); font-family: var(--head); font-weight: 700; }
.magazine-masthead h1 { margin: 0; font-family: var(--editorial); font-size: clamp(5rem, 11vw, 12rem); font-weight: 400; line-height: .68; letter-spacing: -.08em; }
.magazine-masthead h1 em { display: inline-block; margin-left: 12%; font-family: var(--editorial); font-style: italic; font-weight: 400; }
.magazine-masthead > p { margin: 0 0 .3rem; color: #586662; font-family: var(--editorial); font-size: 1.15rem; line-height: 1.55; }
.magazine-rule { display: flex; grid-column: 1 / -1; justify-content: space-between; margin-top: 2.5rem; padding-top: .8rem; border-top: 4px double var(--navy); color: var(--navy); font-size: .65rem; letter-spacing: .12em; text-transform: uppercase; }
.magazine-rule b { font-family: var(--head); font-size: inherit; }
.magazine-lead { display: grid; grid-template-columns: 1.45fr 1fr; min-height: 650px; background: var(--navy-deep); color: var(--white); }
.magazine-lead-image { position: relative; overflow: hidden; min-height: 650px; }
.magazine-lead-image::after { position: absolute; inset: 0; background: linear-gradient(90deg, transparent 60%, rgba(3,36,61,.35)); content: ""; }
.magazine-lead-image img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.72); transition: transform .8s ease, filter .4s ease; }
.magazine-lead-image:hover img { transform: scale(1.025); filter: saturate(1); }
.magazine-lead-image span { position: absolute; z-index: 1; top: 2rem; left: 2rem; padding: .55rem .7rem; background: var(--teal); color: var(--navy-deep); font-family: var(--head); font-size: .6rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.magazine-lead > div { position: relative; display: flex; flex-direction: column; justify-content: flex-end; padding: 5rem 5vw; }
.magazine-number { position: absolute; top: 2.5rem; right: 3vw; color: rgba(255,255,255,.12); font-family: var(--editorial); font-size: 9rem; line-height: 1; }
.magazine-lead h2 { margin: 1rem 0 1.4rem; color: var(--white); font-family: var(--editorial); font-size: clamp(2.6rem, 4.4vw, 5.2rem); font-weight: 600; line-height: .98; letter-spacing: -.055em; }
.magazine-lead p { max-width: 530px; color: rgba(255,255,255,.65); font-family: var(--editorial); font-size: 1.05rem; line-height: 1.7; }
.magazine-story-meta { display: flex; gap: 1.5rem; margin-top: 1rem; color: rgba(255,255,255,.58); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; }
.magazine-read { display: flex; justify-content: space-between; margin-top: 3rem; padding-top: 1rem; border-top: 1px solid rgba(255,255,255,.25); color: var(--mint); font-family: var(--head); font-size: .67rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.magazine-index { padding: 8rem 8vw; background: #f1ede3; }
.magazine-index > header { display: grid; grid-template-columns: 1fr 1.4fr; gap: 7vw; align-items: end; margin-bottom: 4rem; padding-bottom: 2rem; border-bottom: 4px double var(--navy); }
.magazine-index h2 { margin: .8rem 0 0; font-family: var(--editorial); font-size: clamp(3rem, 5vw, 6rem); font-weight: 400; line-height: .9; }
.magazine-topic-filter { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: flex-end; }
.magazine-topic-filter button { display: flex; gap: .7rem; padding: .65rem .8rem; border: 1px solid rgba(8,45,77,.25); background: transparent; color: #566560; cursor: pointer; font-size: .68rem; }
.magazine-topic-filter button span { color: var(--teal); font-family: var(--head); font-size: .58rem; font-weight: 700; }
.magazine-topic-filter button:hover, .magazine-topic-filter button.active { background: var(--navy); color: var(--white); }
.magazine-story-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 4rem 1.5rem; }
.magazine-story { display: block; grid-column: span 4; border-top: 1px solid var(--navy); }
.magazine-story:nth-child(1), .magazine-story:nth-child(4) { grid-column: span 8; }
.magazine-story[hidden] { display: none; }
.magazine-story figure { position: relative; overflow: hidden; margin: 0 0 1.5rem; background: var(--navy); }
.magazine-story img { display: block; width: 100%; aspect-ratio: 1.25; object-fit: cover; filter: saturate(.62); transition: transform .6s ease, filter .3s ease; }
.magazine-story:nth-child(1) img, .magazine-story:nth-child(4) img { aspect-ratio: 1.8; }
.magazine-story:hover img { transform: scale(1.025); filter: saturate(1); }
.magazine-story figure span { position: absolute; right: 1rem; bottom: .7rem; color: var(--white); font-family: var(--editorial); font-size: 3.5rem; line-height: 1; text-shadow: 0 2px 12px rgba(0,0,0,.3); }
.magazine-story h3 { margin: .8rem 0 1rem; font-family: var(--editorial); font-size: clamp(1.7rem, 2.5vw, 3rem); font-weight: 600; line-height: 1.02; letter-spacing: -.045em; }
.magazine-story p { color: #5f6c67; font-family: var(--editorial); line-height: 1.65; }
.magazine-story footer { display: flex; justify-content: space-between; margin-top: 1.5rem; padding-top: .8rem; border-top: 1px solid rgba(8,45,77,.18); color: #6a7671; font-size: .65rem; text-transform: uppercase; }
.magazine-story footer b { color: var(--navy); font-family: var(--head); font-size: .58rem; letter-spacing: .08em; }
.magazine-empty { padding: 5rem 0; color: #5f6c67; font-family: var(--editorial); font-size: 1.2rem; text-align: center; }
.magazine-play { display: grid; grid-template-columns: 1fr 1.3fr; gap: 8vw; align-items: center; padding: 8rem 8vw; background: var(--teal); color: var(--navy-deep); }
.magazine-play .eyebrow { color: var(--navy-deep); }
.magazine-play h2 { margin: 1rem 0 1.5rem; color: var(--navy-deep); font-family: var(--editorial); font-size: clamp(3.2rem, 5.5vw, 6.5rem); font-weight: 600; line-height: .9; }
.magazine-play p { max-width: 420px; font-family: var(--editorial); font-size: 1.1rem; }
.crossword-puzzle { display: grid; grid-template-columns: minmax(320px, .9fr) 1fr; gap: 2rem; align-items: start; padding: 2rem; border: 1px solid rgba(3,36,61,.4); background: rgba(255,255,255,.18); }
.crossword-board { display: grid; grid-template-columns: repeat(8, minmax(0, 1fr)); aspect-ratio: 8 / 14; border: 2px solid var(--navy-deep); background: var(--navy-deep); gap: 2px; }
.crossword-cell { position: relative; display: block; min-width: 0; background: #fffdf8; }
.crossword-cell-black { background: var(--navy-deep); }
.crossword-cell span { position: absolute; top: .18rem; left: .25rem; color: #52625e; font-family: var(--head); font-size: .52rem; font-weight: 700; line-height: 1; pointer-events: none; }
.crossword-cell input { width: 100%; height: 100%; border: 0; background: transparent; color: var(--navy-deep); font-family: var(--head); font-size: clamp(1rem, 2.2vw, 1.8rem); font-weight: 700; text-align: center; text-transform: uppercase; }
.crossword-cell input:focus { outline: 3px solid var(--mint); outline-offset: -3px; }
.crossword-cell.is-correct { background: rgba(216,244,232,.95); }
.crossword-cell.is-incorrect { background: rgba(255,255,255,.72); box-shadow: inset 0 0 0 3px rgba(167,48,48,.55); }
.crossword-panel { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem 2rem; }
.crossword-panel h3 { margin: 0 0 .8rem; font-family: var(--head); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; }
.crossword-panel ol { margin: 0; padding-left: 1.4rem; color: var(--navy-deep); font-family: var(--editorial); font-size: .98rem; line-height: 1.45; }
.crossword-panel li + li { margin-top: .55rem; }
.crossword-actions { display: flex; flex-wrap: wrap; gap: .7rem; grid-column: 1 / -1; }
.crossword-actions button { padding: .8rem 1rem; border: 1px solid var(--navy-deep); background: transparent; color: var(--navy-deep); cursor: pointer; font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.crossword-actions button:hover { background: var(--navy-deep); color: var(--white); }
.crossword-status { grid-column: 1 / -1; min-height: 1.4em; margin: 0; color: var(--navy-deep); font-family: var(--head) !important; font-size: .7rem !important; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.issue-shelf { display: grid; grid-template-columns: .7fr 2fr; gap: 7vw; padding: 8rem 8vw; background: var(--navy-deep); color: var(--white); }
.issue-shelf h2 { margin: 1rem 0 0; color: var(--white); font-family: var(--editorial); font-size: clamp(3rem, 5vw, 6rem); font-weight: 400; line-height: .92; }
.issue-shelf > div:last-child { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.issue-shelf a, .issue-shelf article { position: relative; display: flex; min-height: 260px; flex-direction: column; padding: 2rem; border: 1px solid rgba(255,255,255,.2); color: rgba(255,255,255,.65); }
.issue-shelf a.active { border-color: var(--teal); background: rgba(76,180,154,.08); }
.issue-shelf span { color: var(--teal); font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.issue-shelf strong { margin: auto 0 .7rem; color: var(--white); font-family: var(--editorial); font-size: 2.4rem; font-weight: 600; }
.issue-shelf small { font-family: var(--editorial); font-size: .9rem; }
.issue-shelf b { position: absolute; top: 1.5rem; right: 1.5rem; color: var(--teal); }

.reading-progress { position: fixed; z-index: 60; top: 0; right: 0; left: 0; height: 3px; pointer-events: none; }
.reading-progress span { display: block; width: 0; height: 100%; background: var(--teal); }
.magazine-article-cover { padding: 2rem 8vw 0; background: #f1ede3; }
.magazine-cover-kicker { display: flex; justify-content: space-between; padding-bottom: .8rem; border-bottom: 4px double var(--navy); color: var(--navy); font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.magazine-cover-title { display: grid; grid-template-columns: .45fr 2fr 1fr; gap: 3vw; align-items: end; padding: 5rem 0 4rem; }
.magazine-section { align-self: start; color: var(--teal); font-family: var(--head); font-size: .65rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; writing-mode: vertical-rl; }
.magazine-cover-title h1 { margin: 0; font-family: var(--editorial); font-size: clamp(4rem, 8vw, 9.5rem); font-weight: 600; line-height: .86; letter-spacing: -.075em; }
.magazine-cover-title > p { margin: 0; color: #57655f; font-family: var(--editorial); font-size: 1.15rem; line-height: 1.6; }
.magazine-byline { display: flex; grid-column: 2 / -1; gap: 2rem; margin-top: 1rem; padding-top: 1rem; border-top: 1px solid rgba(8,45,77,.2); color: #65716d; font-size: .68rem; letter-spacing: .07em; text-transform: uppercase; }
.magazine-byline strong { color: var(--navy); }
.magazine-article-cover figure { position: relative; margin: 0; }
.magazine-article-cover figure::after { position: absolute; inset: 0; border: 1px solid rgba(255,255,255,.25); content: ""; pointer-events: none; }
.magazine-article-cover figure img { display: block; width: 100%; max-height: 78vh; object-fit: cover; filter: saturate(.78); }
.magazine-article-cover figcaption { position: absolute; right: 0; bottom: 0; padding: .55rem .75rem; background: #f1ede3; color: #61706a; font-size: .6rem; }
.magazine-article { display: grid; grid-template-columns: .7fr 2fr .4fr; gap: 6vw; padding: 7rem 8vw 9rem; background: #fffdf8; }
.magazine-article-rail { position: sticky; top: 2rem; display: flex; height: fit-content; flex-direction: column; gap: 2.5rem; }
.magazine-back { padding-bottom: .7rem; border-bottom: 1px solid var(--line); color: var(--navy); font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.magazine-article-rail > div { display: flex; flex-direction: column; gap: .65rem; }
.magazine-article-rail nav { display: flex; flex-direction: column; border-top: 1px solid var(--line); }
.magazine-article-rail nav a { padding: .65rem 0; border-bottom: 1px solid var(--line); color: #65726d; font-family: var(--editorial); font-size: .78rem; line-height: 1.25; }
.magazine-article-rail nav a.active, .magazine-article-rail nav a:hover { color: var(--navy); font-weight: 600; }
.magazine-topic { color: #65726d; font-family: var(--editorial); font-size: .82rem; }
.magazine-article .article-content { max-width: 800px; }
.magazine-article .article-content p { color: #394a49; font-family: var(--editorial); font-size: 1.12rem; line-height: 1.9; }
.magazine-article .article-content > p:nth-of-type(2)::first-letter { float: left; margin: .08em .12em 0 0; color: var(--navy); font-family: var(--editorial); font-size: 5.7rem; font-weight: 600; line-height: .7; }
.magazine-article .article-lead { margin-bottom: 4rem; padding-bottom: 2.5rem; border-bottom: 1px solid var(--line); color: var(--navy) !important; font-family: var(--editorial); font-size: clamp(1.5rem, 2.5vw, 2.5rem) !important; font-weight: 600; line-height: 1.35 !important; }
.magazine-article .article-content h2 { margin: 5rem 0 1.5rem; font-family: var(--editorial); font-size: clamp(2.4rem, 4vw, 4.8rem); font-weight: 600; line-height: .98; }
.magazine-article .article-content h3 { margin: 3rem 0 1rem; font-family: var(--editorial); font-size: 1.65rem; }
.magazine-article .article-content ul, .magazine-article .article-content ol { margin: 2rem 0 3rem; padding: 2rem 2rem 2rem 3.5rem; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); color: #394a49; font-family: var(--editorial); font-size: 1.05rem; line-height: 1.8; }
.magazine-article .article-content img { display: block; width: min(1000px, calc(100% + 10vw)); max-width: none; height: auto; margin: 3.5rem 0 3.5rem -5vw; }
.magazine-article .article-content a { color: #087b83; text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: .18em; }
.magazine-article .article-content blockquote { margin: 4rem -8vw; padding: 3rem 8vw; border: 0; background: var(--navy); color: var(--white); font-family: var(--editorial); font-size: clamp(1.8rem, 3vw, 3.5rem); font-weight: 600; line-height: 1.2; }
.magazine-related { padding: 7rem 8vw; border-top: 1px solid rgba(255,255,255,.14); background: var(--navy-deep); color: var(--white); }
.magazine-related header { display: flex; align-items: end; justify-content: space-between; margin-bottom: 3rem; padding-bottom: 1.5rem; border-bottom: 1px solid rgba(255,255,255,.18); }
.magazine-related h2 { margin: 0; color: var(--white); font-family: var(--editorial); font-size: clamp(2.7rem, 5vw, 5.5rem); font-weight: 400; }
.magazine-related > div { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.magazine-related a { display: flex; flex-direction: column; }
.magazine-related img { width: 100%; aspect-ratio: 1.45; margin-bottom: 1.3rem; object-fit: cover; filter: saturate(.65); transition: filter .3s ease; }
.magazine-related a:hover img { filter: saturate(1); }
.magazine-related h3 { margin: .8rem 0 1.5rem; color: var(--white); font-family: var(--editorial); font-size: 1.6rem; font-weight: 600; }
.magazine-related b { margin-top: auto; color: var(--mint); font-family: var(--head); font-size: .6rem; letter-spacing: .1em; text-transform: uppercase; }

.home-news { display: grid; grid-template-columns: 1fr 1.6fr; gap: 7vw; padding: 7rem 8vw; background: var(--navy); color: var(--white); }
.home-news h2 { margin: 1rem 0; color: var(--white); }
.home-news p { color: rgba(255,255,255,.62); }
.home-news-list { border-top: 1px solid rgba(255,255,255,.16); }
.home-news-list a { display: grid; grid-template-columns: 1fr auto; gap: .6rem 1rem; padding: 1.5rem 0; border-bottom: 1px solid rgba(255,255,255,.16); }
.home-news-list small { grid-column: 1 / -1; color: var(--teal); font-family: var(--head); font-size: .6rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.home-news-list span { font-family: var(--head); font-size: .95rem; font-weight: 700; }
.home-news-list b { color: var(--teal); }

.contact-band { display: flex; align-items: center; justify-content: space-between; padding: 6rem 8vw; background: var(--teal); color: var(--navy-deep); }
.contact-band h2 { margin: 1rem 0 0; color: var(--navy-deep); }
.contact-band .eyebrow { color: var(--navy-deep); }
.circle-link { display: flex; width: 170px; height: 170px; align-items: center; justify-content: center; gap: 1rem; border: 1px solid var(--navy-deep); border-radius: 50%; font-family: var(--head); font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; transition: .2s ease; }
.circle-link:hover { background: var(--navy-deep); color: var(--white); }
.circle-link b { font-size: 1.2rem; }
.site-footer { display: grid; grid-template-columns: minmax(220px, 1.8fr) repeat(5, minmax(120px, 1fr)); gap: 2.2rem; padding: 5rem 8vw 2rem; background: var(--navy-deep); color: rgba(255,255,255,.7); font-size: .84rem; }
.site-footer .brand-logo { width: 175px; }
.site-footer p { margin-top: 1.5rem; }
.site-footer > div:not(.footer-brand):not(.footer-bottom) { display: flex; flex-direction: column; gap: .65rem; }
.footer-label { margin-bottom: .7rem; color: var(--mint); }
.footer-bottom { display: flex; grid-column: 1 / -1; justify-content: space-between; margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,.14); color: rgba(255,255,255,.58); font-size: .72rem; }

.breadcrumb { display: flex; gap: .6rem; padding: .8rem 8vw; background: var(--navy-deep); color: rgba(255,255,255,.58); font-size: .65rem; letter-spacing: .06em; }
.breadcrumb a:hover { color: var(--white); }
.page-hero { min-height: 620px; display: flex; align-items: flex-end; padding: 7rem 8vw 5rem; background: radial-gradient(circle at 78% 42%, var(--tone, #126b8a) 0, var(--navy) 28%, var(--navy-deep) 70%); }
.page-hero.hero-short { min-height: 430px; padding-top: 5rem; padding-bottom: 4rem; }
.page-hero .hero-copy { position: relative; z-index: 2; max-width: 1000px; }
.page-hero h1 { margin: 1rem 0 1.8rem; color: var(--white); }
.page-hero p { max-width: 580px; color: rgba(255,255,255,.7); font-size: 1.05rem; }
.image-hero { min-height: 680px; background: var(--navy-deep); }
.image-hero > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(.92) contrast(1.03); }
.image-hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(3,36,61,.92) 0, rgba(3,36,61,.62) 42%, rgba(3,36,61,.16) 82%), linear-gradient(0deg, rgba(3,36,61,.58), transparent 48%); }
.image-hero::after { opacity: .05; }
.city-image-hero .hero-copy { max-width: 880px; }
.service-hero { position: relative; overflow: hidden; display: grid; min-height: 700px; grid-template-columns: minmax(0, 1.05fr) minmax(380px, .95fr); gap: 5vw; align-items: end; padding: 6rem 8vw; background: linear-gradient(145deg, color-mix(in srgb, var(--tone-active, var(--teal)) 10%, var(--cream)) 0, var(--cream) 58%); color: var(--navy); }
.service-hero::before { position: absolute; width: 52vw; height: 52vw; right: -24vw; top: -28vw; border: 1px solid color-mix(in srgb, var(--tone-active, var(--teal)) 28%, transparent); border-radius: 50%; box-shadow: 0 0 0 60px color-mix(in srgb, var(--tone-active, var(--teal)) 8%, transparent), 0 0 0 120px color-mix(in srgb, var(--tone-active, var(--teal)) 5%, transparent); content: ""; }
.service-hero .hero-copy { position: relative; z-index: 2; padding-bottom: 2rem; }
.service-hero h1 { margin: 1rem 0 1.6rem; font-size: clamp(3.2rem, 6.8vw, 7.2rem); }
.service-hero h1 em { color: var(--tone-active, var(--teal)); }
.service-hero p { max-width: 620px; color: #516268; font-size: 1.08rem; }
.service-hero-main, .service-hero-accent { position: relative; z-index: 2; overflow: hidden; margin: 0; background: var(--navy); }
.service-hero-main { min-height: 520px; align-self: stretch; }
.service-hero-accent { position: absolute; right: 8vw; bottom: 4rem; width: min(22vw, 300px); aspect-ratio: 1.12; border: 10px solid color-mix(in srgb, var(--tone-active, var(--teal)) 18%, var(--cream)); box-shadow: 0 24px 50px rgba(8,45,77,.18); }
.service-hero img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.86); }
.contact-hero { position: relative; overflow: hidden; display: grid; min-height: 520px; grid-template-columns: minmax(0, 1.5fr) minmax(320px, .72fr); gap: 6vw; align-items: end; padding: 6rem 8vw 5rem; background: var(--green); color: var(--white); }
.contact-hero::before { position: absolute; inset: 0; opacity: .18; background-image: linear-gradient(120deg, transparent 0 44%, rgba(255,255,255,.18) 44% 45%, transparent 45% 100%), repeating-linear-gradient(0deg, transparent 0 58px, rgba(255,255,255,.12) 59px, transparent 60px); content: ""; }
.contact-hero .hero-copy, .contact-hero-card { position: relative; z-index: 2; }
.contact-hero h1 { margin: 1rem 0 1.4rem; color: var(--white); }
.contact-hero p { max-width: 560px; color: rgba(255,255,255,.78); font-size: 1.05rem; }
.contact-hero .eyebrow { color: var(--white); }
.contact-hero-card { display: flex; flex-direction: column; gap: .85rem; padding: 2rem; border: 1px solid rgba(255,255,255,.28); background: rgba(3,36,61,.28); backdrop-filter: blur(10px); }
.contact-hero-card address { color: var(--white); font-style: normal; font-family: var(--head); font-size: 1rem; font-weight: 700; line-height: 1.5; }
.contact-hero-card a { color: var(--mint); font-family: var(--head); font-size: .82rem; font-weight: 700; }
.contact-hero-card p { margin: .4rem 0 0; font-size: .84rem; }
.hero-orbit { position: absolute; border: 1px solid rgba(255,255,255,.16); border-radius: 50%; }
.orbit-one { width: 500px; height: 500px; right: -120px; top: 60px; box-shadow: 0 0 0 60px rgba(255,255,255,.025), 0 0 0 120px rgba(255,255,255,.018); }
.orbit-two { width: 18px; height: 18px; right: 22%; top: 38%; background: var(--teal); box-shadow: 0 0 0 15px rgba(76,180,154,.12); border: 0; }
.hero-scroll { position: absolute; z-index: 2; right: 3vw; bottom: 4rem; display: flex; flex-direction: column; align-items: center; gap: .8rem; color: rgba(255,255,255,.5); font-family: var(--head); font-size: .55rem; letter-spacing: .15em; text-transform: uppercase; writing-mode: vertical-rl; }
.hero-scroll span { width: 1px; height: 60px; background: var(--teal); }
.service-photo { display: grid; grid-template-columns: 2fr 1fr; min-height: 480px; background: var(--navy-deep); color: var(--white); }
.service-photo > img { width: 100%; height: 100%; min-height: 480px; object-fit: cover; filter: saturate(.75); }
.service-photo > div { position: relative; overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end; padding: 4rem; }
.service-photo > div::before { position: absolute; width: 320px; height: 320px; top: -160px; right: -160px; border: 1px solid rgba(167,220,203,.2); border-radius: 50%; box-shadow: 0 0 0 45px rgba(167,220,203,.04), 0 0 0 90px rgba(167,220,203,.025); content: ""; }
.service-photo p { max-width: 360px; margin: 1rem 0 2rem; color: rgba(255,255,255,.66); }
.service-photo svg { width: 64px; height: 64px; fill: none; stroke: var(--teal); stroke-width: 1.1; stroke-linecap: round; stroke-linejoin: round; }
.service-photo.compact { min-height: 360px; }.service-photo.compact > img { min-height: 360px; }
.service-system-section { position: relative; overflow: hidden; padding: 5.5rem 8vw 6.5rem; background: linear-gradient(180deg, var(--white) 0, #fbfaf6 100%); }
.service-system-section::before { position: absolute; top: -180px; right: -120px; width: 620px; height: 620px; border: 1px solid color-mix(in srgb, var(--tone-active, var(--teal)) 22%, transparent); border-radius: 48% 52% 46% 54%; box-shadow: 0 0 0 34px color-mix(in srgb, var(--tone-active, var(--teal)) 7%, transparent), 0 0 0 72px color-mix(in srgb, var(--tone-active, var(--teal)) 5%, transparent), 0 0 0 116px color-mix(in srgb, var(--tone-active, var(--teal)) 4%, transparent); content: ""; transform: rotate(-12deg); }
.service-system-section > header { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(220px, .45fr) minmax(0, .9fr); gap: 7vw; align-items: start; margin-bottom: 3rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--line); }
.service-system-section > header h2 { max-width: 820px; margin: .8rem 0 0; font-size: clamp(1.7rem, 2.7vw, 3.15rem); letter-spacing: -.035em; }
.service-system-section > header p { max-width: 540px; margin-top: 4.5rem; color: #58686d; font-size: .98rem; line-height: 1.75; }
.service-system-layout { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(260px, .42fr) minmax(0, 1fr); gap: 2rem; align-items: start; }
.service-knowledge-panel { position: sticky; top: 2rem; overflow: hidden; padding: 1.5rem; border: 1px solid color-mix(in srgb, var(--tone-active, var(--mint)) 35%, transparent); background: var(--navy-deep); color: var(--white); }
.service-knowledge-panel::before { position: absolute; inset: auto -20% -42% -20%; height: 58%; background: repeating-radial-gradient(ellipse at 50% 10%, transparent 0, transparent 20px, color-mix(in srgb, var(--tone-active, var(--mint)) 24%, transparent) 21px, transparent 22px); content: ""; opacity: .42; }
.service-knowledge-panel > span { position: relative; z-index: 1; display: grid; width: 58px; height: 58px; place-items: center; margin-bottom: 2.5rem; border: 1px solid color-mix(in srgb, var(--tone-active, var(--mint)) 70%, var(--white)); border-radius: 50%; color: color-mix(in srgb, var(--tone-active, var(--mint)) 70%, var(--white)); }
.service-knowledge-panel svg { width: 30px; height: 30px; fill: none; stroke: currentColor; stroke-width: 1.35; stroke-linecap: round; stroke-linejoin: round; }
.service-knowledge-panel h3, .service-knowledge-panel p, .service-knowledge-panel ul { position: relative; z-index: 1; }
.service-knowledge-panel h3 { margin-bottom: .8rem; color: var(--white); font-size: 1.35rem; }
.service-knowledge-panel p { color: rgba(255,255,255,.66); font-size: .88rem; line-height: 1.65; }
.service-knowledge-panel ul { margin: 2rem 0 0; padding: 0; list-style: none; }
.service-knowledge-panel li { padding: .8rem 0; border-top: 1px solid rgba(255,255,255,.16); color: color-mix(in srgb, var(--tone-active, var(--mint)) 70%, var(--white)); font-family: var(--head); font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.service-component-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.service-component-grid article { position: relative; overflow: hidden; min-height: 330px; padding: 1.7rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--white); }
.service-component-grid article::before { position: absolute; top: 0; right: 0; left: 0; height: 5px; background: var(--tone-active, var(--teal)); content: ""; }
.service-component-grid article:nth-child(2)::before, .service-component-grid article:nth-child(3)::before, .service-component-grid article:nth-child(4)::before { background: var(--tone-active, var(--teal)); }
.service-component-grid article::after { position: absolute; right: -70px; bottom: -70px; width: 150px; height: 150px; border: 1px solid rgba(8,45,77,.08); border-radius: 50%; box-shadow: 0 0 0 22px rgba(8,45,77,.025); content: ""; }
.service-component-grid article > span { position: relative; z-index: 1; color: var(--tone-active, var(--teal)); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .1em; }
.service-component-grid h3 { margin: 3rem 0 1rem; font-size: clamp(1.25rem, 1.8vw, 2rem); letter-spacing: -.03em; }
.service-component-grid p { color: #5d6b70; font-size: .9rem; line-height: 1.65; }
.service-component-grid ul { display: flex; flex-wrap: wrap; gap: .45rem; margin: 1.5rem 0 0; padding: 0; list-style: none; }
.service-component-grid li { position: relative; z-index: 1; padding: .38rem .6rem; border: 1px solid color-mix(in srgb, var(--tone-active, var(--teal)) 28%, transparent); background: color-mix(in srgb, var(--tone-active, var(--teal)) 14%, var(--white)); color: var(--navy); font-size: .72rem; }
.service-expertise-section { position: relative; overflow: hidden; padding: 4.6rem 8vw 5.5rem; background: var(--cream); }
.service-expertise-section::before { position: absolute; inset: 0; background-image: linear-gradient(90deg, rgba(8,45,77,.055) 1px, transparent 1px), linear-gradient(0deg, rgba(8,45,77,.045) 1px, transparent 1px); background-size: 72px 72px; content: ""; opacity: .45; pointer-events: none; }
.service-expertise-section::after { position: absolute; right: -140px; bottom: -180px; width: 460px; height: 460px; border: 1px solid color-mix(in srgb, var(--tone-active, var(--teal)) 22%, transparent); border-radius: 50%; box-shadow: 0 0 0 42px color-mix(in srgb, var(--tone-active, var(--teal)) 7%, transparent), 0 0 0 86px color-mix(in srgb, var(--tone-active, var(--teal)) 5%, transparent); content: ""; }
.service-expertise-section header { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(260px, .55fr) minmax(0, 1fr); gap: 7vw; align-items: end; margin-bottom: 2.2rem; }
.service-expertise-section h2 { margin: 1rem 0 0; font-size: clamp(1.9rem, 3.2vw, 3.7rem); }
.service-expertise-section header p { max-width: 520px; color: #5f6d72; line-height: 1.72; }
.expertise-map { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); border-top: 1px solid var(--line); border-left: 1px solid var(--line); background: rgba(255,255,255,.55); backdrop-filter: blur(8px); }
.expertise-map article { min-height: 300px; padding: 1.5rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: rgba(255,255,255,.62); }
.expertise-map article > span { color: var(--tone-active, var(--teal)); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .1em; }
.expertise-map h3 { margin: 2.8rem 0 1.3rem; font-size: 1rem; letter-spacing: .08em; text-transform: uppercase; }
.expertise-map ul { margin: 0; padding: 0; list-style: none; }
.expertise-map li { display: grid; grid-template-columns: 1rem 1fr; gap: .55rem; padding: .45rem 0; color: #3d4d52; font-size: .84rem; line-height: 1.35; }
.expertise-map li::before { color: var(--tone-active, var(--teal)); content: "•"; font-family: var(--head); font-weight: 700; }
.expertise-map aside { display: flex; min-height: 300px; flex-direction: column; justify-content: flex-end; padding: 1.5rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--navy-deep); color: var(--white); }
.expertise-map aside strong { color: var(--mint); font-family: var(--head); font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; }
.expertise-map aside p { margin: 1rem 0 0; color: rgba(255,255,255,.68); font-size: .88rem; line-height: 1.65; }
.service-method-section { position: relative; overflow: hidden; display: grid; grid-template-columns: minmax(260px, .6fr) minmax(0, 1fr); gap: 7vw; padding: 6rem 8vw; background: var(--navy-deep); color: var(--white); }
.service-method-section::before { position: absolute; inset: 0; background-image: linear-gradient(115deg, transparent 0 62%, rgba(31,167,194,.08) 62% 63%, transparent 63%), repeating-linear-gradient(0deg, transparent 0 58px, rgba(255,255,255,.045) 59px, transparent 60px); content: ""; pointer-events: none; }
.service-method-section > div, .service-method-section ol { position: relative; z-index: 1; }
.service-method-section h2 { margin: 1rem 0 0; color: var(--white); font-size: clamp(1.8rem, 3vw, 3.3rem); }
.service-method-section ol { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin: 0; padding: 0; list-style: none; border-left: 1px solid rgba(255,255,255,.16); }
.service-method-section li { min-height: 260px; padding: 1.4rem; border-right: 1px solid rgba(255,255,255,.16); }
.service-method-section li span { color: var(--mint); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .1em; }
.service-method-section h3 { margin: 4rem 0 .8rem; color: var(--white); font-size: 1.1rem; }
.service-method-section p { color: rgba(255,255,255,.62); font-size: .84rem; line-height: 1.6; }
.city-photo { display: grid; grid-template-columns: 1.7fr 1fr; min-height: 480px; background: var(--navy-deep); color: var(--white); }
.city-photo img { width: 100%; height: 100%; min-height: 480px; object-fit: cover; filter: saturate(.8); }
.city-photo > div { position: relative; overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end; padding: 4rem; }
.city-photo > div::before { position: absolute; width: 340px; height: 340px; top: -180px; right: -180px; border: 1px solid rgba(167,220,203,.2); border-radius: 50%; box-shadow: 0 0 0 50px rgba(167,220,203,.035), 0 0 0 100px rgba(167,220,203,.02); content: ""; }
.city-service-photo > div::before { border-color: color-mix(in srgb, var(--tone-active, var(--mint)) 35%, transparent); box-shadow: 0 0 0 50px color-mix(in srgb, var(--tone-active, var(--mint)) 8%, transparent), 0 0 0 100px color-mix(in srgb, var(--tone-active, var(--mint)) 5%, transparent); }
.city-service-photo .eyebrow, .city-service-intro .eyebrow, .city-service-intro .big-index, .city-service-capabilities span { color: var(--tone-active, var(--teal)); }
.city-photo h2 { margin: 1rem 0; color: var(--white); font-size: clamp(2rem, 3.6vw, 4rem); }
.city-photo p { max-width: 380px; color: rgba(255,255,255,.64); }
.city-market-section { position: relative; overflow: hidden; padding: 7rem 8vw; background: var(--white); }
.city-market-section::before { position: absolute; top: -180px; right: -120px; width: 560px; height: 560px; border: 1px solid rgba(18,107,138,.12); border-radius: 50%; box-shadow: 0 0 0 42px rgba(31,167,194,.04), 0 0 0 86px rgba(167,220,203,.04); content: ""; }
.city-market-section > header { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(260px, .55fr) minmax(0, 1fr); gap: 7vw; align-items: end; margin-bottom: 4rem; padding-bottom: 2rem; border-bottom: 1px solid var(--line); }
.city-market-section > header h2 { margin: 1rem 0 0; font-size: clamp(2rem, 3.8vw, 4.4rem); }
.city-market-section > header p { max-width: 620px; color: #5c6b70; font-size: 1rem; line-height: 1.75; }
.city-market-layout { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(280px, .62fr) minmax(0, 1fr); gap: 2rem; align-items: stretch; }
.city-market-read { min-height: 760px; padding: 2rem; background: var(--navy-deep); color: var(--white); }
.city-market-read .eyebrow { color: var(--mint); }
.city-market-read h3 { margin: 1rem 0 1.2rem; color: var(--white); font-size: clamp(1.7rem, 2.3vw, 2.65rem); }
.city-market-read p { color: rgba(255,255,255,.68); line-height: 1.75; }
.city-market-read .city-market-tags { display: flex; flex-wrap: wrap; gap: .55rem; margin-top: 2rem; }
.city-market-read .city-market-tags span { padding: .48rem .65rem; border: 1px solid rgba(167,220,203,.32); color: var(--mint); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.city-data-panel { display: grid; grid-template-rows: auto auto 1fr; gap: 1rem; }
.city-infra-card { margin-top: 1rem; padding: 1.4rem; border: 1px solid rgba(167,220,203,.2); background: rgba(255,255,255,.045); }
.city-infra-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .6rem; margin-top: 1.1rem; }
.city-infra-grid span { display: flex; min-height: 96px; min-width: 0; flex-direction: column; justify-content: space-between; padding: .8rem; border: 1px solid var(--line); background: var(--cream); color: #788489; }
.city-infra-grid span.is-active { border-color: rgba(18,107,138,.32); background: linear-gradient(145deg, rgba(31,167,194,.13), var(--white)); color: var(--navy); }
.city-market-read .city-infra-grid span { border-color: rgba(255,255,255,.12); background: rgba(255,255,255,.035); color: rgba(255,255,255,.58); }
.city-market-read .city-infra-grid span.is-active { border-color: rgba(167,220,203,.35); background: rgba(167,220,203,.1); color: var(--mint); }
.city-infra-grid svg { width: 30px; height: 30px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.city-infra-grid b { color: inherit; font-family: var(--head); font-size: .7rem; letter-spacing: .06em; text-transform: uppercase; }
.city-infra-grid small { color: #728086; font-size: .68rem; line-height: 1.2; }
.city-market-read .city-infra-grid small { color: rgba(255,255,255,.58); }
.city-infra-card p { margin: 1rem 0 0; color: rgba(255,255,255,.58); font-size: .78rem; line-height: 1.55; }
.city-chart-card { padding: 2rem; border: 1px solid var(--line); background: var(--cream); }
.city-chart-card > .eyebrow { margin-bottom: 1.5rem; }
.city-chart-card h4 { margin: 1.8rem 0 .9rem; padding-top: 1rem; border-top: 1px solid var(--line); color: var(--teal); font-family: var(--head); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; }
.city-chart-card > .eyebrow + h4 { margin-top: 0; padding-top: 0; border-top: 0; }
.city-bar + .city-bar { margin-top: 1rem; }
.city-bar > div { display: flex; justify-content: space-between; margin-bottom: .45rem; color: var(--navy); font-family: var(--head); font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.city-bar b { color: var(--teal); }
.city-bar i { display: block; height: 10px; background: linear-gradient(90deg, var(--teal) 0 var(--bar), rgba(8,45,77,.1) var(--bar) 100%); }
.city-chart-card p { margin: 1.6rem 0 0; color: #647278; font-size: .82rem; line-height: 1.6; }
.city-land-use-card { padding: 1.7rem 2rem; border: 1px solid var(--line); background: var(--navy-deep); color: var(--white); }
.city-land-use-card h3 { margin: .7rem 0; color: var(--white); font-size: clamp(1.25rem, 1.8vw, 1.8rem); }
.city-land-use-card p { margin: 0; color: rgba(255,255,255,.64); font-size: .84rem; line-height: 1.6; }
.city-resource-grid { display: grid; grid-template-columns: repeat(2, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.city-resource-grid a { position: relative; min-height: 170px; padding: 1.3rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--white); }
.city-resource-grid strong { display: block; max-width: 230px; color: var(--navy); font-family: var(--head); font-size: .92rem; line-height: 1.25; }
.city-resource-grid span { display: block; margin-top: 1rem; color: #647278; font-size: .78rem; line-height: 1.5; }
.city-resource-grid b { position: absolute; right: 1rem; top: 1rem; color: var(--teal); }
.detail-intro { display: grid; grid-template-columns: .3fr 1.5fr 1fr; gap: 5vw; padding: 8rem 8vw; background: var(--white); }
.detail-intro h2 { margin: .8rem 0 0; font-size: clamp(2rem, 3.6vw, 4rem); }
.detail-intro p { color: #617078; }
.capability-grid { display: grid; grid-template-columns: repeat(4, 1fr); padding: 0 8vw 8rem; background: var(--white); }
.capability-grid article { min-height: 280px; padding: 2rem; border: solid var(--line); border-width: 1px 1px 1px 0; }
.capability-grid article:first-child { border-left-width: 1px; }
.capability-grid span { color: var(--teal); font-family: var(--head); font-size: .68rem; font-weight: 700; }
.capability-grid h3 { margin-top: 5rem; }
.capability-grid p { color: #69777d; font-size: .86rem; }
.offering-section { padding: 8rem 8vw; background: var(--cream); }
.offering-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.offering-grid a { position: relative; overflow: hidden; display: flex; min-height: 300px; flex-direction: column; padding: 2rem; border: 1px solid color-mix(in srgb, var(--tone-active, var(--teal)) 20%, var(--line)); background: linear-gradient(145deg, color-mix(in srgb, var(--tone-active, var(--teal)) 8%, var(--white)) 0, var(--white) 62%); transition: transform .2s ease, box-shadow .2s ease; }
.offering-grid a::before { position: absolute; top: 0; right: 0; left: 0; height: 5px; background: var(--tone-active, var(--teal)); content: ""; }
.offering-grid i { color: var(--tone-active, var(--teal)); }
.offering-grid a:hover { transform: translateY(-4px); box-shadow: 0 16px 32px rgba(8,45,77,.1); }
.offering-grid h3 { margin: 3.5rem 0 1rem; font-size: clamp(1.35rem, 2vw, 2rem); }
.offering-grid p { color: #647278; font-size: .88rem; }
.offering-grid b { display: flex; justify-content: space-between; margin-top: auto; padding-top: 1.2rem; border-top: 1px solid var(--line); color: var(--navy); font-family: var(--head); font-size: .65rem; letter-spacing: .08em; text-transform: uppercase; }
.offering-grid i { font-size: 1rem; font-style: normal; }
.related-services { display: grid; grid-template-columns: 1fr 1.5fr; gap: 7vw; padding: 7rem 8vw; background: var(--navy-deep); color: var(--white); }
.related-services h2 { margin: 1rem 0 2rem; color: var(--white); }
.related-list { border-top: 1px solid rgba(255,255,255,.16); }
.related-list a { display: flex; align-items: center; justify-content: space-between; padding: 1.4rem 0; border-bottom: 1px solid rgba(255,255,255,.16); color: rgba(255,255,255,.82); font-family: var(--head); font-size: .86rem; font-weight: 700; }
.related-services { border-top: 6px solid var(--tone-active, var(--teal)); }
.related-list b { color: var(--tone-active, var(--teal)); }
.process-strip { padding: 7rem 8vw; background: var(--navy); color: var(--white); }
.process-strip > div { display: grid; grid-template-columns: repeat(4, 1fr); margin-top: 3rem; }
.process-strip article { padding: 1.8rem; border-left: 1px solid rgba(255,255,255,.15); }
.process-strip b { color: var(--teal); font-family: var(--head); font-size: .7rem; }
.process-strip h3 { margin-top: 4rem; color: var(--white); }
.process-strip p { color: rgba(255,255,255,.58); font-size: .85rem; }
.directory { background: var(--white); }
.directory-list { margin-top: 2rem; border-top: 1px solid var(--line); }
.directory-list a { display: grid; grid-template-columns: 1fr 2fr auto; gap: 2rem; align-items: center; padding: 2rem 0; border-bottom: 1px solid var(--line); transition: padding .2s ease; }
.directory-list a:hover { padding-right: 1rem; padding-left: 1rem; background: var(--cream); }
.directory-list span { color: var(--navy); font-family: var(--head); font-size: clamp(1.2rem, 2.3vw, 2.4rem); font-weight: 700; }
.directory-list small { color: #647278; font-size: .9rem; }
.directory-list b { color: var(--teal); }
.city-directory { padding: 8rem 8vw; background: var(--white); }
.city-directory > section + section { margin-top: 7rem; }
.city-directory header { display: grid; grid-template-columns: .7fr 2fr; gap: 4vw; align-items: end; margin-bottom: 2.5rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--line); }
.city-directory header h2 { margin: 0; font-size: clamp(1.7rem, 3vw, 3.2rem); }
.city-card-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.city-card { overflow: hidden; border: 1px solid var(--line); background: var(--cream); transition: transform .2s ease, box-shadow .2s ease; }
.city-card:hover { transform: translateY(-4px); box-shadow: 0 16px 30px rgba(8,45,77,.1); }
.city-card img { display: block; width: 100%; aspect-ratio: 1.35; object-fit: cover; filter: saturate(.8); transition: filter .2s ease, transform .3s ease; }
.city-card:hover img { filter: saturate(1); transform: scale(1.02); }
.city-card > div { display: grid; grid-template-columns: 1fr auto; gap: .3rem 1rem; padding: 1.2rem; }
.city-card span { color: var(--navy); font-family: var(--head); font-size: .9rem; font-weight: 700; }
.city-card small { color: #68777d; font-size: .7rem; }
.city-card b { grid-row: 1 / 3; grid-column: 2; color: var(--teal); }
.industry-hero { --tone-active: var(--tone, var(--teal)); display: grid; min-height: 650px; grid-template-columns: 1fr 1fr; background: linear-gradient(145deg, color-mix(in srgb, var(--tone-active) 12%, var(--cream)), var(--cream)); }
.industry-hero-copy { position: relative; overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end; padding: 6rem 4vw 5rem 8vw; }
.industry-hero-copy::after { position: absolute; width: 440px; height: 440px; top: -220px; left: -220px; border: 1px solid color-mix(in srgb, var(--tone-active) 28%, transparent); border-radius: 50%; box-shadow: 0 0 0 45px color-mix(in srgb, var(--tone-active) 7%, transparent), 0 0 0 90px color-mix(in srgb, var(--tone-active) 4%, transparent); content: ""; }
.industry-hero h1 { position: relative; z-index: 1; margin: 1rem 0 1.7rem; font-size: clamp(3rem, 5.9vw, 6.5rem); }
.industry-hero h1 em { color: var(--tone-active); }
.industry-hero-copy p { position: relative; z-index: 1; max-width: 580px; color: #52636a; font-size: 1.05rem; }
.industry-hero figure { position: relative; overflow: hidden; margin: 0; background: var(--navy-deep); }
.industry-hero figure::after { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(3,36,61,.68), transparent 50%); content: ""; }
.industry-hero figure img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.75); }
.industry-hero figcaption { position: absolute; z-index: 1; right: 2rem; bottom: 2rem; left: 2rem; display: flex; justify-content: space-between; padding-top: 1rem; border-top: 1px solid rgba(255,255,255,.45); color: var(--white); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.industry-hero figcaption span { color: color-mix(in srgb, var(--tone-active) 65%, var(--white)); }
.industry-position { display: grid; grid-template-columns: .25fr 1.05fr .8fr; gap: 5vw; padding: 7rem 8vw; background: var(--white); }
.industry-position h2 { margin: 1rem 0 0; font-size: clamp(2rem, 3.5vw, 3.8rem); }
.industry-position > div:last-child > p { color: #56666c; font-size: 1rem; line-height: 1.75; }
.industry-operator-list { display: flex; flex-wrap: wrap; gap: .45rem; margin-top: 1.5rem; }
.industry-operator-list span { padding: .45rem .6rem; border: 1px solid var(--line); color: var(--navy); font-family: var(--head); font-size: .65rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
.industry-cycle { --tone-active: var(--tone, var(--teal)); padding: 6rem 8vw; background: var(--navy-deep); color: var(--white); }
.industry-cycle header { display: grid; grid-template-columns: 1fr .7fr; gap: 7vw; align-items: end; margin-bottom: 3rem; }
.industry-cycle h2 { margin: 1rem 0 0; color: var(--white); font-size: clamp(2rem, 3.4vw, 3.7rem); }
.industry-cycle header p { color: rgba(255,255,255,.62); line-height: 1.7; }
.industry-cycle ol { display: grid; grid-template-columns: repeat(6, 1fr); margin: 0; padding: 0; border-top: 1px solid rgba(255,255,255,.18); border-left: 1px solid rgba(255,255,255,.18); list-style: none; }
.industry-cycle li { min-height: 250px; padding: 1.2rem; border-right: 1px solid rgba(255,255,255,.18); border-bottom: 1px solid rgba(255,255,255,.18); }
.industry-cycle li > span { color: color-mix(in srgb, var(--tone-active) 68%, var(--white)); font-family: var(--head); font-size: .65rem; font-weight: 700; }
.industry-cycle li h3 { margin: 4rem 0 .8rem; color: var(--white); font-size: 1rem; }
.industry-cycle li p { color: rgba(255,255,255,.56); font-size: .78rem; line-height: 1.55; }
.industry-operations { padding: 7rem 8vw; background: var(--cream); }
.industry-operations > header { display: grid; grid-template-columns: .45fr 1fr; gap: 5vw; align-items: start; margin-bottom: 3rem; padding-bottom: 2rem; border-bottom: 1px solid var(--line); }
.industry-operations > header h2 { max-width: 900px; margin: 0; font-size: clamp(2rem, 3.4vw, 3.7rem); }
.industry-operations-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.industry-operations-grid article { min-height: 360px; padding: 1.7rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--white); }
.industry-operations-grid ul { margin: 3rem 0 0; padding: 0; list-style: none; }
.industry-operations-grid li { display: grid; grid-template-columns: 1rem 1fr; gap: .6rem; padding: .8rem 0; border-top: 1px solid var(--line); color: #506168; font-size: .88rem; }
.industry-operations-grid li::before { color: var(--teal); content: "✓"; font-weight: 700; }
.industry-workforce { display: grid; grid-template-columns: 1fr .8fr; gap: 8vw; padding: 7rem 8vw; background: var(--green); color: var(--white); }
.industry-workforce h2 { margin: 1rem 0 0; color: var(--white); font-size: clamp(2.1rem, 4vw, 4.4rem); }
.industry-workforce p { color: rgba(255,255,255,.76); line-height: 1.75; }
.industry-services { --tone-active: var(--tone, var(--teal)); padding: 7rem 8vw; background: var(--white); }
.industry-services > header { display: grid; grid-template-columns: 1fr .7fr; gap: 7vw; align-items: end; margin-bottom: 3rem; }
.industry-services > header h2 { margin: 1rem 0 0; font-size: clamp(2rem, 3.4vw, 3.7rem); }
.industry-services > header p { color: #596970; line-height: 1.7; }
.industry-services > div { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.industry-services a { display: flex; min-height: 340px; flex-direction: column; padding: 1.5rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: linear-gradient(145deg, color-mix(in srgb, var(--tone-active) 8%, var(--white)), var(--white) 65%); }
.industry-services a > span { display: grid; width: 48px; height: 48px; place-items: center; border: 1px solid color-mix(in srgb, var(--tone-active) 45%, transparent); border-radius: 50%; color: var(--tone-active); }
.industry-services svg { width: 25px; height: 25px; fill: none; stroke: currentColor; stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; }
.industry-services h3 { margin: 3rem 0 1rem; font-size: 1.15rem; }
.industry-services p { color: #617077; font-size: .83rem; line-height: 1.6; }
.industry-services b { display: flex; justify-content: space-between; margin-top: auto; padding-top: 1rem; border-top: 1px solid var(--line); color: var(--navy); font-family: var(--head); font-size: .62rem; letter-spacing: .07em; text-transform: uppercase; }
.industry-services i { color: var(--tone-active); font-size: 1rem; font-style: normal; }
.industry-cta { display: grid; grid-template-columns: 1fr .75fr; gap: 8vw; padding: 6rem 8vw; background: var(--navy); color: var(--white); }
.industry-cta h2 { margin: 1rem 0 0; color: var(--white); font-size: clamp(2rem, 4vw, 4.4rem); }
.industry-cta p { color: rgba(255,255,255,.68); line-height: 1.7; }
.industry-cta .button { margin-top: 1.5rem; }
.industry-directory { padding: 7rem 8vw; background: var(--white); }
.industry-directory > section + section { margin-top: 5rem; }
.industry-directory > section > header { display: flex; align-items: end; justify-content: space-between; margin-bottom: 1.5rem; padding-bottom: 1rem; border-bottom: 1px solid var(--line); }
.industry-directory > section > header p { margin: 0; color: #69777d; font-size: .75rem; }
.industry-directory > section > div { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.industry-directory a { --tone-active: var(--tone, var(--teal)); position: relative; display: flex; min-height: 280px; flex-direction: column; padding: 1.6rem; border: 1px solid color-mix(in srgb, var(--tone-active) 26%, var(--line)); background: linear-gradient(145deg, color-mix(in srgb, var(--tone-active) 11%, var(--white)), var(--white) 60%); }
.industry-directory a::before { position: absolute; top: 0; right: 0; left: 0; height: 5px; background: var(--tone-active); content: ""; }
.industry-directory a > span { color: var(--navy); font-family: var(--head); font-size: 1.35rem; font-weight: 700; line-height: 1.15; }
.industry-directory a p { color: #617077; font-size: .86rem; line-height: 1.6; }
.industry-directory a b { display: flex; justify-content: space-between; margin-top: auto; padding-top: 1rem; border-top: 1px solid var(--line); color: var(--navy); font-family: var(--head); font-size: .62rem; letter-spacing: .07em; text-transform: uppercase; }
.industry-directory a i { color: var(--tone-active); font-size: 1rem; font-style: normal; }
.product-mark { display: grid; width: 54px; height: 54px; place-items: center; border: 1px solid currentColor; color: var(--tone-active, var(--teal)); font-family: var(--head); font-size: .75rem; font-weight: 700; letter-spacing: .08em; }
.product-directory-intro { display: grid; grid-template-columns: .25fr 1.15fr .7fr; gap: 5vw; padding: 7rem 8vw; background: var(--white); }
.product-directory-intro h2 { margin: 1rem 0 0; font-size: clamp(2rem, 3.6vw, 4rem); }
.product-directory-intro > p { color: #596970; line-height: 1.75; }
.product-directory { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; padding: 0 8vw 7rem; background: var(--white); }
.product-card { --tone-active: var(--tone, var(--teal)); display: grid; grid-template-rows: 1fr auto; min-height: 430px; border: 1px solid color-mix(in srgb, var(--tone-active) 28%, var(--line)); background: linear-gradient(145deg, color-mix(in srgb, var(--tone-active) 10%, var(--white)), var(--white) 58%); }
.product-card:first-child { grid-column: 1 / -1; min-height: 500px; }
.product-card-main { position: relative; display: grid; grid-template-columns: 90px 1fr; gap: 2rem; padding: 2rem; }
.product-card-main::before { position: absolute; top: 0; right: 0; left: 0; height: 6px; background: var(--tone-active); content: ""; }
.product-card-main h2 { margin: .7rem 0 1rem; font-size: clamp(2rem, 4vw, 4.2rem); }
.product-card:not(:first-child) .product-card-main h2 { font-size: clamp(1.8rem, 2.8vw, 3rem); }
.product-card-main p { max-width: 650px; color: #5c6c72; }
.product-card-main > b { grid-column: 2; align-self: end; display: flex; justify-content: space-between; padding-top: 1rem; border-top: 1px solid var(--line); color: var(--navy); font-family: var(--head); font-size: .65rem; letter-spacing: .08em; text-transform: uppercase; }
.product-card-main i { color: var(--tone-active); font-size: 1rem; font-style: normal; }
.product-card footer { display: flex; justify-content: space-between; padding: 1rem 2rem; border-top: 1px solid var(--line); color: #69777c; font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.product-card footer a { color: var(--tone-active); }
.product-hero { --tone-active: var(--tone, var(--teal)); display: grid; min-height: 720px; grid-template-columns: 1fr 1fr; background: linear-gradient(145deg, color-mix(in srgb, var(--tone-active) 10%, var(--cream)), var(--cream)); }
.product-hero-copy { position: relative; overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end; padding: 5rem 5vw 5rem 8vw; }
.product-hero-copy::after { position: absolute; width: 520px; height: 520px; top: -280px; left: -250px; border: 1px solid color-mix(in srgb, var(--tone-active) 35%, transparent); border-radius: 50%; box-shadow: 0 0 0 50px color-mix(in srgb, var(--tone-active) 7%, transparent), 0 0 0 100px color-mix(in srgb, var(--tone-active) 4%, transparent); content: ""; }
.product-status { position: absolute; z-index: 1; top: 3rem; right: 3rem; left: 8vw; display: flex; justify-content: space-between; padding-bottom: .8rem; border-bottom: 1px solid color-mix(in srgb, var(--tone-active) 35%, var(--line)); color: var(--navy); font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.product-status span:first-child { color: var(--tone-active); }
.product-mark-large { position: relative; z-index: 1; width: 76px; height: 76px; margin-bottom: 2rem; font-size: 1rem; }
.product-hero h1 { position: relative; z-index: 1; margin: 0 0 1.5rem; font-size: clamp(4rem, 8vw, 8rem); }
.product-hero-copy > p { position: relative; z-index: 1; max-width: 650px; color: #53646b; font-size: 1.05rem; }
.product-hero-copy .button { position: relative; z-index: 1; align-self: flex-start; margin-top: 1.5rem; }
.product-hero figure { position: relative; overflow: hidden; margin: 0; background: var(--navy-deep); }
.product-hero figure::after { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(3,36,61,.72), transparent 55%); content: ""; }
.product-hero figure img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.7) contrast(1.05); }
.product-hero figcaption { position: absolute; z-index: 1; right: 2rem; bottom: 2rem; left: 2rem; display: flex; justify-content: space-between; padding-top: 1rem; border-top: 1px solid rgba(255,255,255,.4); color: rgba(255,255,255,.72); font-family: var(--head); font-size: .62rem; letter-spacing: .08em; text-transform: uppercase; }
.product-thesis { display: grid; grid-template-columns: .25fr 1fr .85fr; gap: 5vw; padding: 7rem 8vw; background: var(--white); }
.product-thesis h2 { margin: 1rem 0 0; font-size: clamp(2rem, 3.6vw, 4rem); }
.product-thesis > div:last-child > p { color: #58686e; font-size: 1rem; line-height: 1.75; }
.product-thesis > div:last-child > div { display: flex; flex-wrap: wrap; gap: .45rem; margin-top: 1.5rem; }
.product-thesis > div:last-child span { padding: .42rem .6rem; border: 1px solid var(--line); color: var(--navy); font-family: var(--head); font-size: .64rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
.product-capabilities { --tone-active: var(--tone, var(--teal)); padding: 7rem 8vw; background: var(--cream); }
.product-capabilities > header { display: grid; grid-template-columns: 1fr .7fr; gap: 7vw; align-items: end; margin-bottom: 3rem; }
.product-capabilities h2 { margin: 1rem 0 0; font-size: clamp(2rem, 3.6vw, 4rem); }
.product-capabilities header p { color: #58686e; line-height: 1.7; }
.product-capabilities > div { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.product-capabilities article { min-height: 330px; padding: 1.6rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--white); }
.product-capabilities article > span { color: var(--tone-active); font-family: var(--head); font-size: .65rem; font-weight: 700; }
.product-capabilities h3 { margin: 4rem 0 1rem; font-size: 1.15rem; }
.product-capabilities article p { color: #607078; font-size: .84rem; line-height: 1.65; }
.product-architecture { display: grid; grid-template-columns: .8fr 1.2fr; gap: 7vw; padding: 7rem 8vw; background: var(--navy-deep); color: var(--white); }
.product-architecture h2 { margin: 1rem 0 0; color: var(--white); font-size: clamp(2rem, 3.6vw, 4rem); }
.product-architecture ol { margin: 0; padding: 0; border-top: 1px solid rgba(255,255,255,.18); list-style: none; }
.product-architecture li { display: grid; grid-template-columns: 70px 1fr; padding: 1.6rem 0; border-bottom: 1px solid rgba(255,255,255,.18); }
.product-architecture li span { color: var(--mint); font-family: var(--head); font-size: .65rem; }
.product-architecture li strong { color: var(--white); font-family: var(--head); font-size: 1rem; }
.product-roadmap { --tone-active: var(--tone, var(--teal)); display: grid; grid-template-columns: .65fr 1.35fr; gap: 6vw; padding: 7rem 8vw; background: var(--white); }
.product-roadmap header h2 { margin: 1rem 0; font-size: clamp(2rem, 3.5vw, 3.8rem); }
.product-roadmap header p { color: #5d6d73; line-height: 1.7; }
.product-roadmap > div { display: grid; grid-template-columns: repeat(2, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.product-roadmap article { min-height: 210px; padding: 1.5rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: linear-gradient(145deg, color-mix(in srgb, var(--tone-active) 8%, var(--white)), var(--white)); }
.product-roadmap article > span { color: var(--tone-active); font-family: var(--head); font-size: .65rem; font-weight: 700; }
.product-roadmap h3 { margin-top: 3rem; font-size: 1rem; }
.product-related { padding: 7rem 8vw; background: var(--cream); }
.product-related > header { display: grid; grid-template-columns: .4fr 1fr; gap: 5vw; align-items: start; margin-bottom: 2.5rem; }
.product-related > header h2 { margin: 0; font-size: clamp(2rem, 3.5vw, 3.8rem); }
.product-related > div { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.product-related a { position: relative; display: grid; min-height: 300px; grid-template-columns: 60px 1fr; gap: 1rem; padding: 1.5rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--white); }
.product-related small { color: var(--teal); font-family: var(--head); font-size: .6rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.product-related h3 { margin: .6rem 0 1rem; }
.product-related p { color: #617077; font-size: .82rem; line-height: 1.6; }
.product-related a > b { position: absolute; right: 1.3rem; bottom: 1.1rem; color: var(--teal); }
.product-cta { --tone-active: var(--tone, var(--teal)); display: grid; grid-template-columns: 1fr .8fr; gap: 7vw; padding: 6rem 8vw; background: color-mix(in srgb, var(--tone-active) 72%, var(--navy-deep)); color: var(--white); }
.product-cta h2 { margin: 1rem 0 0; color: var(--white); font-size: clamp(2rem, 4vw, 4.4rem); }
.product-cta p { color: rgba(255,255,255,.74); line-height: 1.7; }
.product-cta .button { margin-top: 1.5rem; }
.about-hero { position: relative; overflow: hidden; min-height: 720px; display: flex; align-items: flex-end; padding: 7rem 8vw 5rem; background: var(--navy-deep); color: var(--white); }
.about-hero > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(.7) contrast(1.05); }
.about-hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(3,36,61,.97) 0, rgba(3,36,61,.78) 46%, rgba(3,36,61,.18) 100%), linear-gradient(0deg, rgba(3,36,61,.7), transparent 55%); }
.about-hero::after { position: absolute; width: 620px; height: 620px; right: -100px; top: 40px; border: 1px solid rgba(167,220,203,.18); border-radius: 50%; box-shadow: 0 0 0 52px rgba(167,220,203,.035), 0 0 0 104px rgba(167,220,203,.025); content: ""; }
.about-hero-copy { position: relative; z-index: 2; max-width: 920px; }
.about-hero h1 { margin: 1rem 0 1.8rem; color: var(--white); }
.about-hero p { max-width: 650px; color: rgba(255,255,255,.74); font-size: 1.08rem; }
.about-hero-note { position: absolute; z-index: 2; right: 4vw; bottom: 4rem; display: flex; flex-direction: column; padding-left: 1rem; border-left: 1px solid var(--teal); color: rgba(255,255,255,.58); font-size: .68rem; letter-spacing: .06em; text-transform: uppercase; }
.about-thesis { display: grid; grid-template-columns: .4fr 1.25fr .65fr; gap: 5vw; padding: 8rem 8vw; background: var(--white); }
.about-thesis > div { display: flex; justify-content: space-between; align-content: start; gap: 1rem; padding-top: 1rem; border-top: 1px solid var(--line); }
.about-thesis h2 { margin-bottom: 1.7rem; font-size: clamp(2rem, 3.6vw, 4rem); }
.about-thesis article p { max-width: 680px; color: #58686e; font-size: 1rem; line-height: 1.75; }
.about-thesis aside { align-self: end; padding: 1.5rem; border-left: 5px solid var(--teal); background: var(--cream); }
.about-thesis aside strong { color: var(--navy); font-family: var(--head); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; }
.about-thesis aside p { margin: 1rem 0 0; color: #58686e; font-size: .88rem; line-height: 1.65; }
.about-system-map { position: relative; overflow: hidden; padding: 7rem 8vw; background: var(--cream); }
.about-system-map::before { position: absolute; inset: 0; opacity: .45; background-image: linear-gradient(90deg, rgba(8,45,77,.05) 1px, transparent 1px), linear-gradient(0deg, rgba(8,45,77,.04) 1px, transparent 1px); background-size: 72px 72px; content: ""; }
.about-system-map > header { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr .7fr; gap: 7vw; align-items: end; margin-bottom: 3rem; }
.about-system-map > header h2 { margin: 1rem 0 0; font-size: clamp(2rem, 3.7vw, 4rem); }
.about-system-map > header p { color: #58686e; line-height: 1.75; }
.about-system-grid { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.about-system-grid article { min-height: 300px; padding: 1.5rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: rgba(255,255,255,.78); }
.about-system-grid article > span { color: var(--teal); font-family: var(--head); font-size: .68rem; font-weight: 700; }
.about-system-grid h3 { margin: 4.5rem 0 1rem; }
.about-system-grid p { color: #5d6c72; font-size: .86rem; line-height: 1.65; }
.about-system-grid aside { grid-column: 1 / -1; display: grid; grid-template-columns: .45fr .7fr 1fr; gap: 3vw; align-items: center; padding: 2rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--navy-deep); color: var(--white); }
.about-system-grid aside h3 { margin: 0; color: var(--white); font-size: clamp(1.4rem, 2.2vw, 2.3rem); }
.about-system-grid aside p { margin: 0; color: rgba(255,255,255,.65); }
.about-commitments { padding: 7rem 8vw; background: var(--white); }
.about-commitments > header { display: grid; grid-template-columns: .45fr 1fr; gap: 5vw; align-items: start; margin-bottom: 3rem; padding-bottom: 2rem; border-bottom: 1px solid var(--line); }
.about-commitments > header h2 { max-width: 850px; margin: 0; font-size: clamp(2rem, 3.5vw, 3.8rem); }
.about-commitments > div { display: grid; grid-template-columns: repeat(6, 1fr); }
.about-commitments article { grid-column: span 2; min-height: 300px; padding: 1.6rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.about-commitments article:nth-child(-n+3) { border-top: 1px solid var(--line); }
.about-commitments article:nth-child(1), .about-commitments article:nth-child(4) { border-left: 1px solid var(--line); }
.about-commitments article:nth-child(4), .about-commitments article:nth-child(5) { grid-column: span 3; }
.about-commitments article > span { color: var(--teal); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.about-commitments h3 { margin: 4rem 0 1rem; font-size: 1.25rem; }
.about-commitments p { color: #637178; font-size: .86rem; line-height: 1.65; }
.about-values { display: grid; grid-template-columns: .7fr 1.3fr; gap: 7vw; padding: 7rem 8vw; background: var(--navy-deep); color: var(--white); }
.about-values header { position: sticky; top: 2rem; align-self: start; }
.about-values h2 { margin: 1rem 0 1.5rem; color: var(--white); font-size: clamp(2rem, 3.8vw, 4.2rem); }
.about-values header p { max-width: 420px; color: rgba(255,255,255,.62); }
.about-values ol { margin: 0; padding: 0; border-top: 1px solid rgba(255,255,255,.18); list-style: none; }
.about-values li { display: grid; grid-template-columns: 80px 1fr; gap: 1.5rem; padding: 2rem 0; border-bottom: 1px solid rgba(255,255,255,.18); }
.about-values li > span { color: var(--mint); font-family: var(--head); font-size: .7rem; font-weight: 700; }
.about-values h3 { margin: 0 0 .7rem; color: var(--white); font-size: 1.5rem; }
.about-values li p { max-width: 620px; margin: 0; color: rgba(255,255,255,.63); line-height: 1.65; }
.about-partnerships { display: grid; grid-template-columns: 1fr .8fr; gap: 7vw; padding: 7rem 8vw; background: var(--green); color: var(--white); }
.about-partnerships h2 { margin: 1rem 0 0; color: var(--white); font-size: clamp(2.2rem, 4.2vw, 4.7rem); }
.about-partnerships p { color: rgba(255,255,255,.76); line-height: 1.75; }
.about-partnerships .button { margin-top: 1.5rem; }
.contact-form-wrap { display: grid; grid-template-columns: .7fr 1.4fr; gap: 4vw; padding: 1rem 8vw 8rem; background: var(--white); }
.contact-form-wrap form { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; max-width: 950px; padding: 3rem; background: var(--cream); }
.contact-options { padding-top: 3rem; }
.contact-options a { display: block; margin-top: 1rem; color: var(--navy); font-family: var(--head); font-size: clamp(1.2rem, 2vw, 2rem); font-weight: 700; line-height: 1.15; }
.contact-options p { margin-top: 2rem; color: #617078; font-size: .95rem; line-height: 1.7; }
.contact-form-wrap label { display: flex; flex-direction: column; gap: .5rem; color: var(--navy); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.contact-form-wrap .wide { grid-column: 1 / -1; }
.contact-form-wrap input, .contact-form-wrap select, .contact-form-wrap textarea { width: 100%; padding: .9rem; border: 0; border-bottom: 1px solid var(--line); background: var(--white); color: var(--ink); font-family: var(--body); font-size: .95rem; text-transform: none; }
.contact-form-wrap button { cursor: pointer; }
.contact-form-status { padding: 1rem 1.2rem; border-left: 3px solid var(--teal); background: var(--white); }
.contact-form-status.is-error { border-left-color: #a63b32; }
.contact-form-status strong { color: var(--navy); font-family: var(--head); font-size: .9rem; }
.contact-form-status p { margin: .35rem 0 0; color: #58686e; font-size: .85rem; line-height: 1.55; }
.contact-form-trap { position: absolute !important; left: -10000px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }
.article-body { display: grid; grid-template-columns: .7fr 2fr; gap: 7vw; padding: 8rem max(8vw, calc((100vw - 1250px) / 2)); background: var(--white); }
.article-body aside { position: sticky; top: 2rem; display: flex; height: fit-content; flex-direction: column; gap: .8rem; padding-top: .5rem; }
.article-body aside .eyebrow { margin-bottom: .6rem; }
.article-body aside a { color: #66757b; font-size: .82rem; }
.article-body aside strong { color: var(--navy); font-family: var(--head); font-size: .85rem; }
.article-body aside > span:not(.eyebrow) { color: #66757b; font-size: .82rem; }
.article-body .article-topic-label { margin-top: 1.4rem; }
.article-body > div { max-width: 760px; }
.article-body p { color: #56666d; font-size: 1rem; line-height: 1.85; }
.article-body .article-lead { margin-bottom: 4rem; color: var(--navy); font-size: clamp(1.4rem, 2.2vw, 2.1rem); line-height: 1.5; }
.article-body h2 { margin: 4rem 0 1.3rem; font-size: clamp(2rem, 3.2vw, 3.5rem); }
.article-body h3 { margin: 2.5rem 0 1rem; color: var(--navy); font-size: 1.4rem; }
.article-body ul, .article-body ol { margin: 1.5rem 0 2rem; padding-left: 1.3rem; color: #56666d; line-height: 1.8; }
.article-body li { margin-bottom: .55rem; }
.article-body .article-content a { color: #0b7180; text-decoration: underline; text-underline-offset: .18em; }
.article-body .article-content img { display: block; width: 100%; height: auto; margin: 2.5rem 0; border-radius: .25rem; }
.article-body .article-content h2:first-of-type img { margin-top: 0; }
.article-body blockquote { margin: 3.5rem 0; padding: 2rem 0 2rem 2rem; border-left: 2px solid var(--teal); color: var(--navy); font-family: var(--head); font-size: clamp(1.25rem, 2vw, 2rem); font-weight: 700; line-height: 1.45; }
.newsroom { padding: 8rem 8vw; background: var(--white); }
.newsroom-header { display: grid; grid-template-columns: 1.5fr 1fr; gap: 7vw; margin-bottom: 5rem; padding-bottom: 4rem; border-bottom: 1px solid var(--line); }
.newsroom-header h2 { margin: 1rem 0 0; }
.newsroom-header p { max-width: 440px; color: #627178; }
.news-browser { display: grid; grid-template-columns: .48fr 2fr; gap: 5vw; align-items: start; }
.news-filters { position: sticky; top: 2rem; display: flex; flex-direction: column; gap: 1.2rem; padding: 1.6rem; border: 1px solid var(--line); background: var(--cream); }
.news-filters p { margin: .5rem 0 0; color: #65747a; font-size: .78rem; }
.news-filters p strong { color: var(--navy); font-family: var(--head); }
.news-filters label { display: flex; flex-direction: column; gap: .45rem; color: var(--navy); font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.news-filters select { width: 100%; padding: .8rem; border: 1px solid var(--line); background: var(--white); color: var(--navy); font-family: var(--body); font-size: .8rem; text-transform: none; }
.news-filters > button { padding: .8rem; border: 1px solid var(--navy); background: transparent; color: var(--navy); cursor: pointer; font-family: var(--head); font-size: .62rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.news-filters > button:hover { background: var(--navy); color: var(--white); }
.year-jump { display: flex; flex-direction: column; margin-top: .5rem; border-top: 1px solid var(--line); }
.year-jump .eyebrow { margin: 1.2rem 0 .5rem; }
.year-jump button { display: flex; justify-content: space-between; padding: .7rem 0; border: 0; border-bottom: 1px solid var(--line); background: none; color: #65747a; cursor: pointer; font-size: .8rem; text-align: left; }
.year-jump button b { color: var(--teal); font-family: var(--head); font-size: .65rem; }
.year-jump button.active, .year-jump button:hover { color: var(--navy); font-weight: 700; }
.news-archive section { display: grid; grid-template-columns: .45fr 2fr; gap: 4vw; padding: 3rem 0; border-bottom: 1px solid var(--line); }
.news-archive section:first-child { padding-top: 0; }
.news-archive section[hidden] { display: none; }
.news-archive section > h3 { margin: 0; font-size: 1rem; }
.news-archive section > a { display: grid; grid-template-columns: .4fr 2fr auto; gap: 2rem; align-items: start; padding: 0 0 2rem; }
.news-archive section > a + a { grid-column: 2; padding-top: 2rem; border-top: 1px solid var(--line); }
.news-archive time { color: #647278; font-size: .75rem; }
.news-archive h4 { margin: .5rem 0 .7rem; color: var(--navy); font-family: var(--head); font-size: clamp(1.15rem, 2vw, 1.8rem); line-height: 1.2; letter-spacing: -.035em; }
.news-archive p { margin: 0; color: #647278; font-size: .86rem; }
.news-archive b { color: var(--teal); }
.news-empty { padding: 4rem 0; border-top: 1px solid var(--line); color: #647278; }
.press-release { display: grid; grid-template-columns: .6fr 2fr; gap: 7vw; padding: 8rem max(8vw, calc((100vw - 1250px) / 2)); background: var(--white); }
.press-tools { position: sticky; top: 2rem; display: flex; height: fit-content; flex-direction: column; gap: .9rem; }
.press-tools a { display: flex; justify-content: space-between; padding-bottom: .7rem; border-bottom: 1px solid var(--line); color: var(--navy); font-family: var(--head); font-size: .68rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.press-copy { max-width: 780px; }
.press-copy p { color: #56666d; line-height: 1.85; }
.press-copy .article-lead { color: var(--navy); font-size: clamp(1.35rem, 2.2vw, 2rem); line-height: 1.5; }
.press-dateline { font-size: .78rem; letter-spacing: .05em; text-transform: uppercase; }
.press-copy blockquote { margin: 3.5rem 0; padding: 2rem; background: var(--cream); color: var(--navy); font-family: var(--head); font-size: clamp(1.2rem, 2vw, 1.8rem); font-weight: 700; line-height: 1.5; }
.press-copy h2 { margin: 4rem 0 1rem; font-size: clamp(2rem, 3vw, 3.3rem); }
.media-contact { display: flex; flex-direction: column; gap: .35rem; margin-top: 4rem; padding: 2rem; border-left: 2px solid var(--teal); background: var(--cream); color: #617078; font-size: .85rem; }
.media-contact strong, .media-contact a { color: var(--navy); }

.policy-page { display: grid; grid-template-columns: .7fr 2fr; gap: 7vw; padding: 7rem max(8vw, calc((100vw - 1250px) / 2)); background: var(--white); }
.policy-page aside { position: sticky; top: 2rem; display: flex; height: fit-content; flex-direction: column; gap: .8rem; padding-top: .5rem; }
.policy-page aside a { padding-bottom: .7rem; border-bottom: 1px solid var(--line); color: #66757b; font-size: .82rem; }
.policy-page aside a.active, .policy-page aside a:hover { color: var(--navy); font-weight: 700; }
.policy-page article { max-width: 820px; color: #4f6064; }
.policy-updated { margin: 0 0 3rem; color: #66757b; font-family: var(--head); font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.policy-page article h2 { margin: 4rem 0 1.2rem; color: var(--navy); font-size: clamp(1.9rem, 3vw, 3.2rem); }
.policy-page article h2:first-of-type { margin-top: 0; }
.policy-page article h3 { margin: 2rem 0 .8rem; color: var(--navy); font-size: 1.2rem; }
.policy-page article p, .policy-page article li { font-size: 1rem; line-height: 1.8; }
.policy-page article ul { margin: 1.2rem 0 2rem; padding-left: 1.25rem; }

@media (max-width: 1100px) {
    .site-header { height: 72px; }
    .brand { width: 180px; }
    .menu-toggle { display: flex; width: 85px; flex-direction: column; gap: 5px; align-items: center; justify-content: center; margin-left: auto; border: 0; border-left: 1px solid rgba(255,255,255,.18); background: none; color: var(--white); }
    .menu-toggle span { display: block; width: 21px; height: 1px; background: var(--white); transition: .2s; }
    .menu-toggle b { margin-top: 2px; font-family: var(--head); font-size: .48rem; letter-spacing: .12em; text-transform: uppercase; }
    .site-nav { visibility: hidden; position: fixed; inset: 72px 0 0; display: block; overflow: auto; background: var(--navy-deep); opacity: 0; transition: .2s; }
    body.menu-open .site-nav { visibility: visible; opacity: 1; }
    .nav-list { display: block; padding: 1.2rem; }
    .nav-list > li { display: block; border-bottom: 1px solid rgba(255,255,255,.14); }
    .nav-list > li > a, .nav-list > li > button { width: 100%; justify-content: space-between; padding: 1.2rem .3rem; }
    .nav-cta { width: auto; height: 55px; margin: 1rem; }
    .mega-menu { visibility: visible; position: static; display: none; min-height: 0; grid-template-columns: 1fr; background: rgba(255,255,255,.04); box-shadow: none; opacity: 1; transform: none; }
    .has-mega:hover .mega-menu { display: none; }
    .has-mega.open .mega-menu { display: block; }
    .mega-intro { display: none; }
    .mega-columns, .city-links, .industry-links { display: grid; grid-template-columns: 1fr 1fr; gap: 0 1.2rem; padding: .5rem 1rem 1.5rem; }
    .mega-columns a { border-color: rgba(255,255,255,.1); }
    .mega-columns b { color: var(--white); }.mega-columns small { color: rgba(255,255,255,.5); }
    .mega-label { margin-top: 1rem; }
    .service-grid { grid-template-columns: repeat(2, 1fr); }.service-card, .service-card:nth-child(1), .service-card:nth-child(2) { grid-column: span 1; min-height: 410px; }
    .method-section { grid-template-columns: 1fr; }.method-copy { padding: 5rem 8vw; }
    .service-photo { grid-template-columns: 1.5fr 1fr; }
    .city-photo { grid-template-columns: 1.4fr 1fr; }
    .city-market-section > header, .city-market-layout { grid-template-columns: 1fr; }
    .city-market-read { min-height: 420px; }
    .service-hero { grid-template-columns: 1fr .9fr; gap: 3vw; padding-right: 5vw; padding-left: 5vw; }
    .service-hero-accent { display: none; }
    .service-system-section > header, .service-system-layout, .service-expertise-section header, .service-method-section { grid-template-columns: 1fr; }
    .service-knowledge-panel { position: static; }
    .expertise-map { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .service-method-section ol { grid-template-columns: repeat(2, 1fr); }
    .capability-grid { grid-template-columns: repeat(2, 1fr); }.capability-grid article:nth-child(3) { border-left-width: 1px; }
    .offering-grid { grid-template-columns: repeat(2, 1fr); }
    .city-card-grid { grid-template-columns: repeat(3, 1fr); }
    .product-capabilities > div { grid-template-columns: repeat(2, 1fr); }
    .product-related > div { grid-template-columns: 1fr 1fr; }
    .industry-cycle ol { grid-template-columns: repeat(3, 1fr); }
    .industry-services > div { grid-template-columns: repeat(2, 1fr); }
    .industry-directory > section > div { grid-template-columns: repeat(2, 1fr); }
    .about-thesis { grid-template-columns: .35fr 1.2fr; }.about-thesis aside { grid-column: 2; }
    .about-system-grid { grid-template-columns: repeat(2, 1fr); }
    .about-values { grid-template-columns: .65fr 1fr; }
    .home-news { grid-template-columns: 1fr; }
    .news-browser { grid-template-columns: .65fr 2fr; gap: 3vw; }
    .magazine-masthead { grid-template-columns: .7fr 2fr; }.magazine-masthead > p { grid-column: 2; }.magazine-lead { grid-template-columns: 1.2fr 1fr; }
    .magazine-article { grid-template-columns: .65fr 2fr; }.magazine-cover-title { grid-template-columns: .25fr 2fr 1fr; }
    .magazine-play, .issue-shelf { grid-template-columns: 1fr 1.5fr; gap: 4vw; }
    .edition-story-copy { padding: 5rem 5vw; }.edition-brochure { column-count: 2; }.edition-dispatch { grid-template-columns: 1fr 1.5fr; }.dispatch-intro { grid-column: 1; }.dispatch-main { grid-column: 2; }.edition-dispatch figure:not(.dispatch-main) { display: none; }
}

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
    .service-card:hover, .offering-grid a:hover, .city-card:hover, .photo-story figure:hover img, .edition-card-front:hover > figure img, .edition-dispatch:hover figure img, .magazine-story:hover img { transform: none !important; }
}

@media (forced-colors: active) {
    a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible, [tabindex]:focus-visible { outline: 3px solid Highlight; }
}

@media (min-width: 721px) and (max-height: 860px) {
    .edition-story-copy { padding-top: 2.4rem; padding-bottom: 2.2rem; }
    .edition-folio { margin-bottom: clamp(1.1rem, 4vh, 2.4rem); }
    .edition-story-copy h2 { margin: .55rem 0 .75rem; font-size: clamp(2.05rem, 3.2vw, 3.8rem); line-height: .96; }
    .edition-story-copy .edition-deck { font-size: clamp(.96rem, 1.1vw, 1.15rem); line-height: 1.3; }
    .edition-story-copy p { font-size: .9rem; line-height: 1.48; }
    .edition-story-copy footer { padding-top: .75rem; }
    .edition-article-face { padding-top: 2rem; padding-bottom: 1.8rem; }
    .edition-article-face h2 { margin: .75rem 0 .55rem; font-size: clamp(1.9rem, 3.35vw, 3.65rem); }
    .edition-article-lead { margin-bottom: .9rem; font-size: clamp(.96rem, 1.2vw, 1.22rem); line-height: 1.28; }
    .edition-brochure { font-size: .82rem; line-height: 1.38; }
    .edition-brochure h2, .edition-brochure h3 { font-size: 1.08rem; }
}

@media (max-width: 720px) {
    h1 { font-size: clamp(2.85rem, 14vw, 4.6rem); }
    h2 { font-size: clamp(2rem, 10vw, 3.3rem); }
    .home-hero { min-height: 740px; padding: 5rem 1.25rem 4rem; }
    .home-hero .hero-copy > p { font-size: .95rem; }
    .hero-actions { align-items: flex-start; flex-direction: column; gap: 1.4rem; }
    .hero-ping { display: none; }.hero-note { right: 1.25rem; bottom: 1.5rem; }
    .intro-block, .detail-intro { grid-template-columns: 1fr; padding: 5rem 1.25rem; }
    .intro-block > div:first-child { margin-bottom: 2rem; }
    .services-section, .insights-section, .directory, .offering-section { padding: 5rem 1.25rem; }
    .photo-story { grid-template-columns: 1fr; grid-template-rows: 420px repeat(2, 240px); padding: 0 1.25rem 5rem; }.photo-story-main { grid-row: auto; }
    .section-heading { grid-template-columns: 1fr; margin-bottom: 2.5rem; }
    .service-grid, .post-grid { grid-template-columns: 1fr; }
    .service-card, .service-card:nth-child(1), .service-card:nth-child(2) { min-height: 380px; }
    .method-visual { min-height: 480px; }.method-copy { padding: 5rem 1.25rem; }
    .contact-band { align-items: flex-start; flex-direction: column; gap: 2rem; padding: 4rem 1.25rem; }
    .circle-link { width: 140px; height: 140px; }
    .site-footer { grid-template-columns: 1fr 1fr; padding: 4rem 1.25rem 2rem; }
    .footer-brand { grid-column: 1 / -1; }.footer-bottom { align-items: flex-start; flex-direction: column; gap: .6rem; }
    .breadcrumb { padding: .8rem 1.25rem; overflow: auto; white-space: nowrap; }
    .page-hero { min-height: 540px; padding: 5rem 1.25rem 3rem; }
    .page-hero.hero-short { min-height: 360px; }
    .image-hero { min-height: 560px; }
    .image-hero-shade { background: linear-gradient(90deg, rgba(3,36,61,.94) 0, rgba(3,36,61,.68) 68%, rgba(3,36,61,.3)); }
    .service-hero { min-height: auto; grid-template-columns: 1fr; gap: 2rem; padding: 4.5rem 1.25rem 3rem; }
    .service-hero .hero-copy { padding-bottom: 0; }
    .service-hero h1 { font-size: clamp(3rem, 13vw, 4.7rem); }
    .service-hero-main { min-height: 330px; }
    .service-system-section, .service-expertise-section, .service-method-section { padding: 5rem 1.25rem; }
    .service-system-section > header, .service-system-layout, .service-expertise-section header, .service-method-section { grid-template-columns: 1fr; }
    .service-system-section > header { margin-bottom: 2.5rem; }
    .service-system-section > header p { margin-top: 0; }
    .service-component-grid { grid-template-columns: 1fr; }
    .expertise-map { grid-template-columns: 1fr; }
    .service-component-grid article { min-height: 0; padding: 1.4rem; }
    .service-component-grid h3 { margin-top: 2rem; }
    .service-method-section ol { grid-template-columns: 1fr; }
    .service-method-section li { min-height: 0; border-bottom: 1px solid rgba(255,255,255,.16); }
    .service-method-section h3 { margin-top: 2.5rem; }
    .contact-hero { min-height: auto; grid-template-columns: 1fr; gap: 2rem; padding: 4.5rem 1.25rem 3rem; }
    .contact-hero-card { padding: 1.4rem; }
    .service-photo { grid-template-columns: 1fr; }.service-photo > img { min-height: 320px; }.service-photo > div { padding: 3rem 1.25rem; }
    .city-photo { grid-template-columns: 1fr; }.city-photo img { min-height: 320px; }.city-photo > div { padding: 3rem 1.25rem; }
    .city-market-section { padding: 5rem 1.25rem; }.city-market-section > header, .city-market-layout { grid-template-columns: 1fr; }.city-market-section > header { margin-bottom: 2.5rem; }.city-market-read { min-height: 0; padding: 1.5rem; }.city-infra-grid { grid-template-columns: repeat(2, 1fr); }.city-bar > div { align-items: flex-start; gap: .7rem; }.city-bar b { max-width: 52%; text-align: right; }.city-resource-grid { grid-template-columns: 1fr; }
    .hero-scroll { display: none; }
    .capability-grid { grid-template-columns: 1fr; padding: 0 1.25rem 5rem; }
    .capability-grid article, .capability-grid article:nth-child(3) { border-width: 0 1px 1px; }.capability-grid article:first-child { border-top-width: 1px; }
    .offering-grid, .related-services { grid-template-columns: 1fr; }.related-services { padding: 5rem 1.25rem; }.offering-grid a { min-height: 270px; }
    .process-strip { padding: 5rem 1.25rem; }.process-strip > div { grid-template-columns: 1fr 1fr; }.process-strip article:nth-child(3) { border-top: 1px solid rgba(255,255,255,.15); }
    .directory-list a { grid-template-columns: 1fr auto; gap: .5rem; }.directory-list small { grid-column: 1 / -1; }
    .city-directory { padding: 5rem 1.25rem; }.city-directory > section + section { margin-top: 5rem; }.city-directory header { grid-template-columns: 1fr; }.city-card-grid { grid-template-columns: 1fr 1fr; }
    .product-directory-intro, .product-thesis, .product-capabilities > header, .product-architecture, .product-roadmap, .product-related > header, .product-cta { grid-template-columns: 1fr; }
    .product-directory-intro, .product-capabilities, .product-architecture, .product-roadmap, .product-related, .product-cta { padding: 5rem 1.25rem; }
    .product-directory { grid-template-columns: 1fr; padding: 0 1.25rem 5rem; }.product-card:first-child { grid-column: auto; }.product-card, .product-card:first-child { min-height: 390px; }.product-card-main { grid-template-columns: 64px 1fr; gap: 1rem; padding: 1.5rem; }.product-card-main > b { grid-column: 1 / -1; }.product-card footer { padding: 1rem 1.5rem; }
    .product-hero { min-height: auto; grid-template-columns: 1fr; }.product-hero-copy { min-height: 600px; padding: 7rem 1.25rem 3rem; }.product-status { top: 2rem; right: 1.25rem; left: 1.25rem; }.product-hero h1 { font-size: clamp(3.7rem, 17vw, 5.8rem); }.product-hero figure { min-height: 340px; }
    .product-thesis { gap: 2rem; padding: 5rem 1.25rem; }
    .product-capabilities > div, .product-roadmap > div, .product-related > div { grid-template-columns: 1fr; }.product-capabilities article { min-height: 260px; }.product-capabilities h3 { margin-top: 3rem; }
    .product-related a { min-height: 260px; }
    .industry-hero { min-height: auto; grid-template-columns: 1fr; }.industry-hero-copy { min-height: 520px; padding: 5rem 1.25rem 3rem; }.industry-hero h1 { font-size: clamp(3rem, 13vw, 4.7rem); }.industry-hero figure { min-height: 340px; }
    .industry-position, .industry-cycle header, .industry-operations > header, .industry-workforce, .industry-services > header, .industry-cta { grid-template-columns: 1fr; }
    .industry-position, .industry-cycle, .industry-operations, .industry-workforce, .industry-services, .industry-cta, .industry-directory { padding: 5rem 1.25rem; }
    .industry-cycle ol { grid-template-columns: 1fr 1fr; }.industry-cycle li { min-height: 220px; }.industry-cycle li h3 { margin-top: 3rem; }
    .industry-operations-grid { grid-template-columns: 1fr; }.industry-operations-grid article { min-height: 0; }
    .industry-services > div, .industry-directory > section > div { grid-template-columns: 1fr; }.industry-services a { min-height: 290px; }.industry-directory a { min-height: 240px; }
    .industry-directory > section > header { align-items: flex-start; flex-direction: column; gap: .4rem; }
    .about-hero { min-height: 620px; padding: 5rem 1.25rem 3rem; }.about-hero-note { display: none; }.about-hero h1 { font-size: clamp(3.1rem, 14vw, 4.8rem); }
    .about-thesis, .about-system-map > header, .about-values, .about-partnerships { grid-template-columns: 1fr; }
    .about-thesis { gap: 2.5rem; padding: 5rem 1.25rem; }.about-thesis aside { grid-column: auto; }
    .about-system-map, .about-commitments, .about-values, .about-partnerships { padding: 5rem 1.25rem; }
    .about-system-map > header { margin-bottom: 2rem; }.about-system-grid { grid-template-columns: 1fr; }.about-system-grid article { min-height: 240px; }.about-system-grid h3 { margin-top: 3rem; }.about-system-grid aside { grid-column: auto; grid-template-columns: 1fr; }
    .about-commitments > header { grid-template-columns: 1fr; }.about-commitments > div { grid-template-columns: 1fr; }.about-commitments article, .about-commitments article:nth-child(4), .about-commitments article:nth-child(5) { grid-column: auto; min-height: 240px; border-width: 0 1px 1px; }.about-commitments article:first-child { border-top-width: 1px; }.about-commitments h3 { margin-top: 3rem; }
    .about-values header { position: static; }.about-values li { grid-template-columns: 44px 1fr; gap: .8rem; }
    .contact-form-wrap { grid-template-columns: 1fr; padding: 0 1.25rem 5rem; }.contact-options { padding-top: 2rem; }.contact-form-wrap form { grid-template-columns: 1fr; padding: 1.5rem; }.contact-form-wrap .wide { grid-column: auto; }
    .article-body { grid-template-columns: 1fr; padding: 5rem 1.25rem; }.article-body aside { position: static; }
    .home-news { grid-template-columns: 1fr; padding: 5rem 1.25rem; }
    .newsroom { padding: 5rem 1.25rem; }.newsroom-header, .press-release, .news-browser { grid-template-columns: 1fr; }.newsroom-header { margin-bottom: 2rem; padding-bottom: 3rem; }.news-filters { position: static; }.year-jump { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0 .8rem; }.year-jump .eyebrow { grid-column: 1 / -1; }.news-archive section { grid-template-columns: 1fr; }.news-archive section > a, .news-archive section > a + a { grid-column: auto; grid-template-columns: 1fr auto; gap: 1rem; }.news-archive section > a time { grid-column: 1 / -1; }.news-archive section > a div { grid-column: 1; }.press-release { padding: 5rem 1.25rem; }.press-tools { position: static; }
    .policy-page { grid-template-columns: 1fr; padding: 5rem 1.25rem; }.policy-page aside { position: static; }
    .mega-columns, .city-links, .industry-links { grid-template-columns: 1fr; }
    .magazine-masthead { grid-template-columns: 1fr; padding: 3rem 1.25rem 2rem; }.magazine-masthead > p { grid-column: auto; }.magazine-masthead h1 { margin: 2rem 0; font-size: clamp(4.2rem, 20vw, 6.5rem); }.magazine-masthead h1 em { margin-left: 3%; }.magazine-rule { margin-top: 1rem; }
    .magazine-lead { grid-template-columns: 1fr; }.magazine-lead-image { min-height: 360px; }.magazine-lead > div { padding: 4rem 1.25rem; }.magazine-number { top: 1.5rem; right: 1rem; font-size: 6rem; }
    .magazine-index { padding: 5rem 1.25rem; }.magazine-index > header { grid-template-columns: 1fr; }.magazine-topic-filter { justify-content: flex-start; }.magazine-story-grid { grid-template-columns: 1fr; gap: 3.5rem; }.magazine-story, .magazine-story:nth-child(1), .magazine-story:nth-child(4) { grid-column: auto; }.magazine-story:nth-child(1) img, .magazine-story:nth-child(4) img { aspect-ratio: 1.25; }
    .magazine-article-cover { padding: 1.3rem 1.25rem 0; }.magazine-cover-kicker span { display: none; }.magazine-cover-title { grid-template-columns: 1fr; padding: 3rem 0 2rem; }.magazine-section { writing-mode: initial; }.magazine-cover-title h1 { font-size: clamp(3.5rem, 16vw, 5.8rem); }.magazine-byline { grid-column: auto; flex-wrap: wrap; gap: .8rem 1.5rem; }.magazine-article-cover figure img { min-height: 330px; }
    .magazine-article { grid-template-columns: 1fr; padding: 4rem 1.25rem 6rem; }.magazine-article-rail { position: static; }.magazine-toc-wrap { display: none !important; }.magazine-article .article-content img { width: calc(100% + 2.5rem); margin-right: -1.25rem; margin-left: -1.25rem; }.magazine-article .article-content blockquote { margin-right: -1.25rem; margin-left: -1.25rem; padding: 2.5rem 1.25rem; }
    .magazine-related { padding: 5rem 1.25rem; }.magazine-related header { align-items: flex-start; flex-direction: column; gap: .8rem; }.magazine-related > div { grid-template-columns: 1fr; gap: 3rem; }
    .magazine-play, .issue-shelf { grid-template-columns: 1fr; padding: 5rem 1.25rem; }.crossword-puzzle { grid-template-columns: 1fr; padding: 1rem; }.crossword-panel { grid-template-columns: 1fr; }.issue-shelf > div:last-child { grid-template-columns: 1fr; }.issue-shelf a, .issue-shelf article { min-height: 220px; }
    .edition-nav { display: none; }.edition-page { min-height: 0; scroll-margin-top: 72px; }.edition-cover { min-height: calc(100vh - 72px); padding: 2rem 1.25rem; }.edition-cover-title h1 { font-size: clamp(4.2rem, 22vw, 6.5rem); }.edition-cover-title p { font-size: 1rem; }.edition-cover-top, .edition-cover-bottom { gap: 1rem; font-size: .52rem; }.edition-cover-bottom span { display: none; }.paint-stroke-cover { right: -20vw; width: 90vw; }
    .edition-card, .edition-card-face { height: calc(100vh - 72px); min-height: 680px; }.edition-card-face { position: relative; }.edition-card-front, .edition-story-split .edition-card-front { display: flex; flex-direction: column; }.edition-card-back { display: none; transform: none; }.edition-story.is-reading .edition-card-front { display: none; }.edition-story.is-reading .edition-card-back { display: block; opacity: 1; }.edition-card-front > figure { height: 30%; min-height: 210px; }.edition-field-note > img { min-height: 390px; height: 55vh; }.edition-story-copy { flex: 1; min-height: 0; padding: 1.45rem 1.25rem 1.35rem; }.edition-folio { margin-bottom: 1.3rem; }.edition-story-copy .eyebrow { margin-top: 0; }.edition-story-copy h2 { margin: .55rem 0 .7rem; font-size: clamp(2rem, 8.7vw, 2.85rem); line-height: .95; }.edition-story-copy .edition-deck { font-size: .96rem; line-height: 1.28; }.edition-story-copy .edition-deck + p { display: none; }.edition-story-copy footer { align-items: flex-start; flex-direction: column; margin-top: auto; }
    .edition-article-face { height: calc(100vh - 72px); min-height: 620px; padding: 2rem 1.25rem; }.edition-article-face header, .edition-article-face footer { align-items: flex-start; flex-direction: column; }.edition-article-face h2 { font-size: clamp(2.15rem, 10vw, 3.4rem); }.edition-article-lead { font-size: 1rem; }.edition-brochure { overflow: hidden; column-count: 1; font-size: .88rem; line-height: 1.48; }
    .edition-dispatch { display: flex; flex-direction: column; padding: 0; }.dispatch-intro { padding: 4rem 1.25rem; }.edition-dispatch figure, .edition-dispatch figure:not(.dispatch-main) { display: block; min-height: 350px; }.edition-dispatch figcaption { flex-direction: column; gap: .2rem; }.edition-field-note > div { padding: 4rem 1.25rem; }.edition-field-note h2 { font-size: clamp(3rem, 14vw, 4.8rem); }.edition-colophon { min-height: 80vh; padding: 6rem 1.25rem; }.edition-colophon h2 { font-size: clamp(4.5rem, 21vw, 7rem); }
}
