@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Spectral:ital,wght@0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700&display=swap');

/* ─── Tokens ─── */
:root {
    --bg:           #FDFBF7;
    --surface:      #F4F0E6;
    --surface-2:    #EAE4D8;
    --border:       rgba(0,52,61,0.09);
    --border-light: rgba(0,52,61,0.18);
    --text:         #00343d;
    --text-muted:   #2e6158;
    --text-dim:     rgba(0,52,61,0.45);
    --accent:       #cbad68;
    --accent-hover: #b89a50;
    --accent-bg:    rgba(203,173,104,0.10);
    --teal:         #00343d;
    --honey:        #9e7b1a;
    --font-serif:   'Spectral', Georgia, serif;
    --font-display: 'Spectral', Georgia, serif;
    --font-body:    'Outfit', sans-serif;
    --radius:       10px;
    --radius-lg:    20px;
    --ease:         cubic-bezier(0.25,0.46,0.45,0.94);
    --ease-out:     cubic-bezier(0.16,1,0.3,1);
    --nav-h:        72px;
    --max-w:        1400px;
    --pad:          56px;
}

/* ─── Film Grain ─── */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 9000;
    opacity: 0.026;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C%2Ffilter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C%2Fsvg%3E");
    background-repeat: repeat;
    background-size: 200px;
}

/* ─── Reset ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
    background: var(--bg);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.65;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
ul { list-style: none; }
img { display: block; max-width: 100%; }
.cursor, .cursor-ring { display: none !important; }

/* ─── Max-width container ─── */
.container {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0 var(--pad);
}

/* ─── Navigation ─── */
nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    height: var(--nav-h);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 var(--pad);
    background: var(--teal);
    border-bottom: 1px solid rgba(255,255,255,0.07);
    transition: box-shadow .5s var(--ease);
}
nav.scrolled { box-shadow: 0 1px 32px rgba(0,0,0,.30); }
.nav-logo { display: flex; align-items: center; }
.nav-logo-img { height: 52px; width: auto; }
.nav-links { display: flex; align-items: center; gap: 32px; }
.nav-links a {
    font-size: 13px; letter-spacing: 0.01em;
    color: rgba(255,255,255,0.55);
    transition: color .25s ease;
}
.nav-links a:hover, .nav-links a.active { color: #fff; }
.nav-cta { display: flex; align-items: center; gap: 10px; }
.btn-ghost {
    font-family: var(--font-body);
    font-size: 13px; font-weight: 500;
    color: rgba(255,255,255,0.65);
    padding: 8px 16px;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.16);
    transition: color .25s, background .25s, border-color .25s;
}
.btn-ghost:hover { color: #fff; background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.32); }
.btn-primary {
    font-family: var(--font-body);
    font-size: 13px; font-weight: 600;
    color: var(--teal);
    background: var(--accent);
    padding: 9px 20px;
    border-radius: 6px;
    transition: background .25s, transform .25s;
    will-change: transform;
}
.btn-primary:hover { background: var(--accent-hover); transform: translateY(-1px); }

/* ─── Hamburger ─── */
.nav-hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    padding: 8px;
    z-index: 1100;
    cursor: pointer;
}
.nav-hamburger span { display: block; width: 22px; height: 1px; background: rgba(255,255,255,0.70); border-radius: 1px; }
.nav-mobile {
    position: fixed; inset: 0;
    background: var(--teal);
    z-index: 1090;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    opacity: 0; pointer-events: none;
    transition: opacity 0.25s var(--ease);
}
.nav-mobile.open { opacity: 1; pointer-events: all; }
.nav-mobile-close {
    position: absolute; top: 28px; right: 28px;
    color: rgba(255,255,255,0.40); padding: 8px; cursor: pointer;
}
.nav-mobile-close:hover { color: #fff; }
.nav-mobile-links { display: flex; flex-direction: column; align-items: center; gap: 4px; margin-bottom: 40px; }
.nav-mobile-links a {
    font-family: var(--font-serif);
    font-size: 28px; font-weight: 600; letter-spacing: -0.01em;
    color: rgba(255,255,255,0.55); padding: 10px 24px;
    transition: color 0.2s; display: block;
}
.nav-mobile-links a:hover, .nav-mobile-links a.active { color: var(--accent); }
.nav-mobile-cta { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

/* ─── Hero Split (Homepage) ─── */
.hero-split {
    display: grid;
    grid-template-columns: 48fr 52fr;
    min-height: 100dvh;
    padding-top: var(--nav-h);
}
.hero-split-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 80px var(--pad) 80px var(--pad);
}
.hero-split-visual {
    position: relative;
    overflow: hidden;
    background: transparent;
}
.hero-visual-inner {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}
.hero-visual-grid {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(var(--border) 1px, transparent 1px),
        linear-gradient(90deg, var(--border) 1px, transparent 1px);
    background-size: 48px 48px;
    opacity: .5;
}
.hero-visual-map {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center;
}
.hero-mobile-video { display: none; }
.hero-visual-fade {
    position: absolute; inset: 0;
    background:
        linear-gradient(to right,  var(--bg) 0%, transparent 28%),
        linear-gradient(to left,   var(--bg) 0%, transparent 28%),
        linear-gradient(to bottom, var(--bg) 0%, transparent 14%),
        linear-gradient(to top,    var(--bg) 0%, transparent 14%);
    pointer-events: none;
    z-index: 1;
}
.hero-visual-accent {
    position: absolute;
    top: 40px; right: 40px;
    width: 180px; height: 180px;
    border: 1px solid rgba(203,173,104,0.20);
    border-radius: 50%;
}
.hero-visual-accent::after {
    content: '';
    position: absolute;
    inset: 20px;
    border: 1px solid rgba(203,173,104,0.12);
    border-radius: 50%;
}
.hero-visual-tag {
    position: absolute;
    bottom: 48px; left: 40px;
    font-size: 10px; font-weight: 700;
    color: var(--accent);
    letter-spacing: .14em;
    text-transform: uppercase;
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    opacity: 0.6;
}
.hero-visual-stat {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}
.hero-visual-stat-n {
    font-family: var(--font-serif);
    font-size: clamp(52px, 6vw, 80px);
    font-weight: 200;
    letter-spacing: -0.04em;
    line-height: 1;
    color: rgba(0,52,61,0.08);
}
.hero-eyebrow {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 10px; font-weight: 700;
    color: var(--text-muted);
    letter-spacing: .14em; text-transform: uppercase;
    margin-bottom: 32px;
}
.hero-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--accent); }
.hero-title {
    font-family: var(--font-serif);
    font-size: clamp(48px, 5.5vw, 84px);
    font-weight: 700;
    line-height: 1.03;
    letter-spacing: -0.03em;
    margin-bottom: 28px;
}
.hero-title em { font-style: italic; color: var(--accent); font-weight: 500; }
.hero-desc {
    font-size: 17px;
    line-height: 1.78;
    color: var(--text-muted);
    max-width: 480px;
    margin-bottom: 44px;
}
.hero-desc em { font-style: italic; color: var(--accent); }
.hero-actions { display: flex; align-items: center; gap: 14px; margin-bottom: 56px; }
.btn-xl {
    font-family: var(--font-body);
    font-size: 14px; font-weight: 600;
    color: var(--teal);
    background: var(--accent);
    padding: 15px 30px;
    border-radius: 6px;
    display: flex; align-items: center; gap: 9px;
    transition: background .3s, transform .3s;
    will-change: transform;
}
.btn-xl:hover { background: var(--accent-hover); transform: translateY(-2px); }
.btn-xl-outline {
    font-family: var(--font-body);
    font-size: 14px; font-weight: 500;
    color: var(--text-muted);
    padding: 15px 30px;
    border-radius: 6px;
    border: 1px solid var(--border-light);
    display: flex; align-items: center; gap: 9px;
    transition: color .3s, background .3s, border-color .3s;
}
.btn-xl-outline:hover { color: var(--text); background: var(--surface-2); border-color: rgba(0,52,61,0.28); }
.hero-proof { display: flex; align-items: center; gap: 28px; }
.proof-item { display: flex; flex-direction: column; gap: 3px; }
.proof-val { font-family: var(--font-serif); font-size: 24px; font-weight: 700; letter-spacing: -.03em; }
.proof-val span { color: var(--accent); }
.proof-lbl { font-size: 11px; color: var(--text-muted); letter-spacing: 0.02em; }
.proof-sep { width: 1px; height: 32px; background: var(--border-light); }
.hero-scroll {
    position: absolute;
    bottom: 36px; left: var(--pad);
    display: flex; flex-direction: column; align-items: flex-start; gap: 6px;
    z-index: 2; opacity: 0.40; pointer-events: none;
    color: var(--text-muted);
    animation: scrollFadeIn 1.2s ease 1s both;
}
.hero-scroll-label { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; }
.hero-scroll-icon { animation: scrollBounce 2s ease-in-out infinite; }
@keyframes scrollBounce { 0%,100%{transform:translateY(0)} 50%{transform:translateY(5px)} }
@keyframes scrollFadeIn { from{opacity:0;transform:translateY(6px)} to{opacity:0.40;transform:translateY(0)} }

