*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--black:#000;--white:#fff;--red:#E32029;--muted:rgba(255,255,255,.62);--surface:#060606}
html{scroll-behavior:smooth}
html,body,*{cursor:none!important}
body{background:#000;color:#fff;font-family:'Barlow',Helvetica,Arial,sans-serif;overflow-x:hidden}

.pw-cursor{width:10px;height:10px;background:#fff;border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:width .15s,height .15s,background .2s;will-change:left,top}
.pw-cursor.grow{width:36px;height:36px;background:#E32029;opacity:.6}

#pwNav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:32px 60px;transition:background .3s,padding .3s}
#pwNav.scrolled{background:rgba(0,0,0,.95);padding:22px 60px}
.pw-nav-logo{display:flex;align-items:center;flex-shrink:0}
.pw-nav-logo img{height:44px!important;width:auto!important;display:block!important}
.pw-nav-links{display:flex;align-items:center;gap:36px;list-style:none;padding:0;margin:0}
.pw-nav-links li a{color:rgba(255,255,255,.62);text-decoration:none;font-size:14px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:color .2s;display:block}
.pw-nav-links li a:hover,.pw-nav-links li.current-menu-item>a,.pw-nav-links li.current_page_item>a{color:#fff}
.pw-nav-links li ul{display:none}
.pw-nav-cta{background:none;border:1.5px solid rgba(255,255,255,.3);color:#fff;font-family:'Barlow',sans-serif;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:13px 28px;flex-shrink:0;transition:background .2s,color .2s,border-color .2s;white-space:nowrap}
.pw-nav-cta:hover{background:#fff;color:#000;border-color:#fff}
.pw-hamburger{display:none;flex-direction:column;gap:6px;background:none;border:none;padding:4px;z-index:1010;flex-shrink:0}
.pw-hamburger span{width:28px;height:2px;background:#fff;display:block;transition:all .3s}
.pw-hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.pw-hamburger.open span:nth-child(2){opacity:0}
.pw-hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.pw-mob-menu{display:none;position:fixed;inset:0;z-index:900;background:#000;flex-direction:column;align-items:center;justify-content:center}
.pw-mob-menu.open{display:flex}
.pw-mob-menu a{color:#fff;text-decoration:none;font-family:'Barlow Condensed',sans-serif;font-size:clamp(38px,10vw,56px);font-weight:900;text-transform:uppercase;padding:14px 0;line-height:1;border-bottom:1px solid rgba(255,255,255,.08);width:80%;text-align:center;transition:color .2s}
.pw-mob-menu a:hover{color:#E32029}
.pw-mob-menu a.mob-cta{border:none;margin-top:16px;font-size:clamp(16px,4vw,20px);letter-spacing:.2em;color:#E32029;font-family:'Barlow',sans-serif;font-weight:700}

.pw-footer{background:#050505;border-top:1px solid rgba(255,255,255,.07);padding:80px 60px 44px}
.pw-footer-inner{max-width:1200px;margin:0 auto}
.pw-footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.07)}
.pw-footer-tagline{font-size:13px;color:rgba(255,255,255,.5);line-height:1.75;max-width:220px;margin:16px 0 24px}
.pw-footer-social{display:flex;gap:10px}
.pw-footer-social a{width:36px;height:36px;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);text-decoration:none;transition:border-color .2s,color .2s,background .2s}
.pw-footer-social a:hover{border-color:#E32029;color:#fff;background:rgba(227,32,41,.12)}
.pw-footer-col-title{font-size:9px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:18px}
.pw-footer-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.pw-footer-col ul a{color:rgba(255,255,255,.5);text-decoration:none;font-size:13px;transition:color .2s}
.pw-footer-col ul a:hover{color:#fff}
.pw-footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:28px;flex-wrap:wrap;gap:12px}
.pw-footer-copy{font-size:11px;color:rgba(255,255,255,.22);letter-spacing:.04em}
.pw-footer-copy .heart{color:#E32029}
.pw-footer-badge{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.08);padding:5px 12px}

.pw-popup-overlay{display:none;position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.93);align-items:center;justify-content:center;padding:20px}
.pw-popup-overlay.open{display:flex}
.pw-popup-box{max-width:620px;width:100%;background:#0a0a0a;border:1px solid rgba(255,255,255,.1);max-height:92vh;overflow-y:auto}
.pw-popup-head{display:flex;align-items:flex-start;justify-content:space-between;padding:32px 36px 0;gap:16px}
.pw-popup-eyebrow{font-size:9px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:#E32029;margin-bottom:8px}
.pw-popup-title{font-family:'Barlow Condensed',Helvetica,sans-serif;font-weight:900;font-size:clamp(26px,5vw,44px);text-transform:uppercase;line-height:.92;letter-spacing:-.01em}
.pw-popup-title em{font-style:normal;color:#E32029}
.pw-popup-close{background:none;border:1px solid rgba(255,255,255,.15);color:#fff;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:16px;margin-top:4px;transition:border-color .2s,background .2s}
.pw-popup-close:hover{border-color:#E32029;background:rgba(227,32,41,.1);color:#E32029}
.pw-popup-form{padding:22px 36px 36px;display:flex;flex-direction:column;gap:0}
.pw-row{display:grid;grid-template-columns:1fr 1fr;gap:0 24px}
.pw-field{position:relative;border-bottom:1px solid rgba(255,255,255,.12);transition:border-color .2s}
.pw-field.pw-full{grid-column:1/-1}
.pw-field:first-child{border-top:1px solid rgba(255,255,255,.12)}
.pw-field:focus-within{border-color:#E32029}
.pw-field label{display:block;font-size:9px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.28);padding:14px 0 3px;transition:color .2s}
.pw-field:focus-within label{color:#E32029}
.pw-field input,.pw-field select,.pw-field textarea{display:block;width:100%;background:none;border:none;outline:none;font-family:'Barlow',sans-serif;font-size:15px;color:#fff;padding:0 0 14px;caret-color:#E32029}
.pw-field select{-webkit-appearance:none;appearance:none}
.pw-field select option{background:#111}
.pw-field textarea{resize:none;height:76px;padding-top:4px}
.pw-field input::placeholder,.pw-field textarea::placeholder{color:rgba(255,255,255,.18)}
.pw-sel-wrap{position:relative}
.pw-sel-arr{position:absolute;right:0;bottom:18px;pointer-events:none;color:rgba(255,255,255,.3);font-size:11px}
.pw-actions{margin-top:24px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.pw-submit{background:#E32029;color:#fff;font-family:'Barlow',sans-serif;font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:15px 36px;border:none;flex:1;transition:background .2s}
.pw-submit:hover{background:#c41c23}
.pw-note{font-size:11px;color:rgba(255,255,255,.22);line-height:1.6}
.pw-popup-ok{display:none;text-align:center;padding:56px 36px}
.pw-popup-ok.show{display:block}
.pw-ok-icon{width:50px;height:50px;border:1px solid #E32029;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.pw-popup-ok h3{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:900;text-transform:uppercase;margin-bottom:8px}
.pw-popup-ok p{font-size:13px;color:rgba(255,255,255,.5);line-height:1.7}




































@media(max-width:960px){
  #pwNav{padding:22px 24px}
  #pwNav.scrolled{padding:16px 24px}
  .pw-nav-links,.pw-nav-cta{display:none!important}
  .pw-hamburger{display:flex!important}
  .pw-footer{padding:64px 24px 36px}
  .pw-footer-top{grid-template-columns:1fr 1fr;gap:36px 24px}
  
  
  .pw-row{grid-template-columns:1fr}
}
@media(max-width:480px){
  #pwNav{padding:18px 20px}
  .pw-footer{padding:48px 20px 28px}
  .pw-footer-top{grid-template-columns:1fr}
  .pw-footer-bottom{flex-direction:column;align-items:flex-start}
  
}


*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --black: #000000;
  --white: #FFFFFF;
  --red: #E32029;
  --white-muted: rgba(255,255,255,0.62);
  --white-dim: rgba(255,255,255,0.07);
}

html { scroll-behavior: smooth; }

body {
  background: var(--black);
  color: var(--white);
  font-family: 'Barlow', Helvetica, Arial, sans-serif;
  overflow-x: hidden;
}

@media (pointer: fine) {
  body { cursor: none; }
  .cursor {
    width: 10px; height: 10px;
    background: var(--white);
    border-radius: 50%;
    position: fixed; top: 0; left: 0;
    pointer-events: none; z-index: 9999;
    transform: translate(-50%,-50%);
    transition: width 0.15s, height 0.15s, background 0.2s;
  }
  .cursor.grow { width: 36px; height: 36px; background: var(--red); opacity: 0.55; }
}

/* ── NAV ── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: 26px 60px;
  background: rgba(0,0,0,0.0);
  backdrop-filter: none;
  transition: background 0.3s, padding 0.3s;
}
nav.scrolled { background: rgba(0,0,0,0.92); padding: 18px 60px; }

.nav-logo { display: flex; align-items: center; }
.nav-logo img { height: 30px; display: block; width: auto; }

.nav-links { display: flex; gap: 36px; list-style: none; }
.nav-links a {
  color: var(--white-muted); text-decoration: none;
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  transition: color 0.2s;
}
.nav-links a:hover { color: var(--white); }

.nav-cta {
  background: none; border: 1px solid rgba(255,255,255,0.28);
  color: var(--white); font-family: 'Barlow', sans-serif;
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 10px 22px; cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.nav-cta:hover { background: var(--white); color: var(--black); }

/* Hamburger */
.hamburger {
  display: none; flex-direction: column; gap: 5px;
  cursor: pointer; background: none; border: none; padding: 4px; z-index: 210;
}
.hamburger span { width: 26px; height: 2px; background: var(--white); display: block; transition: all 0.3s; }
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu overlay */
.mobile-menu {
  display: none; position: fixed; inset: 0; z-index: 190;
  background: #000;
  flex-direction: column; align-items: center; justify-content: center;
  gap: 0;
}
.mobile-menu.open { display: flex; }
.mobile-menu a {
  color: var(--white); text-decoration: none;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(36px, 10vw, 56px); font-weight: 900;
  text-transform: uppercase; letter-spacing: 0.04em;
  padding: 12px 0; line-height: 1;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  width: 80%; text-align: center;
  transition: color 0.2s;
}
.mobile-menu a:hover, .mobile-menu a:last-child { color: var(--red); }
.mobile-menu a:last-child { border: none; margin-top: 16px; font-size: clamp(16px, 4vw, 20px); letter-spacing: 0.2em; }

/* ── HERO ── */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: 0 60px;
  position: relative; overflow: hidden;
}
.hero-container {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 400px;
  align-items: center;
  gap: 0;
}

.hero-bg-text {
  position: absolute; top: 50%; left: -10px;
  transform: translateY(-50%);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(180px, 24vw, 320px);
  font-weight: 900; color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.035);
  user-select: none; pointer-events: none;
  white-space: nowrap; z-index: 0; line-height: 1;
}

.grid-lines {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 80px 80px;
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 40%, transparent 100%);
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 40%, transparent 100%);
}

/* LEFT */
.hero-left {
  position: relative; z-index: 2;
  padding-top: 100px; padding-bottom: 80px;
}

.tag-cluster { display: flex; gap: 10px; margin-bottom: 44px; flex-wrap: wrap; }
.tag {
  border: 1px solid rgba(255,255,255,0.18);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  padding: 6px 13px; color: var(--white-muted);
}
.tag.red { border-color: var(--red); color: var(--red); }

.headline {
  font-family: 'Barlow Condensed', Helvetica, sans-serif;
  font-weight: 900; line-height: 0.91;
  letter-spacing: -0.01em; text-transform: uppercase;
}
.headline .line1 { font-size: clamp(64px, 8.5vw, 108px); color: var(--white); display: block; }
.headline .line2 { font-size: clamp(82px, 11.5vw, 144px); color: var(--red); display: block; }
.headline .line3 { font-size: clamp(64px, 8.5vw, 108px); color: var(--white); display: block; }

.subtext {
  margin-top: 34px; font-size: 15px; font-weight: 400;
  color: var(--white-muted); max-width: 400px; line-height: 1.7;
}

.cta-row {
  display: flex; gap: 14px; margin-top: 42px; align-items: center; flex-wrap: wrap;
}
.btn-primary {
  background: var(--white); color: var(--black);
  font-family: 'Barlow', sans-serif; font-size: 12px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 16px 34px; border: none; cursor: pointer;
  transition: background 0.2s, color 0.2s;
  display: inline-block; text-decoration: none;
}
.btn-primary:hover { background: var(--red); color: var(--white); }

.btn-secondary {
  background: transparent; color: var(--white);
  font-family: 'Barlow', sans-serif; font-size: 12px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 15px 34px; border: 1px solid rgba(255,255,255,0.3); cursor: pointer;
  transition: border-color 0.2s, background 0.2s, color 0.2s;
  display: inline-block; text-decoration: none;
}
.btn-secondary:hover { border-color: var(--white); background: transparent; }

.stats-row {
  display: flex; gap: 44px; margin-top: 60px;
  padding-top: 36px; border-top: 1px solid rgba(255,255,255,0.1);
  flex-wrap: wrap;
}
.stat-num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 42px; font-weight: 400; color: var(--white); line-height: 1;
}
.stat-num span { color: var(--red); }
.stat-label {
  font-size: 10px; font-weight: 600; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--white-muted); margin-top: 5px;
}

/* RIGHT VISUAL */
.hero-right {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: center;
  height: 100vh;
}

.visual-frame {
  position: relative; width: 340px; height: 440px;
}
.visual-frame::before {
  content: ''; position: absolute; inset: 0;
  border: 1px solid rgba(255,255,255,0.08);
}
.visual-frame::after {
  content: ''; position: absolute;
  top: 14px; left: 14px; right: -14px; bottom: -14px;
  border: 1px solid rgba(227,32,41,0.22);
  pointer-events: none;
}

.float-tag {
  position: absolute; font-size: 9px; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--white-muted); border: 1px solid rgba(255,255,255,0.14);
  padding: 6px 12px; white-space: nowrap; background: rgba(0,0,0,0.85);
}
.float-tag.top-right { top: -18px; right: -28px; }
.float-tag.mid-left  { left: -86px; top: 50%; transform: translateY(-50%); }
.float-tag.bottom    { bottom: -22px; right: 18px; color: var(--red); border-color: rgba(227,32,41,0.28); }

/* SCROLL INDICATOR */
.scroll-indicator {
  position: absolute; bottom: 38px; left: 60px;
  display: flex; align-items: center; gap: 12px; z-index: 3;
}
.scroll-line { width: 38px; height: 1px; background: rgba(255,255,255,0.25); }
.scroll-text {
  font-size: 9px; font-weight: 700; letter-spacing: 0.28em;
  text-transform: uppercase; color: var(--white-muted);
}

/* TICKER */
.ticker-wrap {
  overflow: hidden; background: var(--red); padding: 13px 0;
  white-space: nowrap; position: relative; z-index: 3;
}
.ticker-track {
  display: inline-flex;
  animation: ticker 32s linear infinite;
}
.ticker-track span {
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--white); padding: 0 28px;
}
.ticker-track span.dot {
  color: rgba(255,255,255,0.45); padding: 0 5px;
  letter-spacing: 0; font-size: 16px;
}
@keyframes ticker {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ══════════════════════════════
   MOBILE RESPONSIVE
══════════════════════════════ */
@media (max-width: 960px) {
  nav { padding: 20px 24px; }
  nav.scrolled { padding: 16px 24px; }
  .nav-links, .nav-cta { display: none; }
  .hamburger { display: flex; }

  .hero {
    padding: 90px 24px 60px;
    min-height: 100svh;
    align-items: flex-start;
  }
  .hero-container { grid-template-columns: 1fr; }
  .hero-container {
    grid-template-columns: 1fr;
  }
  .hero-right { display: none; }
  .hero-bg-text { font-size: clamp(120px, 32vw, 200px); }

  .headline .line1 { font-size: clamp(54px, 16vw, 80px); }
  .headline .line2 { font-size: clamp(72px, 21vw, 104px); }
  .headline .line3 { font-size: clamp(54px, 16vw, 80px); }

  .subtext { font-size: 15px; max-width: 100%; }

  .cta-row { flex-direction: column; gap: 12px; }
  .btn-primary, .btn-secondary {
    width: 100%; text-align: center; padding: 18px 24px;
    font-size: 13px;
  }

  .stats-row { gap: 32px; }
  .stat-num { font-size: 36px; font-weight: 400; }

  .scroll-indicator { display: none; }
  .tag-cluster { margin-bottom: 32px; }
  .hero-left { padding-top: 20px; padding-bottom: 40px; }
}

@media (max-width: 480px) {
  nav { padding: 18px 20px; }
  .nav-logo img { height: 24px; }
  .hero { padding: 80px 20px 50px; }
  .hero-container { grid-template-columns: 1fr; }
  .hero-container { grid-template-columns: 1fr; }
  .headline .line1 { font-size: clamp(46px, 18vw, 64px); }
  .headline .line2 { font-size: clamp(60px, 23vw, 88px); }
  .headline .line3 { font-size: clamp(46px, 18vw, 64px); }
  .stats-row { gap: 24px; }
  .tag { font-size: 9px; padding: 5px 10px; }
}

/* ── SECTION 2: WHY PHOTOWANT ── */
.section-why {
  background: var(--black);
  padding: 120px 60px;
  position: relative;
  overflow: hidden;
}

.section-why .grid-lines {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
  background-size: 80px 80px;
}

.why-inner {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

/* Section label */
.section-label {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 60px;
}
.section-label-line {
  width: 40px; height: 1px;
  background: var(--red);
}
.section-label-text {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--red);
}

/* Section heading */
.why-heading {
  font-family: 'Barlow Condensed', Helvetica, sans-serif;
  font-weight: 900; font-size: clamp(48px, 6vw, 82px);
  text-transform: uppercase; line-height: 0.93;
  letter-spacing: -0.01em;
  max-width: 700px;
  margin-bottom: 80px;
}
.why-heading em {
  font-style: normal;
  color: var(--red);
}

/* Two-column layout */
.why-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

/* Left: numbered list */
.why-list { }

.why-item {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 0 24px;
  padding: 32px 0;
  border-top: 1px solid rgba(255,255,255,0.08);
  transition: border-color 0.2s;
  cursor: default;
}
.why-item:last-child { border-bottom: 1px solid rgba(255,255,255,0.08); }
.why-item:hover { border-top-color: rgba(227,32,41,0.3); }
.why-item:hover .why-num { color: var(--red); }

.why-num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 400;
  color: rgba(255,255,255,0.22);
  letter-spacing: 0.08em;
  padding-top: 4px;
  transition: color 0.2s;
}

.why-content {}
.why-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 22px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: 10px; line-height: 1.1;
}
.why-desc {
  font-size: 14px; font-weight: 400;
  color: var(--white-muted); line-height: 1.7;
  max-width: 380px;
}

/* Right: visual panel */
.why-right {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  padding-left: 60px;
  padding-top: 8px;
}

.why-panel {
  position: relative;
  width: 100%;
  max-width: 420px;
}

/* Large decorative number */
.why-panel-number {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(160px, 18vw, 240px);
  font-weight: 900; color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.05);
  line-height: 1; user-select: none;
  margin-bottom: -30px;
}

.why-card-stack {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.why-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  padding: 28px 30px;
  position: relative;
  transition: background 0.2s, border-color 0.2s;
}
.why-card:hover { background: rgba(227,32,41,0.06); border-color: rgba(227,32,41,0.2); }

.why-card-icon {
  width: 36px; height: 36px;
  margin-bottom: 16px;
}

.why-card-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em;
  margin-bottom: 8px;
}
.why-card-text {
  font-size: 13px; font-weight: 400;
  color: var(--white-muted); line-height: 1.65;
}
.why-card-arrow {
  position: absolute; top: 28px; right: 28px;
  font-size: 18px; color: rgba(255,255,255,0.15);
  transition: color 0.2s, transform 0.2s;
}
.why-card:hover .why-card-arrow { color: var(--red); transform: translate(3px,-3px); }

/* Bottom CTA strip */
.why-cta-strip {
  margin-top: 80px;
  padding-top: 48px;
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.why-cta-text {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(28px, 3.5vw, 44px); font-weight: 900;
  text-transform: uppercase; letter-spacing: -0.01em;
  line-height: 1.05;
}
.why-cta-text em { font-style: normal; color: var(--red); }

/* Mobile section-why */
@media (max-width: 960px) {
  .section-why { padding: 80px 24px; }
  .why-grid { grid-template-columns: 1fr; }
  .why-right { padding-left: 0; padding-top: 48px; justify-content: flex-start; }
  .why-panel { max-width: 100%; }
  .why-panel-number { font-size: clamp(100px, 26vw, 160px); }
  .why-cta-strip { flex-direction: column; align-items: flex-start; gap: 20px; }
  .why-heading { margin-bottom: 48px; }
}
@media (max-width: 480px) {
  .section-why { padding: 64px 20px; }
  .why-item { grid-template-columns: 44px 1fr; gap: 0 16px; padding: 24px 0; }
  .why-title { font-size: 19px; }
}


/* ══════════════════════════════
   SECTION 3: SERVICES
══════════════════════════════ */
.section-services {
  background: #080808;
  padding: 120px 60px;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(255,255,255,0.06);
}

.services-inner {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

/* Header row */
.services-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 40px;
  margin-bottom: 72px;
  flex-wrap: wrap;
}

.services-heading {
  font-family: 'Barlow Condensed', Helvetica, sans-serif;
  font-weight: 900;
  font-size: clamp(46px, 6vw, 80px);
  text-transform: uppercase;
  line-height: 0.92;
  letter-spacing: -0.01em;
}
.services-heading em { font-style: normal; color: var(--red); }

.services-sub {
  max-width: 280px;
  font-size: 14px;
  font-weight: 400;
  color: var(--white-muted);
  line-height: 1.7;
  text-align: right;
}

/* Services accordion list */
.services-list { border-top: 1px solid rgba(255,255,255,0.1); }

.service-row {
  display: grid;
  grid-template-columns: 60px 1fr auto 160px;
  align-items: center;
  gap: 0 32px;
  padding: 28px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  cursor: pointer;
  transition: background 0.2s;
  position: relative;
}
.service-row::before {
  content: '';
  position: absolute;
  left: -60px; right: -60px; top: 0; bottom: 0;
  background: rgba(227,32,41,0.04);
  opacity: 0;
  transition: opacity 0.2s;
  pointer-events: none;
}
.service-row:hover::before { opacity: 1; }
.service-row:hover .service-num { color: var(--red); }
.service-row:hover .service-arrow { color: var(--red); transform: translate(4px,-4px); }
.service-row:hover .service-name { color: var(--white); }

.service-num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px; font-weight: 400;
  color: rgba(255,255,255,0.2);
  letter-spacing: 0.1em;
  transition: color 0.2s;
}

.service-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(22px, 3vw, 36px);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.85);
  transition: color 0.2s;
}

.service-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
}
.service-tag {
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  border: 1px solid rgba(255,255,255,0.12);
  padding: 4px 10px;
  color: rgba(255,255,255,0.35);
  white-space: nowrap;
}

.service-arrow {
  font-size: 20px;
  color: rgba(255,255,255,0.18);
  text-align: right;
  transition: color 0.2s, transform 0.2s;
}

/* Expandable detail panel */
.service-detail {
  display: none;
  grid-column: 1 / -1;
  padding: 0 0 28px 92px;
}
.service-detail.open { display: block; }
.service-detail p {
  font-size: 14px; font-weight: 400;
  color: var(--white-muted); line-height: 1.75;
  max-width: 560px;
}
.service-detail-chips {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px;
}
.service-chip {
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  background: rgba(227,32,41,0.1);
  border: 1px solid rgba(227,32,41,0.2);
  color: var(--red);
  padding: 5px 12px;
}

/* Big marquee number behind list */
.services-bg-num {
  position: absolute;
  right: -20px; top: 50%;
  transform: translateY(-50%);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(200px, 28vw, 360px);
  font-weight: 900; color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.03);
  user-select: none; pointer-events: none;
  line-height: 1; z-index: 0;
}

/* Mobile */
@media (max-width: 960px) {
  .section-services { padding: 80px 24px; }
  .services-header { flex-direction: column; align-items: flex-start; gap: 20px; }
  .services-sub { text-align: left; max-width: 100%; }
  .service-row { grid-template-columns: 44px 1fr 36px; gap: 0 16px; }
  .service-tags { display: none; }
  .service-detail { padding-left: 60px; }
  .services-bg-num { display: none; }
}
@media (max-width: 480px) {
  .section-services { padding: 60px 20px; }
  .service-row { grid-template-columns: 36px 1fr 30px; gap: 0 12px; padding: 22px 0; }
  .service-name { font-size: clamp(18px, 6vw, 26px); }
  .service-detail { padding-left: 48px; }
}


/* ══════════════════════════════
   SECTION 4: CONTACT FORM
══════════════════════════════ */




.contact-heading-centered {
  font-family: 'Barlow Condensed', Helvetica, sans-serif;
  font-weight: 900;
  font-size: clamp(52px, 8vw, 110px);
  text-transform: uppercase;
  line-height: 0.9;
  letter-spacing: -0.01em;
  margin-top: 32px;
  margin-bottom: 20px;
}
.contact-heading-centered em { font-style: normal; color: var(--red); }

.contact-desc-centered {
  font-size: 15px;
  font-weight: 400;
  color: var(--white-muted);
  line-height: 1.75;
  margin-bottom: 52px;
}



/* Right: Form */
.contact-right {}













/* Submit */














/* Form success state */






/* Decorative bg text */
.contact-bg-text {
  position: absolute;
  bottom: -40px; right: -20px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(140px, 20vw, 260px);
  font-weight: 900; color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.028);
  user-select: none; pointer-events: none;
  line-height: 1; z-index: 0;
}

/* Mobile */
@media (max-width: 960px) {
  
  
  .contact-bg-text { display: none; }
  
  
}
@media (max-width: 480px) {
  
  
  
}


/* ══════════════════════════════
   SECTION 5: FOOTER
══════════════════════════════ */
.site-footer {
  background: #050505;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: 64px 60px 40px;
}
.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
}
.footer-top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.footer-brand {}
.footer-logo { margin-bottom: 20px; }
.footer-logo img { height: 26px; width: auto; display: block; }
.footer-tagline {
  font-size: 13px; font-weight: 400;
  color: var(--white-muted); line-height: 1.7;
  max-width: 240px; margin-bottom: 28px;
}
.footer-social {
  display: flex; gap: 12px;
}
.footer-social a {
  width: 34px; height: 34px;
  border: 1px solid rgba(255,255,255,0.12);
  display: flex; align-items: center; justify-content: center;
  color: var(--white-muted);
  text-decoration: none; font-size: 13px;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.footer-social a:hover { border-color: var(--red); color: var(--white); background: rgba(227,32,41,0.1); }

.footer-col-title {
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: rgba(255,255,255,0.25);
  margin-bottom: 20px;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-col ul a {
  color: var(--white-muted); text-decoration: none;
  font-size: 13px; font-weight: 400;
  transition: color 0.2s;
}
.footer-col ul a:hover { color: var(--white); }

.footer-bottom {
  display: flex; align-items: center;
  justify-content: space-between;
  padding-top: 28px;
  flex-wrap: wrap; gap: 12px;
}
.footer-copy {
  font-size: 11px; font-weight: 400;
  color: rgba(255,255,255,0.22);
  letter-spacing: 0.04em;
}
.footer-copy span { color: var(--red); }
.footer-badge {
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(255,255,255,0.18);
  border: 1px solid rgba(255,255,255,0.08);
  padding: 5px 12px;
}

@media (max-width: 960px) {
  .site-footer { padding: 56px 24px 32px; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 36px 24px; }
}
@media (max-width: 480px) {
  .site-footer { padding: 48px 20px 28px; }
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}


/* ══════════════════════════════
   SECTION: OUR WORK
══════════════════════════════ */
.section-work {
  background: #060606;
  padding: 120px 60px;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.work-inner {
  max-width: 1400px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

/* Header */
.work-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 32px;
  margin-bottom: 56px;
  flex-wrap: wrap;
}
.work-heading {
  font-family: 'Barlow Condensed', Helvetica, sans-serif;
  font-weight: 900;
  font-size: clamp(48px, 6.5vw, 88px);
  text-transform: uppercase;
  line-height: 0.91;
  letter-spacing: -0.01em;
}
.work-heading em { font-style: normal; color: var(--red); }

.work-header-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 20px;
}
.work-sub {
  font-size: 14px; font-weight: 400;
  color: var(--white-muted); line-height: 1.7;
  text-align: right; max-width: 280px;
}

/* Filter tabs */
.work-filters {
  display: flex; gap: 0;
  border: 1px solid rgba(255,255,255,0.1);
  flex-wrap: wrap;
}
.work-filter {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.38);
  padding: 9px 18px;
  cursor: pointer;
  border-right: 1px solid rgba(255,255,255,0.1);
  transition: color 0.2s, background 0.2s;
  background: none; border-top: none; border-bottom: none; border-left: none;
  border-right: 1px solid rgba(255,255,255,0.1);
  font-family: 'Barlow', sans-serif;
}
.work-filter:last-child { border-right: none; }
.work-filter.active,
.work-filter:hover { color: var(--white); background: rgba(255,255,255,0.05); }
.work-filter.active { color: var(--red); background: rgba(227,32,41,0.07); }

/* ── MASONRY GRID ── */
.work-grid {
  columns: 3;
  column-gap: 12px;
  gap: 12px;
}

.work-item {
  break-inside: avoid;
  margin-bottom: 12px;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  display: block;
}

/* Hide/show by filter */
.work-item[data-type] { transition: opacity 0.3s, transform 0.3s; }
.work-item.hidden { display: none; }

/* Placeholder media blocks */
.work-thumb {
  width: 100%;
  display: block;
  background: #111;
  position: relative;
  overflow: hidden;
}

/* Landscape video: 16:9 */
.work-thumb.ratio-landscape { aspect-ratio: 16/9; }
/* Portrait video: 9:16 */
.work-thumb.ratio-portrait  { aspect-ratio: 9/16; }
/* Square photo */
.work-thumb.ratio-square    { aspect-ratio: 1/1; }
/* Tall photo */
.work-thumb.ratio-tall      { aspect-ratio: 3/4; }
/* Poster: A4-ish */
.work-thumb.ratio-poster    { aspect-ratio: 2/3; }
/* Wide photo */
.work-thumb.ratio-wide      { aspect-ratio: 4/3; }

/* Geometric placeholder art */
.work-thumb-art {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
}

/* Overlay on hover */
.work-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.72);
  opacity: 0;
  transition: opacity 0.28s;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  padding: 20px;
  gap: 6px;
}
.work-item:hover .work-overlay { opacity: 1; }
.work-item:hover .work-thumb-art { transform: scale(1.04); transition: transform 0.5s ease; }

.work-overlay-tag {
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--red);
  border: 1px solid rgba(227,32,41,0.4);
  padding: 3px 9px;
}
.work-overlay-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 18px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.04em;
  color: var(--white);
}
.work-overlay-arrow {
  position: absolute; top: 16px; right: 16px;
  width: 32px; height: 32px;
  border: 1px solid rgba(255,255,255,0.3);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; color: var(--white);
}

