:root {
  --warm:#f0ede8; --dark:#1a1a1a; --navy:#0f1f3d; --teal:#00a896;
  --teal-l:#00c9b1; --grey:#555; --grey-l:#888; --grey-f:#d4d0cb;
  --amber:#c9882e; --card:#f7f5f1;
  --serif:'Lora',Georgia,serif; --sans:'Instrument Sans',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sans);background:var(--warm);color:var(--dark);overflow-x:hidden}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--warm)}::-webkit-scrollbar-thumb{background:var(--teal);border-radius:3px}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:0 52px;height:70px;transition:background .35s,box-shadow .35s,color .35s}
nav.solid{background:rgba(240,237,232,.97);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(0,0,0,.07)}
/* Light mode (default — on solid nav or light-bg pages) */
nav[data-mode="light"] .n-word{color:var(--dark)}
nav[data-mode="light"] .n-word span{color:var(--grey)}
nav[data-mode="light"] .n-links button,
nav[data-mode="light"] .n-links a:not(.n-cta){color:var(--dark)}
nav[data-mode="light"] .hamburger span{background:var(--dark)}
/* Dark mode (on dark hero, not yet scrolled) */
nav[data-mode="dark"] .n-word{color:#f0ede8}
nav[data-mode="dark"] .n-word span{color:rgba(240,237,232,.55)}
nav[data-mode="dark"] .n-links button,
nav[data-mode="dark"] .n-links a:not(.n-cta){color:#f0ede8}
nav[data-mode="dark"] .n-links button:hover,
nav[data-mode="dark"] .n-links a:hover:not(.n-cta){color:var(--teal-l);background:rgba(255,255,255,.07)}
nav[data-mode="dark"] .hamburger span{background:#f0ede8}
/* Logo SVG colour vars */
nav[data-mode="dark"]  .logo-use{color:#f0ede8!important}
nav[data-mode="light"] .logo-use{color:var(--dark)!important}
/* Shared nav link styles */
.n-logo{display:flex;align-items:center;gap:11px;cursor:pointer;text-decoration:none}
.n-logo svg{width:34px;height:34px}
.n-word{font-family:var(--serif);font-size:21px;font-weight:700;transition:color .3s}
.n-links{display:flex;align-items:center;gap:2px}
.n-links button,.n-links a{font-family:var(--sans);font-size:13.5px;font-weight:500;background:none;border:none;cursor:pointer;padding:8px 13px;border-radius:6px;text-decoration:none;transition:background .2s,color .2s}
.n-links button:hover,.n-links a:hover{background:rgba(0,168,150,.09);color:var(--teal)}
.n-cta{background:var(--teal)!important;color:#fff!important;padding:9px 22px!important;border-radius:6px!important}
.n-cta:hover{background:var(--teal-l)!important;color:#fff!important}
.n-active{border-bottom:2px solid var(--teal);border-radius:0!important}
nav[data-mode="dark"] .n-active{border-color:var(--teal-l)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.hamburger span{width:23px;height:2px;border-radius:2px;transition:.3s;display:block}
.mob-menu{display:none;position:fixed;inset:0;background:var(--warm);z-index:999;flex-direction:column;padding:96px 48px 48px;gap:4px;overflow-y:auto}
.mob-menu.open{display:flex}
.mob-menu button{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--dark);background:none;border:none;border-bottom:1px solid var(--grey-f);padding:14px 0;text-align:left;cursor:pointer}
.mob-cta{margin-top:20px!important;background:var(--teal)!important;color:#fff!important;border-radius:8px!important;border:none!important;text-align:center!important;font-size:18px!important;padding:16px!important}

/* PAGES */
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}
.fu{animation:fadeUp .75s ease both}
.d1{animation-delay:.1s}.d2{animation-delay:.2s}.d3{animation-delay:.3s}.d4{animation-delay:.4s}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;background:var(--navy);position:relative;overflow:hidden;padding:130px 52px 80px}
.hero-mark{position:absolute;right:-40px;top:50%;transform:translateY(-50%);width:min(660px,78vw);height:min(660px,78vw);opacity:.055;pointer-events:none;animation:spin 120s linear infinite;transform-origin:50% 50%}
.hero-mark{animation:none}
.hero-mark-wrap{position:absolute;right:-40px;top:50%;transform:translateY(-50%);width:min(660px,78vw);height:min(660px,78vw);opacity:.055;pointer-events:none;animation:heroSpin 120s linear infinite}
@keyframes heroSpin{from{transform:translateY(-50%) rotate(0deg)}to{transform:translateY(-50%) rotate(360deg)}}
.hero-content{position:relative;z-index:2;max-width:780px}
.eyebrow{font-size:11px;font-weight:600;letter-spacing:.18em;color:var(--teal);text-transform:uppercase;margin-bottom:22px}
.hero h1{font-family:var(--serif);font-size:clamp(44px,6.2vw,84px);font-weight:700;line-height:1.06;color:#f0ede8;margin-bottom:26px}
.hero h1 em{font-style:italic;color:var(--teal-l)}
.hero-sub{font-size:18px;line-height:1.72;color:rgba(240,237,232,.62);max-width:560px;margin-bottom:44px}
.ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn{font-family:var(--sans);font-size:15px;font-weight:600;padding:14px 32px;border-radius:7px;border:none;cursor:pointer;text-decoration:none;display:inline-block;transition:background .2s,transform .2s,border-color .2s,color .2s}
.btn-p{background:var(--teal);color:#fff}.btn-p:hover{background:var(--teal-l);transform:translateY(-2px)}
.btn-g{background:transparent;color:#f0ede8;border:1.5px solid rgba(240,237,232,.28)}.btn-g:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px)}
.btn-d{background:var(--dark);color:#fff}.btn-d:hover{background:#333;transform:translateY(-2px)}
.btn-o{background:transparent;color:var(--teal);border:1.5px solid var(--teal)}.btn-o:hover{background:var(--teal);color:#fff}

/* PAGE HERO (inner) */
.ph{background:var(--navy);padding:150px 52px 80px;position:relative;overflow:hidden}
.ph-mark{position:absolute;right:40px;top:50%;transform:translateY(-50%);width:380px;height:380px;opacity:.06;pointer-events:none}
.ph .tag{display:block;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin-bottom:18px}
.ph h1{font-family:var(--serif);font-size:clamp(34px,4.8vw,64px);font-weight:700;color:#f0ede8;line-height:1.1;max-width:680px;margin-bottom:18px}
.ph p{font-size:17px;color:rgba(240,237,232,.6);max-width:540px;line-height:1.72}

/* SECTIONS */
.sec{padding:96px 0}
.sec-dark{background:var(--navy);color:#f0ede8}
.sec-mid{background:#e8e4de}
.con{max-width:1200px;margin:0 auto;padding:0 24px}
.stag{display:block;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin-bottom:14px}
.sec-dark .stag{color:var(--teal-l)}
h2.st{font-family:var(--serif);font-size:clamp(30px,3.8vw,52px);font-weight:700;line-height:1.12;margin-bottom:18px}
.sec-dark h2.st{color:#f0ede8}
.sb{font-size:16.5px;line-height:1.76;color:var(--grey);max-width:620px}
.sec-dark .sb{color:rgba(240,237,232,.62)}

/* PILLARS */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--grey-f)}
.pillar{background:var(--warm);padding:52px 42px;cursor:pointer;transition:background .2s}
.pillar:hover{background:var(--card)}
.p-num{font-family:var(--serif);font-size:12px;font-weight:600;letter-spacing:.12em;color:var(--teal);margin-bottom:18px}
.pillar h3{font-family:var(--serif);font-size:25px;font-weight:700;margin-bottom:12px;line-height:1.2}
.pillar p{font-size:14.5px;line-height:1.7;color:var(--grey)}
.p-arrow{display:inline-block;margin-top:26px;font-size:13px;color:var(--teal);font-weight:600;letter-spacing:.04em;transition:letter-spacing .2s}
.pillar:hover .p-arrow{letter-spacing:.1em}

/* ABOUT GRID */
/* ABOUT SNAPSHOT — full width, centred, logo bg */
.about-snap{position:relative;overflow:hidden;padding-top:100px;padding-bottom:100px;}
.about-bg-mark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:0;}
.about-bg-mark svg{width:min(600px,85vw);height:min(600px,85vw);opacity:.03;}
/* Horizontal stats row */
.stats-row{display:flex;align-items:stretch;justify-content:center;gap:16px;flex-wrap:wrap;max-width:900px;margin:0 auto;}
.stat-h{flex:1;min-width:160px;padding:36px 24px;text-align:center;background:var(--card);border:1.5px solid var(--grey-f);border-radius:12px;}
.stat-div{display:none;}
.stat-n{font-family:var(--serif);font-size:44px;font-weight:700;color:var(--dark);line-height:1;margin-bottom:8px;}
.stat-l{font-size:13px;color:var(--grey);letter-spacing:.02em;line-height:1.4;}
/* Keep old .ag for about page, remove unused .stats */
.ag{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}

/* CARDS */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.card{background:var(--warm);border:1.5px solid var(--grey-f);border-radius:12px;padding:34px 30px;transition:transform .25s,box-shadow .25s,border-color .25s;cursor:default}
.card:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(0,0,0,.09);border-color:var(--teal)}
.badge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;padding:5px 12px;border-radius:99px;margin-bottom:20px}
.b-ai{background:rgba(0,168,150,.12);color:var(--teal)}
.b-dt{background:rgba(15,31,61,.1);color:var(--navy)}
.b-edu{background:rgba(201,136,46,.12);color:var(--amber)}
.card h4{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--dark);margin-bottom:11px;line-height:1.3}
.card p{font-size:13.5px;line-height:1.72;color:var(--grey);margin-bottom:22px}
.card-meta{display:flex;gap:18px;flex-wrap:wrap;border-top:1px solid var(--grey-f);padding-top:18px}
.cm strong{display:block;font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--dark);margin-bottom:2px}
.cm{font-size:12px;color:var(--grey-l)}
.card-cta{display:inline-block;margin-top:18px;font-size:13px;font-weight:600;color:var(--teal);letter-spacing:.04em;transition:letter-spacing .2s;text-decoration:none;cursor:pointer}
.card:hover .card-cta{letter-spacing:.09em}

/* SERVICES */
.svc-block{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:stretch;padding:56px 0;border-top:1px solid var(--grey-f)}
.svc-block:first-child{border-top:none;padding-top:0}
.svc-block > div{display:flex;flex-direction:column}
.svc-n{font-family:var(--serif);font-size:42px;font-weight:700;color:var(--grey-f);line-height:1;margin-bottom:10px}
.svc-block h3{font-family:var(--serif);font-size:28px;font-weight:700;color:var(--dark);margin-bottom:12px;line-height:1.2}
.svc-list{list-style:none;margin-top:20px}
.svc-list li{font-size:14px;color:var(--grey);padding:8px 0;border-bottom:1px solid var(--grey-f);display:flex;align-items:center;gap:10px}
.svc-list li::before{content:'';width:5px;height:5px;background:var(--teal);border-radius:50%;flex-shrink:0}
.steps-col{display:flex;flex-direction:column;flex:1}
.step{padding:22px 0 22px 24px;border-left:2px solid var(--grey-f);flex:1}
.step:first-child{border-color:var(--teal)}
.step-n{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--grey-f)}
.step h5{font-family:var(--serif);font-size:16px;color:var(--dark);margin:5px 0}
.step p{font-size:13px;color:var(--grey);line-height:1.6}
.svc-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;flex:1}
.svc-stat-box{border-radius:12px;padding:28px;border:1px solid var(--grey-f);display:flex;flex-direction:column;justify-content:center}
.svc-stat-box.dark{background:var(--navy);border-color:var(--navy)}
.svc-stat-n{font-family:var(--serif);font-size:36px;font-weight:700;color:var(--teal);line-height:1;margin-bottom:8px}
.svc-stat-l{font-size:13px;font-weight:600;color:var(--dark);margin-bottom:5px}
.svc-stat-sub{font-size:12px;color:var(--grey-l);line-height:1.5}
.svc-quote{background:var(--navy);border-radius:14px;padding:44px;color:#f0ede8;flex:1;display:flex;flex-direction:column;justify-content:center}
.svc-quote p.q{font-family:var(--serif);font-size:22px;font-weight:700;line-height:1.44;margin-bottom:20px;color:#f0ede8}
.svc-quote p.sub{font-size:14px;color:rgba(240,237,232,.52);line-height:1.68}

/* INSIGHTS */
.ins-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.ins-card{background:var(--card);border-radius:10px;overflow:hidden;border:1px solid var(--grey-f);transition:transform .25s,box-shadow .25s;cursor:pointer;display:flex;flex-direction:column}
.ins-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(0,0,0,.08)}
.ins-hdr{height:170px;background:var(--navy);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;flex-shrink:0}
.ins-hdr svg{width:110px;opacity:.07}
.ins-hdr .cat{position:absolute;top:14px;left:14px;font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;background:var(--teal);color:#fff;padding:4px 10px;border-radius:4px}
.ins-body{padding:22px;flex:1;display:flex;flex-direction:column}
.ins-meta{font-size:11.5px;color:var(--grey-l);margin-bottom:8px}
.ins-body h4{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--dark);line-height:1.36;margin-bottom:9px}
.ins-body p{font-size:13px;line-height:1.65;color:var(--grey)}

/* ARTICLE PAGE */
.art-hero{background:var(--navy);padding:150px 52px 64px;position:relative;overflow:hidden}
.art-hero-mark{position:absolute;right:40px;top:50%;transform:translateY(-50%);width:360px;height:360px;opacity:.055;pointer-events:none}
.art-back{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:rgba(240,237,232,.65);background:none;border:none;cursor:pointer;padding:0;margin-bottom:32px;letter-spacing:.04em;transition:color .2s,gap .2s}
.art-back:hover{color:var(--teal-l);gap:12px}
.art-cat{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:16px}
.art-hero h1{font-family:var(--serif);font-size:clamp(30px,4vw,54px);font-weight:700;color:#f0ede8;line-height:1.1;max-width:760px;margin-bottom:20px}
.art-hero-meta{font-size:13px;color:rgba(240,237,232,.48);display:flex;gap:20px;flex-wrap:wrap}
.art-body{max-width:720px;margin:0 auto;padding:72px 52px}
.art-body h2{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--dark);margin:44px 0 14px;line-height:1.2}
.art-body h3{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--dark);margin:32px 0 12px}
.art-body p{font-size:16.5px;line-height:1.84;color:var(--grey);margin-bottom:22px}
.art-body ul,.art-body ol{margin:0 0 22px 24px}
.art-body li{font-size:16px;line-height:1.78;color:var(--grey);margin-bottom:8px}
.art-pull{border-left:4px solid var(--teal);padding:20px 28px;margin:36px 0;background:rgba(0,168,150,.06);border-radius:0 8px 8px 0}
.art-pull p{font-family:var(--serif);font-size:20px;font-style:italic;color:var(--dark);line-height:1.5;margin:0}
.art-divider{border:none;border-top:1px solid var(--grey-f);margin:44px 0}
.art-cta{background:var(--navy);padding:56px 52px;text-align:center}
.art-cta h3{font-family:var(--serif);font-size:28px;font-weight:700;color:#f0ede8;margin-bottom:12px}
.art-cta p{font-size:15px;color:rgba(240,237,232,.56);margin-bottom:28px}
.art-related{padding:72px 52px;background:var(--card)}
.art-related h4{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--dark);margin-bottom:28px}
.art-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){
  .art-body{padding:48px 24px}
  .art-hero{padding:120px 24px 52px}
  .art-related{padding:48px 24px}
  .art-related-grid{grid-template-columns:1fr}
  .ins-grid{grid-template-columns:1fr}
}

/* CASE STUDIES */
.cs-card{background:var(--card);border-radius:14px;overflow:hidden;border:1.5px solid var(--grey-f);transition:transform .25s,box-shadow .25s}
.cs-card:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(0,0,0,.09)}
.cs-hdr{padding:38px;position:relative;overflow:hidden}
.cs-hdr svg{position:absolute;right:-20px;top:-20px;width:150px;height:150px;opacity:.06}
.cs-sector{font-size:11.5px;color:rgba(240,237,232,.42);letter-spacing:.08em;text-transform:uppercase;margin-bottom:9px}
.cs-hdr h3{font-family:var(--serif);font-size:22px;font-weight:700;color:#f0ede8;line-height:1.32}
.cs-body{padding:34px}
.cs-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--teal);margin-bottom:7px}
.cs-body p{font-size:13.5px;line-height:1.72;color:var(--grey);margin-bottom:22px}
.cs-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px;padding:18px;background:var(--warm);border-radius:10px}
.cs-stat{text-align:center}
.cs-stat-n{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--teal)}
.cs-stat-l{font-size:11px;color:var(--grey-l);margin-top:3px}
.cs-sep{border-left:1px solid var(--grey-f)}
blockquote.pull{border-left:3px solid var(--teal);padding-left:20px;margin-bottom:22px}
blockquote.pull p{font-family:var(--serif);font-size:15.5px;font-style:italic;color:var(--dark);line-height:1.58;margin-bottom:0}
blockquote.pull cite{font-size:11.5px;color:var(--grey-l);margin-top:8px;display:block;font-style:normal}
.cs-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:48px}
.cf{padding:7px 20px;border-radius:99px;border:1.5px solid var(--grey-f);background:transparent;color:var(--grey);font-family:var(--sans);font-size:13px;font-weight:500;cursor:pointer;transition:.2s}
.cf.active,.cf:hover{border-color:var(--teal);background:var(--teal);color:#fff}

/* ABOUT */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:54px}
.team-card{background:var(--card);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .25s,box-shadow .25s;border:1.5px solid transparent}
.team-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.10);border-color:var(--teal)}
.team-av{width:100%;height:280px;background:var(--navy);display:flex;align-items:center;justify-content:center;overflow:hidden}
.team-av svg{width:55%;opacity:.13}
.team-av-photo{background:var(--grey-f)}
.team-av-photo img{width:100%;height:100%;object-fit:cover;object-position:center 15%;display:block}
.team-inf{padding:26px}
.team-inf h4{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--dark)}
.team-inf .role-title{font-size:13px;color:var(--grey);margin:3px 0 2px;font-weight:500}
.team-inf .role{font-size:12.5px;color:var(--teal);margin:2px 0 11px;font-weight:500}
.team-inf p{font-size:13.5px;line-height:1.65;color:var(--grey)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.val{background:var(--navy);border-radius:12px;padding:32px 28px}
.val-l{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:10px}
.val h5{font-family:var(--serif);font-size:18px;font-weight:700;color:#f0ede8;margin-bottom:10px}
.val p{font-size:13.5px;line-height:1.65;color:rgba(240,237,232,.6)}

/* CONTACT */
.cg{display:grid;grid-template-columns:1.3fr 1fr;gap:76px}
.fg{margin-bottom:22px}
.fg label{display:block;font-size:11.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--grey);margin-bottom:7px}
.fg input,.fg select,.fg textarea{width:100%;font-family:var(--sans);font-size:14.5px;padding:13px 17px;border-radius:8px;border:1.5px solid var(--grey-f);background:var(--warm);color:var(--dark);outline:none;transition:border-color .2s;resize:vertical}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--teal)}
.cdet h5{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--dark);margin-bottom:7px}
.cdet p{font-size:13.5px;line-height:1.7;color:var(--grey);margin-bottom:26px}
.cdet a{color:var(--teal);text-decoration:none}

