/* ═══════════════════════════════════════════════════════════
   TAKWEEN — V2 (AIMS-aligned)
   Shared stylesheet for all pages
   ═══════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --stone:#ECE6E1;--sand:#EFEAE6;--paper:#FFFFFF;--hair:#D9D9D9;
  --ink:#474D4F;--ink-dim:#6B6F71;--silver:#C0C0C0;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --ease:cubic-bezier(0.16,1,0.3,1);
  --container:1320px;--gutter:72px;--col-narrow:800px;--col-hero:860px;--col-read:640px;
  --sp-sec:132px;--sp-sec-sm:100px;
}
@media(max-width:900px){:root{--gutter:32px;--sp-sec:80px;--sp-sec-sm:64px}}
@media(max-width:520px){:root{--gutter:24px;--sp-sec:64px;--sp-sec-sm:56px}}

html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{background:var(--stone);color:var(--ink);font-family:var(--sans);font-weight:300;font-size:18px;line-height:1.65;overflow-x:hidden}
::selection{background:var(--ink);color:var(--stone)}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}

/* ═══ Typography ═══ */
.t-hero{font-weight:400;font-size:clamp(52px,7.2vw,108px);line-height:1.03;letter-spacing:-0.024em}
.t-title{font-weight:300;font-size:clamp(34px,4.4vw,54px);line-height:1.12;letter-spacing:-0.012em}
.t-sub-title{font-weight:300;font-size:clamp(22px,2.4vw,32px);line-height:1.3}
.t-sub{font-weight:300;font-size:clamp(18px,1.6vw,22px);line-height:1.55;color:var(--ink-dim)}
.t-body{font-weight:300;font-size:17px;line-height:1.75;color:var(--ink)}
.t-body-lg{font-weight:300;font-size:20px;line-height:1.7;color:var(--ink)}

/* Eyebrow — the AIMS metronome */
.eyebrow{font-weight:400;font-size:13px;line-height:1.6;letter-spacing:0.24em;text-transform:uppercase;color:var(--ink);display:inline-block}
.eyebrow--light{color:var(--paper)}
.eyebrow--dim{color:var(--ink-dim)}

/* Underline-draw link — the AIMS signature CTA */
.link-u{position:relative;display:inline-block;font-weight:300;font-size:13px;letter-spacing:0.24em;text-transform:uppercase;padding:4px 0;color:inherit;transition:color .3s var(--ease);cursor:pointer}
.link-u::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.link-u:hover::after{transform:scaleX(1)}
.link-u .arrow{display:inline-block;margin-left:10px;transition:transform .4s var(--ease)}
.link-u:hover .arrow{transform:translateX(6px)}

/* Reveal-on-scroll */
.rv{opacity:0;transform:translateY(40px);transition:opacity 1.8s var(--ease),transform 1.8s var(--ease);will-change:transform,opacity}
.rv.in{opacity:1;transform:translateY(0)}
.rv-2{transition-delay:.12s}
.rv-3{transition-delay:.24s}
.rv-4{transition-delay:.36s}
.rv-5{transition-delay:.48s}
.rv-6{transition-delay:.60s}

/* Horizontal slide-in variant */
.rv-h{opacity:0;transform:translateX(-56px);transition:opacity 1.6s var(--ease),transform 1.6s var(--ease);will-change:transform,opacity}
.rv-h.in{opacity:1;transform:translateX(0)}
.rv-h.from-right{transform:translateX(56px)}
.rv-h.from-right.in{transform:translateX(0)}

/* ═══ Cinematic text reveal system ═══ */
/* Word-by-word staggered lift (use data-words on element) */
.tx-words{display:inline}
.tx-words .tx-w{display:inline-block;overflow:hidden;vertical-align:baseline}
.tx-words .tx-w>span{display:inline-block;transform:translateY(110%) skewY(4deg);transition:transform 1.1s cubic-bezier(0.2,0.8,0.2,1);transition-delay:calc(var(--i,0)*70ms + var(--tx-delay,0ms));will-change:transform}
.tx-words.in .tx-w>span{transform:translateY(0) skewY(0)}

