/* ── TOKENS ─────────────────────────────────────────── */
:root{
    --bg:        #d9d7d2;
    --paper:     #ececea;
    --paper-2:   #e4e1d8;
    --ink:       #0a0a0a;
    --ink-soft:  #2a2a2a;
    --ink-mute:  #6a6a64;
    --rule:      rgba(0,0,0,0.18);
    --rule-soft: rgba(0,0,0,0.08);
    --hairline:  1px;

    --orange-a:  #ff7a18;
    --orange-b:  #ffc24b;
    --violet:    #7e6dd6;
    --peach:     #ff8e6a;
    --teal:      #4a9d8a;
    --pink:      #e88ec8;
    --lime:      #b6d147;

    --nav-h:     60px;
    --side-w:    48px;
    --gut:       clamp(20px, 4vw, 56px);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
    font-family:'Inter Tight','Helvetica Neue',Helvetica,Arial,sans-serif;
    background:var(--paper);
    color:var(--ink);
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    overflow-x:hidden;
    font-weight:500;
    letter-spacing:-0.005em;
    line-height:1.45;
}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button{font-family:inherit;}

/* ── SITE NAV ──────────────────────────────────────── */
.site-nav{
    position:sticky; top:0; z-index:100;
    background:rgba(236,236,234,0.94);
    backdrop-filter:saturate(140%) blur(10px);
    -webkit-backdrop-filter:saturate(140%) blur(10px);
    border-bottom:var(--hairline) solid var(--rule-soft);
    display:grid;
    grid-template-columns: auto 1fr auto;
    align-items:center;
    padding:0 var(--gut);
    height:var(--nav-h);
    gap:32px;
}
.site-logo{
    display:flex; align-items:center;
}
.site-logo img{height:22px; width:auto; display:block;}
.primary-nav{display:flex; gap:0; justify-self:center; align-items:center;}
.primary-nav a{
    padding:8px 18px;
    font-size:13px; font-weight:600; letter-spacing:0.02em;
    position:relative;
    color:var(--ink-soft);
    transition:color .15s;
}
.primary-nav a:hover{color:var(--ink);}
.primary-nav a.active{color:var(--ink);}
.primary-nav a.active::after{
    content:''; position:absolute; left:18px; right:18px; bottom:0;
    height:1.5px; background:var(--ink);
}
.site-cta{
    display:inline-flex; align-items:center; gap:8px;
    padding:10px 18px; background:var(--ink); color:#fff; border-radius:100px;
    font-size:12px; font-weight:600; letter-spacing:0.02em;
    transition:background .2s, transform .2s;
}
.site-cta:hover{background:var(--orange-a); transform:translateY(-1px);}

/* mobile menu toggle */
.menu-toggle{display:none; background:none; border:none; cursor:pointer; padding:8px;}
.menu-toggle span{display:block; width:20px; height:1.5px; background:var(--ink); margin:4px 0;}

/* ── PAGE SHELL ─────────────────────────────────────── */
.page-shell{
    display:grid;
    grid-template-columns: var(--side-w) 1fr;
    min-height:calc(100vh - var(--nav-h));
    background:var(--paper);
}

/* sticky vertical sidebar — slides with content */
.vertical-side{
    border-right:var(--hairline) solid var(--rule-soft);
    position:sticky;
    top:var(--nav-h);
    height:calc(100vh - var(--nav-h));
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:space-between;
    padding:24px 0;
}
.vertical-side .v-text{
    writing-mode:vertical-rl;
    transform:rotate(180deg);
    font-size:10.5px; font-weight:600; letter-spacing:0.18em; text-transform:uppercase;
    white-space:nowrap;
    color:var(--ink-soft);
}
.vertical-side .v-dot{
    width:6px; height:6px; border-radius:50%; background:var(--ink);
    margin:8px 0;
}

.page-main{min-width:0;}

