
/* ══════════════════════════════════════════════
   BRAND TOKENS
══════════════════════════════════════════════ */
:root {
  --red:      #D21F27;
  --red-glow: rgba(210,31,39,0.18);
  --red-dim:  rgba(210,31,39,0.08);
  --charcoal: #252626;
  --black:    #070707;
  --white:    #ffffff;
  --t1: rgba(255,255,255,0.97);
  --t2: rgba(255,255,255,0.86);
  --t3: rgba(255,255,255,0.65);
  --surface:  #111111;
  --surface2: #181818;
  --border:   rgba(255,255,255,0.06);
  --font:    'Poppins', sans-serif;
  --display: 'Bebas Neue', sans-serif;
  --ease:    cubic-bezier(0.22, 1, 0.36, 1);
  --snap:    cubic-bezier(0.34, 1.56, 0.64, 1);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--black);
  color: var(--t1);
  font-family: var(--font);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration: none; color: inherit; }

::-webkit-scrollbar { width: 2px; }
::-webkit-scrollbar-track { background: var(--black); }
::-webkit-scrollbar-thumb { background: var(--red); }

/* grain */
body::before {
  content: '';
  position: fixed; inset: 0;
  pointer-events: none; z-index: 1000; opacity: 0.022;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  background-repeat: repeat; background-size: 128px 128px;
}


/* ── PAGE TRANSITION OVERLAY ─────────────────── */
#page-transition {
  position: fixed; inset: 0; z-index: 2000;
  background: var(--black);
  transform: scaleX(0); transform-origin: left;
  pointer-events: none;
}
#page-transition.entering { animation: wipe-in .45s var(--ease) forwards; }
#page-transition.leaving  { animation: wipe-out .45s var(--ease) forwards; transform-origin: right; }
@keyframes wipe-in  { from{transform:scaleX(0)} to{transform:scaleX(1)} }
@keyframes wipe-out { from{transform:scaleX(1)} to{transform:scaleX(0)} }

/* ── TRANSITION LOGO ─────────────────────────── */
#pt-logo {
  position: fixed; inset: 0; z-index: 2001;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none; opacity: 0;
}
#pt-logo img { width: 80px; height: 80px; display: block; }
#pt-logo.pt-show { animation: pt-in .28s var(--ease) forwards; }
#pt-logo.pt-hide { animation: pt-out .22s var(--ease) forwards; }
@keyframes pt-in  { from{opacity:0; transform:scale(.72)} to{opacity:1; transform:scale(1)} }
@keyframes pt-out { from{opacity:1; transform:scale(1)}   to{opacity:0; transform:scale(1.18)} }

/* ── PAGE LOADER ─────────────────────────────── */
#page-loader {
  position: fixed; inset: 0; z-index: 3000;
  pointer-events: all;
}
.loader-panel {
  position: absolute; top: 0; bottom: 0; width: 50%;
  background: var(--black);
}
.loader-panel-left  { left: 0;  border-right: 1px solid rgba(210,31,39,.25); }
.loader-panel-right { right: 0; border-left:  1px solid rgba(210,31,39,.25); }
.loader-logo-wrap {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  z-index: 1; opacity: 0;
}
.loader-logo-wrap img { width: 100px; height: 100px; display: block; }

/* logo appears */
#page-loader.ldr-show .loader-logo-wrap {
  animation: ldr-logo-in .5s .2s var(--ease) forwards;
}
/* curtains open */
#page-loader.ldr-out .loader-panel-left  { animation: ldr-curtain-left  .6s var(--ease) forwards; }
#page-loader.ldr-out .loader-panel-right { animation: ldr-curtain-right .6s var(--ease) forwards; }
#page-loader.ldr-out .loader-logo-wrap   { animation: ldr-logo-out .35s var(--ease) forwards; }

@keyframes ldr-logo-in       { from{opacity:0; transform:scale(.65)} to{opacity:1; transform:scale(1)} }
@keyframes ldr-logo-out      { from{opacity:1; transform:scale(1)}   to{opacity:0; transform:scale(1.22)} }
@keyframes ldr-curtain-left  { from{transform:translateX(0)}         to{transform:translateX(-100%)} }
@keyframes ldr-curtain-right { from{transform:translateX(0)}         to{transform:translateX(100%)} }

/* ── PAGE SYSTEM ─────────────────────────────── */
.page { display: none; min-height: 100vh; padding-top: 62px; }
.page.active { display: block; animation: page-appear .5s var(--ease) both; }
@keyframes page-appear { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:none} }

/* ── NAV ─────────────────────────────────────── */
.nav {
  position: fixed; top:0; left:0; right:0; z-index:500;
  height:62px; display:flex; align-items:center; justify-content:space-between;
  padding:0 52px;
  background: rgba(7,7,7,.9);
  backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border);
  transition: background .4s;
}
.nav.scrolled { background: rgba(7,7,7,.98); }

.nav-logo {
  display:flex; align-items:center; gap:10px;
  font-size:15px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  cursor: none;
  background:none; /* ensure no default button fill */
}

/* remove grey/white tap/click highlights on all buttons and strip native outline/background */
button {
  -webkit-tap-highlight-color: transparent;
  background: none;
  border: none;
  outline: none;
}
button:focus {
  outline: none;
}


/* logo image styling (height may be adjusted to fit) */
.nav-logo-img {
  height:32px; /* larger so logo appears bigger in nav */
  display:block;
  pointer-events:none;
}

/* adjust nav layout spacing in case logo size increased */
.nav-logo { gap:12px; }

.nav-logo:hover { color: var(--t1); }
.slash-mark { display:flex; gap:3px; align-items:center; }
.slash-mark span { display:block; width:5px; height:22px; transform:skewX(-12deg); border-radius:1px; }
.slash-mark span:nth-child(1) { background:var(--red); }
.slash-mark span:nth-child(2) { background:rgba(255,255,255,.25); }
.nav-logo .sep { color:var(--red); font-weight:300; margin-left:2px; }

.nav-verbs { display:flex; align-items:center; gap:2px; }
.nav-verb {
  position:relative; font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:var(--t2); padding:8px 18px; background:transparent; border:none; cursor:pointer;
  font-family:var(--font); transition:color .2s;
}
.nav-verb::after {
  content:''; position:absolute; bottom:4px; left:18px; right:18px; height:1px;
  background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .25s var(--ease);
}
.nav-verb:hover, .nav-verb.active { color:var(--t1); }
.nav-verb.active::after, .nav-verb:hover::after { transform:scaleX(1); }

/* MORE dropdown */
.nav-more-wrap { position:relative; }
.nav-more-btn {
  font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:var(--t2); padding:8px 18px; background:transparent; border:none; cursor:pointer;
  font-family:var(--font); transition:color .2s; display:flex; align-items:center; gap:6px;
}
.nav-more-btn:hover { color:var(--t1); }
.nav-more-btn .caret { font-size:8px; transition:transform .2s; }
.nav-more-wrap:hover .caret { transform: rotate(180deg); }
.nav-dropdown {
  position:absolute; top:100%; left:50%; /* centre below parent */
  background:rgba(10,10,10,.97); border:1px solid var(--border);
  min-width:160px; opacity:0; pointer-events:none;
  transform:translate(-50%, -6px); transition:opacity .2s, transform .2s var(--ease);
  backdrop-filter: blur(12px);
  z-index:501; /* rise above any logo/image overlaps */
}
.nav-more-wrap:hover .nav-dropdown { opacity:1; pointer-events:all; transform:none; }
.nav-drop-item {
  display:block; padding:13px 20px;
  font-size:11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  color:var(--t2); border-bottom:1px solid var(--border); cursor:pointer;
  transition:color .15s, background .15s;
}
.nav-drop-item:last-child { border:none; }
.nav-drop-item:hover { color:var(--t1); background:rgba(210,31,39,.06); }

.nav-cta {
  background:var(--red); color:#fff; font-family:var(--font);
  font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  padding:11px 24px; border:none; cursor:pointer; margin-left:12px;
  transition:background .2s,transform .2s var(--snap);
}

.nav-cta:hover { background:#b81c23; transform:translateY(-1px) scale(1.02); }

/* Language button */
.lang-btn {
  display: none; /* Initially hidden */
  font-size:11px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:11px 24px;
  border:1px solid var(--t3);
  color:var(--t2);
  background:transparent;
  cursor:pointer;
  margin-left:12px;
  transition:all .2s;
}
.lang-btn:hover {
  background:var(--t1);
  border-color:var(--t1);
  color:var(--black);
}
.lang-toggle {
  display:inline-flex; align-items:center; justify-content:center;
  padding:5px 12px; border:1px solid rgba(255,255,255,.5);
  color:#fff; font-size:11px; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase; text-decoration:none;
  margin-left:16px; flex-shrink:0;
  transition:border-color .2s,color .2s,background .2s;
}
.lang-toggle:hover { border-color:var(--red); color:var(--red); }
.lang-btn.show {
  display: block; /* Show the button */
}

/* Hamburger */
.nav-burger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; }
.nav-burger span { display:block; width:22px; height:1.5px; background:var(--t1); transition:all .3s; }
.nav-burger.open span:nth-child(1) { transform:rotate(45deg) translate(4px,4px); }
.nav-burger.open span:nth-child(2) { opacity:0; }
.nav-burger.open span:nth-child(3) { transform:rotate(-45deg) translate(4px,-4px); }

