@import url("https://fonts.googleapis.com/css2?family=Libre+Baskerville:wght@400;700&family=Manrope:wght@400;500;600;700&display=swap");

:root {
--charcoal-900: #111820;
--charcoal-850: #171f29;
--charcoal-800: #1c2631;
--navy-700: #243244;
--slate-500: #6f7d8f;
--stone-200: #d8d2c8;
--stone-100: #e9e4db;
--mist-50: #f4f2ee;
--brand-ink: #101923;
--brand-navy: #182536;
--brand-blue: #2e4f73;
--brand-sky: #86a9c9;
--brand-gold: #c8aa73;
--brand-brass: #8f7651;
--brand-champagne: #d8c49a;
--brand-cream: #f3eee4;
--brand-white: #f8fbfd;
--property-white: #fbfcfd;
--property-mist: #eef5f8;

--ink: #e6ebf1;
--ink-soft: #b6c0cd;
--ink-dark: #273343;

--space-0: 4px;
--space-1: 8px;
--space-2: 12px;
--space-3: 16px;
--space-4: 24px;
--space-5: 36px;
--space-6: 56px;
--space-7: 84px;
--space-8: 120px;

--radius-sm: 8px;
--radius-md: 14px;
--radius-lg: 20px;

--shell-max: 2280px;
--shell-pad: clamp(14px, 2.8vw, 64px);

--glass-nav: rgba(17, 24, 32, 0.5);
--glass-edge: rgba(232, 238, 245, 0.17);
--glass-highlight: rgba(255, 255, 255, 0.34);
--glass-shadow: rgba(8, 12, 18, 0.24);
--glass-surface: rgba(248, 252, 254, 0.58);
--glass-surface-strong: rgba(248, 252, 254, 0.74);
--glass-border: rgba(255, 255, 255, 0.56);
--glass-blue-edge: rgba(134, 169, 201, 0.3);
--material-nav-bg: rgba(15, 22, 31, 0.56);
--material-nav-edge: rgba(233, 239, 246, 0.18);
--material-panel-bg: rgba(19, 29, 40, 0.34);
--material-panel-edge: rgba(238, 244, 251, 0.15);
--material-overlay-fallback: rgba(18, 27, 38, 0.82);

--shadow-soft: 0 16px 44px rgba(7, 10, 14, 0.2);
--shadow-deep: 0 30px 80px rgba(5, 8, 12, 0.42);
--shadow-premium-sm: 0 10px 24px rgba(6, 10, 16, 0.16);
--shadow-premium-md: 0 18px 40px rgba(6, 10, 16, 0.22);

--ease: cubic-bezier(.2,.68,.2,1);
--ease-premium: cubic-bezier(.16, 1, .3, 1);
}

* { box-sizing: border-box; }
html, body { max-width: 100%; overflow-x: clip; }
html { scroll-behavior: smooth; }

body {
margin: 0;
font-family: "Manrope", "Segoe UI", Roboto, Arial, sans-serif;
color: var(--ink-dark);
font-size: clamp(0.95rem, 0.14vw + 0.9rem, 1.03rem);
line-height: 1.62;
background:
radial-gradient(1200px 620px at 88% -16%, rgba(134, 169, 201, 0.22), transparent 70%),
radial-gradient(860px 520px at 8% 8%, rgba(200, 170, 115, 0.1), transparent 72%),
linear-gradient(180deg, #f8fafb 0%, #eef3f4 44%, #e7ecee 100%);
}

img { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
a:hover { text-decoration: none; }
h1, h2, h3, p { margin: 0; }

h1 {
font-size: clamp(2.02rem, 2.06vw + 0.88rem, 3.12rem);
line-height: 1.04;
letter-spacing: 0;
font-family: "Manrope", "Segoe UI", Roboto, Arial, sans-serif;
font-weight: 700;
}
h2 {
font-size: clamp(1.44rem, 1.05vw + 0.95rem, 2.12rem);
line-height: 1.15;
letter-spacing: 0;
font-family: "Manrope", "Segoe UI", Roboto, Arial, sans-serif;
font-weight: 700;
}
h3 {
font-size: clamp(1.03rem, 0.28vw + 0.94rem, 1.17rem);
line-height: 1.3;
font-weight: 600;
}
p { color: #5f6b7a; font-size: clamp(0.93rem, 0.1vw + 0.89rem, 1.01rem); }

.skip-link { position: absolute; left: -9999px; }
.skip-link:focus {
left: 12px; top: 12px; z-index: 900;
padding: 8px 11px; border-radius: 8px;
border: 1px solid #d8e0e8; background: #fff;
}
:focus-visible { outline: 2px solid rgba(126, 156, 191, 0.5); outline-offset: 2px; }

.shell {
width: min(100% - (var(--shell-pad) * 2), var(--shell-max));
margin-inline: auto;
}

.site-header {
position: sticky;
top: 0;
z-index: 100;
background: rgba(248, 252, 254, 0.92);
background: linear-gradient(180deg, rgba(251, 253, 254, 0.94), rgba(246, 250, 252, 0.8));
border-bottom: 1px solid rgba(46, 79, 115, 0.14);
backdrop-filter: blur(18px) saturate(128%);
box-shadow: 0 10px 28px rgba(20, 34, 48, 0.1);
}
.site-header::before {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background:
linear-gradient(90deg, rgba(46, 79, 115, 0.08), transparent 34%, transparent 74%, rgba(134, 169, 201, 0.16)),
linear-gradient(180deg, rgba(255,255,255,0.42), rgba(255,255,255,0));
opacity: 0.9;
}
.nav-wrap {
position: relative;
z-index: 1;
min-height: clamp(62px, 4vw, 76px);
display: flex;
align-items: center;
justify-content: space-between;
gap: var(--space-3);
}
.brand-link {
display: inline-flex;
align-items: center;
padding: 2px 0;
border-radius: 0;
background: transparent;
border: 0;
box-shadow: none;
text-decoration: none;
}
.brand-logo {
display: block;
width: auto;
height: clamp(34px, 2.4vw, 44px);
max-width: clamp(184px, 16.5vw, 236px);
max-height: 44px;
object-fit: contain;
filter: none;
}

.site-nav ul { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 6px; flex-wrap: nowrap; }
.site-nav a {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 36px;
padding: 7px 11px;
border-radius: 9px;
color: rgba(232, 238, 246, 0.92);
color: #24364a;
text-decoration: none;
white-space: nowrap;
font-weight: 500;
font-size: clamp(0.84rem, 0.06vw + 0.83rem, 0.93rem);
letter-spacing: 0;
transition: background-color 260ms var(--ease-premium), color 260ms var(--ease-premium), box-shadow 260ms var(--ease-premium);
}
.site-nav a:hover,
.site-nav a[aria-current="page"] {
background: linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(232, 242, 247, 0.72));
color: #102033;
box-shadow: inset 0 0 0 1px rgba(46, 79, 115, 0.12), 0 8px 20px rgba(20, 34, 48, 0.08);
}

.nav-toggle {
display: none;
width: 40px;
height: 40px;
min-width: 40px;
border: 0;
border-radius: 8px;
background: transparent;
color: #24364a;
align-items: center;
justify-content: center;
transition: background-color 160ms var(--ease);
}
.nav-toggle:hover { background: rgba(238, 244, 250, 0.12); }
.hamburger { width: 17px; height: 12px; display: inline-flex; flex-direction: column; justify-content: space-between; }
.hamburger span { width: 100%; height: 1.5px; border-radius: 2px; background: #24364a; transition: transform 180ms var(--ease), opacity 180ms var(--ease); }
.nav-toggle.is-open .hamburger span:nth-child(1) { transform: translateY(5.2px) rotate(45deg); }
.nav-toggle.is-open .hamburger span:nth-child(2) { opacity: 0; }
.nav-toggle.is-open .hamburger span:nth-child(3) { transform: translateY(-5.2px) rotate(-45deg); }

.eyebrow {
text-transform: uppercase;
letter-spacing: 0;
font-size: 0.69rem;
color: #90a0b4;
font-weight: 600;
}

main { padding-bottom: var(--space-7); }
.section { padding-block: clamp(var(--space-5), 5.4vw, var(--space-7)); }
.section + .section { padding-top: clamp(var(--space-4), 4vw, var(--space-6)); }
main section[id] { scroll-margin-top: clamp(76px, 6vw, 104px); }

.hero {
position: relative;
min-height: min(92vh, 1000px);
display: grid;
align-items: center;
margin-bottom: 0;
isolation: isolate;
}
.hero-stage { position: absolute; inset: 0; overflow: hidden; }
.hero-stage::after {
content: "";
position: absolute;
inset: auto 0 0;
height: 32%;
background: linear-gradient(180deg, transparent, rgba(10, 18, 26, 0.3));
pointer-events: none;
}
.hero-stage img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: 52% 51%;
transform: translate3d(0, var(--scroll-y, 0px), 0) scale(var(--scroll-scale, 1.02));
filter: saturate(1.08) contrast(1.04) brightness(0.96);
opacity: var(--scroll-opacity, 1);
will-change: transform;
}
.hero-vignette {
position: absolute;
inset: 0;
background:
radial-gradient(80% 70% at 73% 18%, rgba(255, 255, 255, 0.2), transparent 54%),
linear-gradient(100deg, rgba(10, 18, 27, 0.68) 0%, rgba(15, 29, 42, 0.44) 32%, rgba(22, 45, 66, 0.14) 64%, rgba(255, 255, 255, 0.06) 100%),
linear-gradient(180deg, rgba(9, 15, 22, 0.04) 0%, rgba(9, 15, 22, 0.1) 52%, rgba(9, 15, 22, 0.34) 100%);
transform: translate3d(0, var(--scroll-y, 0px), 0);
will-change: transform;
}
.hero-content-wrap {
position: relative;
z-index: 2;
padding-block: clamp(var(--space-7), 14vh, var(--space-8)) clamp(var(--space-6), 9vh, var(--space-8));
display: grid;
grid-template-columns: minmax(0, 0.86fr) minmax(320px, 0.58fr);
align-items: end;
gap: clamp(var(--space-4), 4vw, var(--space-7));
}
.hero-content {
max-width: 52ch;
display: grid;
gap: clamp(var(--space-2), 1.2vw, var(--space-3));
color: #f4f7fb;
transform: translate3d(0, var(--scroll-y, 0px), 0);
will-change: transform;
}
.hero-content h1, .hero-content p, .hero-content .eyebrow { color: #f4f7fb; }
.hero-content h1 {
max-width: 10ch;
font-size: clamp(2.46rem, 4vw, 5.04rem);
line-height: 0.98;
letter-spacing: 0;
text-shadow: 0 16px 42px rgba(4, 8, 12, 0.36);
}
.hero-content .eyebrow {
color: #dec58f;
letter-spacing: 0;
}
.hero-content .lead {
max-width: 45ch;
color: rgba(242, 246, 250, 0.9);
font-size: clamp(1rem, 0.24vw + 0.94rem, 1.16rem);
line-height: 1.62;
}
.hero-trust-line {
max-width: 46ch;
font-size: clamp(0.82rem, 0.12vw + 0.79rem, 0.92rem);
letter-spacing: 0;
color: rgba(218, 227, 237, 0.82);
}
.hero-content.glass-focus {
background: transparent;
border: 0;
box-shadow: none;
backdrop-filter: none;
border-radius: 0;
padding: 0 0 0 clamp(var(--space-3), 1.2vw, var(--space-4));
border-left: 2px solid rgba(216, 196, 154, 0.74);
}
.glass-focus {
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.08) 42%, rgba(20, 31, 43, 0.14)),
linear-gradient(165deg, var(--material-panel-bg), rgba(19, 29, 40, 0.22));
border: 1px solid rgba(255, 255, 255, 0.22);
box-shadow: 0 18px 42px rgba(6, 10, 16, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.24);
backdrop-filter: blur(14px) saturate(118%);
border-radius: var(--radius-lg);
padding: clamp(var(--space-4), 2.4vw, var(--space-6));
}

.actions { display: flex; flex-wrap: wrap; gap: var(--space-2); }

.hero-media-strip {
align-self: end;
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 10px;
padding: 10px;
border-radius: 16px;
background: var(--glass-surface-strong);
border: 1px solid var(--glass-border);
box-shadow: 0 24px 58px rgba(7, 12, 18, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.58);
backdrop-filter: blur(16px) saturate(126%);
clip-path: inset(0 0 0 0 round 16px);
transform: translate3d(0, var(--scroll-y, 0px), 0) scale(var(--scroll-scale, 1));
will-change: transform;
}

.hero-media-strip article {
position: relative;
min-height: 132px;
overflow: hidden;
border-radius: 11px;
isolation: isolate;
}

.hero-media-strip img {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
filter: saturate(1.04) contrast(1.04);
transition: transform 620ms var(--ease-premium), filter 620ms var(--ease-premium);
}

.hero-media-strip article::after {
content: "";
position: absolute;
inset: 0;
background: linear-gradient(180deg, transparent 32%, rgba(6, 12, 18, 0.7));
z-index: 1;
}

.hero-media-strip span {
position: absolute;
left: 12px;
right: 12px;
bottom: 10px;
z-index: 2;
color: #fff;
font-size: 0.78rem;
font-weight: 700;
text-shadow: 0 2px 12px rgba(0, 0, 0, 0.34);
}

.hero-media-strip article:hover img {
transform: scale(1.05) translateY(-2px);
filter: saturate(1.1) contrast(1.07);
}
.hero-media-strip article:focus-within img {
transform: scale(1.05) translateY(-2px);
filter: saturate(1.1) contrast(1.07);
}
.btn {
min-height: 44px;
padding: 10px 16px;
border-radius: 10px;
border: 1px solid transparent;
font: inherit;
text-decoration: none;
font-size: 0.9rem;
font-weight: 600;
letter-spacing: 0;
display: inline-flex;
align-items: center;
justify-content: center;
transition: transform 260ms var(--ease-premium), background-color 260ms var(--ease-premium), color 260ms var(--ease-premium), border-color 260ms var(--ease-premium), box-shadow 260ms var(--ease-premium);
}
.btn-primary {
background: linear-gradient(135deg, var(--brand-champagne), #eadbb8);
color: var(--brand-ink);
border-color: rgba(143, 118, 81, 0.28);
box-shadow: var(--shadow-premium-sm);
}
.btn-primary:hover {
background: linear-gradient(135deg, #cdb783, #efe0bd);
box-shadow: var(--shadow-premium-md);
transform: translateY(-1px);
}
.btn-secondary {
background: rgba(240, 246, 252, 0.03);
color: rgba(232, 239, 247, 0.93);
border-color: rgba(227, 236, 246, 0.24);
}
.btn-secondary:hover {
background: rgba(227, 236, 246, 0.1);
border-color: rgba(236, 243, 251, 0.34);
transform: translateY(-1px);
}

.split-intro {
display: grid;
grid-template-columns: 1.28fr 0.72fr;
gap: clamp(var(--space-4), 3vw, var(--space-6));
align-items: end;
margin-bottom: clamp(var(--space-4), 3.2vw, var(--space-6));
}
.split-intro > div { display: grid; gap: var(--space-2); max-width: 56ch; }
.split-intro p { max-width: 40ch; }
.editorial-intro {
align-items: start;
padding-bottom: clamp(var(--space-2), 1.4vw, var(--space-3));
border-bottom: 1px solid rgba(96, 110, 126, 0.18);
}
.editorial-intro h2 { max-width: 15ch; }
.editorial-intro p {
font-size: clamp(0.98rem, 0.16vw + 0.94rem, 1.08rem);
line-height: 1.66;
color: #586577;
}

#who-we-serve,
#services,
#portfolio,
#contact {
background:
radial-gradient(980px 520px at 78% 0%, rgba(134, 169, 201, 0.2), transparent 68%),
linear-gradient(180deg, rgba(248, 251, 253, 0.94), rgba(235, 242, 245, 0.9));
}
#services {
scroll-margin-top: clamp(62px, 5vw, 78px);
padding-top: clamp(var(--space-5), 5.5vw, var(--space-7));
background:
radial-gradient(1100px 560px at 86% -4%, rgba(134, 169, 201, 0.24), transparent 68%),
radial-gradient(780px 460px at 12% 8%, rgba(200, 170, 115, 0.14), transparent 70%),
linear-gradient(180deg, #f7fafb 0%, #edf4f7 100%);
}
#who-we-serve {
padding-top: clamp(var(--space-6), 7vw, var(--space-8));
}
.home-flow {
position: relative;
}
.home-flow::before {
content: "";
position: absolute;
inset: 0 var(--shell-pad) auto;
height: 1px;
background: linear-gradient(90deg, transparent, rgba(46, 79, 115, 0.24), rgba(200, 170, 115, 0.28), transparent);
pointer-events: none;
}

.home-page .glass-panel,
.home-page .form-block,
.home-page .service-panel,
.home-page .audience-card,
.home-page .tour-card {
position: relative;
overflow: hidden;
background: var(--glass-surface);
border: 1px solid var(--glass-blue-edge);
box-shadow: 0 22px 54px rgba(27, 47, 66, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.72);
backdrop-filter: blur(18px) saturate(122%);
}

@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .site-header,
  .site-nav,
  .home-page .glass-panel,
  .home-page .form-block,
  .home-page .service-panel,
  .home-page .audience-card,
  .home-page .tour-card,
  .hero-media-strip {
    background: rgba(248, 252, 254, 0.94);
  }
}