/* Play icon for video */
.play-icon {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
}
.play-icon svg {
  width: 44px; height: 44px;
  opacity: 0.5;
  transition: opacity 0.2s, transform 0.2s;
}
.work-item:hover .play-icon svg { opacity: 1; transform: scale(1.15); }

/* Video type badge */
.type-badge {
  position: absolute; top: 12px; left: 12px;
  font-size: 8px; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  background: rgba(0,0,0,0.7);
  border: 1px solid rgba(255,255,255,0.15);
  color: var(--white-muted);
  padding: 3px 8px;
  z-index: 3;
}
.type-badge.red-badge {
  background: rgba(227,32,41,0.2);
  border-color: rgba(227,32,41,0.4);
  color: var(--red);
}

/* CTA row below grid */
.work-cta {
  margin-top: 56px;
  text-align: center;
}
.work-count {
  font-size: 11px; font-weight: 400;
  color: rgba(255,255,255,0.28);
  letter-spacing: 0.1em;
  margin-bottom: 24px;
}
.work-count span { color: var(--white); font-weight: 700; }

/* Mobile */
@media (max-width: 960px) {
  .section-work { padding: 80px 24px; }
  .work-grid { columns: 2; }
  .work-header { flex-direction: column; align-items: flex-start; }
  .work-header-right { align-items: flex-start; }
  .work-sub { text-align: left; }
}
@media (max-width: 560px) {
  .section-work { padding: 64px 20px; }
  .work-grid { columns: 1; }
  .work-filters { width: 100%; overflow-x: auto; flex-wrap: nowrap; }
}