/* Line wipe reveal — for eyebrows & short lines */
.tx-line{position:relative;display:inline-block;clip-path:inset(0 100% 0 0);transition:clip-path 1.4s cubic-bezier(0.76,0,0.24,1);transition-delay:var(--tx-delay,0ms);will-change:clip-path}
.tx-line.in{clip-path:inset(0 0 0 0)}

/* Strong rise — blurred fade-up used on t-title/t-sub */
.tx-rise{opacity:0;transform:translateY(48px);filter:blur(10px);transition:opacity 1.4s var(--ease),transform 1.4s var(--ease),filter 1.6s var(--ease);transition-delay:var(--tx-delay,0ms);will-change:transform,opacity,filter}
.tx-rise.in{opacity:1;transform:translateY(0);filter:blur(0)}

/* Stagger children automatically via --i */
.tx-stagger>*{opacity:0;transform:translateY(32px);transition:opacity 1s var(--ease),transform 1.1s var(--ease);transition-delay:calc(var(--i,0)*100ms)}
.tx-stagger.in>*{opacity:1;transform:translateY(0)}

/* ═══ Preloader ═══ */
#preload{position:fixed;inset:0;z-index:9999;background:var(--ink);display:flex;align-items:center;justify-content:center;transition:opacity .8s var(--ease),visibility 0s .8s}
#preload.gone{opacity:0;visibility:hidden}
#preload img{width:140px;height:auto;filter:brightness(0) invert(1);opacity:0;animation:preloadFade 1.4s var(--ease) forwards}
@keyframes preloadFade{0%{opacity:0;transform:scale(0.98)}40%{opacity:0.85}100%{opacity:0.85;transform:scale(1)}}

/* ═══ Nav ═══ */
#nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:28px var(--gutter);transition:padding .4s var(--ease),background .4s var(--ease),border-color .4s var(--ease);border-bottom:1px solid transparent}
#nav .nav-logo img{height:48px;width:auto;filter:brightness(0) invert(1);transition:filter .4s var(--ease),height .4s var(--ease)}
#nav.scrolled .nav-logo img{height:40px}
.nav-links{display:flex;gap:40px}
.nav-links a{font-size:16px;font-weight:400;color:var(--paper);position:relative;padding:6px 0;transition:color .3s var(--ease);letter-spacing:0.01em}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{font-size:14px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:var(--paper);position:relative;padding:4px 0}
.nav-cta::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.nav-cta:hover::after{transform:scaleX(1)}
#nav.scrolled{background:var(--stone);padding:16px var(--gutter);border-bottom-color:var(--hair)}
#nav.scrolled .nav-logo img{filter:brightness(0)}
#nav.scrolled .nav-links a,#nav.scrolled .nav-cta{color:var(--ink)}

/* Solid-nav variant — for pages with a light top section (no dark hero) */
#nav.solid{background:var(--stone);border-bottom-color:var(--hair)}
#nav.solid .nav-logo img{filter:brightness(0)}
#nav.solid .nav-links a,#nav.solid .nav-cta{color:var(--ink)}
#nav.solid #nav-toggle span{background:var(--ink)}
/* On light-background pages (inner pages after hero), nav starts dark */
#nav.on-light{background:transparent}
#nav.on-light .nav-logo img{filter:brightness(0) invert(1)}
#nav.on-light .nav-links a,#nav.on-light .nav-cta{color:var(--paper)}
#nav.on-light.scrolled{background:var(--stone)}
#nav.on-light.scrolled .nav-logo img{filter:brightness(0)}
#nav.on-light.scrolled .nav-links a,#nav.on-light.scrolled .nav-cta{color:var(--ink)}

