:root {
  --ink: #17110f;
  --cream: #f4f0e9;
  --pink: #f6cbd3;
  --hot: #eb5170;
  --line: rgba(23,17,15,.2);
  --serif: "Playfair Display", Georgia, serif;
  --sans: "DM Sans", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: clip; }
body { margin: 0; background: var(--cream); color: var(--ink); font-family: var(--sans); }
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
img { display: block; width: 100%; }
.noise { position: fixed; inset: 0; pointer-events: none; z-index: 20; opacity: .035; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/%3E%3C/svg%3E"); }

.nav { height: 86px; padding: 0 4vw; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); position: relative; z-index: 10; }
.brand { font: 700 18px/1 "Manrope", sans-serif; letter-spacing: .035em; white-space: nowrap; }
.brand span { color: var(--hot); padding: 0 .2em; }
.nav nav { display: flex; align-items: center; gap: 34px; font-size: 13px; }
.nav nav a { font-weight: 500; transition: color .2s, background .2s, border-color .2s; }
.nav nav a:hover { color: var(--hot); }
.nav-cta { border: 1px solid var(--ink); padding: 13px 18px; background: var(--ink); color: white; }
.nav nav .nav-cta:hover { color: white; border-color: var(--hot); background: var(--hot); }
.nav-cta span { margin-left: 20px; }
.menu-button { display: none; border: 0; background: none; text-transform: uppercase; font-size: 12px; letter-spacing: .1em; }

.hero { min-height: calc(100vh - 86px); display: grid; grid-template-columns: 52% 48%; position: relative; overflow: hidden; padding: 6.5vh 4vw 5vh; }
.hero-copy { position: relative; z-index: 2; padding-top: 2vh; }
.eyebrow { margin: 0 0 32px; font-size: 11px; letter-spacing: .16em; font-weight: 600; }
.eyebrow span { display: inline-block; width: 24px; height: 1px; background: currentColor; vertical-align: middle; margin-right: 10px; }
h1, h2 { font: 500 clamp(58px, 7.4vw, 118px)/.88 var(--serif); letter-spacing: -.055em; margin: 0; }
h1 em, h2 em { font-weight: 500; color: var(--hot); }
.hero-lead { max-width: 500px; margin: 38px 0 35px; font-size: clamp(17px, 1.4vw, 20px); line-height: 1.55; font-weight: 450; }
.hero-actions { display: flex; align-items: center; gap: 34px; }
.button { display: inline-flex; align-items: center; justify-content: space-between; min-width: 225px; padding: 18px 21px; font-size: 13px; font-weight: 600; transition: transform .2s, background .2s; }
.button.dark { color: white; background: var(--ink); }
.button:hover { transform: translateY(-2px); }
.button.dark:hover { background: var(--hot); }
.text-link { display: inline-block; padding-bottom: 5px; border-bottom: 1px solid currentColor; font-size: 13px; font-weight: 500; }
.text-link span { margin-left: 16px; }
.hero-visual { display: flex; position: relative; justify-content: center; align-items: center; min-width: 0; }
.hero-photo { width: min(68%, 430px); aspect-ratio: .68; position: relative; transform: rotate(2deg); background: var(--pink); box-shadow: 16px 18px 0 var(--pink); }
.hero-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 45% center; filter: saturate(.82) contrast(.95); }
.hero-photo::after { content: ""; position: absolute; inset: 0; border: 1px solid rgba(255,255,255,.35); }
.floating-tag { position: absolute; z-index: 2; background: white; padding: 7px 12px; font: italic 16px var(--serif); box-shadow: 0 8px 20px rgba(23,17,15,.12); }
.tag-one { left: -28px; top: 20%; transform: rotate(-8deg); }
.tag-two { right: -25px; top: 48%; transform: rotate(6deg); }
.tag-three { left: 12%; bottom: -15px; transform: rotate(-3deg); }
.hero-note { align-self: flex-end; margin: 0 0 1.2vh 5%; display: flex; gap: 12px; font-size: 11px; line-height: 1.35; }
.hero-note strong { font: 500 34px var(--serif); }
.note-arrow { font-size: 26px; color: var(--hot); }
.hero-index { position: absolute; right: 4vw; top: 3vh; font: 11px var(--sans); opacity: .5; }

.trust-strip { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 26px 4vw; display: flex; align-items: center; justify-content: space-between; }
.trust-strip p { margin: 0; font: italic 17px var(--serif); }
.logo-row { display: flex; align-items: center; gap: 22px; color: rgba(23,17,15,.72); font-size: 10px; letter-spacing: .16em; font-weight: 700; }
.logo-row i { width: 3px; height: 3px; border-radius: 50%; background: var(--hot); }
.numbers { padding-top: 80px; padding-bottom: 80px; }
.numbers-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.numbers-grid > div { padding: 38px 26px; border-right: 1px solid var(--line); }
.numbers-grid > div:last-child { border: 0; }
.numbers-grid strong { font: 500 clamp(42px, 5vw, 75px) var(--serif); color: var(--hot); }
.numbers-grid p { margin: 12px 0 0; font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: .08em; }

