
:root{
  --bg:#ffffff;
  --text:#111111;
  --muted:#5f5f5f;
  --muted-2:#7e7e7e;
  --line:rgba(17,17,17,.12);
  --line-strong:rgba(17,17,17,.22);
  --soft:#f6f6f6;
  --soft-2:#efefef;
  --max:1440px;
  --content:1260px;
  --header-h:92px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Arial,Helvetica,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body.menu-open{overflow:hidden}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button,input,textarea{font:inherit}
.container{width:min(var(--max),calc(100% - 56px));margin:0 auto}
.thin{font-weight:400}
.site-header{
  position:sticky;top:0;z-index:80;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  min-height:var(--header-h);
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  gap:28px;
  align-items:center;
}
.brand{
  display:inline-grid;
  grid-template-columns:58px auto;
  gap:16px;
  align-items:center;
}
.brand-mark{
  width:58px;height:58px;border:2px solid #111;
  display:grid;place-items:center;
  font-family:Georgia,"Times New Roman",serif;
  font-size:28px;letter-spacing:-.04em;
}
.brand-copy{display:flex;flex-direction:column;gap:4px}
.brand-copy strong{
  font-size:14px;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;
}
.brand-copy span{
  color:var(--muted);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
}
.main-nav{
  display:flex;justify-content:center;gap:26px;align-items:center;
}
.main-nav a{
  position:relative;font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  color:#222;padding:8px 0;
}
.main-nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:#111;
  transform:scaleX(0);transform-origin:left center;transition:transform .7s cubic-bezier(.16,1,.3,1);
}
.main-nav a:hover::after,.main-nav a.active::after{transform:scaleX(1)}
.header-meta{
  display:flex;gap:18px;align-items:center;justify-self:end;
}
.header-note{
  max-width:230px;font-size:11px;line-height:1.5;color:var(--muted);
  text-transform:uppercase;letter-spacing:.1em;
}
.header-cta,.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:50px;padding:0 20px;border:1px solid #111;
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  transition:color .6s cubic-bezier(.16,1,.3,1), background .6s cubic-bezier(.16,1,.3,1), transform .6s cubic-bezier(.16,1,.3,1), box-shadow .6s cubic-bezier(.16,1,.3,1);
}
.header-cta:hover,.btn.dark:hover{background:#111;color:#fff;box-shadow:12px 12px 0 rgba(0,0,0,.08);transform:translate(-4px,-4px)}
.btn.light{border-color:var(--line-strong);background:#fff}
.btn.light:hover{border-color:#111;box-shadow:12px 12px 0 rgba(0,0,0,.06);transform:translate(-4px,-4px)}
.mobile-toggle{
  display:none;background:none;border:0;padding:0;font-size:34px;line-height:1;cursor:pointer;
}
.hero{
  position:relative;border-bottom:1px solid var(--line);
}
.hero-grid{
  display:grid;grid-template-columns:minmax(0,1.1fr) minmax(420px,.9fr);
  gap:40px;align-items:end;
  min-height:calc(100vh - var(--header-h));
  padding:48px 0 40px;
}
.kicker{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
  margin-bottom:22px;
}
.hero h1{
  margin:0;max-width:760px;font-size:clamp(46px,6vw,94px);line-height:.94;font-weight:600;letter-spacing:-.05em;
}
.hero-copy{
  max-width:700px;margin:28px 0 34px;color:#272727;font-size:18px;line-height:1.65;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:38px}
.hero-strip{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding-top:20px;border-top:1px solid var(--line);
  max-width:880px;
}
.hero-strip article{padding-right:10px}
.hero-strip small{
  display:block;margin-bottom:9px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
}
.hero-strip p{margin:0;font-size:15px;color:#1d1d1d}
.hero-visual{
  position:relative;min-height:760px;padding-left:44px;
}
.frame-note{
  position:absolute;left:0;top:0;transform:rotate(-90deg) translateX(-100%);
  transform-origin:left top;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);
}
.visual-shell{
  position:relative;height:100%;border-left:1px solid var(--line);
}
.visual-primary{
  position:absolute;top:0;left:44px;right:0;height:72%;
  overflow:hidden;border:1px solid var(--line-strong);
}
.visual-primary img,.image-panel img,.service-tile img,.media-stack img,.quote-image img,.sector-visual img,.contact-visual img,.value-image img,.story-image img{
  width:100%;height:100%;object-fit:cover;
}
.visual-primary::after,.image-panel::after,.service-tile::after,.sector-visual::after,.story-image::after,.contact-visual::after{
  content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.18));
}
.visual-secondary{
  position:absolute;right:40px;bottom:46px;width:44%;height:38%;
  overflow:hidden;border:1px solid var(--line-strong);background:#f1f1f1;
}
.visual-mark{
  position:absolute;left:0;bottom:0;transform:translate(-24px,24px);
  width:116px;height:116px;border:2px solid #111;background:#fff;
  display:grid;place-items:center;font-family:Georgia,"Times New Roman",serif;font-size:58px;z-index:3;
}
.visual-gridline{
  position:absolute;background:var(--line);
  animation:gridShift 16s linear infinite;
}
.visual-gridline.v1{top:9%;left:20px;right:16%;height:1px}
.visual-gridline.v2{top:50%;left:10%;right:0;height:1px;animation-duration:20s}
.visual-gridline.v3{top:0;bottom:15%;right:19%;width:1px;animation-duration:22s}
.visual-gridline.v4{top:14%;bottom:0;left:56px;width:1px;animation-duration:18s}
.hero-float{
  position:absolute;right:-20px;top:9%;width:110px;height:110px;border:1px solid var(--line);
  background:linear-gradient(180deg,#fff,#f2f2f2);animation:floatY 7s ease-in-out infinite;
}
.hero-float::before,.hero-float::after{
  content:"";position:absolute;background:var(--line);
}
.hero-float::before{left:18px;right:18px;top:50%;height:1px}
.hero-float::after{top:18px;bottom:18px;left:50%;width:1px}
.section{
  position:relative;padding:110px 0;border-bottom:1px solid var(--line);
}
.section-head{
  display:grid;grid-template-columns:320px 1fr;gap:32px;align-items:start;margin-bottom:44px;
}
.section-head h2{
  margin:0;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.22em;
}
.section-head .lead{
  font-size:clamp(30px,3.5vw,56px);line-height:1.02;letter-spacing:-.04em;margin-bottom:14px;max-width:860px;
}
.section-head p{margin:0;max-width:800px;color:#333;font-size:17px;line-height:1.75}
.position-grid{
  display:grid;grid-template-columns:1.2fr .8fr;gap:34px;align-items:start;
}
.editorial-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
}
.block{
  border-top:1px solid var(--line-strong);
  padding-top:18px;position:relative;
}
.block small{
  display:block;margin-bottom:12px;color:var(--muted);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
}
.block h3{margin:0 0 12px;font-size:26px;line-height:1.08;letter-spacing:-.03em}
.block p{margin:0;color:#333;font-size:16px;line-height:1.75}
.col-6{grid-column:span 6}
.col-5{grid-column:span 5}
.col-4{grid-column:span 4}
.col-7{grid-column:span 7}
.col-8{grid-column:span 8}
.col-12{grid-column:span 12}
.image-panel{
  position:relative;min-height:540px;border:1px solid var(--line-strong);overflow:hidden;
}
.image-panel .caption{
  position:absolute;left:24px;bottom:24px;display:grid;gap:6px;z-index:2;
  background:rgba(255,255,255,.84);padding:16px 18px;max-width:280px;border-left:2px solid #111;
}
.image-panel .caption small{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.image-panel .caption span{font-size:14px;line-height:1.55}
.stats-rail{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.stats-rail article{
  border-top:1px solid var(--line-strong);padding-top:14px;
}
.stats-rail strong{
  display:block;font-size:clamp(28px,4vw,50px);letter-spacing:-.05em;margin-bottom:6px;font-weight:600;
}
.stats-rail span{font-size:14px;color:#333;line-height:1.65}
.service-mosaic{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
}
.service-tile{
  position:relative;min-height:420px;border:1px solid var(--line-strong);overflow:hidden;background:#f2f2f2;
}
.service-tile .copy{
  position:absolute;left:0;right:0;bottom:0;z-index:2;padding:26px 24px 24px;background:linear-gradient(180deg, rgba(17,17,17,0) 0%, rgba(17,17,17,.78) 62%, rgba(17,17,17,.94) 100%);
  color:#fff;
}
.service-tile .copy small{display:block;margin-bottom:10px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.74)}
.service-tile .copy h3{margin:0 0 10px;font-size:24px;font-weight:600;letter-spacing:-.03em}
.service-tile .copy p{margin:0;font-size:15px;line-height:1.65;color:rgba(255,255,255,.9)}
.tall{grid-column:span 5;min-height:580px}
.wide{grid-column:span 7;min-height:580px}
.medium{grid-column:span 6;min-height:420px}
.slim-list{
  display:grid;grid-template-columns:repeat(6,1fr);gap:20px;margin-top:26px;
}
.slim-item{
  grid-column:span 2;border-top:1px solid var(--line-strong);padding-top:14px;
}
.slim-item h4{margin:0 0 10px;font-size:18px;font-weight:600}
.slim-item p{margin:0;color:#333;font-size:15px;line-height:1.65}
.story-wrap{
  display:grid;grid-template-columns:1fr 1.1fr;gap:34px;align-items:start;
}
.story-image{
  position:relative;min-height:760px;border:1px solid var(--line-strong);overflow:hidden;
}
.story-card{
  display:grid;gap:22px;
}
.story-card .lead{font-size:clamp(30px,3.2vw,54px);line-height:1.04;letter-spacing:-.04em}
.story-card p{margin:0;color:#333;font-size:17px;line-height:1.85}
.value-stack{display:grid;gap:18px}
.value-card{
  display:grid;grid-template-columns:110px 1fr;gap:18px;padding-top:16px;border-top:1px solid var(--line-strong);
}
.value-card small{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.value-card h4{margin:0 0 8px;font-size:20px;letter-spacing:-.02em}
.value-card p{margin:0;color:#333;font-size:15px;line-height:1.7}
.media-stack{
  display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch;
}
.media-stack .large,.media-stack .small{
  position:relative;border:1px solid var(--line-strong);overflow:hidden;min-height:430px;
}
.media-stack .small{min-height:430px}
.sector-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
}
.sector-card{
  grid-column:span 4;border-top:1px solid var(--line-strong);padding-top:16px;display:grid;gap:12px;
}
.sector-card h3{margin:0;font-size:22px;letter-spacing:-.03em}
.sector-card p{margin:0;color:#333;font-size:15px;line-height:1.72}
.sector-visual{
  position:relative;grid-column:span 8;border:1px solid var(--line-strong);min-height:520px;overflow:hidden;
}
.framework-grid{
  display:grid;grid-template-columns:320px 1fr;gap:32px;
}
.framework-steps{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
}
.step{
  border-top:1px solid var(--line-strong);padding-top:16px;min-height:160px;
}
.step strong{
  display:block;margin-bottom:10px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
}
.step h3{margin:0 0 10px;font-size:22px;letter-spacing:-.03em}
.step p{margin:0;color:#333;font-size:15px;line-height:1.72}
.quote-band{
  display:grid;grid-template-columns:1fr 300px;gap:34px;align-items:center;
  border-top:1px solid var(--line-strong);padding-top:24px;margin-top:24px;
}
.quote-band blockquote{
  margin:0;font-size:clamp(28px,3vw,48px);line-height:1.08;letter-spacing:-.04em;
}
.quote-image{
  border:1px solid var(--line-strong);min-height:250px;overflow:hidden;
}
.contact-grid{
  display:grid;grid-template-columns:.95fr 1.05fr;gap:34px;align-items:start;
}
.contact-panel{
  display:grid;gap:28px;
}
.contact-list{
  display:grid;gap:16px;
}
.contact-list article{
  border-top:1px solid var(--line-strong);padding-top:16px;
}
.contact-list small{
  display:block;margin-bottom:8px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);
}
.contact-list p{margin:0;font-size:16px;line-height:1.7;color:#222}
.contact-visual{
  position:relative;min-height:700px;border:1px solid var(--line-strong);overflow:hidden;
}
.form-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:10px;
}
.field{display:grid;gap:8px}
.field label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea{
  width:100%;border:1px solid var(--line-strong);padding:16px 14px;background:#fff;outline:none;
  transition:border-color .4s ease, box-shadow .4s ease;
}
.field input:focus,.field textarea:focus{border-color:#111;box-shadow:8px 8px 0 rgba(0,0,0,.04)}
.field textarea{min-height:160px;resize:vertical}
.form-note{font-size:13px;color:var(--muted);line-height:1.65}
.site-footer{
  padding:26px 0 40px;
}
.footer-grid{
  display:grid;grid-template-columns:auto 1fr auto;gap:30px;align-items:end;
}
.footer-nav{
  display:flex;flex-wrap:wrap;gap:18px 24px;justify-content:center;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
}
.footer-copy{
  text-align:right;font-size:12px;color:var(--muted);line-height:1.7;
}
.legal-links{
  display:flex;gap:16px;justify-content:flex-end;flex-wrap:wrap;font-size:12px;
}
.reveal{
  opacity:0;transform:translateY(34px);transition:opacity 1.15s cubic-bezier(.16,1,.3,1), transform 1.15s cubic-bezier(.16,1,.3,1);
}
.reveal.in-view{opacity:1;transform:none}
.delay-1{transition-delay:.12s}
.delay-2{transition-delay:.24s}
.delay-3{transition-delay:.36s}
.delay-4{transition-delay:.48s}
.delay-5{transition-delay:.60s}
[data-parallax]{will-change:transform}
.desktop-only{display:block}
.mobile-nav{
  position:fixed;inset:var(--header-h) 0 auto 0;background:#fff;border-bottom:1px solid var(--line);
  transform:translateY(-105%);transition:transform .7s cubic-bezier(.16,1,.3,1);z-index:70;padding:18px 28px 24px;display:none;
}
.mobile-nav.open{transform:translateY(0)}
.mobile-nav a{
  display:block;padding:12px 0;border-bottom:1px solid var(--line);font-size:13px;letter-spacing:.14em;text-transform:uppercase;
}
@keyframes gridShift{
  0%,100%{transform:none;opacity:.65}
  50%{transform:translate3d(-12px,8px,0);opacity:1}
}
@keyframes floatY{
  0%,100%{transform:translate3d(0,0,0)}
  50%{transform:translate3d(0,18px,0)}
}
@media (max-width: 1180px){
  .header-inner{grid-template-columns:auto 1fr auto}
  .main-nav,.header-note,.header-cta{display:none}
  .mobile-toggle{display:block}
  .mobile-nav{display:block}
  .hero-grid,.position-grid,.story-wrap,.contact-grid,.framework-grid,.quote-band,.media-stack{grid-template-columns:1fr}
  .hero-visual{min-height:620px;padding-left:0}
  .visual-shell{border-left:0}
  .visual-primary{left:0}
  .visual-mark{transform:translate(18px,24px)}
  .section-head{grid-template-columns:1fr}
  .sector-visual,.sector-card,.col-4,.col-5,.col-6,.col-7,.col-8,.slim-item,.tall,.wide,.medium{grid-column:span 12}
  .framework-steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-copy{text-align:left}
  .legal-links,.footer-nav{justify-content:flex-start}
}
@media (max-width: 760px){
  .container{width:calc(100% - 32px)}
  .brand{grid-template-columns:48px auto;gap:12px}
  .brand-mark{width:48px;height:48px;font-size:24px}
  .brand-copy strong{font-size:12px}
  .brand-copy span{font-size:10px;letter-spacing:.1em}
  .hero-grid{min-height:auto;padding:34px 0 30px}
  .hero-copy{font-size:17px}
  .hero-strip,.stats-rail,.form-grid{grid-template-columns:1fr}
  .hero-visual{min-height:460px}
  .visual-secondary{width:48%;height:38%;right:18px;bottom:18px}
  .visual-mark{width:88px;height:88px;font-size:42px}
  .section{padding:82px 0}
  .section-head .lead,.story-card .lead{font-size:34px}
  .service-tile,.story-image,.contact-visual,.image-panel,.sector-visual{min-height:360px}
  .service-tile .copy h3{font-size:22px}
  .quote-band blockquote{font-size:28px}
}
