/* ==========================================================================
   sections.css
   Per-page section styles. Every per-page rule is scoped under a wrapper
   class on <main> so /home, /about, /contact, and /services/<slug> can
   coexist in one global stylesheet without colliding.

   Wrappers:
     .home               → front-page.php
     .page-about         → page-about.php
     .page-contact       → page-contact.php
     .page-service       → single-service.php (with .svc-<slug-id> modifier)
     .archive-services   → archive-service.php

   Shared blocks (.cta) live in their own section at the top.
   ========================================================================== */


/* ==========================================================================
   === SHARED / CTA (every page) ===
   Source: home.html .cta / .cta-inner / .cta-row + same shape across pages
   ========================================================================== */

.cta{
	background:var(--navy-deep);color:var(--ivory);
	padding:clamp(96px,16vw,240px) var(--pad);
	position:relative;overflow:hidden;
}
.cta-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr;gap:48px}
.cta h2{
	font-family:var(--f-display);font-weight:700;
	font-size:clamp(56px,9vw,180px);line-height:.93;letter-spacing:-.035em;
	max-width:14ch;
}
.cta h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.cta-row{display:flex;justify-content:space-between;align-items:flex-end;gap:48px;border-top:1px solid rgba(245,242,236,.18);padding-top:32px;flex-wrap:wrap}
.cta-row .actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.cta-row .meta{font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.55;text-align:right;display:grid;gap:6px}
@media(max-width:900px){.cta-row .meta{text-align:left}}


/* ==========================================================================
   === HOME / HERO ===
   Source: home.html .hero / .hero-meta / .hero-mid / .hero-headline /
           .hero-bot / .hero-reel
   ========================================================================== */

.home .hero{
	min-height:100vh;background:var(--navy-deep);color:var(--ivory);
	display:grid;grid-template-rows:auto 1fr auto;
	padding:108px var(--pad) 40px;
	position:relative;overflow:hidden;
}
.home .hero-meta{display:flex;justify-content:space-between;align-items:flex-start;font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.6}
.home .hero-meta .right{text-align:right;display:grid;gap:6px}

.home .hero-mid{display:flex;align-items:center;padding:48px 0}
.home .hero-headline{
	font-family:var(--f-display);font-weight:700;
	font-size:clamp(64px,10vw,180px);line-height:.92;letter-spacing:-.035em;
}
.home .hero-headline em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold);letter-spacing:-.02em}
.home .hero-headline .line{display:block;overflow:hidden}
.home .hero-headline .line .inner{display:block;transform:translateY(110%);animation:najaha-rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.home .hero-headline .line:nth-child(2) .inner{animation-delay:.12s}
.home .hero-headline .line:nth-child(3) .inner{animation-delay:.24s}
.home .hero-headline .rotator{display:inline-block;font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold);letter-spacing:-.02em;position:relative;min-width:14ch}
.home .hero-headline .rotator span{position:absolute;left:0;top:0;white-space:nowrap;opacity:0;transform:translateY(28%);transition:opacity .55s ease, transform .55s cubic-bezier(.2,.7,.2,1)}
.home .hero-headline .rotator span.is-active{opacity:1;transform:translateY(0);position:relative}
@keyframes najaha-rise{from{transform:translateY(110%)}to{transform:translateY(0)}}

.home .hero-bot{
	display:grid;grid-template-columns:1fr auto;align-items:end;gap:48px;
	border-top:1px solid rgba(245,242,236,.18);padding-top:22px;
	font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
}
.home .hero-bot .lbl{opacity:.5;margin-right:10px}
.home .hero-bot .scroll-cue{display:flex;align-items:center;gap:10px;opacity:.7}
.home .hero-bot .scroll-cue .line-v{width:1px;height:32px;background:var(--ivory);opacity:.5;animation:najaha-cue 1.8s ease-in-out infinite}
@keyframes najaha-cue{0%{transform:scaleY(.2);transform-origin:top}50%{transform:scaleY(1)}100%{transform:scaleY(.2);transform-origin:bottom}}

.home .hero-reel{width:340px;aspect-ratio:16/9;background:linear-gradient(135deg,#274769,#0f2438);border:1px solid rgba(245,242,236,.18);position:relative;cursor:pointer;overflow:hidden;flex:none;transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.home .hero-reel:hover{transform:scale(1.03)}
.home .hero-reel .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.home .hero-reel .play::after{content:"";width:0;height:0;border-left:18px solid var(--ivory);border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:6px}
.home .hero-reel .reel-cap{position:absolute;left:12px;top:12px;font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;opacity:.6;text-transform:uppercase}
.home .hero-reel .reel-time{position:absolute;right:12px;bottom:12px;font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;opacity:.7;text-transform:uppercase}
.home .hero-reel::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(245,242,236,.04) 0 1px,transparent 1px 14px);pointer-events:none}

@media(max-width:900px){
	.home .hero-bot{grid-template-columns:1fr}
	.home .hero-reel{width:100%;max-width:340px}
}


/* ==========================================================================
   === HOME / MANIFESTO ===
   ========================================================================== */

.home .manifesto{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.home .mani-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:96px;max-width:var(--max);margin:0 auto;align-items:start}
.home .mani-grid h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,96px);line-height:.95;letter-spacing:-.03em;max-width:14ch;margin-top:18px}
.home .mani-grid h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--charcoal)}
.home .mani-body p{font-size:18px;line-height:1.6;margin-bottom:1.1em;max-width:48ch;color:var(--ink)}
.home .mani-body .dropcap{font-family:var(--f-edit);font-style:italic;font-weight:400;float:left;font-size:78px;line-height:.85;padding:8px 12px 0 0;color:var(--charcoal)}

.home .pq{max-width:var(--max);margin:120px auto 0;padding-left:48px;position:relative}
.home .pq::before{content:"";position:absolute;left:0;top:18px;width:40px;height:2px;background:var(--gold)}
.home .pq blockquote{font-family:var(--f-edit);font-style:italic;font-weight:400;font-size:clamp(32px,4.4vw,64px);line-height:1.12;letter-spacing:-.01em;color:var(--charcoal);max-width:22ch}
.home .pq cite{display:block;margin-top:32px;font-family:var(--f-mono);font-style:normal;font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.7}

@media(max-width:900px){.home .mani-grid{grid-template-columns:1fr;gap:48px}}


/* ==========================================================================
   === HOME / APPROACH (4 pillars) ===
   ========================================================================== */

.home .approach{
	background:var(--navy);color:var(--ivory);
	padding:clamp(80px,14vw,200px) var(--pad);
	position:relative;
	background-image:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 100%);
}
.home .approach .head{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:end;max-width:var(--max);margin:0 auto;margin-bottom:80px}
.home .approach h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.home .approach h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.home .approach .head p{font-size:17px;opacity:.7;max-width:42ch;line-height:1.6}

.home .pillars{max-width:var(--max);margin:0 auto;display:flex;flex-direction:column}
.home .pillar{
	display:grid;grid-template-columns:200px 1.2fr 1fr;gap:64px;align-items:center;
	border-top:1px solid rgba(245,242,236,.2);padding:64px 0;position:relative;
}
.home .pillar:last-child{border-bottom:1px solid rgba(245,242,236,.2)}
.home .pillar .n{font-family:var(--f-display);font-weight:700;font-size:clamp(96px,11vw,180px);line-height:.85;letter-spacing:-.04em;color:var(--ivory);opacity:.16}
.home .pillar h3{font-family:var(--f-display);font-weight:600;font-size:clamp(32px,4vw,56px);letter-spacing:-.02em;line-height:1;margin-bottom:18px}
.home .pillar p{font-size:17px;opacity:.72;line-height:1.55;max-width:40ch;margin-bottom:18px}
.home .pillar .tags{display:flex;gap:8px;flex-wrap:wrap}
.home .pillar .tags .pill{color:var(--ivory);border-color:rgba(245,242,236,.35)}
.home .pillar .img{aspect-ratio:5/4;background:linear-gradient(135deg,#274769,#0f2438);border:1px solid rgba(245,242,236,.18);position:relative;overflow:hidden}
.home .pillar .img::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(245,242,236,.05) 0 1px,transparent 1px 14px)}
.home .pillar .img .ph-cap{position:absolute;left:12px;bottom:12px;font-family:var(--f-mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--ivory);background:rgba(15,36,56,.7);border:1px solid rgba(245,242,236,.2);padding:6px 8px;z-index:1}

@media(max-width:1100px){.home .pillar{grid-template-columns:120px 1fr 1fr}}
@media(max-width:900px){.home .pillar{grid-template-columns:1fr;gap:24px}.home .pillar .n{font-size:80px}.home .approach .head{grid-template-columns:1fr}}


/* ==========================================================================
   === HOME / SELECTED WORK ===
   ========================================================================== */

.home .work{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.home .work .head{display:grid;grid-template-columns:1fr auto;align-items:end;max-width:var(--max);margin:0 auto 80px;gap:48px}
.home .work h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.home .work h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.home .work-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(12,1fr);gap:32px}