/* ══════════════════════════════
   SECTION: OUR WORK
══════════════════════════════ */
.section-work {
  background: #060606;
  padding: 120px 60px;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(255,255,255,0.06);
}

.work-inner {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

/* Header */
.work-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 32px;
  margin-bottom: 56px;
  flex-wrap: wrap;
}
.work-heading {
  font-family: 'Barlow Condensed', Helvetica, sans-serif;
  font-weight: 900;
  font-size: clamp(46px, 6vw, 80px);
  text-transform: uppercase;
  line-height: 0.92;
  letter-spacing: -0.01em;
}
.work-heading em { font-style: normal; color: var(--red); }
.work-header-right {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

/* Filter tabs */
.work-filters {
  display: flex;
  gap: 2px;
  flex-wrap: wrap;
}
.work-filter {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 9px 18px;
  border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.4);
  cursor: pointer;
  background: none;
  font-family: 'Barlow', sans-serif;
  transition: all 0.2s;
}
.work-filter:hover { border-color: rgba(255,255,255,0.3); color: var(--white); }
.work-filter.active { background: var(--red); border-color: var(--red); color: var(--white); }

/* Masonry-style grid */
.work-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 80px;
  gap: 6px;
}

/* Grid item base */
.work-item {
  position: relative;
  overflow: hidden;
  background: #111;
  cursor: pointer;
}
.work-item[data-hidden="true"] { display: none; }