.mobile-menu {
  display:none; position:fixed; top:62px; left:0; right:0; bottom:0;
  background:rgba(7,7,7,.97); z-index:490; flex-direction:column;
  padding:40px 32px; gap:6px; backdrop-filter:blur(24px);
  overflow-y: auto;
}
.mobile-menu.open { display:flex; animation:page-appear .3s var(--ease) both; }
.mm-item {
  font-family:var(--display); font-size:36px; letter-spacing:.04em; text-transform:uppercase;
  color:var(--t2); padding:12px 0; border-bottom:1px solid var(--border);
  background:none; border-left:none; border-right:none; border-top:none;
  cursor:pointer; font-family:var(--display); transition:color .2s; text-align:left;
  width:100%;
}
.mm-item:hover, .mm-item.active { color:var(--red); }
.mm-item:last-child { border:none; }
.mm-caret { display:inline-block; transition:transform .25s; margin-left:8px; font-size:20px; }
.mm-services-toggle.open .mm-caret { transform:rotate(180deg); }
.mm-services-toggle.open { color:var(--red); }
.mm-services-list { display:none; flex-direction:column; padding-left:20px; border-bottom:1px solid var(--border); }
.mm-services-list.open { display:flex; }
.mm-sub-item {
  font-family:var(--display); font-size:22px; letter-spacing:.04em; text-transform:uppercase;
  color:var(--t2); padding:10px 0; border:none; background:none;
  cursor:pointer; text-align:left; width:100%; transition:color .2s;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.mm-sub-item:last-child { border:none; }
.mm-sub-item:hover { color:var(--red); }
.mm-cta {
  background:var(--red); color:#fff; font-family:var(--font);
  font-size:11px; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  padding:14px 24px; border:none; cursor:pointer; margin-top:24px; align-self:flex-start;
}

/* ── SHARED COMPONENTS ────────────────────── */
.btn-primary {
  background:var(--red); color:#fff; font-family:var(--font);
  font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  padding:15px 34px; border:none; cursor:pointer; display:inline-block;
  transition:background .2s,transform .25s var(--snap);
}
.btn-primary:hover { background:#b81c23; transform:translateY(-2px); }
.btn-ghost {
  border:1px solid rgba(255,255,255,.18); color:var(--t2); font-family:var(--font);
  font-size:11px; font-weight:500; letter-spacing:.16em; text-transform:uppercase;
  padding:14px 30px; cursor:pointer; display:inline-block; background:none;
  transition:border-color .2s,color .2s,transform .2s;
}
.btn-ghost:hover { border-color:rgba(255,255,255,.5); color:var(--t1); transform:translateY(-2px); }

.section-tag { display:flex; align-items:center; gap:10px; margin-bottom:20px; }
.section-tag-line { width:18px; height:2px; background:var(--red); }
.section-tag-text { font-size:10px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--red); }
.section-title { font-family:var(--display); font-size:clamp(36px,5vw,68px); line-height:1.0; letter-spacing:.02em; text-transform:uppercase; }
.section-title .acc { color:var(--red); }
.section-body { font-size:13px; font-weight:300; line-height:1.9; color:var(--t2); }

.reveal { opacity:0; transform:translateY(28px); transition:opacity .75s var(--ease),transform .75s var(--ease); }
.reveal.d1{transition-delay:.10s} .reveal.d2{transition-delay:.20s}
.reveal.d3{transition-delay:.30s} .reveal.d4{transition-delay:.40s}
.reveal.in { opacity:1; transform:none; }
.reveal-left { opacity:0; transform:translateX(-32px); transition:opacity .75s var(--ease),transform .75s var(--ease); }
.reveal-left.d1{transition-delay:.10s} .reveal-left.d2{transition-delay:.20s} .reveal-left.d3{transition-delay:.30s}
.reveal-left.in { opacity:1; transform:none; }
.reveal-scale { opacity:0; transform:scale(0.96); transition:opacity .8s var(--ease),transform .8s var(--ease); }
.reveal-scale.in { opacity:1; transform:none; }

/* ── MOMENTUM TICKER (shared) ─────────────── */
.momentum-band { background:var(--red); overflow:hidden; padding:13px 0; }
.momentum-track { display:flex; animation:momentum-scroll 16s linear infinite; width:max-content; }
@keyframes momentum-scroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.momentum-item { display:flex; align-items:center; white-space:nowrap; }
.momentum-word { font-family:var(--display); font-size:15px; letter-spacing:.28em; text-transform:uppercase; color:rgba(255,255,255,.9); padding:0 28px; }
.momentum-sep { font-size:10px; color:rgba(255,255,255,.4); padding:0 4px; }

/* ── FOOTER (shared) ──────────────────────── */
.footer { background:var(--charcoal); padding:72px 52px 40px; border-top:3px solid var(--red); }
.footer-grid { display:grid; grid-template-columns:1fr 1fr 1fr 220px; gap:52px; margin-bottom:60px; }
.footer-logo-img { height:36px; width:auto; display:block; margin-bottom:24px; }
.footer-brand-name { font-family:var(--display); font-size:32px; letter-spacing:.1em; margin-bottom:6px; }
.footer-brand-sub { font-size:9.5px; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--red); margin-bottom:20px; }
.footer-brand-body { font-size:12px; font-weight:300; line-height:1.85; color:var(--t3); margin-bottom:28px; }
.footer-slash { display:flex; gap:4px; margin-bottom:8px; }
.footer-slash span { display:block; height:3px; border-radius:1px; transform:skewX(-12deg); }
.footer-slash span:nth-child(1){width:28px;background:var(--red);}
.footer-slash span:nth-child(2){width:14px;background:var(--t3);}
.footer-col-head { font-size:9.5px; font-weight:700; letter-spacing:.24em; text-transform:uppercase; color:var(--red); margin-bottom:22px; }
.footer-col-head::before { content:'// '; }
.footer-links-list { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-links-list button, .footer-links-list a {
  font-size:12px; font-weight:300; color:var(--t3); letter-spacing:.06em;
  background:none; border:none; cursor:pointer; text-align:left;
  transition:color .2s,padding-left .2s; display:block; padding:0; font-family:var(--font);
}
.footer-links-list button:hover, .footer-links-list a:hover { color:var(--t1); padding-left:8px; }
.footer-contact-item { margin-bottom:16px; }
.fci-label { font-size:9px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--t3); margin-bottom:6px; }
.fci-value { font-size:12px; font-weight:300; color:var(--t2); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.05); padding-top:28px; display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap; }
.footer-copy { font-size:10px; font-weight:300; color:var(--t3); letter-spacing:.08em; }
.footer-copy .r { color:var(--red); }
.footer-legal { font-size:9px; font-weight:300; color:rgba(255,255,255,.12); max-width:500px; text-align:right; line-height:1.75; }

/* ══════════════════════════════════════════════
   PAGE: HOME
══════════════════════════════════════════════ */
.hero {
  min-height: calc(100vh - 62px);
  min-height: calc(100svh - 62px);
  position:relative; display:flex; flex-direction:column; justify-content:center;
  padding:80px 52px; overflow:hidden;
  background-color: var(--black);
}