.home-page .glass-panel::before,
.home-page .form-block::before,
.home-page .service-panel::before,
.home-page .audience-card::before,
.home-page .tour-card::before {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background:
linear-gradient(135deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.03) 40%, transparent 72%),
linear-gradient(180deg, rgba(134, 169, 201, 0.05), transparent 52%);
opacity: 0.34;
}

.home-page .glass-panel > *,
.home-page .form-block > *,
.home-page .service-panel > *,
.home-page .audience-card > *,
.home-page .tour-card > * {
position: relative;
z-index: 1;
}

.editorial-marker {
width: fit-content;
min-width: 0;
height: auto;
display: inline-flex;
align-items: center;
justify-content: center;
border-radius: 0;
padding: 0 0 7px;
background: transparent;
color: #2e5d83;
font-size: 0.74rem;
font-weight: 700;
line-height: 1;
letter-spacing: 0;
word-spacing: 0.14em;
text-transform: uppercase;
box-shadow: inset 0 -2px 0 rgba(200, 170, 115, 0.72);
}

.editorial-marker.small {
height: auto;
padding: 0 0 6px;
font-size: 0.66rem;
}

.editorial-spread {
display: grid;
grid-template-columns: minmax(0, 1.1fr) minmax(360px, 0.9fr);
gap: clamp(var(--space-4), 3vw, var(--space-6));
align-items: center;
}

.editorial-media {
position: relative;
margin: 0;
min-height: clamp(390px, 46vw, 760px);
overflow: hidden;
border-radius: 12px;
box-shadow: 0 24px 58px rgba(27, 47, 66, 0.16);
}

.editorial-media::after {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background:
linear-gradient(180deg, transparent 48%, rgba(9, 15, 22, 0.34)),
linear-gradient(90deg, rgba(12, 21, 31, 0.18), transparent 42%);
}

.editorial-media img {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
object-position: center 48%;
filter: saturate(0.96) contrast(1.05) brightness(0.9);
transform: translate3d(0, var(--scroll-y, 0px), 0) scale(var(--scroll-scale, 1.02));
transition: transform 700ms var(--ease-premium), filter 700ms var(--ease-premium);
will-change: transform;
}

.editorial-spread:hover .editorial-media img {
transform: translate3d(0, var(--scroll-y, 0px), 0) scale(1.045);
filter: saturate(1.02) contrast(1.06) brightness(0.94);
}

.editorial-panel {
display: grid;
gap: clamp(var(--space-3), 1.6vw, var(--space-4));
padding: clamp(var(--space-4), 3vw, var(--space-6));
border-radius: 12px;
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.68), rgba(237, 247, 251, 0.42) 54%, rgba(255, 255, 255, 0.64)),
var(--glass-surface);
border: 1px solid var(--glass-blue-edge);
box-shadow: 0 22px 52px rgba(27, 47, 66, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

.editorial-panel h2 {
max-width: 14ch;
color: var(--brand-ink);
}

.editorial-panel > p {
max-width: 44ch;
color: #465466;
}

.audience-list {
display: grid;
gap: 0;
border-top: 1px solid rgba(46, 79, 115, 0.16);
}

.audience-list article {
display: grid;
gap: 5px;
padding-block: var(--space-3);
border-bottom: 1px solid rgba(46, 79, 115, 0.14);
}

.audience-list article:last-child { border-bottom: 0; padding-bottom: 0; }
.audience-list h3 { color: #1b2d40; }
.audience-list p { color: #596879; }
.home-flow .editorial-intro {
margin-bottom: clamp(var(--space-5), 4.6vw, var(--space-7));
}
.home-flow .editorial-intro h2 {
max-width: 17ch;
}

.services-intro h2 {
max-width: 21ch;
}

.services-intro .editorial-marker {
display: none;
}

.services-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: clamp(var(--space-3), 1.8vw, var(--space-4));
align-items: stretch;
}

.service-panel {
display: grid;
grid-template-rows: auto 1fr;
height: 100%;
border-radius: 12px;
overflow: hidden;
background:
linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(238, 247, 251, 0.78));
border: 1px solid rgba(134, 169, 201, 0.26);
box-shadow: 0 18px 42px rgba(27, 47, 66, 0.12);
transition: transform 320ms var(--ease-premium), box-shadow 320ms var(--ease-premium), border-color 320ms var(--ease-premium);
}

.service-panel:hover {
transform: translateY(-6px);
border-color: rgba(46, 79, 115, 0.34);
box-shadow: 0 30px 66px rgba(27, 47, 66, 0.18);
}

.service-panel-featured {
grid-row: auto;
background:
linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(236, 246, 250, 0.82)),
linear-gradient(135deg, rgba(200, 170, 115, 0.12), transparent 52%);
}

.service-panel-muted {
opacity: 0.92;
}

.service-media {
position: relative;
margin: 0;
overflow: hidden;
background: #dfe8ee;
}

.service-media::after {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background:
linear-gradient(180deg, transparent 72%, rgba(8, 14, 21, 0.12)),
linear-gradient(135deg, rgba(255, 255, 255, 0.04), transparent 45%);
}

.service-media img {
width: 100%;
aspect-ratio: 16 / 11;
object-fit: cover;
filter: saturate(1.02) contrast(1.05) brightness(0.98);
transition: transform 720ms var(--ease-premium), filter 720ms var(--ease-premium);
}

.service-panel-featured .service-media img {
aspect-ratio: 16 / 11;
object-position: center 52%;
}

.service-panel:nth-child(2) .service-media img { object-position: center 48%; }
.service-panel:nth-child(3) .service-media img { object-position: center 50%; }
.service-panel:nth-child(4) .service-media img { object-position: center 48%; }

.service-panel:hover .service-media img {
transform: scale(1.055);
filter: saturate(1.04) contrast(1.06) brightness(0.98);
}

.service-content {
display: grid;
gap: clamp(var(--space-1), 0.9vw, var(--space-2));
align-content: start;
grid-template-rows: auto auto 1fr auto;
padding: clamp(var(--space-3), 1.8vw, var(--space-4));
}

.service-panel-featured .service-content {
padding: clamp(var(--space-4), 2.4vw, var(--space-5));
}

.service-price {
width: fit-content;
display: inline-flex;
align-items: center;
min-height: 30px;
padding: 5px 10px;
border-radius: 999px;
background: linear-gradient(135deg, rgba(216, 196, 154, 0.9), rgba(238, 222, 187, 0.86));
color: #1b2735;
font-size: 0.78rem;
font-weight: 800;
line-height: 1;
box-shadow: inset 0 0 0 1px rgba(143, 118, 81, 0.18), 0 8px 18px rgba(27, 47, 66, 0.08);
}

.service-content h3 {
color: #162536;
max-width: 18ch;
line-height: 1.08;
letter-spacing: -0.01em;
}

.service-content p {
color: #526273;
max-width: 42ch;
line-height: 1.58;
}

.service-note {
margin-top: var(--space-1);
padding-top: var(--space-2);
border-top: 1px solid rgba(46, 79, 115, 0.14);
font-weight: 700;
color: #33485e;
}

.service-panel-muted .service-price {
background: rgba(238, 244, 248, 0.82);
color: #596879;
box-shadow: inset 0 0 0 1px rgba(96, 110, 126, 0.14);
}

.service-grid {
display: grid;
grid-template-columns: 1.16fr 1fr 1fr;
gap: clamp(var(--space-2), 1.3vw, var(--space-3));
}
.service-card {
position: relative;
overflow: hidden;
background: linear-gradient(180deg, rgba(248,245,239,0.68), rgba(239,233,224,0.58));
border: 1px solid rgba(150, 162, 176, 0.38);
border-radius: var(--radius-md);
padding: clamp(var(--space-4), 2.2vw, var(--space-5));
display: grid;
gap: var(--space-2);
box-shadow: 0 10px 24px rgba(10, 15, 22, 0.07);
transition: transform 320ms var(--ease-premium), border-color 320ms var(--ease-premium), box-shadow 320ms var(--ease-premium);
}
.service-card::before {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background: linear-gradient(135deg, rgba(255,255,255,0.34), transparent 44%);
opacity: 0;
transition: opacity 320ms var(--ease-premium);
}
.service-card:hover {
transform: translateY(-2px);
border-color: rgba(120, 135, 153, 0.5);
box-shadow: 0 18px 42px rgba(10, 15, 22, 0.11);
}
.service-card:hover::before { opacity: 1; }
.service-card h3,
.service-card p,
.service-card .card-kicker { position: relative; z-index: 1; }
.card-kicker {
text-transform: uppercase;
letter-spacing: 0;
font-size: 0.67rem;
font-weight: 700;
color: #7b6f5d;
}
.service-card-primary {
background:
linear-gradient(170deg, rgba(236, 232, 224, 0.82), rgba(224, 218, 207, 0.66)),
linear-gradient(135deg, rgba(31, 43, 57, 0.08), transparent 52%);
border-color: rgba(128, 142, 159, 0.54);
}
.capability-grid { align-items: stretch; }
.capability-card {
min-height: clamp(250px, 18vw, 360px);
align-content: end;
}
.capability-card h3 { max-width: 16ch; }
.capability-card p { max-width: 35ch; }
.capability-card.service-card-primary {
grid-column: span 1;
}
.homepage-capabilities .capability-grid {
grid-template-columns: minmax(0, 1.34fr) repeat(2, minmax(0, 0.83fr));
gap: 0;
border: 1px solid rgba(126, 141, 158, 0.34);
border-radius: var(--radius-lg);
overflow: hidden;
box-shadow: 0 18px 42px rgba(8, 12, 18, 0.1);
}
.homepage-capabilities .capability-card {
border: 0;
border-radius: 0;
box-shadow: none;
min-height: clamp(280px, 21vw, 420px);
background:
linear-gradient(180deg, rgba(248, 245, 239, 0.78), rgba(235, 229, 219, 0.66));
}
.homepage-capabilities .capability-card + .capability-card {
border-left: 1px solid rgba(126, 141, 158, 0.24);
}
.homepage-capabilities .service-card-primary {
background:
linear-gradient(155deg, rgba(28, 39, 52, 0.92), rgba(38, 50, 65, 0.78)),
linear-gradient(135deg, rgba(232, 220, 202, 0.1), transparent 58%);
}
.homepage-capabilities .service-card-primary h3,
.homepage-capabilities .service-card-primary p { color: rgba(240, 245, 250, 0.9); }
.homepage-capabilities .service-card-primary .card-kicker { color: #d7cbb9; }
.homepage-capabilities .capability-card:hover {
transform: none;
box-shadow: none;
}

.who-section {
padding-bottom: clamp(var(--space-6), 7vw, var(--space-8));
background:
radial-gradient(920px 520px at 8% 18%, rgba(200, 170, 115, 0.12), transparent 70%),
radial-gradient(1120px 620px at 88% 2%, rgba(134, 169, 201, 0.24), transparent 70%),
linear-gradient(180deg, #f7fafb 0%, #ecf3f6 100%);
}

.who-intro h2 {
max-width: 19ch;
}

.audience-group {
display: grid;
gap: clamp(var(--space-3), 2vw, var(--space-4));
}

.audience-group + .audience-group {
margin-top: clamp(var(--space-5), 4.4vw, var(--space-7));
}

.audience-group-heading {
display: flex;
align-items: end;
justify-content: space-between;
gap: var(--space-4);
padding: clamp(var(--space-3), 1.8vw, var(--space-4));
border-radius: 12px;
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(236, 247, 251, 0.48) 54%, rgba(255, 255, 255, 0.68)),
var(--glass-surface);
border: 1px solid var(--glass-blue-edge);
box-shadow: 0 18px 42px rgba(27, 47, 66, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.74);
}

.audience-group-heading h3 {
max-width: 34ch;
color: #17283a;
text-align: right;
}

.audience-grid {
display: grid;
gap: clamp(var(--space-3), 1.8vw, var(--space-4));
align-items: stretch;
}

.audience-grid-residential {
grid-template-columns: minmax(0, 1.28fr) repeat(2, minmax(0, 0.86fr));
}

.audience-grid-commercial {
grid-template-columns: repeat(3, minmax(0, 1fr));
}

.audience-card {
display: grid;
grid-template-rows: auto 1fr;
border-radius: 12px;
overflow: hidden;
background:
linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(238, 247, 251, 0.78));
border: 1px solid rgba(134, 169, 201, 0.25);
box-shadow: 0 18px 42px rgba(27, 47, 66, 0.12);
transition: transform 320ms var(--ease-premium), box-shadow 320ms var(--ease-premium), border-color 320ms var(--ease-premium);
}

.audience-card:hover {
transform: translateY(-6px);
border-color: rgba(46, 79, 115, 0.34);
box-shadow: 0 30px 66px rgba(27, 47, 66, 0.18);
}