/* Span presets */
.work-item.span-wide       { grid-column: span 8; grid-row: span 4; }
.work-item.span-tall       { grid-column: span 4; grid-row: span 5; }
.work-item.span-square     { grid-column: span 4; grid-row: span 4; }
.work-item.span-landscape  { grid-column: span 8; grid-row: span 3; }
.work-item.span-portrait   { grid-column: span 3; grid-row: span 5; }
.work-item.span-small      { grid-column: span 4; grid-row: span 3; }
.work-item.span-banner     { grid-column: span 12; grid-row: span 2; }
.work-item.span-third      { grid-column: span 4; grid-row: span 3; }

/* Inner visual */
.work-item-visual {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  position: relative;
  overflow: hidden;
}

/* Placeholder SVG visuals */
.work-placeholder {
  width: 100%; height: 100%;
  display: block;
}

/* Overlay on hover */
.work-item-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.7);
  display: flex; flex-direction: column;
  align-items: flex-start; justify-content: flex-end;
  padding: 20px;
  opacity: 0;
  transition: opacity 0.25s;
}
.work-item:hover .work-item-overlay { opacity: 1; }

.work-item-label {
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--red);
  margin-bottom: 6px;
}
.work-item-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(15px, 2vw, 20px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--white);
  line-height: 1.1;
}