/* Hero background video */
.hero-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 30%;
  z-index: 0; pointer-events: none;
}
@media(hover:none),(pointer:coarse) {
  /* Touch devices: show video (muted + playsinline handles autoplay on iOS/Android) */
  .hero-video { display: block; }
}
/* Dark overlay: strong on left for text legibility, fades right; also dark at bottom for stats bar */
.hero::before {
  content: '';
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(to right,  rgba(4,4,4,.78) 0%, rgba(4,4,4,.60) 45%, rgba(4,4,4,.25) 100%),
    linear-gradient(to top,    rgba(4,4,4,.70) 0%, transparent 35%);
}
.hero-wm {
  position:absolute; right:-40px; top:50%; transform:translateY(-50%);
  font-family:var(--display); font-size:clamp(120px,18vw,260px);
  color:rgba(210,31,39,.07); letter-spacing:-.02em; line-height:1;
  pointer-events:none; user-select:none; white-space:nowrap;
  animation:wm-drift 14s ease-in-out infinite alternate;
  z-index: 2;
}
@keyframes wm-drift { 0%{transform:translateY(-50%) translateX(0)} 100%{transform:translateY(-48%) translateX(-20px)} }
.hero-lines { position:absolute; inset:0; pointer-events:none; overflow:hidden; z-index:2; }
.h-line { position:absolute; top:0; bottom:0; width:1px; background:linear-gradient(to bottom,transparent 0%,rgba(210,31,39,.14) 40%,rgba(210,31,39,.07) 70%,transparent 100%); animation:line-appear 1.8s var(--ease) both; }
@keyframes line-appear { from{opacity:0;transform:scaleY(0);transform-origin:top} to{opacity:1;transform:scaleY(1)} }
.hero-scan { position:absolute; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--red),transparent); opacity:.4; animation:scan-down 4s ease-in-out infinite; pointer-events:none; z-index:3; }
@keyframes scan-down { 0%{top:-1px;opacity:0} 10%{opacity:.3} 90%{opacity:.2} 100%{top:100%;opacity:0} }