.home .case{position:relative;display:block;overflow:hidden;cursor:pointer}
.home .case .img-wrap{aspect-ratio:4/3;overflow:hidden;position:relative;background:var(--bone)}
.home .case .img-wrap .ph,
.home .case .img-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05);transition:filter .6s ease, transform .6s cubic-bezier(.2,.7,.2,1)}
.home .case:hover .ph,.home .case:hover img{filter:grayscale(0) contrast(1);transform:scale(1.04)}
.home .case .img-wrap .ph-cap{position:absolute;left:14px;bottom:14px;z-index:2;font-family:var(--f-mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;background:var(--ivory);color:var(--charcoal);padding:6px 10px;border:1px solid var(--stone);opacity:.92}
.home .case .meta{display:flex;justify-content:space-between;align-items:flex-end;padding:18px 0 6px;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);opacity:.7}
.home .case .title{font-family:var(--f-display);font-weight:600;font-size:clamp(22px,2vw,30px);letter-spacing:-.015em;line-height:1.1;margin-top:4px;display:flex;align-items:baseline;gap:14px}
.home .case .title .arr{font-family:var(--f-mono);font-weight:400;font-size:14px;opacity:.5;transform:translateX(0);transition:transform .35s,opacity .3s}
.home .case:hover .title .arr{opacity:1;transform:translateX(6px);color:var(--gold)}
.home .case .scope{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}

.home .work-grid .c-1{grid-column:1 / span 7}
.home .work-grid .c-2{grid-column:9 / span 4;align-self:end}
.home .work-grid .c-3{grid-column:1 / span 4}
.home .work-grid .c-4{grid-column:6 / span 7}
.home .work-grid .c-5{grid-column:1 / span 5}
.home .work-grid .c-6{grid-column:7 / span 5;align-self:start}
.home .work-grid .c-1 .img-wrap,.home .work-grid .c-4 .img-wrap{aspect-ratio:16/10}
.home .work-grid .c-2 .img-wrap,.home .work-grid .c-3 .img-wrap{aspect-ratio:3/4}

@media(max-width:1100px){
	.home .work-grid .c-1,.home .work-grid .c-2,.home .work-grid .c-3,.home .work-grid .c-4,.home .work-grid .c-5,.home .work-grid .c-6{grid-column:1 / -1}
	.home .work-grid .c-1 .img-wrap,.home .work-grid .c-2 .img-wrap,.home .work-grid .c-3 .img-wrap,.home .work-grid .c-4 .img-wrap{aspect-ratio:16/10}
}

.home .work-foot{max-width:var(--max);margin:80px auto 0;display:flex;justify-content:space-between;align-items:center;gap:32px;border-top:1px solid var(--stone);padding-top:32px;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink);opacity:.7}


/* ==========================================================================
   === HOME / CLIENTS MARQUEE ===
   ========================================================================== */

.home .clients{background:var(--charcoal);color:var(--ivory);padding:clamp(80px,12vw,160px) 0;position:relative}
.home .clients .shell-pad{padding:0 var(--pad)}
.home .clients .head{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;align-items:end;gap:48px;margin-bottom:64px}
.home .clients h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em}
.home .clients h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.home .clients .meta{font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.55;text-align:right}

.marquee{overflow:hidden;border-block:1px solid rgba(245,242,236,.18);padding:32px 0}
.marquee .track{display:flex;gap:96px;animation:najaha-slide 38s linear infinite;width:max-content;align-items:center}
.marquee--rev .track{animation-direction:reverse;animation-duration:46s}
.marquee .cell,.marquee .logo-cell{font-family:var(--f-display);font-weight:700;font-size:clamp(24px,2.4vw,36px);letter-spacing:.03em;color:var(--ivory);opacity:.55;flex:none;display:flex;align-items:center;gap:16px;text-transform:uppercase}
.marquee .cell .glyph,.marquee .logo-cell .glyph{width:32px;height:32px;border:1.6px solid currentColor;display:inline-block}
.marquee .cell .glyph.c,.marquee .logo-cell .glyph.c{border-radius:50%}
.marquee .cell .glyph.t,.marquee .logo-cell .glyph.t{transform:rotate(45deg)}
.marquee .cell .glyph.h{position:relative}
.marquee .cell .glyph.h::after{content:"";position:absolute;inset:46% 0 46% 0;background:currentColor}
@keyframes najaha-slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}


/* ==========================================================================
   === HOME / RECOGNITION ===
   ========================================================================== */

.home .recog{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.home .recog .head{max-width:var(--max);margin:0 auto 64px}
.home .recog h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.home .recog h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}

.home .awards{max-width:var(--max);margin:0 auto;border-top:1px solid var(--stone)}
.home .award{display:grid;grid-template-columns:120px 1fr 2fr auto;gap:48px;padding:28px 0;border-bottom:1px solid var(--stone);align-items:center;font-family:var(--f-display);font-size:clamp(20px,1.8vw,26px);letter-spacing:-.005em;transition:padding .35s, color .3s}
.home .award:hover{padding-left:14px;color:var(--charcoal)}
.home .award .y{font-family:var(--f-mono);font-size:13px;letter-spacing:.14em;opacity:.6}
.home .award .a{font-weight:600}
.home .award .p{opacity:.7;font-weight:400}
.home .award .ar{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.5;transition:transform .35s, opacity .3s, color .3s}
.home .award:hover .ar{transform:translateX(8px);opacity:1;color:var(--gold)}
@media(max-width:900px){.home .award{grid-template-columns:1fr;gap:6px}.home .award .ar{display:none}}


/* ==========================================================================
   === ABOUT / HERO (massive editorial display) ===
   Source: about.html .hero / .footer-row
   ========================================================================== */

.page-about .hero{background:var(--navy-deep);color:var(--ivory);padding:160px var(--pad) 120px;min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;gap:80px;position:relative}
.page-about .hero .meta{display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.6}
.page-about .hero h1{font-family:var(--f-display);font-weight:700;font-size:clamp(64px,11vw,220px);line-height:.88;letter-spacing:-.045em;max-width:14ch}
.page-about .hero h1 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-about .hero .footer-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;border-top:1px solid rgba(245,242,236,.18);padding-top:40px}
@media(max-width:1100px){.page-about .hero .footer-row{grid-template-columns:1fr}}
.page-about .hero .lede{max-width:50ch;font-size:clamp(17px,1.4vw,20px);opacity:.82;line-height:1.6}
.page-about .hero .footer-row .stats{display:flex;gap:32px;flex-wrap:wrap;justify-content:flex-end;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.page-about .hero .footer-row .stats > div{text-align:right}
.page-about .hero .footer-row .stats b{display:block;font-family:var(--f-display);font-weight:700;font-size:36px;letter-spacing:-.02em;margin-top:6px;color:var(--gold)}


/* ==========================================================================
   === ABOUT / STORY / PRINCIPLES / TEAM / TIMELINE / CLIENTS ===
   ========================================================================== */

.page-about .story{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-about .story-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:96px;align-items:start}
@media(max-width:1100px){.page-about .story-inner{grid-template-columns:1fr;gap:48px}}
.page-about .story h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;margin-top:14px;position:sticky;top:120px}
.page-about .story h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-about .story-body{display:grid;gap:28px}
.page-about .story-body p{font-size:18px;line-height:1.65;color:var(--ink);max-width:60ch}
.page-about .story-body p:first-of-type::first-letter{font-family:var(--f-edit);font-style:italic;font-weight:400;font-size:5em;line-height:.85;float:left;padding:8px 14px 0 0;color:var(--gold)}
.page-about .story-body p em{font-family:var(--f-edit);font-style:italic;font-weight:400}

.page-about .princ{padding:clamp(80px,14vw,200px) var(--pad);background:var(--bone)}
.page-about .princ .head{max-width:var(--max);margin:0 auto 80px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.page-about .princ h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;margin-top:14px;max-width:14ch}
.page-about .princ h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-about .princ-list{max-width:var(--max);margin:0 auto;border-top:1px solid var(--stone)}
.page-about .princ-row{display:grid;grid-template-columns:120px 1fr 1.4fr;gap:48px;padding:48px 0;border-bottom:1px solid var(--stone);align-items:start;transition:padding .35s}
.page-about .princ-row:hover{padding-left:14px}
.page-about .princ-row .n{font-family:var(--f-edit);font-style:italic;font-weight:400;font-size:64px;line-height:.85;color:var(--gold);letter-spacing:-.02em}
.page-about .princ-row h3{font-family:var(--f-display);font-weight:600;font-size:clamp(24px,2.4vw,32px);letter-spacing:-.015em;line-height:1.1}
.page-about .princ-row h3 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-about .princ-row p{font-size:16px;line-height:1.6;color:var(--ink);opacity:.78;max-width:48ch}
@media(max-width:900px){.page-about .princ-row{grid-template-columns:1fr;gap:14px}.page-about .princ-row .n{font-size:48px}}