/* Video badge */
.work-video-badge {
  position: absolute;
  top: 14px; left: 14px;
  background: rgba(227,32,41,0.9);
  padding: 4px 10px;
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--white);
  display: flex; align-items: center; gap: 6px;
  z-index: 2;
}
.work-video-badge svg { width: 8px; height: 8px; }

/* Play icon for video items */
.work-play-icon {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 48px; height: 48px;
  border: 1px solid rgba(255,255,255,0.35);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  opacity: 0.6;
  transition: opacity 0.2s, transform 0.2s;
  pointer-events: none;
  z-index: 2;
}
.work-item:hover .work-play-icon { opacity: 1; transform: translate(-50%,-50%) scale(1.08); }

/* Upload CTA item */
.work-item-upload {
  border: 1px dashed rgba(255,255,255,0.1);
  background: transparent;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 10px;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
}
.work-item-upload:hover { border-color: rgba(227,32,41,0.4); background: rgba(227,32,41,0.03); }
.work-item-upload span {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(255,255,255,0.25);
}
.work-item-upload svg { opacity: 0.25; transition: opacity 0.2s; }
.work-item-upload:hover svg,
.work-item-upload:hover span { opacity: 0.7; color: var(--red); }

/* View all CTA */
.work-cta {
  margin-top: 44px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 20px;
  padding-top: 36px;
  border-top: 1px solid rgba(255,255,255,0.07);
}
.work-cta-text {
  font-size: 13px; font-weight: 400;
  color: var(--white-muted);
}
.work-cta-text strong {
  color: var(--white);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 18px; font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Lightbox */
.lightbox {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.95);
  z-index: 9000;
  align-items: center;
  justify-content: center;
}
.lightbox.open { display: flex; }
.lightbox-content {
  max-width: 90vw;
  max-height: 90vh;
  position: relative;
}
.lightbox-content svg, .lightbox-content img {
  max-width: 90vw;
  max-height: 80vh;
  display: block;
}
.lightbox-close {
  position: absolute;
  top: -44px; right: 0;
  background: none; border: none;
  color: var(--white); font-size: 28px;
  cursor: pointer; opacity: 0.7;
  line-height: 1; padding: 0;
}
.lightbox-close:hover { opacity: 1; color: var(--red); }
.lightbox-meta {
  margin-top: 16px;
}
.lightbox-meta .work-item-label { opacity: 1; }
.lightbox-meta .work-item-title { font-size: 22px; }

