*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:#fff;color:#000;font-family:Arial,Helvetica,sans-serif}
a{color:inherit;text-decoration:none}
img,video{display:block;width:100%;object-fit:cover}
.topbar{position:fixed;top:0;left:0;right:0;height:86px;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);display:flex;justify-content:space-between;align-items:center;padding:18px 36px;border-bottom:1px solid #e9e9e9}
.logo img{width:94px;height:auto}
nav{display:flex;gap:30px;text-transform:uppercase;font-size:12px;letter-spacing:.14em}
nav a:hover,.footer-links a:hover,.social-strip a:hover{opacity:.45}
.home-hero{min-height:100vh;padding-top:86px;display:grid;grid-template-columns:1fr 1fr}
.home-copy{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:40px}
.home-copy img{width:min(560px,82%);height:auto}
.home-copy p{font-size:25px;max-width:520px;line-height:1.15;margin:30px 0}
.btn{border:1px solid #000;padding:14px 24px;text-transform:uppercase;letter-spacing:.12em;font-size:12px}
.btn:hover{background:#000;color:#fff}
.home-media img{height:calc(100vh - 86px)}
.statement{padding:110px 36px;border-top:1px solid #eee;border-bottom:1px solid #eee}
.statement p{font-size:clamp(42px,6vw,92px);line-height:.94;letter-spacing:-.075em;font-weight:900;max-width:1250px;margin:0}
.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#000}
.preview-grid a{position:relative;min-height:620px;overflow:hidden;background:#000}
.preview-grid img{height:620px;opacity:.86;transition:transform .8s ease}
.preview-grid a:hover img{transform:scale(1.05)}
.preview-grid span{position:absolute;left:24px;bottom:24px;color:#fff;font-size:44px;font-weight:900;letter-spacing:-.06em}
.video-feature{position:relative;background:#000;min-height:80vh}
.video-feature video{height:80vh;opacity:.72}
.video-feature div{position:absolute;left:36px;bottom:36px;color:#fff;max-width:900px}
.video-feature span,.page-hero span,.services>span,.work-list span{font-size:12px;text-transform:uppercase;letter-spacing:.15em}
.video-feature h1{font-size:clamp(42px,6vw,92px);line-height:.94;letter-spacing:-.075em;margin:18px 0 0}
.page{padding-top:86px}
.page-hero{padding:110px 36px 90px;border-bottom:1px solid #eee}
.page-hero h1{font-size:clamp(54px,8vw,126px);line-height:.88;letter-spacing:-.085em;margin:20px 0 0;max-width:1200px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:44px;padding:36px;border-bottom:1px solid #eee;align-items:center}
.two-col img{height:760px}
.two-col p{font-size:26px;line-height:1.28;margin:0 0 24px}
.services{padding:90px 36px;background:#f3f3f3}
.services div{margin-top:30px;display:grid;grid-template-columns:repeat(4,1fr);border-left:2px solid #000;border-top:2px solid #000}
.services p{min-height:135px;margin:0;padding:18px;display:flex;align-items:end;border-right:2px solid #000;border-bottom:2px solid #000;font-size:25px;font-weight:800;letter-spacing:-.045em}
.artist-cats{display:grid;grid-template-columns:repeat(4,1fr);border-left:2px solid #000;border-top:2px solid #000;margin:36px}
.artist-cats a{min-height:150px;border-right:2px solid #000;border-bottom:2px solid #000;padding:18px;display:flex;align-items:end;font-size:32px;font-weight:900;letter-spacing:-.05em}
.artist-cats a:hover{background:#000;color:#fff}
.talent-grid{padding:0 36px 90px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.talent-grid img{height:520px}
.talent-grid h2{font-size:34px;margin:16px 0 4px;letter-spacing:-.055em}
.talent-grid p{margin:0;text-transform:uppercase;letter-spacing:.12em;font-size:12px}
.work-list{padding:36px}
.work-list article{display:grid;grid-template-columns:1.15fr .85fr;gap:36px;align-items:end;padding:0 0 50px;margin-bottom:50px;border-bottom:1px solid #ddd}
.work-list article:nth-child(even){grid-template-columns:.85fr 1.15fr}
.work-list article:nth-child(even) img{order:2}
.work-list img{height:680px}
.work-list h2{font-size:clamp(44px,6vw,90px);line-height:.9;letter-spacing:-.075em;margin:16px 0}
.work-list p{font-size:22px;line-height:1.28;max-width:520px}
.offices{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:36px 36px 90px}
.office{border-top:2px solid #000;padding-top:22px;min-height:330px}
.office h2{font-size:36px;margin:0 0 18px;letter-spacing:-.055em}
.office p,.office a{font-size:17px;line-height:1.38}
.office>a{border-bottom:1px solid #000}
.social-strip{display:flex;gap:34px;padding:34px 36px;border-top:1px solid #eee;text-transform:uppercase;letter-spacing:.13em;font-size:13px}
.footer{border-top:1px solid #eee;padding:34px 36px;display:flex;justify-content:space-between;align-items:end;text-transform:uppercase;letter-spacing:.13em;font-size:12px}
.footer img{width:92px;height:auto;margin-bottom:16px}
.footer p{margin:0}
.footer-links{display:flex;gap:28px}

@media(max-width:900px){
  .topbar{height:auto;min-height:76px;padding:14px 18px;align-items:flex-start}
  .logo img{width:76px}
  nav{gap:12px;flex-wrap:wrap;justify-content:flex-end;font-size:10px}
  .home-hero{grid-template-columns:1fr;padding-top:76px}
  .home-media img{height:55vh}
  .home-copy{padding:60px 18px}
  .home-copy img{width:min(370px,90%)}
  .statement,.page-hero,.services{padding:70px 18px}
  .preview-grid,.two-col,.services div,.artist-cats,.talent-grid,.work-list article,.work-list article:nth-child(even),.offices{grid-template-columns:1fr}
  .preview-grid a,.preview-grid img{min-height:460px;height:460px}
  .two-col{padding:18px}
  .two-col img,.work-list img{height:500px}
  .artist-cats{margin:18px}
  .talent-grid{padding:0 18px 70px}
  .work-list{padding:18px}
  .work-list article:nth-child(even) img{order:0}
  .offices{padding:18px 18px 70px}
  .footer{padding:26px 18px;display:block}
  .footer-links{margin-top:22px;flex-wrap:wrap;gap:18px}
}
