/*
Theme Name: No Filter Lighting
Theme URI: https://nofilterlighting.com
Author: No Filter Lighting
Author URI: https://nofilterlighting.com
Description: Custom theme for No Filter Lighting — cinema-grade lighting, balloon, power and transport hire. Built from hand-coded prototype HTML for maximum performance and fidelity.
Version: 1.5.7
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: nfl
Tags: business, custom-colors, custom-logo, custom-menu, featured-images, full-width-template, threaded-comments
*/

/* ═══════════════════════════════════════════════════════════════
   NFL — WordPress theme CSS
   Built from prototype HTML · v1.0 · June 2026
   Source of truth: _assets/squarespace.css (canonical brand system)
   + shared header / hero / footer chrome from the prototype HTML pages

   Layout:
     1  Brand tokens
     2  Globals & resets
     3  Header (utility bar + nav)
     4  Mega menu (homepage Lighting dropdown)
     5  Buttons (.btn and .nfl-btn-* variants)
     6  Hero (homepage + interior pages)
     7  Section helpers (sec-head, dark variant, link button)
     8  Hero foot — markets strip
     9  Markets cards
    10  Department cards (dark band)
    11  Production cards
    12  About / location block (homepage)
    13  Clients wall
    14  CTA banner
    15  Footer
    16  Live-dot pulse
    17  Responsive (all breakpoints)
   ═══════════════════════════════════════════════════════════════ */

/* ───── 1 · BRAND TOKENS ───── */
:root{
  --bg:#fafaf8;
  --paper:#f1efe9;
  --slate:#373e47;
  --slate-2:#49525e;
  --slate-3:#717784;
  --ink:#0a0a0a;
  --line:rgba(10,10,10,.10);
  --line-2:rgba(10,10,10,.18);
  --hot:#ff5b1f;            /* warm orange accent */
  --hot-soft:rgba(255,91,31,.08);
}

/* ───── 2 · GLOBALS & RESETS ───── */
*{ box-sizing:border-box; margin:0; padding:0 }
html{ scroll-behavior:smooth; scroll-padding-top:140px }
html,body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter',sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none }
a:hover{ color:var(--hot); transition:color .2s }
img{ display:block; max-width:100% }
::selection{ background:var(--ink); color:#fff }
.display{ font-family:'Archivo',sans-serif; font-weight:600; letter-spacing:-.025em }
.uppercase{ text-transform:uppercase; letter-spacing:.16em }
.mono{ font-family:'JetBrains Mono', monospace; letter-spacing:.02em }

/* ───── 3 · HEADER (utility bar + nav) ───── */
header.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  background:rgba(250,250,248,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.hdr-pre{
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 40px;
  background:var(--slate); color:#fff;
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.12em;
  text-transform:uppercase; font-weight:500;
}
.hdr-pre .l{ display:flex; gap:32px; align-items:center }
.hdr-pre .l span{ display:flex; align-items:center; gap:8px }
.hdr-pre .dot{
  width:7px; height:7px; border-radius:50%;
  background:var(--hot);
  box-shadow:0 0 10px var(--hot);
}
.hdr-pre a:hover{ color:var(--hot) }

.hdr-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 40px; gap:32px;
}
.monogram{
  display:flex; align-items:center; gap:14px;
  color:var(--ink); text-decoration:none; flex:0 0 auto;
}
.monogram img.logo{ height:40px; width:auto; display:block }
.monogram .lock{
  display:flex; flex-direction:column;
  border-left:1px solid var(--line);
  padding-left:14px; gap:2px;
}
.monogram .lock .nm{
  font-family:'Archivo',sans-serif;
  font-weight:700; font-size:14px;
  letter-spacing:.1em; text-transform:uppercase;
}
.monogram .lock .sub{
  font-family:'Archivo',sans-serif;
  font-weight:500; font-size:10.5px;
  letter-spacing:.16em;
  color:var(--slate-3);
  text-transform:uppercase;
}

nav.primary{ flex:1; display:flex; justify-content:flex-end }
nav.primary ul{ list-style:none; display:flex; gap:4px; align-items:center }
nav.primary a{
  font-family:'Archivo',sans-serif;
  font-size:13.5px; font-weight:500;
  color:var(--slate);
  padding:12px 16px; border-radius:6px;
  transition:all .2s ease;
  display:flex; align-items:center; gap:6px;
}
nav.primary a:hover,
nav.primary a.active,
nav.primary li.current-menu-item > a{
  color:var(--ink); background:var(--paper);
}
nav.primary a.cta{
  background:var(--ink); color:#fff;
  padding:12px 22px; font-weight:600;
}
nav.primary a.cta:hover{ background:var(--hot); color:#fff }

/* Hamburger button (hidden on desktop, shown <=960px via responsive block) */
.nav-toggle{
  display:none;
  background:transparent; border:0; cursor:pointer;
  width:44px; height:44px; padding:0;
  align-items:center; justify-content:center;
  position:relative; z-index:60;
  border-radius:6px;
  -webkit-tap-highlight-color:transparent;
}
.nav-toggle:focus-visible{ outline:2px solid var(--hot); outline-offset:2px }
.nav-toggle .bars{
  position:relative; display:block;
  width:22px; height:14px;
}
.nav-toggle .bars span{
  position:absolute; left:0; right:0; height:2px;
  background:var(--ink); border-radius:2px;
  transition:transform .25s ease, top .25s ease .1s, opacity .15s ease;
}
.nav-toggle .bars span:nth-child(1){ top:0 }
.nav-toggle .bars span:nth-child(2){ top:6px }
.nav-toggle .bars span:nth-child(3){ top:12px }
body.nav-open .nav-toggle .bars span:nth-child(1){
  top:6px; transform:rotate(45deg);
  transition:top .25s ease, transform .25s ease .1s;
}
body.nav-open .nav-toggle .bars span:nth-child(2){ opacity:0 }
body.nav-open .nav-toggle .bars span:nth-child(3){
  top:6px; transform:rotate(-45deg);
  transition:top .25s ease, transform .25s ease .1s;
}

/* Mobile menu backdrop + panel (hidden on desktop, controlled by responsive block) */
.nav-backdrop{
  display:none;
  position:fixed; inset:0;
  background:rgba(10,10,10,.4);
  z-index:55;
  opacity:0; transition:opacity .3s ease;
}
body.nav-open .nav-backdrop{ opacity:1 }

.mobile-nav{
  display:none;
  position:fixed; top:0; right:0; bottom:0;
  width:min(86vw, 380px);
  background:#fff;
  z-index:58;
  flex-direction:column;
  justify-content:flex-start;
  align-items:stretch;
  transform:translateX(100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);
  box-shadow:-12px 0 32px rgba(10,10,10,.12);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding:0 0 32px;
}
body.nav-open .mobile-nav{ transform:translateX(0) }
.mobile-nav-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 20px 18px 24px;
  border-bottom:1px solid var(--line);
  background:var(--bg);
  position:sticky; top:0; z-index:2;
}
.mobile-nav-head .monogram{
  display:flex; align-items:center; gap:12px;
  text-decoration:none; color:var(--ink);
}
.mobile-nav-head .monogram img{
  height:32px; width:auto; display:block;
}
.mobile-nav-head .monogram .nm{
  font-family:'Archivo',sans-serif; font-weight:700;
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
}
.mobile-nav-close{
  width:44px; height:44px; padding:0;
  border:0; background:transparent; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:6px;
  -webkit-tap-highlight-color:transparent;
}
.mobile-nav-close:hover{ background:var(--paper) }
.mobile-nav-close:focus-visible{ outline:2px solid var(--hot); outline-offset:2px }
.mobile-nav-close svg{ width:20px; height:20px; stroke:var(--ink) }
.mobile-nav > ul{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column;
  align-items:stretch;
}
.mobile-nav > ul > li{
  border-bottom:1px solid var(--line);
}
.mobile-nav > ul > li > a,
.mobile-nav .mob-mega-toggle{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px;
  font-family:'Archivo',sans-serif;
  font-size:16px; font-weight:600;
  color:var(--ink); text-decoration:none;
  background:none; border:0; width:100%;
  cursor:pointer; text-align:left;
  min-height:56px;
  -webkit-tap-highlight-color:transparent;
}
.mobile-nav > ul > li > a:hover,
.mobile-nav .mob-mega-toggle:hover{
  background:var(--paper); color:var(--ink);
}
.mobile-nav > ul > li > a.cta{
  background:var(--ink); color:#fff;
  margin:16px 24px 0; border-radius:8px;
  padding:18px 24px; justify-content:center;
}
.mobile-nav > ul > li > a.cta:hover{ background:var(--hot) }
.mobile-nav > ul > li:has(> a.cta){ border-bottom:0 }

.mob-mega-toggle .caret{
  width:14px; height:14px;
  border-right:2px solid var(--slate);
  border-bottom:2px solid var(--slate);
  transform:rotate(45deg);
  transition:transform .25s ease;
  margin-right:4px;
}
.mob-mega-toggle[aria-expanded="true"] .caret{
  transform:rotate(-135deg);
  margin-top:6px;
}

.mob-mega-panel{
  display:none;
  background:var(--paper);
  padding:8px 24px 18px;
}
.mob-mega-panel[data-open="true"]{ display:block }
.mob-mega-panel .col{ padding:14px 0 6px }
.mob-mega-panel .col + .col{ border-top:1px solid var(--line-2) }
.mob-mega-panel .col h6{
  font-family:'Archivo',sans-serif;
  font-size:10px; letter-spacing:.24em;
  color:var(--slate-3);
  margin-bottom:6px;
  text-transform:uppercase; font-weight:600;
}
.mob-mega-panel .col a{
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 0;
  font-family:'Archivo',sans-serif;
  font-size:14px; font-weight:500;
  color:var(--slate);
  min-height:44px;
  border-bottom:1px solid rgba(10,10,10,.06);
}
.mob-mega-panel .col a:last-child{ border-bottom:0 }
.mob-mega-panel .col a small{
  font-family:'Archivo',sans-serif;
  font-size:11px; color:var(--slate-3); font-weight:500;
}
.mob-mega-panel .feature{ display:none } /* hide the desktop feature card on mobile */

/* When mobile nav is open, lock body scroll */
body.nav-open{ overflow:hidden }

/* ───── 4 · MEGA MENU (Lighting dropdown on homepage) ───── */
.has-mega{ position:relative }
.mega{
  position:fixed; left:0; right:0; top:104px;
  background:#fff;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:48px 64px;
  display:none;
  grid-template-columns:1fr 1fr 1fr 1.4fr;
  gap:48px;
  box-shadow:0 24px 48px rgba(10,10,10,.06);
}
.has-mega:hover .mega,
.mega:hover{ display:grid }
.mega .col h6{
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.2em;
  color:var(--slate-3);
  margin-bottom:14px;
  text-transform:uppercase; font-weight:600;
}
.mega .col a{
  display:flex; justify-content:space-between; align-items:center;
  font-size:15px; font-weight:500;
  color:var(--slate);
  padding:11px 0;
  border-bottom:1px solid var(--line);
  transition:padding-left .2s, color .2s;
}
.mega .col a:hover{ color:var(--ink); padding-left:6px }
.mega .col a small{
  font-family:'Archivo',sans-serif;
  font-size:11px; color:var(--slate-3); font-weight:500;
}
.mega .feature{
  position:relative; overflow:hidden;
  border-radius:12px; min-height:240px;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:24px; color:#fff; background:#000;
}
.mega .feature img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; opacity:.7;
}
.mega .feature::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.2),rgba(0,0,0,.85));
  pointer-events:none;
}
.mega .feature .body{ position:relative; z-index:2 }
.mega .feature h4{
  font-family:'Archivo',sans-serif;
  font-weight:600; font-size:22px;
  letter-spacing:-.01em; line-height:1.1;
  margin-bottom:10px;
}
.mega .feature p{
  font-size:13px;
  color:rgba(255,255,255,.85);
  line-height:1.5;
}