/* ── HERO ───────────────────────────────────────────── */
.page-hero{
    position:relative;
    padding:64px var(--gut) 80px;
    overflow:hidden;
    border-bottom:var(--hairline) solid var(--rule-soft);
}
.hero-eyebrow{
    display:inline-flex; align-items:center; gap:10px;
    font-size:11px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase;
    margin-bottom:28px;
}
.hero-eyebrow::after{content:''; display:inline-block; width:32px; height:1px; background:var(--ink);}

.hero-inner{
    position:relative; z-index:1;
    display:grid;
    grid-template-columns: 1.15fr 1fr;
    gap:56px;
    align-items:end;
    min-height:380px;
}
.hero-headline{
    font-family:'Inter Tight','Helvetica Neue',sans-serif;
    font-weight:700;
    font-size:clamp(40px,5.5vw,84px);
    line-height:1.02;
    letter-spacing:-0.03em;
    text-transform:uppercase;
    max-width:14ch;
}
.hero-headline.compact{font-size:clamp(34px,4vw,60px);}
.hero-lede{
    font-size:16px; line-height:1.55; color:var(--ink); font-weight:500;
    max-width:42ch;
    margin-bottom:6px;
}
.hero-mark{width:54px; height:32px; margin-bottom:36px; position:relative;}
.hero-mark .circle{position:absolute; left:0; top:0; width:28px; height:28px; border-radius:50%; background:var(--ink);}
.hero-mark .square{position:absolute; left:16px; top:3px; width:26px; height:26px; border:1.5px solid var(--ink);}

.hero-crumb{
    position:absolute; right:var(--gut); top:28px;
    font-size:11px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase;
    color:var(--ink-soft); z-index:2;
}
.hero-crumb a:hover{color:var(--orange-a);}

/* ── ORB ────────────────────────────────────────────── */
.orb{
    position:absolute; border-radius:50%;
    filter:blur(40px);
    pointer-events:none;
    mix-blend-mode:multiply;
    z-index:0;
}
.orb.hero-orb{
    width:680px; height:680px;
    right:-100px; top:-80px;
    background: radial-gradient(closest-side,
        var(--orange-a) 0%, var(--orange-a) 18%,
        var(--orange-b) 45%, rgba(255,194,75,0.6) 60%,
        rgba(126,109,214,0.55) 80%, rgba(126,109,214,0.0) 100%);
    animation:breath 14s ease-in-out infinite alternate;
}
.orb.violet{background: radial-gradient(closest-side, var(--violet) 0%, var(--violet) 22%, var(--pink) 50%, rgba(232,142,200,0.4) 75%, transparent 100%);}
.orb.teal{background: radial-gradient(closest-side, var(--teal) 0%, var(--teal) 25%, var(--lime) 55%, rgba(182,209,71,0.3) 80%, transparent 100%);}
.orb.peach{background: radial-gradient(closest-side, var(--peach) 0%, var(--peach) 25%, var(--orange-b) 55%, rgba(255,194,75,0.3) 80%, transparent 100%);}
.orb.small{width:440px; height:440px;}
.orb.tl{left:-160px; top:-80px; right:auto;}
.orb.br{right:-180px; bottom:-200px; top:auto;}
.orb.tr{right:-100px; top:-100px;}
@keyframes breath{
    0%{transform:scale(1) translate(0,0);}
    100%{transform:scale(1.04) translate(-12px, 8px);}
}