/* ─── Page Hero (Inner Pages) ─── */
.page-hero {
    padding: clamp(100px,12vw,160px) var(--pad) clamp(60px,8vw,100px);
    margin-top: var(--nav-h);
    position: relative;
    overflow: hidden;
}
.page-hero-inner { max-width: 780px; }
.page-hero-eyebrow {
    font-size: 10px; font-weight: 700;
    color: var(--text-muted);
    letter-spacing: .15em; text-transform: uppercase;
    margin-bottom: 24px;
    display: flex; align-items: center; gap: 10px;
}
.page-hero-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--accent); }
.page-hero-title {
    font-family: var(--font-serif);
    font-size: clamp(42px, 5.5vw, 80px);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.04;
    margin-bottom: 28px;
}
.page-hero-title em { font-style: italic; color: var(--accent); font-weight: 500; }
.page-hero-desc {
    font-size: 18px; line-height: 1.75;
    color: var(--text-muted);
    max-width: 560px;
}
.page-hero-bg {
    position: absolute;
    top: 0; right: 0;
    width: 40%;
    height: 100%;
    background-image:
        linear-gradient(var(--border) 1px, transparent 1px),
        linear-gradient(90deg, var(--border) 1px, transparent 1px);
    background-size: 48px 48px;
    opacity: .4;
    mask-image: linear-gradient(to left, rgba(0,0,0,0.3) 0%, transparent 100%);
    -webkit-mask-image: linear-gradient(to left, rgba(0,0,0,0.3) 0%, transparent 100%);
    pointer-events: none;
}

/* ─── Marquee ─── */
.marquee-wrap {
    background: var(--teal);
    padding: 18px 0;
    overflow: hidden;
    border-top: 1px solid rgba(255,255,255,0.06);
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.marquee-track {
    display: flex;
    width: max-content;
    animation: marquee 36s linear infinite;
}
.marquee-track:hover { animation-play-state: paused; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.m-item {
    display: flex; align-items: center; gap: 14px;
    padding: 0 36px;
    white-space: nowrap;
    font-size: 11px; font-weight: 600;
    color: rgba(255,255,255,0.45);
    letter-spacing: .12em; text-transform: uppercase;
}
.m-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--accent); opacity: .6; flex-shrink: 0; }

