
/* ============ Fox&Fifth — faithful static replica ============ */
:root{
  --bg:#210000;            /* live base (rgb 33,0,0) */
  --bg-2:#1a0000;          /* live section bg (rgb 26,0,0) */
  --panel:#260606;
  --panel-hover:#360c0c;
  --border:#4a1414;
  --card-bd:rgba(255,93,0,.55);   /* prominent box border, site-wide */
  --orange:#ff5d00;        /* live accent */
  --orange-hover:#ff7a2e;
  --white:#ffffff;
  --t-2:rgba(255,255,255,.7);
  --t-3:rgba(255,255,255,.52);
  --maxw:1180px;
  --display:"BW Gradual Black","BW Gradual",proxima-nova,Arial,sans-serif;
  --display-bold:"BW Gradual Bold","BW Gradual",proxima-nova,Arial,sans-serif;
  --body:proxima-nova,Arial,Helvetica,sans-serif;
}
@font-face{font-family:"BW Gradual Black";src:url("/assets/fonts/Bw_Gradual_Black.ttf") format("truetype");font-weight:900;font-display:swap;}
@font-face{font-family:"BW Gradual Bold";src:url("/assets/fonts/Bw_Gradual_Bold.ttf") format("truetype");font-weight:700;font-display:swap;}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;overscroll-behavior-y:none}
:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:2px}
::selection{background:#ff5d00;color:#000}
h1,h2,.section-title{text-wrap:balance}
body{
  background:var(--bg);color:var(--white);font-family:var(--body);
  font-size:18px;line-height:1.55;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
.skip-link{position:absolute;left:-9999px;top:16px;z-index:200;background:var(--orange);color:#000;
  padding:14px 22px;border-radius:4px;font-family:var(--body);font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;font-size:13px}
.skip-link:focus{left:16px}
.visually-hidden{position:absolute!important;width:1px;height:1px;margin:-1px;padding:0;border:0;
  clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap}
/* Visible, polite form feedback (newsletter + contact) */
.form-msg{min-height:1.4em;margin:10px auto 0;font-size:14.5px;text-align:inherit}
.form-msg.ok{color:#fff}
.form-msg.err{color:var(--orange)}
.form-msg a{color:var(--orange);text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
section{position:relative}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:900;line-height:1.02;letter-spacing:-.02em}
.eyebrow{font-family:var(--body);font-weight:700;text-transform:uppercase;letter-spacing:.28em;
  font-size:12px;color:var(--orange);margin-bottom:22px}
.lead{color:var(--t-2);font-size:19px;line-height:1.6;max-width:620px}
p{color:var(--t-2)}
.accent{color:var(--orange)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--body);font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;font-size:13.5px;padding:18px 30px;border-radius:4px;
  cursor:pointer;border:1px solid transparent;transition:.18s ease;line-height:1}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(5px)}
.btn-primary{background:var(--orange);color:#000}
.btn-primary:hover{background:var(--orange-hover)}
.btn-ghost{background:transparent;border-color:var(--border);color:#fff}
.btn-ghost:hover{border-color:var(--orange);color:#fff}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:90;transition:background .3s,backdrop-filter .3s;
  padding:18px 0}
.site-header.scrolled,.site-header.solid{background:rgba(26,10,5,.95);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(74,42,31,.5)}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.logo img{height:50px}
.nav{display:flex;align-items:center;gap:34px}
.nav a{font-family:var(--body);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:13px;
  color:#fff;opacity:.85;transition:.18s;position:relative;padding:6px 0}
.nav a:hover,.nav a.active{opacity:1;color:var(--orange)}
.nav a.active::after{content:"";position:absolute;left:0;bottom:-2px;width:18px;height:2px;background:var(--orange)}
.has-drop{position:relative}
.drop{position:absolute;top:130%;left:50%;transform:translateX(-50%) translateY(8px);min-width:280px;
  background:var(--bg-2);border:1px solid var(--card-bd);border-radius:8px;padding:8px;opacity:0;visibility:hidden;
  transition:.2s;box-shadow:0 30px 60px rgba(0,0,0,.5)}
.has-drop:hover .drop,.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{display:block;padding:12px 16px;border-radius:6px;opacity:.9;letter-spacing:.04em;transition:.18s ease}
.drop a:hover{background:var(--panel-hover);color:var(--orange);padding-left:22px;opacity:1}
.nav-cta{margin-left:6px}
.burger{display:none;background:none;border:0;color:#fff;cursor:pointer;flex-direction:column;gap:5px;padding:8px;
  min-width:44px;min-height:44px;align-items:center;justify-content:center}
.burger span{width:24px;height:2px;background:#fff;display:block;transition:.2s}
.mobile-nav{position:fixed;inset:0;background:var(--bg);z-index:95;transform:translateX(100%);
  visibility:hidden;transition:transform .3s,visibility 0s .3s;
  display:flex;flex-direction:column;padding:90px 32px 32px;overflow-y:auto;
  padding-bottom:max(32px,env(safe-area-inset-bottom))}
.mobile-nav.open{transform:translateX(0);visibility:visible;transition:transform .3s,visibility 0s}
.mobile-nav a{font-family:var(--display);font-size:30px;padding:14px 0;border-bottom:1px solid var(--border)}
.mobile-nav .close{position:absolute;top:24px;right:26px;font-size:34px;background:none;border:0;color:#fff;cursor:pointer}

/* ---------- Hero (home) ---------- */
.hero{min-height:56vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  position:relative;overflow:hidden;padding:120px 0 44px}
.field-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.field-bg canvas{position:absolute;inset:0;width:100%;height:100%}
.has-field{position:relative;overflow:hidden}
.has-field>.wrap{position:relative;z-index:2}
.hero .wrap{position:relative;z-index:2}
.hero h1{font-size:clamp(38px,6.6vw,76px);text-transform:uppercase;letter-spacing:-.025em;line-height:1.0;min-height:1em}
.swap{display:inline-flex;flex-wrap:wrap;gap:0 .28em;justify-content:center}
.swap .static-word,.swap .swap-word{display:inline-block;transition:transform .85s cubic-bezier(.4,0,.2,1),opacity .75s ease;will-change:transform,opacity}
.swap .static-word{color:#fff}
.swap .swap-word{color:var(--orange);position:relative}
.hero-divider{display:flex;justify-content:center;margin:30px 0 28px}
.hero-divider span{width:72px;height:3px;border-radius:2px;background:var(--orange);display:block}
.hero .lead{margin:0 auto 40px;max-width:660px;text-align:center}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
/* ---------- Generic page hero ---------- */
.page-hero{padding:190px 0 70px}
.page-hero h1{font-size:clamp(40px,7.5vw,86px);text-transform:uppercase}
.page-hero .lead{margin-top:26px}
.page-hero.two-tone .l2{color:var(--orange)}
.page-hero.notfound{padding-bottom:140px;text-align:center}
.page-hero.notfound .lead{margin:26px auto 40px}

/* ---------- Sections ---------- */
.sec{padding:96px 0}
.sec-tight{padding:64px 0}
.band{background:var(--bg-2)}
.section-title{font-size:clamp(30px,4.2vw,46px);line-height:1.06;max-width:880px;text-transform:none}

/* ---------- Client logo strip ---------- */
.clients{padding:48px 0;background:linear-gradient(to right,#0d0000 0%,#3d0000 30%,#5a0000 50%,#3d0000 70%,#0d0000 100%)}
.clients .eyebrow{text-align:center;color:rgba(255,255,255,.7);letter-spacing:.22em}
.client-carousel{overflow:hidden;margin-top:24px;padding:12px 0}
.client-track{display:flex;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.client-page{flex:0 0 100%;display:flex;align-items:center;justify-content:space-around;gap:30px}
.client-track img{height:60px;width:auto;transform-origin:center;opacity:.85;
  filter:grayscale(1) brightness(2.1);transition:opacity .25s,filter .25s}
/* Measured ink-area equalisation. Every logo PNG is a 200×200 canvas with the
   mark occupying a measured content box inside (canvas alpha-channel analysis).
   The uniform 60px layout box keeps carousel rows stable; the per-logo
   transform:scale(k) equalises the VISUAL ink area across all 19 marks
   (target ~3000px² content area, ink height clamped 26–62px, ink width ≤120px).
   k = targetContentH / (60 × contentH/200). Hover is opacity/filter only so it
   never fights the scale transform. */
.clogo-colt{transform:scale(2.18)}
.clogo-devo{transform:scale(3.13)}
.clogo-dewynters{transform:scale(1.99)}
.clogo-ee{transform:scale(2.07)}
.clogo-ey{transform:scale(1.74)}
.clogo-ford{transform:scale(2.28)}
.clogo-gsg{transform:scale(1.03)}
.clogo-gth{transform:scale(0.91)}
.clogo-hpe{transform:scale(1.85)}
.clogo-iagto{transform:scale(2.54)}
.clogo-jlr{transform:scale(1.19)}
.clogo-openreach{transform:scale(3.01)}
.clogo-puma{transform:scale(1.90)}
.clogo-rentokil{transform:scale(1.72)}
.clogo-resillion{transform:scale(1.28)}
.clogo-abb{transform:scale(2.14)}
.clogo-avamore{transform:scale(0.92)}
.clogo-bentley{transform:scale(1.41)}
.clogo-btgroup{transform:scale(2.69)}
.client-track img:hover{opacity:1;filter:grayscale(1) brightness(2.6)}
.client-dots{display:flex;gap:9px;justify-content:center;align-items:center;margin-top:34px}
.client-dots .dot{width:26px;height:3px;border-radius:2px;background:rgba(255,255,255,.25);cursor:pointer;transition:.2s;
  position:relative;border:0;padding:0}
.client-dots .dot::after{content:"";position:absolute;left:-9px;right:-9px;top:-21px;bottom:-20px}
.client-dots .dot.on{background:var(--orange)}
@media(max-width:560px){.client-page{gap:18px}.client-track img{height:44px}}

/* ---------- Service cards (home) ---------- */
.svc-cards{display:flex;flex-direction:column;gap:26px;margin-top:54px}
.svc-card{background:rgba(40,8,8,.5);border:1px solid var(--card-bd);border-radius:14px;
  padding:46px;position:relative;overflow:hidden;backdrop-filter:blur(2px)}
/* Prominent, consistent box border across the whole site */
.svc-card,.about-card,.cs-card,.post-card,.casestudy-featured,.loc-card,.direct,.np{border:1px solid var(--card-bd)}
.svc-card .ico{position:absolute;top:34px;right:40px;width:104px;height:104px;border-radius:50%;
  background:var(--orange);display:flex;align-items:center;justify-content:center;color:#1a0000}
.svc-card .ico svg{width:50px;height:50px}
.svc-card h3{font-size:30px;color:var(--orange);text-transform:none;margin-bottom:18px}
.pills{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:20px}
.pill{border:1px solid var(--border);border-radius:40px;padding:6px 15px;font-size:12.5px;color:var(--t-2);
  font-family:var(--body);letter-spacing:.02em}
.svc-card p{max-width:660px;margin-bottom:26px}
.closing-line{text-align:center;font-family:var(--display);font-size:clamp(22px,3vw,34px);line-height:1.25;
  max-width:900px;margin:70px auto 0;text-transform:none;color:rgba(255,255,255,.92)}

/* ---------- Stats ---------- */
.stats-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px 70px;margin-top:60px}
.stat{position:relative;padding-left:26px}
.stat::before{content:"";position:absolute;left:0;top:14px;width:9px;height:9px;border-radius:50%;background:var(--orange)}
.stat .num{font-family:var(--display);font-size:clamp(48px,7vw,82px);line-height:1;letter-spacing:-.03em}
.stat .lbl{color:var(--t-2);margin-top:14px;font-size:16px}

/* ---------- Showreel ---------- */
.video-frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;background:#000;
  border:1px solid var(--border)}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---------- Testimonials ---------- */
.testi{text-align:center;padding:110px 0}
.testi .qmark{font-family:var(--display);color:var(--orange);font-size:80px;line-height:.6;margin-bottom:30px}
/* Grid-stacked slides: the stage sizes to the tallest quote (no fixed heights),
   so long quotes can't overflow into the dots at narrow widths. */
.testi-stage{display:grid;max-width:840px;margin:0 auto}
.testi-slide{grid-area:1/1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .5s ease}
.testi-slide.active{opacity:1;visibility:visible}
.testi-quote{font-size:clamp(20px,2.6vw,30px);line-height:1.45;font-family:var(--display-bold);font-weight:700;
  text-transform:none;letter-spacing:-.01em}
.testi-name{margin-top:30px;font-weight:700;font-family:var(--body)}
.testi-role{color:var(--t-3);font-size:15px;margin-top:4px}
.testi-cta{margin-top:40px}
.dots{display:flex;gap:9px;justify-content:center;align-items:center;margin-top:30px}
.dots .dot{width:26px;height:3px;border-radius:2px;background:var(--border);cursor:pointer;transition:.2s;
  position:relative;border:0;padding:0}
.dots .dot::after{content:"";position:absolute;left:-9px;right:-9px;top:-21px;bottom:-20px}
.dots .dot.on{background:var(--orange)}

/* ---------- CTA band ---------- */
/* Padding is heavier below: the H2's cap-height whitespace makes equal padding
   read top-heavy, so the button needs more room to the band's bottom edge. */
.cta-band{text-align:center;padding:120px 0 150px;background:radial-gradient(120% 100% at 50% 0%,#2a0f07 0%,#1a0a05 70%)}
.cta-band h2{font-size:clamp(34px,6vw,72px);text-transform:uppercase;line-height:1}
.cta-band .lead{margin:24px auto 0;text-align:center}
/* Consistent headline→button gap whether or not the band has a lead line
   (Our Work / About / Meet the Team / Insights bands have none). */
.cta-band .btn{margin-top:38px}

/* ---------- Newsletter strip ---------- */
.news{text-align:center;padding:96px 0;background:var(--bg-2)}
.news h2{font-size:clamp(28px,4.4vw,52px);text-transform:uppercase;margin-bottom:16px}
.news .lead{margin:0 auto 30px;text-align:center}
.news-form{display:flex;gap:12px;max-width:520px;margin:0 auto;flex-wrap:wrap}
.news-form input{flex:1;min-width:220px;background:transparent;border:0;border-bottom:1px solid var(--border);
  padding:14px 4px;color:#fff;font-family:var(--body);font-size:16px;transition:border-color .18s ease}
.news-form .form-msg{flex-basis:100%;text-align:center}
.news-form input::placeholder{color:var(--t-3)}
.news-form input:focus{border-color:var(--orange)}

/* ---------- Footer ---------- */
.footer{padding:80px 0 30px;border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:50px}
.footer .f-logo{height:34px;margin-bottom:20px}
.footer .blurb{color:var(--t-2);max-width:330px;font-size:15.5px}
.footer h4{font-family:var(--body);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:12px;
  color:var(--orange);margin-bottom:22px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:12px}
.footer ul a{color:var(--t-2);font-size:15px}
.footer ul a:hover{color:#fff}
.footer .contact a{color:var(--t-2);font-size:15px;display:block;margin-bottom:12px}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{width:38px;height:38px;border:1px solid var(--border);border-radius:8px;display:flex;
  align-items:center;justify-content:center;color:var(--t-2);transition:.2s;position:relative}
.socials a::after{content:"";position:absolute;inset:-4px}
.socials a:hover{border-color:var(--orange);color:var(--orange)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  margin-top:60px;padding-top:24px;border-top:1px solid var(--border);font-size:13px;color:var(--t-3)}
.footer-bottom .sign{font-family:var(--display);color:#fff;letter-spacing:.02em}
.footer-bottom .sign b{color:var(--orange);font-weight:900}
.footer-bottom a{color:var(--t-3)}
.footer-bottom a:hover{color:#fff}

/* ---------- Newsletter popup ---------- */
.np{position:fixed;right:26px;bottom:26px;width:min(330px,calc(100vw - 32px));background:#220d06;border:1px solid var(--card-bd);
  border-radius:12px;padding:24px;z-index:80;box-shadow:0 30px 60px rgba(0,0,0,.55);
  transform:translateY(140%);transition:transform .5s cubic-bezier(.16,1,.3,1)}
.np.show{transform:translateY(0)}
.np .x{position:absolute;top:0;right:0;min-width:44px;min-height:44px;display:flex;align-items:center;
  justify-content:center;background:none;border:0;color:var(--t-3);font-size:18px;cursor:pointer}
.np .eyebrow{margin-bottom:10px}
.np h4{font-family:var(--display);font-size:20px;text-transform:uppercase;margin-bottom:10px;line-height:1.05}
.np p{font-size:14px;margin-bottom:16px}
.np input{width:100%;background:transparent;border:1px solid var(--border);border-radius:6px;padding:11px 12px;
  color:#fff;margin-bottom:12px;font-family:var(--body);font-size:16px;transition:border-color .18s ease}
.np .form-msg{font-size:13px;margin:0 0 8px;text-align:left}
.np input:focus{border-color:var(--orange)}
.np .btn{width:100%;justify-content:center;padding:13px}
.np .nothanks{display:block;text-align:center;margin-top:4px;padding:14px 0;min-height:44px;color:var(--t-3);
  font-size:13px;background:none;border:0;width:100%;cursor:pointer}

/* ---------- Services page: honest / numbered ---------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.two-col h2{font-size:clamp(26px,3.4vw,40px);text-transform:none;line-height:1.12}
.two-col .body p{margin-bottom:20px}
.numbered{display:grid;grid-template-columns:1fr 1.4fr;gap:40px 60px;padding:48px 0;border-top:1px solid var(--border)}
/* Big index numerals: watermark-weight orange — present but not shouting. */
.numbered .n{font-family:var(--display);font-size:clamp(46px,7vw,86px);color:var(--orange);line-height:.9;opacity:.6}
.numbered h3{font-size:30px;text-transform:none;margin:14px 0 18px}
.numbered .explore{font-family:var(--body);font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  font-size:13px;color:var(--orange);display:inline-flex;gap:10px;align-items:center}
.numbered .explore:hover .arr{transform:translateX(5px)}
.numbered .body p{margin-bottom:16px}
/* Client-name pills: same .pill component as the home service cards, placed
   below the section title in the headline column. */
.client-pills{margin-top:26px;margin-bottom:0}

/* ---------- Service detail: included list ---------- */
.included{border-top:1px solid var(--border)}
.included .row{display:grid;grid-template-columns:1fr 1.5fr;gap:40px;padding:34px 0;border-bottom:1px solid var(--border)}
.included .row h4{font-family:var(--display-bold);font-weight:700;font-size:21px;text-transform:none;color:#fff}
.statrow{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin:60px 0;text-align:center}
.statrow .num{font-family:var(--display);font-size:clamp(40px,6vw,68px);color:var(--orange);line-height:1}
.statrow .lbl{text-transform:uppercase;letter-spacing:.16em;font-size:12px;color:var(--t-2);margin-top:12px}

/* ---------- Our Work ---------- */
.film-feature{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--border);
  aspect-ratio:16/9;background:#000;margin-top:46px}
.film-feature .thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55}
.film-feature .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.8));
  display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;padding:46px}
.film-feature .cat{color:var(--orange);text-transform:uppercase;letter-spacing:.2em;font-size:12px;font-weight:700;margin-bottom:12px}
.film-feature h3{font-size:clamp(24px,3.4vw,40px);text-transform:uppercase;margin-bottom:22px;max-width:640px}
.film-counter{position:absolute;top:24px;right:28px;font-family:var(--display);color:#fff;opacity:.8;letter-spacing:.1em}
.film-nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;
  background:rgba(0,0,0,.5);border:1px solid var(--border);color:#fff;display:flex;align-items:center;
  justify-content:center;cursor:pointer;z-index:3;transition:background .18s ease,color .18s ease,border-color .18s ease}
.film-nav:hover{background:var(--orange);color:#000}
.film-nav.prev{left:18px}.film-nav.next{right:18px}
.film-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:18px}
.film-thumb{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:16/9;cursor:pointer;
  border:1px solid var(--border);background:#000;padding:0;display:block;width:100%;
  font:inherit;color:inherit;text-align:left}
.film-thumb img{width:100%;height:100%;object-fit:cover;opacity:.7;transition:.25s}
.film-thumb:hover img{opacity:1;transform:scale(1.04)}
.film-thumb .cap{position:absolute;left:0;right:0;bottom:0;padding:10px 12px;font-size:12px;
  background:linear-gradient(transparent,rgba(0,0,0,.85));color:#fff}
.section-title.upper{text-transform:uppercase}
.casestudy-featured{background:var(--panel);border:1px solid var(--card-bd);border-radius:16px;padding:48px;
  display:grid;grid-template-columns:1.3fr 1fr;gap:50px;margin-top:46px}
.cs-card-cat{color:var(--orange);text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:700}
.cs-featured-title{font-size:30px;text-transform:uppercase;margin:10px 0 6px}
.cs-block h4{font-family:var(--body);font-weight:700;letter-spacing:.16em;line-height:1.55;
  color:var(--orange);text-transform:uppercase;font-size:12px;margin:20px 0 8px}
.cs-stats{display:flex;gap:40px;align-items:flex-end}
.cs-stats .num{font-family:var(--display);font-size:54px;color:var(--orange);line-height:1}
.cs-stats .lbl{text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--t-2)}
.cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:30px}
.cs-grid > :last-child:nth-child(odd){grid-column:1/-1}
.cs-card{background:var(--panel);border:1px solid var(--card-bd);border-radius:14px;padding:34px;transition:.25s}
.cs-card:hover{border-color:var(--orange);background:var(--panel-hover)}
.cs-card .cat{color:var(--orange);text-transform:uppercase;letter-spacing:.18em;font-size:11px;font-weight:700}
.cs-card .cs-card-title{font-family:var(--display);font-size:24px;text-transform:uppercase;margin:10px 0 14px}
.cs-card p{font-size:15px;margin-bottom:18px}
.readmore{font-family:var(--body);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;
  color:var(--orange);display:inline-flex;gap:8px;align-items:center}
button.readmore{background:none;border:0;cursor:pointer;padding:12px 0;min-height:44px}
button.readmore:hover{color:var(--orange-hover)}

/* ---------- Modal (video) ----------
   The iframe is absolutely positioned inside a fixed 16:9 frame (same pattern as
   .video-frame). Never size the iframe with height:100% against an aspect-ratio
   parent: that percentage resolves to 0 in several engines and the video collapses. */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:120;display:flex;align-items:center;
  justify-content:center;padding:30px;opacity:0;visibility:hidden;
  transition:opacity .2s ease,visibility 0s .2s;overscroll-behavior:contain}
.modal.open{opacity:1;visibility:visible;transition:opacity .2s ease,visibility 0s}
.modal .inner{width:min(1100px,92vw,calc((100vh - 60px)*16/9));aspect-ratio:16/9;position:relative;
  background:#000;border-radius:10px}
.modal iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:10px}
.modal .x{position:absolute;top:0;right:0;z-index:2;width:48px;height:48px;display:flex;align-items:center;
  justify-content:center;background:rgba(0,0,0,.65);border:1px solid var(--border);border-radius:0 10px 0 10px;
  color:#fff;font-size:28px;line-height:1;cursor:pointer}
.modal .x:hover{background:var(--orange);color:#000}

/* ---------- About team ---------- */
.about-cards{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:46px}
.about-card{background:var(--panel);border:1px solid var(--card-bd);border-radius:14px;padding:34px}
.about-card h3{font-family:var(--display);font-size:20px;text-transform:uppercase;color:var(--orange);margin-bottom:12px}
.about-card p{font-size:15.5px}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px 24px;margin-top:50px}
.team-member{text-align:center;display:block;color:inherit}
/* Plain cut-out PNGs straight on the page background — no orange circle, no shadow. */
.team-photo{width:150px;height:150px;margin:0 auto 18px;
  display:flex;align-items:flex-end;justify-content:center;position:relative}
.team-photo img{width:100%;height:100%;object-fit:contain;object-position:bottom center}
.team-member .nm{font-family:var(--display);font-size:18px;text-transform:uppercase}
a.team-member:hover .nm{color:var(--orange)}
.team-member .ro{color:var(--t-3);font-size:13px;margin-top:6px}
.team-link{text-align:center;margin-top:46px}

/* ---------- Meet the Team page ---------- */
.team-hero{padding-bottom:30px}
.team-hero .back-link{margin-bottom:30px}
.team-rows{padding-top:40px}
.person-row{display:grid;grid-template-columns:300px 1fr;gap:50px;align-items:start;
  padding:56px 0;border-top:1px solid var(--border)}
.person-row:first-child{border-top:0}
.person-photo{border:1px solid var(--card-bd);border-radius:14px;background:var(--bg-2);
  aspect-ratio:1/1;display:flex;align-items:flex-end;justify-content:center;overflow:hidden;padding:18px 18px 0}
.person-photo img{width:100%;height:100%;object-fit:contain;object-position:bottom center}
.person-bio .eyebrow{margin-bottom:12px}
.person-bio h2{font-size:clamp(26px,3.4vw,40px);text-transform:uppercase;margin-bottom:18px}
.person-bio p{margin-bottom:16px;max-width:680px}
.bio-books{display:flex;gap:16px;margin-top:24px;flex-wrap:wrap}
.bio-books img{height:140px;width:auto;border-radius:6px;border:1px solid var(--border)}
@media(max-width:768px){
  .person-row{grid-template-columns:1fr;gap:26px}
  .person-photo{max-width:280px}
}
.pullquote{text-align:center;max-width:760px;margin:80px auto 0}
.pullquote .q{font-family:var(--display);font-size:clamp(26px,4vw,44px);text-transform:none;line-height:1.05}
.pullquote p{margin-top:24px}

/* ---------- Insights ---------- */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px}
.post-card{background:var(--panel);border:1px solid var(--card-bd);border-radius:14px;padding:34px;transition:.25s;display:flex;flex-direction:column}
.post-card:hover{border-color:var(--orange);background:var(--panel-hover);transform:translateY(-3px)}
.post-card .post-meta{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.post-card .chip{border:1px solid var(--orange);color:var(--orange);border-radius:40px;
  padding:4px 13px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.14em}
.post-card .readtime{color:var(--t-3);font-size:12.5px}
.post-card .date{color:var(--t-3);font-size:13px;display:flex;align-items:center;gap:8px;margin-bottom:18px}
.post-card h3{font-family:var(--display);font-size:21px;text-transform:uppercase;line-height:1.12;margin-bottom:16px}
.post-card p{font-size:15px;flex:1;margin-bottom:20px}

/* ---------- Article ---------- */
.article{max-width:820px;margin:0 auto;padding:170px 0 40px;
  padding-left:clamp(20px,5vw,40px);padding-right:clamp(20px,5vw,40px)}
.back-link{display:inline-flex;align-items:center;gap:10px;color:var(--orange);text-transform:uppercase;
  letter-spacing:.12em;font-size:12px;font-weight:700;margin-bottom:36px}
.article .date{color:var(--t-3);font-size:14px;margin-bottom:18px}
.article h1{font-size:clamp(34px,5.4vw,62px);text-transform:uppercase;line-height:1.02;margin-bottom:30px}
.article .article-lead{font-size:22px;line-height:1.5;color:#fff;margin-bottom:18px;font-family:var(--body)}
.article h2{font-family:var(--display-bold);font-weight:700;font-size:24px;letter-spacing:-.02em;text-transform:none;margin:38px 0 16px;color:#fff}
.article p{font-size:18px;line-height:1.7;margin-bottom:20px;color:var(--t-2)}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:50px}
.contact-title{text-transform:uppercase;font-size:34px}
.contact-form{margin-top:30px}
.loc-list{margin-top:30px}
.field{margin-bottom:18px}
.field input,.field textarea{width:100%;background:var(--panel);border:1px solid var(--border);border-radius:8px;
  padding:16px;color:#fff;font-family:var(--body);font-size:16px;transition:border-color .18s ease}
.field textarea{min-height:150px;resize:vertical}
.field input:focus,.field textarea:focus{border-color:var(--orange)}
.contact-form .btn{width:100%;justify-content:center}
.contact-form .form-msg{text-align:center}
/* Honeypot field: visually removed, still in the DOM for bots to fill. */
.contact-form .hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.direct{margin-top:28px;background:var(--panel);border:1px solid var(--card-bd);border-radius:12px;padding:26px}
.direct h3{font-family:var(--display);text-transform:none;font-size:18px;margin-bottom:16px}
.direct .lbl{color:var(--orange);font-size:12px;text-transform:uppercase;letter-spacing:.12em}
.direct .val{margin:4px 0 14px;color:var(--t-2)}
.loc-card{background:var(--panel);border:1px solid var(--card-bd);border-radius:14px;overflow:hidden;margin-bottom:24px}
.loc-card iframe{width:100%;height:200px;border:0;filter:grayscale(.3) invert(.9) hue-rotate(180deg) contrast(.9)}
.loc-body{padding:24px;display:flex;gap:14px}
.loc-body .pin{color:var(--orange);flex-shrink:0}
.loc-body h3{font-family:var(--display);text-transform:none;font-size:18px;margin-bottom:8px;line-height:1.02;letter-spacing:-.02em}
.loc-body address{font-style:normal;color:var(--t-2);font-size:15px;line-height:1.6}

/* ---------- Cookie consent banner ---------- */
.consent{position:fixed;left:0;right:0;bottom:0;z-index:110;background:#220d06;
  border-top:1px solid var(--card-bd);box-shadow:0 -18px 40px rgba(0,0,0,.45);
  display:flex;align-items:center;justify-content:center;gap:26px;flex-wrap:wrap;
  padding:18px clamp(20px,5vw,40px)}
.consent p{font-size:14px;color:var(--t-2);margin:0;max-width:560px}
.consent a{color:var(--orange);text-decoration:underline}
.consent-actions{display:flex;gap:12px}
.consent .btn{padding:10px 22px;font-size:13px}
@media(max-width:560px){
  .consent{flex-direction:column;gap:14px;text-align:center}
  .consent-actions{width:100%}
  .consent .btn{flex:1;justify-content:center}
}

/* ---------- Reveal animation (JS-gated: no-JS users see everything) ---------- */
.js .reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.js .reveal.in{opacity:1;transform:none}

/* ---------- Legal ---------- */
.legal{max-width:820px;margin:0 auto;padding:170px 0 40px;
  padding-left:clamp(20px,5vw,40px);padding-right:clamp(20px,5vw,40px)}
.legal h1{font-size:clamp(34px,5vw,56px);text-transform:uppercase;margin-bottom:10px}
.legal .updated{color:var(--t-3);margin-bottom:40px}
.legal h2{font-family:var(--display-bold);font-weight:700;font-size:19px;text-transform:uppercase;margin:34px 0 12px;color:var(--orange);letter-spacing:.04em}
.legal p{margin-bottom:16px;color:var(--t-2)}
.legal ul{margin:0 0 16px 22px;color:var(--t-2)}
.legal li{margin-bottom:8px}

/* ---------- Our Work mobile fixes ---------- */
@media(max-width:768px){
  .casestudy-featured{padding:28px;margin-left:0;margin-right:0;transform:none}
  .cs-stats{flex-wrap:wrap;gap:24px}
  .film-feature{aspect-ratio:auto;min-height:62vw}
  .film-feature .overlay{padding:24px;padding-top:64px}
  .film-counter{top:16px;left:20px;right:auto}
  .film-nav{top:16px;transform:none;width:44px;height:44px}
  .film-nav.prev{left:auto;right:72px}
  .film-nav.next{right:18px}
}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .nav,.nav-cta{display:none}
  .burger{display:flex}
  .footer-grid{grid-template-columns:1fr;gap:36px}
  .two-col,.numbered,.included .row,.contact-grid,.casestudy-featured,.cs-grid{grid-template-columns:1fr;gap:26px}
  .posts,.team-grid,.film-thumbs,.statrow{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr}
  .about-cards{grid-template-columns:1fr}
}
@media(max-width:560px){
  .wrap{padding:0 20px}
  .posts,.team-grid,.film-thumbs,.statrow{grid-template-columns:1fr}
  .svc-card{padding:30px}
  .svc-card .ico{width:56px;height:56px;top:24px;right:24px}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%;justify-content:center}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js .reveal{opacity:1;transform:none}
}
/* Breadcrumbs + related links (SEO/AEO) */
.breadcrumb{margin:0 0 1.25rem}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem .65rem;padding:0;margin:0;font-size:.78rem;letter-spacing:.02em;opacity:.7}
.breadcrumb li{display:flex;align-items:center;gap:.65rem}
.breadcrumb li:not(:last-child)::after{content:"\203A";opacity:.5}
.breadcrumb a{color:inherit;text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb li[aria-current="page"]{opacity:.9}
.related-list{list-style:none;padding:0;margin:0;display:grid;gap:.55rem}
.related-list a{color:inherit;text-decoration:none;border-bottom:1px solid currentColor;padding-bottom:2px}
.related-list a:hover{opacity:.7}
.related-service{margin-top:1.5rem;font-size:.9rem;opacity:.85}
.related-service a{color:inherit;border-bottom:1px solid currentColor}