/* Mobile menu toggle */
#nav-toggle{display:none;width:28px;height:18px;position:relative;cursor:pointer;background:transparent;border:0}
#nav-toggle span{position:absolute;left:0;width:100%;height:1px;background:currentColor;color:var(--paper);transition:transform .3s var(--ease),top .3s var(--ease),opacity .3s var(--ease)}
#nav-toggle span:nth-child(1){top:0}#nav-toggle span:nth-child(2){top:8px}#nav-toggle span:nth-child(3){top:16px}
#nav.scrolled #nav-toggle span,#nav.on-light.scrolled #nav-toggle span{background:var(--ink)}
#nav-toggle.open span:nth-child(1){top:8px;transform:rotate(45deg)}
#nav-toggle.open span:nth-child(2){opacity:0}
#nav-toggle.open span:nth-child(3){top:8px;transform:rotate(-45deg)}
@media(max-width:960px){
  .nav-links{position:fixed;inset:0;top:0;background:var(--ink);flex-direction:column;align-items:center;justify-content:center;gap:32px;opacity:0;pointer-events:none;transition:opacity .5s var(--ease)}
  .nav-links.open{opacity:1;pointer-events:auto}
  .nav-links a{color:var(--paper)!important;font-size:22px;letter-spacing:0.12em;padding:8px 0}
  #nav-toggle{display:block;color:var(--paper);z-index:1001}
  .nav-cta{display:none}
}

/* ═══ Hero (home) ═══ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--paper);text-align:center}
.hero-photo{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-photo img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);animation:heroScale 2.4s var(--ease) forwards}
@keyframes heroScale{to{transform:scale(1)}}
.hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(71,77,79,0.25) 0%,rgba(71,77,79,0.1) 45%,rgba(71,77,79,0.55) 85%,rgba(71,77,79,0.75) 100%)}
.hero-ct{position:relative;z-index:1;max-width:var(--col-hero);padding:0 var(--gutter);width:100%}
.hero-eyebrow{margin-bottom:28px;opacity:0;transform:translateY(24px);animation:fadeUp 1.8s .5s var(--ease) forwards}
.hero-title{margin-bottom:32px;opacity:0;transform:translateY(32px);animation:fadeUp 2s .7s var(--ease) forwards}
.hero-sub{margin-bottom:52px;opacity:0;transform:translateY(24px);animation:fadeUp 2s 1s var(--ease) forwards;color:rgba(255,255,255,0.88)}
.hero-cta{opacity:0;transform:translateY(20px);animation:fadeUp 2s 1.3s var(--ease) forwards}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.hero-scroll{position:absolute;bottom:44px;left:50%;transform:translateX(-50%);z-index:1;opacity:0;animation:scrollFade 2s 1.8s var(--ease) forwards;display:flex;flex-direction:column;align-items:center;gap:12px;color:rgba(255,255,255,0.85)}
@keyframes scrollFade{to{opacity:1}}
.hero-scroll::after{content:'';display:block;width:1px;height:52px;background:currentColor;animation:scrollPulse 2.4s ease-in-out infinite;transform-origin:top}
@keyframes scrollPulse{0%,100%{opacity:.35;transform:scaleY(1)}50%{opacity:1;transform:scaleY(.5)}}

/* ═══ Inner-page hero (smaller, photo + title) ═══ */
.page-hero{position:relative;min-height:72vh;display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--paper);text-align:center}
.page-hero-photo{position:absolute;inset:0;z-index:0;overflow:hidden}
.page-hero-photo img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);animation:heroScale 2.4s var(--ease) forwards}
.page-hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(71,77,79,0.35) 0%,rgba(71,77,79,0.25) 50%,rgba(71,77,79,0.7) 100%)}
.page-hero-ct{position:relative;z-index:1;max-width:var(--col-hero);padding:140px var(--gutter) 100px;width:100%}
.page-hero .eyebrow{margin-bottom:24px;opacity:0;transform:translateY(20px);animation:fadeUp 1.6s .4s var(--ease) forwards}
.page-hero .t-hero{margin-bottom:24px;opacity:0;transform:translateY(32px);animation:fadeUp 2s .6s var(--ease) forwards}
.page-hero-kicker{font-weight:300;font-size:clamp(16px,1.5vw,20px);line-height:1.6;color:rgba(255,255,255,0.85);max-width:620px;margin:0 auto;opacity:0;transform:translateY(20px);animation:fadeUp 1.8s .9s var(--ease) forwards}