.audience-card img {
width: 100%;
aspect-ratio: 16 / 11;
object-fit: cover;
filter: saturate(1.02) contrast(1.06) brightness(0.98);
transition: transform 720ms var(--ease-premium), filter 720ms var(--ease-premium);
}

.audience-card-featured img {
aspect-ratio: 16 / 14;
}

.audience-card:hover img {
transform: scale(1.055);
filter: saturate(1.04) contrast(1.06) brightness(0.98);
}

.audience-card-body {
display: grid;
gap: clamp(var(--space-1), 0.9vw, var(--space-2));
align-content: start;
padding: clamp(var(--space-3), 1.8vw, var(--space-4));
}

.audience-card-featured .audience-card-body {
padding: clamp(var(--space-4), 2.4vw, var(--space-5));
}

.audience-card-body span {
width: fit-content;
padding-bottom: 6px;
box-shadow: inset 0 -2px 0 rgba(200, 170, 115, 0.68);
color: #2e5d83;
font-size: 0.68rem;
font-weight: 800;
line-height: 1;
text-transform: uppercase;
}

.audience-card-body h3 {
color: #162536;
max-width: 20ch;
word-spacing: 0.08em;
line-height: 1.08;
letter-spacing: -0.01em;
}

.audience-card-body p {
color: #526273;
max-width: 42ch;
line-height: 1.58;
}

.who-packages-bridge {
margin-top: clamp(var(--space-5), 4.2vw, var(--space-7));
}

.placeholder-page main {
min-height: calc(100vh - 170px);
display: grid;
place-items: center;
padding-block: clamp(var(--space-7), 12vw, var(--space-8));
}

.placeholder-message {
width: min(100% - (var(--shell-pad) * 2), 820px);
margin-inline: auto;
text-align: center;
}

.placeholder-message p {
font-size: clamp(1.1rem, 0.8vw + 0.94rem, 1.42rem);
color: #24364a;
}

.packages-page main {
padding-bottom: 0;
}

.packages-page .editorial-marker,
.packages-page .card-kicker {
word-spacing: 0.16em;
}

.packages-page {
background:
radial-gradient(1020px 640px at 82% -8%, rgba(134, 169, 201, 0.22), transparent 70%),
radial-gradient(760px 460px at 8% 8%, rgba(200, 170, 115, 0.12), transparent 72%),
linear-gradient(180deg, #f8fbfd 0%, #edf4f7 46%, #f7fafb 100%);
}

.packages-hero {
position: relative;
overflow: hidden;
padding-block: clamp(var(--space-6), 7.2vw, var(--space-8));
background:
linear-gradient(180deg, rgba(248, 251, 253, 0.92), rgba(235, 243, 247, 0.94));
}

.packages-hero::before {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background:
radial-gradient(980px 560px at 76% 18%, rgba(46, 79, 115, 0.12), transparent 68%),
linear-gradient(90deg, rgba(255, 255, 255, 0.34), transparent 58%);
}

.packages-hero-grid {
position: relative;
z-index: 1;
display: grid;
grid-template-columns: minmax(0, 0.92fr) minmax(500px, 1.08fr);
gap: clamp(var(--space-5), 5.4vw, var(--space-8));
align-items: center;
}

.packages-hero-copy {
display: grid;
gap: clamp(var(--space-3), 1.8vw, var(--space-4));
max-width: 720px;
}

.packages-hero-copy h1 {
max-width: 12ch;
color: #111f2d;
font-size: clamp(2.72rem, 4.28vw + 0.82rem, 5.78rem);
line-height: 0.96;
letter-spacing: -0.04em;
}

.packages-hero-copy .lead {
max-width: 53ch;
font-size: clamp(1.02rem, 0.28vw + 0.96rem, 1.2rem);
color: #4f6072;
line-height: 1.66;
}

.packages-hero-visual {
position: relative;
min-height: clamp(420px, 38vw, 660px);
display: grid;
grid-template-columns: minmax(0, 1fr) minmax(180px, 0.34fr);
gap: clamp(10px, 1.2vw, 16px);
padding: clamp(8px, 1vw, 12px);
border-radius: 18px;
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.68), rgba(235, 246, 251, 0.46)),
rgba(255, 255, 255, 0.42);
border: 1px solid rgba(255, 255, 255, 0.66);
box-shadow: 0 34px 82px rgba(18, 34, 50, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.78);
backdrop-filter: blur(18px) saturate(118%);
}

.packages-hero-visual figure {
position: relative;
margin: 0;
overflow: hidden;
border-radius: 13px;
background: #dfe8ee;
box-shadow: inset 0 0 0 1px rgba(255,255,255,0.16);
}

.packages-hero-visual figure::after,
.pricing-media::after {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background:
linear-gradient(180deg, transparent 52%, rgba(7, 12, 18, 0.34)),
linear-gradient(135deg, rgba(255,255,255,0.12), transparent 42%);
}

.hero-visual-main img,
.hero-visual-stack img {
width: 100%;
height: 100%;
object-fit: cover;
filter: saturate(0.98) contrast(1.05) brightness(0.92);
}

.hero-visual-main img { object-position: center 48%; }
.hero-visual-stack {
display: grid;
gap: clamp(10px, 1.2vw, 16px);
}
.hero-visual-stack figure:first-child img { object-position: center 46%; }
.hero-visual-stack figure:last-child img { object-position: center 52%; }

.packages-intro h2 { max-width: 18ch; }

.pricing-section {
background:
linear-gradient(180deg, #edf4f7 0%, #f8fbfd 100%);
}

.section-heading {
display: grid;
gap: var(--space-2);
margin-bottom: clamp(var(--space-4), 3vw, var(--space-5));
}

.section-heading h2 {
max-width: 22ch;
color: #17283a;
}

.section-heading p {
max-width: 64ch;
}

.pricing-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: clamp(var(--space-3), 1.6vw, var(--space-4));
align-items: stretch;
grid-auto-rows: auto;
}

.pricing-card {
position: relative;
overflow: hidden;
display: grid;
grid-template-rows: auto 1fr;
height: 100%;
min-height: clamp(500px, 31vw, 570px);
border-radius: 14px;
background:
linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(239, 247, 251, 0.84));
border: 1px solid rgba(134, 169, 201, 0.28);
box-shadow: 0 20px 48px rgba(27, 47, 66, 0.11), inset 0 1px 0 rgba(255,255,255,0.74);
transition: transform 320ms var(--ease-premium), box-shadow 320ms var(--ease-premium), border-color 320ms var(--ease-premium);
}

.pricing-card:hover {
transform: translateY(-5px);
border-color: rgba(46, 79, 115, 0.34);
box-shadow: 0 32px 68px rgba(27, 47, 66, 0.17), inset 0 1px 0 rgba(255,255,255,0.78);
}

.pricing-card::before,
.combination-card::before,
.simple-steps article::before,
.packages-cta::before {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background: linear-gradient(135deg, rgba(255,255,255,0.44), transparent 46%);
opacity: 0.52;
}

.pricing-card > *,
.combination-card > *,
.simple-steps article > *,
.packages-cta > * {
position: relative;
z-index: 1;
}

.pricing-card-muted {
grid-column: 1 / -1;
grid-template-columns: minmax(220px, 0.34fr) minmax(0, 1fr);
grid-template-rows: 1fr;
height: auto;
min-height: 220px;
opacity: 0.86;
background:
linear-gradient(180deg, rgba(252, 253, 253, 0.92), rgba(242, 247, 249, 0.78));
}

.pricing-media {
position: relative;
margin: 0;
overflow: hidden;
background: #dfe8ee;
}

.pricing-media img {
width: 100%;
aspect-ratio: 16 / 10.4;
object-fit: cover;
object-position: center 48%;
filter: saturate(0.96) contrast(1.05) brightness(0.92);
transition: transform 720ms var(--ease-premium), filter 720ms var(--ease-premium);
}

.pricing-card:hover .pricing-media img {
transform: scale(1.055);
filter: saturate(1.04) contrast(1.06) brightness(0.97);
}

.pricing-card:nth-child(3) .pricing-media img { object-position: center 52%; }
.pricing-card:nth-child(4) .pricing-media img { object-position: center 48%; filter: saturate(0.92) contrast(1.03) brightness(0.92); }

.pricing-card-body {
display: grid;
gap: var(--space-2);
align-content: start;
grid-template-rows: auto auto 1fr auto;
padding: clamp(var(--space-3), 1.7vw, var(--space-4));
}

.pricing-card-muted .pricing-card-body {
align-content: center;
grid-template-rows: auto auto 1fr;
}

.pricing-card-top {
display: grid;
gap: var(--space-1);
padding: 0 0 var(--space-2);
border-bottom: 1px solid rgba(46, 79, 115, 0.13);
}

.price-line {
color: #24364a;
font-weight: 700;
font-size: clamp(0.92rem, 0.14vw + 0.9rem, 1.02rem);
}

.price-line strong {
display: block;
margin-top: 5px;
color: #142235;
font-size: clamp(1.7rem, 1.08vw + 1rem, 2.34rem);
line-height: 0.98;
letter-spacing: -0.04em;
}

.pricing-card-body h3,
.combination-card h3,
.simple-steps h3 {
color: #162536;
}

.pricing-card-body p {
color: #526273;
}

.pricing-note {
margin-top: var(--space-1);
padding-top: var(--space-2);
border-top: 1px solid rgba(46, 79, 115, 0.12);
font-weight: 700;
color: #33485e;
}

.simple-estimate-section {
background:
radial-gradient(760px 430px at 12% 0%, rgba(200, 170, 115, 0.1), transparent 72%),
linear-gradient(180deg, #f8fbfd 0%, #eef5f8 100%);
}

.simple-estimate-heading {
max-width: 900px;
}

.simple-steps {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: clamp(var(--space-3), 1.8vw, var(--space-4));
}

.simple-steps article,
.combination-card,
.packages-cta {
position: relative;
overflow: hidden;
border-radius: 14px;
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.84), rgba(242, 249, 252, 0.66) 58%, rgba(255, 255, 255, 0.74));
border: 1px solid rgba(134, 169, 201, 0.24);
box-shadow: 0 16px 36px rgba(27, 47, 66, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.simple-steps article {
display: grid;
gap: var(--space-1);
min-height: 210px;
padding: clamp(var(--space-4), 2.2vw, var(--space-5));
}

.simple-steps article span {
width: fit-content;
color: #8f7651;
font-size: 0.72rem;
font-weight: 800;
box-shadow: inset 0 -2px 0 rgba(200, 170, 115, 0.62);
padding-bottom: 6px;
}

.combinations-section {
background:
linear-gradient(180deg, #eef5f8 0%, #f8fbfd 100%);
}

.combination-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: clamp(var(--space-3), 1.8vw, var(--space-4));
}

.combination-card {
display: grid;
gap: var(--space-2);
align-content: start;
grid-template-columns: minmax(96px, 0.32fr) minmax(0, 1fr);
align-items: center;
min-height: clamp(190px, 12vw, 230px);
padding: clamp(var(--space-3), 1.7vw, var(--space-4));
}

.combination-thumb {
position: relative;
margin: 0;
overflow: hidden;
border-radius: 10px;
background: #dfe8ee;
box-shadow: 0 12px 26px rgba(27, 47, 66, 0.12), inset 0 0 0 1px rgba(255,255,255,0.24);
}

.combination-thumb::after {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background: linear-gradient(180deg, transparent 42%, rgba(8, 14, 21, 0.2));
}

.combination-thumb img {
width: 100%;
aspect-ratio: 1 / 1;
object-fit: cover;
filter: saturate(0.94) contrast(1.04) brightness(0.92);
}

.combination-copy {
display: grid;
gap: var(--space-2);
}

.combination-card p,
.simple-steps p {
max-width: 34ch;
}

.packages-cta-section {
padding-top: clamp(var(--space-4), 4vw, var(--space-6));
}

.packages-cta {
display: flex;
align-items: center;
justify-content: space-between;
gap: var(--space-4);
padding: clamp(var(--space-4), 3vw, var(--space-6));
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.8), rgba(236, 247, 252, 0.52) 52%, rgba(255, 255, 255, 0.72)),
linear-gradient(135deg, rgba(200, 170, 115, 0.12), transparent 56%);
}

.packages-cta div {
display: grid;
gap: var(--space-2);
max-width: 720px;
}

.packages-cta .btn {
flex: 0 0 auto;
}

@media (max-width: 1120px) {
  .packages-hero-grid { grid-template-columns: 1fr; }
  .packages-hero-visual { min-height: 560px; grid-template-columns: minmax(0, 1fr) minmax(150px, 0.34fr); }
  .simple-steps { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .packages-hero { padding-block: clamp(var(--space-5), 12vw, var(--space-7)); }
  .packages-hero-grid { gap: var(--space-5); }
  .packages-hero-copy h1 { font-size: clamp(2.3rem, 10vw, 3.25rem); max-width: 9ch; }
  .packages-hero-visual { min-height: 430px; grid-template-columns: 1fr; }
  .hero-visual-stack { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-visual-stack figure { min-height: 112px; }
  .pricing-grid,
  .simple-steps,
  .combination-grid { grid-template-columns: 1fr; }
  .pricing-card { min-height: 0; border-radius: 12px; }
  .pricing-media img { aspect-ratio: 16 / 10; }
  .pricing-card-body,
  .simple-steps article,
  .combination-card { padding: var(--space-4); }
  .simple-steps article { min-height: 0; }
  .packages-cta { display: grid; align-items: start; border-radius: 12px; }
}

#why-3d-tours {
background:
radial-gradient(900px 520px at 15% 4%, rgba(134, 169, 201, 0.2), transparent 68%),
linear-gradient(180deg, #f6f9fb 0%, #eaf2f6 100%);
}
#why-3d-tours .eyebrow { color: #2e5d83; }
#why-3d-tours h2 { color: var(--brand-ink); }
#why-3d-tours p,
#why-3d-tours li,
#why-3d-tours strong { color: #586879; }
#why-3d-tours strong { color: #203247; }

.story-grid {
display: grid;
grid-template-columns: minmax(0, 1.28fr) minmax(320px, 0.72fr);
gap: clamp(var(--space-4), 3.2vw, var(--space-6));
align-items: stretch;
}
#why-3d-tours .story-grid {
grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.85fr);
align-items: center;
}
.story-media {
position: relative;
margin: 0;
border-radius: var(--radius-lg);
overflow: hidden;
min-height: clamp(330px, 40vw, 680px);
box-shadow: var(--shadow-deep);
}
.story-media::after {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background: linear-gradient(180deg, transparent 48%, rgba(7, 11, 16, 0.28));
}
.story-media img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: center 45%;
filter: saturate(0.98) contrast(1.05) brightness(0.9);
transform: translate3d(0, var(--scroll-y, 0px), 0) scale(var(--scroll-scale, 1.02));
transition: transform 720ms var(--ease-premium), filter 720ms var(--ease-premium);
will-change: transform;
}
.story-grid:hover .story-media img {
transform: translate3d(0, var(--scroll-y, 0px), 0) scale(1.045);
filter: saturate(1.04) contrast(1.06) brightness(0.94);
}
.story-copy {
padding: clamp(var(--space-4), 2.5vw, var(--space-5));
border-radius: var(--radius-md);
background: linear-gradient(180deg, rgba(28, 39, 52, 0.78), rgba(20, 28, 38, 0.74));
border: 1px solid rgba(200, 212, 226, 0.18);
display: grid;
gap: var(--space-3);
align-content: center;
box-shadow: inset 0 1px 0 rgba(244, 248, 252, 0.08);
}
#why-3d-tours .story-copy {
position: relative;
margin-left: clamp(-80px, -4vw, -38px);
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(238, 247, 251, 0.5) 52%, rgba(255, 255, 255, 0.68));
border-color: var(--glass-blue-edge);
box-shadow: 0 26px 60px rgba(27, 47, 66, 0.13), inset 0 1px 0 rgba(255, 255, 255, 0.74);
backdrop-filter: blur(18px) saturate(118%);
transform: translate3d(0, var(--scroll-y, 0px), 0);
will-change: transform;
}
#why-3d-tours .story-copy h2 {
max-width: 11ch;
}
.story-list { margin: 0; padding: 0; list-style: none; display: grid; gap: var(--space-3); }
.story-list li {
padding-top: var(--space-3);
border-top: 1px solid rgba(46, 79, 115, 0.14);
}
.story-list li:first-child { padding-top: 0; border-top: 0; }