.hero-content { position:relative; z-index:10; max-width:820px; }
.hero-mobile-logo { display:none; }
.hero-eyebrow { display:flex; align-items:center; gap:12px; margin-bottom:28px; animation:fade-up .8s .2s var(--ease) both; }
.hero-eyebrow-line { width:28px; height:2px; background:var(--red); animation:expand-w .8s .4s var(--ease) both; }
@keyframes expand-w { from{width:0} to{width:28px} }
.hero-eyebrow-text { font-size:10px; font-weight:600; letter-spacing:.3em; text-transform:uppercase; color:var(--red); }
.hero-h1 { font-family:var(--display); font-size:clamp(72px,11vw,148px); line-height:.94; letter-spacing:.01em; text-transform:uppercase; margin-bottom:28px; animation:fade-up .9s .35s var(--ease) both; }
.hero-h1 .line-1 { display:block; color:var(--t1); }
.hero-h1 .line-2 { display:inline-block; color:var(--red); position:relative; }
.hero-h1 .line-2::after { content:''; position:absolute; left:0; bottom:-4px; width:100%; height:3px; background:#ffffff; transform-origin:left; animation:expand-w2 .8s 1s var(--ease) both; }
@keyframes expand-w2 { from{transform:scaleX(0)} to{transform:scaleX(1)} }
.hero-tagline-svg { width:660px; max-width:90vw; display:block; margin-bottom:32px; animation:fade-up .9s .2s var(--ease) both; }
.hero-sub { font-size:13px; font-weight:300; letter-spacing:.08em; color:rgba(255,255,255,.72); margin-bottom:44px; display:flex; align-items:center; gap:18px; flex-wrap:wrap; animation:fade-up .8s .5s var(--ease) both; }
.hero-sub-dot { width:3px; height:3px; border-radius:50%; background:var(--red); flex-shrink:0; }
.hero-actions { display:flex; gap:12px; align-items:center; margin-bottom:80px; animation:fade-up .8s .65s var(--ease) both; }
@keyframes fade-up { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }

.hero-stats { position:absolute; bottom:0; left:0; right:0; display:flex; border-top:1px solid rgba(255,255,255,.10); animation:fade-up .8s .8s var(--ease) both; z-index:10; background:rgba(4,4,4,.55); backdrop-filter:blur(12px); }
.hero-stat { flex:1; padding:28px 52px; border-right:1px solid rgba(255,255,255,.08); display:flex; align-items:center; gap:18px; transition:background .25s; }
.hero-stat:last-child { border-right:none; }
.hero-stat:hover { background:rgba(255,255,255,.04); }
.hero-stat-n { font-family:var(--display); font-size:42px; color:#ffffff; line-height:1; letter-spacing:.02em; }
.hero-stat-n .acc { color:var(--red); }
.hero-stat-l { font-size:10.5px; font-weight:500; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.5); line-height:1.6; }


/* ══════════════════════════════════════════════
   PAGE: WORK / GALLERY
══════════════════════════════════════════════ */
.gallery-hero { padding:80px 52px 60px; position:relative; overflow:hidden; }
.gallery-hero-wm { position:absolute;right:-20px;top:50%;transform:translateY(-50%); font-family:var(--display);font-size:200px;color:rgba(210,31,39,.03);letter-spacing:-.02em;user-select:none;pointer-events:none; }
.gallery-filters { display:flex; gap:2px; margin-bottom:52px; padding:0 52px; flex-wrap:wrap; }
.filter-btn { font-size:10px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; padding:11px 22px; background:none; border:1px solid var(--border); color:var(--t3); cursor:pointer; transition:all .2s; font-family:var(--font); }
.filter-btn:hover, .filter-btn.active { background:var(--red); border-color:var(--red); color:#fff; }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px; padding:0 52px 80px; }
.gallery-card { position:relative; aspect-ratio:4/3; overflow:hidden; background:var(--charcoal); cursor:pointer; }
.gallery-card-bg { position:absolute; inset:0; transition:transform .6s var(--ease); }
.gallery-card:hover .gallery-card-bg { transform:scale(1.05); }
.gallery-card-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.9) 0%,transparent 55%); display:flex; flex-direction:column; justify-content:flex-end; padding:32px 28px; }
.gallery-verb-tag { font-family:var(--display); font-size:12px; letter-spacing:.22em; color:var(--red); margin-bottom:8px; }
.gallery-title { font-size:17px; font-weight:800; margin-bottom:6px; transition:color .2s; }
.gallery-card:hover .gallery-title { color:var(--red); }
.gallery-result { font-size:11.5px; font-weight:300; color:var(--t2); display:flex; align-items:center; gap:8px; }
.gallery-result::before { content:''; display:block; width:10px; height:1px; background:var(--red); }
.gallery-corner { position:absolute; top:0; right:0; width:0; height:0; border-top:40px solid var(--red); border-left:40px solid transparent; }
.gallery-arrow { position:absolute; top:20px; right:20px; width:32px; height:32px; border:1px solid rgba(255,255,255,.15); display:flex; align-items:center; justify-content:center; color:var(--t2); font-size:12px; opacity:0; transform:translate(4px,-4px); transition:opacity .25s,transform .25s var(--ease),background .2s; }
.gallery-card:hover .gallery-arrow { opacity:1; transform:translate(0,0); background:var(--red); border-color:var(--red); color:#fff; }

/* scene CSS */
.scene-1 { background:radial-gradient(ellipse at 30% 80%,rgba(210,31,39,.25) 0%,transparent 50%),radial-gradient(ellipse at 70% 20%,rgba(255,150,0,.08) 0%,transparent 50%),linear-gradient(160deg,#0a0a0f 0%,#1a0808 100%); }
.scene-2 { background:radial-gradient(ellipse at 60% 60%,rgba(80,100,255,.15) 0%,transparent 55%),linear-gradient(140deg,#080810 0%,#100810 100%); }
.scene-3 { background:radial-gradient(ellipse at 50% 40%,rgba(255,255,255,.06) 0%,transparent 60%),linear-gradient(120deg,#0a0a0a 0%,#141010 100%); }
.scene-4 { background:radial-gradient(ellipse at 20% 70%,rgba(210,31,39,.2) 0%,transparent 50%),radial-gradient(ellipse at 80% 30%,rgba(255,200,0,.06) 0%,transparent 50%),linear-gradient(150deg,#0f0a0a 0%,#0a0a0f 100%); }
.scene-5 { background:radial-gradient(ellipse at 70% 50%,rgba(0,180,120,.08) 0%,transparent 50%),linear-gradient(130deg,#080a09 0%,#09090f 100%); }
.scene-6 { background:radial-gradient(ellipse at 40% 60%,rgba(180,0,210,.08) 0%,transparent 50%),linear-gradient(155deg,#0a080f 0%,#100808 100%); }
.light-rays { position:absolute; top:0;left:0;right:0; height:60%; overflow:hidden; }
.ray { position:absolute; top:0; width:1px; transform-origin:top center; border-radius:1px; }
.scene-floor { position:absolute; bottom:0;left:0;right:0; height:80px; background:linear-gradient(to top,rgba(0,0,0,.8),transparent); }

/* ══════════════════════════════════════════════
   HOME: CASE STUDIES SHOWCASE
══════════════════════════════════════════════ */
.home-work {
  background: var(--surface);
  padding: 100px 52px 52px;
  position: relative;
  overflow: hidden;
}
.home-work-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 56px;
}
.home-work-header-left {}
.home-work-header-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
}
.home-work-count {
  font-family: var(--display);
  font-size: 80px;
  color: rgba(210,31,39,.12);
  line-height: 1;
  letter-spacing: .02em;
  user-select: none;
}

/* Featured case study — big horizontal card */
.cs-featured {
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: var(--charcoal);
  margin-bottom: 3px;
  cursor: none;
  position: relative;
  overflow: hidden;
  min-height: 380px;
}
.cs-featured-visual {
  position: relative;
  overflow: hidden;
}
.cs-featured-visual .gallery-card-bg { position:absolute; inset:0; transition:transform .7s var(--ease); }
.cs-featured:hover .gallery-card-bg { transform: scale(1.04); }
.cs-featured-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, transparent 60%, var(--charcoal) 100%);
}
.cs-featured-content {
  padding: 52px 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.cs-featured-num {
  font-family: 'Courier New', monospace;
  font-size: 10.5px;
  font-weight: 700;
  color: var(--red);
  letter-spacing: .2em;
  margin-bottom: 14px;
}
.cs-featured-verb {
  font-family: var(--display);
  font-size: 13px;
  letter-spacing: .28em;
  color: var(--red);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.cs-featured-title {
  font-family: var(--display);
  font-size: clamp(32px, 3.5vw, 52px);
  line-height: 1.0;
  letter-spacing: .02em;
  text-transform: uppercase;
  margin-bottom: 20px;
  transition: color .25s;
}
.cs-featured:hover .cs-featured-title { color: var(--red); }
.cs-featured-body {
  font-size: 12.5px;
  font-weight: 300;
  line-height: 1.8;
  color: var(--t2);
  margin-bottom: 28px;
  max-width: 380px;
}
.cs-featured-result {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 11px;
  font-weight: 600;
  color: var(--t1);
  margin-bottom: 8px;
}
.cs-featured-result::before {
  content: '';
  display: block;
  width: 16px;
  height: 2px;
  background: var(--red);
  flex-shrink: 0;
}
.cs-featured-link {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--red);
  background: none;
  border: none;
  cursor: none;
  font-family: var(--font);
  padding: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 20px;
  transition: gap .2s;
}
.cs-featured-link::after { content: '→'; }
.cs-featured-link:hover { gap: 12px; }

/* 3-column mini grid below featured */
.cs-mini-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
  margin-bottom: 40px;
}
.cs-mini {
  position: relative;
  background: var(--charcoal);
  aspect-ratio: 16/9;
  overflow: hidden;
  cursor: none;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px 22px;
}
.cs-mini-bg {
  position: absolute;
  inset: 0;
  transition: transform .6s var(--ease);
}
.cs-mini:hover .cs-mini-bg { transform: scale(1.05); }
.cs-mini-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.88) 0%, transparent 55%);
}
.cs-mini-content { position: relative; z-index: 1; }
.cs-mini-verb {
  font-family: var(--display);
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--red);
  margin-bottom: 5px;
}
.cs-mini-title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 5px;
  transition: color .2s;
  line-height: 1.3;
}
.cs-mini:hover .cs-mini-title { color: var(--red); }
.cs-mini-metric {
  font-size: 10px;
  font-weight: 300;
  color: var(--t2);
  display: flex;
  align-items: center;
  gap: 8px;
}
.cs-mini-metric::before {
  content: '';
  display: block;
  width: 8px;
  height: 1px;
  background: var(--red);
}
.cs-mini-corner {
  position: absolute;
  top: 0; right: 0;
  width: 0; height: 0;
  border-top: 32px solid var(--red);
  border-left: 32px solid transparent;
}

/* View all CTA row */
.home-work-cta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--border);
  padding-top: 36px;
}
.home-work-cta-left {
  font-size: 12px;
  font-weight: 300;
  color: var(--t3);
  max-width: 400px;
  line-height: 1.7;
}
.home-work-cta-left strong { color: var(--t2); font-weight: 600; }

/* ══════════════════════════════════════════════
   WORK PAGE: EXPANDED LAYOUT
══════════════════════════════════════════════ */
/* Stats band on work page */
.work-stats-band {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.work-stat-cell {
  padding: 36px 44px;
  border-right: 1px solid var(--border);
  transition: background .2s;
}
.work-stat-cell:last-child { border-right: none; }
.work-stat-cell:hover { background: var(--surface2); }
.work-stat-n { font-family: var(--display); font-size: 52px; line-height: 1; color: var(--white); }
.work-stat-n .acc { color: var(--red); }
.work-stat-l { font-size: 10.5px; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: var(--t3); margin-top: 6px; }

/* Featured project row (2-col) */
.work-featured-row {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 3px;
  padding: 0 52px;
  margin-bottom: 3px;
}
.work-featured-card {
  position: relative;
  overflow: hidden;
  background: var(--charcoal);
  cursor: none;
}
.work-featured-card.tall { min-height: 480px; }
.work-featured-card.medium { min-height: 480px; }
.wfc-bg { position: absolute; inset: 0; transition: transform .7s var(--ease); }
.work-featured-card:hover .wfc-bg { transform: scale(1.04); }
.wfc-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.92) 0%, rgba(0,0,0,.1) 60%, transparent 100%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 36px 32px;
}
.wfc-type { font-family: var(--display); font-size: 12px; letter-spacing: .24em; color: var(--red); margin-bottom: 10px; }
.wfc-title { font-size: 24px; font-weight: 800; margin-bottom: 10px; transition: color .2s; line-height: 1.2; }
.work-featured-card:hover .wfc-title { color: var(--red); }
.wfc-desc { font-size: 12.5px; font-weight: 300; color: var(--t2); line-height: 1.65; margin-bottom: 16px; max-width: 360px; }
.wfc-result { font-size: 12px; font-weight: 600; color: var(--t1); display: flex; align-items: center; gap: 10px; }
.wfc-result::before { content: ''; display: block; width: 14px; height: 2px; background: var(--red); }
.wfc-arrow { position: absolute; top: 24px; right: 24px; width: 36px; height: 36px; border: 1px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; font-size: 14px; color: var(--t2); opacity: 0; transform: translate(4px,-4px); transition: opacity .25s,transform .25s var(--ease),background .2s; }
.work-featured-card:hover .wfc-arrow { opacity: 1; transform: translate(0,0); background: var(--red); border-color: var(--red); color: #fff; }

/* Video showcase section */
.video-showcase {
  padding: 80px 52px;
  background: var(--black);
  border-top: 1px solid var(--border);
}
.video-single {
  margin-top: 48px;
  position: relative;
  aspect-ratio: 16 / 9;
  background: var(--charcoal);
  border: 1px solid var(--border);
}
.video-single iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

/* Work page filter row with count */
.work-filter-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 52px;
  margin-bottom: 36px;
  flex-wrap: wrap;
  gap: 16px;
}
.work-filter-count {
  font-size: 11px;
  font-weight: 300;
  color: var(--t3);
  letter-spacing: .1em;
}
.work-filter-count strong { color: var(--red); font-weight: 700; }

/* Testimonials carousel strip on work page */
.work-testimonials {
  padding: 80px 52px;
  background: var(--surface);
  border-top: 1px solid var(--border);
}
.work-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
  margin-top: 48px;
}
.wt-card {
  background: var(--black);
  padding: 40px 36px;
  border-top: 2px solid var(--border);
  transition: border-color .25s, background .25s;
  position: relative;
}
.wt-card:hover { border-top-color: var(--red); background: rgba(210,31,39,.04); }
.wt-quote-mark { font-family: Georgia, serif; font-size: 64px; color: var(--red); line-height: .8; margin-bottom: 18px; opacity: .4; }
.wt-quote { font-size: 13px; font-weight: 300; line-height: 1.85; color: var(--t2); margin-bottom: 28px; font-style: italic; }
.wt-divider { width: 24px; height: 1px; background: var(--red); margin-bottom: 18px; }
.wt-name { font-size: 13px; font-weight: 700; color: var(--t1); margin-bottom: 4px; }
.wt-role { font-size: 11px; font-weight: 300; color: var(--t3); letter-spacing: .08em; margin-bottom: 12px; }
.wt-tag { font-size: 9px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--red); border: 1px solid rgba(210,31,39,.3); padding: 5px 10px; display: inline-block; }

/* Responsive additions */
@media(max-width:1100px) {
  .cs-featured { grid-template-columns: 1fr; }
  .cs-featured-visual { min-height: 260px; }
  .cs-featured-visual::after { background: linear-gradient(to top, var(--charcoal) 0%, transparent 60%); }
  .work-stats-band { grid-template-columns: repeat(2,1fr); }
  .work-featured-row { grid-template-columns: 1fr; padding: 0 20px; }
  .work-testimonials-grid { grid-template-columns: 1fr; }
}
@media(max-width:768px) {
  .home-work { padding: 64px 20px 32px; }
  .home-work-header { flex-direction: column; align-items: flex-start; gap: 16px; }
  .cs-strip { padding: 40px 20px 0; }
  .work-filter-row { padding: 0 20px; }
  .video-showcase { padding: 60px 20px; }
  .work-testimonials { padding: 60px 20px; }
  .work-testimonials-grid { grid-template-columns: 1fr; }
  .work-stats-band { grid-template-columns: repeat(2,1fr); }
  .work-featured-row { margin-bottom: 0; }
}