/* ═══ Sections ═══ */
.sec{padding:var(--sp-sec) 0;position:relative}
.sec--sand{background:var(--sand)}
.sec--stone{background:var(--stone)}
.sec--ink{background:var(--ink);color:var(--paper)}
.sec-col{max-width:var(--col-narrow)}
.sec-eyebrow{margin-bottom:28px}
.sec-title{margin-bottom:28px}
.sec-body{margin-bottom:40px}
.sec-body p+p{margin-top:18px}
.sec-center{margin:0 auto;text-align:center}

/* Hairline rule */
.rule{display:block;width:100%;height:1px;background:var(--hair);border:0;margin:0}
.rule--dark{background:rgba(255,255,255,0.18)}

/* ═══ Pillar photo band + service list ═══ */
.pillar{position:relative;min-height:620px;display:flex;align-items:flex-end;overflow:hidden;color:var(--paper)}
.pillar-photo{position:absolute;inset:0;z-index:0}
.pillar-photo img{width:100%;height:100%;object-fit:cover}
.pillar-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(71,77,79,0.3) 0%,rgba(71,77,79,0.2) 40%,rgba(71,77,79,0.8) 100%)}
.pillar-ct{position:relative;z-index:1;max-width:var(--container);margin:0 auto;padding:170px var(--gutter) 100px;width:100%}
.pillar-title{max-width:var(--col-narrow);margin-top:20px;margin-bottom:28px;color:var(--paper)}
.pillar-sub{max-width:640px;color:rgba(255,255,255,0.88);font-size:18px;line-height:1.65;margin-bottom:0}

.svc-section{padding:var(--sp-sec-sm) 0}
.svc-list{max-width:var(--col-narrow)}
.svc{display:grid;grid-template-columns:56px 1fr;gap:36px;align-items:baseline;padding:28px 0;border-bottom:1px solid var(--hair)}
.svc:first-child{border-top:1px solid var(--hair)}
.svc-n{font-size:13px;font-weight:400;letter-spacing:0.24em;text-transform:uppercase;color:var(--ink-dim)}
.svc-t{font-size:22px;font-weight:300;color:var(--ink);line-height:1.35}
.svc-d{font-size:16px;font-weight:300;color:var(--ink-dim);line-height:1.65;margin-top:6px}
@media(max-width:600px){.svc{grid-template-columns:40px 1fr;gap:20px;padding:22px 0}.svc-t{font-size:18px}.svc-d{font-size:14px}}

/* ═══ Deploy gallery (home + services) ═══ */
.dep-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:64px 56px;margin-top:72px}
.dep-grid--3{grid-template-columns:repeat(3,1fr);gap:48px}
@media(max-width:960px){.dep-grid--3{grid-template-columns:1fr;gap:56px}}
@media(max-width:720px){.dep-grid{grid-template-columns:1fr;gap:56px}}
.dep-card-img{aspect-ratio:4/3;overflow:hidden;margin-bottom:28px;background:var(--hair)}
.dep-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s var(--ease)}
.dep-card:hover .dep-card-img img{transform:scale(1.04)}
.dep-card-tag{margin-bottom:12px}
.dep-card-name{font-size:26px;font-weight:300;line-height:1.2;margin-bottom:14px;color:var(--ink)}
.dep-card-body{font-size:16px;font-weight:300;line-height:1.7;color:var(--ink-dim);max-width:460px}