.tours-intro { margin-bottom: clamp(var(--space-4), 2.5vw, var(--space-5)); }
.tour-grid {
display: grid;
grid-template-columns: 1.18fr 0.91fr 0.91fr;
gap: clamp(var(--space-3), 1.8vw, var(--space-4));
}
.tour-showcase .tour-grid {
grid-template-columns: minmax(0, 1.26fr) repeat(2, minmax(0, 0.87fr));
align-items: stretch;
}
.tour-card {
border-radius: 12px;
overflow: hidden;
background:
linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(239, 247, 250, 0.84));
border: 1px solid rgba(134, 169, 201, 0.22);
box-shadow: 0 16px 36px rgba(27, 47, 66, 0.1);
transition: transform 320ms var(--ease-premium), box-shadow 320ms var(--ease-premium), border-color 320ms var(--ease-premium);
}
.tour-card:hover {
transform: translateY(-6px);
border-color: rgba(121, 136, 153, 0.52);
box-shadow: 0 28px 58px rgba(27, 47, 66, 0.18);
}
.tour-card img {
width: 100%;
aspect-ratio: 16 / 11;
object-fit: cover;
filter: saturate(0.94) contrast(1.05) brightness(0.9);
transition: transform 680ms var(--ease-premium), filter 680ms var(--ease-premium);
}
.tour-card:hover img {
transform: scale(1.06);
filter: saturate(1.06) contrast(1.06) brightness(0.96);
}
.tour-card:nth-child(1) img { object-position: center 40%; }
.tour-card:nth-child(2) img { object-position: center 47%; }
.tour-card:nth-child(3) img { object-position: center 49%; }
.tour-body { padding: clamp(var(--space-3), 1.8vw, var(--space-4)); display: grid; gap: clamp(var(--space-1), 0.9vw, var(--space-2)); }
.tour-body p { max-width: 38ch; line-height: 1.58; }
.tour-showcase .tour-card {
display: grid;
grid-template-rows: auto 1fr;
}
.tour-showcase .tour-card:first-child {
grid-row: span 2;
}
.tour-showcase .tour-card:first-child img {
aspect-ratio: 16 / 14;
}
.tour-showcase .tour-card:first-child .tour-body {
padding: clamp(var(--space-4), 2.4vw, var(--space-5));
}
.section-bridge {
margin-top: clamp(var(--space-4), 3vw, var(--space-6));
padding: clamp(var(--space-3), 2vw, var(--space-4));
border: 1px solid rgba(255, 255, 255, 0.38);
border-radius: var(--radius-md);
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(235, 247, 252, 0.56) 52%, rgba(255, 255, 255, 0.74));
box-shadow: 0 16px 36px rgba(27, 47, 66, 0.09), inset 0 1px 0 rgba(255, 255, 255, 0.62);
display: flex;
align-items: center;
justify-content: space-between;
gap: var(--space-3);
}
.section-bridge p {
max-width: 52ch;
color: #4f5c6b;
}
.section-bridge .btn {
flex: 0 0 auto;
}

.contact-grid {
display: grid;
grid-template-columns: minmax(0, 0.92fr) minmax(420px, 1.08fr);
gap: clamp(var(--space-4), 2.8vw, var(--space-6));
align-items: stretch;
}
.consultation-section {
padding-top: clamp(var(--space-6), 6.4vw, var(--space-8));
}
.consultation-section .contact-grid {
align-items: stretch;
}
.contact-copy {
display: grid;
gap: var(--space-3);
align-content: start;
height: 100%;
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(236, 247, 252, 0.62) 46%, rgba(255, 255, 255, 0.82)),
linear-gradient(135deg, rgba(31, 43, 57, 0.08), transparent 54%);
border: 1px solid rgba(134, 169, 201, 0.24);
box-shadow: 0 22px 48px rgba(27, 47, 66, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.72);
}
.contact-detail-card {
display: grid;
gap: var(--space-2);
padding: clamp(var(--space-2), 2.2vw, var(--space-3));
border-radius: var(--radius-md);
border: 1px solid rgba(134, 169, 201, 0.22);
background: rgba(255, 255, 255, 0.54);
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.68);
}
.contact-detail-card h3 {
margin: 0;
font-size: clamp(1.05rem, 1.5vw, 1.24rem);
letter-spacing: 0;
}
.contact-detail-card p {
margin: 0;
max-width: 58ch;
}
.contact-chips {
list-style: none;
display: flex;
flex-wrap: wrap;
gap: 8px;
margin: 0;
padding: 0;
}
.contact-chips li {
display: inline-flex;
align-items: center;
border: 1px solid rgba(74, 99, 130, 0.18);
border-radius: 999px;
background: rgba(244, 248, 251, 0.82);
color: #344253;
font-size: 0.78rem;
font-weight: 700;
letter-spacing: 0.01em;
padding: 7px 10px;
}
.surface-elevated {
background: linear-gradient(180deg, rgba(244, 240, 232, 0.72), rgba(233, 226, 214, 0.64));
border: 1px solid rgba(162, 174, 188, 0.46);
border-radius: var(--radius-md);
box-shadow: 0 8px 18px rgba(8, 12, 18, 0.1);
}
.contact-meta {
display: grid;
gap: var(--space-1);
padding-top: var(--space-1);
}
.contact-meta p {
margin: 0;
font-size: 0.95rem;
display: flex;
flex-wrap: wrap;
gap: 0 0.34em;
}
.contact-meta strong { color: #344253; font-weight: 700; }
.contact-meta a {
font-weight: 700;
}

.form-block {
display: grid;
align-content: start;
height: 100%;
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(237, 248, 252, 0.66) 48%, rgba(255, 255, 255, 0.84));
border: 1px solid rgba(134, 169, 201, 0.26);
border-radius: var(--radius-md);
padding: clamp(var(--space-3), 2.6vw, var(--space-4));
box-shadow: 0 24px 54px rgba(27, 47, 66, 0.13), inset 0 1px 0 rgba(255, 255, 255, 0.76);
}
.form-support {
margin: 0 0 var(--space-3);
color: #5f6b7a;
font-size: 0.95rem;
line-height: 1.65;
}
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-3); }
.field { display: grid; gap: var(--space-1); }
.field.full { grid-column: 1 / -1; }
.form-status {
margin: 0;
font-size: 0.88rem;
color: #5f6b7a;
min-height: 1.2em;
}
label { color: #344253; font-size: 0.9rem; font-weight: 600; }
input, select, textarea, button { font: inherit; }
input, select, textarea {
border: 1px solid rgba(125, 145, 166, 0.48);
background: rgba(255,255,255,0.72);
color: #253140;
border-radius: var(--radius-sm);
padding: 10px 11px;
}
input:focus,
select:focus,
textarea:focus {
border-color: rgba(74, 99, 130, 0.72);
box-shadow: 0 0 0 3px rgba(74, 99, 130, 0.12);
outline: none;
}
textarea { min-height: 124px; resize: vertical; }

.site-footer {
border-top: 1px solid rgba(152, 165, 179, 0.24);
background: linear-gradient(180deg, rgba(248, 251, 253, 0.82), rgba(235, 242, 245, 0.88));
padding-block: var(--space-4) var(--space-5);
}
.footer-inner {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
gap: var(--space-2);
color: #6a7788;
font-size: 0.84rem;
}

.reveal { opacity: 1; transform: none; clip-path: inset(0 0 0 0 round 0); }
.js .reveal {
opacity: 1;
transform: none;
transition: opacity 820ms var(--ease-premium), transform 820ms var(--ease-premium), clip-path 920ms var(--ease-premium);
clip-path: inset(0 0 0 0 round 0);
}
.js .reveal.is-visible {
opacity: 1;
transform: none;
clip-path: inset(0 0 0 0 round 0);
}

.js .home-page .reveal:nth-of-type(2) { transition-delay: 80ms; }
.js .home-page .reveal:nth-of-type(3) { transition-delay: 120ms; }
.js .home-page .reveal:nth-of-type(4) { transition-delay: 160ms; }

.js .hero-content > *,
.js .hero-media-strip,
.js .editorial-media,
.js .editorial-panel,
.js .story-media,
.js .story-copy,
.js .service-panel,
.js .tour-card,
.js .section-bridge,
.js .contact-copy,
.js .form-block {
opacity: 1;
transform: none;
transition: opacity 820ms var(--ease-premium), transform 820ms var(--ease-premium), clip-path 900ms var(--ease-premium);
}

.js .hero.is-visible .hero-content > *,
.js .hero.is-visible .hero-media-strip,
.js .reveal.is-visible .editorial-media,
.js .reveal.is-visible .editorial-panel,
.js .reveal.is-visible .story-media,
.js .reveal.is-visible .story-copy,
.js .reveal.is-visible .service-panel,
.js .reveal.is-visible .tour-card,
.js .reveal.is-visible .section-bridge,
.js .reveal.is-visible .contact-copy,
.js .reveal.is-visible .form-block {
opacity: 1;
transform: none;
}

.js .hero-media-strip,
.js .editorial-media,
.js .story-media,
.js .service-panel,
.js .tour-card {
clip-path: inset(0 0 0 0 round 12px);
}

.js .hero.is-visible .hero-media-strip,
.js .reveal.is-visible .editorial-media,
.js .reveal.is-visible .story-media,
.js .reveal.is-visible .service-panel,
.js .reveal.is-visible .tour-card {
clip-path: inset(0 0 0 0 round 12px);
}

.js .hero.is-visible .hero-content > :nth-child(1) { transition-delay: 120ms; }
.js .hero.is-visible .hero-content > :nth-child(2) { transition-delay: 220ms; }
.js .hero.is-visible .hero-content > :nth-child(3) { transition-delay: 330ms; }
.js .hero.is-visible .hero-content > :nth-child(4) { transition-delay: 420ms; }
.js .hero.is-visible .hero-content > :nth-child(5) { transition-delay: 520ms; }
.js .hero.is-visible .hero-media-strip { transition-delay: 660ms; }
.js .reveal.is-visible .service-panel:nth-child(2) { transition-delay: 90ms; }
.js .reveal.is-visible .service-panel:nth-child(3) { transition-delay: 160ms; }
.js .reveal.is-visible .service-panel:nth-child(4) { transition-delay: 230ms; }
.js .reveal.is-visible .tour-card:nth-child(2) { transition-delay: 110ms; }
.js .reveal.is-visible .tour-card:nth-child(3) { transition-delay: 190ms; }

@keyframes heroDrift {
from { transform: scale(1.015) translate3d(0, 0, 0); }
to { transform: scale(1.045) translate3d(-0.8%, -0.6%, 0); }
}

@media (min-width: 2000px) {
.hero-content { max-width: min(56ch, 42%); }
}

@media (max-width: 1400px) {
.split-intro { grid-template-columns: 1fr 1fr; }
.service-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 1120px) {
.hero { min-height: 80vh; }
.hero-content { max-width: 62ch; }
.hero-content-wrap {
grid-template-columns: 1fr;
align-items: start;
}
.hero-media-strip {
max-width: 680px;
}
.split-intro { grid-template-columns: 1fr; gap: var(--space-3); }
.editorial-intro h2 { max-width: 22ch; }
.service-grid { grid-template-columns: 1fr; }
.services-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.service-panel-featured { grid-row: auto; }
.service-panel-featured .service-media img { aspect-ratio: 16 / 11; }
.estimate-grid { grid-template-columns: 1fr; }
.pricing-grid,
.combination-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.factor-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.audience-grid-residential,
.audience-grid-commercial { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.audience-card-featured img { aspect-ratio: 16 / 11; }
.homepage-capabilities .capability-grid { grid-template-columns: 1fr; }
.homepage-capabilities .capability-card + .capability-card {
border-left: 0;
border-top: 1px solid rgba(126, 141, 158, 0.24);
}
.capability-card { min-height: 0; align-content: start; }
.story-grid { grid-template-columns: 1fr; }
#why-3d-tours .story-grid { grid-template-columns: 1fr; }
#why-3d-tours .story-copy { margin-left: 0; }
.editorial-spread { grid-template-columns: 1fr; }
.editorial-panel h2 { max-width: 20ch; }
.contact-grid { grid-template-columns: 1fr; }
.tour-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.tour-showcase .tour-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.tour-showcase .tour-card:first-child { grid-row: auto; }
.tour-showcase .tour-card:first-child img { aspect-ratio: 16 / 11; }
}

@media (max-width: 960px) {
.nav-toggle { display: inline-flex; }
.site-nav {
position: absolute;
top: calc(100% + 10px);
right: 10px;
width: min(324px, calc(100vw - 18px));
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.05) 46%, rgba(46, 79, 115, 0.14)),
linear-gradient(165deg, rgba(15, 22, 31, 0.98), rgba(18, 27, 38, 0.96));
border: 1px solid rgba(228, 236, 245, 0.3);
border-radius: 12px;
box-shadow: 0 22px 54px rgba(3, 6, 10, 0.54), inset 0 1px 0 rgba(255, 255, 255, 0.12);
backdrop-filter: blur(18px) saturate(122%);
opacity: 0;
visibility: hidden;
pointer-events: none;
transform: translateY(-4px);
transition: opacity 180ms var(--ease), transform 180ms var(--ease), visibility 0s linear 180ms;
}
.site-nav.open {
opacity: 1;
visibility: visible;
pointer-events: auto;
transform: translateY(0);
transition: opacity 180ms var(--ease), transform 180ms var(--ease);
}
.nav-open .hero-content {
opacity: 0.18;
filter: blur(1px);
transition: opacity 180ms var(--ease), filter 180ms var(--ease);
}
.nav-open .hero-media-strip {
opacity: 0.22;
filter: blur(1px);
transition: opacity 180ms var(--ease), filter 180ms var(--ease);
}
.site-nav ul { flex-direction: column; align-items: stretch; gap: 3px; padding: 10px; }
.site-nav a { min-height: 44px; justify-content: flex-start; padding-inline: 13px; color: #e9eff6; border-radius: 9px; }

.section { padding-block: clamp(var(--space-5), 8vw, var(--space-6)); }
.hero { min-height: 82vh; margin-bottom: var(--space-3); }
.hero-content-wrap { padding-bottom: clamp(var(--space-5), 9vh, var(--space-7)); }
.hero-content { gap: var(--space-3); }
.glass-focus { padding: clamp(var(--space-3), 5vw, var(--space-4)); }
}

@media (max-width: 760px) {
.shell { width: min(100% - 24px, var(--shell-max)); }
.nav-wrap { min-height: 58px; }
.brand-logo { height: 30px; max-height: 30px; max-width: 166px; }
.brand-link { padding: 2px 6px; border-radius: 10px; }

h1 {
font-size: clamp(2rem, 8.1vw, 2.72rem);
line-height: 0.98;
letter-spacing: 0;
}
h2 {
font-size: clamp(1.25rem, 4.4vw, 1.62rem);
line-height: 1.17;
}

.hero {
min-height: 760px;
align-items: start;
}
.hero-stage img { object-position: 54% 43%; }
.hero-content-wrap {
padding-top: clamp(112px, 17vh, 144px);
padding-bottom: 0;
gap: var(--space-4);
}
.hero-content { max-width: 100%; }
.hero-content h1 { max-width: 9.5ch; }
.hero-content .eyebrow { font-size: 0.68rem; }
.hero-content .lead {
max-width: 32ch;
font-size: 0.96rem;
line-height: 1.56;
}
.hero-trust-line { display: none; }
.hero-content.glass-focus {
padding-left: var(--space-3);
border-left-width: 1px;
}
.actions {
display: grid;
grid-template-columns: 1fr;
gap: 10px;
max-width: 100%;
}
.hero-media-strip {
margin-top: clamp(76px, 17vh, 136px);
grid-template-columns: 1fr;
gap: 8px;
padding: 8px;
border-radius: 14px;
background: rgba(248, 251, 253, 0.86);
box-shadow: 0 18px 44px rgba(7, 12, 18, 0.2);
}
.hero-media-strip article {
min-height: 88px;
}
.hero-media-strip article:nth-child(n+2) { display: none; }
.editorial-intro { padding-bottom: var(--space-3); }
.editorial-intro h2 { max-width: 100%; }
.editorial-intro p { max-width: 100%; }
.editorial-media { min-height: 300px; }
.editorial-panel { padding: var(--space-4); }
.editorial-panel h2 { max-width: 100%; }

.tour-grid { grid-template-columns: 1fr; }
.tour-showcase .tour-grid { grid-template-columns: 1fr; }
.services-grid { grid-template-columns: 1fr; }
.packages-hero {
padding-block: clamp(var(--space-6), 14vw, var(--space-7)) clamp(var(--space-5), 12vw, var(--space-6));
}
.packages-hero-copy h1 {
font-size: clamp(2.28rem, 10vw, 3.2rem);
max-width: 9ch;
}
.packages-hero-copy .actions {
max-width: none;
}
.pricing-card,
.factor-grid article,
.combination-card,
.packages-cta {
border-radius: 10px;
}
.pricing-grid,
.factor-grid,
.combination-grid {
grid-template-columns: 1fr;
}
.pricing-card {
min-height: 410px;
}
.pricing-card-top,
.pricing-card-body,
.factor-grid article,
.combination-card {
padding: var(--space-4);
}
.price-line strong {
font-size: clamp(2rem, 10vw, 2.72rem);
}
.combination-card {
min-height: 0;
}
.packages-cta {
display: grid;
align-items: start;
}
.audience-grid-residential,
.audience-grid-commercial { grid-template-columns: 1fr; }
.audience-group-heading {
display: grid;
align-items: start;
gap: var(--space-2);
}
.audience-group-heading h3 {
max-width: 100%;
text-align: left;
}
.audience-card-body,
.audience-card-featured .audience-card-body {
padding: var(--space-4);
}
.service-content,
.service-panel-featured .service-content {
padding: var(--space-4);
}
.homepage-capabilities .capability-card {
min-height: 0;
padding-block: var(--space-4);
}
.section-bridge {
display: grid;
align-items: start;
}
.contact-copy,
.form-block {
padding: var(--space-3);
}
.contact-detail-card {
padding: var(--space-3);
}
.contact-chips {
gap: 7px;
}
.contact-chips li {
font-size: 0.76rem;
padding: 6px 9px;
}
.form-support {
margin-bottom: var(--space-2);
font-size: 0.9rem;
}
.form-grid { grid-template-columns: 1fr; gap: var(--space-2); }
.btn { width: 100%; }

.footer-inner { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 760px) {
  .packages-page .site-header {
    position: relative;
    top: auto;
  }
  .packages-page .packages-hero {
    padding-top: clamp(96px, 22vw, 124px);
  }
  .packages-page .packages-hero-grid {
    gap: var(--space-4);
  }
  .packages-page .packages-hero-visual {
    min-height: 380px;
  }
  .packages-page .pricing-card {
    min-height: 0;
  }
  .packages-page .pricing-card-body {
    padding: 14px var(--space-3) var(--space-3);
    gap: 8px;
  }
  .packages-page .pricing-card-top {
    padding: 0 0 10px;
  }
  .packages-page .pricing-media img {
    aspect-ratio: 16 / 8.2;
  }
  .packages-page .price-line strong {
    font-size: clamp(1.76rem, 7.5vw, 2.22rem);
  }
  .packages-page .pricing-note {
    margin-top: 0;
    padding-top: 10px;
  }
  .packages-page .pricing-card-muted {
    grid-template-columns: 1fr;
    min-height: 0;
  }
  .packages-page .pricing-card-muted .pricing-media img {
    aspect-ratio: 16 / 7.4;
  }
  .packages-page .simple-steps article,
  .packages-page .combination-card {
    padding: var(--space-3) var(--space-3) calc(var(--space-3) + 2px);
  }
  .packages-page .combination-card {
    grid-template-columns: 94px minmax(0, 1fr);
    gap: clamp(var(--space-3), 4.5vw, var(--space-4));
    align-items: center;
  }
  .packages-page .combination-thumb img {
    aspect-ratio: 1 / 1;
  }
}


.hp-field { position: absolute !important; left: -10000px !important; width: 1px; height: 1px; overflow: hidden; }

.form-status[data-state="pending"] { color: #5f6b7a; }
.form-status[data-state="success"] { color: #2f4a64; }
.form-status[data-state="error"] { color: #8b2f2f; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .js .reveal {
    opacity: 1;
    transform: none;
  }
  .hero-stage img,
  .editorial-spread:hover .editorial-media img,
  .story-grid:hover .story-media img,
  .service-panel:hover .service-media img,
  .tour-card:hover img {
    transform: none;
  }
}

/* Learning Hub / SEO-AEO Slice 1 */
.learning-page main {
  padding-bottom: var(--space-7);
}

.learning-hero,
.learning-article-hero {
  position: relative;
  overflow: hidden;
  padding-top: clamp(var(--space-6), 8vw, var(--space-8));
  background:
    radial-gradient(760px 420px at 88% 2%, rgba(134, 169, 201, 0.18), transparent 70%),
    radial-gradient(620px 360px at 8% 14%, rgba(200, 170, 115, 0.11), transparent 68%),
    linear-gradient(180deg, rgba(248, 251, 253, 0.9), rgba(239, 245, 247, 0.72));
}

.learning-hero::after,
.learning-article-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(46, 79, 115, 0.2), transparent);
}

.learning-hero-grid,
.learning-article-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.52fr);
  gap: clamp(var(--space-4), 5vw, var(--space-7));
  align-items: start;
}