/* Mobile */
@media (max-width: 960px) {
  .section-work { padding: 80px 24px; }
  .work-grid {
    grid-template-columns: repeat(6, 1fr);
    grid-auto-rows: 70px;
  }
  .work-item.span-wide      { grid-column: span 6; grid-row: span 4; }
  .work-item.span-tall      { grid-column: span 3; grid-row: span 5; }
  .work-item.span-square    { grid-column: span 3; grid-row: span 4; }
  .work-item.span-landscape { grid-column: span 6; grid-row: span 3; }
  .work-item.span-portrait  { grid-column: span 3; grid-row: span 5; }
  .work-item.span-small     { grid-column: span 3; grid-row: span 3; }
  .work-item.span-banner    { grid-column: span 6; grid-row: span 2; }
  .work-item.span-third     { grid-column: span 3; grid-row: span 3; }
  .work-header { flex-direction: column; align-items: flex-start; gap: 24px; }
}
@media (max-width: 480px) {
  .section-work { padding: 60px 20px; }
  .work-grid {
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 64px;
  }
  .work-item.span-wide, .work-item.span-landscape, .work-item.span-banner { grid-column: span 4; }
  .work-item.span-tall, .work-item.span-square, .work-item.span-portrait, .work-item.span-small, .work-item.span-third { grid-column: span 2; }
  .work-filters { gap: 4px; }
}