/* ─── Section Base ─── */
section { padding: clamp(72px,9vw,120px) var(--pad); }
.s-eyebrow, .s-tag {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 10px; font-weight: 700;
    color: var(--text-muted);
    letter-spacing: .15em; text-transform: uppercase;
    margin-bottom: 20px;
}
.s-eyebrow::before, .s-tag::before { content: ''; width: 24px; height: 1px; background: var(--accent); }
.s-title {
    font-family: var(--font-serif);
    font-size: clamp(32px, 4vw, 56px);
    font-weight: 700;
    letter-spacing: -0.025em;
    line-height: 1.07;
}
.s-title em { font-style: italic; color: var(--accent); font-weight: 500; }
.section-divider {
    border: none;
    border-top: 1px solid var(--border);
    margin: 0 var(--pad);
}
.s-desc {
    font-size: 17px; color: var(--text-muted);
    line-height: 1.72; max-width: 480px;
    margin-top: 18px;
}
.s-header {
    display: flex; align-items: flex-end;
    justify-content: space-between;
    gap: 40px;
    margin-bottom: 56px;
}
.s-link {
    font-size: 13px; font-weight: 600;
    color: var(--text-muted);
    display: flex; align-items: center; gap: 6px;
    letter-spacing: 0.02em;
    white-space: nowrap;
    transition: color .25s;
    flex-shrink: 0;
}
.s-link:hover { color: var(--text); }
.s-link svg { transition: transform .25s; }
.s-link:hover svg { transform: translateX(3px); }

/* ─── Services Bento (Asymmetric) ─── */
.bento-asymm {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 12px;
    align-items: stretch;
}
.bento-hero { grid-column: span 7; grid-row: span 2; }
.bento-sm   { grid-column: span 5; }
.svc {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 40px;
    position: relative;
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: border-color .35s, background .35s, transform .35s;
    cursor: default;
}
.svc::after {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(203,173,104,0), transparent);
    transition: background .35s;
}
.svc:hover { border-color: var(--border-light); background: var(--surface-2); transform: translateY(-3px); }
.svc:hover::after { background: linear-gradient(90deg, transparent, rgba(203,173,104,.40), transparent); }
.svc-num {
    font-family: var(--font-serif);
    font-size: 11px; font-weight: 700;
    color: var(--accent);
    letter-spacing: .14em; text-transform: uppercase;
    margin-bottom: 40px;
}
.bento-hero .svc-num { font-size: clamp(80px, 10vw, 140px); font-weight: 800; letter-spacing: -.05em; color: var(--border); margin-bottom: 0; position: absolute; bottom: -20px; right: 20px; line-height: 1; }
.svc-icon {
    width: 44px; height: 44px;
    background: var(--accent-bg);
    border: 1px solid rgba(203,173,104,.18);
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 24px; flex-shrink: 0;
}
.svc-icon svg { width: 21px; height: 21px; stroke: var(--accent); fill: none; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.svc-name {
    font-family: var(--font-serif);
    font-size: clamp(20px, 2.2vw, 30px); font-weight: 700;
    letter-spacing: -.025em; line-height: 1.1;
    margin-bottom: 16px;
}
.svc-p { font-size: 15px; line-height: 1.72; color: var(--text-muted); flex: 1; }
.svc-tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 28px; }
.svc-tag {
    font-size: 10px; font-weight: 600;
    color: var(--text-muted);
    background: var(--accent-bg);
    border: 1px solid rgba(203,173,104,0.20);
    padding: 4px 10px; border-radius: 3px;
    letter-spacing: 0.05em; text-transform: uppercase;
}
.svc-arr {
    position: absolute; bottom: 28px; right: 28px;
    width: 36px; height: 36px;
    border-radius: 50%; border: 1px solid var(--border-light);
    display: flex; align-items: center; justify-content: center;
    transition: background .3s, border-color .3s;
}
.svc:hover .svc-arr { background: var(--teal); border-color: var(--teal); }
.svc-arr svg { width: 13px; height: 13px; stroke: var(--text-muted); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; transition: stroke .3s; }
.svc:hover .svc-arr svg { stroke: var(--bg); }
.svc-arr a { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; }

/* ─── Stats Strip (Dark) ─── */
.stats-dark {
    background: var(--teal);
    border-top: none; border-bottom: none;
}
.stats-dark .stats-row {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0 var(--pad);
}
.stats-dark .stat-cell {
    padding: 36px 32px;
    border-right: 1px solid rgba(255,255,255,0.08);
}
.stats-dark .stat-cell:last-child { border-right: none; }
.stat-n {
    font-family: var(--font-serif);
    font-size: clamp(24px,2.8vw,40px);
    font-weight: 500; letter-spacing: -.025em;
    line-height: 1; margin-bottom: 10px;
    color: var(--bg);
}
.stat-n span { color: var(--accent); }
.stat-lbl { font-size: 13px; color: rgba(253,251,247,0.45); line-height: 1.5; }