/* ══════════════════════════════════════════════
   PAGE: ABOUT
══════════════════════════════════════════════ */
.about-hero { padding:100px 52px 80px; position:relative; overflow:hidden; display:flex; flex-direction:column; background-image:url('assets/images/gallery/page-section-images/about-hero.jpg'); background-size:cover; background-position:center 40%; background-repeat:no-repeat; min-height:92vh; justify-content:center; }
.about-hero::before { content:''; position:absolute; inset:0; z-index:0; pointer-events:none; background:linear-gradient(to right,rgba(4,4,4,.96) 0%,rgba(4,4,4,.88) 55%,rgba(4,4,4,.60) 100%), linear-gradient(to top,rgba(4,4,4,.80) 0%,transparent 45%); }
.about-hero > * { position:relative; z-index:1; }
.about-wm { position:absolute;right:-20px;bottom:-30px;font-family:var(--display);font-size:200px;color:rgba(255,255,255,.018);letter-spacing:-.05em;user-select:none;pointer-events:none; }
.about-hero-eyebrow { display:flex; align-items:center; gap:24px; margin-bottom:40px; }
.about-hero-rule { flex:1; height:1px; background:rgba(255,255,255,.10); }
.about-headline { font-family:var(--display); font-size:clamp(72px,9.5vw,148px); line-height:.92; letter-spacing:.02em; text-transform:uppercase; margin-bottom:56px; }
.about-headline .acc { color:var(--red); }
.about-stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:3px; margin-bottom:56px; }
.about-stat-cell { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07); padding:32px 28px; transition:background .2s; }
.about-stat-cell:hover { background:rgba(255,255,255,.08); }
.about-stat-n { font-family:var(--display); font-size:56px; color:var(--white); line-height:1; margin-bottom:8px; }
.about-stat-n .acc { color:var(--red); }
.about-stat-l { font-size:10.5px; font-weight:500; letter-spacing:.15em; text-transform:uppercase; color:var(--t3); }
.about-hero-bottom { display:flex; align-items:flex-end; gap:80px; }
.about-hero-text { flex:1; max-width:680px; }
.about-body-text { font-size:13.5px; font-weight:300; line-height:1.95; color:var(--t2); margin-bottom:20px; }
.about-values { padding:0 52px 80px; }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px; margin-top:48px; }
.value-card { background:var(--surface); padding:44px 36px; border-top:3px solid transparent; transition:border-color .25s,background .25s; }
.value-card:hover { border-top-color:var(--red); background:var(--surface2); }
.value-label { font-size:9.5px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--red); margin-bottom:14px; }
.value-title { font-size:20px; font-weight:800; margin-bottom:12px; }
.value-body { font-size:12.5px; font-weight:300; line-height:1.85; color:var(--t2); }
.about-team { padding:0 52px 80px; }
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:3px; margin-top:48px; }
.team-card { background:var(--surface); padding:40px 32px; position:relative; overflow:hidden; }
.team-card::after { content:''; position:absolute; bottom:0;left:0;right:0; height:2px; background:var(--red); transform:scaleX(0); transition:transform .3s var(--ease); }
.team-card:hover::after { transform:scaleX(1); }
.team-avatar { width:60px; height:60px; border-radius:50%; background:var(--charcoal); border:2px solid var(--border); display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:24px; color:var(--red); margin-bottom:20px; }
.team-name { font-size:15px; font-weight:700; margin-bottom:5px; }
.team-role { font-size:10.5px; font-weight:400; color:var(--red); letter-spacing:.1em; text-transform:uppercase; margin-bottom:12px; }
.team-bio { font-size:12px; font-weight:300; line-height:1.75; color:var(--t3); }