.page-about .team{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-about .team .head{max-width:var(--max);margin:0 auto 64px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.page-about .team h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;margin-top:14px;max-width:18ch}
.page-about .team h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-about .team-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:32px 24px}
@media(max-width:900px){.page-about .team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.page-about .team-grid{grid-template-columns:1fr}}
.page-about .member{display:grid;gap:14px}
.page-about .member .ph{aspect-ratio:3/4;background:linear-gradient(135deg,#3a4a5a,#1f2a3a);position:relative;overflow:hidden;filter:grayscale(.2);transition:filter .5s}
.page-about .member:hover .ph{filter:grayscale(0)}
.page-about .member .ph::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(245,242,236,.05) 0 1px,transparent 1px 14px)}
.page-about .member .ph .ph-cap{position:absolute;left:10px;bottom:10px;font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;background:var(--ivory);color:var(--charcoal);padding:5px 8px;border:1px solid var(--stone);opacity:.92;z-index:2}
.page-about .member h3{font-family:var(--f-display);font-weight:600;font-size:18px;letter-spacing:-.005em;line-height:1.2}
.page-about .member .role{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6}
.page-about .member .bio{font-size:13px;line-height:1.5;opacity:.78;color:var(--ink)}

.page-about .team-stats{max-width:var(--max);margin:80px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--stone);border-left:1px solid var(--stone)}
@media(max-width:900px){.page-about .team-stats{grid-template-columns:repeat(2,1fr)}}
.page-about .tstat{padding:36px 28px;border-right:1px solid var(--stone);border-bottom:1px solid var(--stone);display:grid;gap:8px}
.page-about .tstat .n{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,4.5vw,64px);letter-spacing:-.03em;line-height:.9}
.page-about .tstat .n em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold);font-size:.7em}
.page-about .tstat .lbl{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6}

.page-about .tline{background:var(--charcoal);color:var(--ivory);padding:clamp(80px,14vw,200px) var(--pad)}
.page-about .tline .head{max-width:var(--max);margin:0 auto 64px}
.page-about .tline h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.page-about .tline h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-about .tline-list{max-width:var(--max);margin:0 auto;display:grid;gap:0}
.page-about .year{display:grid;grid-template-columns:160px 1fr;gap:48px;padding:32px 0;border-top:1px solid rgba(245,242,236,.18);align-items:start}
.page-about .year:last-child{border-bottom:1px solid rgba(245,242,236,.18)}
.page-about .year .y{font-family:var(--f-display);font-weight:700;font-size:clamp(36px,4vw,56px);letter-spacing:-.025em;line-height:1;color:var(--gold)}
.page-about .year .body{display:grid;gap:14px}
.page-about .year .body h4{font-family:var(--f-display);font-weight:600;font-size:clamp(22px,2vw,28px);letter-spacing:-.01em;line-height:1.15}
.page-about .year .body h4 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-about .year .body p{font-size:15px;line-height:1.55;opacity:.78;max-width:60ch}
@media(max-width:700px){.page-about .year{grid-template-columns:1fr;gap:14px}}

.page-about .clients{padding:clamp(80px,14vw,200px) var(--pad);background:var(--bone)}
.page-about .clients .head{max-width:var(--max);margin:0 auto 64px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.page-about .clients h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;max-width:18ch}
.page-about .clients h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-about .cl-marq{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--stone);border-left:1px solid var(--stone)}
@media(max-width:1100px){.page-about .cl-marq{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.page-about .cl-marq{grid-template-columns:repeat(2,1fr)}}
.page-about .cl-cell{aspect-ratio:3/2;border-right:1px solid var(--stone);border-bottom:1px solid var(--stone);display:grid;place-items:center;font-family:var(--f-display);font-weight:600;font-size:18px;letter-spacing:-.005em;color:var(--ink);opacity:.7;transition:opacity .3s,background .3s}
.page-about .cl-cell:hover{opacity:1;background:var(--ivory)}
.page-about .cl-cell em{font-family:var(--f-edit);font-style:italic;font-weight:400}


/* ==========================================================================
   === CONTACT / HERO + FORM SPLIT ===
   ========================================================================== */

.page-contact .hero{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
@media(max-width:1100px){.page-contact .hero{grid-template-columns:1fr}}
.page-contact .hero-left{background:var(--navy-deep);color:var(--ivory);padding:140px var(--pad) 60px;display:grid;grid-template-rows:auto 1fr auto;gap:48px;position:relative}
.page-contact .hero-left .meta{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.6;display:flex;justify-content:space-between}
.page-contact .hero-left h1{font-family:var(--f-display);font-weight:700;font-size:clamp(56px,8vw,140px);line-height:.92;letter-spacing:-.035em;align-self:end;max-width:14ch}
.page-contact .hero-left h1 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-contact .hero-left .lede{margin-top:32px;max-width:46ch;font-size:clamp(17px,1.4vw,20px);opacity:.82}

.page-contact .contact-blocks{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid rgba(245,242,236,.18)}
.page-contact .contact-blocks > div{padding:24px 0;border-right:1px solid rgba(245,242,236,.18)}
.page-contact .contact-blocks > div:last-child{border-right:0;padding-left:24px}
.page-contact .contact-blocks .lbl{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.55;margin-bottom:8px}
.page-contact .contact-blocks a,.page-contact .contact-blocks p{font-family:var(--f-display);font-weight:600;font-size:18px;letter-spacing:-.005em;display:block}
.page-contact .contact-blocks a:hover{color:var(--gold)}

.page-contact .hero-right{background:var(--ivory);padding:140px var(--pad) 80px;display:flex;flex-direction:column;justify-content:center}
.page-contact .form-frame{max-width:560px;width:100%;margin:0 auto;display:grid;gap:24px}
.page-contact .form-frame h2{font-family:var(--f-display);font-weight:700;font-size:clamp(28px,3vw,40px);letter-spacing:-.02em;line-height:1.05}
.page-contact .form-frame h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-contact .form-frame p.intro{font-size:15px;color:var(--ink);opacity:.78;max-width:48ch}
.page-contact .form-frame .field{display:grid;gap:8px}
.page-contact .form-frame .field label{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);opacity:.7;display:flex;justify-content:space-between}
.page-contact .form-frame .field label .req{color:var(--gold)}
.page-contact .form-frame .field input,
.page-contact .form-frame .field textarea,
.page-contact .form-frame .field select{width:100%;font:inherit;font-family:var(--f-display);font-size:16px;color:var(--charcoal);background:transparent;border:0;border-bottom:1px solid var(--stone);padding:10px 0;outline:0;transition:border-color .3s}
.page-contact .form-frame .field input:focus,
.page-contact .form-frame .field textarea:focus,
.page-contact .form-frame .field select:focus{border-bottom-color:var(--gold)}
.page-contact .form-frame .field textarea{min-height:120px;resize:vertical}
.page-contact .form-frame .field input::placeholder,
.page-contact .form-frame .field textarea::placeholder{color:var(--ink);opacity:.4}
.page-contact .row2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:600px){.page-contact .row2{grid-template-columns:1fr}}
.page-contact .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:4px}
@media(max-width:600px){.page-contact .svc-grid{grid-template-columns:repeat(2,1fr)}}
.page-contact .svc-chip{position:relative;cursor:pointer}
.page-contact .svc-chip input{position:absolute;opacity:0;pointer-events:none}
.page-contact .svc-chip span{display:block;text-align:center;padding:10px 12px;border:1px solid var(--stone);border-radius:999px;font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);opacity:.78;transition:all .25s}
.page-contact .svc-chip:hover span{border-color:var(--ink);opacity:1}
.page-contact .svc-chip input:checked + span,
.page-contact .svc-chip input:focus-visible + span{background:var(--navy-deep);color:var(--ivory);border-color:var(--navy-deep);opacity:1}
.page-contact .submit-row{display:flex;justify-content:space-between;align-items:center;gap:24px;margin-top:14px;padding-top:18px;border-top:1px solid var(--stone);flex-wrap:wrap}
.page-contact .submit-row small{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;opacity:.55}
.page-contact .form-status{font-family:var(--f-mono);font-size:12px;letter-spacing:.06em;padding:14px 18px;min-height:14px;border-radius:4px;transition:background .25s ease,color .25s ease;line-height:1.5}
.page-contact .form-status:empty{padding:0;min-height:0}
.page-contact .form-recaptcha-notice{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.04em;line-height:1.55;color:var(--ink);opacity:.55;display:block;margin-top:4px}
.page-contact .form-recaptcha-notice a{color:var(--ink);text-decoration:underline;text-underline-offset:2px}
.page-contact .form-recaptcha-notice a:hover{color:var(--gold)}
.page-contact .form-status--ok{color:var(--success);background:rgba(74,124,89,.08);border-left:2px solid var(--success);padding-left:14px}
.page-contact .form-status--err{color:var(--error);background:rgba(161,69,69,.08);border-left:2px solid var(--error);padding-left:14px}
.page-contact .form-frame .field input,
.page-contact .form-frame .field textarea,
.page-contact .form-frame .field select{transition:border-color .25s ease, box-shadow .25s ease, background-color .25s ease}
.page-contact .form-frame .field input:focus,
.page-contact .form-frame .field textarea:focus,
.page-contact .form-frame .field select:focus{border-bottom-color:var(--gold);box-shadow:0 1px 0 0 var(--gold)}
.page-contact .form-frame .field input:hover,
.page-contact .form-frame .field textarea:hover,
.page-contact .form-frame .field select:hover{border-bottom-color:var(--ink)}
.page-contact .form-frame .field--error input,
.page-contact .form-frame .field--error textarea{border-bottom-color:var(--error);box-shadow:0 1px 0 0 var(--error)}
.page-contact .submit-row .btn{padding:14px 28px;font-size:14px;letter-spacing:.04em}
.page-contact .submit-row .btn[disabled]{opacity:.6;pointer-events:none;cursor:wait}
.page-contact .svc-chip:hover span{transform:translateY(-1px)}
.page-contact .svc-chip span{transition:all .2s ease}