.section { padding: 120px 4vw; }
.section-head { display: grid; grid-template-columns: 1.25fr .55fr; align-items: end; gap: 10vw; margin-bottom: 64px; }
.section-head h2, .about h2 { font-size: clamp(52px, 6vw, 92px); }
.section-head > p { margin: 0 0 5px; font-size: 15px; line-height: 1.65; max-width: 410px; color: rgba(23,17,15,.78); }
.filters { display: flex; gap: 8px; margin-bottom: 25px; }
.filters button { border: 1px solid var(--line); background: transparent; border-radius: 30px; padding: 10px 16px; cursor: pointer; font-size: 12px; transition: .25s; }
.filters button.active, .filters button:hover { background: var(--ink); color: white; }
.filters sup { opacity: .5; margin-left: 5px; }
.work-grid { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 520px; gap: 14px; max-width: 1280px; margin-inline: auto; }
.work-card { position: relative; overflow: hidden; background: #d8d0c7; transition: opacity .25s, transform .25s; }
.work-card.hidden { display: none; }
.work-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s cubic-bezier(.2,.7,.2,1); }
.work-card:hover img { transform: scale(1.035); }
.work-overlay { position: absolute; inset: auto 0 0; padding: 70px 20px 20px; display: flex; justify-content: space-between; align-items: center; color: white; background: linear-gradient(transparent, rgba(0,0,0,.78)); font-size: 13px; font-weight: 600; text-shadow: 0 1px 8px rgba(0,0,0,.55); }
.work-overlay button { width: 38px; height: 38px; border: 1px solid rgba(255,255,255,.6); border-radius: 50%; color: white; background: rgba(0,0,0,.12); cursor: pointer; }
.library { background: #e9e2d9; }
.library-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 28px; }
.library-filters button { border: 1px solid var(--line); background: transparent; border-radius: 999px; padding: 10px 15px; cursor: pointer; font-size: 11px; }
.library-filters button.active { color: white; background: var(--ink); }
.video-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.video-card { position: relative; aspect-ratio: 9 / 16; overflow: hidden; background: #ccc; }
.video-card video { width: 100%; height: 100%; object-fit: cover; }
.video-card-info { position: absolute; inset: auto 0 0; color: white; padding: 64px 16px 16px; background: linear-gradient(transparent, rgba(0,0,0,.86)); pointer-events: none; text-shadow: 0 1px 8px rgba(0,0,0,.5); }
.video-card-info strong { display: block; font: 500 18px var(--serif); }
.video-card-info span { font-size: 9px; letter-spacing: .12em; text-transform: uppercase; opacity: .95; font-weight: 700; }
.video-card .play-pill { position: absolute; top: 12px; right: 12px; width: 38px; height: 38px; border: 0; border-radius: 50%; color: var(--ink); background: rgba(255,255,255,.9); cursor: pointer; }
.load-more { display: flex; justify-content: space-between; width: min(330px, 100%); margin: 42px auto 0; padding: 16px 18px; border: 1px solid var(--ink); background: transparent; cursor: pointer; }
.campaigns { display: grid; grid-template-columns: 1fr 1fr; background: var(--pink); gap: 8vw; }
.campaign-intro h2 { font-size: clamp(55px, 7vw, 100px); }
.campaign-tags { display: flex; align-content: center; align-items: center; justify-content: center; flex-wrap: wrap; gap: 12px; }
.campaign-tags span { padding: 14px 20px; border-radius: 999px; border: 1px solid var(--ink); font: italic 18px var(--serif); transform: rotate(-2deg); }
.campaign-tags span:nth-child(even) { transform: rotate(3deg); background: var(--cream); }
.campaign-note { grid-column: 2; max-width: 520px; margin: -30px 0 0; line-height: 1.6; font-size: 13px; }

.about { position: relative; display: grid; grid-template-columns: .72fr 1.15fr; gap: 9vw; align-items: center; background: var(--pink); overflow: hidden; }
.about-image { position: relative; max-width: 520px; }
.about-image img { aspect-ratio: .75; object-fit: cover; object-position: center top; filter: saturate(.75); }
.stamp { position: absolute; right: -54px; top: -44px; width: 106px; height: 106px; border-radius: 50%; background: var(--ink); color: white; display: grid; place-items: center; font-size: 8px; line-height: 1.5; letter-spacing: .12em; text-align: center; padding: 20px; transform: rotate(12deg); }
.about-copy .lead { max-width: 650px; font: italic clamp(20px, 2vw, 28px)/1.4 var(--serif); margin: 40px 0 25px; }
.about-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; max-width: 680px; margin-bottom: 28px; }
.about-columns p { font-size: 13px; line-height: 1.65; margin: 0; }
.about-number { position: absolute; right: 4vw; top: 35px; font-size: 11px; opacity: .5; }