/* ══════════════════════════════════════════════
   PAGE: SERVICE DETAIL (shared layout)
══════════════════════════════════════════════ */
.service-hero { padding:80px 52px 60px; position:relative; overflow:hidden; display:grid; grid-template-columns:1fr 440px; gap:80px; align-items:start; background-size:cover; background-position:center 30%; background-repeat:no-repeat; }
.service-hero::before { content:''; position:absolute; inset:0; z-index:0; pointer-events:none; background: linear-gradient(to right, rgba(4,4,4,.96) 0%, rgba(4,4,4,.88) 50%, rgba(4,4,4,.72) 100%), linear-gradient(to top, rgba(4,4,4,.88) 0%, transparent 40%); }
.service-hero > * { position:relative; z-index:1; }
#page-launch .service-hero { background-image:url('assets/images/gallery/page-section-images/eventsmanagement-hero.jpg'); }
#page-exhibit .service-hero { background-image:url('assets/images/gallery/page-section-images/exhibitionservices-hero.jpg'); }
#page-convene .service-hero { background-image:url('assets/images/gallery/page-section-images/hero-supportservices.jpg'); }
#page-reveal .service-hero { background-image:url('assets/images/gallery/page-section-images/contentcreation-hero.jpg'); }
.service-hero-wm { position:absolute;right:-20px;bottom:0;font-family:var(--display);font-size:220px;color:rgba(210,31,39,.04);letter-spacing:-.04em;line-height:1;user-select:none;pointer-events:none; }
.service-hero-num { font-family:'Courier New',monospace; font-size:11px; font-weight:700; color:var(--red); letter-spacing:.18em; margin-bottom:18px; }
.service-hero-title { font-family:var(--display); font-size:clamp(72px,10vw,140px); line-height:.92; letter-spacing:.02em; text-transform:uppercase; margin-bottom:24px; color:var(--t1); }
.service-hero-title .acc { color:var(--red); }
.service-hero-desc { font-size:14px; font-weight:300; line-height:1.9; color:var(--t2); margin-bottom:36px; max-width:520px; }
.service-hero-items { list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:36px; }
.service-hero-items li { display:flex; align-items:flex-start; gap:14px; font-size:12.5px; font-weight:400; color:var(--t2); line-height:1.5; }
.service-hero-items li::before { content:''; display:block; width:16px; height:1px; background:var(--red); flex-shrink:0; margin-top:10px; }
.service-panel { background:var(--surface); padding:44px 36px; border-top:3px solid var(--red); position:sticky; top:80px; }
.service-panel-title { font-size:11px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--red); margin-bottom:8px; }
.service-panel-sub { font-size:12px; font-weight:300; color:var(--t3); margin-bottom:28px; }
.service-form-field { margin-bottom:16px; }
.service-form-field label { display:block; font-size:10px; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:var(--t3); margin-bottom:8px; }
.service-form-field input, .service-form-field select, .service-form-field textarea { width:100%; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); color:var(--t1); font-family:var(--font); font-size:13px; font-weight:300; padding:11px 14px; outline:none; transition:border-color .2s; resize:none; }
.service-form-field input:focus, .service-form-field select:focus, .service-form-field textarea:focus { border-color:rgba(210,31,39,.4); }
.service-form-field select option { background:var(--charcoal); }
.service-form-submit { width:100%; background:var(--red); color:#fff; font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; padding:15px; border:none; cursor:pointer; font-family:var(--font); transition:background .2s; margin-top:8px; }
.service-form-submit:hover { background:#b81c23; }

.service-projects { padding:0 52px 80px; background:var(--surface); }
.service-project-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:3px; margin-top:48px; }

/* ══════════════════════════════════════════════
   PAGE: BRIEF / CONTACT
══════════════════════════════════════════════ */
.brief-page { padding:80px 52px; position:relative; overflow:hidden;
  /* background hero image – swap path for whichever you prefer */
  background: url('assets/images/gallery/event-asmo-incorporation/01-hero.jpg') center/cover no-repeat;
  color: #fff; /* default all text white */
}
.brief-page * { color: inherit; } /* ensure descendants inherit white */
.brief-page::before {
  content: '';
  position: absolute;
  inset: 0;
  /* stronger gradient overlay for improved contrast */
  background: linear-gradient(to bottom, rgba(0,0,0,0.75), rgba(0,0,0,0.45));
  pointer-events: none;
}
.brief-wm { position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:var(--display);font-size:clamp(80px,14vw,200px);color:rgba(255,255,255,.015);letter-spacing:.02em;white-space:nowrap;user-select:none; }
.brief-grid { display:grid; grid-template-columns:1fr 580px; gap:80px; position:relative; z-index:1; }
.brief-eyebrow { font-size:10px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--red); margin-bottom:22px; display:flex; align-items:center; gap:10px; }
.brief-eyebrow::before { content:''; width:18px; height:2px; background:var(--red); }
.brief-headline { font-family:var(--display); font-size:clamp(52px,8vw,110px); line-height:1; letter-spacing:.02em; text-transform:uppercase; margin-bottom:20px; }
.brief-headline .acc { color:var(--red); }
.brief-body { font-size:13px; font-weight:300; line-height:1.9; color:var(--t2); margin-bottom:40px; max-width:460px; }
.brief-promise { display:flex; flex-direction:column; gap:16px; }
.brief-promise-item { display:flex; align-items:flex-start; gap:16px; }
.bpi-dot { width:8px; height:8px; background:var(--red); border-radius:50%; flex-shrink:0; margin-top:5px; }
.bpi-text { font-size:12px; font-weight:300; line-height:1.7; color:var(--t2); }
.bpi-text strong { color:var(--t1); font-weight:700; }
.brief-form-wrap { background:rgba(37,37,38,.85); /* charcoal with opacity */ border:1px solid rgba(255,255,255,.3); padding:48px 40px; position:relative; }
.brief-form-wrap::before { content:''; position:absolute; top:0;left:0;right:0; height:3px; background:var(--red); }
.brief-form-title { font-size:13px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; margin-bottom:6px; }
.brief-form-sub { font-size:11.5px; font-weight:300; color:var(--t3); margin-bottom:32px; }
.brief-form-field { margin-bottom:18px; }
.brief-form-field label { display:block; font-size:10px; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:#fff; margin-bottom:8px; }
.brief-form-field input, .brief-form-field select, .brief-form-field textarea { width:100%; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); color:var(--t1); font-family:var(--font); font-size:13px; font-weight:300; padding:12px 14px; outline:none; transition:border-color .2s; resize:none; }
.brief-form-field input:focus, .brief-form-field select:focus, .brief-form-field textarea:focus { border-color:rgba(210,31,39,.4); }
.brief-form-field select option { background:var(--charcoal); }
.brief-submit { width:100%; background:var(--red); color:#fff; font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; padding:16px; border:none; cursor:pointer; font-family:var(--font); transition:background .2s; margin-top:10px; }
.brief-submit:hover { background:#b81c23; }
.brief-submit:disabled { background:var(--charcoal); cursor:default; }
.field-error { display:block; color:#e8393f; font-size:10.5px; font-weight:500; margin-top:5px; letter-spacing:.02em; }
.brief-success { display:none; text-align:center; padding:40px 20px; }
.brief-success-icon { font-size:40px; margin-bottom:16px; color:var(--red); }
.brief-success h3 { font-family:var(--display); font-size:36px; letter-spacing:.04em; text-transform:uppercase; margin-bottom:10px; }
.brief-success p { font-size:12px; font-weight:300; color:var(--t2); line-height:1.7; }

.contact-strip { display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--border); margin:0; }
.contact-cell { padding:44px 48px; border-right:1px solid var(--border); }
.contact-cell:last-child { border:none; }
.contact-cell-label { font-size:9.5px; font-weight:700; letter-spacing:.24em; text-transform:uppercase; color:var(--red); margin-bottom:10px; }
.contact-cell-value { font-size:13px; font-weight:300; color:var(--t2); line-height:1.65; }

/* ══════════════════════════════════════════════
   SPEED / ABOUT SECTION (reused)
══════════════════════════════════════════════ */
.speed-section { background:var(--black); border-top:1px solid var(--border); border-bottom:1px solid var(--border); display:grid; grid-template-columns:1fr 1fr; }
.speed-left { padding:80px 52px; border-right:1px solid var(--border); position:relative; overflow:hidden; }
.speed-wm { position:absolute;bottom:-20px;left:-10px;font-family:var(--display);font-size:200px;color:rgba(255,255,255,.018);letter-spacing:-.05em;line-height:1;user-select:none;pointer-events:none; }
.speed-eyebrow { font-size:10px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--red);margin-bottom:22px;display:flex;align-items:center;gap:10px; }
.speed-eyebrow::before{content:'';width:18px;height:2px;background:var(--red);}
.speed-headline { font-family:var(--display);font-size:clamp(42px,5.5vw,80px);line-height:.96;letter-spacing:.02em;text-transform:uppercase;margin-bottom:32px;position:relative;z-index:1; }
.speed-headline .acc { color:var(--red); }
.speed-body { font-size:13px;font-weight:300;line-height:1.9;color:var(--t2);margin-bottom:32px;max-width:460px;position:relative;z-index:1; }
.speed-proof { display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);position:relative;z-index:1; }
.speed-proof-cell { background:var(--black);padding:26px 22px;transition:background .2s; }
.speed-proof-cell:hover{background:var(--surface);}
.speed-proof-n { font-family:var(--display);font-size:40px;color:var(--white);line-height:1;margin-bottom:6px; }
.speed-proof-n .acc{color:var(--red);}
.speed-proof-l { font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--t3); }
.speed-right { padding:80px 52px;display:flex;flex-direction:column;justify-content:center; }
.process-step { display:flex;gap:28px;padding:28px 0;border-bottom:1px solid var(--border);align-items:flex-start;position:relative;margin:0 -20px;padding-left:20px;padding-right:20px;transition:background .2s; }
.process-step:last-child{border:none;}
.process-step:hover{background:rgba(255,255,255,.02);}
.process-step::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--red);transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ease);}
.process-step:hover::before{transform:scaleY(1);}
.ps-num{font-family:'Courier New',monospace;font-size:11px;font-weight:700;color:var(--red);letter-spacing:.1em;flex-shrink:0;padding-top:4px;min-width:30px;}
.ps-phase{font-size:9.5px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--t3);margin-bottom:6px;}
.ps-title{font-size:16px;font-weight:700;margin-bottom:6px;transition:color .2s;}
.process-step:hover .ps-title{color:var(--red);}
.ps-body{font-size:12px;font-weight:300;line-height:1.75;color:var(--t2);}

/* Testimonial */
.testimonial-section { background:var(--red); padding:80px 52px; position:relative; overflow:hidden; }
.testimonial-section::before { content:'"';position:absolute;left:40px;top:-20px;font-family:Georgia,serif;font-size:280px;color:rgba(0,0,0,.12);line-height:1;pointer-events:none;user-select:none; }
.t-wm { position:absolute;right:-20px;bottom:-30px;font-family:var(--display);font-size:180px;color:rgba(0,0,0,.08);letter-spacing:-.04em;user-select:none;line-height:1; }
.testimonial-inner { max-width:860px; position:relative; z-index:1; }
.testimonial-quote { font-size:clamp(16px,2.2vw,26px);font-weight:300;line-height:1.6;color:rgba(255,255,255,.95);margin-bottom:36px;font-style:italic; }
.testimonial-author { display:flex;align-items:center;gap:18px; }
.t-avatar { width:44px;height:44px;border-radius:50%;background:rgba(0,0,0,.2);border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff;flex-shrink:0; }
.t-name{font-size:13px;font-weight:700;color:#fff;}
.t-role{font-size:10px;font-weight:300;color:rgba(255,255,255,.65);letter-spacing:.08em;}
.t-tag{margin-left:auto;border:1px solid rgba(255,255,255,.25);padding:6px 16px;font-size:9.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7);}

/* Clients ticker */
.clients-strip { padding:64px 52px; background:var(--surface); overflow:hidden; border-bottom:1px solid var(--border); }
.clients-header-row { display:flex;align-items:center;gap:20px;margin-bottom:40px; }
.clients-label { font-size:10px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--t3);white-space:nowrap;display:flex;align-items:center;gap:10px; }
.clients-label::before{content:'//';color:var(--red);}
.clients-divider { flex:1;height:1px;background:var(--border); }
.ticker-wrap { overflow-x:hidden;overflow-y:visible;position:relative; }
.ticker-wrap::before,.ticker-wrap::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;}
.ticker-wrap::before{left:0;background:linear-gradient(to right,var(--surface),transparent);}
.ticker-wrap::after{right:0;background:linear-gradient(to left,var(--surface),transparent);}
.ticker{display:flex;gap:72px;animation:ticker-scroll 45s linear infinite;width:max-content;}
.ticker:hover{animation-play-state:paused;}
@keyframes ticker-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.client-chip{font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--t3);white-space:nowrap;transition:color .2s;}
.client-chip:hover{color:var(--t1);}
.client-sep{color:var(--red);font-size:10px;align-self:center;flex-shrink:0;}