/* === CONTACT / OFFICE / DEPT / FAQ === */

.page-contact .office{padding:clamp(80px,14vw,200px) var(--pad);background:var(--bone)}
.page-contact .office .head{max-width:var(--max);margin:0 auto 64px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.page-contact .office h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;max-width:18ch}
.page-contact .office h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-contact .off-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr;gap:0;border:1px solid var(--stone);background:var(--ivory)}
@media(max-width:1100px){.page-contact .off-grid{grid-template-columns:1fr}}
.page-contact .map{aspect-ratio:4/3;position:relative;background:var(--bone);border-right:1px solid var(--stone);overflow:hidden}
@media(max-width:1100px){.page-contact .map{border-right:0;border-bottom:1px solid var(--stone)}}
.page-contact .map svg{width:100%;height:100%;display:block}
.page-contact .map .pin{position:absolute;left:48%;top:54%;transform:translate(-50%,-100%)}
.page-contact .map .pin .dot{width:18px;height:18px;border-radius:50%;background:var(--gold);border:3px solid var(--ivory);box-shadow:0 0 0 2px var(--navy-deep);position:relative;z-index:2}
.page-contact .map .pin .ring{position:absolute;left:50%;top:50%;width:18px;height:18px;border-radius:50%;border:2px solid var(--gold);transform:translate(-50%,-50%);animation:najaha-ping 2.4s cubic-bezier(.2,.7,.2,1) infinite;z-index:1}
@keyframes najaha-ping{0%{transform:translate(-50%,-50%) scale(1);opacity:.8}100%{transform:translate(-50%,-50%) scale(4);opacity:0}}
.page-contact .map .pin .lbl{position:absolute;top:-44px;left:50%;transform:translateX(-50%);background:var(--navy-deep);color:var(--ivory);font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:6px 10px;white-space:nowrap;z-index:3}
.page-contact .map .pin .lbl::after{content:"";position:absolute;left:50%;bottom:-6px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--navy-deep);transform:translateX(-50%)}
.page-contact .off-info{padding:48px 36px;display:grid;gap:32px;align-content:start}
.page-contact .off-info .blk{display:grid;gap:8px}
.page-contact .off-info .blk .l{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.55}
.page-contact .off-info .blk p,.page-contact .off-info .blk a{font-family:var(--f-display);font-weight:500;font-size:17px;letter-spacing:-.005em}
.page-contact .off-info .blk a:hover{color:var(--navy-deep);text-decoration:underline}
.page-contact .off-info hr{border:0;border-top:1px solid var(--stone);margin:0}
.page-contact .off-info .hours-row{display:grid;grid-template-columns:1fr auto;gap:14px;font-family:var(--f-mono);font-size:13px;letter-spacing:.04em;padding:6px 0;border-bottom:1px solid var(--stone)}
.page-contact .off-info .hours-row:last-child{border-bottom:0}
.page-contact .off-info .hours-row span:last-child{color:var(--navy-deep)}
.page-contact .off-info .hours-row.closed span:last-child{color:var(--ink);opacity:.5}

.page-contact .dept{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-contact .dept .head{max-width:var(--max);margin:0 auto 64px}
.page-contact .dept h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.page-contact .dept h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-contact .dept-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--stone);border-left:1px solid var(--stone)}
@media(max-width:900px){.page-contact .dept-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.page-contact .dept-grid{grid-template-columns:1fr}}
.page-contact .dept-cell{padding:36px 28px;border-right:1px solid var(--stone);border-bottom:1px solid var(--stone);display:grid;gap:10px;min-height:200px;align-content:start;transition:background-color .35s}
.page-contact .dept-cell:hover{background:var(--bone)}
.page-contact .dept-cell .l{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.55}
.page-contact .dept-cell h3{font-family:var(--f-display);font-weight:600;font-size:20px;letter-spacing:-.005em;line-height:1.2}
.page-contact .dept-cell h3 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-contact .dept-cell .em{font-family:var(--f-mono);font-size:13px;letter-spacing:.04em;color:var(--navy-deep);margin-top:auto;padding-top:10px}
.page-contact .dept-cell .em:hover{color:var(--gold)}

.page-contact .faq{background:var(--charcoal);color:var(--ivory);padding:clamp(80px,14vw,200px) var(--pad)}
.page-contact .faq .head{max-width:var(--max);margin:0 auto 48px}
.page-contact .faq h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.page-contact .faq h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-contact .faq-list{max-width:var(--max);margin:0 auto;border-top:1px solid rgba(245,242,236,.2)}
.page-contact .faq-item{border-bottom:1px solid rgba(245,242,236,.2)}
.page-contact .faq-item summary{padding:28px 0;font-family:var(--f-display);font-weight:600;font-size:clamp(20px,2vw,26px);letter-spacing:-.01em;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px}
.page-contact .faq-item summary::-webkit-details-marker{display:none}
.page-contact .faq-item summary em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-contact .faq-item summary .pl{flex:none;width:32px;height:32px;border:1px solid rgba(245,242,236,.4);border-radius:50%;display:grid;place-items:center;font-size:18px;font-weight:300;transition:transform .4s,background .3s,color .3s}
.page-contact .faq-item[open] summary .pl{transform:rotate(45deg);background:var(--gold);color:var(--navy-deep);border-color:var(--gold)}
.page-contact .faq-item .body{padding:0 0 28px;max-width:80ch;font-size:16px;line-height:1.6;opacity:.82}


/* ==========================================================================
   === SERVICE / SHARED HERO / SECTIONS ===
   Each service can override its hero via .svc-<slug>; common service rules
   live under .page-service.
   ========================================================================== */

/* Service hero — branding default (full-bleed dark) */
.page-service.svc-branding .hero{
	min-height:92vh;background:var(--navy-deep);color:var(--ivory);
	position:relative;overflow:hidden;display:grid;grid-template-rows:auto 1fr auto;
	padding:120px var(--pad) 48px;
}
.page-service.svc-branding .hero-bg{position:absolute;inset:0;background:radial-gradient(120% 80% at 80% 30%, rgba(61,123,196,.28), transparent 60%),linear-gradient(180deg, rgba(15,36,56,.9) 0%, rgba(15,36,56,.5) 40%, rgba(15,36,56,.95) 100%),linear-gradient(135deg,#3a4a3f 0%,#5a4a3a 50%,#1f2a3a 100%);z-index:0}
.page-service.svc-branding .hero-bg::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(245,242,236,.03) 0 1px,transparent 1px 14px)}
.page-service.svc-branding .hero > *{position:relative;z-index:2}
.page-service.svc-branding .hero-meta{display:flex;justify-content:space-between;align-items:flex-start;font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.7}
.page-service.svc-branding .hero-meta .right{text-align:right;display:grid;gap:6px}
.page-service.svc-branding .hero-mid{display:flex;align-items:flex-end;padding:48px 0}
.page-service.svc-branding .hero h1{font-family:var(--f-display);font-weight:700;font-size:clamp(56px,9vw,160px);line-height:.92;letter-spacing:-.035em;max-width:18ch}
.page-service.svc-branding .hero h1 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-service.svc-branding .hero .lede{margin-top:32px;max-width:56ch;font-size:clamp(18px,1.6vw,22px);line-height:1.5;opacity:.78}
.page-service.svc-branding .hero-bot{display:grid;grid-template-columns:1fr 1fr;gap:48px;border-top:1px solid rgba(245,242,236,.18);padding-top:22px;font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;align-items:end}
.page-service.svc-branding .hero-bot .right{justify-self:end;text-align:right;display:grid;gap:6px;opacity:.7}
.page-service.svc-branding .hero-bot .lbl{opacity:.5;margin-right:10px}