/* ───── 5 · BUTTONS ───── */
.btn,
.nfl-btn-primary,
.nfl-btn-ghost,
.nfl-btn-dark{
  display:inline-flex; align-items:center; gap:12px;
  padding:16px 26px;
  font-family:'Archivo',sans-serif;
  font-size:13px; letter-spacing:.04em; font-weight:600;
  border-radius:6px;
  transition:all .25s ease;
  border:1px solid transparent;
  text-decoration:none;
  cursor:pointer;
}
.btn.primary,
.nfl-btn-primary{
  background:var(--hot); color:#fff; border-color:var(--hot);
}
.btn.primary:hover,
.nfl-btn-primary:hover{
  background:#fff; color:var(--ink); border-color:#fff;
}
.btn.ghost,
.nfl-btn-ghost{
  background:transparent; color:#fff;
  border-color:rgba(255,255,255,.4);
}
.btn.ghost:hover,
.nfl-btn-ghost:hover{
  background:#fff; color:var(--ink); border-color:#fff;
}
.btn.dark,
.nfl-btn-dark{
  background:var(--ink); color:#fff; border-color:var(--ink);
}
.btn.dark:hover,
.nfl-btn-dark:hover{
  background:var(--hot); border-color:var(--hot);
}
.btn .arrow,
.nfl-btn-primary .arr,
.nfl-btn-ghost .arr,
.nfl-btn-dark .arr{ transition:transform .25s }
.btn:hover .arrow,
.nfl-btn-primary:hover .arr,
.nfl-btn-ghost:hover .arr,
.nfl-btn-dark:hover .arr{ transform:translateX(4px) }