/* ─── Projects Editorial ─── */
.projects-editorial {
    display: grid;
    grid-template-columns: 7fr 5fr;
    grid-template-rows: 1fr 1fr;
    gap: 14px;
}
.proj-hero-card { grid-column: 1; grid-row: span 2; }
.proj-sm-card   { grid-column: 2; }
.proj {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: border-color .35s, transform .35s;
    cursor: default;
    display: flex; flex-direction: column;
}
.proj:hover { border-color: var(--border-light); transform: translateY(-4px); }
.proj-img { position: relative; overflow: hidden; flex-shrink: 0; }
.proj-hero-card .proj-img { height: 320px; }
.proj-sm-card .proj-img { height: 170px; }
.proj-img-inner {
    width: 100%; height: 100%;
    position: relative; display: flex;
    align-items: center; justify-content: center;
}
.pi-blue  { background: linear-gradient(140deg,#0D1A2E,#14253E); }
.pi-amber { background: linear-gradient(140deg,#1C1208,#2C1E0E); }
.pi-green { background: linear-gradient(140deg,#0C1E18,#0E2B20); }
.proj-grid-lines {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
    background-size: 28px 28px;
}
.proj-badge {
    position: absolute; bottom: 14px; left: 14px;
    font-size: 10px; font-weight: 700;
    color: var(--accent); letter-spacing: .08em; text-transform: uppercase;
    background: rgba(28,16,7,0.80);
    border: 1px solid rgba(203,173,104,.24);
    padding: 4px 10px; border-radius: 3px;
}
.proj-body { padding: 24px; flex: 1; }
.proj-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.proj-type { font-size: 10px; font-weight: 700; color: var(--accent); letter-spacing: .07em; text-transform: uppercase; }
.proj-sep { width: 3px; height: 3px; border-radius: 50%; background: var(--border-light); }
.proj-yr { font-size: 11px; color: var(--text-muted); }
.proj-name { font-family: var(--font-serif); font-size: 17px; font-weight: 600; letter-spacing: -.02em; margin-bottom: 4px; }
.proj-loc { font-size: 13px; color: var(--text-muted); }
.proj-outcomes { display: flex; gap: 14px; margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--border); }
.oc { flex: 1; }
.oc-v { font-family: var(--font-serif); font-size: 17px; font-weight: 700; letter-spacing: -.02em; }
.oc-l { font-size: 11px; color: var(--text-muted); margin-top: 1px; }

/* ─── Process Steps (Homepage) ─── */
.process-bg { background: var(--surface); }
.process-steps { display: flex; flex-direction: column; }
.process-step {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 48px;
    padding: 48px 0;
    border-top: 1px solid var(--border);
    transition: background .3s;
}
.process-step:last-child { border-bottom: 1px solid var(--border); }
.step-num {
    font-family: var(--font-serif);
    font-size: clamp(48px, 5vw, 72px); font-weight: 800;
    letter-spacing: -.04em; line-height: 1;
    color: rgba(0,52,61,0.08);
    padding-top: 4px;
}
.step-body { display: flex; flex-direction: column; justify-content: center; }
.step-label {
    font-size: 10px; font-weight: 700;
    color: var(--accent); letter-spacing: .14em;
    text-transform: uppercase; margin-bottom: 10px;
}
.step-title {
    font-family: var(--font-serif);
    font-size: clamp(20px, 2.5vw, 30px); font-weight: 700;
    letter-spacing: -.02em; margin-bottom: 14px;
}
.step-p { font-size: 15px; line-height: 1.72; color: var(--text-muted); max-width: 640px; }

/* ─── Testimonials Editorial ─── */
.testi-editorial {
    display: grid;
    grid-template-columns: 6fr 3fr 3fr;
    gap: 14px;
    align-items: start;
}
.testi-featured { grid-column: 1; }
.testi {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 40px;
    transition: border-color .3s, transform .3s;
}
.testi:hover { border-color: var(--border-light); transform: translateY(-2px); }
.testi-featured {
    background: var(--teal);
    border-color: transparent;
}
.testi-featured .testi-q { color: rgba(253,251,247,0.85); }
.testi-featured .t-name { color: var(--bg); }
.testi-featured .t-role { color: rgba(253,251,247,0.50); }
.testi-featured .star { fill: var(--accent); }
.testi-featured .t-av { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.12); color: var(--accent); }
.testi-stars { display: flex; gap: 4px; margin-bottom: 24px; }
.star { width: 13px; height: 13px; fill: var(--accent); }
.testi-q { font-size: 15px; line-height: 1.78; color: var(--text); margin-bottom: 28px; font-style: italic; }
.testi-author { display: flex; align-items: center; gap: 12px; }
.t-av {
    width: 42px; height: 42px; border-radius: 50%;
    background: var(--surface-2); border: 1px solid var(--border-light);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-serif); font-size: 13px; font-weight: 700;
    color: var(--accent); flex-shrink: 0;
}
.t-name { font-family: var(--font-serif); font-size: 14px; font-weight: 600; margin-bottom: 2px; }
.t-role { font-size: 12px; color: var(--text-muted); }

/* ─── CTA Section ─── */
.cta-section { background: var(--surface); border-top: 1px solid var(--border); }
.cta-box {
    background: var(--teal);
    border-radius: var(--radius-lg);
    padding: clamp(64px,9vw,112px) 80px;
    text-align: center;
    position: relative; overflow: hidden;
}
.cta-box::before {
    content: '';
    position: absolute; top: -80px; left: 50%;
    transform: translateX(-50%);
    width: 600px; height: 320px;
    background: radial-gradient(circle, rgba(203,173,104,.09) 0%, transparent 70%);
    pointer-events: none;
}
.cta-title {
    font-family: var(--font-serif);
    font-size: clamp(36px,5vw,68px); font-weight: 800;
    letter-spacing: -.035em; line-height: 1.03;
    margin-bottom: 20px; color: var(--bg);
}
.cta-title em { color: var(--accent); font-style: italic; }
.cta-desc { font-size: 17px; color: rgba(253,251,247,0.60); max-width: 480px; margin: 0 auto 48px; line-height: 1.70; }
.cta-btns { display: flex; align-items: center; justify-content: center; gap: 14px; }
.cta-note { font-size: 12px; color: rgba(253,251,247,0.30); margin-top: 22px; letter-spacing: .03em; }
.cta-box .s-eyebrow { color: rgba(253,251,247,0.40); justify-content: center; margin-bottom: 20px; }
.cta-box .s-eyebrow::before { background: rgba(203,173,104,0.50); }
.cta-box .btn-xl { background: var(--accent); color: var(--teal); }
.cta-box .btn-xl:hover { background: var(--accent-hover); }
.cta-box .btn-xl-outline { border-color: rgba(253,251,247,0.22); color: rgba(253,251,247,0.75); background: transparent; }
.cta-box .btn-xl-outline:hover { background: rgba(253,251,247,0.07); border-color: rgba(253,251,247,0.40); color: var(--bg); }

/* ─── Footer ─── */
footer { background: var(--teal); padding: 80px var(--pad) 40px; }
.footer-top {
    display: grid;
    grid-template-columns: 2fr repeat(3,1fr);
    gap: 64px; margin-bottom: 64px;
}
.footer-logo-img { height: 52px; width: auto; margin-bottom: 16px; }
.footer-brand-desc { font-size: 14px; color: rgba(253,251,247,0.46); line-height: 1.72; max-width: 260px; }
.footer-col-title {
    font-family: var(--font-serif);
    font-size: 10px; font-weight: 700;
    color: rgba(253,251,247,0.30);
    letter-spacing: .12em; text-transform: uppercase;
    margin-bottom: 20px;
}
.footer-links { display: flex; flex-direction: column; gap: 12px; }
.footer-links a { font-size: 14px; color: rgba(253,251,247,0.52); transition: color .25s; }
.footer-links a:hover { color: #fff; }
.footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.08);
    padding-top: 28px;
    display: flex; align-items: center; justify-content: space-between;
}
.footer-copy { font-size: 12px; color: rgba(253,251,247,0.24); }
.footer-legal { display: flex; gap: 22px; }
.footer-legal a { font-size: 12px; color: rgba(253,251,247,0.24); transition: color .25s; }
.footer-legal a:hover { color: rgba(253,251,247,0.65); }

/* ─── Scroll Reveal ─── */
.reveal {
    opacity: 0; transform: translateY(24px);
    transition: opacity .70s var(--ease-out), transform .70s var(--ease-out);
}
.reveal.d1 { transition-delay: .08s; }
.reveal.d2 { transition-delay: .16s; }
.reveal.d3 { transition-delay: .24s; }
.reveal.d4 { transition-delay: .32s; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ─── Inner Page Shared ─── */
.surface-section { background: var(--surface); }

/* Split section (about, services detail) */
.split-section {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}
.split-section.reverse { direction: rtl; }
.split-section.reverse > * { direction: ltr; }
.split-visual {
    border-radius: var(--radius-lg);
    overflow: hidden;
    aspect-ratio: 4/3;
    background: var(--surface);
    border: 1px solid var(--border);
    position: relative;
}
.split-visual-inner {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(var(--border) 1px, transparent 1px),
        linear-gradient(90deg, var(--border) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: .6;
}
.split-visual-accent {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 120px; height: 120px;
    border: 1px solid rgba(203,173,104,0.22);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
}
.split-visual-accent::after {
    content: '';
    width: 80px; height: 80px;
    border: 1px solid rgba(203,173,104,0.12);
    border-radius: 50%;
}

/* Team cards */
.team-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.team-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 48px;
    transition: border-color .35s, transform .35s;
}
.team-card:hover { border-color: var(--border-light); transform: translateY(-3px); }
.team-av {
    width: 64px; height: 64px; border-radius: 50%;
    background: var(--teal);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-serif); font-size: 20px; font-weight: 700;
    color: var(--accent); margin-bottom: 28px; border: 2px solid rgba(203,173,104,0.30);
}
.team-name { font-family: var(--font-serif); font-size: clamp(22px,2.5vw,30px); font-weight: 700; letter-spacing: -.02em; margin-bottom: 6px; }
.team-role { font-size: 13px; color: var(--accent); letter-spacing: 0.02em; margin-bottom: 28px; font-weight: 600; }
.team-bio { font-size: 15px; line-height: 1.75; color: var(--text-muted); margin-bottom: 28px; }
.team-bio + .team-bio { margin-top: -12px; }
.team-tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 28px; }
.team-tag {
    font-size: 10px; font-weight: 600; color: var(--text-muted);
    background: var(--accent-bg); border: 1px solid rgba(203,173,104,0.20);
    padding: 4px 10px; border-radius: 3px;
    letter-spacing: 0.05em; text-transform: uppercase;
}

/* Brand pillars */
.pillars-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; }
.pillar {
    background: var(--surface);
    padding: 48px 40px;
    transition: background .3s;
}
.pillar:hover { background: var(--surface-2); }
.pillar-n { font-family: var(--font-serif); font-size: 10px; font-weight: 700; color: var(--accent); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 20px; }
.pillar-title { font-family: var(--font-serif); font-size: 20px; font-weight: 700; letter-spacing: -.02em; margin-bottom: 12px; }
.pillar-p { font-size: 14px; line-height: 1.70; color: var(--text-muted); }

