/* ===================================================================
   PUSH Holding — Website-beta2 design system
   Navy-drenched editorial. Navy canvas · ivory breaks · burgundy heat.
   =================================================================== */
:root{
  --ink:#070D17;
  --navy:#0B1322;
  --navy2:#0E1A2D;
  --raise:#13213A;
  --ivory:#F5F1E9;
  --ivory2:#FBF8F1;
  --burg:#7A2C39;
  --burg-bright:#A6404E;
  --burg-tint:#EFE2E3;
  --on-dark:#D6DCE6;
  --on-dark-soft:#94A0B2;
  --on-dark-faint:#828FA4;
  --on-light:#26303D;
  --on-light-soft:#5A5F66;
  --line-d:rgba(214,222,234,.12);
  --line-d2:rgba(214,222,234,.22);
  --line-l:#E4DCCC;
  --dac:var(--burg-bright); /* per-division accent, overridden inline */
  --serif:'Cormorant',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --ez:cubic-bezier(.22,1,.36,1);
  --ez-soft:cubic-bezier(.4,0,.2,1);
  --maxw:1240px;
  --z-grain:1; --z-fab:60; --z-header:90; --z-menu:100;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--navy);color:var(--on-dark);line-height:1.7;font-weight:400;font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.04;letter-spacing:-.01em;color:#fff}
h1,h2,h3{text-wrap:balance}
p{text-wrap:pretty}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--burg);color:#fff}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.section{padding:clamp(80px,11vw,160px) 0;position:relative}
section{scroll-margin-top:110px}
.eyebrow{font-family:var(--sans);font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;font-weight:600;color:var(--on-dark-soft)}
.hair{width:46px;height:1px;background:var(--burg);margin:22px 0}
.hair.acc{background:var(--dac)}
.hair.long{width:100%;background:var(--line-d)}
.lead{color:var(--on-dark-soft);font-weight:300}
.acc-logo{height:58px;width:auto;max-width:72%;object-fit:contain;object-position:left;display:block;margin-bottom:26px}
@media(max-width:860px){.acc-logo{height:46px}}