/* ═══ Heritage case layout ═══ */
.case{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-top:100px}
.case--reverse{direction:rtl}
.case--reverse>*{direction:ltr}
@media(max-width:900px){.case{grid-template-columns:1fr;gap:40px;margin-top:72px}.case--reverse{direction:ltr}}
.case-photo{aspect-ratio:4/3;overflow:hidden;background:var(--hair)}
.case-photo img{width:100%;height:100%;object-fit:cover;transition:transform 1.8s var(--ease)}
.case:hover .case-photo img{transform:scale(1.03)}
.case-body{max-width:540px}
.case-tag{margin-bottom:16px}
.case-title{font-size:clamp(28px,3.4vw,44px);font-weight:300;line-height:1.12;margin-bottom:24px;color:var(--ink)}
.case-text{font-size:17px;font-weight:300;line-height:1.75;color:var(--ink-dim);margin-bottom:28px}
.case-stats{display:flex;flex-wrap:wrap;gap:28px 44px;margin-bottom:8px;padding-top:28px;border-top:1px solid var(--hair)}
.case-stat .n{font-size:30px;font-weight:300;color:var(--ink);line-height:1;margin-bottom:6px;letter-spacing:-0.01em}
.case-stat .l{font-size:11px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-dim)}

/* Full-bleed pinned parallax photo section */
.pin{position:relative;min-height:720px;display:flex;align-items:center;color:var(--paper);overflow:hidden}
.pin-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;background-attachment:fixed}
@media(max-width:900px){.pin-bg{background-attachment:scroll}}
.pin-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,rgba(71,77,79,0.82) 0%,rgba(71,77,79,0.5) 55%,rgba(71,77,79,0.3) 100%)}
.pin-ct{position:relative;z-index:1;max-width:var(--container);margin:0 auto;padding:100px var(--gutter);width:100%}
.pin-body{max-width:640px}
.pin-body .case-title,.pin-body .t-title{color:var(--paper)}
.pin-body .case-text,.pin-body .t-body{color:rgba(255,255,255,0.85)}
.pin-body .case-stats{border-top-color:rgba(255,255,255,0.2)}
.pin-body .case-stat .n{color:var(--paper)}
.pin-body .case-stat .l{color:rgba(255,255,255,0.7)}

/* ═══ Leadership — AIMS-style alternating bands ═══ */
.lead-band{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;min-height:720px;border-bottom:1px solid var(--hair)}
.lead-band--reverse{direction:rtl}
.lead-band--reverse>*{direction:ltr}
@media(max-width:900px){.lead-band{grid-template-columns:1fr;min-height:0}.lead-band--reverse{direction:ltr}}
.lead-photo{position:relative;overflow:hidden;min-height:680px;background:var(--stone);display:flex;align-items:flex-end;justify-content:center}
.lead-photo img{width:100%;height:100%;max-width:none;object-fit:contain;object-position:center bottom;transition:transform 1.8s var(--ease)}
.lead-band:hover .lead-photo img{transform:scale(1.015)}
.lead-body-wrap{display:flex;align-items:center;padding:80px 72px;background:var(--sand)}
.lead-band--reverse .lead-body-wrap{background:var(--stone)}
@media(max-width:900px){.lead-photo{min-height:520px}}
@media(max-width:900px){.lead-body-wrap{padding:64px var(--gutter)}}
.lead-body{max-width:520px}
.lead-eyebrow{margin-bottom:18px}
.lead-name{font-size:clamp(30px,3vw,40px);font-weight:300;line-height:1.15;margin-bottom:10px;color:var(--ink)}
.lead-role{margin-bottom:28px}
.lead-bio{font-size:16px;font-weight:300;line-height:1.75;color:var(--ink-dim)}
.lead-bio p+p{margin-top:14px}