/* ══════════════════════════════
   SECTION: CLIENTS
══════════════════════════════ */
.section-clients {
  background: #040404;
  padding: 96px 60px;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.clients-inner {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.clients-header {
  text-align: center;
  margin-bottom: 56px;
}
.clients-eyebrow {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: rgba(255,255,255,0.25);
  margin-bottom: 12px;
}
.clients-heading {
  font-family: 'Barlow Condensed', Helvetica, sans-serif;
  font-weight: 900;
  font-size: clamp(36px, 5vw, 64px);
  text-transform: uppercase;
  line-height: 0.92;
  letter-spacing: -0.01em;
}
.clients-heading em { font-style: normal; color: var(--red); }

/* Logo grid */
.clients-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.06);
  margin-bottom: 48px;
}
.client-cell {
  background: #040404;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 36px 28px;
  position: relative;
  transition: background 0.25s;
  cursor: default;
}
.client-cell:hover { background: rgba(255,255,255,0.03); }
.client-cell:hover .client-logo-mark { opacity: 1; }
.client-cell:hover .client-logo-name { color: var(--white); }

/* Logo SVG mock */
.client-logo-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  opacity: 0.35;
  transition: opacity 0.25s;
}
.client-cell:hover .client-logo-wrap { opacity: 0.75; }

.client-logo-mark { transition: opacity 0.25s; }
.client-logo-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  transition: color 0.25s;
  white-space: nowrap;
}

/* Stat strip below grid */
.clients-stat-strip {
  display: flex;
  justify-content: center;
  gap: 0;
  border: 1px solid rgba(255,255,255,0.07);
}
.clients-stat {
  flex: 1;
  text-align: center;
  padding: 28px 20px;
  border-right: 1px solid rgba(255,255,255,0.07);
}
.clients-stat:last-child { border-right: none; }
.clients-stat-num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 36px; font-weight: 400;
  color: var(--white); line-height: 1;
}
.clients-stat-num span { color: var(--red); }
.clients-stat-label {
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(255,255,255,0.25);
  margin-top: 6px;
}

@media (max-width: 960px) {
  .section-clients { padding: 72px 24px; }
  .clients-grid { grid-template-columns: repeat(3, 1fr); }
  .clients-stat-strip { flex-wrap: wrap; }
  .clients-stat { min-width: 33%; }
}
@media (max-width: 480px) {
  .section-clients { padding: 56px 20px; }
  .clients-grid { grid-template-columns: repeat(2, 1fr); }
  .clients-stat { min-width: 50%; }
  .client-cell { padding: 28px 16px; }
}