.s-dark{background:var(--navy)}
.s-darker{background:var(--ink)}
.s-light{background:var(--ivory);color:var(--on-light)}
.s-light h1,.s-light h2,.s-light h3,.s-light h4{color:#0C1424}
.s-light .eyebrow{color:var(--dact,var(--burg))}
.s-light .hair.long{background:var(--line-l)}
.s-light .lead{color:var(--on-light-soft)}

/* ===== buttons ===== */
.btn{display:inline-flex;align-items:center;gap:.65em;font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:16px 30px;border-radius:10px;cursor:pointer;border:1px solid transparent;transition:transform .35s var(--ez),background .4s var(--ez),color .4s var(--ez),border-color .4s var(--ez),box-shadow .4s var(--ez)}
.btn .ar{transition:transform .4s var(--ez)}
.btn:hover .ar{transform:translateX(5px)}
.btn-fill{background:var(--burg);color:#fff;box-shadow:0 10px 30px -10px rgba(122,44,57,.7)}
.btn-fill:hover{background:var(--burg-bright);transform:translateY(-2px);box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 24px 52px -26px rgba(122,44,57,.6)}
.btn-ghost{border-color:var(--line-d2);color:#fff}
.btn-ghost:hover{border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.04);transform:translateY(-2px)}
.s-light .btn-ghost{border-color:#CFC6B4;color:#1A2230}
.s-light .btn-ghost:hover{border-color:var(--burg);color:var(--burg);background:transparent}
.btn-sm{padding:11px 20px;font-size:.7rem;letter-spacing:.1em}
.btn:active{transform:scale(.98)}
.textlink{display:inline-flex;align-items:center;gap:.55em;font-family:var(--sans);font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--burg-bright);position:relative}
.s-dark .textlink,.s-darker .textlink{color:#E6CDD0}
.textlink .ar{transition:transform .4s var(--ez)}
.textlink:hover .ar{transform:translateX(5px)}
.textlink::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ez)}
.textlink:hover::after{transform:scaleX(1)}
/* ===== soft static gloss (no movement) ===== */
.btn-fill{background-image:linear-gradient(180deg,#94363f 0%,#7A2C39 52%,#6b2531 100%);box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 16px 42px -22px rgba(122,44,57,.55)}
.btn-fill:hover{background-image:linear-gradient(180deg,#a64049 0%,#8a3340 52%,#762a36 100%)}
.s-light .btn-ghost,.btn-ghost{box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.brand{position:relative}
.brand::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,#aeb9c8 0%,#ffffff 28%,#d2dbe6 50%,#ffffff 72%,#aeb9c8 100%);-webkit-mask:url(logos/holding.png) left center/contain no-repeat;mask:url(logos/holding.png) left center/contain no-repeat;mix-blend-mode:multiply;pointer-events:none}

/* ===== header ===== */
header{position:fixed;inset:0 0 auto 0;z-index:var(--z-header);transition:background .45s var(--ez),box-shadow .45s var(--ez),border-color .45s var(--ez);border-bottom:1px solid transparent}
header.scrolled{background:rgba(8,15,26,.82);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border-bottom-color:var(--line-d);box-shadow:0 18px 50px -20px rgba(0,0,0,.6)}
nav{display:flex;align-items:center;justify-content:space-between;height:96px;max-width:var(--maxw);margin:0 auto;padding:0 40px;transition:height .45s var(--ez)}
header.scrolled nav{height:78px}
nav .brand img{height:74px;width:auto;transition:height .45s var(--ez)}
header.scrolled nav .brand img{height:60px}
.nlinks{display:flex;align-items:center;gap:36px;list-style:none}
.nlinks>li{display:flex;align-items:center}
.nlinks>li>a:not(.btn):not(.nav-portal){display:inline-flex;align-items:center;font-family:var(--sans);font-size:.82rem;font-weight:500;letter-spacing:.03em;color:rgba(255,255,255,.74);position:relative;padding:6px 0;transition:color .3s}
.nlinks>li>a:not(.btn):not(.nav-portal):hover{color:#fff}
.nlinks>li>a:not(.btn):not(.nav-portal)::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--burg-bright);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ez)}
.nlinks>li>a:not(.btn):not(.nav-portal):hover::after,.nlinks>li>a.active::after{transform:scaleX(1)}
.nlinks i{font-style:normal;font-size:.6em;opacity:.6;margin-left:3px}
.nav-portal{display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fff;border:1px solid var(--line-d2);border-radius:9px;padding:11px 18px;transition:background .3s var(--ez),border-color .3s var(--ez),transform .3s var(--ez)}
.nav-portal svg{flex:none}
.nav-portal:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.55);transform:translateY(-1px)}
.dd{position:relative;display:flex;align-items:center}
.dmenu{position:absolute;top:calc(100% + 18px);left:-22px;min-width:262px;background:rgba(12,21,37,.97);backdrop-filter:blur(20px);border:1px solid var(--line-d);border-radius:12px;padding:16px 0;box-shadow:0 40px 80px -24px rgba(0,0,0,.7);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .3s var(--ez),transform .3s var(--ez),visibility .3s}
.dd:hover .dmenu,.dd:focus-within .dmenu{opacity:1;visibility:visible;transform:translateY(0)}
.dmenu .dh{display:block;padding:0 24px 12px;font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--on-dark-faint);border-bottom:1px solid var(--line-d);margin-bottom:8px;font-weight:600}
.dmenu a{display:block;padding:9px 24px;font-size:.88rem;color:rgba(255,255,255,.74);transition:color .2s,background .2s,padding .25s var(--ez)}
.dmenu a:hover{color:#fff;background:rgba(255,255,255,.05);padding-left:30px}
.menu-btn{display:none;background:none;border:0;color:#fff;cursor:pointer;width:30px;height:22px;position:relative}
.menu-btn span{position:absolute;left:0;height:1.5px;width:100%;background:#fff;transition:transform .4s var(--ez),opacity .3s}
.menu-btn span:nth-child(1){top:2px}.menu-btn span:nth-child(2){top:10px}.menu-btn span:nth-child(3){top:18px}
.menu-btn.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.menu-btn.open span:nth-child(2){opacity:0}
.menu-btn.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ===== grain ===== */
.grain{position:fixed;inset:0;z-index:var(--z-grain);pointer-events:none;opacity:.035;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ===== home hero ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:radial-gradient(125% 120% at 78% 8%,#1A2C49 0%,#0C1727 46%,#070E1A 100%)}
.hero .mono{position:absolute;right:0;top:50%;transform:translateY(-50%);width:min(320px,28%);opacity:.06;pointer-events:none;z-index:1}
.hero .glow{position:absolute;width:560px;height:560px;left:-160px;bottom:-200px;border-radius:50%;background:radial-gradient(circle,rgba(122,44,57,.5) 0%,rgba(122,44,57,0) 68%);filter:blur(20px);pointer-events:none;z-index:0}
.hero .wrap{position:relative;z-index:2;padding-top:120px;padding-bottom:80px;width:100%}
.hero .lbl{display:flex;align-items:center;gap:16px;color:var(--on-dark-soft);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;font-weight:600}
.hero .lbl::before{content:"";width:34px;height:1px;background:var(--burg-bright)}
.hero h1{color:#fff;font-size:clamp(3rem,7vw,5.8rem);font-weight:300;letter-spacing:-.018em;margin:28px 0 0;max-width:15ch}
.hero h1 em{font-style:italic;font-weight:400;color:#EAD7DA}
.hero .sub{margin-top:30px;max-width:54ch;font-size:clamp(1.05rem,1.5vw,1.32rem);font-weight:300;color:#BAC4D2;line-height:1.6}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:44px}
.hero .scroller{position:absolute;left:40px;bottom:34px;display:flex;align-items:center;gap:14px;color:var(--on-dark-faint);font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;font-weight:600;z-index:2}
.hero .scroller .ln{width:54px;height:1px;background:linear-gradient(90deg,var(--burg-bright),transparent);position:relative;overflow:hidden}
.hero .scroller .ln::after{content:"";position:absolute;inset:0;width:40%;background:#fff;animation:slide 2.6s var(--ez-soft) infinite}
@keyframes slide{0%{transform:translateX(-100%)}60%,100%{transform:translateX(280%)}}

/* ===== page hero (inner pages, with image) ===== */
.phero{position:relative;overflow:hidden;background:#0A1322;padding:clamp(140px,20vw,230px) 0 clamp(70px,9vw,128px)}
.phero .bg{position:absolute;inset:0;z-index:0}
.phero .bg img{width:100%;height:100%;object-fit:cover;opacity:.5}
.phero .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(102deg,rgba(8,13,24,.96) 24%,rgba(8,13,24,.66) 62%,rgba(8,13,24,.34) 100%)}
.phero .scrim2{position:absolute;inset:auto 0 0 0;height:55%;z-index:1;background:linear-gradient(to top,#0A1322 2%,rgba(10,19,34,0) 100%)}
.phero .wrap{position:relative;z-index:2}
.phero .plogo{height:94px;width:auto;max-width:86%;object-fit:contain;object-position:left;margin-bottom:28px;filter:drop-shadow(0 4px 18px rgba(0,0,0,.5))}
.phero .lbl{display:flex;align-items:center;gap:14px;color:var(--dac);font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600}
.phero .lbl::before{content:"";width:30px;height:1px;background:var(--dac)}
.phero h1{color:#fff;font-size:clamp(2.4rem,5vw,4.2rem);font-weight:300;letter-spacing:-.015em;margin:22px 0 0;max-width:18ch}
.phero .sub{margin-top:24px;max-width:58ch;font-size:clamp(1.04rem,1.4vw,1.24rem);font-weight:300;color:#C2CAD6;line-height:1.6}
.phero .cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:38px}
.phero .btn-fill{background:var(--dac)}
.phero .btn-fill:hover{filter:brightness(1.08)}

/* short hero (about/work/etc, no image) */
.shero{position:relative;overflow:hidden;background:radial-gradient(120% 130% at 80% 0%,#1A2C49 0%,#0C1727 52%,#070E1A 100%);padding:clamp(150px,20vw,240px) 0 clamp(70px,9vw,120px)}
.shero .wrap{position:relative;z-index:2}
.shero h1{color:#fff;font-size:clamp(2.6rem,5.6vw,4.6rem);font-weight:300;letter-spacing:-.018em;margin:24px 0 0;max-width:16ch}
.shero h1 em{font-style:italic;color:#EAD7DA}
.shero .sub{margin-top:26px;max-width:58ch;font-size:clamp(1.05rem,1.4vw,1.28rem);font-weight:300;color:#BAC4D2}
.shero .mono{position:absolute;right:0;top:50%;transform:translateY(-50%);width:min(240px,24%);opacity:.06;z-index:1;pointer-events:none}

/* ===== ledger band ===== */
.ledger{background:var(--ink);border-top:1px solid var(--line-d);border-bottom:1px solid var(--line-d)}
.ledger .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.lcell{padding:40px 34px;border-left:1px solid var(--line-d)}
.lcell:first-child{border-left:0;padding-left:0}
.lcell b{display:block;font-family:var(--serif);font-size:2.5rem;font-weight:400;color:#fff;line-height:1}
.lcell.word b{font-size:1.5rem;letter-spacing:-.01em}
.lcell span{display:block;margin-top:12px;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--on-dark-faint);font-weight:600}

/* ===== editorial statement / split ===== */
.statement-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,7vw,110px);align-items:start}
.statement{font-family:var(--serif);font-size:clamp(1.9rem,3.4vw,3rem);font-weight:400;line-height:1.18;letter-spacing:-.01em;color:#0C1424}
.s-dark .statement,.s-darker .statement{color:#fff}
.statement .hl{color:var(--burg);font-style:italic}
.s-dark .statement .hl,.s-darker .statement .hl{color:#EAD7DA}
.colbody p{color:var(--on-light-soft);font-size:1.04rem;font-weight:400;margin-bottom:18px;max-width:62ch}
.s-dark .colbody p,.s-darker .colbody p{color:var(--on-dark);font-weight:300}
.values{margin-top:34px;display:flex;flex-direction:column}
.vrow{display:grid;grid-template-columns:auto 1fr;gap:8px 26px;padding:20px 0;border-top:1px solid var(--line-l);align-items:baseline}
.vrow:last-child{border-bottom:1px solid var(--line-l)}
.vrow .vk{font-family:var(--serif);font-size:1.5rem;color:#0C1424;font-style:italic}
.vrow .vd{color:var(--on-light-soft);font-size:.98rem}

/* ===== divisions interactive index (home) ===== */
.divisions{background:var(--ink);position:relative}
.dv-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:64px}
.dv-head h2{font-size:clamp(2.2rem,4.6vw,3.6rem);font-weight:300}
.dv-head .lead{max-width:46ch;font-size:1.06rem}
.dv-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,80px);align-items:start}
.dv-list{display:flex;flex-direction:column}
.dx{display:grid;grid-template-columns:auto 1fr auto;gap:0 22px;align-items:center;padding:22px 6px;border-top:1px solid var(--line-d);cursor:pointer;position:relative;transition:padding-left .45s var(--ez)}
.dx:last-child{border-bottom:1px solid var(--line-d)}
.dx .num{font-family:var(--serif);font-size:1rem;color:var(--on-dark-faint);width:30px;transition:color .4s var(--ez)}
.dx .dn{font-family:var(--serif);font-size:clamp(1.5rem,2.5vw,2rem);font-weight:400;color:rgba(255,255,255,.5);letter-spacing:-.01em;transition:color .4s var(--ez),transform .45s var(--ez);transform-origin:left}
.dx .go{opacity:0;transform:translateX(-8px);transition:opacity .4s var(--ez),transform .4s var(--ez);color:#fff;font-size:1.1rem}
.dx::before{content:"";position:absolute;left:0;top:-1px;height:1px;width:0;background:var(--dac,var(--burg));transition:width .5s var(--ez);z-index:2}
.dx.active{padding-left:16px}
.dx.active::before{width:100%}
.dx.active .num{color:var(--dac,var(--burg-bright))}
.dx.active .dn{color:#fff}
.dx.active .go{opacity:1;transform:translateX(0)}
.dx:hover .dn{transform:translateX(2px)}
.dv-stage{position:sticky;top:120px;border:1px solid var(--line-d);border-radius:18px;overflow:hidden;background:var(--navy2);aspect-ratio:1/1.02}
.dv-stage .frame{position:absolute;inset:0}
.dv-stage .frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.06);transition:opacity .8s var(--ez),transform 1.2s var(--ez)}
.dv-stage .frame img.show{opacity:.62;transform:scale(1)}
.dv-stage .scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,13,23,.96) 4%,rgba(7,13,23,.5) 48%,rgba(7,13,23,.15) 100%)}
.dv-stage .meta{position:absolute;inset:auto 0 0 0;padding:38px 40px}
.dv-stage .meta .tlogo{height:72px;width:auto;max-width:86%;object-fit:contain;object-position:left;margin-bottom:18px;filter:drop-shadow(0 2px 14px rgba(0,0,0,.6))}
.dv-stage .meta .dsc{color:#CBD3DF;font-weight:300;font-size:1.1rem;max-width:34ch;min-height:2.8em}
.dv-stage .meta .lk{margin-top:22px;display:inline-flex;align-items:center;gap:.5em;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:#fff}
.dv-stage .meta .lk .ar{transition:transform .4s var(--ez)}
.dv-stage:hover .meta .lk .ar{transform:translateX(5px)}

/* ===== "in motion" brand band ===== */
.inmotion{position:relative;overflow:hidden;text-align:center;background:radial-gradient(120% 130% at 50% 130%,#17263F 0%,#070D17 58%)}
.inmotion .wrap{position:relative;z-index:2}
.inmotion .hair{background:var(--burg)}
.im-h2{font-family:var(--serif);font-size:clamp(2.2rem,5vw,4rem);font-weight:300;color:#fff;margin-top:16px;letter-spacing:-.015em;line-height:1.05}
.im-h2 em{font-style:italic;color:#EAD7DA}
.im-sub{color:var(--on-dark-soft);font-weight:300;margin-top:18px;font-size:1.1rem}
.inmotion .glow2{position:absolute;width:680px;height:680px;left:50%;top:34%;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(122,44,57,.32),rgba(122,44,57,0) 64%);filter:blur(16px);animation:imPulse 7s ease-in-out infinite;z-index:0;pointer-events:none}
.inmotion .mono2{position:absolute;left:50%;top:42%;transform:translate(-50%,-50%);width:min(560px,64%);opacity:.045;z-index:1;animation:imRise 9s ease-in-out infinite;pointer-events:none}
@keyframes imPulse{0%,100%{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:.85;transform:translate(-50%,-50%) scale(1.14)}}
@keyframes imRise{0%,100%{transform:translate(-50%,-44%)}50%{transform:translate(-50%,-56%)}}
.marquee{position:relative;z-index:2;margin-top:clamp(48px,6vw,76px);overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;align-items:center;gap:clamp(40px,5vw,72px);width:max-content;animation:imMarq 48s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track img{height:70px;width:auto;opacity:.92;flex:none}
@keyframes imMarq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:860px){.marquee-track img{height:30px}}

/* ===== proposition grid ===== */
.prop-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,6vw,90px);align-items:start}
.prop-list{display:grid;grid-template-columns:1fr 1fr;gap:0}
.prop{padding:30px 30px 34px 0;border-top:1px solid var(--line-l)}
.prop:nth-child(odd){padding-right:40px}
.prop:nth-child(even){padding-left:40px;border-left:1px solid var(--line-l)}
.prop h3{font-size:1.5rem;font-weight:500;margin-bottom:10px;letter-spacing:-.01em}
.prop p{color:var(--on-light-soft);font-size:1rem;max-width:38ch}
.s-dark .prop,.s-darker .prop{border-top-color:var(--line-d)}
.s-dark .prop:nth-child(even),.s-darker .prop:nth-child(even){border-left-color:var(--line-d)}
.s-dark .prop p,.s-darker .prop p{color:var(--on-dark-soft)}

/* ===== service list (division "what we do") ===== */
.svc{margin-top:54px;border-top:1px solid var(--line-l)}
.s-dark .svc,.s-darker .svc{border-top-color:var(--line-d)}
.srow{display:grid;grid-template-columns:auto 1fr;gap:6px 30px;padding:30px 6px;border-bottom:1px solid var(--line-l);transition:padding-left .4s var(--ez),background .4s var(--ez)}
.s-dark .srow,.s-darker .srow{border-bottom-color:var(--line-d)}
.srow:hover{padding-left:18px}
.s-light .srow:hover{background:rgba(255,255,255,.45)}
.srow .sn{font-family:var(--serif);font-size:1.9rem;color:var(--dac);font-weight:400;grid-row:span 2;line-height:1}
.srow h3{font-size:1.46rem;font-weight:500}
.srow p{color:var(--on-light-soft);font-size:1.02rem;font-weight:400;margin-top:4px;max-width:60ch}
.s-dark .srow p,.s-darker .srow p{color:var(--on-dark-soft);font-weight:300}

/* ===== full scope (hairline columns) ===== */
.scope{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:0 40px;margin-top:46px;border-top:1px solid var(--line-d)}
.s-light .scope{border-top-color:var(--line-l)}
.scope div{padding:16px 0 16px 22px;border-bottom:1px solid var(--line-d);position:relative;color:var(--on-dark);font-size:1rem;font-weight:300}
.s-light .scope div{border-bottom-color:var(--line-l);color:var(--on-light);font-weight:400}
.scope div::before{content:"";position:absolute;left:0;top:1.55em;width:5px;height:5px;border-radius:50%;background:var(--dac)}

/* ===== why points ===== */
.whyrow{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:36px 44px;margin-top:48px}
.whyrow .it h3{font-size:1.24rem;font-weight:500;display:flex;align-items:baseline;gap:12px}
.whyrow .it h3 .d{font-family:var(--sans);font-size:.74rem;color:var(--dac);font-weight:700;letter-spacing:.08em}
.whyrow .it p{color:var(--on-light-soft);font-size:1rem;margin-top:8px}
.s-dark .whyrow .it p,.s-darker .whyrow .it p{color:var(--on-dark-soft);font-weight:300}

/* ===== sectors inline ===== */
.sectors{display:flex;flex-wrap:wrap;gap:0;margin-top:8px;border-top:1px solid var(--line-d)}
.s-light .sectors{border-top-color:var(--line-l)}
.sectors .se{flex:1 1 260px;padding:28px 30px 28px 0;border-bottom:1px solid var(--line-d);display:flex;align-items:baseline;gap:16px}
.s-light .sectors .se{border-bottom-color:var(--line-l)}
.sectors .se .sn{color:var(--burg-bright);font-size:.5rem;transform:translateY(-3px)}
.sectors .se .st{font-family:var(--serif);font-size:1.45rem;color:#fff;font-weight:400}
.s-light .sectors .se .st{color:#0C1424}

/* ===== related divisions ===== */
.others{margin-top:30px;display:flex;flex-wrap:wrap;gap:10px 28px}
.others a{color:var(--on-dark-soft);font-weight:400;font-size:.98rem;position:relative;transition:color .3s}
.s-light .others a{color:var(--on-light-soft)}
.others a::after{content:"";position:absolute;left:0;bottom:-4px;height:1px;width:100%;background:var(--dac);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ez)}
.others a:hover{color:#fff}
.s-light .others a:hover{color:var(--burg)}
.others a:hover::after{transform:scaleX(1)}

/* ===== division footer: part-of-group + brand quote ===== */
.dx-foot{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(40px,5vw,80px);margin-top:66px;padding-top:44px;border-top:1px solid var(--line-l)}
.dx-foot .qt{font-family:var(--serif);font-size:clamp(1.4rem,2.2vw,1.9rem);color:#0C1424;line-height:1.22;margin:16px 0 0;font-weight:400;max-width:24ch}
.dx-foot .qmail{margin-top:18px}
.dx-foot .qmail a{color:var(--dac);font-weight:600;font-size:1rem;border-bottom:1px solid currentColor;padding-bottom:2px}
.dx-foot .btn-fill{background:var(--dac)}
.dx-foot .btn-fill:hover{filter:brightness(1.08)}
@media(max-width:860px){.dx-foot{grid-template-columns:1fr;gap:40px}}

/* ===== pull quote ===== */
.pull{max-width:24ch;font-family:var(--serif);font-size:clamp(1.8rem,3.2vw,2.7rem);font-weight:400;line-height:1.2;color:#0C1424}
.s-dark .pull,.s-darker .pull{color:#fff}
.pull .hl{color:var(--burg);font-style:italic}
.s-dark .pull .hl,.s-darker .pull .hl{color:#EAD7DA}

/* ===== logo family ===== */
.family{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-top:54px}
.family{grid-template-columns:repeat(auto-fill,minmax(212px,1fr))}
.lw{position:relative;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line-l);border-radius:16px;min-height:186px;padding:30px;transition:transform .45s var(--ez),box-shadow .45s var(--ez),border-color .4s}
.lw:hover{transform:translateY(-4px);box-shadow:0 24px 50px -22px rgba(12,20,36,.35);border-color:#D8CFBD}
.lw img{max-height:108px;max-width:90%;width:auto;object-fit:contain;transition:opacity .4s var(--ez)}
.lw img.c{position:absolute;opacity:0}
.lw:hover img.n{opacity:0}.lw:hover img.c{opacity:1}

/* ===== founder letter ===== */
.letter{display:grid;grid-template-columns:.78fr 1.22fr;gap:clamp(40px,6vw,84px);align-items:start}
.fframe{position:relative}
.fframe img{border-radius:8px;width:100%;box-shadow:0 40px 80px -30px rgba(0,0,0,.6)}
.fframe::after{content:"";position:absolute;left:-14px;bottom:-14px;width:110px;height:110px;border-left:1px solid var(--burg);border-bottom:1px solid var(--burg)}
.fmsg .quote{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,2.4vw,2.1rem);line-height:1.32;color:#fff;margin-bottom:30px;font-weight:400}
.s-light .fmsg .quote{color:#0C1424}
.fmsg p{color:var(--on-dark);font-size:1.08rem;font-weight:300;margin-bottom:18px;max-width:64ch}
.s-light .fmsg p{color:var(--on-light-soft);font-weight:400}
.sig{font-family:var(--serif);font-size:1.7rem;color:#fff;margin-top:30px;font-weight:500}
.s-light .sig{color:#0C1424}
.sigt{color:var(--burg-bright);font-weight:600;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-top:6px}

/* ===== leadership team ===== */
.team{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:32px;margin-top:54px}
.tcard{background:var(--navy2);border:1px solid var(--line-d);border-radius:16px;overflow:hidden;transition:transform .45s var(--ez),box-shadow .45s var(--ez),border-color .4s}
.s-light .tcard{background:#fff;border-color:var(--line-l)}
.tcard:hover{transform:translateY(-6px);box-shadow:0 34px 64px -30px rgba(0,0,0,.6)}
.tcard .ph{position:relative;aspect-ratio:4/5;background:#0C1626;overflow:hidden}
.tcard .ph img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .8s var(--ez)}
.tcard:hover .ph img{transform:scale(1.04)}
.tcard .ph::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:3px;background:var(--burg)}
.tcard .bd{padding:26px 30px 32px}
.tcard h3{font-size:1.6rem;color:#fff}
.s-light .tcard h3{color:#0C1424}
.tcard .role{color:var(--burg-bright);font-weight:600;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;margin:8px 0 16px}
.tcard .bio{color:var(--on-dark-soft);font-size:1rem;font-weight:300;margin-bottom:18px}
.s-light .tcard .bio{color:var(--on-light-soft);font-weight:400}
.tcard a.em{color:#E6CDD0;font-weight:600;font-size:.9rem;position:relative}
.s-light .tcard a.em{color:var(--burg)}
.tcard a.em::after{content:"";position:absolute;left:0;bottom:-3px;height:1px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ez)}
.tcard a.em:hover::after{transform:scaleX(1)}

/* ===== work cases ===== */
.cases{margin-top:54px;display:grid;gap:22px}
.case{background:var(--navy2);border:1px solid var(--line-d);border-radius:18px;padding:36px 38px;transition:transform .4s var(--ez),box-shadow .4s var(--ez),border-color .4s}
.s-light .case{background:#fff;border-color:var(--line-l)}
.case:hover{transform:translateY(-4px);box-shadow:0 30px 64px -32px rgba(0,0,0,.55);border-color:var(--line-d2)}
.s-light .case:hover{box-shadow:0 28px 56px -30px rgba(16,28,48,.35)}
.case .ct{display:flex;flex-wrap:wrap;gap:10px 14px;align-items:center;margin-bottom:18px}
.case .ct .dv{font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:#fff;background:var(--ckc,var(--burg));padding:5px 12px;border-radius:3px}
.case .ct .sec{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--on-dark-soft);font-weight:600}
.s-light .case .ct .sec{color:#9A938A}
.case h3{font-size:1.7rem;margin-bottom:20px;color:#fff;line-height:1.2}
.s-light .case h3{color:#101C30}
.case .cg{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.case .cg .l{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--on-dark-faint);font-weight:700;margin-bottom:6px;display:block}
.s-light .case .cg .l{color:#9A938A}
.case .cg p{color:var(--on-dark-soft);font-size:.98rem;font-weight:300;margin:0}
.s-light .case .cg p{color:var(--on-light-soft);font-weight:400}

/* ===== prose (privacy) ===== */
.prose{max-width:760px;margin-top:20px}
.prose h2{font-size:1.7rem;margin:44px 0 14px;font-weight:500}
.prose h2:first-child{margin-top:0}
.prose p{color:var(--on-light-soft);margin-bottom:16px;font-size:1.04rem}
.s-dark .prose p,.s-darker .prose p{color:var(--on-dark-soft);font-weight:300}
.prose a{color:var(--burg);font-weight:500;border-bottom:1px solid currentColor}
.prose ul{margin:0 0 16px 22px;color:var(--on-light-soft)}
.prose li{margin-bottom:8px}

/* ===== 404 ===== */
.err{min-height:78vh;display:flex;align-items:center;text-align:center}
.err .wrap{width:100%}
.err .big{font-family:var(--serif);font-size:clamp(5rem,16vw,12rem);font-weight:300;color:#fff;line-height:1;letter-spacing:-.02em}
.err h1{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:400;margin-top:10px}
.err p{color:var(--on-dark-soft);max-width:46ch;margin:18px auto 0;font-weight:300}
.err .cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:36px}

/* ===== contact ===== */
.contact{background:radial-gradient(120% 120% at 80% 0%,#16243E 0%,#0A1322 56%)}
.c-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(40px,6vw,90px);margin-top:54px;align-items:start}
.c-methods{display:flex;flex-direction:column;gap:26px}
.cm .cl{display:block;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--on-dark-soft);font-weight:600;margin-bottom:8px}
.cm a,.cm span{font-size:1.12rem;font-weight:300;color:#fff}
.cm a:hover{color:#EAD7DA}
.wa{display:inline-flex!important;align-items:center;gap:8px;background:#1EBE57;color:#04230f!important;font-weight:600;font-size:.76rem;letter-spacing:.02em;padding:9px 16px;border-radius:9px;white-space:nowrap;align-self:flex-start;transition:transform .3s var(--ez),filter .3s}
.cm .wa{font-size:.76rem!important;font-weight:600!important}
.wa svg{width:15px;height:15px;flex:none}
.wa:hover{transform:translateY(-2px);filter:brightness(1.07)}
.cform{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.ff{display:flex;flex-direction:column}.ff.full{grid-column:1/-1}
.ff label{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--on-dark-soft);font-weight:600;margin-bottom:9px}
.ff input,.ff textarea{background:rgba(255,255,255,.04);border:1px solid var(--line-d2);border-radius:9px;padding:14px 16px;color:#fff;font-family:inherit;font-size:1rem;transition:border-color .3s,background .3s}
.ff input:focus,.ff textarea:focus{outline:none;border-color:var(--burg-bright);background:rgba(255,255,255,.07)}
.ff textarea{resize:vertical;min-height:120px}
.cform .sub-row{grid-column:1/-1;display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.cnote{font-size:.84rem;color:var(--on-dark-soft);font-weight:300}
.cnote a{color:#EAD7DA}
.cstatus{grid-column:1/-1;margin-top:4px;font-size:.92rem;min-height:1.1em;transition:color .3s}
.cstatus.ok{color:#86D9AB}
.cstatus.err{color:#E79AA2}

/* ===== footer ===== */
footer{background:var(--ink);color:var(--on-dark-soft);padding:80px 0 36px;border-top:1px solid var(--line-d)}
.fgrid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.1fr;gap:48px}
.fbrand img{height:74px;margin-bottom:20px}
.fbrand p{font-size:.92rem;font-weight:300;color:var(--on-dark-faint);max-width:34ch}
.fcol h4{font-family:var(--sans);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:#B7C0CE;font-weight:600;margin-bottom:18px}
.flinks{display:flex;flex-direction:column;gap:11px}
.flinks a,.flinks span{font-size:.9rem;font-weight:300;color:var(--on-dark-faint);transition:color .25s}
.flinks a:hover{color:#fff}
.ffamily{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:22px 34px;margin-top:58px;padding-bottom:36px}
.ffamily a{display:inline-flex}
.ffamily img{height:30px;width:auto;opacity:.78;transition:opacity .35s var(--ez),transform .35s var(--ez)}
.ffamily a:hover img{opacity:1;transform:translateY(-3px)}
@media(max-width:860px){.ffamily{gap:18px 24px}.ffamily img{height:24px}}
.fbar{margin-top:0;padding-top:26px;border-top:1px solid var(--line-d);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.78rem;color:var(--on-dark-faint)}
.fbar a:hover{color:#fff}

/* ===== skip link (a11y) ===== */
.skip-link{position:fixed;top:-60px;left:14px;z-index:200;background:var(--burg);color:#fff;padding:10px 18px;border-radius:0 0 6px 6px;font-family:var(--sans);font-size:.85rem;font-weight:600;transition:top .25s var(--ez)}
.skip-link:focus{top:0;outline:2px solid #fff;outline-offset:2px}

/* ===== back to top ===== */
.totop{position:fixed;left:22px;bottom:22px;z-index:var(--z-fab);width:46px;height:46px;border-radius:50%;border:1px solid var(--line-d2);background:rgba(12,21,37,.82);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;font-size:1.15rem;line-height:1;cursor:pointer;opacity:0;transform:translateY(16px);pointer-events:none;transition:opacity .4s var(--ez),transform .4s var(--ez),background .3s,border-color .3s}
.totop.show{opacity:1;transform:none;pointer-events:auto}
.totop:hover{background:var(--burg);border-color:var(--burg);transform:translateY(-3px)}
@media(max-width:860px){.totop{left:16px;bottom:16px;width:42px;height:42px}}

/* ===== FAQ ===== */
.faq{margin-top:42px;border-top:1px solid var(--line-l)}
.faq-item{padding:26px 2px;border-bottom:1px solid var(--line-l)}
.faq-item h3{font-size:1.3rem;font-weight:500;margin-bottom:8px;color:#0C1424}
.faq-item p{color:var(--on-light-soft);max-width:72ch}

/* ===== floating whatsapp ===== */
.wafab{position:fixed;right:22px;bottom:22px;z-index:var(--z-fab);width:54px;height:54px;border-radius:50%;background:#1EBE57;color:#fff!important;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 34px -8px rgba(4,40,18,.6);opacity:0;transform:translateY(16px) scale(.85);pointer-events:none;transition:opacity .4s var(--ez),transform .4s var(--ez),filter .25s}
.wafab.show{opacity:1;transform:none;pointer-events:auto}
.wafab:hover{filter:brightness(1.07);transform:translateY(-3px)}
.wafab svg{width:28px;height:28px}

/* ===== motion (visible by default; motion only enhances) ===== */
.reveal{transition:opacity .9s var(--ez),transform .9s var(--ez),filter .9s var(--ez)}
.reveal.pre{opacity:0;transform:translateY(26px);filter:blur(6px)}
.reveal.in{opacity:1;transform:none;filter:none}
.hero.anim .stagger,.phero.anim .stagger,.shero.anim .stagger{opacity:0;animation:up .95s var(--ez) both}
.anim .stagger:nth-child(1){animation-delay:.05s}
.anim .stagger:nth-child(2){animation-delay:.13s}
.anim .stagger:nth-child(3){animation-delay:.22s}
.anim .stagger:nth-child(4){animation-delay:.31s}
.anim .stagger:nth-child(5){animation-delay:.4s}
.anim .stagger:nth-child(6){animation-delay:.49s}
@keyframes up{from{opacity:0;transform:translateY(24px);filter:blur(6px)}to{opacity:1;transform:none;filter:none}}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--burg-bright);outline-offset:3px}

/* ===== responsive ===== */
@media(max-width:1040px){
  .statement-grid,.prop-grid,.c-grid,.letter{grid-template-columns:1fr;gap:44px}
  .dv-grid{grid-template-columns:1fr;gap:0}
  .dv-stage{display:none}
  .fgrid{grid-template-columns:1fr 1fr;gap:36px}
  .fframe img{max-width:420px}
}
@media(max-width:860px){
  .wrap{padding:0 26px}nav{padding:0 26px}
  .nlinks{position:fixed;inset:96px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:rgba(8,15,26,.98);backdrop-filter:blur(18px);padding:10px 0 22px;border-top:1px solid var(--line-d);transform:translateY(-12px);opacity:0;visibility:hidden;transition:opacity .35s var(--ez),transform .35s var(--ez),visibility .35s;max-height:calc(100vh - 96px);overflow:auto}
  .nlinks.open{opacity:1;visibility:visible;transform:none}
  .nlinks>li>a:not(.btn):not(.nav-portal){display:block;padding:16px 26px;font-size:1rem}
  .nlinks>li>a:not(.btn):not(.nav-portal)::after{display:none}
  .nlinks .cta-li{padding:16px 26px}.nlinks .cta-li .btn{width:100%;justify-content:center}
  .nlinks .portal-li{padding:4px 26px 16px}.nlinks .portal-li .nav-portal{width:100%;justify-content:center}
  .dd{display:block}
  .dmenu{position:static;opacity:1;visibility:visible;transform:none;background:transparent;border:0;box-shadow:none;padding:0 0 8px;min-width:0}
  .dmenu .dh{display:none}.dmenu a{padding-left:42px}
  .menu-btn{display:block}
  .hero .scroller{display:none}
  .hero{min-height:auto;padding:40px 0}
  .ledger .wrap{grid-template-columns:1fr 1fr}
  .lcell:nth-child(3){border-left:0;padding-left:0}
  .lcell{padding:28px 22px}
  .prop-list{grid-template-columns:1fr}
  .prop:nth-child(even){padding-left:0;border-left:0}
  .prop:nth-child(odd){padding-right:0}
  .prop:last-child{border-bottom:1px solid var(--line-l)}
  .s-dark .prop:last-child,.s-darker .prop:last-child{border-bottom:1px solid var(--line-d)}
  .case .cg{grid-template-columns:1fr;gap:16px}
  .fgrid{grid-template-columns:1fr}
  .cform{grid-template-columns:1fr}
  .fbar{flex-direction:column}
}
@media(hover:none){.dx .go{display:none}}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal,.reveal.pre{opacity:1!important;transform:none!important;filter:none!important;transition:none}
  .anim .stagger{animation:none!important;opacity:1!important}
  .hero .scroller .ln::after{animation:none}
  .dv-stage .frame img{transition:opacity .3s}
  .marquee-track,.inmotion .glow2,.inmotion .mono2{animation:none!important}
}

/* ===== brand film (full-bleed, no frame — reads as immersive video) ===== */
.filmsec{background:var(--ink);line-height:0;position:relative}
.film-frame{width:100%;aspect-ratio:16/9;overflow:hidden;background:#05080F}
.film-video{width:100%;height:100%;display:block;object-fit:cover}