/* ── SECTION PRIMITIVES ─────────────────────────────── */
.section{
    padding:80px var(--gut);
    border-top:var(--hairline) solid var(--rule-soft);
    position:relative;
    overflow:hidden;
}
.section.tight{padding:56px var(--gut);}
.section.flush{border-top:none;}
.section.alt{background:var(--paper-2);}
.section.dark{background:var(--ink); color:#fff;}
.section.dark .section-eyebrow, .section.dark .section-sub{color:rgba(255,255,255,0.6);}

.section-eyebrow{
    display:inline-flex; align-items:center; gap:10px;
    font-size:11px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase;
    color:var(--ink-soft);
    margin-bottom:18px;
}
.section-eyebrow::before{content:''; display:inline-block; width:24px; height:1px; background:currentColor;}

.section-head{
    display:grid;
    grid-template-columns: 1.2fr 1fr;
    gap:48px;
    align-items:end;
    margin-bottom:48px;
}
.section-head h2{
    font-family:'Inter Tight','Helvetica Neue',sans-serif;
    font-weight:700;
    font-size:clamp(32px,4vw,60px);
    line-height:1.0;
    letter-spacing:-0.03em;
    text-transform:uppercase;
    max-width:14ch;
}
.section-sub{
    font-size:15px; line-height:1.6; color:var(--ink-soft); max-width:42ch;
}

/* ── BUTTONS ────────────────────────────────────────── */
.btn{
    display:inline-flex; align-items:center; gap:12px;
    padding:14px 22px; background:var(--ink); color:#fff;
    font-size:12px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase;
    border-radius:100px;
    cursor:pointer; border:none;
    transition:background .2s, transform .2s;
}
.btn:hover{background:var(--orange-a); transform:translateY(-1px);}
.btn.ghost{background:transparent; color:var(--ink); border:1px solid var(--ink);}
.btn.ghost:hover{background:var(--ink); color:#fff;}
.btn.lg{padding:18px 28px; font-size:13px;}

.btn-row{display:flex; gap:12px; flex-wrap:wrap; align-items:center; margin-top:24px;}

/* ── STAT BAR ───────────────────────────────────────── */
.stat-bar{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:0;
}
.stat-bar .item{
    padding:32px 24px;
    border-right:var(--hairline) solid var(--rule-soft);
}
.stat-bar .item:last-child{border-right:none;}
.stat-bar .item:first-child{padding-left:0;}
.stat-bar .num{
    font-family:'Inter Tight';
    font-size:clamp(36px,4vw,56px);
    font-weight:700; letter-spacing:-0.03em; line-height:1;
}
.stat-bar .lab{font-size:11px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; margin-top:10px; color:var(--ink-soft);}
.stat-bar .des{font-size:13px; color:var(--ink-mute); margin-top:4px;}

/* ── SERVICES LIST ──────────────────────────────────── */
.svc-list{display:flex; flex-direction:column;}
.svc-row{
    display:grid;
    grid-template-columns: 56px 1.4fr 2fr 60px;
    gap:32px;
    padding:28px 0;
    border-top:var(--hairline) solid var(--rule-soft);
    align-items:start;
    transition:padding-left .3s, background .3s;
    text-decoration:none; color:inherit; cursor:pointer;
}
.svc-row:last-child{border-bottom:var(--hairline) solid var(--rule-soft);}
.svc-row:hover{padding-left:16px; background:rgba(0,0,0,0.02);}
.svc-row .n{font-size:13px; font-weight:600; letter-spacing:0.14em; padding-top:6px;}
.svc-row .t{
    font-family:'Inter Tight';
    font-size:clamp(22px,2.2vw,32px);
    line-height:1.05; letter-spacing:-0.025em; font-weight:700; text-transform:uppercase;
}
.svc-row .d{font-size:14px; line-height:1.6; color:var(--ink-soft); max-width:48ch; padding-top:4px;}
.svc-row .arrow{display:flex; justify-content:flex-end; align-items:flex-start; padding-top:8px;}
.svc-row .arrow svg{width:24px; height:24px; transition:transform .3s;}
.svc-row:hover .arrow svg{transform:translate(4px,-4px);}

/* ── FEATURED CASE ──────────────────────────────────── */
.featured{
    display:grid;
    grid-template-columns: 1.3fr 1fr;
    gap:56px;
    align-items:start;
}
.featured-img{
    aspect-ratio:4/3;
    background-size:cover; background-position:center;
    position:relative; overflow:hidden;
}
.featured-img .stamp{
    position:absolute; top:18px; left:18px;
    font-size:10.5px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase;
    color:#fff; padding:8px 14px; background:rgba(0,0,0,0.55); backdrop-filter:blur(6px);
}
.featured-side h3{
    font-family:'Inter Tight';
    font-size:clamp(28px,3.2vw,46px);
    line-height:1.0; letter-spacing:-0.025em; font-weight:700; text-transform:uppercase;
    margin-bottom:18px;
}
.featured-side p{font-size:15px; line-height:1.6; color:var(--ink-soft); margin-bottom:18px;}
.meta-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px 24px; padding-top:18px; border-top:var(--hairline) solid var(--rule); margin-top:18px;}
.meta-grid .k{font-size:10.5px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; margin-bottom:4px; color:var(--ink-soft);}
.meta-grid .v{font-size:15px; font-weight:600;}

/* ── WORK GRID ──────────────────────────────────────── */
.work-grid{
    display:grid;
    grid-template-columns: repeat(3,1fr);
    gap:24px 20px;
}
.work-grid .wcard{cursor:pointer; background:transparent; text-decoration:none; color:inherit;}
.work-grid .img{
    aspect-ratio:4/5;
    background-size:cover; background-position:center;
    margin-bottom:12px;
    transition:transform .35s ease;
}
.work-grid .wcard:hover .img{transform:scale(1.015);}
.work-grid .meta{
    display:flex; justify-content:space-between; align-items:start;
    gap:16px; padding-top:6px;
    border-top:var(--hairline) solid var(--rule);
}
.work-grid .name{font-family:'Inter Tight'; font-size:16px; font-weight:700; text-transform:uppercase; letter-spacing:-0.01em; line-height:1.1;}
.work-grid .cat{font-size:10px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-soft); white-space:nowrap; padding-top:3px;}
.work-grid .yr{font-size:10px; font-weight:600; letter-spacing:0.12em; color:var(--ink-soft); display:block; margin-top:3px;}