.learning-hero-copy,
.learning-article-grid > div:first-child {
  display: grid;
  gap: var(--space-3);
  max-width: 900px;
}

.learning-hero-copy h1,
.learning-article-grid h1 {
  max-width: 17ch;
  color: var(--brand-ink);
}

.learning-article-grid h1 { max-width: 20ch; }
.learning-hero-copy .lead,
.learning-article-grid .lead { max-width: 66ch; color: #4f5d6d; }
.editorial-secondary-link { align-self: center; }

.guide-index-panel,
.article-summary {
  align-self: stretch;
  display: grid;
  gap: var(--space-3);
  align-content: center;
  padding: clamp(var(--space-4), 3vw, var(--space-5));
  border-left: 1px solid rgba(46, 79, 115, 0.16);
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.52), rgba(247, 250, 252, 0.28)),
    linear-gradient(145deg, rgba(201, 170, 115, 0.06), transparent 52%);
  box-shadow: 0 18px 42px rgba(20, 34, 48, 0.08);
  backdrop-filter: blur(14px) saturate(118%);
}

.guide-focus-list {
  display: grid;
  gap: var(--space-3);
  margin: 0;
  padding: 0;
  list-style: none;
}
.guide-focus-list li {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: var(--space-1) var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid rgba(46, 79, 115, 0.13);
}
.guide-focus-list li:first-child { padding-top: 0; border-top: 0; }
.guide-focus-list span {
  grid-row: span 2;
  color: var(--brand-brass);
  font-size: 0.78rem;
  font-weight: 800;
}
.guide-focus-list strong { color: var(--brand-ink); }
.guide-focus-list p { max-width: 38ch; color: #566170; line-height: 1.58; }

.guide-hero-media,
.guide-card-media,
.article-hero-media {
  position: relative;
  overflow: hidden;
  margin: 0;
  border: 1px solid rgba(46, 79, 115, 0.14);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.4);
}

.guide-hero-media,
.article-hero-media {
  aspect-ratio: 16 / 10;
  box-shadow: 0 18px 44px rgba(20, 34, 48, 0.11);
}

.guide-card-media {
  aspect-ratio: 16 / 10;
  margin: calc(clamp(var(--space-4), 3vw, var(--space-5)) * -1) calc(clamp(var(--space-4), 3vw, var(--space-5)) * -1) var(--space-3);
  border-width: 0 0 1px;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.guide-hero-media img,
.guide-card-media img,
.article-hero-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.98) contrast(1.05) brightness(0.96);
}

.learning-card .guide-card-media img {
  transition: transform 360ms ease;
}

.learning-card:hover .guide-card-media img {
  transform: scale(1.025);
}

.featured-guide-card .guide-card-media {
  border-color: rgba(233, 239, 246, 0.14);
}

@media (prefers-reduced-motion: reduce) {
  .learning-card .guide-card-media img {
    transition: none;
  }

  .learning-card:hover .guide-card-media img {
    transform: none;
  }
}

.learning-card-section { padding-top: clamp(var(--space-5), 5vw, var(--space-7)); }
.learning-card-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) repeat(2, minmax(0, 0.84fr));
  gap: clamp(var(--space-3), 2.1vw, var(--space-4));
}