/* CTA BANNER */
.cta-b{background:var(--navy);padding:96px 52px;text-align:center;position:relative;overflow:hidden}
.cta-b-mark{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:480px;height:480px;opacity:.04;pointer-events:none}
.cta-b h2{font-family:var(--serif);font-size:clamp(28px,3.8vw,50px);font-weight:700;color:#f0ede8;margin-bottom:18px;position:relative;z-index:2}
.cta-b p{font-size:17px;color:rgba(240,237,232,.58);margin-bottom:40px;position:relative;z-index:2}
.cta-b .ctas{justify-content:center;position:relative;z-index:2}

/* NEWSLETTER */
.nws{background:var(--teal);padding:56px 52px;display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap}
.nws h3{font-family:var(--serif);font-size:24px;font-weight:700;color:#fff;max-width:360px}
.nws-form{display:flex;gap:0;flex:1;min-width:260px;max-width:440px}
.nws-form input{flex:1;padding:13px 18px;border:none;border-radius:6px 0 0 6px;font-family:var(--sans);font-size:14px;outline:none;background:rgba(255,255,255,.18);color:#fff}
.nws-form input::placeholder{color:rgba(255,255,255,.6)}
.nws-form button{padding:13px 22px;background:var(--dark);color:#fff;border:none;border-radius:0 6px 6px 0;cursor:pointer;font-weight:600;font-size:13.5px;transition:background .2s}
.nws-form button:hover{background:var(--navy)}

/* PARTNERS MARQUEE */
.marquee-wrap{position:relative;overflow:hidden;margin-top:40px;background:var(--warm);padding:16px 0}
.marquee-wrap::before,.marquee-wrap::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.marquee-wrap::before{left:0;background:linear-gradient(to right,var(--warm),transparent)}
.marquee-wrap::after{right:0;background:linear-gradient(to left,var(--warm),transparent)}
.marquee-track{display:flex;gap:56px;width:max-content;animation:marquee 28s linear infinite;align-items:center;padding:0 24px}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.partner-slot{width:160px;height:64px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.6;transition:opacity .2s}
.partner-slot:hover{opacity:1}
.partner-slot img{width:100%;height:100%;object-fit:contain}

/* FOOTER */
footer{background:#09101e;padding:76px 52px 36px;position:relative;overflow:hidden}
.foot-mark{position:absolute;right:-70px;bottom:-70px;width:420px;height:420px;opacity:.04;pointer-events:none}
.fg-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;margin-bottom:56px}
.fb .fl{display:flex;align-items:center;gap:11px;margin-bottom:16px;cursor:pointer}
.fb .fl svg{width:30px;height:30px}
.fb .fl-name{font-family:var(--serif);font-size:19px;font-weight:700;color:#f0ede8}
.fb .fl-name span{font-weight:400;color:rgba(240,237,232,.45)}
.fb > p{font-size:13.5px;line-height:1.7;color:rgba(240,237,232,.4);max-width:260px}
.fc h6{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(240,237,232,.35);margin-bottom:18px}
.fc a{display:block;font-size:13.5px;color:rgba(240,237,232,.55);text-decoration:none;margin-bottom:10px;transition:color .2s;cursor:pointer}
.fc a:hover{color:var(--teal)}
.fbot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(255,255,255,.05);padding-top:28px}
.fbot p{font-size:12.5px;color:rgba(240,237,232,.28)}
.fsoc{display:flex;gap:18px}
.fsoc a{font-size:12.5px;color:rgba(240,237,232,.38);text-decoration:none;transition:color .2s}
.fsoc a:hover{color:var(--teal)}

/* MOBILE */
@media(max-width:960px){
  nav{padding:0 24px}
  .n-links{display:none}
  .hamburger{display:flex}
  .hero{padding:120px 24px 60px}
  .ph{padding:120px 24px 56px}
  .ph-mark{display:none}
  .sec{padding:68px 0}
  .pillars{grid-template-columns:1fr}
  .ag,.cg{grid-template-columns:1fr;gap:36px}
  .stats-row{gap:12px;}
  .stat-h{min-width:calc(50% - 8px);flex:none;padding:26px 16px;}
  .stat-div{display:none;}
  .svc-block{grid-template-columns:1fr;gap:32px;align-items:start}
  .svc-block > div{display:block}
  .steps-col{display:flex;flex-direction:column;flex:none}
  .step{flex:none;border-left:none;border-top:2px solid var(--grey-f);padding:18px 0 0 0}
  .step:first-child{border-color:var(--teal)}
  .svc-stat-grid{grid-template-columns:1fr 1fr;flex:none}
  .svc-quote{flex:none}
  .grid-3,.grid-2,.team-grid,.ins-grid,.values-grid{grid-template-columns:1fr}
  .cs-grid-inner{grid-template-columns:1fr!important}
  .fg-grid{grid-template-columns:1fr 1fr;gap:36px}
  .nws{padding:44px 24px}
  .cta-b{padding:68px 24px}
  footer{padding:56px 24px 28px}
}
@media(max-width:580px){
  .fg-grid{grid-template-columns:1fr}
  .fbot{flex-direction:column;gap:14px;text-align:center}
  .hero h1{font-size:38px}
}
/* Multi-page nav link adjustments */
.n-links a{font-family:var(--sans);font-size:13.5px;font-weight:500;background:none;border:none;cursor:pointer;padding:8px 13px;border-radius:6px;text-decoration:none;transition:background .2s,color .2s}
.n-links a:hover{background:rgba(0,168,150,.09);color:var(--teal)}
nav[data-mode="dark"] .n-links a:not(.n-cta){color:#f0ede8}
nav[data-mode="dark"] .n-links a:hover:not(.n-cta){color:var(--teal-l);background:rgba(255,255,255,.07)}
nav[data-mode="light"] .n-links a:not(.n-cta){color:var(--dark)}
.mob-menu a{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--dark);text-decoration:none;border-bottom:1px solid var(--grey-f);padding:14px 0;text-align:left;display:block}
a.art-back{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:rgba(240,237,232,.65);text-decoration:none;padding:0;margin-bottom:32px;letter-spacing:.04em;transition:color .2s,gap .2s}
a.art-back:hover{color:var(--teal-l)}

/* Multi-file site — anchor-based navigation elements */
a.ins-card, a.team-card, a.cs-card, a.pillar {
  display: block;
  text-decoration: none;
  color: inherit;
}
a.btn, a.btn-p, a.btn-g, a.btn-o, a.btn-d {
  text-decoration: none;
  display: inline-block;
}
a.art-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
}
a.card-cta {
  text-decoration: none;
}
a.n-link {
  text-decoration: none;
}

/* ── Bio page responsive layout ─────────────────────────────── */
.bio-layout{display:grid;grid-template-columns:280px 1fr;gap:64px;align-items:start}
.bio-photo{border-radius:16px;overflow:hidden;margin-bottom:24px;height:320px}
.bio-photo img{width:100%;height:100%;object-fit:cover;object-position:center 15%;display:block}
.bio-links{display:flex;flex-direction:column;gap:10px}
.bio-links a{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--teal);text-decoration:none;font-weight:500}
.bio-expertise{margin-top:28px;padding-top:24px;border-top:1px solid var(--grey-f)}
.bio-expertise-label{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-l);margin-bottom:12px}
.bio-tags{display:flex;flex-wrap:wrap;gap:8px}
.bio-tag{font-size:12px;padding:5px 12px;border-radius:99px;background:rgba(0,168,150,.1);color:var(--teal);font-weight:500}
.bio-name{font-family:var(--serif);font-size:36px;font-weight:700;color:var(--dark);margin-bottom:4px}
.bio-role{font-size:14.5px;color:var(--grey);font-weight:600;margin-bottom:2px}
.bio-org{font-size:14px;color:var(--teal);font-weight:600;letter-spacing:.04em;margin-bottom:32px}
.bio-body p{font-size:16.5px;line-height:1.82;color:var(--grey);margin-bottom:20px}
.bio-quote{border-left:4px solid var(--teal);padding:20px 28px;margin:36px 0;background:rgba(0,168,150,.05);border-radius:0 8px 8px 0}
.bio-quote p{font-family:var(--serif);font-size:19px;font-style:italic;color:var(--dark);line-height:1.5;margin:0}
.bio-section-title{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--dark);margin:36px 0 16px}
.bio-list{list-style:none;margin:0;padding:0}
.bio-list li{font-size:15.5px;line-height:1.75;color:var(--grey);padding:9px 0;border-bottom:1px solid var(--grey-f);display:flex;align-items:flex-start;gap:12px;word-break:break-word;min-width:0}
.bio-list li:last-child{border-bottom:none}
.bio-list li span{width:6px;height:6px;background:var(--teal);border-radius:50%;flex-shrink:0;margin-top:8px}
.bio-actions{margin-top:40px;display:flex;flex-wrap:wrap;gap:14px}

@media(max-width:960px){
  .bio-layout{grid-template-columns:1fr;gap:32px}
  .bio-photo{height:260px}
  .bio-name{font-size:28px}
  .bio-body p{font-size:15px}
  .bio-quote p{font-size:16px}
  .bio-quote{padding:16px 20px}
  .bio-actions{flex-direction:column;gap:12px}
  .bio-actions .btn{text-align:center;width:100%}
}
@media(max-width:480px){
  .bio-photo{height:200px}
  .bio-name{font-size:22px}
  .bio-section-title{font-size:18px}
}