.filter-row{
    display:flex; gap:0; flex-wrap:wrap;
    margin-bottom:36px;
    border-bottom:var(--hairline) solid var(--rule);
}
.ftab{
    padding:10px 16px;
    font-size:11.5px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase;
    background:transparent; border:none; color:var(--ink-soft);
    cursor:pointer; transition:color .15s;
}
.ftab:hover{color:var(--ink);}
.ftab.active{color:var(--ink); position:relative;}
.ftab.active::after{content:''; position:absolute; left:16px; right:16px; bottom:-1px; height:2px; background:var(--ink);}

/* ── LOGO STRIP ─────────────────────────────────────── */
.logo-strip{
    display:grid;
    grid-template-columns:repeat(8,1fr);
    border-top:var(--hairline) solid var(--rule);
    border-bottom:var(--hairline) solid var(--rule);
}
.logo-strip .cell{
    display:flex; align-items:center; justify-content:center;
    border-right:var(--hairline) solid var(--rule-soft);
    padding:16px;
}
.logo-strip .cell:last-child{border-right:none;}
.logo-strip .cell img{max-height:100px; max-width:100%; transition:filter .2s;}

.logo-wall{
    display:grid;
    grid-template-columns:repeat(6,1fr);
    border-top:var(--hairline) solid var(--rule);
}
.logo-wall .cell{
    aspect-ratio:5/3;
    display:flex; align-items:center; justify-content:center;
    border-right:var(--hairline) solid var(--rule-soft);
    border-bottom:var(--hairline) solid var(--rule-soft);
    padding:24px;
}
.logo-wall .cell:nth-child(6n){border-right:none;}
.logo-wall .cell img{max-height:30px; max-width:100%; object-fit:contain; filter:grayscale(100%) opacity(.7); transition:filter .2s;}
.logo-wall .cell:hover img{filter:grayscale(0%) opacity(1);}

/* ── PROCESS TABLE ──────────────────────────────────── */
.proc-table{display:flex; flex-direction:column;}
.proc-row{
    display:grid;
    grid-template-columns: 56px 1.2fr 2fr 1fr;
    gap:32px;
    padding:24px 0;
    border-top:var(--hairline) solid var(--rule-soft);
    align-items:start;
}
.proc-row:last-child{border-bottom:var(--hairline) solid var(--rule-soft);}
.proc-row .n{font-size:13px; font-weight:600; letter-spacing:0.14em;}
.proc-row .t{font-family:'Inter Tight'; font-size:20px; font-weight:700; text-transform:uppercase; letter-spacing:-0.015em; line-height:1.05;}
.proc-row .d{font-size:14px; line-height:1.6; color:var(--ink-soft); max-width:48ch;}
.proc-row .when{font-size:12px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-soft); text-align:right; padding-top:4px;}