.services { background: var(--ink); color: var(--cream); }
.section-head.light h2 em { color: var(--pink); }
.service-list { border-top: 1px solid rgba(255,255,255,.2); }
.service-list article { display: grid; grid-template-columns: 60px 1fr 1fr 40px; gap: 25px; align-items: center; min-height: 130px; border-bottom: 1px solid rgba(255,255,255,.2); transition: padding .3s, background .3s; }
.service-list article:hover { padding: 0 18px; background: rgba(255,255,255,.035); }
.service-list span { color: var(--hot); font-size: 11px; }
.service-list h3 { font: 500 clamp(25px, 3vw, 40px) var(--serif); margin: 0; }
.service-list p { max-width: 430px; margin: 0; color: rgba(255,255,255,.76); font-size: 13px; line-height: 1.55; }
.service-list i { font-style: normal; font-size: 22px; }
.deliverables { margin-top: 90px; padding-top: 45px; border-top: 1px solid rgba(255,255,255,.2); }
.deliverables > div { display: flex; flex-wrap: wrap; gap: 9px; }
.deliverables > div span { padding: 11px 15px; border: 1px solid rgba(255,255,255,.38); border-radius: 999px; font-size: 11px; color: rgba(255,255,255,.9); }
.packages { background: var(--cream); }
.package-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.package-grid article { position: relative; min-height: 310px; padding: 24px; border: 1px solid var(--line); display: flex; flex-direction: column; }
.package-grid small { color: var(--hot); }
.package-grid h3 { margin: auto 0 12px; font: 500 31px var(--serif); }
.package-grid p { min-height: 58px; margin: 0; font-size: 12px; line-height: 1.6; opacity: .82; }
.package-grid .featured { color: white; background: var(--hot); border-color: var(--hot); }
.package-grid .featured small { color: white; }
.package-grid b { position: absolute; right: 14px; top: 14px; padding: 6px 9px; color: var(--ink); background: var(--cream); border-radius: 99px; font-size: 8px; text-transform: uppercase; letter-spacing: .1em; }
.results { display: grid; grid-template-columns: 1fr .85fr; gap: 9vw; align-items: center; background: var(--ink); color: white; }
.results h2 { font-size: clamp(54px, 6vw, 92px); }
.results-copy > p:not(.eyebrow) { max-width: 600px; margin: 35px 0 30px; color: rgba(255,255,255,.65); line-height: 1.7; }
.result-stack { border-top: 1px solid rgba(255,255,255,.2); }
.result-stack > div { display: grid; grid-template-columns: 35px 120px 1fr; gap: 10px; align-items: center; padding: 25px 0; border-bottom: 1px solid rgba(255,255,255,.2); }
.result-stack span { color: var(--hot); font-size: 10px; }
.result-stack strong { font: 500 25px var(--serif); }
.result-stack p { margin: 0; color: rgba(255,255,255,.72); font-size: 11px; line-height: 1.55; }
.reviews { background: #e9e2d9; }
.trustpilot-card { margin-top: 12px; min-height: 100px; display: grid; grid-template-columns: 52px 1fr 30px; gap: 18px; align-items: center; padding: 20px 26px; color: white; background: var(--ink); }
.trustpilot-star { display: grid; place-items: center; width: 48px; height: 48px; color: white; background: #00b67a; font-size: 26px; }
.trustpilot-card strong, .trustpilot-card small { display: block; }
.trustpilot-card strong { font: 500 23px var(--serif); }
.trustpilot-card small { margin-top: 4px; color: rgba(255,255,255,.55); font-size: 10px; letter-spacing: .08em; }
.trustpilot-card i { font-style: normal; font-size: 22px; }
.gear { display: grid; grid-template-columns: .8fr 1fr; gap: 8vw; align-items: center; }
.gear h2 { font-size: clamp(54px, 6vw, 90px); }
.gear-copy > p:not(.eyebrow) { max-width: 510px; line-height: 1.7; font-size: 14px; margin-top: 35px; }
.gear-specs { display: flex; flex-wrap: wrap; gap: 8px; max-width: 540px; margin-top: 30px; }
.gear-specs span { padding: 10px 13px; border: 1px solid var(--line); border-radius: 99px; font-size: 10px; text-transform: uppercase; letter-spacing: .07em; }
.gear-specs b { color: var(--hot); margin-right: 4px; }
.gear-images { min-width: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; align-items: stretch; }
.gear-product { min-width: 0; position: relative; min-height: 285px; margin: 0; padding: 34px 22px 48px; display: grid; place-items: center; border: 1px solid var(--line); background: linear-gradient(145deg, rgba(255,255,255,.75), rgba(246,203,211,.2)); overflow: hidden; }
.gear-product > span { position: absolute; left: 16px; top: 14px; color: var(--hot); font-size: 9px; }
.gear-product img { width: 100%; height: 100%; max-height: 245px; object-fit: contain; }
.gear-product figcaption { position: absolute; left: 18px; bottom: 16px; font: italic 16px var(--serif); }
.tripod-product img { max-height: 250px; }
.phone-product { background: linear-gradient(145deg, rgba(246,203,211,.48), rgba(255,255,255,.8)); }
.phone-product img { max-height: 215px; }
.microphone-product { background: var(--pink); }
.microphone-product img { max-height: 190px; }
.brands { padding-top: 90px; padding-bottom: 90px; border-top: 1px solid var(--line); }
.brands-head { display: flex; justify-content: space-between; align-items: end; gap: 40px; margin-bottom: 55px; }
.brands-head h2 { font-size: clamp(52px, 6vw, 90px); }
.brands-head > p { max-width: 230px; margin: 0 0 8px; font-size: 12px; line-height: 1.6; text-transform: uppercase; letter-spacing: .08em; }
.brands-head > p strong { display: block; color: var(--hot); font: 500 50px/1 var(--serif); letter-spacing: -.04em; }
.brand-wall { display: grid; grid-template-columns: repeat(6, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.brand-logo { position: relative; height: 140px; display: grid; place-items: center; padding: 12px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: rgba(255,255,255,.55); transition: background .25s, transform .25s; }
.brand-logo:hover { z-index: 2; background: white; transform: scale(1.025); }
.brand-logo img { width: 100%; height: 100%; object-fit: contain; opacity: 1; transition: opacity .25s, transform .25s; }
.brand-logo:hover img { opacity: 1; }
.brand-logo.brand-hidden { display: none; }
.brand-logo.brand-cta { padding: 18px; align-content: center; color: white; background: var(--hot); text-align: center; }
.brand-logo.brand-cta strong { display: block; font: italic 20px/1.15 var(--serif); }
.brand-logo.brand-cta span { margin-top: 8px; font-size: 18px; }
.brands-more { margin-top: 30px; }

.process .eyebrow { margin-bottom: 55px; }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); }
.process-grid > div { padding: 30px 26px 10px 0; border-right: 1px solid var(--line); min-height: 200px; }
.process-grid > div:not(:first-child) { padding-left: 26px; }
.process-grid > div:last-child { border-right: 0; }
.process-grid b { font-size: 10px; color: var(--hot); }
.process-grid h3 { font: 500 29px var(--serif); margin: 40px 0 10px; }
.process-grid p { font-size: 12px; line-height: 1.55; opacity: .78; max-width: 210px; }

.contact { padding: 120px 4vw 45px; background: var(--hot); text-align: center; color: var(--ink); }
.contact .eyebrow { margin-bottom: 48px; }
.contact h2 { font-size: clamp(58px, 8vw, 124px); }
.contact h2 em { color: var(--cream); }
.contact-mail { display: inline-flex; align-items: center; gap: 35px; margin: 65px 0 100px; padding: 17px 22px; border: 1px solid var(--ink); font-size: 14px; }
.social-buttons { display: grid; grid-template-columns: repeat(3, 1fr); max-width: 1000px; margin: -58px auto 90px; border-top: 1px solid var(--ink); border-left: 1px solid var(--ink); }
.social-buttons a { min-height: 115px; padding: 22px; display: grid; grid-template-columns: 34px 1fr 20px; gap: 15px; align-items: center; text-align: left; border-right: 1px solid var(--ink); border-bottom: 1px solid var(--ink); transition: background .25s, color .25s; }
.social-buttons a:hover { color: white; background: var(--ink); }
.social-buttons svg { width: 28px; height: 28px; fill: none; stroke: currentColor; stroke-width: 1.7; }
.social-buttons svg.tp-icon { fill: currentColor; stroke: none; }
.social-buttons span, .social-buttons small { display: block; }
.social-buttons span { font: 500 21px var(--serif); }
.social-buttons small { margin-bottom: 4px; font: 500 8px var(--sans); text-transform: uppercase; letter-spacing: .13em; opacity: .65; }
.social-buttons i { font-style: normal; }
.contact-bottom { display: flex; justify-content: space-between; font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }
footer { padding: 27px 4vw; display: flex; justify-content: space-between; align-items: center; font-size: 11px; }
.thanks-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 32px;
}
.thanks-screen {
  width: min(720px, calc(100% - 40px));
  padding: clamp(36px, 6vw, 72px);
  border: 1px solid var(--line);
  background: rgba(255, 252, 247, .78);
  box-shadow: var(--shadow);
  text-align: center;
}
.thanks-screen .brand {
  display: inline-block;
  margin-bottom: clamp(46px, 8vw, 84px);
}
.thanks-screen h1 {
  max-width: 620px;
  margin: 20px auto;
  font: 700 clamp(3rem, 7.5vw, 6rem)/.9 var(--serif);
  letter-spacing: -.07em;
}
.thanks-screen p:not(.eyebrow) {
  max-width: 560px;
  margin: 0 auto 30px;
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.65;
}
.thanks-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  justify-content: center;
  align-items: center;
}
.thanks-eyebrow {
  justify-content: center;
}
.social-rail {
  position: fixed;
  right: 20px;
  top: 50%;
  z-index: 25;
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 7px;
  transform: translateY(-50%);
  border: 1px solid rgba(23,17,15,.13);
  border-radius: 999px;
  background: rgba(244,240,233,.88);
  box-shadow: 0 14px 45px rgba(23,17,15,.15);
  backdrop-filter: blur(14px);
}
.social-rail-link {
  position: relative;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  color: var(--ink);
  background: rgba(255,255,255,.72);
  transition: color .22s, background .22s, transform .22s, box-shadow .22s;
}
.social-rail-link svg {
  width: 19px;
  height: 19px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
}
.social-rail-link.facebook svg,
.social-rail-link.trustpilot svg {
  fill: currentColor;
  stroke: none;
}
.social-rail-link .social-dot { fill: currentColor; stroke: none; }
.social-rail-link span {
  position: absolute;
  right: calc(100% + 13px);
  padding: 8px 11px;
  border-radius: 7px;
  color: white;
  background: var(--ink);
  box-shadow: 0 8px 25px rgba(23,17,15,.18);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .03em;
  opacity: 0;
  pointer-events: none;
  transform: translateX(6px);
  transition: opacity .2s, transform .2s;
}
.social-rail-link span::after {
  content: "";
  position: absolute;
  left: 100%;
  top: 50%;
  border: 5px solid transparent;
  border-left-color: var(--ink);
  transform: translateY(-50%);
}
.social-rail-link:hover,
.social-rail-link:focus-visible {
  color: white;
  background: var(--ink);
  box-shadow: 0 8px 20px rgba(23,17,15,.2);
  transform: translateX(-3px);
}
.social-rail-link.instagram:hover,
.social-rail-link.instagram:focus-visible { background: var(--hot); }
.social-rail-link.trustpilot:hover,
.social-rail-link.trustpilot:focus-visible { background: #00b67a; }
.social-rail-link:hover span,
.social-rail-link:focus-visible span {
  opacity: 1;
  transform: translateX(0);
}

.hero-proof {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: -10px 0 30px;
}
.hero-proof span {
  padding: 8px 11px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.38);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.trust-score {
  display: grid;
  grid-template-columns: auto auto auto;
  gap: 10px;
  align-items: center;
}
.trust-score strong {
  color: #00a66b;
  font: 600 19px var(--sans);
}
.trust-score span {
  font: italic 16px var(--serif);
}
.trust-score i { font-style: normal; }
.work-overlay > span {
  display: grid;
  gap: 4px;
}
.work-overlay b { font-weight: 600; }
.work-overlay small {
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .05em;
  opacity: .85;
  text-transform: uppercase;
}

.for-whom { background: var(--cream); }
.fit-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--line);
}
.fit-grid article {
  min-height: 260px;
  padding: 26px;
  border-right: 1px solid var(--line);
}
.fit-grid article:last-child { border-right: 0; }
.fit-grid span {
  color: var(--hot);
  font-size: 10px;
}
.fit-grid h3 {
  margin: 78px 0 12px;
  font: 500 26px/1.05 var(--serif);
}
.fit-grid p {
  margin: 0;
  color: rgba(23,17,15,.7);
  font-size: 12px;
  line-height: 1.6;
}