/* Project-leads compact grid (tier 2) */
.proj-leads-wrap{background:var(--sand);padding:var(--sp-sec) 0}
.proj-leads-head{max-width:var(--col-narrow);margin:0 auto 56px;text-align:center;padding:0 var(--gutter)}
.proj-leads{display:grid;grid-template-columns:repeat(2,1fr);gap:80px 88px;max-width:1440px;margin:0 auto;padding:0 var(--gutter)}
@media(max-width:720px){.proj-leads{grid-template-columns:1fr;gap:64px}}
.proj-lead{text-align:left}
.proj-lead-photo{position:relative;overflow:hidden;background:var(--stone);aspect-ratio:3/4;max-width:660px;margin:0 auto 40px;display:flex;align-items:flex-end;justify-content:center}
.proj-lead-photo img{width:100%;height:100%;max-width:none;object-fit:contain;object-position:center bottom;transition:transform 1.8s var(--ease)}
.proj-lead:hover .proj-lead-photo img{transform:scale(1.02)}
.proj-lead-body{max-width:560px;margin:0 auto;text-align:center}
.proj-lead-name{font-size:28px;font-weight:300;margin-bottom:8px;color:var(--ink);letter-spacing:-0.01em}
.proj-lead-role{margin-bottom:20px}
.proj-lead-bio{font-size:16px;font-weight:300;line-height:1.75;color:var(--ink-dim);text-align:left}
@media(max-width:720px){.proj-lead-photo{max-width:440px}}

/* ═══ Partners ═══ */
.part-block{padding:56px 0;border-top:1px solid var(--hair);display:grid;grid-template-columns:1fr 1.6fr;gap:48px}
.part-block:last-of-type{border-bottom:1px solid var(--hair)}
@media(max-width:820px){.part-block{grid-template-columns:1fr;gap:24px;padding:44px 0}}
.part-head .part-name{font-size:30px;font-weight:300;color:var(--ink);line-height:1.2;margin-bottom:12px}
.part-head .part-meta{font-size:12px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-dim)}
.part-body{font-size:17px;font-weight:300;line-height:1.75;color:var(--ink-dim);max-width:560px}
.part-body-kicker{margin-bottom:14px;font-size:12px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-dim);font-weight:400}

.oem-list{margin-top:72px}
.oem-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
@media(max-width:720px){.oem-row{grid-template-columns:repeat(2,1fr)}}
.oem-cell{padding:48px 28px;border-right:1px solid var(--hair);text-align:left;transition:background .3s var(--ease)}
.oem-cell:hover{background:rgba(255,255,255,0.4)}
.oem-cell:last-child{border-right:0}
@media(max-width:720px){.oem-cell:nth-child(2n){border-right:0}.oem-cell:nth-child(-n+2){border-bottom:1px solid var(--hair)}}
.oem-name{font-size:20px;font-weight:300;color:var(--ink);margin-bottom:10px}
.oem-sub{font-size:12px;font-weight:400;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim)}
.part-note{margin-top:48px;max-width:var(--col-narrow);font-size:14px;font-weight:300;color:var(--ink-dim);line-height:1.75}