/* Web Dev hero — split dark/light wireframe */
.page-service.svc-website-development .hero{display:grid;grid-template-columns:1.05fr 1fr;min-height:100vh}
@media(max-width:1100px){.page-service.svc-website-development .hero{grid-template-columns:1fr;min-height:auto}}
.page-service.svc-website-development .hero-left{background:var(--navy-deep);color:var(--ivory);padding:140px var(--pad) 60px;position:relative;display:grid;grid-template-rows:auto 1fr auto}
.page-service.svc-website-development .hero-left .meta{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.6;display:flex;justify-content:space-between}
.page-service.svc-website-development .hero-left h1{font-family:var(--f-display);font-weight:700;font-size:clamp(56px,8vw,140px);line-height:.92;letter-spacing:-.035em;align-self:end;padding:48px 0 0;max-width:14ch}
.page-service.svc-website-development .hero-left h1 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-service.svc-website-development .hero-left .lede{margin-top:32px;max-width:46ch;font-size:clamp(17px,1.4vw,20px);line-height:1.5;opacity:.8}
.page-service.svc-website-development .hero-left .stats-row{margin-top:48px;display:flex;gap:48px;border-top:1px solid rgba(245,242,236,.18);padding-top:22px;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.page-service.svc-website-development .hero-left .stats-row b{display:block;font-family:var(--f-display);font-weight:700;font-size:32px;letter-spacing:-.02em;margin-top:6px;color:var(--gold)}
.page-service.svc-website-development .hero-right{background:var(--ivory);color:var(--charcoal);padding:140px var(--pad) 60px;position:relative;display:flex;flex-direction:column;justify-content:center;gap:32px}
.page-service.svc-website-development .hero-right .lbl{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6}
.page-service.svc-website-development .wf-stage{position:relative;width:100%;aspect-ratio:5/4;border:1px solid var(--stone);background:var(--ivory);overflow:hidden}

/* Performance — full-bleed navy + chart */
.page-service.svc-performance-marketing .hero{background:var(--navy-deep);color:var(--ivory);min-height:100vh;padding:140px var(--pad) 80px;display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center;position:relative}
@media(max-width:1100px){.page-service.svc-performance-marketing .hero{grid-template-columns:1fr;gap:48px}}
.page-service.svc-performance-marketing .hero h1{font-family:var(--f-display);font-weight:700;font-size:clamp(56px,8.5vw,160px);line-height:.92;letter-spacing:-.035em;max-width:13ch}
.page-service.svc-performance-marketing .hero h1 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-service.svc-performance-marketing .hero .lede{margin-top:32px;max-width:48ch;font-size:clamp(17px,1.4vw,20px);opacity:.8}
.page-service.svc-performance-marketing .hero .meta{position:absolute;top:120px;left:var(--pad);right:var(--pad);display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.55}
.page-service.svc-performance-marketing .hero .actions{margin-top:48px;display:flex;gap:16px;flex-wrap:wrap}
.page-service.svc-performance-marketing .hero .stats-row{margin-top:64px;display:flex;gap:48px;flex-wrap:wrap;border-top:1px solid rgba(245,242,236,.18);padding-top:24px;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.85}
.page-service.svc-performance-marketing .hero .stats-row b{display:block;font-family:var(--f-display);font-weight:700;font-size:32px;letter-spacing:-.02em;margin-top:6px;color:var(--gold)}

/* Social — split navy/bone with feed */
.page-service.svc-social-media-marketing .hero{display:grid;grid-template-columns:1.05fr 1fr;min-height:100vh}
@media(max-width:1100px){.page-service.svc-social-media-marketing .hero{grid-template-columns:1fr;min-height:auto}}
.page-service.svc-social-media-marketing .hero-left{background:var(--navy-deep);color:var(--ivory);padding:140px var(--pad) 60px;display:grid;grid-template-rows:auto 1fr auto;position:relative}
.page-service.svc-social-media-marketing .hero-left h1{font-family:var(--f-display);font-weight:700;font-size:clamp(56px,8vw,140px);line-height:.92;letter-spacing:-.035em;align-self:end;padding-top:48px;max-width:14ch}
.page-service.svc-social-media-marketing .hero-left h1 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-service.svc-social-media-marketing .hero-left .lede{margin-top:32px;max-width:46ch;font-size:clamp(17px,1.4vw,20px);opacity:.8}
.page-service.svc-social-media-marketing .hero-right{background:var(--bone);padding:140px var(--pad) 60px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;position:relative}

/* IT Training — split bone/navy with cert stack */
.page-service.svc-it-training .hero{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
@media(max-width:1100px){.page-service.svc-it-training .hero{grid-template-columns:1fr}}
.page-service.svc-it-training .hero-left{background:var(--bone);color:var(--charcoal);padding:140px var(--pad) 60px;display:grid;grid-template-rows:auto 1fr auto;position:relative}
.page-service.svc-it-training .hero-left h1{font-family:var(--f-display);font-weight:700;font-size:clamp(56px,8vw,140px);line-height:.92;letter-spacing:-.035em;align-self:end;padding-top:48px;max-width:14ch}
.page-service.svc-it-training .hero-left h1 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--navy-deep)}
.page-service.svc-it-training .hero-left .lede{margin-top:32px;max-width:46ch;font-size:clamp(17px,1.4vw,20px);opacity:.78}
.page-service.svc-it-training .hero-left .actions{margin-top:48px;display:flex;gap:14px;flex-wrap:wrap}
.page-service.svc-it-training .hero-left .stats-row{margin-top:48px;display:flex;gap:48px;border-top:1px solid var(--stone);padding-top:22px;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.page-service.svc-it-training .hero-left .stats-row b{display:block;font-family:var(--f-display);font-weight:700;font-size:32px;letter-spacing:-.02em;margin-top:6px;color:var(--navy-deep)}
.page-service.svc-it-training .hero-right{background:var(--navy-deep);color:var(--ivory);padding:140px var(--pad) 60px;display:flex;flex-direction:column;justify-content:center;gap:24px;position:relative}


/* === SERVICE / CAPS === */

.page-service .caps{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-service .caps-grid{display:grid;grid-template-columns:1.1fr 1.4fr;gap:96px;max-width:var(--max);margin:0 auto;align-items:start}
.page-service .caps-grid h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,96px);line-height:.95;letter-spacing:-.03em;max-width:14ch;margin-top:14px}
.page-service .caps-grid h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-service .caps-grid p.lede{max-width:38ch;margin-top:32px;font-size:17px;line-height:1.6;color:var(--ink);opacity:.78}
@media(max-width:1100px){.page-service .caps-grid{grid-template-columns:1fr;gap:48px}}

/* Branding caps: icon-text 2-col */
.page-service.svc-branding .caps-list{display:grid;grid-template-columns:1fr 1fr;gap:0}
.page-service.svc-branding .cap{display:grid;grid-template-columns:48px 1fr;gap:20px;padding:24px 0;border-top:1px solid var(--stone);align-items:start}
.page-service.svc-branding .caps-list .cap:nth-last-child(-n+2){border-bottom:1px solid var(--stone)}
.page-service.svc-branding .cap .icon{width:32px;height:32px;color:var(--charcoal);margin-top:4px}
.page-service.svc-branding .cap h4{font-family:var(--f-display);font-weight:600;font-size:20px;letter-spacing:-.01em;margin-bottom:6px}
.page-service.svc-branding .cap p{font-size:14px;line-height:1.55;color:var(--ink);opacity:.75;max-width:36ch}
@media(max-width:1100px){.page-service.svc-branding .caps-list{grid-template-columns:1fr}}

/* Web Dev caps: pill-big cloud */
.page-service.svc-website-development .cap-cloud{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.page-service.svc-website-development .cap-cloud .pill-big{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:999px;border:1px solid var(--stone);font-family:var(--f-display);font-weight:500;font-size:clamp(16px,1.4vw,20px);letter-spacing:-.005em;color:var(--charcoal);background:transparent;transition:background .35s,color .35s,border-color .35s,transform .35s;cursor:default}
.page-service.svc-website-development .cap-cloud .pill-big::after{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.4}
.page-service.svc-website-development .cap-cloud .pill-big:hover{background:var(--charcoal);color:var(--ivory);border-color:var(--charcoal);transform:translateY(-2px)}
.page-service.svc-website-development .cap-cloud .pill-big--gold{background:transparent;color:var(--charcoal);border-color:var(--gold)}
.page-service.svc-website-development .cap-cloud .pill-big--gold:hover{background:var(--gold);color:var(--navy-deep);border-color:var(--gold)}


/* === BRANDING / PROCESS / FEATURED / PQ === */

.page-service.svc-branding .process{background:var(--navy);color:var(--ivory);padding:clamp(80px,14vw,200px) 0;background-image:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 100%);overflow:hidden}
.page-service.svc-branding .process .head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:48px;max-width:var(--max);margin:0 auto 80px;padding:0 var(--pad)}
.page-service.svc-branding .process h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.page-service.svc-branding .process h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-service.svc-branding .process-meta{font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.6;text-align:right}
.page-service.svc-branding .process-strip{display:grid;grid-template-columns:repeat(5, minmax(380px, 1fr));gap:0;padding:0 var(--pad);overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--gold) transparent}
.page-service.svc-branding .process-strip::-webkit-scrollbar{height:6px}
.page-service.svc-branding .process-strip::-webkit-scrollbar-thumb{background:rgba(200,163,92,.5);border-radius:3px}
.page-service.svc-branding .process-step{scroll-snap-align:start;border-left:1px solid rgba(245,242,236,.18);padding:0 40px 0 32px;display:grid;grid-template-rows:auto auto 1fr auto;gap:24px;min-height:520px}
.page-service.svc-branding .process-step:last-child{border-right:1px solid rgba(245,242,236,.18)}
.page-service.svc-branding .process-step .n{font-family:var(--f-display);font-weight:700;font-size:clamp(80px,9vw,140px);line-height:.85;letter-spacing:-.04em;color:var(--ivory);opacity:.18}
.page-service.svc-branding .process-step h3{font-family:var(--f-display);font-weight:600;font-size:clamp(28px,3vw,40px);letter-spacing:-.02em;line-height:1.05}
.page-service.svc-branding .process-step p{font-size:15px;opacity:.72;line-height:1.55;max-width:34ch}
.page-service.svc-branding .process-step .img{aspect-ratio:5/4;background:linear-gradient(135deg,#274769,#0f2438);border:1px solid rgba(245,242,236,.18);position:relative;overflow:hidden;align-self:end}
.page-service.svc-branding .process-step .img::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(245,242,236,.05) 0 1px,transparent 1px 14px)}
.page-service.svc-branding .process-step .img .ph-cap{position:absolute;left:10px;bottom:10px;font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ivory);background:rgba(15,36,56,.7);border:1px solid rgba(245,242,236,.2);padding:5px 7px;z-index:1}
.page-service.svc-branding .process-foot{max-width:var(--max);margin:48px auto 0;padding:0 var(--pad);display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}