.package-grid-sales { grid-template-columns: repeat(3, 1fr); }
.package-grid-sales article { min-height: 365px; }
.package-grid-sales ul {
  display: grid;
  gap: 9px;
  margin: 22px 0 0;
  padding: 20px 0 0;
  border-top: 1px solid var(--line);
  list-style: none;
}
.package-grid-sales li {
  position: relative;
  padding-left: 17px;
  font-size: 11px;
  line-height: 1.4;
}
.package-grid-sales li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--hot);
  font-weight: 700;
}
.package-grid-sales .featured ul { border-color: rgba(255,255,255,.35); }
.package-grid-sales .featured li::before { color: white; }

.case-grid {
  display: grid;
  gap: 10px;
}
.case-grid article {
  padding: 22px;
  border: 1px solid rgba(255,255,255,.2);
  background: rgba(255,255,255,.035);
}
.case-grid span {
  color: var(--hot);
  font-size: 9px;
  letter-spacing: .1em;
}
.case-grid strong {
  display: block;
  margin: 9px 0 7px;
  font: 500 22px var(--serif);
}
.case-grid p {
  margin: 0;
  color: rgba(255,255,255,.72);
  font-size: 11px;
  line-height: 1.55;
}
.case-grid small {
  display: block;
  margin-top: 13px;
  color: rgba(255,255,255,.45);
  font-size: 8px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.review-slider {
  max-width: 1050px;
  margin-inline: auto;
}
.review-slide {
  min-height: 430px;
  padding: clamp(38px, 5vw, 70px);
  color: var(--ink);
  background: var(--pink);
}
.review-rating {
  color: #00a66b;
  font-size: 25px;
  letter-spacing: .06em;
}
.review-kicker {
  margin: 22px 0 35px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .14em;
}
.review-slide h3 {
  max-width: 780px;
  margin: 0 0 18px;
  font: italic clamp(28px, 3.5vw, 50px)/1.08 var(--serif);
}
.review-text {
  max-width: 760px;
  margin: 0;
  font-size: 15px;
  line-height: 1.7;
}
.review-slide footer {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-top: 42px;
  padding: 0;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.review-slide footer span { opacity: .55; }
.review-controls {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  border: 1px solid var(--line);
  border-top: 0;
}
.review-controls button {
  min-height: 58px;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
}
.review-controls button:first-child { text-align: left; padding-left: 22px; }
.review-controls button:last-child { text-align: right; padding-right: 22px; }
.review-controls button:hover { color: var(--hot); }
.review-controls span {
  font: 500 14px var(--serif);
}
.reviews .trustpilot-card {
  max-width: 1050px;
  margin: 12px auto 0;
}

.brief-layout {
  display: grid;
  grid-template-columns: .55fr 1fr;
  gap: 6vw;
  max-width: 1250px;
  margin: 60px auto 85px;
  text-align: left;
}
.brief-copy > p {
  margin: 0 0 30px;
  font: italic 23px/1.45 var(--serif);
}
.brief-copy .contact-mail {
  margin: 0;
  font-size: 12px;
}
.brief-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.hidden-field {
  display: none;
}
.brief-form label {
  display: grid;
  gap: 7px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.brief-form input,
.brief-form select,
.brief-form textarea {
  width: 100%;
  border: 1px solid rgba(23,17,15,.45);
  border-radius: 0;
  color: var(--ink);
  background: rgba(255,255,255,.3);
  font: 13px var(--sans);
  padding: 14px;
  outline: none;
}
.brief-form textarea { resize: vertical; }
.brief-form input:focus,
.brief-form select:focus,
.brief-form textarea:focus {
  border-color: var(--ink);
  background: rgba(255,255,255,.55);
}
.brief-wide { grid-column: 1 / -1; }
.brief-submit {
  grid-column: 1 / -1;
  border: 0;
  cursor: pointer;
}
.brief-status {
  grid-column: 1 / -1;
  margin: 0;
  min-height: 20px;
  font-size: 12px;
  line-height: 1.5;
  color: var(--muted);
}
.brief-status.success {
  color: #0f6b4d;
}
.brief-status.error {
  color: #b4334b;
}

a:focus-visible,
button:focus-visible {
  outline: 3px solid var(--hot);
  outline-offset: 4px;
}

.lightbox { width: min(430px, 90vw); padding: 0; border: 0; background: #111; box-shadow: 0 30px 90px rgba(0,0,0,.35); }
.lightbox::backdrop { background: rgba(23,17,15,.85); backdrop-filter: blur(8px); }
.lightbox img { max-height: 82vh; object-fit: contain; }
.lightbox-close { position: fixed; top: 22px; right: 28px; border: 0; background: none; color: white; font-size: 36px; cursor: pointer; }

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* Desktop premium layout */
@media (min-width: 1100px) {
  :root { --page-pad: max(4vw, calc((100vw - 1500px) / 2)); }

  .nav {
    height: 76px;
    padding-inline: var(--page-pad);
    position: sticky;
    top: 0;
    z-index: 30;
    background: rgba(244,240,233,.92);
    backdrop-filter: blur(14px);
  }
  .nav nav { gap: 27px; }
  .nav-cta { padding: 11px 16px; }

  .hero {
    width: min(100%, 1920px);
    min-height: min(800px, calc(100vh - 76px));
    margin-inline: auto;
    padding: clamp(65px, 7vh, 90px) var(--page-pad) 64px;
    grid-template-columns: minmax(0, 1.08fr) minmax(440px, .92fr);
    gap: clamp(55px, 6vw, 115px);
    align-items: center;
  }
  .hero-copy { padding-top: 0; }
  .hero-copy h1 {
    max-width: 800px;
    font-size: clamp(74px, 5.7vw, 108px);
    line-height: .9;
  }
  .hero-lead {
    max-width: 560px;
    margin: 32px 0 30px;
    font-size: 18px;
  }
  .hero-visual {
    min-height: 650px;
    justify-content: flex-end;
  }
  .hero-photo {
    width: min(92%, 510px);
    transform: rotate(1.2deg);
  }
  .hero-note {
    position: absolute;
    left: 0;
    bottom: 25px;
    margin: 0;
    padding: 16px 18px;
    background: rgba(244,240,233,.9);
    backdrop-filter: blur(10px);
  }
  .hero-index { right: var(--page-pad); }

  .trust-strip,
  .section,
  .contact {
    padding-left: var(--page-pad);
    padding-right: var(--page-pad);
  }
  .trust-strip { padding-top: 20px; padding-bottom: 20px; }
  .section.numbers { padding-top: 48px; padding-bottom: 48px; }
  .numbers-grid > div { padding: 28px 26px; }
  .numbers-grid strong { font-size: clamp(45px, 4vw, 64px); }

  .section { padding-top: 88px; padding-bottom: 88px; }
  .section-head {
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 70px;
    margin-bottom: 46px;
  }
  .section-head h2,
  .about h2,
  .campaign-intro h2,
  .results h2,
  .gear h2,
  .brands-head h2 {
    font-size: clamp(58px, 4.6vw, 80px);
    line-height: .92;
  }

  .portfolio { padding-top: 96px; }
  .work-grid {
    max-width: 1260px;
    grid-auto-rows: 500px;
    gap: 12px;
  }

  .library { padding-top: 92px; padding-bottom: 95px; }
  .video-grid {
    max-width: 1500px;
    margin-inline: auto;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
  }
  .load-more { margin-top: 34px; }

  .campaigns {
    grid-template-columns: .9fr 1.1fr;
    gap: 70px;
    padding-top: 72px;
    padding-bottom: 72px;
  }
  .campaign-note { margin-top: -12px; }

  .about {
    grid-template-columns: minmax(360px, .72fr) minmax(0, 1.2fr);
    gap: clamp(65px, 7vw, 120px);
    min-height: 760px;
  }
  .about-image { max-width: 470px; }
  .about-copy .lead { margin: 28px 0 20px; }

  .services { padding-top: 98px; padding-bottom: 95px; }
  .service-list article { min-height: 108px; }
  .deliverables { margin-top: 60px; padding-top: 35px; }

  .packages { padding-top: 68px; padding-bottom: 68px; }
  .package-grid article { min-height: 235px; }
  .process { padding-top: 48px; padding-bottom: 48px; }
  .process .eyebrow { margin-bottom: 26px; }
  .process-grid > div { min-height: 145px; }
  .process-grid h3 { margin-top: 22px; }

  .results { padding-top: 82px; padding-bottom: 82px; }
  .reviews { padding-top: 76px; padding-bottom: 76px; }

  .gear {
    grid-template-columns: minmax(350px, .78fr) minmax(0, 1.22fr);
    gap: 70px;
    padding-top: 90px;
    padding-bottom: 90px;
  }
  .gear-product { min-height: 245px; }
  .gear-product img { max-height: 205px; }

  .brands { padding-top: 75px; padding-bottom: 78px; }
  .brands-head { margin-bottom: 40px; }
  .brand-wall { grid-template-columns: repeat(6, minmax(0, 1fr)); }
  .brand-logo { height: 110px; padding: 15px; }

  .contact { padding-top: 92px; }
  .contact h2 { font-size: clamp(72px, 6.4vw, 110px); }
  .contact-mail { margin: 48px 0 88px; }

  section[id] { scroll-margin-top: 76px; }
}

@media (max-width: 900px) {
  .nav { height: 70px; }
  .menu-button { display: block; }
  .nav nav { position: fixed; inset: 70px 0 0; background: var(--pink); flex-direction: column; justify-content: center; gap: 30px; font: 500 34px var(--serif); transform: translateX(100%); transition: transform .35s ease; }
  .menu-open .nav nav { transform: translateX(0); }
  .nav-cta { font: 13px var(--sans); }
  .hero { grid-template-columns: 1fr; min-height: auto; padding-top: 55px; }
  .hero-copy { padding: 0; }
  h1 { font-size: clamp(58px, 18vw, 84px); }
  .hero-lead { margin-top: 28px; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 20px; }
  .hero-visual { margin-top: 65px; min-height: 550px; }
  .hero-photo { width: min(74vw, 380px); }
  .hero-note { position: absolute; right: 0; bottom: 10px; }
  .hero-index { display: none; }
  .trust-strip { align-items: flex-start; gap: 25px; flex-direction: column; overflow: hidden; }
  .logo-row { width: max-content; }
  .section { padding: 85px 5vw; }
  .section-head { grid-template-columns: 1fr; gap: 32px; }
  .section-head h2, .about h2 { font-size: clamp(50px, 15vw, 78px); }
  .work-grid { grid-template-columns: 1fr 1fr; grid-auto-rows: 430px; }
  .numbers-grid { grid-template-columns: 1fr 1fr; }
  .numbers-grid > div:nth-child(2) { border-right: 0; }
  .numbers-grid > div:nth-child(n+3) { border-top: 1px solid var(--line); }
  .video-grid { grid-template-columns: repeat(3, 1fr); }
  .campaigns, .results, .gear { grid-template-columns: 1fr; }
  .fit-grid { grid-template-columns: 1fr 1fr; }
  .fit-grid article:nth-child(2) { border-right: 0; }
  .fit-grid article:nth-child(n+3) { border-top: 1px solid var(--line); }
  .campaign-note { grid-column: 1; margin-top: 0; }
  .package-grid { grid-template-columns: 1fr 1fr; }
  .package-grid-sales { grid-template-columns: 1fr; }
  .package-grid-sales article { min-height: auto; }
  .brands-head { align-items: flex-start; flex-direction: column; }
  .brand-wall { grid-template-columns: repeat(4, 1fr); }
  .about { grid-template-columns: 1fr; gap: 60px; }
  .about-image { width: 82%; }
  .service-list article { grid-template-columns: 40px 1fr 25px; padding: 26px 0; }
  .service-list article p { grid-column: 2 / 4; }
  .process-grid { grid-template-columns: 1fr 1fr; }
  .process-grid > div:nth-child(2) { border-right: 0; }
  .process-grid > div:nth-child(n+3) { border-top: 1px solid var(--line); }
  .contact-bottom { gap: 30px; }
  .brief-layout { grid-template-columns: 1fr; }
  .social-rail { display: none; }
}

@media (max-width: 560px) {
  .hero { padding-inline: 5vw; }
  .hero-visual { min-height: 500px; }
  .hero-note { right: -6px; }
  .logo-row { gap: 14px; }
  .filters { overflow-x: auto; padding-bottom: 7px; }
  .filters button { flex: 0 0 auto; }
  .work-grid { grid-template-columns: 1fr; grid-auto-rows: 590px; }
  .video-grid { grid-template-columns: 1fr 1fr; }
  .video-card-info strong { font-size: 15px; }
  .package-grid { grid-template-columns: 1fr; }
  .fit-grid { grid-template-columns: 1fr; }
  .fit-grid article { min-height: auto; border-right: 0; border-top: 1px solid var(--line); }
  .fit-grid h3 { margin-top: 35px; }
  .result-stack > div { grid-template-columns: 30px 90px 1fr; }
  .gear-images { grid-template-columns: 1fr 1fr; }
  .brand-wall { grid-template-columns: 1fr 1fr; }
  .brand-logo { height: 115px; padding: 8px; }
  .gear-images { grid-template-columns: 1fr; grid-template-rows: auto; }
  .gear-product { min-height: 340px; }
  .gear-product img { max-height: 270px; }
  .phone-product img { max-height: 240px; }
  .microphone-product img { max-height: 220px; }
  .about-columns { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: 1fr; }
  .process-grid > div { border-right: 0; border-top: 1px solid var(--line); min-height: 160px; padding-left: 0 !important; }
  .process-grid h3 { margin-top: 25px; }
  .contact { padding-inline: 5vw; }
  .contact-mail { max-width: 100%; gap: 10px; font-size: 12px; }
  .brief-layout { margin-top: 42px; }
  .brief-form { grid-template-columns: 1fr; }
  .brief-form label,
  .brief-wide,
  .brief-submit { grid-column: 1; }
  .review-slide { min-height: 500px; padding: 32px 25px; }
  .review-controls button { font-size: 9px; }
  .social-buttons { grid-template-columns: 1fr; margin-top: -55px; }
  .contact-bottom { align-items: flex-start; flex-direction: column; }
  footer { align-items: flex-start; gap: 15px; flex-direction: column; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
}