/* ── TESTIMONIAL ────────────────────────────────────── */
.testimonial{
    display:grid;
    grid-template-columns: 1fr 2fr;
    gap:64px;
    align-items:start;
}
.testimonial .quote{
    font-family:'Inter Tight';
    font-size:clamp(24px,2.8vw,40px);
    line-height:1.2; letter-spacing:-0.02em; font-weight:600;
    max-width:24ch;
}
.testimonial .src{
    margin-top:32px; padding-top:18px;
    border-top:var(--hairline) solid var(--rule);
    font-size:12px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase;
}
.testimonial .src span{display:block; color:var(--ink-soft); margin-top:4px;}

/* ── CONTACT ────────────────────────────────────────── */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start;}
.contact-form{display:flex; flex-direction:column;}
.contact-form .field{
    display:flex; flex-direction:column;
    border-bottom:var(--hairline) solid var(--rule);
    padding:14px 0;
}
.contact-form .field label{
    font-size:10.5px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase;
    color:var(--ink-soft); margin-bottom:6px;
}
.contact-form input, .contact-form textarea, .contact-form select{
    background:transparent; border:none; outline:none;
    font-family:'Inter Tight'; font-size:15px; font-weight:500; color:var(--ink);
}
.contact-form input::placeholder, .contact-form textarea::placeholder{color:rgba(0,0,0,0.35);}
.contact-form textarea{resize:none; height:72px;}
.contact-form select{appearance:none; -webkit-appearance:none; padding-right:24px; cursor:pointer;}
.contact-form .field.select{position:relative;}
.contact-form .field.select::after{content:'↓'; position:absolute; right:0; bottom:14px; font-size:12px; pointer-events:none;}
.contact-form button{margin-top:20px; align-self:flex-start;}

.contact-info .lead{
    font-family:'Inter Tight'; font-size:clamp(28px,3.2vw,44px);
    line-height:1.05; letter-spacing:-0.025em; font-weight:700; text-transform:uppercase;
    max-width:16ch;
}
.contact-info p{font-size:15px; line-height:1.6; color:var(--ink-soft); margin-top:20px; max-width:36ch;}
.direct-links{margin-top:32px;}
.direct-links a{
    display:flex; justify-content:space-between; align-items:center;
    padding:14px 0; border-bottom:var(--hairline) solid var(--rule-soft);
}
.direct-links a:hover{color:var(--orange-a);}
.direct-links a .k{font-size:11px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-soft);}
.direct-links a .v{font-size:14px; font-weight:600;}

/* ── TEAM ───────────────────────────────────────────── */
.team-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:24px;}
.team-card .photo{
    aspect-ratio:4/5; background:rgba(0,0,0,0.05); margin-bottom:12px;
    position:relative; overflow:hidden;
}
.team-card .photo .ph-label{
    position:absolute; left:12px; bottom:12px;
    font-size:9.5px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase;
    color:rgba(0,0,0,0.4); font-family:'Courier New',monospace;
}
.team-card .name{font-family:'Inter Tight'; font-size:16px; font-weight:700; text-transform:uppercase; letter-spacing:-0.01em;}
.team-card .role{font-size:11.5px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-soft); margin-top:3px;}

/* ── STORY (about) ──────────────────────────────────── */
.story-grid{display:grid; grid-template-columns:1fr 1fr; gap:64px;}
.story-grid h3{font-family:'Inter Tight'; font-size:22px; text-transform:uppercase; font-weight:700; letter-spacing:-0.02em; margin-bottom:16px;}
.story-grid p{font-size:15px; line-height:1.65; color:var(--ink-soft); margin-bottom:14px; max-width:50ch;}
.story-grid p strong{font-weight:700; color:var(--ink);}