/* Featured cases (branding + web-dev share this; also used on archive) */
.page-service .featured{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-service .featured .head{max-width:var(--max);margin:0 auto 80px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.page-service .featured h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.page-service .featured h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-service .fcase{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:center;padding:48px 0;border-top:1px solid var(--stone);position:relative;cursor:pointer}
.page-service .fcase:last-child{border-bottom:1px solid var(--stone)}
.page-service .fcase .img-wrap{aspect-ratio:16/10;overflow:hidden;position:relative;background:var(--bone)}
.page-service .fcase .img-wrap .ph,.page-service .fcase .img-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05);transition:filter .6s,transform .6s cubic-bezier(.2,.7,.2,1)}
.page-service .fcase:hover .img-wrap .ph,.page-service .fcase:hover .img-wrap img{filter:grayscale(0) contrast(1);transform:scale(1.04)}
.page-service .fcase .img-wrap .ph-cap{position:absolute;left:14px;bottom:14px;z-index:2;font-family:var(--f-mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;background:var(--ivory);color:var(--charcoal);padding:6px 10px;border:1px solid var(--stone);opacity:.92}
.page-service .fcase .body{display:grid;gap:18px}
.page-service .fcase .meta{display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6}
.page-service .fcase .body h3{font-family:var(--f-display);font-weight:600;font-size:clamp(28px,3.4vw,48px);letter-spacing:-.02em;line-height:1.05}
.page-service .fcase .body h3 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-service .fcase .body .out{font-size:17px;line-height:1.55;opacity:.8;max-width:42ch}
.page-service .fcase .body .out span{display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.55;margin-bottom:8px}
.page-service .fcase .body .scope{display:flex;flex-wrap:wrap;gap:8px}
.page-service .fcase .body .read{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.7;display:inline-flex;gap:8px;align-items:center;margin-top:4px}
.page-service .fcase:hover .body .read{color:var(--gold);opacity:1}
.page-service .fcase--alt{grid-template-columns:1fr 1.4fr}
.page-service .fcase--alt .body{order:-1}
@media(max-width:1100px){.page-service .fcase,.page-service .fcase--alt{grid-template-columns:1fr;gap:32px}.page-service .fcase--alt .body{order:0}}

/* Pull-quote section (branding) */
.page-service.svc-branding .pq-sec{background:var(--bone);padding:clamp(96px,14vw,200px) var(--pad)}
.page-service.svc-branding .pq-sec .pq{max-width:1100px;margin:0 auto;padding-left:48px;position:relative}
.page-service.svc-branding .pq-sec .pq::before{content:"";position:absolute;left:0;top:18px;width:40px;height:2px;background:var(--gold)}
.page-service.svc-branding .pq-sec .pq blockquote{font-family:var(--f-edit);font-style:italic;font-weight:400;font-size:clamp(36px,5.2vw,80px);line-height:1.08;letter-spacing:-.015em;color:var(--charcoal);max-width:22ch}
.page-service.svc-branding .pq-sec .pq cite{display:block;margin-top:40px;font-family:var(--f-mono);font-style:normal;font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.7}
.page-service.svc-branding .pq-sec .pq cite b{font-weight:500;opacity:1}


/* === WEB-DEV / TECH / BUILD / PERF === */

.page-service.svc-website-development .tech{background:var(--charcoal);color:var(--ivory);padding:clamp(80px,12vw,160px) var(--pad);position:relative}
.page-service.svc-website-development .tech .head{max-width:var(--max);margin:0 auto 64px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.page-service.svc-website-development .tech h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;max-width:18ch}
.page-service.svc-website-development .tech h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-service.svc-website-development .tech .meta{font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.55;text-align:right}
.page-service.svc-website-development .tech-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid rgba(245,242,236,.18);border-left:1px solid rgba(245,242,236,.18)}
.page-service.svc-website-development .tech-tile{border-right:1px solid rgba(245,242,236,.18);border-bottom:1px solid rgba(245,242,236,.18);padding:48px 32px;display:flex;flex-direction:column;justify-content:space-between;gap:28px;min-height:200px;color:var(--ivory);opacity:.6;transition:opacity .35s, background-color .35s;cursor:default}
.page-service.svc-website-development .tech-tile:hover{opacity:1;background:rgba(245,242,236,.04)}
.page-service.svc-website-development .tech-tile .tn{font-family:var(--f-display);font-weight:700;font-size:clamp(24px,2.4vw,32px);letter-spacing:-.01em}
.page-service.svc-website-development .tech-tile .ts{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.7}
@media(max-width:1100px){.page-service.svc-website-development .tech-grid{grid-template-columns:repeat(3,1fr)}.page-service.svc-website-development .tech .head{grid-template-columns:1fr}}
@media(max-width:600px){.page-service.svc-website-development .tech-grid{grid-template-columns:repeat(2,1fr)}}

.page-service.svc-website-development .build{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-service.svc-website-development .build .head{max-width:var(--max);margin:0 auto 80px}
.page-service.svc-website-development .build h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.page-service.svc-website-development .build h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-service.svc-website-development .phases{max-width:var(--max);margin:0 auto;border-top:1px solid var(--stone)}
.page-service.svc-website-development .phase{display:grid;grid-template-columns:160px 1.1fr 1.4fr 1fr;gap:48px;padding:48px 0;border-bottom:1px solid var(--stone);align-items:start}
.page-service.svc-website-development .phase .n{font-family:var(--f-display);font-weight:700;font-size:clamp(56px,5vw,84px);line-height:.85;letter-spacing:-.03em;color:var(--charcoal)}
.page-service.svc-website-development .phase h3{font-family:var(--f-display);font-weight:600;font-size:clamp(28px,3vw,40px);letter-spacing:-.02em;line-height:1.05;margin-bottom:10px}
.page-service.svc-website-development .phase .sub{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.55;margin-bottom:6px}
.page-service.svc-website-development .phase ul{list-style:none;display:grid;gap:10px;font-size:16px;color:var(--ink)}
.page-service.svc-website-development .phase ul li{display:flex;gap:12px;align-items:baseline}
.page-service.svc-website-development .phase ul li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);flex:none;transform:translateY(-2px)}
.page-service.svc-website-development .phase .stat{padding-left:32px;border-left:1px solid var(--stone)}
.page-service.svc-website-development .phase .stat .num{font-family:var(--f-display);font-weight:700;font-size:clamp(32px,3.4vw,48px);letter-spacing:-.02em;line-height:1;color:var(--charcoal)}
.page-service.svc-website-development .phase .stat .num em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-service.svc-website-development .phase .stat .lbl{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6;margin-top:10px;max-width:18ch}
@media(max-width:1100px){.page-service.svc-website-development .phase{grid-template-columns:1fr;gap:18px}.page-service.svc-website-development .phase .stat{padding-left:0;border-left:0;border-top:1px solid var(--stone);padding-top:18px;margin-top:8px}}

.page-service.svc-website-development .perf{background:var(--navy);color:var(--ivory);padding:clamp(80px,12vw,160px) var(--pad);background-image:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 100%);position:relative}
.page-service.svc-website-development .perf .head{max-width:var(--max);margin:0 auto 80px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.page-service.svc-website-development .perf h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;max-width:18ch}
.page-service.svc-website-development .perf h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-service.svc-website-development .perf-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);border-block:1px solid rgba(245,242,236,.2)}
@media(max-width:900px){.page-service.svc-website-development .perf-grid{grid-template-columns:repeat(2,1fr)}}
.page-service.svc-website-development .perf-stat{padding:56px 40px;border-right:1px solid rgba(245,242,236,.2);position:relative}
.page-service.svc-website-development .perf-stat:last-child{border-right:0}
.page-service.svc-website-development .perf-stat .num{font-family:var(--f-display);font-weight:700;font-size:clamp(56px,7vw,108px);line-height:.9;letter-spacing:-.035em}
.page-service.svc-website-development .perf-stat .num em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold);font-size:.7em}
.page-service.svc-website-development .perf-stat .num sup{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold);font-size:.4em;vertical-align:super;margin-left:4px}
.page-service.svc-website-development .perf-stat .lbl{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6;margin-top:24px}
.page-service.svc-website-development .perf-stat .desc{margin-top:8px;font-size:14px;opacity:.7;max-width:24ch;line-height:1.5}
.page-service.svc-website-development .perf-foot{max-width:var(--max);margin:32px auto 0;display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.55}