/* ══════════════════════════════════════════════
   HOME: CASE STUDIES — UPGRADED
══════════════════════════════════════════════ */
.cs-featured-play {
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  background:rgba(0,0,0,0);z-index:3;transition:background .35s;cursor:pointer;
}
.cs-featured:hover .cs-featured-play { background:rgba(0,0,0,.25); }
.cs-fp-ring {
  width:64px;height:64px;border:2px solid rgba(255,255,255,.22);border-radius:50%;
  display:flex;align-items:center;justify-content:center;position:relative;
  opacity:0;transform:scale(.8);transition:opacity .3s,transform .3s var(--snap),background .25s,border-color .25s;
}
.cs-featured:hover .cs-fp-ring { opacity:1;transform:scale(1); }
.cs-fp-ring:hover { background:var(--red);border-color:var(--red); }
.cs-fp-icon { font-size:18px;color:#fff;padding-left:4px;opacity:0;transition:opacity .3s .05s; }
.cs-featured:hover .cs-fp-icon { opacity:1; }
.cs-fp-label {
  font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.7);
  opacity:0;transform:translateY(6px);transition:opacity .3s .1s,transform .3s .1s var(--ease);
}
.cs-featured:hover .cs-fp-label { opacity:1;transform:none; }

.cs-strip { margin-top:3px;padding:56px 52px 0;background:var(--surface);border-top:1px solid var(--border); }
.cs-strip-label { display:flex;align-items:center;gap:14px;margin-bottom:28px;font-size:10px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--t3); }
.cs-strip-all { font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--red);background:none;border:none;cursor:pointer;font-family:var(--font);white-space:nowrap;transition:opacity .2s; }
.cs-strip-all:hover { opacity:.7; }
.cs-strip-row { display:flex;gap:3px;overflow-x:auto;padding-bottom:4px;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none; }
.cs-strip-row::-webkit-scrollbar { display:none; }
/* ── CS-STRIP CARDS: split layout — image top / info panel bottom ── */
.cs-card { flex:0 0 300px;height:320px;position:relative;overflow:hidden;background:var(--charcoal);cursor:pointer;border-top:3px solid transparent;transition:border-color .25s; }
.cs-card:hover { border-top-color:var(--red); }

/* Image zone — top 170px only */
.cs-card-bg { position:absolute;top:0;left:0;right:0;height:170px;background-size:cover;background-position:center;filter:brightness(1.1);transition:transform .6s var(--ease); }
.cs-card:hover .cs-card-bg { transform:scale(1.06); }

/* Subtle vignette on image only */
.cs-card-overlay { position:absolute;top:0;left:0;right:0;height:170px;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.35) 100%); }
.cs-card-corner { position:absolute;top:0;right:0;width:0;height:0;border-top:28px solid rgba(210,31,39,.6);border-left:28px solid transparent;z-index:3; }

/* Solid info panel — bottom 150px */
.cs-card-content { position:absolute;bottom:0;left:0;right:0;height:150px;background:var(--black);padding:18px 20px 16px;border-top:1px solid rgba(255,255,255,.07);z-index:2;display:flex;flex-direction:column; }

/* Category tag — pill style */
.cs-card-verb { font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red);background:rgba(210,31,39,.1);border:1px solid rgba(210,31,39,.22);padding:3px 9px;display:inline-block;width:fit-content;margin-bottom:10px;font-family:var(--font); }

.cs-card-title { font-size:14px;font-weight:700;line-height:1.35;margin-bottom:8px;transition:color .2s;color:var(--t1);flex:1; }
.cs-card:hover .cs-card-title { color:var(--red); }

.cs-card-metric { font-size:10.5px;font-weight:300;color:var(--t2);display:flex;align-items:center;gap:8px; }
.cs-card-metric::before { content:'';display:block;width:8px;height:1px;background:var(--red);flex-shrink:0; }

/* Hover arrow — slides in from right inside the info panel */
.cs-card-hover-btn { position:absolute;bottom:14px;right:18px;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--red);background:none;border:none;cursor:pointer;font-family:var(--font);display:flex;align-items:center;gap:5px;z-index:3;opacity:0;transform:translateX(6px);transition:opacity .25s,transform .25s var(--ease); }
.cs-card:hover .cs-card-hover-btn { opacity:1;transform:none; }