/* ═══ Vision 2030 ═══ */
.vis-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--hair);margin-top:72px}
@media(max-width:820px){.vis-pillars{grid-template-columns:1fr}}
.vis-pil{padding:64px 48px;border-right:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.vis-pil:last-child{border-right:0}
@media(max-width:820px){.vis-pil{border-right:0;padding:48px 0}}
.vis-pil .eyebrow{margin-bottom:20px}
.vis-pil-t{font-size:22px;font-weight:300;margin-bottom:16px;color:var(--ink)}
.vis-pil-b{font-size:15px;font-weight:300;line-height:1.75;color:var(--ink-dim)}

.vis-logos{margin-top:96px;padding-top:56px;border-top:1px solid var(--hair)}
.vis-logos-label{margin-bottom:32px}
.vis-logos img{width:100%;max-width:720px;opacity:0.75;filter:grayscale(1) brightness(0.4);transition:opacity .4s}
.vis-logos img:hover{opacity:1}

/* Institutions-we-serve grid */
.vis-ent-sec{padding-top:var(--sp-sec)}
.vis-ent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:24px}
@media(max-width:1060px){.vis-ent-grid{grid-template-columns:repeat(2,1fr);gap:24px}}
@media(max-width:680px){.vis-ent-grid{grid-template-columns:1fr;gap:20px}}
.vis-ent{background:var(--paper);border:1px solid var(--hair);padding:36px 32px 32px;display:flex;flex-direction:column;gap:20px;position:relative;overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s var(--ease)}
.vis-ent::before{content:'';position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease)}
.vis-ent:hover{transform:translateY(-4px);box-shadow:0 22px 60px -26px rgba(71,77,79,.2);border-color:transparent}
.vis-ent:hover::before{transform:scaleX(1)}
.vis-ent-logo{height:110px;display:flex;align-items:center;justify-content:flex-start}
.vis-ent-logo img{height:96px;width:auto;max-width:220px;object-fit:contain;filter:grayscale(0.4);opacity:0.92;transition:filter .4s var(--ease),opacity .4s var(--ease);display:block}
.vis-ent:hover .vis-ent-logo img{filter:grayscale(0);opacity:1}
.vis-ent-body{display:flex;flex-direction:column;gap:12px}
.vis-ent-name{font-size:20px;font-weight:400;line-height:1.25;color:var(--ink);letter-spacing:-0.005em}
.vis-ent-desc{font-size:14.5px;font-weight:300;line-height:1.65;color:var(--ink-dim);margin:0}
.vis-ent-role{margin-top:8px;padding-top:16px;border-top:1px solid var(--hair)}
.vis-ent-role .eyebrow{font-size:10px;letter-spacing:0.26em}
.vis-ent-cta{font-size:14.5px;font-weight:300;line-height:1.7;color:var(--ink);margin:0}

/* ═══ Contact ═══ */
.con{max-width:var(--col-narrow);margin:0 auto;text-align:left}
.con-email{display:inline-flex;align-items:baseline;gap:16px;font-size:clamp(22px,2.8vw,32px);font-weight:300;color:var(--ink);margin:12px 0 0;position:relative;padding-bottom:6px;line-height:1.2}
.con-email::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.con-email:hover::after{transform:scaleX(1)}
.con-email .arrow{font-size:0.72em;opacity:0.55;transition:transform .4s var(--ease)}
.con-email:hover .arrow{transform:translateX(8px)}
.con-meta{font-size:13px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:10px}
.con-divider{margin:72px 0;height:1px;background:var(--hair);border:0}
.con-addr{margin-top:56px}
.con-addr .t-body{margin-bottom:0}

/* ═══ Legal pages ═══ */
.legal{max-width:800px;margin:0 auto}
.legal h2{font-size:22px;font-weight:400;line-height:1.35;margin:48px 0 16px;color:var(--ink);letter-spacing:-0.005em}
.legal h2:first-child{margin-top:0}
.legal p{font-size:16px;font-weight:300;line-height:1.75;color:var(--ink);margin-bottom:14px}
.legal p+p{margin-top:0}
.legal ul{padding-left:20px;margin-bottom:14px}
.legal ul li{font-size:16px;font-weight:300;line-height:1.75;color:var(--ink);margin-bottom:6px}
.legal a{color:var(--ink);border-bottom:1px solid var(--hair);transition:border-color .3s var(--ease)}
.legal a:hover{border-color:var(--ink)}
.legal-meta{font-size:12px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-dim);margin-top:48px;padding-top:24px;border-top:1px solid var(--hair)}
.services-intro{padding-top:220px}
@media(max-width:720px){.services-intro{padding-top:160px}.con-addr[style*="grid"]{grid-template-columns:1fr!important}}