/* === PERFORMANCE-MARKETING / CHANNELS / FUNNEL / METHOD / BIGSTAT / DASH === */

.page-service.svc-performance-marketing .channels{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-service.svc-performance-marketing .channels .head{max-width:var(--max);margin:0 auto 80px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end}
.page-service.svc-performance-marketing .channels h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;margin-top:14px}
.page-service.svc-performance-marketing .channels h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-service.svc-performance-marketing .channels .head p{max-width:48ch;font-size:17px;color:var(--ink);opacity:.78}
.page-service.svc-performance-marketing .ch-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--stone);border-left:1px solid var(--stone)}
@media(max-width:900px){.page-service.svc-performance-marketing .ch-grid{grid-template-columns:repeat(2,1fr)}.page-service.svc-performance-marketing .channels .head{grid-template-columns:1fr}}
@media(max-width:600px){.page-service.svc-performance-marketing .ch-grid{grid-template-columns:1fr}}
.page-service.svc-performance-marketing .ch{padding:48px 36px;border-right:1px solid var(--stone);border-bottom:1px solid var(--stone);display:flex;flex-direction:column;gap:18px;min-height:280px;transition:background-color .35s}
.page-service.svc-performance-marketing .ch:hover{background:var(--bone)}
.page-service.svc-performance-marketing .ch .num{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.5}
.page-service.svc-performance-marketing .ch h3{font-family:var(--f-display);font-weight:600;font-size:clamp(22px,2vw,28px);letter-spacing:-.015em;line-height:1.1}
.page-service.svc-performance-marketing .ch h3 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-service.svc-performance-marketing .ch p{font-size:14px;line-height:1.55;color:var(--ink);opacity:.78;flex:1}
.page-service.svc-performance-marketing .ch .platforms{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.page-service.svc-performance-marketing .ch .platforms span{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--stone);padding:4px 8px;border-radius:999px;color:var(--ink);opacity:.7}

.page-service.svc-performance-marketing .funnel{background:var(--charcoal);color:var(--ivory);padding:clamp(80px,14vw,200px) var(--pad)}
.page-service.svc-performance-marketing .funnel .head{max-width:var(--max);margin:0 auto 80px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.page-service.svc-performance-marketing .funnel h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;max-width:18ch}
.page-service.svc-performance-marketing .funnel h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-service.svc-performance-marketing .funnel-rows{display:grid;gap:14px}
.page-service.svc-performance-marketing .fr{display:grid;grid-template-columns:120px 1fr 90px;gap:24px;align-items:center;border-top:1px solid rgba(245,242,236,.2);padding-top:18px}
.page-service.svc-performance-marketing .fr:first-child{border-top:0;padding-top:0}
.page-service.svc-performance-marketing .fr .stage{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6}
.page-service.svc-performance-marketing .fr .barwrap{height:38px;background:rgba(245,242,236,.05);position:relative;overflow:hidden}
.page-service.svc-performance-marketing .fr .bar{height:100%;background:var(--gold);transform-origin:left;animation:najaha-grow 1.6s cubic-bezier(.2,.7,.2,1) forwards;position:relative}
@keyframes najaha-grow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.page-service.svc-performance-marketing .fr .num{font-family:var(--f-display);font-weight:700;font-size:22px;letter-spacing:-.01em;text-align:right}

.page-service.svc-performance-marketing .method{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-service.svc-performance-marketing .method-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--stone)}
@media(max-width:1100px){.page-service.svc-performance-marketing .method-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.page-service.svc-performance-marketing .method-grid{grid-template-columns:1fr}}
.page-service.svc-performance-marketing .rule{padding:48px 32px 56px;border-right:1px solid var(--stone);border-bottom:1px solid var(--stone);display:grid;gap:16px}
.page-service.svc-performance-marketing .rule .n{font-family:var(--f-edit);font-style:italic;font-weight:400;font-size:64px;line-height:.9;color:var(--gold);letter-spacing:-.02em}
.page-service.svc-performance-marketing .rule h3{font-family:var(--f-display);font-weight:600;font-size:22px;line-height:1.15;letter-spacing:-.01em}
.page-service.svc-performance-marketing .rule p{font-size:15px;line-height:1.55;opacity:.78;color:var(--ink)}

.page-service.svc-performance-marketing .bigstat{background:var(--navy-deep);color:var(--ivory);padding:clamp(80px,14vw,200px) var(--pad);overflow:hidden}
.page-service.svc-performance-marketing .bigstat-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr;gap:80px;align-items:center}
@media(max-width:1100px){.page-service.svc-performance-marketing .bigstat-inner{grid-template-columns:1fr}}
.page-service.svc-performance-marketing .bigstat .num{font-family:var(--f-display);font-weight:700;font-size:clamp(140px,22vw,360px);line-height:.85;letter-spacing:-.045em}
.page-service.svc-performance-marketing .bigstat .num sup{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold);font-size:.32em;vertical-align:super;margin-left:6px}

.page-service.svc-performance-marketing .dash{background:var(--charcoal);color:var(--ivory);padding:clamp(80px,14vw,200px) var(--pad)}
.page-service.svc-performance-marketing .dash-frame{max-width:var(--max);margin:0 auto;border:1px solid rgba(245,242,236,.2);background:#0f1418;border-radius:6px;overflow:hidden}
.page-service.svc-performance-marketing .dash-grid{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid rgba(245,242,236,.12)}
@media(max-width:900px){.page-service.svc-performance-marketing .dash-grid{grid-template-columns:repeat(2,1fr)}}
.page-service.svc-performance-marketing .dash-tile{padding:32px 24px;border-right:1px solid rgba(245,242,236,.12);display:grid;gap:10px}
.page-service.svc-performance-marketing .dash-tile:last-child{border-right:0}
.page-service.svc-performance-marketing .dash-tile .lbl{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;opacity:.5}
.page-service.svc-performance-marketing .dash-tile .v{font-family:var(--f-display);font-weight:700;font-size:clamp(28px,2.8vw,40px);letter-spacing:-.02em;color:var(--ivory)}
.page-service.svc-performance-marketing .dash-tile .v em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold);font-size:.7em}


/* === SOCIAL / PLATS / PILLARS / CAL / CGRID / GSTAT === */

.page-service.svc-social-media-marketing .plats{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-service.svc-social-media-marketing .plats .head{max-width:var(--max);margin:0 auto 80px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.page-service.svc-social-media-marketing .plats h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;margin-top:14px;max-width:18ch}
.page-service.svc-social-media-marketing .plats h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-service.svc-social-media-marketing .plats-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--stone);border-left:1px solid var(--stone)}
@media(max-width:1100px){.page-service.svc-social-media-marketing .plats-grid{grid-template-columns:repeat(3,1fr)}.page-service.svc-social-media-marketing .plats .head{grid-template-columns:1fr}}
@media(max-width:600px){.page-service.svc-social-media-marketing .plats-grid{grid-template-columns:repeat(2,1fr)}}
.page-service.svc-social-media-marketing .plat{padding:48px 28px;border-right:1px solid var(--stone);border-bottom:1px solid var(--stone);display:grid;gap:14px;min-height:240px;align-content:start;transition:background-color .35s}
.page-service.svc-social-media-marketing .plat:hover{background:var(--bone)}
.page-service.svc-social-media-marketing .plat .pn{font-family:var(--f-display);font-weight:700;font-size:24px;letter-spacing:-.01em}
.page-service.svc-social-media-marketing .plat .ps{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6}
.page-service.svc-social-media-marketing .plat .pd{font-size:14px;line-height:1.55;color:var(--ink);opacity:.78;margin-top:auto}

.page-service.svc-social-media-marketing .pillars{background:var(--charcoal);color:var(--ivory);padding:clamp(80px,14vw,200px) var(--pad)}
.page-service.svc-social-media-marketing .pillars .head{max-width:var(--max);margin:0 auto 80px}
.page-service.svc-social-media-marketing .pillars h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.page-service.svc-social-media-marketing .pillars h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-service.svc-social-media-marketing .pillars-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid rgba(245,242,236,.2)}
@media(max-width:1100px){.page-service.svc-social-media-marketing .pillars-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.page-service.svc-social-media-marketing .pillars-grid{grid-template-columns:1fr}}
.page-service.svc-social-media-marketing .pillars-grid .pillar{padding:48px 28px;border-right:1px solid rgba(245,242,236,.2);border-bottom:1px solid rgba(245,242,236,.2);min-height:280px;display:grid;gap:18px;align-content:start;grid-template-columns:1fr;align-items:initial}
.page-service.svc-social-media-marketing .pillars-grid .pillar:last-child{border-right:0}
.page-service.svc-social-media-marketing .pillars-grid .pillar .pn{font-family:var(--f-edit);font-style:italic;font-weight:400;font-size:48px;line-height:1;color:var(--gold)}
.page-service.svc-social-media-marketing .pillars-grid .pillar h3{font-family:var(--f-display);font-weight:600;font-size:22px;line-height:1.15;letter-spacing:-.005em}
.page-service.svc-social-media-marketing .pillars-grid .pillar p{font-size:14px;line-height:1.55;opacity:.78}
.page-service.svc-social-media-marketing .pillars-grid .pillar .freq{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;opacity:.5;margin-top:auto;padding-top:14px}