/* ───── 6 · HERO (homepage + interior pages) ───── */
.hero{
  position:relative; padding:0; margin-top:104px;
  height:min(86vh,820px); overflow:hidden; color:#fff;
}
.hero.short{ min-height:min(50vh,460px); height:auto }
.hero-img{
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
}
.hero::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(120deg,rgba(10,10,10,.85) 0%,rgba(10,10,10,.55) 50%,rgba(10,10,10,.35) 100%);
}
.hero-inner{
  position:relative; z-index:2;
  padding:80px 56px;
  height:100%; min-height:100%;
  display:grid; grid-template-rows:auto 1fr auto; gap:30px;
}
.hero-meta{
  display:flex; justify-content:space-between; align-items:center;
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.hero-meta .crumb{ display:flex; gap:14px; align-items:center }
.hero-meta .crumb span{ opacity:.7 }
.hero-meta .crumb strong{ color:#fff; font-weight:600 }
.crumbs{
  font-family:'Archivo',sans-serif;
  font-size:12px; letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7); font-weight:500;
  display:flex; gap:14px; align-items:center;
}
.crumbs a{ color:rgba(255,255,255,.7); transition:color .2s }
.crumbs a:hover{ color:#fff }
.crumbs .sep{ opacity:.4 }
.crumbs strong{ color:#fff; font-weight:600 }
.hero-cap{ align-self:center; max-width:1100px }
.hero-cap .eye{
  font-family:'Archivo',sans-serif;
  font-size:12px; letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--hot); font-weight:600;
  margin-bottom:24px;
  display:inline-flex; align-items:center; gap:10px;
}
.hero-cap .eye::before{
  content:""; width:30px; height:1px; background:var(--hot);
}
.hero-cap h1{
  font-family:'Archivo',sans-serif;
  font-weight:700;
  font-size:clamp(54px,8vw,128px);
  line-height:.95; letter-spacing:-.035em;
  margin-bottom:30px;
}
.hero-cap h1 em{
  font-style:italic; font-weight:400;
  color:rgba(255,255,255,.7);
}
.hero-cap .lede{
  font-size:18px; line-height:1.55;
  color:rgba(255,255,255,.85);
  max-width:580px; font-weight:400;
}
.hero-cap .lede strong{ color:#fff; font-weight:500 }
.hero-cta-row{
  display:flex; gap:14px; flex-wrap:wrap; align-items:center;
}

/* ───── 7 · SECTION HELPERS ───── */
.sec-head{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:40px; margin-bottom:60px;
  border-bottom:1px solid var(--line);
  padding-bottom:30px;
}
.sec-head .l{ flex:1 }
.sec-head .eye{
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--slate-3); font-weight:600;
  margin-bottom:14px;
  display:inline-flex; align-items:center; gap:10px;
}
.sec-head .eye::before{
  content:""; width:24px; height:1px; background:var(--hot);
}
.sec-head h2{
  font-family:'Archivo',sans-serif;
  font-weight:600;
  font-size:clamp(40px,5.5vw,80px);
  line-height:.98; letter-spacing:-.03em;
  color:var(--ink); max-width:900px;
}
.sec-head h2 em{
  font-style:italic; font-weight:300; color:var(--slate-2);
}
.sec-head .r{
  font-family:'Archivo',sans-serif;
  font-size:13px;
  color:var(--slate);
  max-width:380px; line-height:1.55;
}

/* ───── 8 · HERO FOOT — MARKETS STRIP (homepage) ───── */
.hero-foot{
  display:grid; grid-template-columns:repeat(5,1fr);
  gap:24px; align-items:center;
  border-top:1px solid rgba(255,255,255,.18);
  padding-top:24px;
}
.hero-foot .lbl{
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(255,255,255,.65); font-weight:600;
}
.hero-foot .mk{
  font-family:'Archivo',sans-serif;
  font-size:14px; font-weight:600;
  color:#fff; letter-spacing:-.005em;
  display:flex; align-items:center; gap:10px;
}
.hero-foot .mk::before{
  content:""; width:6px; height:6px;
  background:var(--hot); border-radius:50%;
}

/* ───── 9 · MARKETS CARDS ───── */
.markets{ padding:120px 56px; background:var(--bg) }
.markets-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px;
}
.mkt-card{
  position:relative; aspect-ratio:3/4;
  overflow:hidden; border-radius:12px;
  cursor:pointer; background:#000;
  color:#fff; text-decoration:none;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:24px;
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.mkt-card:hover{ transform:translateY(-6px) }
.mkt-card img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  transition:transform .9s cubic-bezier(.2,.8,.2,1);
}
.mkt-card:hover img{ transform:scale(1.06) }
.mkt-card::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.85) 100%);
  pointer-events:none;
}
.mkt-card .body{ position:relative; z-index:2 }
.mkt-card .num{
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
  margin-bottom:8px; font-weight:600;
}
.mkt-card h3{
  font-family:'Archivo',sans-serif;
  font-weight:600; font-size:28px;
  line-height:1.05; letter-spacing:-.015em;
  margin-bottom:10px;
}
.mkt-card p{
  font-size:13px;
  color:rgba(255,255,255,.8);
  line-height:1.5;
  margin-bottom:14px;
}
.mkt-card .more{
  font-family:'Archivo',sans-serif;
  font-size:12px; letter-spacing:.04em;
  font-weight:600;
  display:flex; align-items:center; gap:8px;
  color:#fff;
}
.mkt-card .more::after{ content:"→"; transition:transform .25s }
.mkt-card:hover .more::after{ transform:translateX(4px) }

/* ───── 10 · DEPARTMENT / KIT CARDS (dark band) ───── */
.kit{
  background:var(--slate); color:#fff;
  padding:120px 56px; position:relative;
}
.kit .sec-head{ border-bottom-color:rgba(255,255,255,.15) }
.kit .sec-head .eye{ color:rgba(255,255,255,.7) }
.kit .sec-head h2{ color:#fff }
.kit .sec-head h2 em{ color:rgba(255,255,255,.5) }
.kit .sec-head .r{ color:rgba(255,255,255,.7) }
.kit-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
.kit-card{
  position:relative; overflow:hidden;
  border-radius:12px;
  background:var(--slate-2); color:#fff;
  text-decoration:none;
  display:flex; flex-direction:column;
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.kit-card:hover{ transform:translateY(-6px) }
.kit-card .ph{ aspect-ratio:4/3; position:relative; overflow:hidden }
.kit-card .ph img{
  width:100%; height:100%;
  object-fit:cover;
  transition:transform .9s cubic-bezier(.2,.8,.2,1);
}
.kit-card:hover .ph img{ transform:scale(1.06) }
.kit-card .ph::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.5) 100%);
}
.kit-card .body{
  padding:28px 28px 32px;
  background:transparent;
  flex:1; display:flex; flex-direction:column;
}
.kit-card .body .tag{
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--hot);
  margin-bottom:12px; font-weight:600;
}
.kit-card h3{
  font-family:'Archivo',sans-serif;
  font-weight:600; font-size:30px;
  line-height:1.05; letter-spacing:-.015em;
  margin-bottom:10px;
}
.kit-card p{
  font-size:14px;
  color:rgba(255,255,255,.78);
  line-height:1.55;
  margin-bottom:18px;
}
.kit-card .specs{
  display:flex; flex-wrap:wrap; gap:6px; margin-bottom:20px;
}
.kit-card .specs span{
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.04em;
  font-weight:500;
  padding:6px 10px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:4px;
  color:rgba(255,255,255,.85);
  text-transform:uppercase;
}
.kit-card .more{
  font-family:'Archivo',sans-serif;
  font-size:13px; font-weight:600;
  color:#fff;
  display:flex; align-items:center; gap:8px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.15);
  margin-top:auto;
}
.kit-card .more::after{ content:"→"; transition:transform .25s; color:var(--hot) }
.kit-card:hover .more::after{ transform:translateX(4px) }