/* ═══ Footer ═══ */
footer{background:var(--ink);color:var(--paper);padding:120px 0 40px;margin-top:0}
.ft-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr;gap:80px;margin-bottom:80px}
@media(max-width:720px){.ft-grid{grid-template-columns:1fr;gap:48px}}
.ft-logo{margin-bottom:28px}
.ft-logo img{height:40px;width:auto;filter:brightness(0) invert(1)}
.ft-tag{font-size:15px;font-weight:300;color:rgba(255,255,255,0.68);line-height:1.8;max-width:340px}
.ft-col-t{font-size:13px;font-weight:400;letter-spacing:0.24em;text-transform:uppercase;color:var(--paper);margin-bottom:26px}
.ft-links{display:flex;flex-direction:column;gap:15px}
.ft-links a{font-size:15px;font-weight:300;color:var(--silver);transition:color .3s}
.ft-links a:hover{color:var(--paper)}
.ft-bot{padding-top:40px;border-top:1px solid rgba(255,255,255,0.18);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.ft-copy{font-size:12px;font-weight:300;color:rgba(255,255,255,0.55);letter-spacing:0.02em}
.ft-place{font-size:11px;font-weight:400;letter-spacing:0.26em;text-transform:uppercase;color:rgba(255,255,255,0.4)}

/* ═══ Logo entrance animation (every page load) ═══ */
#nav .nav-logo img{opacity:0;transform:translateY(-14px) scale(0.9);animation:logoEnter 1.6s .2s var(--ease) forwards}
@keyframes logoEnter{to{opacity:1;transform:translateY(0) scale(1)}}

/* ═══ Institutional logos — horizontal marquee (continuous scroll) ═══ */
.logo-marquee{background:var(--stone);padding:96px 0;overflow:hidden;position:relative;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.logo-marquee-head{text-align:center;margin-bottom:56px;padding:0 var(--gutter)}
.logo-marquee-head .eyebrow{color:var(--ink-dim);letter-spacing:0.32em}
.logo-marquee-head h3{font-size:clamp(22px,2vw,28px);font-weight:300;color:var(--ink);margin-top:16px;letter-spacing:-0.005em}
.logo-marquee-mask{position:relative;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%)}
.logo-marquee-track{display:flex;width:max-content;gap:0;animation:marquee 60s linear infinite;will-change:transform}
.logo-marquee:hover .logo-marquee-track{animation-play-state:paused}
.logo-item{flex-shrink:0;height:150px;display:flex;align-items:center;justify-content:center;padding:0 40px;box-sizing:border-box}
.logo-item img{height:120px;width:auto;max-width:240px;object-fit:contain;filter:grayscale(1);opacity:0.62;transition:filter .4s var(--ease),opacity .4s var(--ease),transform .4s var(--ease);display:block}
.logo-item:hover img{filter:grayscale(0);opacity:1;transform:scale(1.04)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@media(max-width:720px){.logo-marquee{padding:64px 0}.logo-item{height:110px;padding:0 22px}.logo-item img{height:86px;max-width:170px}}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:0.01ms!important;transition-duration:0.01ms!important}
  .rv,.rv-h,.tx-rise,.tx-stagger>*{opacity:1!important;transform:none!important;filter:none!important}
  .tx-words .tx-w>span{transform:none!important}
  .tx-line{clip-path:none!important}
  .hero-eyebrow,.hero-title,.hero-sub,.hero-cta,.hero-scroll,
  .page-hero .eyebrow,.page-hero .t-hero,.page-hero-kicker{opacity:1!important;transform:none!important;animation:none!important}
  .hero-photo img,.page-hero-photo img{transform:none!important;animation:none!important}
  #nav .nav-logo img{opacity:1!important;transform:none!important;animation:none!important}
  .logo-marquee-track{animation:none!important}
  #preload{display:none}
}