/* ── CASE STUDY ─────────────────────────────────────── */
.case-cover{aspect-ratio:16/9; background-size:cover; background-position:center;}
.case-block{
    display:grid; grid-template-columns: 1fr 2fr; gap:48px; align-items:start;
    padding:64px 0;
    border-top:var(--hairline) solid var(--rule-soft);
}
.case-block:first-child{border-top:none;}
.case-block .h{font-size:11.5px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; padding-top:6px;}
.case-block .h .n{display:block; font-family:'Inter Tight'; font-size:42px; font-weight:700; letter-spacing:-0.03em; margin-bottom:6px;}
.case-block .body p{font-size:16px; line-height:1.65; margin-bottom:16px; max-width:60ch;}
.case-block .body p strong{font-weight:700;}
.case-images{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
.case-images .ph{aspect-ratio:4/3; background-size:cover; background-position:center;}
.case-images .ph.wide{grid-column:span 2; aspect-ratio:16/7;}
.case-stats{display:grid; grid-template-columns:repeat(4,1fr); gap:24px;}
.case-stats .item{padding:24px 0;}
.case-stats .num{font-family:'Inter Tight'; font-size:clamp(40px,4.5vw,72px); font-weight:700; letter-spacing:-0.04em; line-height:1;}
.case-stats .lab{font-size:11.5px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; margin-top:8px;}
.case-stats .des{font-size:12.5px; color:var(--ink-soft); margin-top:4px;}
.case-pull{padding:60px 0; text-align:center;}
.case-pull .quote{font-family:'Inter Tight'; font-size:clamp(26px,3vw,42px); line-height:1.15; letter-spacing:-0.02em; font-weight:600; max-width:26ch; margin:0 auto;}
.case-pull .src{font-size:11.5px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; margin-top:24px;}

.case-next{display:grid; grid-template-columns:1fr 1fr; gap:24px;}
.case-next a{
    padding:28px; background:transparent;
    display:flex; flex-direction:column; gap:8px;
    border:var(--hairline) solid var(--rule);
    transition:background .2s;
}
.case-next a:hover{background:rgba(0,0,0,0.03);}
.case-next .lab{font-size:11px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-soft);}
.case-next .nm{font-family:'Inter Tight'; font-size:28px; font-weight:700; letter-spacing:-0.02em; text-transform:uppercase;}