.cs-card-cta { background:var(--black);border:1px solid rgba(210,31,39,.2);border-top:3px solid var(--red);padding:32px 26px;display:flex;flex-direction:column;justify-content:center;flex:0 0 260px;height:320px; }
.cs-card-cta-n { font-family:var(--display);font-size:64px;line-height:1;color:rgba(210,31,39,.2);letter-spacing:.02em;margin-bottom:6px; }
.cs-card-cta-n span { color:var(--red); }
.cs-card-cta-label { font-family:var(--display);font-size:19px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px; }
.cs-card-cta-sub { font-size:11px;font-weight:300;color:var(--t3);line-height:1.75; }
.cs-strip-nav { display:flex;gap:4px;justify-content:flex-end;margin-top:16px;padding-bottom:48px; }
.cs-nav-btn { width:36px;height:36px;border:1px solid var(--border);background:none;color:var(--t2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s,color .2s;font-family:var(--font); }
.cs-nav-btn:hover { background:var(--red);border-color:var(--red);color:#fff; }


.gallery-card.hidden-card { display:none; }
.gallery-card.hidden-card.revealed { display:block;animation:page-appear .5s var(--ease) both; }

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media(max-width:1100px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .about-headline{font-size:clamp(64px,8.5vw,110px);}
  .values-grid{grid-template-columns:1fr 1fr;}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .service-hero{grid-template-columns:1fr;}
  .brief-grid{grid-template-columns:1fr;}
  .speed-section{grid-template-columns:1fr;}
  .speed-left{border-right:none;border-bottom:1px solid var(--border);}
  .footer-grid{grid-template-columns:1fr 1fr;}
  /* Darken overlay at mid-widths where image frame shifts */
  .hero::before {
    background:
      linear-gradient(to right, rgba(4,4,4,.80) 0%, rgba(4,4,4,.65) 50%, rgba(4,4,4,.40) 100%),
      linear-gradient(to top,   rgba(4,4,4,.72) 0%, transparent 35%);
  }
  .hero { background-position: 65% 30%; }
}
@media(max-width:768px){
  /* ── Nav ── */
  .nav{padding:0 20px;}
  .nav-verbs,.nav-more-wrap,.nav-cta{display:none;}
  .nav-burger{display:flex;}

  /* ── Hero sections ── */
  .gallery-hero,.about-hero,.brief-page,.service-hero{padding:52px 20px 60px;}
  .hero{
    min-height:100svh;
    padding:80px 24px 40px;
    justify-content:center;
    align-items:center;
    background-position:center;
  }
  .hero::before{
    background:rgba(4,4,4,.65);
  }
  .hero-content{padding-bottom:0;text-align:left;width:100%;}
  .hero-mobile-logo{display:block !important;width:220px;max-width:70%;margin:0 0 32px;animation:fade-up .8s .1s var(--ease) both;}
  .hero-tagline-svg{width:660px;max-width:90vw;margin:0 0 24px;}
  .hero-sub{gap:8px;font-size:13px;margin-bottom:22px;flex-wrap:wrap;justify-content:flex-start;color:#fff;}
  .hero-sub-dot{display:none;}
  .hero-sub span::after{content:' ·';color:var(--red);}
  .hero-sub span:last-child::after{content:'';}
  .hero-actions{margin-bottom:0;flex-direction:row;flex-wrap:wrap;gap:8px;justify-content:flex-start;}
  .hero-actions .btn-primary,.hero-actions .btn-ghost{font-size:11px;padding:11px 20px;letter-spacing:.12em;}
  .hero-stats{display:none;}
  .about-hero::before{background:rgba(4,4,4,.86);}
  .service-hero::before{background:rgba(4,4,4,.88);}

  /* ── Typography ── */
  .about-hero{min-height:auto;padding:64px 20px 52px;}
  .about-hero-eyebrow{margin-bottom:28px;}
  .about-headline{font-size:clamp(52px,13vw,80px);margin-bottom:36px;}
  .about-stats-row{grid-template-columns:repeat(2,1fr);margin-bottom:36px;}
  .about-stat-cell{padding:24px 20px;}
  .about-hero-bottom{flex-direction:column;align-items:flex-start;gap:24px;}
  .service-hero-title{font-size:clamp(44px,12vw,72px);}
  .section-title{font-size:clamp(28px,7vw,50px);}
  .brief-headline{font-size:clamp(40px,10vw,80px);}
  .cs-featured-title{font-size:clamp(24px,6vw,40px);}

  /* ── Service pages ── */
  .service-panel{position:relative;top:auto;}
  .service-project-grid{grid-template-columns:1fr;}
  .service-projects{padding:0 20px 60px;}


  /* ── Gallery / Work ── */
  .gallery-grid{grid-template-columns:1fr;padding:0 20px 60px;}
  .gallery-filters{padding:0 20px 8px;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
  .gallery-filters::-webkit-scrollbar{display:none;}
  .gallery-hero{padding:52px 20px 40px;}
  .cs-mini-grid{grid-template-columns:1fr;}
  .cs-featured-content{padding:28px 20px;}
  .cs-strip{padding:40px 20px 0;}
  .cs-card{flex:0 0 260px;height:300px;}
  .cs-card-bg,.cs-card-overlay{height:150px;}
  .cs-card-content{height:150px;}
  .home-work-cta-row{flex-direction:column;align-items:flex-start;gap:16px;}
  .work-stat-cell{padding:24px 20px;}
  .work-featured-row{padding:0 20px;}
  .video-showcase{padding:60px 20px;}
  .work-filter-row{padding:0 20px;flex-direction:column;align-items:flex-start;}
  .work-filter-row>div:last-child{width:100%;align-items:flex-start;}
  .work-filter-row .gallery-filters{width:100%;margin-bottom:0;}
  .work-stats-band{grid-template-columns:repeat(2,1fr);}

  /* ── About ── */
  .values-grid,.team-grid{grid-template-columns:1fr;}
  .about-values,.about-team{padding:0 20px 60px;}

  /* ── Brief / Contact ── */
  .contact-strip{grid-template-columns:1fr;}
  .contact-cell{padding:28px 20px;border-right:none;border-bottom:1px solid var(--border);}
  .contact-cell:last-child{border:none;}

  /* ── Speed / Process ── */
  .speed-section{display:block;}
  .speed-left,.speed-right{padding:40px 20px;}

  /* ── Work featured card image heights ── */
  .work-featured-card.tall,.work-featured-card.medium{min-height:280px;}
  .work-featured-card{min-height:200px;}
  .wfc-desc{display:none;}
  .wfc-overlay{padding:24px 20px;}
  .wfc-type{font-size:10px;margin-bottom:6px;}
  .wfc-title{font-size:18px;margin-bottom:8px;}
  .wfc-result{font-size:11px;}

  /* ── Process steps accordion ── */
  .proc-toggle{width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--border);padding:14px 0;font-size:13px;font-weight:700;color:var(--t1);font-family:var(--font);cursor:pointer;display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;}
  .proc-toggle-icon{font-size:20px;font-weight:300;color:var(--red);transition:transform .3s var(--ease);}
  .speed-right.proc-open .proc-toggle-icon{transform:rotate(45deg);}
  .proc-accordion-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s var(--ease);}
  .speed-right.proc-open .proc-accordion-body{grid-template-rows:1fr;}
  .proc-accordion-inner{overflow:hidden;}

  /* ── Spacing reductions ── */
  .home-work{padding:40px 20px;}
  .video-showcase{padding:40px 20px;}
  .work-testimonials{padding:40px 20px;}
  .about-values,.about-team{padding:0 20px 40px;}
  .clients-strip{padding:40px 20px;}
  .testimonial-section{padding:52px 20px;}
  .cs-strip{padding:32px 20px 0;}

  /* ── Home CTA padding (overrides inline style) ── */
  .home-cta{padding:64px 20px !important;}
  /* ── Testimonial ── */
  .testimonial-section::before{font-size:100px;top:-5px;}
  .t-wm{font-size:80px;bottom:-10px;}
  .t-tag{display:none;}
  /* ── Home work header ── */
  .home-work-header-right{display:none;}
  /* ── CS strip arrows (swipe on mobile) ── */
  .cs-strip-nav{display:none;}
  /* ── Footer ── */
  .footer{padding:48px 20px 24px;}
  .footer-grid{grid-template-columns:1fr;gap:36px;}
}

/* ── Very small phones ── */
@media(max-width:480px){
  .nav-logo-img{height:20px;}
  .mm-item{font-size:28px;}

  /* Typography scale-down */
  .hero-h1{font-size:clamp(36px,10vw,56px);}
  .about-headline{font-size:clamp(44px,12vw,68px);}
  .about-stats-row{grid-template-columns:repeat(2,1fr);}
  .service-hero-title{font-size:clamp(36px,10vw,52px);}
  .section-title{font-size:clamp(22px,7vw,34px);}
  .brief-headline{font-size:clamp(34px,9vw,56px);}
  .brief-body{font-size:13px;}

  /* Tighter padding */
  .brief-form-wrap{padding:28px 18px;}
  .brief-grid{gap:32px;}
  .contact-cell{padding:24px 18px;}
  .wt-card{padding:28px 18px;}
  .value-card{padding:28px 18px;}
  .team-card{padding:28px 18px;}
  .service-panel{padding:32px 24px;}

  /* Work / stats */
  .work-stat-n{font-size:40px;}

  /* CS cards */
  .cs-card{flex:0 0 230px;height:280px;}
  .cs-card-bg,.cs-card-overlay{height:130px;}
  .cs-card-content{height:150px;}
  .cs-card-cta{flex:0 0 200px;height:280px;}
  .testimonial-section::before{display:none;}
  .t-wm{display:none;}
  .home-cta{padding:48px 16px !important;}
}

/* ── CLIENT LOGO TICKER ─────────────────────────────────── */
.ticker-set {
  display: flex;
  align-items: center;
  gap: 72px;
  padding-right: 72px;
  flex-shrink: 0;
}
.ticker {
  display: flex;
  align-items: center;
  animation: ticker-scroll 45s linear infinite;
  width: max-content;
}
.ticker:hover { animation-play-state: paused; }
@keyframes ticker-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.client-logo-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 160px;
  flex-shrink: 0;
}
.client-logo-img {
  height: 150px;
  width: auto;
  max-width: 280px;
  object-fit: contain;
  opacity: 0.5;
  filter: brightness(0) invert(1);
  transition: opacity 0.25s;
}
.client-logo-img:hover { opacity: 1; }

/* ── GALLERY CARD IMAGES ────────────────────────────────── */
.gallery-card-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.gallery-card:hover .gallery-card-bg {
  transform: scale(1.05);
}

/* ── LIGHTBOX ──────────────────────────────────────────────── */
.lb-overlay {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(0,0,0,.95);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .3s var(--ease);
}
.lb-overlay.open { opacity: 1; pointer-events: all; }
.lb-inner {
  display: flex; flex-direction: column; align-items: center;
  max-width: 90vw; max-height: 92vh;
}
.lb-img {
  max-width: 85vw; max-height: 72vh;
  object-fit: contain; display: block;
  opacity: 1; transition: opacity .18s ease;
}
.lb-img.fading { opacity: 0; }
.lb-info { padding: 18px 0 0; text-align: center; }
.lb-type {
  font-size: 9px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--red); font-weight: 600; margin-bottom: 7px;
}
.lb-title {
  font-family: var(--display); font-size: clamp(18px, 3vw, 34px);
  letter-spacing: .05em; text-transform: uppercase; color: var(--t1); line-height: 1;
}
.lb-result { font-size: 11px; color: var(--t3); margin-top: 7px; letter-spacing: .08em; }
.lb-counter {
  font-size: 9px; color: var(--t3); letter-spacing: .18em;
  text-transform: uppercase; margin-top: 12px;
}
.lb-close {
  position: fixed; top: 22px; right: 26px;
  background: none; border: 1px solid rgba(255,255,255,.18);
  color: var(--t1); font-size: 22px; line-height: 1;
  width: 44px; height: 44px; cursor: pointer;
  transition: border-color .2s, color .2s; display: flex; align-items: center; justify-content: center;
}
.lb-close:hover { border-color: var(--red); color: var(--red); }
.lb-prev, .lb-next {
  position: fixed; top: 50%; transform: translateY(-50%);
  background: none; border: 1px solid rgba(255,255,255,.12);
  color: var(--t1); font-size: 20px;
  width: 48px; height: 72px; cursor: pointer;
  transition: border-color .2s, color .2s, background .2s;
  display: flex; align-items: center; justify-content: center;
}
.lb-prev { left: 20px; }
.lb-next { right: 20px; }
.lb-prev:hover, .lb-next:hover {
  border-color: var(--red); color: var(--red); background: rgba(210,31,39,.08);
}
.gallery-card, .work-featured-card { cursor: pointer; }
@media(max-width:768px) {
  .lb-prev { left: 6px; } .lb-next { right: 6px; }
  .lb-prev, .lb-next { width: 38px; height: 56px; }
  .lb-img { max-width: 92vw; max-height: 55vh; }
}

/* ── HONEYPOT (anti-spam, invisible to real users) ─────────── */
.honeypot-field {
  position: absolute;
  left: -9999px;
  top: -9999px;
  opacity: 0;
  height: 0;
  overflow: hidden;
  pointer-events: none;
}