.page-service.svc-social-media-marketing .gstat{background:var(--navy);color:var(--ivory);padding:clamp(80px,12vw,160px) var(--pad);background-image:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 100%)}
.page-service.svc-social-media-marketing .gstat-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);border-block:1px solid rgba(245,242,236,.2)}
@media(max-width:900px){.page-service.svc-social-media-marketing .gstat-grid{grid-template-columns:repeat(2,1fr)}}
.page-service.svc-social-media-marketing .gst{padding:56px 36px;border-right:1px solid rgba(245,242,236,.2)}
.page-service.svc-social-media-marketing .gst:last-child{border-right:0}
.page-service.svc-social-media-marketing .gst .num{font-family:var(--f-display);font-weight:700;font-size:clamp(56px,7vw,108px);line-height:.9;letter-spacing:-.035em}
.page-service.svc-social-media-marketing .gst .num em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold);font-size:.7em}


/* === IT-TRAINING / TRACKS / CURR / FORMATS / COHORT / TLIST === */

.page-service.svc-it-training .tracks{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-service.svc-it-training .tracks .head{max-width:var(--max);margin:0 auto 80px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.page-service.svc-it-training .tracks h2{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;margin-top:14px;max-width:18ch}
.page-service.svc-it-training .tracks h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-service.svc-it-training .tracks-list{max-width:var(--max);margin:0 auto;border-top:1px solid var(--stone)}
.page-service.svc-it-training .track{display:grid;grid-template-columns:80px 1.4fr 1fr 1fr auto;gap:32px;padding:36px 0;border-bottom:1px solid var(--stone);align-items:center;transition:padding .35s}
.page-service.svc-it-training .track:hover{padding-left:14px}
.page-service.svc-it-training .track .n{font-family:var(--f-edit);font-style:italic;font-weight:400;font-size:32px;color:var(--gold);line-height:1}
.page-service.svc-it-training .track h3{font-family:var(--f-display);font-weight:600;font-size:clamp(22px,2vw,28px);letter-spacing:-.015em;line-height:1.1}
.page-service.svc-it-training .track h3 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.page-service.svc-it-training .track .sub{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.55;margin-top:4px}
.page-service.svc-it-training .track .meta{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;opacity:.7;display:grid;gap:4px}
.page-service.svc-it-training .track .price{font-family:var(--f-display);font-weight:700;font-size:24px;letter-spacing:-.01em;text-align:right}
.page-service.svc-it-training .track .arr{color:var(--charcoal);opacity:.5;transition:transform .35s,opacity .35s}
.page-service.svc-it-training .track:hover .arr{opacity:1;transform:translateX(6px);color:var(--gold)}
@media(max-width:1100px){.page-service.svc-it-training .track{grid-template-columns:60px 1fr 1fr;gap:18px}.page-service.svc-it-training .track .meta{grid-column:2/4}.page-service.svc-it-training .track .price{grid-column:2/3}.page-service.svc-it-training .track .arr{grid-column:3/4;justify-self:end}}

.page-service.svc-it-training .curr{background:var(--charcoal);color:var(--ivory);padding:clamp(80px,14vw,200px) var(--pad)}
.page-service.svc-it-training .curr .head{max-width:var(--max);margin:0 auto 64px}
.page-service.svc-it-training .curr h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;max-width:18ch}
.page-service.svc-it-training .curr h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400;color:var(--gold)}
.page-service.svc-it-training .curr-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid rgba(245,242,236,.2);border-left:1px solid rgba(245,242,236,.2)}
@media(max-width:1100px){.page-service.svc-it-training .curr-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.page-service.svc-it-training .curr-grid{grid-template-columns:1fr}}
.page-service.svc-it-training .mod{padding:36px 28px;border-right:1px solid rgba(245,242,236,.2);border-bottom:1px solid rgba(245,242,236,.2);display:grid;gap:14px;min-height:240px;align-content:start}
.page-service.svc-it-training .mod .wk{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);opacity:.85}
.page-service.svc-it-training .mod h4{font-family:var(--f-display);font-weight:600;font-size:18px;line-height:1.2;letter-spacing:-.005em}

.page-service.svc-it-training .formats{padding:clamp(80px,14vw,200px) var(--pad);background:var(--bone)}
.page-service.svc-it-training .formats h2{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.page-service.svc-it-training .fm-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.page-service.svc-it-training .fm-grid{grid-template-columns:1fr}}
.page-service.svc-it-training .fmt{background:var(--ivory);border:1px solid var(--stone);padding:40px 32px 36px;display:grid;gap:18px;min-height:380px;position:relative;transition:transform .35s,box-shadow .35s}
.page-service.svc-it-training .fmt:hover{transform:translateY(-4px);box-shadow:0 16px 28px -16px rgba(15,36,56,.18)}
.page-service.svc-it-training .fmt.featured{background:var(--navy-deep);color:var(--ivory);border-color:var(--navy-deep)}
.page-service.svc-it-training .fmt h3{font-family:var(--f-display);font-weight:600;font-size:clamp(24px,2.4vw,32px);letter-spacing:-.015em;line-height:1.1}

.page-service.svc-it-training .cohort{background:var(--navy);color:var(--ivory);padding:clamp(80px,12vw,160px) var(--pad);background-image:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 100%)}
.page-service.svc-it-training .coh-list{max-width:var(--max);margin:0 auto;border-top:1px solid rgba(245,242,236,.2)}
.page-service.svc-it-training .coh{display:grid;grid-template-columns:140px 1fr 200px 160px 140px;gap:32px;padding:28px 0;border-bottom:1px solid rgba(245,242,236,.2);align-items:center}
.page-service.svc-it-training .coh .start{font-family:var(--f-display);font-weight:700;font-size:24px;letter-spacing:-.01em}
.page-service.svc-it-training .coh h4{font-family:var(--f-display);font-weight:600;font-size:18px;letter-spacing:-.005em}
@media(max-width:1100px){.page-service.svc-it-training .coh{grid-template-columns:1fr 1fr;gap:14px}}

.page-service.svc-it-training .tlist{padding:clamp(80px,14vw,200px) var(--pad);background:var(--ivory)}
.page-service.svc-it-training .t-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
@media(max-width:900px){.page-service.svc-it-training .t-grid{grid-template-columns:1fr}}
.page-service.svc-it-training .testi{padding:36px 32px;border:1px solid var(--stone);background:var(--bone);display:grid;gap:20px}
.page-service.svc-it-training .testi blockquote{font-family:var(--f-edit);font-style:italic;font-weight:400;font-size:22px;line-height:1.35;letter-spacing:-.005em;color:var(--charcoal)}


/* === SERVICE ARCHIVE === */
.archive-services{padding:160px var(--pad) clamp(80px,12vw,160px);background:var(--ivory);min-height:80vh}
.archive-services .archive-head{max-width:var(--max);margin:0 auto 64px}
.archive-services .archive-head h1{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.03em;max-width:18ch;margin-top:14px}
.archive-services .archive-head h1 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.archive-services .svc-list{max-width:var(--max);margin:0 auto;border-top:1px solid var(--stone)}
.archive-services .svc-row{display:grid;grid-template-columns:120px 1fr 220px;gap:48px;padding:48px 0;border-bottom:1px solid var(--stone);align-items:start;transition:padding .35s}
.archive-services .svc-row:hover{padding-left:14px}
.archive-services .svc-row .num{font-family:var(--f-mono);font-size:13px;letter-spacing:.14em;opacity:.6}
.archive-services .svc-row h2{font-family:var(--f-display);font-weight:600;font-size:clamp(28px,3vw,40px);letter-spacing:-.015em;line-height:1.1;margin-bottom:10px}
.archive-services .svc-row h2 em{font-family:var(--f-edit);font-style:italic;font-weight:400}
.archive-services .svc-row p{font-size:17px;line-height:1.55;opacity:.8;color:var(--ink);max-width:55ch}
.archive-services .svc-row .arr{justify-self:end;align-self:center;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.7;display:inline-flex;gap:8px;align-items:center}
.archive-services .svc-row:hover .arr{color:var(--gold);opacity:1}
.archive-services .svc-row:hover h2{color:var(--gold)}
@media(max-width:900px){.archive-services .svc-row{grid-template-columns:1fr;gap:18px}.archive-services .svc-row .arr{justify-self:start}}