/* ───── 11 · PRODUCTION CARDS ───── */
.productions{ padding:120px 56px }
.prod-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
.prod-card{
  position:relative; overflow:hidden;
  border-radius:10px; aspect-ratio:4/5;
  cursor:pointer;
  color:#fff; text-decoration:none;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:24px;
}
.prod-card img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  transition:transform .9s cubic-bezier(.2,.8,.2,1);
}
.prod-card:hover img{ transform:scale(1.06) }
.prod-card::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.85) 100%);
}
.prod-card .body{ position:relative; z-index:2 }
.prod-card .meta{
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.24em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
  margin-bottom:10px; font-weight:600;
  display:flex; gap:14px; align-items:center;
}
.prod-card .meta .net{ color:var(--hot) }
.prod-card h3{
  font-family:'Archivo',sans-serif;
  font-weight:600; font-size:30px;
  line-height:1.05; letter-spacing:-.015em;
}
.prod-card .typ{
  margin-top:8px;
  font-size:13px;
  color:rgba(255,255,255,.78);
}

/* ───── 12 · ABOUT / LOCATION (homepage) ───── */
.about{
  padding:120px 56px;
  background:var(--paper);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.about-grid{
  display:grid; grid-template-columns:1.4fr 1fr;
  gap:80px; align-items:center;
}
.about h2{
  font-family:'Archivo',sans-serif;
  font-weight:600; font-size:clamp(40px,5vw,72px);
  line-height:1; letter-spacing:-.03em;
  color:var(--ink); margin-bottom:24px;
}
.about h2 em{ font-style:italic; font-weight:300; color:var(--slate-2) }
.about p{
  font-size:17px; line-height:1.6;
  color:var(--slate);
  max-width:560px; margin-bottom:18px;
}
.about .stats{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:40px; margin-top:44px;
  padding-top:34px; border-top:1px solid var(--line);
}
.about .stat{ display:flex; flex-direction:column }
.about .stat .eye{
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--hot); font-weight:600;
  margin-bottom:14px;
  display:inline-flex; align-items:center; gap:10px;
}
.about .stat .eye::before{
  content:""; width:22px; height:1px; background:var(--hot);
}
.about .stat h4{
  font-family:'Archivo',sans-serif;
  font-weight:600; font-size:24px;
  letter-spacing:-.015em; line-height:1.15;
  color:var(--ink); margin-bottom:8px;
}
.about .stat p{
  font-size:14px; line-height:1.6;
  color:var(--slate); max-width:280px;
}
.about-vis{
  position:relative; aspect-ratio:4/5;
  border-radius:14px; overflow:hidden;
}
.about-vis img{
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
}
.about-vis .badge{
  position:absolute; top:24px; left:24px;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(8px);
  padding:14px 20px; border-radius:8px;
  display:flex; flex-direction:column; gap:4px;
}
.about-vis .badge .k{
  font-family:'Archivo',sans-serif;
  font-size:10px; letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--slate-3); font-weight:600;
}
.about-vis .badge .v{
  font-family:'Archivo',sans-serif;
  font-size:14px; font-weight:600;
  color:var(--ink);
}

/* ───── 13 · CLIENTS WALL ───── */
.clients{
  padding:80px 56px;
  background:var(--bg);
  border-bottom:1px solid var(--line);
}
.cl-head{
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.32em;
  text-transform:uppercase; text-align:center;
  color:var(--slate-3);
  margin-bottom:36px; font-weight:600;
}
.cl-grid{
  display:grid; grid-template-columns:repeat(6,1fr);
  gap:40px; align-items:center; justify-items:center;
  max-width:1200px; margin:0 auto;
}
.cl-grid img{
  max-height:46px; max-width:150px;
  width:auto; height:auto; object-fit:contain;
  filter:grayscale(1) opacity(.65);
  transition:filter .25s;
}
.cl-grid img:hover{ filter:none }
.cl-grid img.invert{ filter:invert(1) grayscale(.4) opacity(.65) }
.cl-grid img.invert:hover{ filter:invert(1) }
.cl-grid .text-logo{
  font-family:'Archivo',sans-serif;
  font-weight:800; font-size:17px;
  letter-spacing:.02em;
  color:var(--slate); opacity:.65;
  transition:opacity .25s, color .25s;
}
.cl-grid .text-logo:hover{ opacity:1; color:var(--ink) }

/* ───── 14 · CTA BANNER ───── */
.cta-band{
  padding:100px 56px;
  background:var(--ink); color:#fff;
  text-align:center;
}
.cta-band h2{
  font-family:'Archivo',sans-serif;
  font-weight:600; font-size:clamp(40px,5.5vw,84px);
  line-height:1; letter-spacing:-.035em;
  margin-bottom:24px; max-width:1100px;
  margin-left:auto; margin-right:auto;
}
.cta-band h2 em{
  font-style:italic; font-weight:300;
  color:rgba(255,255,255,.5);
}
.cta-band p{
  font-size:17px;
  color:rgba(255,255,255,.7);
  max-width:580px; margin:0 auto 36px;
  line-height:1.55;
}
.cta-band .btn-row{
  display:flex; gap:14px;
  justify-content:center; flex-wrap:wrap;
}

/* ───── 15 · FOOTER ───── */
footer.site-footer{
  background:var(--slate);
  color:rgba(255,255,255,.85);
  padding:80px 56px 32px;
}
.foot-top{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr 1fr;
  gap:48px; margin-bottom:60px;
  padding-bottom:60px;
  border-bottom:1px solid rgba(255,255,255,.15);
}
.foot-top h5{
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.24em;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
  margin-bottom:18px; font-weight:600;
}
.foot-top a{
  display:block;
  font-size:14px;
  color:rgba(255,255,255,.85);
  padding:6px 0;
  transition:color .2s;
}
.foot-top a:hover{ color:var(--hot) }
.foot-mono{
  display:flex; align-items:center; gap:18px;
  margin-bottom:20px;
}
.foot-mono img.logo{
  height:48px; width:auto; display:block;
  filter:invert(1) brightness(2);
}
.foot-mono .nm{
  font-family:'Archivo',sans-serif;
  font-weight:700; font-size:18px;
  letter-spacing:.06em; color:#fff;
}
.foot-tag{
  font-size:14px;
  color:rgba(255,255,255,.7);
  max-width:380px; line-height:1.6;
  margin-bottom:24px;
}
.foot-call{
  padding:18px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:8px;
  display:flex; flex-direction:column; gap:6px;
  max-width:340px;
}
.foot-call .k{
  font-family:'Archivo',sans-serif;
  font-size:10px; letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--hot); font-weight:600;
}
.foot-call .v{
  font-family:'Archivo',sans-serif;
  font-size:18px; font-weight:600;
  color:#fff;
}
.foot-call .sub{
  font-size:12px;
  color:rgba(255,255,255,.65);
}
.foot-bottom{
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:14px;
  font-family:'Archivo',sans-serif;
  font-size:11px; letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,.55); font-weight:500;
}

/* ───── 16 · LIVE-DOT PULSE ───── */
@keyframes nfl-pulse{
  0%,100%{ box-shadow:0 0 0 4px rgba(255,91,31,.18) }
  50%{ box-shadow:0 0 0 8px rgba(255,91,31,.08) }
}
.live-dot::before{
  content:"";
  width:8px; height:8px;
  background:var(--hot);
  border-radius:50%;
  display:inline-block;
  margin-right:8px;
  vertical-align:middle;
  box-shadow:0 0 0 4px rgba(255,91,31,.18);
  animation:nfl-pulse 2.4s infinite;
}

/* Generic section padding helper (from canonical CSS) */
.nfl-section-pad{ padding:50px 8px }