/* ── FAQ ────────────────────────────────────────────── */
.faq-list{display:flex; flex-direction:column;}
.faq-item{
    border-top:var(--hairline) solid var(--rule-soft);
    padding:20px 0;
}
.faq-item:last-child{border-bottom:var(--hairline) solid var(--rule-soft);}
.faq-item summary{
    display:grid; grid-template-columns: 50px 1fr 30px; gap:24px; align-items:center;
    cursor:pointer; list-style:none;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item .n{font-size:13px; font-weight:600; letter-spacing:0.14em;}
.faq-item .q{font-family:'Inter Tight'; font-size:18px; font-weight:700; text-transform:uppercase; letter-spacing:-0.01em; line-height:1.2;}
.faq-item .toggle{font-size:18px; font-weight:600; justify-self:end; transition:transform .2s;}
.faq-item[open] .toggle{transform:rotate(45deg);}
.faq-item .a{
    margin-top:14px; padding-left:74px;
    font-size:14.5px; line-height:1.6; color:var(--ink-soft); max-width:60ch;
}

/* ── END-OF-PAGE CTA ────────────────────────────────── */
.end-cta{
    padding:96px var(--gut);
    position:relative; overflow:hidden;
    border-top:var(--hairline) solid var(--rule-soft);
}
.end-cta-inner{
    position:relative; z-index:1;
    display:grid; grid-template-columns:1.2fr 1fr; gap:56px; align-items:end;
}
.end-cta h2{
    font-family:'Inter Tight'; font-weight:700;
    font-size:clamp(36px,5vw,72px);
    line-height:1.0; letter-spacing:-0.03em; text-transform:uppercase;
    max-width:14ch;
}

/* ── SITE FOOTER ────────────────────────────────────── */
.site-footer{
    background:var(--ink); color:#fff;
    padding:72px var(--gut) 32px;
}
.footer-top{
    display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:48px;
    padding-bottom:56px;
    border-bottom:var(--hairline) solid rgba(255,255,255,0.12);
}
.footer-top h4{
    font-family:'Inter Tight'; font-weight:700;
    font-size:clamp(32px,4vw,56px); line-height:1.0;
    letter-spacing:-0.03em; text-transform:uppercase;
    max-width:14ch;
}
.footer-col h5{
    font-size:11px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase;
    color:rgba(255,255,255,0.5);
    margin-bottom:18px;
}
.footer-col a{display:block; padding:5px 0; font-size:14px; color:rgba(255,255,255,0.85);}
.footer-col a:hover{color:var(--orange-b);}
.footer-bot{
    display:flex; justify-content:space-between; align-items:center;
    margin-top:32px; gap:24px; flex-wrap:wrap;
    font-size:11.5px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase;
    color:rgba(255,255,255,0.55);
}
.footer-bot a{color:rgba(255,255,255,0.55);}
.footer-bot a:hover{color:#fff;}

/* ── RESPONSIVE ─────────────────────────────────────── */
@media (max-width:1100px){
    .hero-inner, .section-head, .featured, .testimonial, .contact-grid, .story-grid, .end-cta-inner, .case-block{grid-template-columns:1fr; gap:32px;}
    .work-grid{grid-template-columns:repeat(2,1fr);}
    .team-grid{grid-template-columns:repeat(2,1fr);}
    .logo-strip{grid-template-columns:repeat(4,1fr);}
    .logo-wall{grid-template-columns:repeat(4,1fr);}
    .logo-wall .cell:nth-child(6n){border-right:var(--hairline) solid var(--rule-soft);}
    .logo-wall .cell:nth-child(4n){border-right:none;}
    .stat-bar{grid-template-columns:repeat(2,1fr);}
    .stat-bar .item{border-bottom:var(--hairline) solid var(--rule-soft);}
    .case-stats{grid-template-columns:repeat(2,1fr);}
    .case-next{grid-template-columns:1fr;}
    .svc-row{grid-template-columns:48px 1fr; gap:18px;}
    .svc-row .d{grid-column:2;}
    .svc-row .arrow{display:none;}
    .proc-row{grid-template-columns:48px 1fr; gap:18px;}
    .proc-row .d, .proc-row .when{grid-column:2;}
    .proc-row .when{text-align:left; padding-top:4px;}
    .footer-top{grid-template-columns:1fr 1fr; gap:32px;}
}
@media (max-width:768px){
    .primary-nav{display:none;}
    .menu-toggle{display:block;}
    .page-shell{grid-template-columns:1fr;}
    .vertical-side{display:none;}
    .page-hero{padding:48px var(--gut) 64px;}
    .section{padding:56px var(--gut);}
    .hero-crumb{position:static; margin-bottom:14px; display:block;}
    .filter-row{overflow-x:auto; flex-wrap:nowrap;}
    .ftab{white-space:nowrap;}
    .work-grid, .team-grid{grid-template-columns:1fr;}
    .logo-strip, .logo-wall{grid-template-columns:repeat(2,1fr);}
    .logo-wall .cell:nth-child(4n){border-right:var(--hairline) solid var(--rule-soft);}
    .logo-wall .cell:nth-child(2n){border-right:none;}
    .footer-top{grid-template-columns:1fr;}
    .case-stats, .stat-bar{grid-template-columns:1fr 1fr;}
    .orb.hero-orb{width:420px; height:420px;}
}

/* mobile menu open */
.mobile-menu{
    display:none;
    position:fixed; inset:var(--nav-h) 0 0; z-index:99;
    background:var(--paper);
    padding:32px var(--gut);
    flex-direction:column; gap:14px;
}
.mobile-menu.open{display:flex;}
.mobile-menu a{
    font-family:'Inter Tight'; font-size:28px; font-weight:700; text-transform:uppercase; letter-spacing:-0.02em;
    padding:8px 0; border-bottom:var(--hairline) solid var(--rule-soft);
}