/* Values */
.values-list { display: flex; flex-direction: column; }
.value-item {
    display: grid; grid-template-columns: 60px 1fr;
    gap: 40px; padding: 48px 0;
    border-top: 1px solid var(--border);
}
.value-item:last-child { border-bottom: 1px solid var(--border); }
.value-n { font-family: var(--font-serif); font-size: 10px; font-weight: 700; color: var(--accent); letter-spacing: .14em; text-transform: uppercase; padding-top: 5px; }
.value-title { font-family: var(--font-serif); font-size: clamp(20px,2.5vw,28px); font-weight: 700; letter-spacing: -.02em; margin-bottom: 14px; }
.value-p { font-size: 15px; line-height: 1.75; color: var(--text-muted); max-width: 600px; }

/* Services page arms */
.service-arm {
    padding: clamp(72px,9vw,120px) var(--pad);
    position: relative;
}
.service-arm-alt { background: var(--surface); }
.service-arm-inner {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 4fr 8fr;
    gap: 80px;
    align-items: start;
}
.service-arm-label { position: sticky; top: calc(var(--nav-h) + 32px); }
.service-arm-num { font-family: var(--font-serif); font-size: 10px; font-weight: 700; color: var(--accent); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 16px; }
.service-arm-title { font-family: var(--font-serif); font-size: clamp(32px,4vw,52px); font-weight: 700; letter-spacing: -.025em; line-height: 1.06; margin-bottom: 16px; }
.service-arm-tagline { font-size: 14px; color: var(--text-muted); font-style: italic; margin-bottom: 32px; }
.service-arm-lead { font-size: 17px; line-height: 1.75; color: var(--text-muted); margin-bottom: 48px; }
.service-arm-lead strong { color: var(--text); font-weight: 600; }
.capabilities-list { display: flex; flex-direction: column; }
.cap-item {
    display: grid; grid-template-columns: 24px 1fr;
    gap: 20px; padding: 28px 0;
    border-top: 1px solid var(--border);
}
.cap-item:last-child { border-bottom: 1px solid var(--border); }
.cap-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); margin-top: 8px; flex-shrink: 0; }
.cap-title { font-family: var(--font-serif); font-size: 17px; font-weight: 600; letter-spacing: -.01em; margin-bottom: 6px; }
.cap-p { font-size: 14px; line-height: 1.70; color: var(--text-muted); }