.learning-card,
.comparison-grid article {
  position: relative;
  display: grid;
  align-content: start;
  gap: var(--space-3);
  min-height: clamp(260px, 18vw, 350px);
  padding: clamp(var(--space-4), 3vw, var(--space-5));
  border: 1px solid rgba(46, 79, 115, 0.14);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.84), rgba(238, 245, 248, 0.62)),
    linear-gradient(180deg, rgba(200, 170, 115, 0.08), transparent);
  box-shadow: 0 18px 44px rgba(20, 34, 48, 0.09);
}
.featured-guide-card {
  min-height: clamp(340px, 24vw, 470px);
  background:
    linear-gradient(145deg, rgba(21, 32, 45, 0.92), rgba(31, 48, 64, 0.86)),
    radial-gradient(520px 260px at 8% 8%, rgba(200, 170, 115, 0.2), transparent 68%);
  border-color: rgba(233, 239, 246, 0.16);
  box-shadow: var(--shadow-deep);
}
.featured-guide-card h3,
.featured-guide-card p { color: #eef4f8; }
.featured-guide-card .card-kicker { color: #d8c49a; }
.featured-guide-card .text-link { color: #f7efe0; border-bottom-color: rgba(216, 196, 154, 0.52); }

.card-kicker,
.breadcrumb,
.text-link {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.card-kicker { color: var(--brand-brass); }
.text-link {
  color: var(--brand-blue);
  text-decoration: none;
  justify-self: start;
  border-bottom: 1px solid rgba(46, 79, 115, 0.28);
  padding-bottom: 3px;
}
.text-link:hover { color: var(--brand-ink); border-bottom-color: rgba(200, 170, 115, 0.7); }

.decision-strip {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(320px, 1.1fr);
  gap: clamp(var(--space-4), 4vw, var(--space-6));
  align-items: center;
  padding: clamp(var(--space-4), 3vw, var(--space-5));
  border-top: 1px solid rgba(46, 79, 115, 0.13);
  border-bottom: 1px solid rgba(46, 79, 115, 0.13);
}
.decision-strip h2 { max-width: 24ch; }
.decision-strip ul {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-2);
  list-style: none;
  margin: 0;
  padding: 0;
}
.decision-strip li {
  padding: var(--space-3);
  border-radius: 999px;
  text-align: center;
  color: var(--brand-ink);
  background: rgba(255,255,255,0.58);
  border: 1px solid rgba(46, 79, 115, 0.12);
  font-weight: 700;
  font-size: 0.86rem;
}

.learning-cta {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  align-items: center;
  padding: clamp(var(--space-4), 4vw, var(--space-6));
  border-radius: var(--radius-lg);
}
.learning-cta h2 { max-width: 18ch; margin-bottom: var(--space-2); }

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  color: #6c7a8a;
  letter-spacing: 0.06em;
  margin-bottom: var(--space-2);
}
.breadcrumb a { color: var(--brand-blue); text-decoration: none; }
.editorial-callout {
  border-left: 2px solid rgba(200, 170, 115, 0.7);
  background: transparent;
}
.article-summary p {
  color: #374657;
  font-size: clamp(1.02rem, 0.22vw + 0.98rem, 1.14rem);
}

.article-layout {
  display: grid;
  grid-template-columns: minmax(0, 760px) minmax(250px, 0.36fr);
  gap: clamp(var(--space-5), 5vw, var(--space-7));
  align-items: start;
  padding-block: clamp(var(--space-5), 6vw, var(--space-7));
}
.article-body { display: grid; gap: clamp(var(--space-5), 4vw, var(--space-6)); }
.article-body section { display: grid; gap: var(--space-3); }
.article-body h2 { max-width: 24ch; color: var(--brand-ink); }
.article-body p,
.article-body li { max-width: 68ch; }
.article-body a { color: var(--brand-blue); text-decoration-color: rgba(46, 79, 115, 0.3); text-underline-offset: 3px; }
.article-list { display: grid; gap: var(--space-2); margin: 0; padding-left: 1.1rem; color: #5f6b7a; }
.article-callout {
  display: grid;
  gap: var(--space-2);
  max-width: 720px;
  padding: var(--space-4) 0 var(--space-4) var(--space-4);
  border-left: 2px solid rgba(200, 170, 115, 0.72);
}
.article-callout span {
  color: var(--brand-brass);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.article-callout p {
  color: #334254;
  font-size: clamp(1.02rem, 0.18vw + 0.98rem, 1.12rem);
}

.article-faq {
  padding-top: var(--space-4);
  border-top: 1px solid rgba(46, 79, 115, 0.12);
}
.article-faq details {
  border: 1px solid rgba(46, 79, 115, 0.1);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.44);
  padding: var(--space-3) var(--space-4);
}
.article-faq details + details { margin-top: var(--space-2); }
.article-faq summary { cursor: pointer; color: var(--brand-ink); font-weight: 700; }
.article-faq details p { margin-top: var(--space-2); }

.article-rail {
  position: sticky;
  top: 104px;
  display: grid;
  gap: var(--space-4);
  padding-top: var(--space-2);
}
.rail-reference,
.rail-links {
  display: grid;
  gap: var(--space-2);
  padding-top: var(--space-3);
  border-top: 1px solid rgba(46, 79, 115, 0.14);
}
.rail-links a {
  display: block;
  color: var(--brand-blue);
  text-decoration: none;
  padding-block: 7px;
  border-bottom: 1px solid rgba(46, 79, 115, 0.1);
}
.rail-links a:hover { color: var(--brand-ink); }

.comparison-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}
.comparison-grid article { padding: var(--space-4); gap: var(--space-2); min-height: 0; }
.comparison-grid span { color: var(--brand-ink); font-weight: 800; }

@media (max-width: 1120px) {
  .learning-hero-grid,
  .learning-article-grid,
  .article-layout,
  .decision-strip { grid-template-columns: 1fr; }
  .learning-card-grid,
  .comparison-grid { grid-template-columns: 1fr 1fr; }
  .article-rail { position: static; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .featured-guide-card { grid-column: 1 / -1; }
  .decision-strip ul { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .learning-page .site-header { position: relative; top: auto; }
  .learning-hero,
  .learning-article-hero { padding-top: clamp(var(--space-5), 10vw, var(--space-6)); }
  .learning-hero-copy h1,
  .learning-article-grid h1 { max-width: 12.5ch; font-size: clamp(2.14rem, 9vw, 2.82rem); }
  .learning-card-grid,
  .comparison-grid,
  .article-rail,
  .decision-strip ul { grid-template-columns: 1fr; }
  .learning-card,
  .article-faq details,
  .comparison-grid article { border-radius: 12px; padding: var(--space-3); min-height: 0; }
  .guide-index-panel,
  .article-summary { border-left: 0; border-top: 1px solid rgba(46, 79, 115, 0.16); padding-inline: 0; padding-top: var(--space-3); gap: var(--space-4); border-radius: 20px; }
  .guide-focus-list { gap: var(--space-2); }
  .guide-focus-list li { grid-template-columns: 28px minmax(0, 1fr); padding-top: var(--space-2); }
  .learning-cta { display: grid; align-items: start; padding: var(--space-3); gap: var(--space-3); }
  .article-layout { padding-block: var(--space-5); gap: var(--space-5); }
  .breadcrumb { font-size: 0.7rem; }
  .decision-strip { padding-inline: 0; }
  .guide-card-media {
    margin: calc(var(--space-3) * -1) calc(var(--space-3) * -1) var(--space-3);
    border-radius: 12px 12px 0 0;
  }
  .guide-hero-media,
  .article-hero-media {
    border-radius: 12px;
  }
}


/* Property Media Guides balanced editorial rework — local-only 20260603 */
.property-guides-page {
  --pmg-paper: #f7f3ec;
  --pmg-surface: #fffdf8;
  --pmg-soft: #eee6da;
  --pmg-ink: #121923;
  --pmg-navy: #16283a;
  --pmg-muted: #58636f;
  --pmg-warm: #9a704b;
  --pmg-line: rgba(18, 25, 35, 0.13);
  --pmg-line-soft: rgba(18, 25, 35, 0.08);
  color: var(--pmg-ink);
  background: linear-gradient(180deg, var(--pmg-paper) 0%, #fffdf8 48%, var(--pmg-paper) 100%);
}

.property-guides-page main { background: transparent; }
.property-guides-page .section { padding-block: clamp(54px, 6vw, 84px); }
.pmg-hero.section { padding-bottom: clamp(36px, 4.5vw, 58px); }
.pmg-feature-section.section { padding-top: clamp(42px, 4.5vw, 62px); }
.property-guides-page .btn-primary { background: var(--pmg-navy); border-color: var(--pmg-navy); color: #fffaf2; box-shadow: none; }
.property-guides-page .btn-primary:hover,
.property-guides-page .btn-primary:focus-visible { background: #0f1d2b; border-color: #0f1d2b; transform: none; }

.pmg-label,.pmg-kicker { display: inline-block; color: var(--pmg-warm); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.13em; line-height: 1.1; text-transform: uppercase; }
.pmg-text-link,.pmg-read-link,.property-guides-page .text-link { color: var(--pmg-navy); font-weight: 600; text-decoration: none; border-bottom: 1px solid rgba(154,112,75,.42); padding-bottom: .1em; }

.pmg-hero-layout { display: grid; grid-template-columns: minmax(0, .98fr) minmax(360px, .86fr); gap: clamp(32px, 4.5vw, 58px); align-items: center; }
.pmg-hero-copy { max-width: 680px; }
.pmg-hero-copy h1,.pmg-article-titleblock h1 { margin: clamp(14px, 1.6vw, 20px) 0 0; color: var(--pmg-ink); font-size: clamp(2.45rem, 4.5vw, 4.25rem); font-weight: 600; line-height: 1.02; letter-spacing: -0.045em; text-wrap: balance; max-width: 15ch; }
.pmg-article-titleblock h1 { max-width: 13ch; }
.pmg-hero-copy .lead,.pmg-article-titleblock .lead { margin-top: clamp(18px, 2vw, 26px); color: #2a3744; font-size: clamp(1.04rem, 1.35vw, 1.2rem); line-height: 1.58; max-width: 48ch; }
.pmg-hero-copy > p:not(.lead) { margin-top: 14px; color: var(--pmg-muted); font-size: 1rem; line-height: 1.7; max-width: 50ch; }
.pmg-actions { display: flex; flex-wrap: wrap; gap: 16px 22px; align-items: center; margin-top: clamp(26px, 3vw, 36px); }

.pmg-hero-image,.pmg-feature-guide figure,.pmg-guide-row figure,.pmg-article-image { overflow: hidden; margin: 0; background: #e6ded1; border: 1px solid rgba(18,25,35,.10); border-radius: 24px; }
.pmg-hero-image { aspect-ratio: 1 / 1; max-width: 560px; width: 100%; justify-self: end; box-shadow: 0 24px 54px rgba(16,25,34,.10); }
.pmg-hero-image img,.pmg-feature-guide img,.pmg-guide-row img,.pmg-article-image img { width: 100%; height: 100%; display: block; object-fit: cover; object-position: 50% 50%; filter: saturate(.98) contrast(1.04); }

.pmg-section-heading { max-width: 760px; margin-bottom: clamp(28px, 4vw, 44px); }
.pmg-section-heading h2,.pmg-decision-layout h2,.pmg-final-cta-inner h2 { margin: 12px 0 0; color: var(--pmg-ink); font-size: clamp(1.9rem, 3vw, 3.05rem); font-weight: 600; line-height: 1.08; letter-spacing: -0.035em; text-wrap: balance; }
.pmg-section-heading p,.pmg-final-cta-inner p { margin-top: 16px; color: var(--pmg-muted); line-height: 1.65; max-width: 42ch; }

.pmg-feature-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(300px, .78fr); gap: clamp(28px, 4vw, 58px); align-items: start; }
.pmg-feature-guide,.pmg-guide-row { color: inherit; text-decoration: none; }
.pmg-feature-guide { display: grid; gap: 22px; }
.pmg-feature-guide figure { aspect-ratio: 4 / 3; }
.pmg-feature-copy { display: grid; gap: 12px; max-width: 620px; }
.pmg-feature-copy h3,.pmg-guide-row h3 { margin: 0; color: var(--pmg-ink); font-size: clamp(1.35rem, 1.8vw, 1.9rem); font-weight: 600; line-height: 1.14; letter-spacing: -0.025em; }
.pmg-feature-copy p,.pmg-guide-row p { margin: 0; color: var(--pmg-muted); line-height: 1.62; }
.pmg-secondary-guides { display: grid; gap: 22px; }
.pmg-guide-row { display: grid; grid-template-columns: 128px minmax(0,1fr); gap: 20px; align-items: center; padding-bottom: 22px; border-bottom: 1px solid var(--pmg-line-soft); }
.pmg-guide-row figure { aspect-ratio: 1 / 1; border-radius: 20px; }
.pmg-guide-row h3 { margin-top: 8px; font-size: clamp(1.14rem, 1.35vw, 1.38rem); }
.pmg-guide-row p { margin-top: 8px; font-size: .96rem; }

.pmg-decision-section { padding-block: clamp(52px, 6vw, 78px) !important; }
.pmg-decision-layout { display: grid; grid-template-columns: minmax(0,.55fr) minmax(320px,1fr); gap: clamp(28px,4vw,58px); padding-block: clamp(28px,4vw,42px); border-top: 1px solid var(--pmg-line); border-bottom: 1px solid var(--pmg-line); }
.pmg-decision-list { list-style: none; display: grid; gap: 0; margin: 0; padding: 0; }
.pmg-decision-list li { display: grid; grid-template-columns: minmax(130px,.28fr) minmax(0,1fr); gap: 18px; padding: 16px 0; border-bottom: 1px solid var(--pmg-line-soft); }
.pmg-decision-list li:last-child { border-bottom: 0; }
.pmg-decision-list strong { color: var(--pmg-ink); font-weight: 600; }
.pmg-decision-list span { color: var(--pmg-muted); line-height: 1.58; }

.pmg-final-cta-inner { max-width: 700px; margin-inline: auto; text-align: center; }
.pmg-final-cta-inner p { margin: 16px auto 0; }
.pmg-final-cta-inner .btn { margin-top: 26px; }

.pmg-article-masthead { padding-bottom: clamp(36px, 5vw, 58px) !important; }
.pmg-article-hero { display: grid; grid-template-columns: minmax(0,.9fr) minmax(380px,1fr); gap: clamp(34px,5vw,64px); align-items: center; }
.pmg-breadcrumb { margin-bottom: clamp(22px,3vw,34px); color: rgba(20,37,55,.58); font-size: .82rem; }
.pmg-breadcrumb a { color: inherit; text-decoration: none; }
.pmg-article-image { aspect-ratio: 4 / 3; box-shadow: 0 22px 48px rgba(16,25,34,.09); }
.pmg-article-layout { display: grid; grid-template-columns: minmax(0, 720px) minmax(220px, 280px); gap: clamp(32px,5vw,66px); align-items: start; padding-bottom: clamp(70px,8vw,104px); }
.pmg-quick-answer { grid-column: 1; border-top: 1px solid var(--pmg-line); border-bottom: 1px solid var(--pmg-line-soft); padding: 20px 0; }
.pmg-quick-answer p { margin: 10px 0 0; color: #2a3744; font-size: 1.05rem; line-height: 1.62; }
.pmg-article-body { grid-column: 1; max-width: 720px; }
.pmg-related-rail { grid-column: 2; grid-row: 1 / span 2; position: sticky; top: 110px; display: grid; gap: 30px; border-top: 1px solid var(--pmg-line); padding-top: 20px; }
.pmg-rail-reference p { color: var(--pmg-muted); line-height: 1.62; }
.pmg-article-body section { padding-block: clamp(26px,3.5vw,42px); border-top: 1px solid var(--pmg-line-soft); }
.pmg-article-body section:first-of-type { border-top: 0; padding-top: 28px; }
.pmg-article-body h2 { margin: 0 0 14px; color: var(--pmg-ink); font-size: clamp(1.25rem,1.65vw,1.65rem); font-weight: 600; line-height: 1.18; letter-spacing: -0.018em; }
.pmg-article-body p,.pmg-article-body li { color: #3d4852; font-size: 1rem; line-height: 1.72; }
.pmg-article-body p + p { margin-top: 14px; }
.pmg-note { margin: 28px 0 16px; padding: 0 0 0 18px; border-left: 2px solid rgba(154,112,75,.50); }
.pmg-note span { display: block; color: var(--pmg-warm); font-size: .74rem; font-weight: 600; letter-spacing: .11em; text-transform: uppercase; }
.pmg-note p { margin-top: 8px; color: #263542; line-height: 1.66; }
.pmg-article-list { display: grid; gap: 10px; margin: 0; padding-left: 1.1rem; }
.pmg-comparison-lines { border-top: 1px solid var(--pmg-line); }
.pmg-comparison-lines p { display: grid; grid-template-columns: minmax(120px,.28fr) minmax(0,1fr); gap: 18px; margin: 0; padding: 16px 0; border-bottom: 1px solid var(--pmg-line-soft); }
.pmg-comparison-lines strong { color: var(--pmg-ink); font-weight: 600; }
.pmg-faq details { border-top: 1px solid var(--pmg-line-soft); padding: 17px 0; }
.pmg-faq details:last-child { border-bottom: 1px solid var(--pmg-line-soft); }
.pmg-faq summary { color: var(--pmg-ink); cursor: pointer; font-weight: 600; line-height: 1.45; }
.pmg-faq details p { margin: 10px 0 0; color: var(--pmg-muted); }
.pmg-rail-links h3 { margin: 0 0 14px; color: var(--pmg-ink); font-size: 1rem; font-weight: 600; }
.pmg-rail-links a { display: block; color: var(--pmg-navy); text-decoration: none; padding: 12px 0; border-top: 1px solid var(--pmg-line-soft); line-height: 1.45; }

@media (max-width: 1024px) {
  .pmg-hero-layout,.pmg-feature-layout,.pmg-section-heading,.pmg-decision-layout,.pmg-article-hero,.pmg-article-layout { grid-template-columns: 1fr; }
  .pmg-related-rail { grid-column: auto; grid-row: auto; position: static; }
  .pmg-article-body,.pmg-quick-answer { grid-column: auto; }
}

@media (max-width: 720px) {
  .property-guides-page .shell { width: min(100% - 42px, var(--shell, 1180px)); }
  .property-guides-page .section { padding-block: 58px; }
  .pmg-hero-layout,.pmg-feature-layout,.pmg-section-heading,.pmg-decision-layout,.pmg-article-hero,.pmg-article-layout { gap: 28px; }
  .pmg-hero-copy h1,.pmg-article-titleblock h1 { max-width: 12ch; font-size: clamp(2rem, 8.2vw, 2.65rem); line-height: 1.05; letter-spacing: -0.034em; }
  .pmg-hero-copy .lead,.pmg-article-titleblock .lead { margin-top: 18px; font-size: 1.02rem; line-height: 1.58; }
  .pmg-hero-copy > p:not(.lead),.pmg-section-heading p,.pmg-feature-copy p,.pmg-guide-row p,.pmg-decision-list span,.pmg-final-cta-inner p,.pmg-quick-answer p,.pmg-note p,.pmg-article-body p,.pmg-article-body li,.pmg-rail-reference p { font-size: .98rem; line-height: 1.62; }
  .pmg-section-heading h2,.pmg-decision-layout h2,.pmg-final-cta-inner h2 { font-size: clamp(1.55rem, 6.3vw, 2.05rem); line-height: 1.12; letter-spacing: -0.026em; }
  .pmg-hero-image,.pmg-feature-guide figure,.pmg-article-image { aspect-ratio: 4 / 3; min-height: 0; border-radius: 22px; box-shadow: 0 16px 34px rgba(16,25,34,.08); }
  .pmg-guide-row { grid-template-columns: 1fr; gap: 16px; padding-bottom: 30px; }
  .pmg-guide-row figure { aspect-ratio: 4 / 3; border-radius: 20px; }
  .pmg-secondary-guides { gap: 30px; }
  .pmg-feature-copy { gap: 10px; }
  .pmg-feature-copy h3,.pmg-guide-row h3 { font-size: clamp(1.25rem, 5.2vw, 1.55rem); }
  .pmg-actions { flex-direction: column; align-items: flex-start; gap: 16px; margin-top: 28px; }
  .pmg-decision-section { padding-block: 52px !important; }
  .pmg-decision-layout { padding-block: 30px; }
  .pmg-decision-list li,.pmg-comparison-lines p { grid-template-columns: 1fr; gap: 7px; padding: 18px 0; }
  .pmg-final-cta-inner { text-align: left; }
  .pmg-article-masthead { padding-bottom: 34px !important; }
  .pmg-article-layout { padding-bottom: 72px; }
  .pmg-quick-answer,.pmg-related-rail { padding-top: 18px; }
  .pmg-note { margin: 26px 0 8px; padding-left: 16px; }
  .pmg-article-body section { padding-block: 32px; }
  .pmg-article-body section:first-of-type { padding-top: 26px; }
  .pmg-article-body h2 { margin-bottom: 12px; font-size: clamp(1.18rem, 5vw, 1.42rem); }
  .pmg-faq details { padding: 17px 0; }
}

/* Property Media Guides mobile breathing room + restrained image motion — local-only 20260603 */
.guide-hero-media img,
.guide-card-media img,
.article-hero-media img {
  transform: translate3d(0, var(--scroll-y, 0px), 0) scale(var(--scroll-scale, 1.01));
  transform-origin: center center;
  transition: transform 160ms linear;
  will-change: transform;
}

@media (prefers-reduced-motion: reduce) {
  .guide-hero-media img,
  .guide-card-media img,
  .article-hero-media img {
    transform: none !important;
    transition: none !important;
  }
}

@media (max-width: 720px) {
  .property-guides-page .shell {
    width: min(100% - 48px, var(--shell, 1180px));
  }

  .property-guides-page .section {
    padding-block: 68px;
  }

  .pmg-hero.section {
    padding-top: 54px;
    padding-bottom: 64px;
  }

  .pmg-feature-section.section {
    padding-top: 62px;
  }

  .pmg-hero-layout,
  .pmg-feature-layout,
  .pmg-section-heading,
  .pmg-decision-layout,
  .pmg-article-hero,
  .pmg-article-layout {
    gap: 34px;
  }

  .pmg-hero-copy h1,
  .pmg-article-titleblock h1 {
    font-size: clamp(1.82rem, 7.2vw, 2.34rem);
    line-height: 1.1;
    letter-spacing: -0.026em;
    max-width: 13ch;
  }

  .pmg-section-heading h2,
  .pmg-decision-layout h2,
  .pmg-final-cta-inner h2 {
    font-size: clamp(1.38rem, 5.6vw, 1.78rem);
    line-height: 1.16;
    letter-spacing: -0.018em;
  }

  .pmg-hero-copy .lead,
  .pmg-article-titleblock .lead {
    margin-top: 20px;
    font-size: 1rem;
    line-height: 1.6;
  }

  .pmg-hero-copy > p:not(.lead),
  .pmg-section-heading p,
  .pmg-feature-copy p,
  .pmg-guide-row p,
  .pmg-decision-list span,
  .pmg-final-cta-inner p,
  .pmg-quick-answer p,
  .pmg-note p,
  .pmg-article-body p,
  .pmg-article-body li,
  .pmg-rail-reference p {
    font-size: 0.97rem;
    line-height: 1.66;
  }

  .pmg-hero-image,
  .pmg-feature-guide figure,
  .pmg-guide-row figure,
  .pmg-article-image {
    border-radius: 24px;
    margin-inline: auto;
    width: 100%;
    box-shadow: 0 14px 30px rgba(16,25,34,.075);
  }

  .pmg-hero-image,
  .pmg-feature-guide figure,
  .pmg-article-image {
    aspect-ratio: 1 / 1;
  }

  .pmg-guide-row figure {
    aspect-ratio: 5 / 4;
  }

  .pmg-secondary-guides {
    gap: 42px;
  }

  .pmg-guide-row {
    gap: 18px;
    padding-bottom: 42px;
  }

  .pmg-feature-copy,
  .pmg-guide-row > div {
    padding-inline: 2px;
  }

  .pmg-feature-copy h3,
  .pmg-guide-row h3 {
    font-size: clamp(1.18rem, 4.8vw, 1.42rem);
    line-height: 1.18;
  }

  .pmg-decision-section {
    padding-block: 66px !important;
  }

  .pmg-decision-layout {
    padding-block: 36px;
  }

  .pmg-decision-list {
    gap: 8px;
  }

  .pmg-decision-list li,
  .pmg-comparison-lines p {
    padding: 20px 0;
  }

  .pmg-final-cta-inner {
    text-align: left;
  }

  .pmg-article-masthead {
    padding-top: 50px !important;
    padding-bottom: 42px !important;
  }

  .pmg-article-layout {
    gap: 34px;
    padding-bottom: 84px;
  }

  .pmg-quick-answer {
    padding: 24px 0;
  }

  .pmg-note {
    margin: 34px 0 14px;
  }

  .pmg-article-body section {
    padding-block: 40px;
  }

  .pmg-article-body section:first-of-type {
    padding-top: 34px;
  }

  .pmg-article-body h2 {
    font-size: clamp(1.08rem, 4.4vw, 1.28rem);
    line-height: 1.24;
  }
}



/* Property Media Guides compact mobile polish — local-only 20260603 */
.pmg-quick-answer,
.pmg-note,
.pmg-related-rail {
  background: rgba(255,253,248,.62);
  border-radius: 20px;
}
.pmg-quick-answer { padding-inline: clamp(18px, 2.4vw, 24px); }
.pmg-note { padding: 16px 18px 16px 20px; border-left: 0; border-top: 1px solid rgba(154,112,75,.36); }
.pmg-related-rail { padding: 22px 22px 24px; border: 1px solid var(--pmg-line-soft); }
.pmg-rail-links a:last-child { border-bottom: 1px solid var(--pmg-line-soft); }

@media (max-width: 720px) {
  .property-guides-page .shell { width: min(100% - 40px, var(--shell, 1180px)); }
  .property-guides-page .section { padding-block: 48px; }
  .pmg-hero.section { padding-top: 40px; padding-bottom: 44px; }
  .pmg-feature-section.section { padding-top: 38px; padding-bottom: 28px; }
  .pmg-final-cta.section { padding-block: 40px 50px; }
  .pmg-hero-layout,.pmg-feature-layout,.pmg-section-heading,.pmg-decision-layout,.pmg-article-hero,.pmg-article-layout { gap: 24px; }
  .pmg-label,.pmg-kicker { font-size: .66rem; letter-spacing: .115em; }
  .pmg-hero-copy h1,.pmg-article-titleblock h1 { font-size: clamp(1.72rem, 6.7vw, 2.14rem); line-height: 1.12; letter-spacing: -.022em; max-width: 14ch; }
  .pmg-section-heading h2,.pmg-decision-layout h2,.pmg-final-cta-inner h2 { font-size: clamp(1.28rem, 5.1vw, 1.62rem); line-height: 1.18; letter-spacing: -.014em; }
  .pmg-hero-copy .lead,.pmg-article-titleblock .lead { margin-top: 16px; font-size: .98rem; line-height: 1.56; }
  .pmg-hero-copy > p:not(.lead),.pmg-section-heading p,.pmg-feature-copy p,.pmg-guide-row p,.pmg-decision-list span,.pmg-final-cta-inner p,.pmg-quick-answer p,.pmg-note p,.pmg-article-body p,.pmg-article-body li,.pmg-rail-reference p { font-size: .95rem; line-height: 1.58; }
  .pmg-actions { margin-top: 22px; gap: 13px; }
  .pmg-hero-image,.pmg-feature-guide figure,.pmg-guide-row figure,.pmg-article-image { border-radius: 20px; box-shadow: 0 12px 26px rgba(16,25,34,.07); }
  .pmg-hero-image,.pmg-feature-guide figure,.pmg-article-image { aspect-ratio: 16 / 11; }
  .pmg-guide-row figure { aspect-ratio: 16 / 10; }
  .pmg-hero-image img,.pmg-feature-guide img,.pmg-guide-row img,.pmg-article-image img { object-position: 50% 48%; }
  .pmg-section-heading { margin-bottom: 24px; }
  .pmg-feature-guide { gap: 16px; }
  .pmg-feature-copy { gap: 8px; }
  .pmg-secondary-guides { gap: 26px; }
  .pmg-guide-row { gap: 14px; padding-bottom: 26px; }
  .pmg-feature-copy h3,.pmg-guide-row h3 { font-size: clamp(1.12rem, 4.4vw, 1.32rem); line-height: 1.2; }
  .pmg-guide-row h3 { margin-top: 6px; }
  .pmg-guide-row p { margin-top: 6px; }
  .pmg-decision-section { padding-block: 34px !important; }
  .pmg-decision-layout { padding-block: 24px; }
  .pmg-decision-list li,.pmg-comparison-lines p { padding: 14px 0; gap: 5px; }
  .pmg-final-cta-inner { text-align: left; }
  .pmg-final-cta-inner .btn { margin-top: 20px; }
  .pmg-article-masthead { padding-top: 38px !important; padding-bottom: 32px !important; }
  .pmg-breadcrumb { margin-bottom: 18px; font-size: .78rem; }
  .pmg-article-layout { gap: 22px; padding-bottom: 64px; }
  .pmg-quick-answer { padding: 18px; border: 1px solid var(--pmg-line-soft); }
  .pmg-quick-answer p { margin-top: 8px; }
  .pmg-note { margin: 8px 0 6px; padding: 15px 17px; }
  .pmg-note p { margin-top: 7px; }
  .pmg-article-body section { padding-block: 24px; }
  .pmg-article-body section:first-of-type { padding-top: 18px; }
  .pmg-article-body h2 { margin-bottom: 9px; font-size: clamp(1.02rem, 4vw, 1.2rem); line-height: 1.25; }
  .pmg-faq details { padding: 13px 0; }
  .pmg-faq details p { margin-top: 8px; }
  .pmg-related-rail { gap: 18px; padding: 18px; }
  .pmg-rail-links h3 { margin-bottom: 8px; }
  .pmg-rail-links a { padding: 10px 0; }
}

/* Property Media Guides premium editorial hierarchy pass — local-only 20260604 */
.property-guides-page {
  --pmg-paper: #f6efe4;
  --pmg-surface: #fffaf2;
  --pmg-soft: #ebe1d1;
  --pmg-ink: #101821;
  --pmg-navy: #132638;
  --pmg-muted: #52606d;
  --pmg-warm: #8f6645;
  --pmg-line: rgba(16, 24, 33, .15);
  --pmg-line-soft: rgba(16, 24, 33, .085);
  background:
    radial-gradient(980px 520px at 14% 6%, rgba(158, 111, 71, .12), transparent 66%),
    radial-gradient(880px 520px at 88% 22%, rgba(19, 38, 56, .075), transparent 70%),
    linear-gradient(180deg, #f5efe5 0%, #fffaf2 42%, #f5efe5 100%);
}

.property-guides-page .section { position: relative; }
.property-guides-page .section + .section::before {
  content: "";
  position: absolute;
  top: 0;
  left: max(20px, calc((100vw - var(--shell, 1180px)) / 2));
  right: max(20px, calc((100vw - var(--shell, 1180px)) / 2));
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(16, 24, 33, .16), transparent);
}

.pmg-label,
.pmg-kicker,
.pmg-breadcrumb,
.pmg-note span,
.pmg-rail-links h3 {
  font-family: inherit;
  font-size: .71rem;
  font-weight: 650;
  letter-spacing: .12em;
  line-height: 1.1;
  text-transform: uppercase;
}

.pmg-hero-copy h1,
.pmg-article-titleblock h1,
.pmg-section-heading h2,
.pmg-decision-layout h2,
.pmg-final-cta-inner h2,
.pmg-feature-copy h3,
.pmg-guide-row h3,
.pmg-article-body h2 {
  font-weight: 600;
  color: var(--pmg-ink);
}

.pmg-hero-layout,
.pmg-article-hero {
  isolation: isolate;
}

.pmg-hero-copy,
.pmg-article-titleblock {
  position: relative;
}

.pmg-hero-copy::before,
.pmg-article-titleblock::before {
  content: "";
  display: block;
  width: 48px;
  height: 1px;
  margin-bottom: clamp(18px, 2.2vw, 26px);
  background: rgba(143, 102, 69, .58);
}

.pmg-hero-copy .lead,
.pmg-article-titleblock .lead {
  color: #253240;
}

.pmg-hero-copy > p:not(.lead),
.pmg-section-heading p,
.pmg-feature-copy p,
.pmg-guide-row p,
.pmg-decision-list span,
.pmg-final-cta-inner p,
.pmg-article-body p,
.pmg-article-body li,
.pmg-rail-reference p {
  color: var(--pmg-muted);
}

.pmg-hero-copy .lead,
.pmg-article-titleblock .lead,
.pmg-section-heading p,
.pmg-feature-copy p,
.pmg-guide-row p,
.pmg-decision-list span,
.pmg-final-cta-inner p,
.pmg-quick-answer p,
.pmg-note p,
.pmg-article-body p,
.pmg-article-body li,
.pmg-rail-reference p {
  line-height: 1.64;
}

.pmg-text-link,
.pmg-read-link,
.pmg-rail-links a {
  color: var(--pmg-navy);
  font-size: .92rem;
  font-weight: 600;
  letter-spacing: -.01em;
  text-decoration: none;
}

.pmg-text-link,
.pmg-read-link {
  display: inline-flex;
  align-items: center;
  gap: .4em;
  border-bottom: 1px solid rgba(143, 102, 69, .42);
  padding-bottom: .12em;
}

.pmg-text-link:hover,
.pmg-read-link:hover,
.pmg-rail-links a:hover,
.pmg-text-link:focus-visible,
.pmg-read-link:focus-visible,
.pmg-rail-links a:focus-visible {
  color: var(--pmg-ink);
  border-color: rgba(143, 102, 69, .72);
}

.pmg-read-link {
  margin-top: .2rem;
}

.pmg-hero-image,
.pmg-feature-guide figure,
.pmg-guide-row figure,
.pmg-article-image {
  position: relative;
  border-color: rgba(16, 24, 33, .12);
  box-shadow: 0 20px 46px rgba(16, 25, 34, .105), inset 0 1px 0 rgba(255, 250, 242, .5);
}

.pmg-hero-image::after,
.pmg-feature-guide figure::after,
.pmg-guide-row figure::after,
.pmg-article-image::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255, 250, 242, .02), rgba(16, 24, 33, .12)),
    radial-gradient(520px 240px at 16% 10%, rgba(255, 250, 242, .16), transparent 58%);
}

.pmg-feature-layout {
  align-items: stretch;
}

.pmg-feature-guide {
  display: grid;
  gap: clamp(16px, 2vw, 22px);
  padding: clamp(18px, 2.5vw, 26px);
  border: 1px solid rgba(16, 24, 33, .10);
  border-radius: 28px;
  background: linear-gradient(145deg, rgba(255, 250, 242, .88), rgba(238, 229, 214, .38));
  box-shadow: 0 16px 38px rgba(16, 25, 34, .065);
}

.pmg-feature-guide figure {
  border-radius: 22px;
}

.pmg-feature-copy {
  padding: 0 clamp(2px, .5vw, 6px) clamp(2px, .5vw, 8px);
}

.pmg-secondary-guides {
  align-content: stretch;
  padding: clamp(18px, 2.5vw, 26px);
  border: 1px solid rgba(16, 24, 33, .095);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255, 250, 242, .54), rgba(246, 239, 228, .26));
}

.pmg-guide-row {
  position: relative;
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr);
  gap: 20px;
  padding: 18px 16px;
  border-radius: 18px;
  background: rgba(255, 250, 242, .58);
  border: 1px solid rgba(16, 24, 33, .06);
}

.pmg-guide-row + .pmg-guide-row {
  margin-top: 16px;
}

.pmg-guide-row:last-child {
  padding-bottom: 18px;
}

.pmg-guide-row::after {
  content: "Read guide";
  grid-column: 2;
  justify-self: start;
  color: var(--pmg-navy);
  font-size: .72rem;
  font-weight: 650;
  letter-spacing: .09em;
  text-transform: uppercase;
  border-bottom: 1px solid rgba(143, 102, 69, .42);
}

.pmg-decision-layout {
  border-color: rgba(16, 24, 33, .16);
}

.pmg-decision-list li {
  grid-template-columns: minmax(116px, .25fr) minmax(0, 1fr);
}

.pmg-quick-answer,
.pmg-note,
.pmg-related-rail {
  background:
    linear-gradient(145deg, rgba(255, 250, 242, .82), rgba(238, 229, 214, .36));
  border: 1px solid var(--pmg-line-soft);
  box-shadow: 0 14px 34px rgba(16, 25, 34, .055);
}

.pmg-quick-answer {
  border-radius: 22px;
  padding: clamp(18px, 2.2vw, 24px);
}

.pmg-article-body {
  counter-reset: pmg-section;
}

.pmg-article-body > section:not(.pmg-faq) {
  counter-increment: pmg-section;
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  column-gap: 16px;
  padding-block: clamp(24px, 3vw, 34px);
}

.pmg-article-body > section:not(.pmg-faq)::before {
  content: counter(pmg-section, decimal-leading-zero);
  color: rgba(143, 102, 69, .72);
  font-size: .7rem;
  font-weight: 650;
  letter-spacing: .08em;
  padding-top: .32em;
}

.pmg-article-body > section:not(.pmg-faq) > * {
  grid-column: 2;
}

.pmg-article-body h2 {
  font-size: clamp(1.18rem, 1.45vw, 1.48rem);
  line-height: 1.2;
  letter-spacing: -.014em;
}

.pmg-faq {
  margin-top: 6px;
  padding: clamp(18px, 2.5vw, 24px);
  border: 1px solid var(--pmg-line-soft);
  border-radius: 22px;
  background: rgba(255, 250, 242, .52);
}

.pmg-faq h2 {
  margin-bottom: 4px;
}

.pmg-faq details:first-of-type {
  border-top: 0;
}

.pmg-rail-links a,
.pmg-text-link,
.pmg-read-link,
.property-guides-page .text-link {
  transition: color 180ms ease, border-color 180ms ease;
}

.property-guides-page .site-footer .text-link {
  display: inline-block;
  margin-left: .16em;
}

@media (max-width: 720px) {
  .property-guides-page .shell { width: min(100% - 36px, var(--shell, 1180px)); }
  .property-guides-page .section { padding-block: 44px; }
  .pmg-hero.section { padding-top: 36px; padding-bottom: 40px; }
  .pmg-feature-section.section { padding-top: 36px; padding-bottom: 24px; }
  .pmg-decision-section { padding-block: 32px !important; }
  .pmg-final-cta.section { padding-block: 38px 48px; }
  .pmg-hero-layout,
  .pmg-feature-layout,
  .pmg-section-heading,
  .pmg-decision-layout,
  .pmg-article-hero,
  .pmg-article-layout { gap: 22px; }
  .pmg-label,.pmg-kicker,.pmg-breadcrumb,.pmg-note span,.pmg-rail-links h3 { font-size: .64rem; letter-spacing: .105em; }
  .pmg-hero-copy::before,
  .pmg-article-titleblock::before { width: 38px; margin-bottom: 16px; }
  .pmg-hero-copy h1,.pmg-article-titleblock h1 { font-size: clamp(1.72rem, 6.4vw, 2.08rem); line-height: 1.12; letter-spacing: -.02em; max-width: 15ch; }
  .pmg-section-heading h2,.pmg-decision-layout h2,.pmg-final-cta-inner h2 { font-size: clamp(1.28rem, 4.8vw, 1.56rem); line-height: 1.18; letter-spacing: -.012em; }
  .pmg-feature-copy h3,.pmg-guide-row h3 { font-size: clamp(1.1rem, 4.1vw, 1.28rem); line-height: 1.2; }
  .pmg-hero-copy .lead,.pmg-article-titleblock .lead { margin-top: 14px; font-size: .97rem; line-height: 1.55; }
  .pmg-hero-copy > p:not(.lead),.pmg-section-heading p,.pmg-feature-copy p,.pmg-guide-row p,.pmg-decision-list span,.pmg-final-cta-inner p,.pmg-quick-answer p,.pmg-note p,.pmg-article-body p,.pmg-article-body li,.pmg-rail-reference p { font-size: .94rem; line-height: 1.57; }
  .pmg-actions { margin-top: 20px; gap: 12px; }
  .pmg-hero-image,.pmg-feature-guide figure,.pmg-article-image { aspect-ratio: 16 / 10; border-radius: 19px; }
  .pmg-hero-image { max-width: 100%; }
  .pmg-feature-guide { gap: 15px; padding: 14px; border-radius: 23px; }
  .pmg-feature-guide figure { border-radius: 17px; }
  .pmg-secondary-guides { gap: 0; padding: 14px; border-radius: 23px; }
  .pmg-guide-row { grid-template-columns: 104px minmax(0, 1fr); gap: 14px; align-items: center; padding: 0 0 17px; }
  .pmg-guide-row + .pmg-guide-row { padding-top: 17px; }
  .pmg-guide-row figure { aspect-ratio: 4 / 3; border-radius: 15px; }
  .pmg-guide-row h3 { margin-top: 5px; }
  .pmg-guide-row p { margin-top: 5px; }
  .pmg-guide-row::after { grid-column: 2; font-size: .66rem; margin-top: 2px; }
  .pmg-decision-layout { padding-block: 22px; }
  .pmg-decision-list li,.pmg-comparison-lines p { padding: 13px 0; gap: 5px; }
  .pmg-article-masthead { padding-top: 34px !important; padding-bottom: 30px !important; }
  .pmg-breadcrumb { margin-bottom: 16px; }
  .pmg-article-layout { gap: 20px; padding-bottom: 58px; }
  .pmg-quick-answer { padding: 16px; border-radius: 18px; }
  .pmg-note { margin: 6px 0 4px; padding: 14px 16px; border-radius: 18px; }
  .pmg-article-body > section:not(.pmg-faq) { grid-template-columns: 31px minmax(0, 1fr); column-gap: 12px; padding-block: 22px; }
  .pmg-article-body > section:not(.pmg-faq)::before { font-size: .66rem; padding-top: .35em; }
  .pmg-article-body section:first-of-type { padding-top: 17px; }
  .pmg-article-body h2 { margin-bottom: 8px; font-size: clamp(1.02rem, 3.8vw, 1.18rem); line-height: 1.24; }
  .pmg-faq { padding: 16px; border-radius: 18px; }
  .pmg-faq details { padding: 12px 0; }
  .pmg-related-rail { gap: 16px; padding: 16px; border-radius: 18px; }
  .pmg-rail-links h3 { margin-bottom: 6px; }
  .pmg-rail-links a { padding: 9px 0; }
}



/* Premium editorial refinement overrides for the active public site */
:root {
  --shell-max: 1760px;
  --shell-pad: clamp(16px, 3vw, 72px);
  --brand-blue: #32506f;
  --brand-sky: #89adbf;
  --brand-gold: #bea067;
  --brand-brass: #8b704b;
  --brand-champagne: #d4be92;
}

body {
  color: #273343;
  line-height: 1.68;
  background:
    radial-gradient(1220px 680px at 88% -16%, rgba(134, 169, 201, 0.16), transparent 70%),
    radial-gradient(900px 520px at 10% 8%, rgba(200, 170, 115, 0.08), transparent 72%),
    linear-gradient(180deg, #fbfcfd 0%, #f1f4f5 46%, #e7ebee 100%);
}

p { color: #526173; }
h1, h2, h3 { letter-spacing: 0; color: #162230; }

.site-header {
  background: linear-gradient(180deg, rgba(251, 253, 254, 0.96), rgba(246, 250, 252, 0.82));
  border-bottom-color: rgba(42, 60, 80, 0.12);
}
.site-nav a {
  border: 1px solid transparent;
  color: #294055;
}
.site-nav a:hover,
.site-nav a[aria-current="page"] {
  border-color: rgba(42, 64, 86, 0.08);
}

.hero-content-wrap,
.packages-hero-grid,
.learning-hero-grid,
.learning-article-grid,
.article-layout,
.contact-grid {
  gap: clamp(18px, 2vw, 28px);
}

.hero-content {
  padding: clamp(18px, 2.3vw, 28px);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(12, 21, 30, 0.60), rgba(12, 21, 30, 0.42));
  border-color: rgba(255, 255, 255, 0.18);
  box-shadow: 0 24px 56px rgba(9, 14, 20, 0.24);
}
.hero-content .lead { color: rgba(243, 248, 252, 0.92); }
.hero-trust-line { color: rgba(230, 237, 244, 0.82); }
.hero-media-strip article,
.service-panel,
.audience-card,
.tour-card,
.learning-card,
.pricing-card,
.combination-card,
.simple-steps article,
.article-body section,
.article-callout,
.article-faq details,
.rail-reference,
.rail-links,
.guide-index-panel,
.decision-strip,
.learning-cta,
.packages-cta,
.contact-copy,
.form-block {
  box-shadow: 0 16px 38px rgba(12, 17, 24, 0.08);
}

.hero-media-strip article { border-radius: 20px; }
.hero-media-strip span { letter-spacing: 0.14em; }

.editorial-marker {
  letter-spacing: 0.14em;
  color: #728398;
}

.split-intro { margin-bottom: clamp(20px, 4vw, 44px); }
.split-intro p,
.section-heading p,
.learning-hero-copy .lead,
.packages-hero-copy .lead,
.article-summary p { color: #516173; }

.service-panel,
.audience-card,
.tour-card,
.learning-card,
.pricing-card,
.combination-card {
  border-radius: 22px;
  overflow: hidden;
}
.service-panel:hover,
.audience-card:hover,
.tour-card:hover,
.learning-card:hover,
.pricing-card:hover,
.combination-card:hover { transform: translateY(-4px); }

.service-content,
.audience-card-body,
.tour-body,
.learning-card,
.pricing-card-body,
.combination-copy,
.article-body section,
.article-callout,
.rail-reference,
.rail-links,
.guide-index-panel,
.contact-copy,
.form-block,
.simple-steps article {
  backdrop-filter: blur(14px) saturate(118%);
}

.service-price,
.price-line,
.card-kicker,
.tour-body .editorial-marker.small,
.audience-card-body span {
  color: #627487;
}

.guide-index-panel,
.article-summary,
.article-callout,
.rail-reference,
.rail-links {
  gap: 12px;
}
.guide-hero-media,
.article-hero-media,
.packages-hero-visual,
.pricing-media,
.combination-thumb,
.guide-card-media {
  border-radius: 18px;
}
.guide-focus-list li { padding: 15px 0; }
.guide-focus-list strong,
.article-faq summary,
.service-content h3,
.learning-card h3,
.pricing-card-body h3,
.combination-card h3,
.tour-body h3,
.audience-card h3 { color: #162230; }

.learning-card-grid,
.pricing-grid,
.combination-grid,
.tour-grid,
.audience-grid,
.audience-grid-commercial,
.simple-steps,
.comparison-grid { gap: 18px; }

.learning-card,
.pricing-card-body,
.combination-copy,
.tour-body,
.audience-card-body {
  gap: 10px;
}

.article-layout { align-items: start; }
.article-body section,
.article-callout,
.article-faq details,
.comparison-grid article {
  padding: clamp(16px, 2vw, 22px);
}
.article-body section { gap: 12px; }
.article-list { gap: 9px; }
.quiet-article-rail { top: 92px; }
.rail-links a { color: #2e4e6b; }

.packages-hero-copy { padding-top: 8px; }
.packages-hero-visual figure,
.pricing-media,
.combination-thumb,
.guide-card-media { box-shadow: 0 18px 36px rgba(10, 16, 24, 0.11); }

.decision-strip ul { gap: 8px; }
.decision-strip li { background: rgba(235, 241, 245, 0.94); }

.contact-detail-card,
.contact-chips li,
.field input,
.field select,
.field textarea {
  border-radius: 14px;
}
.contact-detail-card { background: rgba(242, 246, 248, 0.82); }
.contact-chips li { color: #5a6876; }
.field input,
.field select,
.field textarea { color: #203041; }

.footer-inner,
.footer-inner p { color: #627181; }

@media (max-width: 1120px) {
  .learning-card-grid,
  .pricing-grid,
  .combination-grid,
  .tour-grid,
  .comparison-grid,
  .audience-grid,
  .audience-grid-commercial { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .article-layout,
  .contact-grid,
  .packages-hero-grid,
  .learning-article-grid { grid-template-columns: 1fr; }
  .quiet-article-rail { position: static; }
}

@media (max-width: 760px) {
  .hero-content-wrap { gap: 18px; }
  .hero-content { border-radius: 18px; }
  .hero-media-strip { grid-template-columns: 1fr; }
  .hero-media-strip img { min-height: 150px; }
  .split-intro,
  .learning-card-grid,
  .pricing-grid,
  .combination-grid,
  .simple-steps,
  .tour-grid,
  .comparison-grid,
  .audience-grid,
  .audience-grid-commercial { grid-template-columns: 1fr; }
  .section-bridge,
  .decision-strip,
  .learning-cta,
  .packages-cta { flex-direction: column; align-items: flex-start; }
  .packages-hero-visual { grid-template-columns: 1fr; }
  .hero-visual-stack { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .guide-focus-list li { grid-template-columns: 1fr; }
  .guide-focus-list p { grid-column: auto; }
}