/* Link button — used in "View all credits" style */
.nfl-link-btn{
  font-family:'Archivo',sans-serif;
  font-size:13px; font-weight:600;
  color:var(--ink);
  padding:14px 22px;
  border:1px solid var(--ink);
  border-radius:6px;
  text-decoration:none;
  transition:all .25s;
}
.nfl-link-btn:hover{ background:var(--ink); color:#fff }

/* Dark variant for sec-head (slate band) */
.nfl-dark{ background:var(--slate); color:#fff }
.sec-head.dark{ border-bottom-color:rgba(255,255,255,.15) }
.sec-head.dark .eye{ color:rgba(255,255,255,.7) }
.sec-head.dark h2{ color:#fff }
.sec-head.dark h2 em{ color:rgba(255,255,255,.5) }
.sec-head.dark .r{ color:rgba(255,255,255,.7) }

/* ───── 17 · RESPONSIVE ───── */
@media (max-width:1080px){
  .hdr-row{ padding:14px 24px }
  .hdr-pre{ padding:8px 24px; flex-wrap:wrap; gap:10px }
  nav.primary a{ padding:10px 12px; font-size:12px }
  .hero-inner{ padding:50px 24px }
  .markets,.kit,.productions,.about,.clients,.cta-band{
    padding-left:24px; padding-right:24px;
    padding-top:80px; padding-bottom:80px;
  }
  footer.site-footer{ padding:60px 24px 24px }
  .markets-grid{ grid-template-columns:repeat(2,1fr) }
  .kit-grid{ grid-template-columns:1fr; gap:14px }
  .prod-grid{ grid-template-columns:1fr; gap:14px }
  .about-grid{ grid-template-columns:1fr; gap:40px }
  .about .stats{ grid-template-columns:1fr 1fr 1fr }
  .cl-grid{ grid-template-columns:repeat(4,1fr); gap:20px }
  .foot-top{ grid-template-columns:repeat(2, 1fr); gap:30px }
  .hero-foot{ grid-template-columns:1fr; gap:14px; padding-top:18px }
  .mega{ padding:24px; grid-template-columns:1fr }
  .sec-head{ flex-direction:column; align-items:flex-start; gap:20px }
  .nfl-section-pad{ padding:30px 4px }
}

/* ── Mobile nav breakpoint ── */
@media (max-width:960px){
  /* Show hamburger, hide desktop nav */
  .nav-toggle{ display:inline-flex }
  nav.primary{ display:none }
  .nav-backdrop{ display:block; opacity:0; pointer-events:none }
  body.nav-open .nav-backdrop{ pointer-events:auto }
  .mobile-nav{ display:flex }

  /* Utility bar — drop email, keep the dot + phone + region */
  .hdr-pre{
    justify-content:space-between;
    padding:6px 18px;
    gap:8px;
    flex-wrap:nowrap;
    overflow:hidden;
    font-size:10.5px;
  }
  .hdr-pre .l{ gap:14px; flex-wrap:nowrap; min-width:0 }
  .hdr-pre .l > span:nth-child(3){ display:none } /* hide email */
  .hdr-pre .l > span{
    overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  }
  .hdr-pre .r{ flex:0 0 auto }

  /* Smaller monogram so logo doesn't compete with hamburger */
  .hdr-row{ padding:12px 18px; gap:14px }
  .monogram img.logo{ height:34px }
  .monogram .lock .nm{ font-size:13px }
  .monogram .lock .sub{ font-size:9.5px }

  /* Hero / page header top spacing — shorter header on mobile */
  .hero{ margin-top:96px }
  html{ scroll-padding-top:110px }
}

/* ── Tablet portrait & below ── */
@media (max-width:780px){
  .hdr-pre{
    flex-wrap:wrap;
    white-space:normal;
    justify-content:center;
    gap:8px;
    padding:6px 14px;
    font-size:10px;
  }
  .hdr-pre .l{ gap:10px; justify-content:center }
  .hdr-pre .r{ margin-left:0; display:none } /* hide Manchester · Liverpool tag */

  .markets-grid{ grid-template-columns:1fr }

  /* Clients wall — flex-wrap on tablet/mobile so logos reflow nicely */
  .cl-grid{
    display:flex; flex-wrap:wrap;
    justify-content:center; align-items:center;
    gap:30px 36px;
  }
  .cl-grid img,
  .cl-grid .text-logo{
    flex:0 0 auto;
    max-height:38px; max-width:120px;
  }
  .cl-grid .text-logo{ font-size:15px }

  /* Footer 2-col then bottom bar wraps */
  .foot-top{
    grid-template-columns:repeat(2,1fr);
    gap:36px 24px;
    margin-bottom:40px;
    padding-bottom:40px;
  }
  .foot-bottom{
    flex-direction:column; align-items:flex-start;
    gap:10px; font-size:10.5px;
  }
  .foot-top h5{ margin-bottom:12px }

  /* About stats: 1-col on small tablet */
  .about .stats{ grid-template-columns:1fr; gap:24px; padding-top:24px; margin-top:30px }

  /* CTA band */
  .cta-band{ padding:70px 20px }
  .cta-band p{ font-size:15px }

  /* Sec head smaller margin */
  .sec-head{ margin-bottom:40px; padding-bottom:20px }

  /* Hero — readable on small screens */
  .hero-inner{ padding:40px 20px; gap:20px }
  .hero-cap h1{ font-size:clamp(40px, 11vw, 64px) }
  .hero-cap .lede{ font-size:16px; line-height:1.55 }
  .hero-cap .eye{ font-size:11px; margin-bottom:18px }
  .hero{ height:auto; min-height:88vh }
  .hero.short{ min-height:auto }

  /* Hero CTAs stack full-width */
  .hero-cta-row{ flex-direction:column; align-items:stretch; width:100% }
  .hero-cta-row .btn{ justify-content:center; width:100% }

  /* Buttons in general get bigger tap area on mobile */
  .btn, .nfl-btn-primary, .nfl-btn-ghost, .nfl-btn-dark{
    padding:14px 22px; min-height:48px;
  }

  /* Markets cards — bigger headlines so they breathe in 1-col layout */
  .mkt-card{ aspect-ratio:5/4; padding:20px }
  .mkt-card h3{ font-size:24px }

  /* Production cards bigger headline */
  .prod-card{ aspect-ratio:4/3; padding:20px }
  .prod-card h3{ font-size:24px }

  /* Kit cards */
  .kit-card .body{ padding:22px }
  .kit-card h3{ font-size:24px }

  /* CTA banner buttons stack */
  .cta-band .btn-row{ flex-direction:column; align-items:stretch }
  .cta-band .btn-row .btn{ justify-content:center; width:100% }

  /* About vis aspect ratio looser on mobile */
  .about-vis{ aspect-ratio:1/1 }
}

/* ── Phone breakpoint ── */
@media (max-width:480px){
  /* Hide the region tag entirely; keep only dot + phone in utility bar */
  .hdr-pre .l > span:nth-child(1){ display:none } /* hide 24/7 production line label */

  /* Tighter chrome */
  .hdr-row{ padding:10px 14px; gap:10px }
  .monogram{ gap:10px }
  .monogram img.logo{ height:30px }
  .monogram .lock{ padding-left:10px }
  .monogram .lock .nm{ font-size:12px; letter-spacing:.08em }
  .monogram .lock .sub{ display:none } /* drop the long subtitle */

  .hero{ margin-top:88px }

  /* Hero card lede max-width drops */
  .hero-cap h1{ font-size:clamp(36px, 13vw, 54px); margin-bottom:22px }
  .hero-cap .lede{ font-size:15px }
  .hero-cap .eye{ font-size:10.5px; letter-spacing:.26em }

  /* Markets/About/etc padding */
  .markets,.kit,.productions,.about,.clients,.cta-band{
    padding-left:16px; padding-right:16px;
    padding-top:60px; padding-bottom:60px;
  }
  footer.site-footer{ padding:48px 16px 20px }

  /* Markets cards stack and fill */
  .markets-grid{ gap:12px }
  .prod-grid{ gap:12px }

  /* Clients wall — 2 per row */
  .cl-grid{ gap:24px 28px }
  .cl-grid img,
  .cl-grid .text-logo{
    max-height:32px; max-width:100px;
  }

  /* Footer — single column */
  .foot-top{ grid-template-columns:1fr; gap:28px; margin-bottom:30px; padding-bottom:30px }
  .foot-mono{ gap:12px; margin-bottom:14px }
  .foot-mono img.logo{ height:40px }
  .foot-mono .nm{ font-size:16px }
  .foot-call{ max-width:none }

  /* Headline sizes inside sec-head */
  .sec-head h2{ font-size:clamp(32px, 9vw, 48px) }
  .about h2{ font-size:clamp(32px, 9vw, 44px) }
  .cta-band h2{ font-size:clamp(32px, 10vw, 52px) }

  /* About p body */
  .about p{ font-size:15px; line-height:1.55 }

  /* Mobile nav typography */
  .mobile-nav > ul > li > a,
  .mobile-nav .mob-mega-toggle{
    font-size:15px; padding:16px 20px;
  }

  /* Ensure no horizontal scroll possible */
  html, body{ overflow-x:hidden; width:100% }
}

/* ── Tiny phones (360px and below) — last-ditch defenses ── */
@media (max-width:380px){
  .hdr-pre{ font-size:9.5px; padding:5px 12px }
  .hdr-pre .l{ gap:8px }
  .monogram .lock .nm{ font-size:11px }
  .hero-cap h1{ font-size:38px }
  .hero-cap .lede{ font-size:14px }
}

/* ═══════════════════════════════════════════════════════════════
   JETPACK CONTACT FORM — brand styling overrides
   Live form on /contact/ is rendered by Jetpack's [contact-form]
   shortcode using its own class names (.contact-form, .grunion-field,
   .grunion-field-label etc.) — the prototype's .form-wrap/.field rules
   do not apply. This block re-styles the rendered Jetpack form so it
   matches the prototype design (light paper card, Archivo labels,
   Inter inputs, dark submit button lifting to hot orange on hover).
   ═══════════════════════════════════════════════════════════════ */
.contact-form{
  font-family:'Inter',sans-serif;
  color:var(--ink);
  display:flex; flex-direction:column;
  gap:0;
}
.contact-form .grunion-field-label,
.contact-form > label,
.contact-form .grunion-field-wrap > label{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:11px; font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--slate-2);
  margin-bottom:8px;
}
.contact-form .grunion-field-label .grunion-label-required,
.contact-form .required{
  color:var(--hot);
  margin-left:4px;
  font-weight:600;
}
.contact-form input.grunion-field,
.contact-form select.grunion-field,
.contact-form textarea.grunion-field,
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form input[type="url"],
.contact-form input[type="date"],
.contact-form select,
.contact-form textarea{
  width:100%;
  font-family:'Inter',sans-serif;
  font-size:15px;
  padding:14px 16px;
  border:1px solid var(--line-2);
  border-radius:8px;
  background:var(--bg);
  color:var(--ink);
  transition:border-color .2s, background .2s, box-shadow .2s;
  font-weight:400;
  min-height:48px;
  box-sizing:border-box;
}
.contact-form textarea.grunion-field,
.contact-form textarea{
  min-height:140px;
  resize:vertical;
  line-height:1.55;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:var(--ink);
  background:#fff;
  box-shadow:0 0 0 3px var(--hot-soft);
}
.contact-form .grunion-field-wrap{
  margin-bottom:22px;
}

/* Radio + checkbox controls */
.contact-form input[type="radio"],
.contact-form input[type="checkbox"]{
  width:auto;
  min-height:0;
  margin:0 10px 0 0;
  accent-color:var(--hot);
  vertical-align:middle;
  transform:scale(1.1);
}
.contact-form input[type="radio"] + label,
.contact-form input[type="checkbox"] + label,
.contact-form .grunion-field-radio-wrap label,
.contact-form .grunion-field-checkbox-wrap label,
.contact-form .grunion-radio-label,
.contact-form .grunion-checkbox-label{
  display:inline-flex; align-items:center;
  font-family:'Inter',sans-serif;
  font-size:14px; font-weight:500;
  letter-spacing:0;
  text-transform:none;
  color:var(--ink);
  margin:0 18px 0 0;
  cursor:pointer;
}
.contact-form .grunion-field-radio-wrap,
.contact-form .grunion-field-checkbox-wrap{
  display:flex; flex-wrap:wrap; gap:12px 18px;
  margin-top:6px;
}

/* Submit button — matches .btn.primary brand button */
.contact-form button[type="submit"],
.contact-form input[type="submit"],
.contact-form .pushbutton-wide,
.contact-form .wp-block-button__link,
.contact-form-submit{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:'Archivo',sans-serif;
  font-size:14px; font-weight:600;
  letter-spacing:.04em;
  padding:16px 36px;
  background:var(--ink);
  color:#fff;
  border:0;
  border-radius:8px;
  cursor:pointer;
  min-height:54px;
  margin-top:8px;
  transition:background .2s ease, transform .2s ease, box-shadow .2s ease;
  text-transform:none;
}
.contact-form button[type="submit"]:hover,
.contact-form input[type="submit"]:hover,
.contact-form .pushbutton-wide:hover,
.contact-form .wp-block-button__link:hover,
.contact-form-submit:hover{
  background:var(--hot);
  transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(255,91,31,.18);
}

/* Validation + success */
.contact-form .form-errors,
.contact-form .grunion-field-error{
  font-family:'Inter',sans-serif;
  font-size:13px;
  color:var(--hot);
  margin-top:6px;
}
/* ─── Jetpack submission success state ───
   The success receipt (.contact-form-submission) is a SIBLING of .contact-form,
   both inside .jetpack-contact-form-container. Jetpack hides/shows it via the
   aria-hidden attribute toggled by the WP Interactivity API on submit. */

/* Hide the receipt by default, show only when aria-hidden="false" */
.contact-form-submission{ display:none !important; }
.contact-form-submission[aria-hidden="false"]{ display:block !important; }

/* When the form is in success state, hide all its field rows + submit button */
.contact-form.submission-success .grunion-field-wrap,
.contact-form.submission-success .grunion-field-label,
.contact-form.submission-success .contact-submit,
.contact-form.submission-success .pushbutton-wide,
.contact-form.submission-success button[type="submit"],
.contact-form.submission-success input[type="submit"]{
  display:none !important;
}

/* The success card — paper background, soft border, brand typography */
.jetpack-contact-form-container .contact-form-submission{
  padding:36px 40px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:12px;
  font-family:'Inter',sans-serif;
  color:var(--ink);
  margin-top:0;
}

/* "← Back" link styled as a ghost button at the top of the card */
.contact-form-submission .go-back-message{
  margin:0 0 24px 0;
  padding:0;
  border:0;
  background:transparent;
}
.contact-form-submission .go-back-message a,
.contact-form-submission .go-back-message .link{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 18px;
  background:transparent;
  color:var(--ink);
  border:1px solid var(--ink);
  border-radius:6px;
  font-family:'Archivo',sans-serif;
  font-size:12px; font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  text-decoration:none;
  cursor:pointer;
  transition:background .2s ease, color .2s ease;
}
.contact-form-submission .go-back-message a:hover,
.contact-form-submission .go-back-message .link:hover{
  background:var(--ink); color:#fff;
}

/* "Thank you for your response." heading — Archivo brand display */
.contact-form-submission h4{
  font-family:'Archivo',sans-serif;
  font-weight:600;
  font-size:28px;
  line-height:1.15;
  letter-spacing:-.018em;
  color:var(--ink);
  margin:0 0 24px 0;
  display:flex; align-items:center; gap:10px;
  flex-wrap:wrap;
}
.contact-form-submission h4 img.emoji,
.contact-form-submission img.emoji{
  width:24px; height:24px;
  vertical-align:middle;
  display:inline-block;
}

/* Submission echo — Jetpack reprints each field as a paragraph below the heading.
   Style them as a clean field-list with uppercase Archivo labels and Inter values. */
.contact-form-submission p:not(.go-back-message){
  font-family:'Inter',sans-serif;
  font-size:15px;
  line-height:1.5;
  color:var(--slate);
  margin:0;
  padding:14px 0;
  border-top:1px solid var(--line);
}
.contact-form-submission p:not(.go-back-message):last-child{
  border-bottom:1px solid var(--line);
}
.contact-form-submission strong,
.contact-form-submission b{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--slate-3);
  margin-bottom:4px;
}

/* Hide the small Jetpack field-icon glyphs that render as black-on-grey boxes
   (👤, ✉, 📞, 📦, ☑) — they look broken without proper font support and add
   nothing to the receipt's information value. */
.contact-form-submission p:not(.go-back-message)::before{
  content:none !important;
}

/* Mobile tweaks for the receipt card */
@media (max-width:480px){
  .jetpack-contact-form-container .contact-form-submission{
    padding:24px 22px;
  }
  .contact-form-submission h4{
    font-size:22px;
  }
}

/* Mobile */
@media (max-width:480px){
  .contact-form button[type="submit"],
  .contact-form input[type="submit"],
  .contact-form .pushbutton-wide,
  .contact-form .wp-block-button__link,
  .contact-form-submit{
    width:100%;
  }
  .contact-form input,
  .contact-form select,
  .contact-form textarea{
    font-size:16px; /* prevent iOS zoom-on-focus */
  }
}

/* ═══════════════════════════════════════════════════════════════
   INSTAGRAM — "From the floor" section (Option C: Latest Drop)
   Featured large recent post + 2×2 grid of smaller thumbnails.
   Wraps an optional Smash Balloon shortcode but falls back to a
   static layout when the plugin is not yet connected.
   ═══════════════════════════════════════════════════════════════ */
.instagram-floor{padding:120px 56px;background:var(--bg);border-top:1px solid var(--line)}
.instagram-floor .sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:60px;border-bottom:1px solid var(--line);padding-bottom:30px}
.instagram-floor .sec-head .l .eye{font-family:'Archivo',sans-serif;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--slate-3);margin-bottom:12px;font-weight:600;display:flex;align-items:center;gap:10px}
.instagram-floor .sec-head .l .eye::before{content:"";width:32px;height:1px;background:var(--hot)}
.instagram-floor .sec-head .l h2{font-family:'Archivo',sans-serif;font-weight:600;font-size:clamp(40px,5vw,68px);letter-spacing:-.025em;line-height:1.02;color:var(--ink)}
.instagram-floor .sec-head .l h2 em{font-style:italic;font-weight:300;color:var(--slate-2)}
.instagram-floor .sec-head .r{display:flex;flex-direction:column;align-items:flex-end;gap:14px}
.instagram-floor .sec-head .r .handle{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--slate-3)}
.instagram-floor .sec-head .r .btn{display:inline-flex;align-items:center;gap:10px;background:transparent;color:var(--ink);border:1px solid var(--ink);padding:14px 22px;border-radius:8px;font-family:'Archivo',sans-serif;font-weight:600;font-size:13px;letter-spacing:.04em;text-decoration:none;transition:background .2s,color .2s}
.instagram-floor .sec-head .r .btn:hover{background:var(--ink);color:#fff}
.instagram-floor .sec-head .r .btn .arrow{transition:transform .2s}
.instagram-floor .sec-head .r .btn:hover .arrow{transform:translateX(2px)}

/* Layout: featured + 2×2 grid */
.instagram-floor .ig-drop{display:grid;grid-template-columns:1.4fr 1fr;gap:24px}
.instagram-floor .ig-featured{position:relative;background:#000;border-radius:12px;overflow:hidden;aspect-ratio:1/1;cursor:pointer;border:1px solid var(--line);text-decoration:none;color:#fff}
.instagram-floor .ig-featured img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.8,.2,1);display:block}
.instagram-floor .ig-featured:hover img{transform:scale(1.04)}
.instagram-floor .ig-featured .badge-new{position:absolute;top:24px;left:24px;background:var(--hot);color:#fff;padding:8px 14px;border-radius:6px;font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;z-index:2}
.instagram-floor .ig-featured .badge-new .live-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:igPulse 1.6s infinite}
@keyframes igPulse{0%,100%{opacity:1}50%{opacity:.3}}
.instagram-floor .ig-featured .body{position:absolute;left:0;right:0;bottom:0;padding:32px;background:linear-gradient(180deg,transparent 0%,rgba(10,10,10,.92) 100%);color:#fff}
.instagram-floor .ig-featured .body .meta{display:flex;gap:18px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:14px}
.instagram-floor .ig-featured .body .caption{font-family:'Archivo',sans-serif;font-size:22px;font-weight:600;letter-spacing:-.015em;line-height:1.2;margin-bottom:18px;max-width:90%}
.instagram-floor .ig-featured .body .stats{display:flex;gap:18px;font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.06em;color:rgba(255,255,255,.85)}
.instagram-floor .ig-featured .body .stats span{display:inline-flex;align-items:center;gap:6px}

.instagram-floor .ig-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:12px}
.instagram-floor .ig-thumb{position:relative;aspect-ratio:1/1;background:#000;border-radius:10px;overflow:hidden;cursor:pointer;border:1px solid var(--line);text-decoration:none;color:#fff;display:block}
.instagram-floor .ig-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.8,.2,1);display:block}
.instagram-floor .ig-thumb:hover img{transform:scale(1.05)}
.instagram-floor .ig-thumb .time{position:absolute;top:10px;left:10px;background:rgba(10,10,10,.6);backdrop-filter:blur(8px);color:#fff;padding:4px 8px;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.08em;text-transform:uppercase;z-index:2}
.instagram-floor .ig-thumb .overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(10,10,10,.85) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:14px;color:#fff;opacity:0;transition:opacity .25s}
.instagram-floor .ig-thumb:hover .overlay{opacity:1}
.instagram-floor .ig-thumb .overlay .cap{font-family:'Inter',sans-serif;font-size:12px;font-weight:500;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Fallback note shown only when Smash Balloon isn't installed */
.instagram-floor .ig-fallback-note{margin-top:32px;display:flex;justify-content:center}
.instagram-floor .ig-fallback-note .dot{width:6px;height:6px;background:var(--hot);border-radius:50%;box-shadow:0 0 10px var(--hot);margin-right:10px}
.instagram-floor .ig-fallback-note{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--slate-3);letter-spacing:.04em}

/* Smash Balloon override: when the [instagram-feed] shortcode renders, force its grid to roughly match Option C */
.instagram-floor #sb_instagram .sb_instagram_header,
.instagram-floor #sb_instagram .sbi_follow_btn{display:none}
.instagram-floor #sb_instagram .sbi_photo_wrap{border-radius:10px;overflow:hidden;border:1px solid var(--line)}

/* Responsive */
@media (max-width:780px){
  .instagram-floor{padding:80px 24px}
  .instagram-floor .sec-head{flex-direction:column;align-items:flex-start;gap:30px}
  .instagram-floor .sec-head .r{align-items:flex-start}
  .instagram-floor .ig-drop{grid-template-columns:1fr;gap:14px}
  .instagram-floor .ig-featured .body{padding:24px}
  .instagram-floor .ig-featured .body .caption{font-size:18px}
  .instagram-floor .ig-featured .body .meta{margin-bottom:10px}
}

/* ═══════════════════════════════════════════════════════════════
   SMASH BALLOON LIVE FEED OVERRIDES — force Option C layout
   When [instagram-feed] renders inside .instagram-floor, override
   the plugin's default uniform grid into the asymmetric "Latest
   Drop" layout: post #1 is the large featured (1.4fr × 2 rows),
   posts #2–5 fill the 2×2 grid on the right, anything past 5 is
   hidden. Shortcode should use num=5 cols=5 for predictable input.
   ═══════════════════════════════════════════════════════════════ */
.instagram-floor #sb_instagram{
  background:transparent !important;
  padding:0 !important;
  margin:0 !important;
}
.instagram-floor #sb_instagram .sb_instagram_header,
.instagram-floor #sb_instagram #sbi_load,
.instagram-floor #sb_instagram .sbi_follow_btn{
  display:none !important;
}
.instagram-floor #sb_instagram #sbi_images,
.instagram-floor #sb_instagram .sbi_photos{
  display:grid !important;
  grid-template-columns:1.4fr 1fr 1fr !important;
  grid-template-rows:1fr 1fr !important;
  gap:12px !important;
  padding:0 !important;
}
/* First item: spans 1 column + 2 rows = featured large tile */
.instagram-floor #sb_instagram .sbi_item:nth-of-type(1){
  grid-column:1 !important;
  grid-row:1 / 3 !important;
}
/* Items 2–5: each takes one cell in the 2×2 grid */
.instagram-floor #sb_instagram .sbi_item:nth-of-type(n+2){
  grid-column:auto !important;
  grid-row:auto !important;
}
/* Anything past 5 — hide so the layout stays clean */
.instagram-floor #sb_instagram .sbi_item:nth-of-type(n+6){
  display:none !important;
}
.instagram-floor #sb_instagram .sbi_item{
  width:100% !important;
  padding:0 !important;
  margin:0 !important;
  background:#000;
  border-radius:10px;
  overflow:hidden;
  border:1px solid var(--line);
  position:relative;
  aspect-ratio:1/1;
}
.instagram-floor #sb_instagram .sbi_item:nth-of-type(1){
  border-radius:12px;
}
.instagram-floor #sb_instagram .sbi_photo_wrap,
.instagram-floor #sb_instagram .sbi_photo_wrap a,
.instagram-floor #sb_instagram .sbi_photo{
  display:block !important;
  height:100% !important;
  width:100% !important;
  border-radius:0 !important;
  overflow:hidden;
}
.instagram-floor #sb_instagram .sbi_photo img,
.instagram-floor #sb_instagram .sbi_item img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  transition:transform .6s cubic-bezier(.2,.8,.2,1);
  display:block;
}
.instagram-floor #sb_instagram .sbi_item:hover .sbi_photo img,
.instagram-floor #sb_instagram .sbi_item:hover img{
  transform:scale(1.04);
}
/* Featured item caption overlay (re-create the static "Latest · today" look) */
.instagram-floor #sb_instagram .sbi_item:nth-of-type(1)::before{
  content:"Latest";
  position:absolute;
  top:24px;
  left:24px;
  background:var(--hot);
  color:#fff;
  padding:8px 14px;
  border-radius:6px;
  font-family:'Archivo',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  z-index:2;
}
.instagram-floor #sb_instagram .sbi_item:nth-of-type(1) .sbi_info,
.instagram-floor #sb_instagram .sbi_item:nth-of-type(1) .sbi_caption_wrap{
  position:absolute !important;
  left:0; right:0; bottom:0;
  padding:32px !important;
  background:linear-gradient(180deg,transparent 0%,rgba(10,10,10,.92) 100%) !important;
  color:#fff !important;
  margin:0 !important;
  border:0 !important;
}
.instagram-floor #sb_instagram .sbi_item:nth-of-type(1) .sbi_caption{
  font-family:'Archivo',sans-serif !important;
  font-size:20px !important;
  font-weight:600 !important;
  letter-spacing:-.015em !important;
  line-height:1.25 !important;
  color:#fff !important;
  max-width:90% !important;
}
/* Smaller items: hide their captions/meta — keep them visually clean like the static thumbs */
.instagram-floor #sb_instagram .sbi_item:nth-of-type(n+2) .sbi_info,
.instagram-floor #sb_instagram .sbi_item:nth-of-type(n+2) .sbi_caption_wrap,
.instagram-floor #sb_instagram .sbi_item:nth-of-type(n+2) .sbi_meta{
  display:none !important;
}
/* Hover overlay for the smaller thumbs */
.instagram-floor #sb_instagram .sbi_item:nth-of-type(n+2)::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(10,10,10,.85) 100%);
  opacity:0;
  transition:opacity .25s;
  pointer-events:none;
  z-index:1;
}
.instagram-floor #sb_instagram .sbi_item:nth-of-type(n+2):hover::after{
  opacity:1;
}

/* Mobile: stack the asymmetric grid into single column */
@media (max-width:780px){
  .instagram-floor #sb_instagram #sbi_images,
  .instagram-floor #sb_instagram .sbi_photos{
    grid-template-columns:1fr !important;
    grid-template-rows:auto !important;
    gap:14px !important;
  }
  .instagram-floor #sb_instagram .sbi_item:nth-of-type(1){
    grid-column:1 !important;
    grid-row:auto !important;
  }
  .instagram-floor #sb_instagram .sbi_item:nth-of-type(n+2){
    aspect-ratio:1/1;
  }
  .instagram-floor #sb_instagram .sbi_item:nth-of-type(1) .sbi_info,
  .instagram-floor #sb_instagram .sbi_item:nth-of-type(1) .sbi_caption_wrap{
    padding:20px !important;
  }
  .instagram-floor #sb_instagram .sbi_item:nth-of-type(1) .sbi_caption{
    font-size:16px !important;
  }
}