/* Integration banner */
.integration-banner {
    background: var(--teal);
    padding: clamp(64px,8vw,100px) var(--pad);
}
.integration-banner-inner {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: 1fr auto;
    gap: 60px; align-items: center;
}
.integration-label { font-size: 10px; font-weight: 700; color: rgba(253,251,247,0.35); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 16px; }
.integration-title { font-family: var(--font-serif); font-size: clamp(28px,4vw,52px); font-weight: 700; letter-spacing: -.025em; line-height: 1.07; color: var(--bg); margin-bottom: 16px; }
.integration-desc { font-size: 16px; line-height: 1.72; color: rgba(253,251,247,0.58); max-width: 560px; }
.integration-links { display: flex; flex-direction: column; gap: 14px; align-items: flex-start; white-space: nowrap; }
.integration-link { font-size: 13px; font-weight: 600; color: rgba(253,251,247,0.65); display: flex; align-items: center; gap: 8px; transition: color .25s; }
.integration-link:hover { color: var(--accent); }

/* Process page (full page) */
.process-arm {
    padding: clamp(72px,9vw,120px) var(--pad);
    position: relative;
}
.process-arm-alt { background: var(--surface); }
.process-arm-inner { max-width: var(--max-w); margin: 0 auto; }
.process-phase {
    display: grid;
    grid-template-columns: 6fr 6fr;
    gap: 80px; align-items: start;
    position: relative;
}
.process-phase-label { position: sticky; top: calc(var(--nav-h) + 32px); }
.phase-tag { font-size: 10px; font-weight: 700; color: var(--accent); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 20px; }
.phase-num { font-family: var(--font-serif); font-size: clamp(80px,10vw,140px); font-weight: 800; letter-spacing: -.05em; line-height: 1; color: rgba(0,52,61,0.07); margin-bottom: 12px; }
.phase-title { font-family: var(--font-serif); font-size: clamp(28px,3.5vw,46px); font-weight: 700; letter-spacing: -.025em; line-height: 1.07; margin-bottom: 20px; }
.phase-lead { font-size: 16px; line-height: 1.75; color: var(--text-muted); }
.phase-lead strong { color: var(--text); font-weight: 600; }
.phase-details { display: flex; flex-direction: column; margin-top: 8px; }
.phase-detail {
    padding: 28px 0;
    border-top: 1px solid var(--border);
}
.phase-detail:last-child { border-bottom: 1px solid var(--border); }
.phase-detail-title { font-family: var(--font-serif); font-size: 17px; font-weight: 600; letter-spacing: -.01em; margin-bottom: 8px; display: flex; align-items: center; gap: 12px; }
.phase-detail-title::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); flex-shrink: 0; }
.phase-detail-p { font-size: 14px; line-height: 1.70; color: var(--text-muted); padding-left: 18px; }
.process-callout {
    background: var(--teal);
    border-radius: var(--radius-lg);
    padding: 64px;
    margin-top: 80px;
}
.process-callout-label { font-size: 10px; font-weight: 700; color: rgba(203,173,104,0.60); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 16px; }
.process-callout-title { font-family: var(--font-serif); font-size: clamp(24px,3vw,40px); font-weight: 700; letter-spacing: -.025em; line-height: 1.08; margin-bottom: 16px; color: var(--bg); }
.process-callout-body { font-size: 16px; line-height: 1.72; color: rgba(253,251,247,0.58); margin-bottom: 48px; max-width: 600px; }
.callout-points { display: grid; grid-template-columns: 1fr 1fr; gap: 32px 48px; }
.callout-point-title { font-family: var(--font-serif); font-size: 16px; font-weight: 700; letter-spacing: -.01em; color: var(--bg); margin-bottom: 8px; display: flex; align-items: center; gap: 10px; }
.callout-point-title::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--accent); flex-shrink: 0; }
.callout-point-p { font-size: 13px; line-height: 1.68; color: rgba(253,251,247,0.52); padding-left: 15px; }

/* Projects page full grid */
.proj-filters { display: flex; align-items: center; gap: 8px; margin-bottom: 48px; flex-wrap: wrap; }
.proj-filter {
    font-size: 12px; font-weight: 600;
    color: var(--text-muted);
    padding: 7px 16px; border-radius: 4px;
    border: 1px solid var(--border-light);
    background: transparent;
    letter-spacing: 0.03em; cursor: pointer;
    transition: color .25s, background .25s, border-color .25s;
}
.proj-filter.active, .proj-filter:hover { color: var(--text); background: var(--surface-2); border-color: rgba(0,52,61,0.25); }
.proj-filter.active { background: var(--teal); color: #fff; border-color: var(--teal); }
.projects-full-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.proj-full { grid-column: auto; }
.proj-featured { grid-column: span 2; }
.proj-full .proj-img { height: 200px; }
.proj-featured .proj-img { height: 280px; }
.proj-status-badge {
    position: absolute; top: 14px; right: 14px;
    font-size: 10px; font-weight: 700;
    color: rgba(60,200,120,0.85); letter-spacing: .07em; text-transform: uppercase;
    background: rgba(0,0,0,0.70); padding: 4px 10px; border-radius: 3px;
    border: 1px solid rgba(60,200,120,0.25);
}
.proj-tags-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.proj-pill {
    font-size: 10px; font-weight: 600; color: var(--text-muted);
    background: var(--accent-bg); border: 1px solid rgba(203,173,104,0.18);
    padding: 3px 9px; border-radius: 3px; letter-spacing: 0.04em; text-transform: uppercase;
}
.proj-disclaimer {
    font-size: 12px; color: var(--text-dim);
    line-height: 1.65; margin-top: 48px;
    padding-top: 32px; border-top: 1px solid var(--border);
    max-width: 700px;
}

/* Contact page */
.contact-layout {
    display: grid;
    grid-template-columns: 6fr 4fr;
    gap: 80px;
    align-items: start;
}
.contact-form-wrap { flex: 1; }
.form-tabs { display: flex; gap: 0; margin-bottom: 40px; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
.form-tab {
    flex: 1; padding: 14px 20px; font-family: var(--font-body);
    font-size: 14px; font-weight: 600; text-align: center;
    color: var(--text-muted); background: transparent; cursor: pointer;
    border: none; transition: color .25s, background .25s;
}
.form-tab.active { background: var(--teal); color: #fff; }
.form-tab:hover:not(.active) { background: var(--surface-2); color: var(--text); }
.form-field { margin-bottom: 24px; }
.form-field label { display: block; font-size: 12px; font-weight: 700; color: var(--text-muted); letter-spacing: .08em; text-transform: uppercase; margin-bottom: 8px; }
.form-field input, .form-field select, .form-field textarea {
    width: 100%; padding: 14px 16px;
    font-family: var(--font-body); font-size: 15px;
    color: var(--text); background: var(--bg);
    border: 1px solid var(--border-light); border-radius: 8px;
    transition: border-color .25s;
    -webkit-appearance: none;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus {
    outline: none; border-color: var(--accent);
}
.form-field textarea { min-height: 140px; resize: vertical; line-height: 1.65; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-privacy { font-size: 12px; color: var(--text-dim); line-height: 1.65; margin-top: 16px; }
.contact-sidebar { display: flex; flex-direction: column; gap: 20px; position: sticky; top: calc(var(--nav-h) + 32px); }
.contact-card {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 32px;
}
.contact-card-title { font-family: var(--font-serif); font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 20px; }
.contact-detail { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; }
.contact-detail:last-child { margin-bottom: 0; }
.contact-detail-label { font-size: 11px; font-weight: 700; color: var(--text-dim); letter-spacing: .07em; text-transform: uppercase; width: 48px; flex-shrink: 0; padding-top: 2px; }
.contact-detail-val { font-size: 14px; color: var(--text); line-height: 1.5; }
.hours-row { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--border); font-size: 14px; }
.hours-row:last-child { border-bottom: none; }
.hours-day { color: var(--text-muted); }
.hours-time { color: var(--text); font-weight: 600; }
.map-embed { border-radius: 10px; overflow: hidden; border: 1px solid var(--border); }
.map-embed iframe { display: block; width: 100%; height: 220px; }
.sub-toggle { display: flex; gap: 0; margin-bottom: 28px; border: 1px solid var(--border); border-radius: 6px; overflow: hidden; }
.sub-toggle-btn {
    flex: 1; padding: 11px 16px; font-family: var(--font-body);
    font-size: 13px; font-weight: 600; text-align: center; cursor: pointer;
    color: var(--text-muted); background: transparent; border: none;
    transition: color .25s, background .25s;
}
.sub-toggle-btn.active { background: var(--teal); color: #fff; }
.conditional-field { display: none; }
.conditional-field.visible { display: block; }
.form-success {
    display: none; text-align: center; padding: 60px 40px;
    background: var(--surface); border-radius: var(--radius-lg);
    border: 1px solid var(--border);
}
.form-success.visible { display: block; }
.form-success-icon { width: 56px; height: 56px; background: var(--accent-bg); border: 1px solid rgba(203,173,104,.25); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; }
.form-success-title { font-family: var(--font-serif); font-size: 24px; font-weight: 700; letter-spacing: -.02em; margin-bottom: 12px; }
.form-success-desc { font-size: 15px; color: var(--text-muted); line-height: 1.70; }

/* Listings */
.listings-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.listing-card {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 32px;
    transition: border-color .35s, transform .35s;
}
.listing-card:hover { border-color: var(--border-light); transform: translateY(-3px); }
.listing-status { display: flex; align-items: center; gap: 8px; margin-bottom: 20px; }
.listing-badge {
    font-size: 10px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
    padding: 4px 10px; border-radius: 3px;
}
.badge-acquired { color: rgba(60,200,120,0.85); background: rgba(60,200,120,0.08); border: 1px solid rgba(60,200,120,0.20); }
.badge-type { color: var(--accent); background: var(--accent-bg); border: 1px solid rgba(203,173,104,0.20); }
.listing-suburb { font-size: 12px; color: var(--text-muted); margin-bottom: 6px; }
.listing-address { font-family: var(--font-serif); font-size: 18px; font-weight: 700; letter-spacing: -.02em; margin-bottom: 14px; line-height: 1.25; }
.listing-desc { font-size: 14px; line-height: 1.70; color: var(--text-muted); margin-bottom: 20px; }
.listing-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.listing-tag {
    font-size: 10px; font-weight: 600; color: var(--text-muted);
    background: var(--accent-bg); border: 1px solid rgba(203,173,104,0.18);
    padding: 3px 9px; border-radius: 3px; letter-spacing: 0.04em; text-transform: uppercase;
}

/* ─── Responsive ─── */
@media (max-width: 1100px) {
    :root { --pad: 40px; }
    .hero-split { display: flex; flex-direction: column; min-height: auto; }
    .hero-split-visual { display: block; order: -1; height: 50vw; min-height: 230px; max-height: 380px; flex-shrink: 0; }
    .hero-split-text { padding: 44px var(--pad) 52px; }
    .hero-mobile-video { display: none; }
    .hero-visual-fade {
        background:
            linear-gradient(to right,  var(--bg) 0%, transparent 8%),
            linear-gradient(to left,   var(--bg) 0%, transparent 8%),
            linear-gradient(to bottom, var(--bg) 0%, transparent 5%),
            linear-gradient(to top,    var(--bg) 0%, transparent 48%);
    }
    .bento-asymm { grid-template-columns: 1fr 1fr; }
    .bento-hero, .bento-sm { grid-column: span 1; grid-row: auto; }
    .bento-hero .svc-num { font-size: 80px; }
    .stats-dark .stats-row { grid-template-columns: repeat(2,1fr); }
    .stats-dark .stat-cell:nth-child(2) { border-right: none; }
    .stats-dark .stat-cell:nth-child(3), .stats-dark .stat-cell:nth-child(4) { border-top: 1px solid rgba(255,255,255,0.08); }
    .projects-editorial { grid-template-columns: 1fr 1fr; }
    .proj-hero-card { grid-column: span 2; grid-row: auto; }
    .proj-sm-card { grid-column: auto; }
    .testi-editorial { grid-template-columns: 1fr 1fr; }
    .testi-featured { grid-column: span 2; }
    .footer-top { grid-template-columns: 1fr 1fr; gap: 40px; }
    .split-section { grid-template-columns: 1fr; gap: 48px; }
    .team-grid { grid-template-columns: 1fr; }
    .service-arm-inner { grid-template-columns: 1fr; gap: 48px; }
    .service-arm-label { position: static; }
    .integration-banner-inner { grid-template-columns: 1fr; gap: 40px; }
    .contact-layout { grid-template-columns: 1fr; gap: 48px; }
    .contact-sidebar { position: static; }
    .listings-grid { grid-template-columns: 1fr 1fr; }
    .projects-full-grid { grid-template-columns: 1fr 1fr; }
    .proj-featured { grid-column: span 2; }
    .process-phase { grid-template-columns: 1fr; gap: 40px; }
    .process-phase-label { position: static; }
    .phase-num { font-size: 80px; }
    .callout-points { grid-template-columns: 1fr; gap: 24px; }
    .pillars-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    :root { --pad: 24px; }
    nav { padding: 0 var(--pad); }
    .nav-links { display: none; }
    .nav-hamburger { display: flex; }
    .nav-cta { display: none !important; }
    section { padding: 64px var(--pad); }
    .service-arm, .process-arm { padding: 64px var(--pad); }
    .hero-split-visual { height: 56vw; max-height: 270px; }
    .hero-split-text { padding: 32px var(--pad) 40px; }
    .hero-title { font-size: clamp(34px, 9vw, 48px); }
    .hero-eyebrow { margin-bottom: 18px; }
    .hero-desc { font-size: 15px; line-height: 1.70; margin-bottom: 28px; }
    .hero-actions { flex-direction: column; align-items: stretch; gap: 10px; margin-bottom: 36px; }
    .hero-actions .btn-xl { justify-content: center; }
    .hero-actions .btn-xl-outline { justify-content: center; }
    .hero-proof { flex-wrap: wrap; gap: 14px; }
    .hero-scroll { display: none; }
    .page-hero { padding: 80px var(--pad) 56px; }
    .s-header { flex-direction: column; align-items: flex-start; }
    .bento-asymm { grid-template-columns: 1fr; }
    .stats-dark .stats-row { grid-template-columns: 1fr 1fr; padding: 0 var(--pad); }
    .projects-editorial { grid-template-columns: 1fr; grid-template-rows: auto; align-items: start; }
    .proj-hero-card, .proj-sm-card { grid-column: auto; grid-row: auto; }
    .testi-editorial { grid-template-columns: 1fr; }
    .testi-featured { grid-column: auto; }
    .cta-box { padding: 52px 28px; }
    .cta-btns { flex-direction: column; }
    .footer-top { grid-template-columns: 1fr; gap: 36px; }
    .footer-bottom { flex-direction: column; gap: 14px; text-align: center; }
    .team-grid { grid-template-columns: 1fr; }
    .pillars-grid { grid-template-columns: 1fr; }
    .value-item { grid-template-columns: 1fr; gap: 8px; }
    .value-n { padding-top: 0; }
    .process-step { grid-template-columns: 1fr; gap: 12px; }
    .step-num { font-size: 48px; }
    .listings-grid { grid-template-columns: 1fr; }
    .projects-full-grid { grid-template-columns: 1fr; }
    .proj-featured { grid-column: auto; }
    .contact-layout { grid-template-columns: 1fr; }
    .form-row { grid-template-columns: 1fr; }
    .integration-banner-inner { grid-template-columns: 1fr; }
    .process-callout { padding: 40px 28px; }
}

/* ─── Premium Ambient Glow Elements (Design Upgrade 3) ─── */
.hero-split-text {
    position: relative;
    overflow: visible;
}
.hero-ambient-glow {
    position: absolute;
    top: 15%;
    left: -5%;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(203, 173, 104, 0.14) 0%, rgba(203, 173, 104, 0) 70%);
    pointer-events: none;
    z-index: 0;
    filter: blur(40px);
    animation: floatGlow 12s ease-in-out infinite alternate;
}
@keyframes floatGlow {
    0% { transform: translate(0, 0) scale(1); }
    100% { transform: translate(40px, -30px) scale(1.15); }
}
.hero-eyebrow, .hero-title, .hero-desc, .hero-actions, .hero-proof {
    position: relative;
    z-index: 2;
}


