:root{
  --bg:#f7f2eb;
  --paper:#fffaf5;
  --ink:#101010;
  --muted:rgba(16,16,16,.70);
  --white:#ffffff;
  --black:#070707;
  --red:#b91f28;
  --red-deep:#8f141b;
  --line:rgba(255,255,255,.12);
  --dark-line:rgba(0,0,0,.10);
  --max:1360px;
  --shadow:0 30px 80px rgba(0,0,0,.16);
  --radius:28px;
  --ease:cubic-bezier(.22,.9,.25,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}
h1,h2,h3,p{margin:0}
p{font-size:19px;line-height:1.55;color:var(--muted)}
.section-dark p{color:rgba(255,255,255,.74)}
.progress{position:fixed;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--red),#ffbec3);z-index:90;box-shadow:0 0 16px rgba(185,31,40,.55)}
.site-header{position:fixed;left:0;right:0;top:0;z-index:80;display:flex;align-items:center;justify-content:space-between;padding:24px clamp(20px,4vw,44px);border-bottom:1px solid transparent;transition:padding .35s var(--ease), background .35s var(--ease), backdrop-filter .35s var(--ease), border-color .35s var(--ease)}
.site-header.scrolled{padding:14px clamp(20px,4vw,44px);background:rgba(7,7,7,.82);backdrop-filter:blur(15px);border-color:rgba(255,255,255,.08)}
.brand img{height:58px}
.nav{display:flex;align-items:center;gap:8px}
.nav a{color:#fff;padding:12px 14px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;opacity:.88;transition:opacity .3s, transform .3s var(--ease)}
.nav a:hover{opacity:1;transform:translateY(-1px)}
.nav-cta{border:1px solid rgba(255,255,255,.18);border-radius:999px;padding-inline:18px!important;background:rgba(255,255,255,.04)}
.nav-toggle{display:none;background:none;border:0;color:#fff;text-transform:uppercase;letter-spacing:.13em;font-size:12px}
.section{padding:clamp(82px,9vw,128px) clamp(20px,5vw,58px);position:relative;overflow:hidden}
.section-dark{background:var(--black);color:#fff}.section-light{background:var(--bg)}.section-red{background:linear-gradient(135deg,var(--red-deep),var(--red));color:#fff}
.section-label,.section-kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:900}
.section-label{max-width:var(--max);margin:0 auto 18px;color:rgba(0,0,0,.46)}.section-label.inverse{color:rgba(255,255,255,.50)}
.section-kicker{display:block;margin-bottom:18px;color:var(--red)}.section-kicker.inverse{color:rgba(255,255,255,.52)}
.eyebrow{display:inline-flex;align-items:center;gap:12px;margin:0 0 18px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.62);font-weight:900}.eyebrow::before{content:"";width:36px;height:1px;background:currentColor;opacity:.7}.eyebrow.red{color:var(--red)}
h1{font-size:clamp(58px,6.3vw,104px);line-height:.93;letter-spacing:-.055em;max-width:820px}
h2{font-size:clamp(38px,4.4vw,68px);line-height:1;letter-spacing:-.045em;max-width:1000px}
h3{font-size:clamp(24px,2vw,34px);line-height:1.05;letter-spacing:-.03em}

.hero{min-height:100svh;padding-top:118px;display:flex;align-items:center;background:radial-gradient(circle at top right, rgba(185,31,40,.20), transparent 38%), #070707}
.hero-shell{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:.74fr 1.06fr;gap:44px;align-items:center;width:100%}
.hero-copy{position:relative;z-index:2}
.hero-text{margin-top:22px;max-width:670px;font-size:22px;color:rgba(255,255,255,.78)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}.button{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 20px;border-radius:999px;border:1px solid rgba(255,255,255,.16);font-size:13px;letter-spacing:.12em;text-transform:uppercase;font-weight:900;transition:transform .35s var(--ease), background .35s var(--ease), border-color .35s var(--ease)}.button:hover{transform:translateY(-2px)}.button-red{background:var(--red);color:#fff;border-color:var(--red)}.button-ghost{background:rgba(255,255,255,.04);color:#fff}
.hero-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:34px}.hero-tags span{border:1px solid rgba(255,255,255,.12);padding:10px 14px;border-radius:999px;font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.70);background:rgba(255,255,255,.03)}
.hero-stage{position:relative}
.stage-frame{position:relative;min-height:760px;border-radius:32px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015));border:1px solid rgba(255,255,255,.10);box-shadow:0 50px 120px rgba(0,0,0,.35);overflow:hidden;padding:26px}
.stage-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);background-size:72px 72px;mask-image:linear-gradient(180deg, rgba(0,0,0,.8), transparent 90%);pointer-events:none}
.thread{position:absolute;left:52%;top:0;bottom:0;width:2px;background:linear-gradient(var(--red), transparent);box-shadow:0 0 24px rgba(185,31,40,.62)}
.stage-panel{position:absolute;border-radius:28px;overflow:hidden;border:1px solid rgba(255,255,255,.10);box-shadow:var(--shadow);background:#111;transition:transform .45s var(--ease), box-shadow .45s var(--ease)}
.stage-panel:hover{transform:translateY(-5px);box-shadow:0 40px 90px rgba(0,0,0,.28)}
.stage-panel figcaption{position:absolute;left:16px;right:16px;bottom:14px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.84);z-index:2}
.panel-event,.panel-showroom,.service-photo,.photo-fill{background-image:linear-gradient(135deg, rgba(0,0,0,.30), rgba(0,0,0,.06)), var(--img), var(--fallback), linear-gradient(135deg,#ddd,#bbb);background-size:cover;background-position:center}.panel-event::after,.panel-showroom::after,.service-photo::after,.photo-fill::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 18%, rgba(0,0,0,.22));pointer-events:none}
.panel-event{left:6%;top:7%;width:48%;height:44%}
.panel-web{right:5%;top:10%;width:48%;height:39%;padding:14px;background:#0f0f0f}
.panel-print{left:14%;bottom:10%;width:32%;height:34%;background:linear-gradient(135deg,#efe5da,#fbf7f2)}
.panel-showroom{right:12%;bottom:7%;width:39%;height:32%}
.panel-browser{height:100%;display:flex;flex-direction:column;border-radius:18px;overflow:hidden;background:#fff}.browser-top{height:32px;display:flex;align-items:center;gap:6px;padding-left:11px;background:rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.12)}.browser-top span{width:7px;height:7px;border-radius:50%;background:#daa0a4}.browser-body{background:#fff;min-height:0;flex:1;padding:16px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.browser-hero{grid-column:1/-1;height:88px;background:linear-gradient(135deg,var(--black) 0 45%, var(--red) 45% 55%, #f4efe8 55%)}.browser-card,.browser-wide{border:1px solid rgba(0,0,0,.08);background:#f3ece4}.browser-card{height:88px}.browser-wide{grid-column:1/-1;height:64px}
.brochure-stack{position:relative;width:100%;height:100%}.brochure-stack div{position:absolute;width:48%;height:74%;left:50%;top:50%;border-radius:14px;border:1px solid rgba(0,0,0,.08);box-shadow:0 18px 42px rgba(0,0,0,.12)}.brochure-stack div:nth-child(1){transform:translate(-72%,-46%) rotate(-10deg);background:#fff}.brochure-stack div:nth-child(2){transform:translate(-45%,-58%) rotate(4deg);background:#f4ede5}.brochure-stack div:nth-child(3){transform:translate(-28%,-44%) rotate(8deg);background:linear-gradient(135deg,var(--black) 0 42%, var(--red) 42% 48%, #fff 48%)}
.stage-note{position:absolute;padding:18px;background:rgba(255,248,240,.97);color:var(--ink);border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.20);font-size:17px;line-height:1.24;max-width:220px;z-index:4}.stage-note span{display:block;margin-bottom:8px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);font-weight:900}.note-left{left:2.5%;bottom:20%}.note-right{right:2%;top:50%;background:rgba(185,31,40,.97);color:#fff}.note-right span{color:#ffd6d9}
.scroll-cue{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.50)}

.intro-grid,.work-head,.process-head,.moments-grid,.founder-section,.brief-section{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr .85fr;gap:54px;align-items:end}
.intro-side p{font-size:21px}
.services-section{padding-top:48px}.service-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.service-card{background:#fff;border:1px solid var(--dark-line);border-radius:24px;padding:18px 18px 22px;box-shadow:0 10px 34px rgba(0,0,0,.05);transition:transform .35s var(--ease), box-shadow .35s var(--ease)}.service-card:hover{transform:translateY(-5px);box-shadow:0 24px 48px rgba(0,0,0,.08)}.service-photo{position:relative;height:190px;border-radius:16px;margin-bottom:18px}.service-card span,.audience-card span,.work-copy span,.step span,.moments-cards article span{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);font-weight:900;margin-bottom:14px}.service-card p{font-size:16px;margin-top:12px}
.support-quote{padding-block:110px}.quote-wrap{max-width:var(--max);margin:0 auto}.quote-wrap h2{max-width:1080px}
.audience-top{max-width:var(--max);margin:0 auto 38px;display:grid;grid-template-columns:1fr .55fr;gap:48px;align-items:end}.audience-top p{font-size:24px;line-height:1.28}.audience-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.audience-card{min-height:210px;padding:26px;border:1px solid rgba(255,255,255,.12);border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));display:flex;flex-direction:column;justify-content:space-between;transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease)}.audience-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.24);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.03))}.audience-card strong{font-size:30px;line-height:1.02;letter-spacing:-.04em}.audience-card em{font-style:normal;color:rgba(255,255,255,.67);font-size:16px;line-height:1.45}
.work-section{background:linear-gradient(180deg,#f9f4ee 0%, #f4ede6 100%)}.work-layout{max-width:var(--max);margin:42px auto 0;display:grid;grid-template-columns:320px minmax(0,1fr);gap:28px;align-items:start}.work-sticky{position:sticky;top:96px;padding-top:8px}.work-sticky h3{margin:10px 0 14px}.work-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}.work-card{background:#fff;border:1px solid var(--dark-line);border-radius:26px;overflow:hidden;box-shadow:0 16px 40px rgba(0,0,0,.06);min-height:420px;display:flex;flex-direction:column;transition:transform .35s var(--ease), box-shadow .35s var(--ease)}.work-card:hover{transform:translateY(-5px);box-shadow:0 24px 54px rgba(0,0,0,.10)}.work-card.large{grid-column:span 2}.placeholder{min-height:270px;background:#f1eae2;position:relative;overflow:hidden}.website-placeholder{padding:16px;background:linear-gradient(135deg,#111,#050505)}.print-placeholder{display:grid;place-items:center;background:linear-gradient(135deg,#eee4d8,#fbf7f2)}.photo-card{position:relative}.photo-fill{position:relative;flex:1;min-height:420px;background-size:cover;background-position:center}.work-copy{padding:26px}.work-copy p{font-size:16px;margin-top:12px}.work-copy.overlay{position:absolute;left:18px;right:18px;bottom:18px;background:rgba(255,248,240,.95);backdrop-filter:blur(8px);border-radius:18px;box-shadow:0 16px 34px rgba(0,0,0,.16)}.work-copy.overlay.light{background:rgba(255,255,255,.92)}
.moments-grid{align-items:start}.moments-copy p{margin-top:18px;max-width:620px}.moments-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}.moments-cards article{background:#fff;border:1px solid var(--dark-line);border-radius:24px;padding:24px;min-height:190px;box-shadow:0 10px 34px rgba(0,0,0,.05)}.moments-cards article p{font-size:16px;margin-top:10px}
.process-grid{max-width:var(--max);margin:38px auto 0;display:grid;grid-template-columns:repeat(5,1fr);gap:14px}.step{border:1px solid rgba(255,255,255,.10);border-radius:24px;padding:24px;min-height:240px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));transition:transform .35s var(--ease), border-color .35s var(--ease)}.step:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.22)}.step p{font-size:15px;margin-top:12px}
.founder-section{align-items:center}.founder-photo img{height:720px;width:100%;object-fit:cover;border-radius:28px;border:1px solid var(--dark-line);box-shadow:var(--shadow)}.founder-copy p{margin-top:18px;max-width:620px}
.brief-section{align-items:start}.brief-copy p:last-child{margin-top:18px;font-size:22px;max-width:620px}.brief-form{background:#fff;color:var(--ink);border-radius:24px;padding:22px;border:1px solid rgba(255,255,255,.08);box-shadow:0 22px 50px rgba(0,0,0,.18)}label{display:block;font-size:11px;letter-spacing:.15em;text-transform:uppercase;font-weight:900;color:rgba(0,0,0,.54);margin-bottom:16px}input,textarea{display:block;width:100%;margin-top:8px;padding:14px 15px;border-radius:14px;border:1px solid rgba(0,0,0,.12);background:#fbf7f2;color:var(--ink)}textarea{min-height:140px;resize:vertical}button{width:100%;height:50px;border:0;border-radius:999px;background:var(--black);color:#fff;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:900;margin-top:8px}
.footer{background:var(--black);color:#fff;padding:38px clamp(20px,5vw,58px);display:grid;grid-template-columns:200px 1fr auto;gap:20px;align-items:center;border-top:1px solid rgba(255,255,255,.08)}.footer img{height:34px}.footer p{font-size:15px;color:rgba(255,255,255,.62)}.footer span{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.56)}
[data-animate]{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease), transform .9s var(--ease)}[data-animate].visible{opacity:1;transform:none}[data-parallax]{will-change:transform;transition:transform .2s linear}
@media (max-width:1120px){.hero-shell,.intro-grid,.work-head,.process-head,.moments-grid,.founder-section,.brief-section,.audience-top{grid-template-columns:1fr}.service-grid,.audience-grid,.moments-cards,.process-grid{grid-template-columns:1fr 1fr}.work-layout{grid-template-columns:1fr}.work-sticky{position:relative;top:auto}.stage-frame{min-height:660px}}
@media (max-width:920px){.site-header{background:rgba(7,7,7,.72);backdrop-filter:blur(12px)}.nav-toggle{display:block}.nav{position:absolute;top:74px;left:16px;right:16px;display:none;flex-direction:column;align-items:flex-start;background:#111;padding:16px;border:1px solid rgba(255,255,255,.10);border-radius:18px}.nav.open{display:flex}.hero{min-height:auto;padding-bottom:84px}.service-grid,.audience-grid,.work-cards,.moments-cards,.process-grid{grid-template-columns:1fr}.work-card.large{grid-column:auto}.footer{grid-template-columns:1fr}.hero-shell{gap:34px}.stage-frame{min-height:560px}.panel-event{width:54%;height:42%}.panel-web{width:50%;height:37%}.panel-print{width:36%;height:30%}.panel-showroom{width:42%;height:30%}}
@media (max-width:640px){.section{padding:76px 18px}h1{font-size:52px}h2{font-size:38px}.hero-text,.intro-side p,.audience-top p,.brief-copy p:last-child{font-size:19px}.hero-tags{gap:8px}.hero-tags span{font-size:11px;padding:8px 11px}.stage-frame{min-height:480px;padding:16px}.panel-event{left:3%;top:7%;width:56%;height:42%}.panel-web{right:3%;top:12%;width:51%;height:34%}.panel-print{left:10%;bottom:10%;width:38%;height:28%}.panel-showroom{right:7%;bottom:7%;width:45%;height:27%}.stage-note{max-width:170px;font-size:13px;padding:13px}.note-left{bottom:19%}.note-right{top:56%}.founder-photo img{height:520px}.footer{padding:32px 18px}}


/* V3 footer + logo polish */
.site-header{padding:22px clamp(20px,4vw,48px)}
.site-header.scrolled{padding:12px clamp(20px,4vw,48px)}
.site-header.scrolled .brand img{height:46px}
.brand{display:flex;align-items:center;min-width:118px}
.brand img{height:58px;width:auto;transition:height .35s var(--ease), opacity .25s var(--ease)}
.nav a{font-size:12px;letter-spacing:.095em}
.hero{padding-top:145px}

.footer{
  background:var(--black);
  color:#fff;
  padding:0 clamp(20px,5vw,58px);
  border-top:1px solid rgba(255,255,255,.10);
  display:block;
}
.footer-main{
  max-width:var(--max);
  margin:0 auto;
  padding:52px 0 42px;
  display:grid;
  grid-template-columns:minmax(170px,.7fr) minmax(260px,1.4fr) minmax(180px,.75fr) auto;
  gap:34px;
  align-items:start;
}
.footer-brand img{
  height:64px;
  width:auto;
}
.footer-message p{
  max-width:520px;
  font-size:18px;
  line-height:1.5;
  color:rgba(255,255,255,.76);
}
.footer-message span{
  display:block;
  margin-top:16px;
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,.46);
}
.footer-links{
  display:grid;
  gap:12px;
}
.footer-links a{
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.64);
  transition:color .25s var(--ease), transform .25s var(--ease);
}
.footer-links a:hover{
  color:#fff;
  transform:translateX(3px);
}
.footer-socials{
  display:flex;
  gap:10px;
  justify-content:flex-end;
}
.footer-socials a{
  width:44px;
  height:44px;
  border-radius:999px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.04);
  color:#fff;
  transition:background .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease);
}
.footer-socials a:hover{
  transform:translateY(-2px);
  background:rgba(185,31,40,.22);
  border-color:rgba(255,255,255,.30);
}
.footer-socials svg{
  width:20px;
  height:20px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.7;
}
.footer-socials a[aria-label="Facebook"] svg{
  fill:currentColor;
  stroke:none;
}
.footer-bottom{
  max-width:var(--max);
  margin:0 auto;
  padding:20px 0 28px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
}
.footer-bottom p{
  font-size:12px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:rgba(255,255,255,.48);
}
@media (max-width:960px){
  .brand img{height:46px}
  .site-header.scrolled .brand img{height:40px}
  .hero{padding-top:128px}
  .footer-main{
    grid-template-columns:1fr;
    gap:28px;
    padding:44px 0 34px;
  }
  .footer-brand img{height:56px}
  .footer-socials{justify-content:flex-start}
  .footer-bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}
@media (max-width:640px){
  .brand img{height:42px}
  .site-header.scrolled .brand img{height:36px}
  .footer-brand img{height:50px}
}


/* ----- V3 luxe refinement: surgical overrides ----- */

/* bigger logo */
.site-header{padding:22px clamp(20px,4vw,48px)}
.site-header.scrolled{padding:14px clamp(20px,4vw,48px)}
.brand{
  display:flex;
  align-items:center;
  width:190px;
  min-width:190px;
}
.brand img{
  height:88px !important;
  width:auto;
  max-width:none;
  transition:height .35s var(--ease), opacity .25s var(--ease);
}
.site-header.scrolled .brand img{height:72px !important}

/* hero polish */
.hero{
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 84% 18%, rgba(185,31,40,.18), transparent 26%),
    radial-gradient(circle at 18% 86%, rgba(255,255,255,.03), transparent 18%);
  pointer-events:none;
}
.hero-shell{position:relative;z-index:1}
.hero-copy h1{letter-spacing:-.07em;max-width:760px}
.hero-text{max-width:650px}
.hero-tags{
  display:grid;
  grid-template-columns:repeat(4,max-content);
  gap:10px;
  margin-top:36px;
}
.hero-tags span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.03);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}

/* section backgrounds */
.intro-section{
  background:
    radial-gradient(circle at 12% 10%, rgba(185,31,40,.06), transparent 26%),
    linear-gradient(180deg, #faf5ef 0%, #f6efe7 100%);
}
.intro-section::before,
.services-section::before,
.bridge-statement::before,
.audience-section::before,
.work-section::before,
.moments-section::before,
.founder-section::before,
.brief-section::before{
  content:"";
  position:absolute;inset:0;
  pointer-events:none;
  opacity:.6;
}
.intro-section::before{
  background-image:
    linear-gradient(rgba(0,0,0,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,.03) 1px, transparent 1px);
  background-size:90px 90px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.55), transparent 80%);
}
.services-section{
  background:
    radial-gradient(circle at 86% 8%, rgba(185,31,40,.08), transparent 28%),
    linear-gradient(180deg,#fffdf9 0%, #f6efe7 100%);
}
.services-section::before{
  background:
    radial-gradient(circle at 30% 120%, rgba(185,31,40,.06), transparent 26%);
}
.service-card{
  cursor:pointer;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.service-card:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 70px rgba(0,0,0,.10);
  border-color:rgba(185,31,40,.24);
}
.service-card-cta{
  margin-top:18px;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--red);
  font-weight:900;
}

.bridge-statement{
  background:
    radial-gradient(circle at 80% 40%, rgba(185,31,40,.10), transparent 24%),
    linear-gradient(180deg, #fbf6f0 0%, #f4ece3 100%);
  padding-block:112px;
}
.bridge-wrap{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:38px;
  align-items:end;
}
.bridge-wrap h2{max-width:860px}
.bridge-wrap p{
  font-size:21px;
  line-height:1.5;
  color:rgba(16,16,16,.72);
  max-width:580px;
}
.bridge-wrap::after{
  content:"";
  grid-column:1 / -1;
  display:block;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(185,31,40,.45), transparent);
  margin-top:14px;
}

.audience-section{
  background:
    radial-gradient(circle at 84% 12%, rgba(185,31,40,.18), transparent 26%),
    radial-gradient(circle at 10% 88%, rgba(255,255,255,.04), transparent 20%),
    #070707;
}
.audience-section::before{
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:88px 88px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.6), transparent 90%);
}
.audience-top{
  align-items:end;
  gap:34px;
}
.audience-top h2{
  max-width:920px;
}
.audience-principles{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  max-width:820px;
}
.audience-principles span{
  display:flex;
  align-items:center;
  min-height:56px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.82);
  font-size:12px;
  letter-spacing:.11em;
  text-transform:uppercase;
  font-weight:800;
}
.audience-grid{
  position:relative;
  z-index:1;
}
.audience-card{
  background:rgba(255,255,255,.03);
  backdrop-filter:blur(10px);
}
.audience-card:hover{
  background:rgba(255,255,255,.05);
}

.work-section{
  background:
    radial-gradient(circle at 85% 12%, rgba(185,31,40,.08), transparent 25%),
    linear-gradient(180deg,#f8f2eb 0%, #f1e8de 100%);
}
.work-section::before{
  background-image:
    linear-gradient(rgba(0,0,0,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,.03) 1px, transparent 1px);
  background-size:96px 96px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.45), transparent 85%);
}

.moments-section{
  background:
    radial-gradient(circle at 80% 15%, rgba(185,31,40,.10), transparent 26%),
    linear-gradient(180deg,#faf4ee 0%, #f4ebe1 100%);
}
.moments-section::before{
  background:radial-gradient(circle at 20% 90%, rgba(185,31,40,.05), transparent 24%);
}

.founder-section{
  background:
    radial-gradient(circle at 84% 14%, rgba(185,31,40,.07), transparent 24%),
    linear-gradient(180deg,#faf5ef 0%, #f3ebe3 100%);
}
.founder-section::before{
  background-image:
    linear-gradient(rgba(0,0,0,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,.03) 1px, transparent 1px);
  background-size:88px 88px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.35), transparent 88%);
}

.brief-section{
  background:
    radial-gradient(circle at 84% 18%, rgba(185,31,40,.16), transparent 28%),
    radial-gradient(circle at 12% 80%, rgba(255,255,255,.03), transparent 20%),
    #070707;
}
.brief-section::before{
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size:92px 92px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.5), transparent 88%);
}

/* service example modals */
.work-modal{
  position:fixed;
  inset:0;
  z-index:120;
  display:none;
}
.work-modal.open{display:block}
.work-modal-backdrop{
  position:absolute;inset:0;
  background:rgba(7,7,7,.72);
  backdrop-filter:blur(12px);
}
.work-modal-panel{
  position:relative;
  z-index:1;
  width:min(1200px, calc(100vw - 40px));
  height:min(82vh, 860px);
  margin:clamp(20px,6vh,50px) auto;
  background:#fffaf5;
  border:1px solid rgba(0,0,0,.08);
  border-radius:30px;
  box-shadow:0 50px 120px rgba(0,0,0,.24);
  overflow:hidden;
}
.work-modal-close{
  position:absolute;
  top:18px; right:18px;
  z-index:3;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  background:rgba(255,255,255,.88);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:11px;
  font-weight:800;
}
.work-modal-grid{
  height:100%;
  display:grid;
  grid-template-columns:.82fr 1.18fr;
}
.work-modal-copy{
  padding:44px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  background:
    radial-gradient(circle at 20% 10%, rgba(185,31,40,.06), transparent 26%),
    linear-gradient(180deg,#fffaf5 0%, #f7efe6 100%);
}
.work-modal-copy h2{
  max-width:420px;
}
.work-modal-copy p{
  margin-top:16px;
  font-size:18px;
  max-width:430px;
}
.work-modal-copy ul{
  margin-top:22px;
  color:rgba(16,16,16,.72);
}
.work-modal-copy li{
  margin:10px 0;
  font-size:15px;
}
.work-modal-visual{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 82% 12%, rgba(185,31,40,.20), transparent 30%),
    #0b0b0b;
}
.work-modal-visual::before{
  content:"";
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size:96px 96px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.75), transparent 90%);
}
.modal-card{
  position:absolute;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.13);
  box-shadow:0 24px 70px rgba(0,0,0,.24);
}
.modal-card.primary{width:52%;height:46%;left:12%;top:15%}
.modal-card.secondary{width:36%;height:30%;right:14%;top:18%}
.modal-card.tertiary{width:42%;height:34%;left:28%;bottom:13%}
.visual-web .modal-card.primary{
  background:#fffaf5;
}
.visual-web .modal-card.secondary{
  background:linear-gradient(135deg,var(--black) 0 46%, var(--red) 46% 54%, #f0e7dd 54%);
}
.visual-web .modal-card.tertiary{
  background:#eadfd2;
}
.visual-sales .modal-card.primary{
  background:#fffaf5;
  transform:rotate(-10deg);
}
.visual-sales .modal-card.secondary{
  background:#efe5da;
  transform:rotate(7deg);
}
.visual-sales .modal-card.tertiary{
  background:linear-gradient(135deg,var(--black) 0 44%, var(--red) 44% 50%, #fffaf5 50%);
  transform:rotate(9deg);
}
.visual-campaigns .modal-card.primary{
  background:linear-gradient(135deg,var(--black) 0 50%, var(--red) 50% 58%, #fffaf5 58%);
}
.visual-campaigns .modal-card.secondary{background:#fffaf5}
.visual-campaigns .modal-card.tertiary{background:#efe4d7}
.visual-events .modal-card.primary{
  background:
    radial-gradient(circle at 60% 40%, rgba(255,255,255,.12), transparent 32%),
    linear-gradient(135deg, rgba(185,31,40,.34), rgba(255,255,255,.08)),
    #111;
}
.visual-events .modal-card.secondary{background:#fffaf5}
.visual-events .modal-card.tertiary{background:rgba(255,255,255,.08)}

/* full page process showcase */
.process-showcase{
  height:420vh;
  padding:0;
  background:
    radial-gradient(circle at 82% 12%, rgba(185,31,40,.18), transparent 28%),
    radial-gradient(circle at 12% 82%, rgba(255,255,255,.04), transparent 20%),
    #070707;
}
.process-showcase::before{
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:92px 92px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.65), transparent 92%);
}
.process-sticky{
  position:sticky;
  top:0;
  min-height:100svh;
  height:100svh;
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:.44fr 1fr 70px;
  gap:34px;
  align-items:center;
  padding:92px clamp(20px,5vw,58px);
}
.process-copy{
  position:relative;
  z-index:2;
}
.process-copy h2{
  max-width:500px;
}
.process-copy p{
  max-width:420px;
  margin-top:18px;
}
.process-stage{
  position:relative;
  height:min(78vh, 760px);
  border-radius:34px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.11);
  box-shadow:0 40px 120px rgba(0,0,0,.34);
  background:rgba(255,255,255,.02);
}
.process-stage::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 84% 14%, rgba(185,31,40,.16), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
}
.process-stage::after{
  content:"";
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size:88px 88px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.85), transparent 92%);
}
.process-panel{
  position:absolute;
  inset:0;
  z-index:1;
  padding:44px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  opacity:0;
  transform:translateY(40px) scale(.98);
  transition:opacity .55s var(--ease), transform .55s var(--ease);
}
.process-panel.active{
  opacity:1;
  transform:none;
  z-index:2;
}
.process-panel span{
  position:absolute;
  left:40px; top:34px;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--red);
  font-weight:900;
}
.process-panel h3{
  font-size:clamp(54px,6vw,110px);
  line-height:.9;
  color:#fff;
  max-width:620px;
}
.process-panel p{
  font-size:22px;
  line-height:1.42;
  max-width:650px;
  margin-top:18px;
}
.process-panel ul{
  margin-top:22px;
  color:rgba(255,255,255,.76);
}
.process-panel li{
  margin:10px 0;
  font-size:15px;
}
.process-rail{
  display:flex;
  flex-direction:column;
  gap:10px;
  position:relative;
  z-index:2;
}
.process-rail button{
  width:52px;
  height:52px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.03);
  color:rgba(255,255,255,.42);
  font-size:12px;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.process-rail button.active{
  background:rgba(185,31,40,.26);
  color:#fff;
  border-color:rgba(255,255,255,.24);
  transform:scale(1.04);
}

/* footer cleanup */
.footer{
  background:var(--black);
  color:#fff;
  padding:0 clamp(20px,5vw,58px);
  border-top:1px solid rgba(255,255,255,.10);
  display:block;
}
.footer-main{
  max-width:var(--max);
  margin:0 auto;
  padding:48px 0 34px;
  display:grid;
  grid-template-columns:minmax(170px,.75fr) minmax(220px,.9fr) minmax(180px,.7fr) auto;
  gap:28px;
  align-items:center;
}
.footer-brand img{height:72px;width:auto}
.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:16px 20px;
}
.footer-links a{
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.62);
  transition:color .25s var(--ease), transform .25s var(--ease);
}
.footer-links a:hover{
  color:#fff;
  transform:translateY(-1px);
}
.footer-meta{
  display:flex;
  justify-content:flex-start;
}
.footer-meta span{
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,.46);
}
.footer-socials{
  display:flex;
  gap:10px;
  justify-content:flex-end;
}
.footer-socials a{
  width:44px;height:44px;
  border-radius:999px;
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.04);
  color:#fff;
  transition:background .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease);
}
.footer-socials a:hover{
  transform:translateY(-2px);
  background:rgba(185,31,40,.22);
  border-color:rgba(255,255,255,.30);
}
.footer-socials svg{
  width:20px;height:20px;
  fill:none;stroke:currentColor;stroke-width:1.7;
}
.footer-socials a[aria-label="Facebook"] svg{fill:currentColor;stroke:none}
.footer-bottom{
  max-width:var(--max);
  margin:0 auto;
  padding:20px 0 28px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
}
.footer-bottom p{
  font-size:12px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:rgba(255,255,255,.48);
}

/* modal open */
body.modal-open{overflow:hidden}

@media (max-width:1120px){
  .bridge-wrap,
  .audience-top,
  .process-sticky,
  .work-modal-grid{
    grid-template-columns:1fr;
  }
  .process-showcase{
    height:auto;
    padding:clamp(82px,9vw,128px) clamp(20px,5vw,58px);
  }
  .process-sticky{
    position:relative;
    top:auto;
    height:auto;
    padding:0;
  }
  .process-stage{
    height:640px;
  }
  .process-rail{
    flex-direction:row;
    justify-content:flex-start;
  }
  .audience-principles{
    grid-template-columns:repeat(2,1fr);
  }
  .work-modal-panel{
    height:auto;
    min-height:0;
    max-height:calc(100vh - 40px);
    overflow:auto;
  }
  .work-modal-grid{
    min-height:0;
  }
  .work-modal-visual{
    min-height:340px;
  }
}
@media (max-width:960px){
  .brand{
    width:150px;
    min-width:150px;
  }
  .brand img{height:68px !important}
  .site-header.scrolled .brand img{height:56px !important}
  .hero-tags{
    grid-template-columns:repeat(2,max-content);
  }
  .audience-principles{
    grid-template-columns:1fr 1fr;
  }
  .footer-main{
    grid-template-columns:1fr;
    align-items:start;
  }
  .footer-brand img{height:60px}
  .footer-socials{justify-content:flex-start}
  .footer-bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}
@media (max-width:640px){
  .brand{
    width:128px;
    min-width:128px;
  }
  .brand img{height:58px !important}
  .site-header.scrolled .brand img{height:48px !important}
  .hero-tags{
    grid-template-columns:1fr 1fr;
  }
  .hero-tags span{
    min-width:0;
    justify-content:flex-start;
  }
  .bridge-wrap p{
    font-size:18px;
  }
  .audience-principles{
    grid-template-columns:1fr;
  }
  .process-stage{
    height:560px;
  }
  .process-panel{
    padding:28px;
  }
  .process-panel span{
    left:28px; top:24px;
  }
  .process-panel p{
    font-size:18px;
  }
}




/* ----- V3 luxe refinement v2 ----- */
:root{ --note-font:"Caveat", cursive; }

/* intro / what dita does */
.intro-grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:56px;
  align-items:end;
}
.intro-main h2{max-width:920px}
.intro-side{
  display:grid;
  gap:20px;
}
.intro-side p{
  font-size:20px;
  line-height:1.58;
  color:rgba(20,17,15,.72);
  max-width:620px;
}
.intro-section{
  padding-block:118px;
}

/* services premium full-width rows */
.services-section{
  padding-top:98px;
  padding-bottom:110px;
}
.services-head{
  max-width:var(--max);
  margin:0 auto 36px;
}
.services-head h2{
  max-width:1040px;
}
.service-luxe{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  gap:0;
  border-top:1px solid rgba(20,17,15,.10);
}
.service-row{
  position:relative;
  display:grid;
  grid-template-columns:minmax(240px,.8fr) 1.3fr auto;
  gap:28px;
  align-items:center;
  min-height:140px;
  padding:34px 10px;
  border-bottom:1px solid rgba(20,17,15,.10);
  cursor:pointer;
  transition:transform .3s var(--ease), padding-left .3s var(--ease), background .3s var(--ease);
}
.service-row::before{
  content:"";
  position:absolute;
  left:0; top:18px; bottom:18px;
  width:2px;
  background:linear-gradient(180deg, transparent, var(--red), transparent);
  opacity:0;
  transition:opacity .3s var(--ease), transform .3s var(--ease);
}
.service-row:hover{
  background:rgba(255,255,255,.38);
  padding-left:24px;
}
.service-row:hover::before{
  opacity:1;
  transform:translateX(0);
}
.service-row-title h3{
  font-size:clamp(34px,3vw,54px);
  line-height:.95;
}
.service-row p{
  font-size:18px;
  color:rgba(20,17,15,.66);
  max-width:620px;
}
.service-row-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border:1px solid rgba(20,17,15,.10);
  border-radius:999px;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:800;
  color:var(--red);
  background:rgba(255,255,255,.55);
}
.service-row:hover .service-row-link{
  background:#fff;
}

/* more premium modals */
.work-modal-panel.luxe-modal{
  background:
    linear-gradient(180deg,#fffbf6 0%,#f7efe6 100%);
  border-radius:34px;
}
.luxe-modal .work-modal-copy{
  padding:54px;
}
.luxe-modal .work-modal-copy p{
  max-width:480px;
}
.luxe-modal .work-modal-visual{
  background:
    radial-gradient(circle at 82% 14%, rgba(185,31,40,.18), transparent 30%),
    linear-gradient(180deg,#0b0b0b 0%, #111 100%);
}
.modal-sheet-stack{
  position:relative;
  width:100%;
  height:100%;
}
.modal-sheet{
  position:absolute;
  border-radius:26px;
  box-shadow:0 30px 80px rgba(0,0,0,.24);
}
.modal-sheet span{
  display:block;
  margin-bottom:8px;
  font-size:10px;
  letter-spacing:.20em;
  text-transform:uppercase;
  color:var(--red);
  font-weight:800;
}
.modal-sheet strong{
  display:block;
  font-size:clamp(28px,2.4vw,42px);
  line-height:.95;
  font-weight:300;
}
.modal-sheet em{
  display:block;
  margin-top:12px;
  font-style:normal;
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(20,17,15,.48);
}
.sheet-primary{
  left:8%;
  top:12%;
  width:52%;
  height:58%;
  background:#fffaf5;
  border:1px solid rgba(20,17,15,.08);
  padding:28px;
  transform:rotate(-4deg);
}
.sheet-secondary{
  right:10%;
  top:18%;
  width:36%;
  height:40%;
  background:linear-gradient(135deg,#efe4d7,#fffbf6);
  border:1px solid rgba(20,17,15,.08);
  padding:24px;
  transform:rotate(5deg);
}
.sheet-note{
  left:28%;
  bottom:12%;
  width:40%;
  min-height:120px;
  background:#b91f28;
  color:#fff;
  padding:24px;
  transform:rotate(-2deg);
}
.sheet-note span{color:rgba(255,255,255,.78)}
.sheet-note strong{
  color:#fff;
  font-family:var(--note-font);
  font-size:38px;
  line-height:1.02;
}
.visual-web .sheet-primary::before,
.visual-sales .sheet-primary::before,
.visual-campaigns .sheet-primary::before,
.visual-events .sheet-primary::before{
  content:"";
  position:absolute;
  left:22px; right:22px; top:64px; bottom:22px;
  border-radius:18px;
  background:
    linear-gradient(135deg,var(--black) 0 44%, var(--red) 44% 50%, #f4ebe2 50%);
}
.visual-sales .sheet-primary::before{
  background:
    linear-gradient(180deg,#fff 0 50%, #efe4d8 50% 100%);
}
.visual-campaigns .sheet-primary::before{
  background:
    linear-gradient(135deg,var(--black) 0 52%, var(--red) 52% 58%, #fffbf6 58%);
}
.visual-events .sheet-primary::before{
  background:
    radial-gradient(circle at 60% 40%, rgba(255,255,255,.16), transparent 26%),
    linear-gradient(135deg, rgba(185,31,40,.32), rgba(255,255,255,.10)),
    #151515;
}
.visual-sales .sheet-secondary{background:#fffaf5}
.visual-campaigns .sheet-secondary{background:#efe4d7}
.visual-events .sheet-secondary{background:#fffaf5}

/* quote section */
.bridge-statement{
  padding-block:130px;
}
.bridge-wrap{
  position:relative;
  max-width:1000px;
  margin:0 auto;
  text-align:center;
  grid-template-columns:1fr;
  gap:22px;
}
.bridge-quote-mark{
  font-size:110px;
  line-height:.6;
  color:rgba(185,31,40,.28);
  font-family:Georgia, serif;
}
.bridge-wrap h2{
  max-width:900px;
  margin:0 auto;
  font-size:clamp(44px,4.8vw,84px);
}
.bridge-wrap p{
  margin:0 auto;
  max-width:700px;
  font-size:20px;
}
.bridge-wrap::before{
  content:"";
  position:absolute;
  left:50%; top:-16px;
  width:1px; height:74px;
  transform:translateX(-50%);
  background:linear-gradient(180deg, rgba(185,31,40,.70), transparent);
}
.bridge-wrap::after{
  margin-top:26px;
}

/* audience */
.audience-top{
  position:relative;
  min-height:260px;
  padding-bottom:16px;
}
.audience-top h2{
  position:relative;
  z-index:2;
  max-width:1060px;
}
.audience-principles{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  max-width:none;
  display:block;
}
.audience-principles span{
  position:absolute;
  min-height:auto;
  padding:0;
  border:none;
  background:none;
  color:rgba(255,255,255,.34);
  font-family:var(--note-font);
  font-size:36px;
  letter-spacing:.01em;
  text-transform:none;
  font-weight:700;
  box-shadow:none;
}
.audience-principles span:nth-child(1){top:8px; right:12%; transform:rotate(-8deg)}
.audience-principles span:nth-child(2){top:94px; left:50%; transform:rotate(7deg)}
.audience-principles span:nth-child(3){bottom:46px; left:6%; transform:rotate(-6deg)}
.audience-principles span:nth-child(4){bottom:0; right:16%; transform:rotate(5deg)}
.audience-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.audience-card{
  min-height:220px;
  padding:28px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow:0 24px 60px rgba(0,0,0,.18);
  transition:transform .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease);
}
.audience-card strong{
  font-size:28px;
  line-height:1;
}
.audience-card em{
  margin-top:18px;
  font-size:16px;
  line-height:1.5;
}
.audience-card:hover{
  transform:translateY(-6px);
  border-color:rgba(255,255,255,.18);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
}

/* process copy and notes */
.process-sticky{
  align-items:start;
  padding-top:64px;
}
.process-copy{
  align-self:start;
  padding-top:10px;
}
.process-copy h2{
  margin-top:6px;
}
.process-stage{
  align-self:center;
  margin-top:42px;
}
.process-panel ul{
  list-style:none;
  padding-left:0;
}
.process-panel li{
  position:relative;
  margin:12px 0;
  padding-left:26px;
  font-family:var(--note-font);
  font-size:26px;
  color:rgba(255,255,255,.86);
  letter-spacing:.01em;
}
.process-panel li::before{
  content:"—";
  position:absolute;
  left:0; top:0;
  color:rgba(185,31,40,.9);
  font-family:var(--note-font);
}

/* founder-led */
.founder-section{
  padding-top:120px;
  padding-bottom:120px;
}
.founder-copy h2{
  max-width:900px;
}
.founder-copy p:not(.section-kicker){
  max-width:760px;
  font-size:20px;
  line-height:1.62;
  color:rgba(20,17,15,.72);
}
.founder-copy p + p{
  margin-top:18px;
}

/* start section */
.brief-section{
  position:relative;
  overflow:hidden;
}
.brief-section::after{
  content:"";
  position:absolute;
  inset:auto -10% -24% auto;
  width:520px;
  height:520px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(185,31,40,.18), transparent 64%);
  filter:blur(30px);
  pointer-events:none;
}
.brief-copy{
  position:relative;
  z-index:2;
}
.brief-copy h2{
  max-width:760px;
}
.brief-copy p{
  max-width:650px;
  font-size:20px;
}
.brief-note{
  display:inline-block;
  margin-top:24px;
  color:rgba(255,255,255,.78);
  font-family:var(--note-font);
  font-size:36px;
  line-height:1;
  transform:rotate(-4deg);
}

/* footer */
.footer-bottom p:first-child{
  letter-spacing:.08em;
}

@media (max-width:1120px){
  .intro-grid{grid-template-columns:1fr}
  .service-row{grid-template-columns:1fr; gap:14px; padding:28px 0}
  .service-row-link{justify-self:start}
  .audience-grid{grid-template-columns:1fr 1fr}
  .audience-top{min-height:320px}
}

@media (max-width:960px){
  .work-modal-grid{grid-template-columns:1fr}
  .luxe-modal .work-modal-copy{padding:34px}
  .service-row-title h3{font-size:36px}
  .audience-principles span{font-size:28px}
  .process-panel li{font-size:22px}
}

@media (max-width:640px){
  .intro-side p{font-size:18px}
  .bridge-wrap h2{font-size:38px}
  .service-row-title h3{font-size:30px}
  .service-row p{font-size:16px}
  .sheet-primary{width:58%; height:54%}
  .sheet-secondary{width:38%; height:34%}
  .sheet-note{left:18%; width:56%}
  .audience-grid{grid-template-columns:1fr}
  .audience-top{min-height:380px}
  .audience-principles span{font-size:24px}
  .process-panel li{font-size:20px}
  .brief-note{font-size:30px}
}



/* ----- V3 quote / notes polish pass ----- */
:root{
  --note-font: "Parisienne", cursive;
  --quote-font: "Cormorant Garamond", serif;
}

/* Shorter what dita does section polish */
.intro-main h2{
  max-width:760px;
}
.intro-side p{
  max-width:680px;
}

/* Handwritten notes more royal / cursive / readable */
.audience-top{
  min-height:320px;
}
.audience-principles span{
  font-family:var(--note-font);
  font-size:48px;
  line-height:1;
  color:rgba(255,255,255,.36);
  text-shadow:0 1px 0 rgba(255,255,255,.02), 0 10px 24px rgba(0,0,0,.14);
}
.audience-principles span:nth-child(1){
  top:2px;
  right:7%;
  transform:rotate(-6deg);
}
.audience-principles span:nth-child(2){
  top:108px;
  left:9%;
  transform:rotate(4deg);
}
.audience-principles span:nth-child(3){
  bottom:52px;
  left:36%;
  transform:rotate(-5deg);
}
.audience-principles span:nth-child(4){
  bottom:6px;
  right:12%;
  transform:rotate(5deg);
}

.process-panel li{
  font-family:var(--note-font);
  font-size:31px;
  line-height:1.06;
  color:rgba(255,255,255,.90);
  text-shadow:0 8px 18px rgba(0,0,0,.14);
}
.process-panel li::before{
  font-family:var(--note-font);
  font-size:28px;
  top:-1px;
}
.brief-note{
  font-family:var(--note-font);
  font-size:44px;
  line-height:1.02;
  color:rgba(255,255,255,.96);
  transform:rotate(-4deg);
  max-width:620px;
}
.brief-quote-note{
  margin-top:26px;
  margin-bottom:10px;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.48);
}

/* Founder-led quotes styling */
.founder-section{
  padding-top:132px;
  padding-bottom:132px;
}
.founder-copy{
  max-width:980px;
}
.founder-quote-wrap{
  position:relative;
  margin-top:8px;
  padding-left:32px;
}
.founder-quote-mark{
  position:absolute;
  left:0;
  top:-18px;
  font-family:var(--quote-font);
  font-size:108px;
  line-height:.7;
  color:rgba(185,31,40,.30);
}
.founder-quote{
  margin:0;
  max-width:900px;
}
.founder-quote p{
  margin:0;
  font-family:var(--quote-font);
  font-style:italic;
  font-weight:500;
  font-size:clamp(40px,4.6vw,72px);
  line-height:.98;
  letter-spacing:-.03em;
  color:var(--ink);
}
.founder-quote cite{
  display:block;
  margin-top:18px;
  font-style:normal;
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(20,17,15,.52);
}
.founder-quote-support{
  margin-top:34px;
  display:grid;
  gap:16px;
  max-width:840px;
}
.founder-quote-note{
  margin:0 0 2px 0;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--red) !important;
}
.founder-quote-support p:not(.founder-quote-note){
  font-family:var(--quote-font);
  font-style:italic;
  font-size:26px;
  line-height:1.34;
  color:rgba(20,17,15,.76);
  margin:0;
}

/* Start section wider / bigger */
.brief-section{
  padding-top:140px;
  padding-bottom:140px;
}
.brief-section .brief-grid,
.brief-section .brief-shell,
.brief-section .brief-inner{
  max-width:none;
}
#brief{
  overflow:visible;
}
#brief .brief-copy,
#brief .brief-form{
  position:relative;
  z-index:2;
}
#brief .brief-copy{
  max-width:none;
}
#brief .brief-copy h2{
  max-width:860px;
  font-size:clamp(58px,5.7vw,98px);
  line-height:.94;
}
#brief .brief-copy p{
  max-width:760px;
  font-size:21px;
  line-height:1.56;
}
#brief .brief-form{
  transform:scale(1.04);
  transform-origin:center right;
}
.brief-form{
  border-radius:34px;
  box-shadow:0 34px 90px rgba(0,0,0,.28);
}
.brief-section::before{
  opacity:.85;
}
.brief-section::after{
  width:680px;
  height:680px;
  inset:auto -8% -28% auto;
}
.footer{
  margin-top:0;
}

/* if brief uses a grid layout, stretch it */
.brief-section > *{
  max-width:1400px;
  margin-left:auto;
  margin-right:auto;
}
.brief-section{
  padding-left:clamp(26px,5vw,70px);
  padding-right:clamp(26px,5vw,70px);
}

/* Keep quote page feeling wide */
@media (min-width: 1100px){
  #brief{
    display:grid;
    grid-template-columns:1.06fr .94fr;
    gap:54px;
    align-items:start;
  }
}

/* responsive */
@media (max-width:1120px){
  .audience-principles span{
    font-size:40px;
  }
  .founder-quote p{
    font-size:52px;
  }
  .founder-quote-support p:not(.founder-quote-note){
    font-size:23px;
  }
  #brief .brief-form{
    transform:none;
  }
}
@media (max-width:960px){
  .audience-top{
    min-height:360px;
  }
  .audience-principles span{
    font-size:34px;
  }
  .process-panel li{
    font-size:26px;
  }
  .brief-note{
    font-size:38px;
  }
  #brief .brief-copy h2{
    font-size:54px;
  }
}
@media (max-width:640px){
  .audience-top{
    min-height:410px;
  }
  .audience-principles span{
    font-size:28px;
  }
  .process-panel li{
    font-size:22px;
  }
  .brief-note{
    font-size:32px;
  }
  .founder-quote-wrap{
    padding-left:18px;
  }
  .founder-quote-mark{
    font-size:78px;
    top:-12px;
  }
  .founder-quote p{
    font-size:36px;
  }
  .founder-quote-support p:not(.founder-quote-note){
    font-size:21px;
  }
}



/* ----- cleanup pass: founder / audience / premium services ----- */

/* what we do: more contrast */
.services-section{
  background:
    radial-gradient(circle at 84% 12%, rgba(185,31,40,.10), transparent 24%),
    linear-gradient(180deg, #f5eee6 0%, #eee4d8 100%);
}
.services-head h2{
  max-width:900px;
}
.service-luxe{
  margin-top:18px;
  display:grid;
  gap:14px;
  border-top:none;
}
.service-row{
  min-height:132px;
  padding:28px 32px;
  border:1px solid rgba(20,17,15,.10);
  border-radius:24px;
  background:linear-gradient(180deg, rgba(13,11,10,.96), rgba(20,17,15,.94));
  box-shadow:0 20px 50px rgba(0,0,0,.12);
}
.service-row::before{
  left:0; top:22px; bottom:22px;
  width:3px;
  background:linear-gradient(180deg, transparent, #e24b54, transparent);
}
.service-row:hover{
  background:linear-gradient(180deg, rgba(17,14,13,.99), rgba(25,21,20,.97));
  padding-left:42px;
}
.service-row-title h3{
  color:#fff8f0;
}
.service-row p{
  color:rgba(255,248,240,.72);
}
.service-row-link{
  background:rgba(255,248,240,.08);
  border-color:rgba(255,248,240,.16);
  color:#fff8f0;
}
.service-row:hover .service-row-link{
  background:rgba(185,31,40,.22);
  border-color:rgba(255,248,240,.22);
}

/* full-screen immersive popups */
.work-modal{
  position:fixed;
  inset:0;
  z-index:200;
  display:none;
}
.work-modal.open{display:block}
.work-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(6,6,6,.80);
  backdrop-filter:blur(14px);
}
.work-modal-panel.fullscreen-modal{
  position:relative;
  z-index:1;
  width:100vw;
  height:100vh;
  margin:0;
  border-radius:0;
  background:
    radial-gradient(circle at 80% 12%, rgba(185,31,40,.16), transparent 25%),
    #0a0908;
  border:none;
  box-shadow:none;
  overflow:hidden;
}
.modal-topbar{
  position:absolute;
  top:0; left:0; right:0;
  z-index:4;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:24px 34px;
}
.modal-topbar-label{
  color:rgba(255,248,240,.52);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:800;
}
.fullscreen-modal .work-modal-close{
  position:relative;
  top:auto; right:auto;
  border-color:rgba(255,248,240,.16);
  background:rgba(255,248,240,.04);
  color:#fff8f0;
}
.fullscreen-modal .work-modal-grid{
  height:100%;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
}
.fullscreen-modal .work-modal-copy{
  padding:110px 54px 54px;
  background:transparent;
  color:#fff8f0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.fullscreen-modal .work-modal-copy .section-kicker{
  color:rgba(255,248,240,.54);
}
.fullscreen-modal .work-modal-copy h2{
  color:#fff8f0;
  max-width:560px;
  font-size:clamp(58px,5vw,96px);
  line-height:.90;
}
.fullscreen-modal .work-modal-copy p{
  margin-top:18px;
  max-width:580px;
  color:rgba(255,248,240,.72);
  font-size:19px;
}
.fullscreen-modal .work-modal-copy ul{
  margin-top:24px;
  color:rgba(255,248,240,.82);
  list-style:none;
  padding-left:0;
}
.fullscreen-modal .work-modal-copy li{
  margin:12px 0;
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,248,240,.56);
}
.fullscreen-modal .work-modal-visual{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 84% 15%, rgba(185,31,40,.18), transparent 28%),
    linear-gradient(180deg,#111 0%, #090909 100%);
}
.fullscreen-modal .work-modal-visual::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:92px 92px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.75), transparent 92%);
}
.immersive-stage{
  position:relative;
  width:100%;
  height:100%;
}
.stage-primary,.stage-secondary,.stage-detail{
  position:absolute;
  border-radius:30px;
  box-shadow:0 34px 100px rgba(0,0,0,.28);
}
.stage-primary span,.stage-secondary span,.stage-detail span{
  display:block;
  margin-bottom:8px;
  font-size:10px;
  letter-spacing:.20em;
  text-transform:uppercase;
  font-weight:800;
}
.stage-primary strong,.stage-secondary strong,.stage-detail strong{
  display:block;
  font-weight:300;
  line-height:.95;
}
.stage-primary em,.stage-secondary em{
  display:block;
  margin-top:12px;
  font-style:normal;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.stage-primary{
  left:10%;
  top:14%;
  width:56%;
  height:54%;
  background:#fff8f0;
  border:1px solid rgba(20,17,15,.08);
  padding:28px;
}
.stage-primary strong{
  font-size:clamp(30px,2.6vw,48px);
  color:#14110f;
}
.stage-primary em{color:rgba(20,17,15,.44)}
.stage-secondary{
  right:9%;
  bottom:14%;
  width:34%;
  height:34%;
  background:#efe5da;
  border:1px solid rgba(20,17,15,.08);
  padding:22px;
}
.stage-secondary strong{
  font-size:clamp(24px,2.0vw,34px);
  color:#14110f;
}
.stage-secondary em{color:rgba(20,17,15,.42)}
.stage-detail{
  left:22%;
  bottom:10%;
  width:32%;
  min-height:120px;
  background:rgba(185,31,40,.96);
  border:1px solid rgba(255,248,240,.12);
  padding:22px;
}
.stage-detail span{color:rgba(255,248,240,.76)}
.stage-detail strong{
  color:#fff;
  font-size:32px;
}
.visual-web .stage-primary::before,
.visual-sales .stage-primary::before,
.visual-campaigns .stage-primary::before,
.visual-events .stage-primary::before{
  content:"";
  position:absolute;
  left:22px; right:22px; top:68px; bottom:22px;
  border-radius:22px;
  background:linear-gradient(135deg,#0b0b0b 0 44%, #b91f28 44% 50%, #f2e8dd 50%);
}
.visual-sales .stage-primary::before{
  background:linear-gradient(180deg,#fffdf9 0 48%, #efe3d7 48% 100%);
}
.visual-campaigns .stage-primary::before{
  background:linear-gradient(135deg,#0b0b0b 0 52%, #b91f28 52% 58%, #fff8f0 58%);
}
.visual-events .stage-primary::before{
  background:
    radial-gradient(circle at 60% 40%, rgba(255,255,255,.16), transparent 26%),
    linear-gradient(135deg, rgba(185,31,40,.34), rgba(255,255,255,.10)),
    #151515;
}

/* better idea for the principle notes: note board below heading, not overlapping */
.audience-top{
  min-height:0;
  padding-bottom:0;
  display:grid;
  gap:28px;
}
.audience-principles{
  position:relative;
  inset:auto;
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:18px;
  max-width:1100px;
  pointer-events:none;
}
.audience-principles span{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:100px;
  padding:18px 20px 14px;
  border-radius:18px;
  background:rgba(255,248,240,.08);
  border:1px solid rgba(255,248,240,.10);
  color:rgba(255,248,240,.88);
  font-family:"Cormorant Garamond", serif;
  font-style:italic;
  font-size:30px;
  line-height:1;
  text-shadow:none;
  box-shadow:0 20px 40px rgba(0,0,0,.14);
}
.audience-principles span:nth-child(1){transform:rotate(-4deg)}
.audience-principles span:nth-child(2){transform:rotate(3deg)}
.audience-principles span:nth-child(3){transform:rotate(-2deg)}
.audience-principles span:nth-child(4){transform:rotate(4deg)}
.audience-grid{
  margin-top:26px;
}

/* founder section simplified */
.founder-quote-wrap{
  padding-left:0;
  margin-top:10px;
}
.founder-quote-mark{display:none}
.founder-quote{
  position:relative;
  margin:0;
  max-width:820px;
  padding-left:24px;
  border-left:2px solid rgba(185,31,40,.34);
}
.founder-quote p{
  font-family:"Cormorant Garamond", serif;
  font-style:italic;
  font-weight:500;
  font-size:clamp(36px,3.8vw,58px);
  line-height:1.02;
  color:rgba(20,17,15,.94);
}
.founder-quote cite{
  margin-top:14px;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(20,17,15,.48);
}
.founder-note-block{
  margin-top:34px;
  max-width:760px;
  display:grid;
  gap:16px;
}
.founder-note-heading{
  margin:0;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--red) !important;
  font-weight:800;
}
.founder-note-block p:not(.founder-note-heading){
  margin:0;
  font-size:20px;
  line-height:1.62;
  color:rgba(20,17,15,.72);
  font-family:Inter, ui-sans-serif, system-ui, sans-serif;
  font-style:normal;
}

/* responsive cleanup */
@media (max-width:1120px){
  .fullscreen-modal .work-modal-grid{
    grid-template-columns:1fr;
  }
  .fullscreen-modal .work-modal-copy{
    padding:96px 28px 28px;
    justify-content:flex-start;
  }
  .fullscreen-modal .work-modal-visual{
    min-height:360px;
  }
  .audience-principles{
    grid-template-columns:1fr 1fr;
  }
}
@media (max-width:640px){
  .service-row{
    padding:24px 20px;
  }
  .fullscreen-modal .work-modal-copy h2{
    font-size:46px;
  }
  .audience-principles{
    grid-template-columns:1fr;
  }
  .audience-principles span{
    min-height:76px;
    font-size:24px;
  }
  .founder-quote p{
    font-size:34px;
  }
  .founder-note-block p:not(.founder-note-heading){
    font-size:18px;
  }
}



/* ----- final polish pass: grey palette, logos, fixed brief, clean modals ----- */
:root{
  --paper-grey:#dcd9d4;
  --paper-grey-2:#d0ccc6;
  --soft-grey:#c8c4bf;
  --charcoal:#0f0e0d;
  --charcoal-2:#171514;
}

/* shift light palette away from egg-white */
body{
  background:#d7d3cd;
}
.section-light,
.intro-section,
.bridge-statement,
.work-section,
.moments-section,
.founder-section{
  background:linear-gradient(180deg, #d8d4cf 0%, #cecac5 100%);
}
.services-section{
  background:
    radial-gradient(circle at 84% 12%, rgba(185,31,40,.10), transparent 24%),
    linear-gradient(180deg, #11100f 0%, #171514 100%);
}
.services-section .section-label,
.services-section .services-head h2{
  color:#fff8f0;
}
.services-section .section-label{opacity:.9}
.services-head{
  margin-bottom:28px;
}
.service-row{
  background:linear-gradient(180deg, rgba(32,29,28,.96), rgba(24,21,20,.96));
  border-color:rgba(255,248,240,.08);
}
.service-row:hover{
  background:linear-gradient(180deg, rgba(37,34,33,.98), rgba(26,23,22,.98));
}
.service-row-link{
  background:rgba(255,248,240,.05);
}

/* intro should contrast services */
.intro-section{
  background:
    radial-gradient(circle at 16% 12%, rgba(185,31,40,.05), transparent 22%),
    linear-gradient(180deg, #dbd8d3 0%, #d2cec9 100%);
}

/* client logo strip */
.logo-strip-section{
  padding:70px 0 56px;
  background:linear-gradient(180deg, #1a1817 0%, #100f0e 100%);
  overflow:hidden;
  border-top:1px solid rgba(255,248,240,.06);
  border-bottom:1px solid rgba(255,248,240,.06);
}
.logo-strip-head{
  max-width:var(--max);
  margin:0 auto 28px;
  padding:0 clamp(20px,5vw,58px);
  color:#fff8f0;
}
.logo-strip-head h2{
  max-width:760px;
  color:#fff8f0;
}
.logo-marquee{
  display:flex;
  width:max-content;
  animation: logoScroll 28s linear infinite;
}
.logo-marquee:hover{
  animation-play-state:paused;
}
.logo-marquee-track{
  display:flex;
  align-items:center;
  gap:18px;
  padding-right:18px;
}
.logo-item{
  flex:0 0 auto;
  width:180px;
  height:88px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  border-radius:18px;
  background:rgba(255,248,240,.05);
  border:1px solid rgba(255,248,240,.08);
}
.logo-item img{
  max-width:100%;
  max-height:42px;
  width:auto;
  height:auto;
  object-fit:contain;
  filter:grayscale(1) brightness(.95) contrast(1.06);
  opacity:.92;
}
@keyframes logoScroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* remove cursive elsewhere */
.audience-principles{
  grid-template-columns:repeat(4, minmax(0,1fr));
}
.audience-principles span{
  min-height:84px;
  padding:16px 18px;
  font-family:Inter, ui-sans-serif, system-ui, sans-serif;
  font-style:normal;
  font-size:13px;
  line-height:1.2;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#fff8f0;
  background:rgba(255,248,240,.06);
  border:1px solid rgba(255,248,240,.09);
  border-radius:16px;
  box-shadow:none;
}
.process-panel li{
  font-family:Inter, ui-sans-serif, system-ui, sans-serif;
  font-size:15px;
  line-height:1.5;
  letter-spacing:.02em;
  color:rgba(255,255,255,.82);
}
.process-panel li::before{
  font-family:Inter, ui-sans-serif, system-ui, sans-serif;
  content:"•";
  font-size:16px;
  top:0;
}
.brief-note{
  font-family:"Cormorant Garamond", serif;
  font-style:italic;
  font-size:26px;
  line-height:1.18;
  color:rgba(255,255,255,.92);
  transform:none;
  max-width:580px;
}
.brief-quote-note{
  margin-top:20px;
}

/* fix start/contact layout */
.brief-section{
  padding:110px clamp(28px,5vw,72px);
}
#brief{
  max-width:1380px;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1fr) 460px;
  gap:56px;
  align-items:start;
}
#brief .brief-copy h2{
  max-width:760px;
  font-size:clamp(56px,5.2vw,88px);
  line-height:.92;
}
#brief .brief-copy p{
  max-width:700px;
  font-size:19px;
}
.brief-form{
  width:100%;
  margin:0;
  background:#d8d5d1;
  color:#14110f;
  border:1px solid rgba(20,17,15,.10);
  border-radius:32px;
  box-shadow:0 28px 80px rgba(0,0,0,.22);
  transform:none !important;
}
.brief-form input,
.brief-form textarea{
  background:#d0ccc7;
  border:1px solid rgba(20,17,15,.12);
  color:#14110f;
}
.brief-form label{
  color:rgba(20,17,15,.56);
}

/* premium fullscreen modals */
.fullscreen-modal{
  background:
    radial-gradient(circle at 80% 12%, rgba(185,31,40,.18), transparent 25%),
    linear-gradient(180deg, #0b0a09 0%, #11100f 100%) !important;
}
.modal-topbar{
  position:absolute;
  top:28px;
  left:34px;
  right:34px;
  z-index:6;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:0;
}
.modal-topbar-logo img{
  height:44px;
  width:auto;
}
.fullscreen-modal .work-modal-close{
  width:auto !important;
  min-width:0 !important;
  height:46px;
  padding:0 18px;
  border-radius:14px;
  border:1px solid rgba(255,248,240,.16);
  background:rgba(255,248,240,.05);
  color:#fff8f0;
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:800;
  box-shadow:0 10px 30px rgba(0,0,0,.18);
}
.fullscreen-modal .work-modal-close:hover{
  background:rgba(255,248,240,.10);
  border-color:rgba(255,248,240,.24);
}
.fullscreen-modal .work-modal-grid{
  grid-template-columns:.82fr 1.18fr;
}
.fullscreen-modal .work-modal-copy{
  padding:122px 54px 54px;
}
.fullscreen-modal .work-modal-copy h2{
  font-size:clamp(56px,4.8vw,92px);
}
.fullscreen-modal .work-modal-visual{
  background:
    radial-gradient(circle at 84% 15%, rgba(185,31,40,.18), transparent 28%),
    linear-gradient(180deg,#141311 0%, #0c0b0a 100%);
}
.stage-primary{
  background:#d7d3cd;
}
.stage-secondary{
  background:#cfcac4;
}
.stage-detail{
  background:#b91f28;
}
.stage-primary strong,
.stage-secondary strong{
  color:#14110f;
}
.stage-primary em,
.stage-secondary em{
  color:rgba(20,17,15,.46);
}
.visual-web .stage-primary::before{
  background:linear-gradient(135deg,#0b0b0b 0 44%, #b91f28 44% 50%, #d7d3cd 50%);
}
.visual-sales .stage-primary::before{
  background:linear-gradient(180deg,#d8d4cf 0 48%, #c9c5bf 48% 100%);
}
.visual-campaigns .stage-primary::before{
  background:linear-gradient(135deg,#0b0b0b 0 52%, #b91f28 52% 58%, #d7d3cd 58%);
}
.visual-events .stage-primary::before{
  background:
    radial-gradient(circle at 60% 40%, rgba(255,255,255,.16), transparent 26%),
    linear-gradient(135deg, rgba(185,31,40,.34), rgba(255,255,255,.10)),
    #151515;
}

/* founder section keep as-is, but harmonize backdrop */
.founder-section{
  background:
    radial-gradient(circle at 84% 14%, rgba(185,31,40,.05), transparent 24%),
    linear-gradient(180deg,#d9d5d0 0%, #cfcbc6 100%);
}

/* responsive */
@media (max-width:1120px){
  .logo-item{
    width:150px;
    height:76px;
  }
  #brief{
    grid-template-columns:1fr;
  }
  .fullscreen-modal .work-modal-grid{
    grid-template-columns:1fr;
  }
  .fullscreen-modal .work-modal-copy{
    padding:110px 28px 28px;
  }
  .fullscreen-modal .work-modal-visual{
    min-height:420px;
  }
}
@media (max-width:640px){
  .audience-principles{
    grid-template-columns:1fr 1fr;
  }
  .audience-principles span{
    min-height:70px;
    font-size:11px;
  }
  .logo-item{
    width:132px;
    height:68px;
    padding:14px;
  }
  .modal-topbar{
    top:20px;
    left:18px;
    right:18px;
  }
  .modal-topbar-logo img{
    height:36px;
  }
}



/* --- luxe links + cleaner quote section + softer logos --- */

/* Hero calls to action: make them editorial links, not buttons */
.hero-actions{
  display:flex;
  gap:26px;
  flex-wrap:wrap;
  margin-top:34px;
  align-items:center;
}
.hero-actions .button{display:none !important}
.hero-link{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:0;
  min-height:auto;
  border:none;
  background:none;
  color:rgba(255,248,240,.86);
  font-size:14px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:800;
}
.hero-link::before{
  content:"";
  width:42px;
  height:1px;
  background:rgba(255,248,240,.45);
  transition:width .25s var(--ease), background .25s var(--ease);
}
.hero-link::after{
  content:"↗";
  font-size:12px;
  line-height:1;
  transform:translateY(-1px);
  opacity:.75;
  transition:transform .25s var(--ease), opacity .25s var(--ease);
}
.hero-link:hover{
  color:#fff;
}
.hero-link:hover::before{
  width:58px;
  background:var(--red);
}
.hero-link:hover::after{
  transform:translate(3px,-2px);
  opacity:1;
}
.hero-link-primary{
  color:#fff;
}

/* Selected brands strip: remove framed/scammy boxes */
.logo-strip-section{
  padding:72px 0 44px;
}
.logo-strip-head{
  margin-bottom:34px;
}
.logo-marquee{
  display:flex;
  width:max-content;
  animation:logoScroll 36s linear infinite;
}
.logo-marquee-track{
  display:flex;
  align-items:center;
  gap:42px;
  padding-right:42px;
}
.logo-item{
  width:auto;
  height:auto;
  padding:0;
  background:none;
  border:none;
  border-radius:0;
  box-shadow:none;
}
.logo-item img{
  max-height:38px;
  max-width:140px;
  filter:grayscale(1) brightness(.93) contrast(1.04);
  opacity:.72;
}
.logo-item:hover img{
  opacity:.95;
}

/* Start section: fewer words and form takes more space */
.brief-section{
  padding:110px clamp(28px,5vw,72px) 96px;
}
#brief{
  max-width:1420px;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,.88fr) minmax(520px,1.12fr);
  gap:48px;
  align-items:start;
}
#brief .brief-copy{
  padding-right:10px;
}
#brief .brief-copy h2{
  max-width:620px;
  font-size:clamp(54px,5vw,82px);
  line-height:.93;
}
#brief .brief-copy p{
  max-width:560px;
  margin-top:20px;
  font-size:18px;
  line-height:1.6;
  color:rgba(255,255,255,.78);
}
#brief .brief-copy .brief-quote-note,
#brief .brief-copy .brief-note{
  display:none !important;
}
.brief-form{
  width:100%;
  max-width:none;
  min-height:640px;
  padding:30px 30px 28px;
  border-radius:34px;
}
.brief-form label{
  display:block;
  margin-bottom:16px;
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:800;
}
.brief-form input,
.brief-form textarea{
  margin-top:10px;
  width:100%;
  min-height:54px;
  padding:16px 16px;
  font-size:16px;
  border-radius:16px;
}
.brief-form textarea{
  min-height:220px;
  resize:vertical;
}
.brief-form button{
  width:100%;
  min-height:58px;
  margin-top:8px;
  border-radius:999px;
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:800;
}

/* keep owner section special, but remove extra cursive feel elsewhere */
.brief-note,
.audience-principles span,
.process-panel li{
  font-family:inherit;
  font-style:normal;
}

/* popup close button less mobile-like, more premium */
.fullscreen-modal .work-modal-close{
  height:44px;
  padding:0 20px;
  border-radius:999px;
  background:rgba(255,248,240,.02);
  border:1px solid rgba(255,248,240,.18);
  letter-spacing:.18em;
}
.modal-topbar{
  top:24px;
}
.modal-topbar-logo img{
  height:48px;
  width:auto;
}

@media (max-width:1120px){
  #brief{
    grid-template-columns:1fr;
  }
  .brief-form{
    min-height:auto;
  }
}
@media (max-width:640px){
  .hero-actions{
    gap:18px;
  }
  .hero-link{
    font-size:12px;
  }
  .logo-marquee-track{
    gap:28px;
    padding-right:28px;
  }
  .logo-item img{
    max-height:28px;
    max-width:110px;
  }
  #brief .brief-copy h2{
    font-size:44px;
  }
}



/* --- audience/cards/section contrast correction --- */

/* Remove random floating principle words and make them clean/intended */
.audience-top{
  min-height:0 !important;
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:30px !important;
  align-items:start !important;
  margin-bottom:42px !important;
}
.audience-top h2{
  max-width:1080px !important;
  position:relative !important;
  z-index:2 !important;
}
.audience-principles{
  position:relative !important;
  inset:auto !important;
  display:grid !important;
  grid-template-columns:repeat(4, minmax(0,1fr)) !important;
  gap:12px !important;
  max-width:980px !important;
  pointer-events:auto !important;
  z-index:2 !important;
}
.audience-principles span{
  position:relative !important;
  inset:auto !important;
  transform:none !important;
  min-height:76px !important;
  padding:16px 18px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  align-items:flex-start !important;
  border-radius:18px !important;
  border:1px solid rgba(255,255,255,.10) !important;
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025)) !important;
  box-shadow:0 18px 46px rgba(0,0,0,.18) !important;
  font-family:Inter, ui-sans-serif, system-ui, sans-serif !important;
  font-style:normal !important;
  text-shadow:none !important;
  color:#fff8f0 !important;
}
.audience-principles span strong{
  display:block;
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:900;
  color:#fff8f0;
}
.audience-principles span em{
  display:block;
  margin-top:6px;
  font-style:normal;
  font-size:13px;
  letter-spacing:.08em;
  color:rgba(255,255,255,.52);
}

/* Premium audience cards */
.audience-grid{
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0,1fr)) !important;
  gap:18px !important;
  margin-top:0 !important;
}
.audience-card{
  min-height:245px !important;
  padding:30px !important;
  border-radius:28px !important;
  border:1px solid rgba(255,255,255,.11) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.022)) !important;
  box-shadow:0 26px 70px rgba(0,0,0,.24) !important;
  backdrop-filter:blur(10px) !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:space-between !important;
  transition:transform .28s var(--ease), border-color .28s var(--ease), background .28s var(--ease), box-shadow .28s var(--ease) !important;
}
.audience-card::before{
  content:"";
  display:block;
  width:46px;
  height:1px;
  background:rgba(185,31,40,.82);
  margin-bottom:22px;
}
.audience-card strong{
  display:block;
  font-size:clamp(24px,2vw,34px) !important;
  line-height:1 !important;
  letter-spacing:-.055em !important;
  color:#fff8f0 !important;
  font-weight:700 !important;
}
.audience-card em{
  display:block;
  margin-top:auto !important;
  max-width:340px;
  font-style:normal !important;
  color:rgba(255,255,255,.64) !important;
  font-size:16px !important;
  line-height:1.5 !important;
}
.audience-card:hover{
  transform:translateY(-7px) !important;
  border-color:rgba(255,255,255,.22) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.035)) !important;
  box-shadow:0 34px 90px rgba(0,0,0,.30) !important;
}

/* Make adjacent backgrounds contrast section-to-section */
.hero.section-dark{
  background:
    radial-gradient(circle at 82% 18%, rgba(185,31,40,.18), transparent 28%),
    #070707 !important;
}
.intro-section{
  background:
    radial-gradient(circle at 16% 12%, rgba(185,31,40,.045), transparent 24%),
    linear-gradient(180deg,#d9d6d1 0%, #cbc7c1 100%) !important;
}
.logo-strip-section{
  background:
    linear-gradient(180deg,#141211 0%, #0b0a09 100%) !important;
}
.services-section{
  background:
    radial-gradient(circle at 88% 12%, rgba(185,31,40,.10), transparent 25%),
    linear-gradient(180deg,#c8c4bd 0%, #bcb7b0 100%) !important;
}
.services-section .section-label,
.services-section .services-head h2{
  color:#14110f !important;
}
.service-row{
  background:linear-gradient(180deg, rgba(16,15,14,.97), rgba(26,24,23,.96)) !important;
}
.bridge-statement{
  background:
    radial-gradient(circle at 50% 10%, rgba(185,31,40,.10), transparent 24%),
    linear-gradient(180deg,#1a1716 0%, #0c0b0a 100%) !important;
  color:#fff8f0 !important;
}
.bridge-statement h2,
.bridge-statement p{
  color:#fff8f0 !important;
}
.audience-section{
  background:
    radial-gradient(circle at 84% 14%, rgba(185,31,40,.18), transparent 30%),
    linear-gradient(180deg,#070707 0%, #11100f 100%) !important;
}
.work-section{
  background:
    radial-gradient(circle at 15% 12%, rgba(185,31,40,.05), transparent 26%),
    linear-gradient(180deg,#d6d2cc 0%, #c7c2bb 100%) !important;
}
.moments-section{
  background:
    radial-gradient(circle at 80% 12%, rgba(185,31,40,.11), transparent 28%),
    linear-gradient(180deg,#1a1716 0%, #0f0d0c 100%) !important;
}
.moments-section h2,
.moments-section p{
  color:#fff8f0 !important;
}
.process-showcase{
  background:
    radial-gradient(circle at 84% 12%, rgba(185,31,40,.18), transparent 30%),
    linear-gradient(180deg,#070707 0%, #11100f 100%) !important;
}
.founder-section{
  background:
    radial-gradient(circle at 84% 14%, rgba(185,31,40,.045), transparent 24%),
    linear-gradient(180deg,#d3d0ca 0%, #c6c1ba 100%) !important;
}
.brief-section{
  background:
    radial-gradient(circle at 82% 18%, rgba(185,31,40,.16), transparent 28%),
    linear-gradient(180deg,#080808 0%, #11100f 100%) !important;
}

/* Cards across website: less cheap, more refined */
.service-row,
.work-card,
.moments-cards article,
.process-stage,
.brief-form{
  border-color:rgba(255,255,255,.10);
  box-shadow:0 28px 78px rgba(0,0,0,.22);
}
.work-card{
  border-radius:28px !important;
}
.moments-cards article{
  border-radius:28px !important;
  background:rgba(255,255,255,.045) !important;
  backdrop-filter:blur(10px);
}

/* Responsive */
@media (max-width:1120px){
  .audience-principles{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
  }
  .audience-grid{
    grid-template-columns:1fr 1fr !important;
  }
}
@media (max-width:720px){
  .audience-principles,
  .audience-grid{
    grid-template-columns:1fr !important;
  }
  .audience-card{
    min-height:210px !important;
  }
}



/* --- section background system refresh: cleaner contrast, stronger red use --- */
:root{
  --dita-red:#b91f28;
  --dita-red-deep:#941820;
  --stone-1:#d7d3cd;
  --stone-2:#c8c3bc;
  --stone-3:#b8b2aa;
  --ink-1:#070707;
  --ink-2:#11100f;
  --ink-3:#181614;
}

/* Remove muddy overlap feeling and give each section a singular identity */
.hero.section-dark{
  background:
    linear-gradient(90deg, #060606 0%, #060606 62%, #170809 62%, #26090b 100%) !important;
}
.hero::before{
  background:
    radial-gradient(circle at 82% 20%, rgba(185,31,40,.12), transparent 22%),
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px) !important;
  background-size:auto, 92px 92px, 92px 92px !important;
  opacity:.75 !important;
}
.hero-visual{
  box-shadow:0 32px 90px rgba(0,0,0,.32) !important;
}

/* What dita does: light stone */
.intro-section{
  background:#d7d3cd !important;
}
.intro-section::before{
  background:
    linear-gradient(135deg, rgba(20,17,15,.03) 0 22%, transparent 22% 100%) !important;
  opacity:1 !important;
  mask-image:none !important;
}

/* Selected brands: deep charcoal, understated */
.logo-strip-section{
  background:#131110 !important;
}
.logo-strip-section .section-kicker,
.logo-strip-section h2{
  color:#fff8f0 !important;
}
.logo-strip-section .section-kicker{opacity:.95}

/* What we do: THIS becomes the strong red section */
.services-section{
  background:#b91f28 !important;
  position:relative;
  overflow:hidden;
}
.services-section::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size:84px 84px;
  opacity:.20;
  pointer-events:none;
}
.services-section::after{
  content:"";
  position:absolute;
  right:-12%;
  top:-18%;
  width:46%;
  height:150%;
  background:linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.18));
  transform:rotate(16deg);
  pointer-events:none;
}
.services-section .section-label,
.services-section .services-head h2{
  color:#fff8f0 !important;
  position:relative;
  z-index:1;
}
.service-luxe,
.services-head{
  position:relative;
  z-index:1;
}
.service-row{
  background:rgba(18,14,13,.88) !important;
  border:1px solid rgba(255,248,240,.12) !important;
  box-shadow:0 22px 56px rgba(0,0,0,.20) !important;
}
.service-row:hover{
  background:rgba(18,14,13,.96) !important;
}
.service-row-link{
  background:rgba(255,255,255,.06) !important;
  border-color:rgba(255,255,255,.16) !important;
  color:#fff8f0 !important;
}

/* Bridge statement: near-black, hard contrast after red */
.bridge-statement{
  background:#0c0b0a !important;
  color:#fff8f0 !important;
}
.bridge-statement .bridge-wrap{
  position:relative;
}
.bridge-statement .bridge-wrap::before{
  background:linear-gradient(180deg, rgba(185,31,40,.9), transparent) !important;
}
.bridge-statement h2,
.bridge-statement p{
  color:#fff8f0 !important;
}
.bridge-statement .bridge-quote-mark{
  color:rgba(185,31,40,.26) !important;
}

/* Who it's for: cool dark graphite, distinct from previous black */
.audience-section{
  background:#151312 !important;
}
.audience-section::before{
  background:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px) !important;
  background-size:96px 96px !important;
  mask-image:none !important;
  opacity:.55 !important;
}
.audience-principles span{
  background:rgba(255,255,255,.04) !important;
  border-color:rgba(255,255,255,.10) !important;
}
.audience-card{
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.022)) !important;
  border-color:rgba(255,255,255,.10) !important;
}
.audience-card:hover{
  background:linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.035)) !important;
}

/* Work: back to clean light stone but cooler */
.work-section{
  background:#cfcac3 !important;
}
.work-section::before{
  background:
    linear-gradient(0deg, rgba(20,17,15,.035), rgba(20,17,15,.035)),
    linear-gradient(90deg, transparent 0 80%, rgba(185,31,40,.06) 80% 100%) !important;
  opacity:1 !important;
  mask-image:none !important;
}
.work-section .section-label,
.work-section h2,
.work-section p,
.work-section h3,
.work-section strong,
.work-section em{
  color:#14110f !important;
}

/* Events/moments: deep red-black split, more creative without muddiness */
.moments-section{
  background:
    linear-gradient(90deg, #0a0908 0%, #0a0908 54%, #b91f28 54%, #941820 100%) !important;
}
.moments-section::before{
  background:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px) !important;
  background-size:92px 92px !important;
  mask-image:none !important;
  opacity:.38 !important;
}
.moments-section h2,
.moments-section p,
.moments-section .section-label{
  color:#fff8f0 !important;
}
.moments-cards article{
  background:rgba(255,255,255,.045) !important;
  border-color:rgba(255,255,255,.10) !important;
}

/* Process: strong dark section */
.process-showcase{
  background:#090908 !important;
}
.process-showcase::before{
  background:
    radial-gradient(circle at 85% 14%, rgba(185,31,40,.16), transparent 24%),
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px) !important;
  background-size:auto, 92px 92px, 92px 92px !important;
  mask-image:none !important;
  opacity:.72 !important;
}

/* Founder: back to light grey */
.founder-section{
  background:#d1cdc7 !important;
}
.founder-section::before{
  background:
    linear-gradient(135deg, transparent 0 68%, rgba(185,31,40,.05) 68% 100%) !important;
  opacity:1 !important;
  mask-image:none !important;
}

/* Start: restrained black with a cleaner red side field */
.brief-section{
  background:
    linear-gradient(90deg, #070707 0%, #070707 70%, #22090b 70%, #22090b 100%) !important;
}
.brief-section::before{
  background:
    linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.028) 1px, transparent 1px) !important;
  background-size:96px 96px !important;
  mask-image:none !important;
  opacity:.6 !important;
}
.brief-section::after{
  display:none !important;
}
.brief-form{
  background:#d8d5d1 !important;
  border:1px solid rgba(20,17,15,.10) !important;
}

/* Footer: separate from start with pure black */
.footer{
  background:#020202 !important;
}

/* Extra premium cleanup across cards */
.service-row,
.audience-card,
.work-card,
.moments-cards article,
.brief-form{
  box-shadow:0 28px 80px rgba(0,0,0,.22) !important;
}
.service-row,
.audience-card,
.work-card,
.moments-cards article{
  border-radius:28px !important;
}

/* Responsive */
@media (max-width:1120px){
  .services-section::after{display:none}
  .moments-section{
    background:#0a0908 !important;
  }
  .brief-section{
    background:#070707 !important;
  }
}



/* =========================================================
   PROFESSIONAL REBUILD OVERRIDE
   Purpose: restraint, expertise, clearer hierarchy, no gimmicks
   ========================================================= */

:root{
  --red:#b91f28;
  --red-dark:#941820;
  --black:#070707;
  --charcoal:#121110;
  --graphite:#181615;
  --stone:#d3d0ca;
  --stone-2:#c5c0b9;
  --line-light:rgba(255,248,240,.11);
  --line-dark:rgba(20,17,15,.12);
}

/* general cleanup */
body{
  background:var(--stone);
}
.section-kicker,
.section-label,
.eyebrow{
  letter-spacing:.18em !important;
}
h1,h2,h3{
  letter-spacing:-.065em;
}
p{
  font-weight:400;
}

/* header + logo */
.brand img{
  height:64px !important;
}
.site-header.scrolled .brand img{
  height:52px !important;
}

/* HERO: controlled black / red field */
.hero.section-dark{
  background:
    linear-gradient(90deg,#070707 0%,#070707 67%,#1b0709 67%,#26090b 100%) !important;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:96px 96px;
  opacity:.62;
  pointer-events:none;
}
.hero-copy h1{
  max-width:780px;
}
.hero-text{
  max-width:680px;
  color:rgba(255,255,255,.78) !important;
}
.hero-actions{
  display:flex !important;
  align-items:center !important;
  flex-wrap:wrap !important;
  gap:28px !important;
  margin-top:34px !important;
}
.hero-actions .button{
  display:none !important;
}
.hero-link{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:12px;
  color:#fff8f0;
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:800;
}
.hero-link::before{
  content:"";
  width:44px;
  height:1px;
  background:rgba(255,255,255,.44);
  transition:width .25s var(--ease), background .25s var(--ease);
}
.hero-link::after{
  content:"↗";
  font-size:12px;
  opacity:.75;
  transform:translateY(-1px);
  transition:transform .25s var(--ease), opacity .25s var(--ease);
}
.hero-link:hover::before{
  width:62px;
  background:var(--red);
}
.hero-link:hover::after{
  opacity:1;
  transform:translate(3px,-2px);
}
.hero-tags{
  gap:10px !important;
}
.hero-tags span{
  background:rgba(255,255,255,.025) !important;
  border:1px solid rgba(255,255,255,.13) !important;
  color:rgba(255,255,255,.68) !important;
  box-shadow:none !important;
}

/* SECTION SYSTEM */
.intro-section{
  background:var(--stone) !important;
  padding-block:118px !important;
}
.intro-section::before{
  background:none !important;
}
.intro-grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr .96fr;
  gap:64px;
  align-items:end;
}
.intro-main h2{
  max-width:780px;
}
.intro-side{
  display:grid;
  gap:20px;
}
.intro-side p{
  max-width:700px;
  font-size:20px !important;
  line-height:1.58;
  color:rgba(20,17,15,.74);
}

/* selected brands: quiet proof */
.logo-strip-section{
  background:#11100f !important;
  padding:64px 0 44px !important;
  overflow:hidden;
  border:none !important;
}
.logo-strip-head{
  max-width:var(--max);
  margin:0 auto 28px !important;
  padding:0 clamp(20px,5vw,58px);
}
.logo-strip-head .section-kicker{
  color:var(--red) !important;
}
.logo-strip-head h2{
  max-width:780px;
  color:#fff8f0 !important;
  font-size:clamp(34px,3.4vw,56px);
}
.logo-marquee{
  display:flex;
  width:max-content;
  animation:logoScroll 38s linear infinite;
}
.logo-marquee-track{
  display:flex;
  align-items:center;
  gap:46px;
  padding-right:46px;
}
.logo-item{
  width:auto !important;
  height:auto !important;
  padding:0 !important;
  border:none !important;
  background:none !important;
  border-radius:0 !important;
  box-shadow:none !important;
}
.logo-item img{
  max-width:142px !important;
  max-height:38px !important;
  filter:grayscale(1) brightness(.90) contrast(1.05) !important;
  opacity:.70 !important;
}
.logo-item:hover img{
  opacity:.95 !important;
}
@keyframes logoScroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* What we do: professional editorial, no loud red card gimmick */
.services-section{
  background:#c4bfb8 !important;
  padding-block:118px !important;
  position:relative;
  overflow:hidden;
}
.services-section::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:10px;
  background:var(--red);
}
.services-section::after{
  display:none !important;
}
.services-section .section-label,
.services-section .services-head h2{
  color:#14110f !important;
}
.services-head{
  max-width:var(--max);
  margin:0 auto 34px !important;
  position:relative;
  z-index:2;
}
.services-head h2{
  max-width:880px;
}
.service-luxe{
  max-width:var(--max);
  margin:0 auto !important;
  display:grid;
  gap:0 !important;
  border-top:1px solid rgba(20,17,15,.16);
  position:relative;
  z-index:2;
}
.service-row{
  display:grid !important;
  grid-template-columns:minmax(260px,.8fr) 1.2fr auto !important;
  gap:32px !important;
  align-items:center !important;
  min-height:134px !important;
  padding:32px 0 !important;
  border:none !important;
  border-bottom:1px solid rgba(20,17,15,.16) !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  cursor:pointer;
}
.service-row::before{
  content:"";
  position:absolute;
  left:0;
  width:0;
  height:1px;
  background:var(--red);
  opacity:.8;
  transition:width .3s var(--ease);
}
.service-row:hover{
  padding-left:18px !important;
  background:rgba(255,255,255,.14) !important;
}
.service-row:hover::before{
  width:92px;
}
.service-row-title h3{
  color:#14110f !important;
  font-size:clamp(34px,3vw,52px) !important;
}
.service-row p{
  color:rgba(20,17,15,.68) !important;
  max-width:640px !important;
  font-size:18px !important;
}
.service-row-link{
  background:none !important;
  border:none !important;
  color:var(--red) !important;
  padding:0 !important;
  min-height:auto !important;
  font-size:11px;
  letter-spacing:.16em;
}

/* bridge: the one decisive red editorial moment */
.bridge-statement{
  background:var(--red) !important;
  color:#fff8f0 !important;
  padding-block:124px !important;
}
.bridge-statement::before{
  display:none !important;
}
.bridge-wrap{
  max-width:1050px !important;
  margin:0 auto !important;
  text-align:left !important;
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:20px !important;
}
.bridge-quote-mark{
  display:none !important;
}
.bridge-wrap h2{
  color:#fff !important;
  max-width:920px !important;
  font-size:clamp(48px,5vw,86px) !important;
}
.bridge-wrap p{
  color:rgba(255,255,255,.78) !important;
  max-width:740px !important;
  margin:0 !important;
}
.bridge-wrap::before{
  content:"";
  width:72px;
  height:1px;
  background:rgba(255,255,255,.72) !important;
  display:block;
}
.bridge-wrap::after{
  display:none !important;
}

/* audience: calm dark, clean principles, premium editorial cards */
.audience-section{
  background:#11100f !important;
  padding-block:118px !important;
}
.audience-section::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.028) 1px, transparent 1px);
  background-size:96px 96px;
  opacity:.5;
  pointer-events:none;
  mask-image:none !important;
}
.audience-top{
  max-width:var(--max);
  margin:0 auto 44px !important;
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:28px !important;
  min-height:0 !important;
  position:relative;
  z-index:2;
}
.audience-top h2{
  max-width:860px !important;
}
.audience-principles{
  position:relative !important;
  inset:auto !important;
  display:flex !important;
  flex-wrap:wrap;
  gap:10px !important;
  max-width:760px !important;
}
.audience-principles span{
  position:relative !important;
  transform:none !important;
  display:inline-flex !important;
  flex-direction:row !important;
  gap:6px !important;
  align-items:center !important;
  min-height:38px !important;
  padding:0 13px !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.12) !important;
  background:rgba(255,255,255,.035) !important;
  box-shadow:none !important;
  font-family:Inter, ui-sans-serif, system-ui, sans-serif !important;
  font-style:normal !important;
  text-shadow:none !important;
}
.audience-principles strong{
  font-size:11px !important;
  letter-spacing:.14em !important;
  text-transform:uppercase;
  color:#fff8f0 !important;
}
.audience-principles em{
  font-style:normal;
  font-size:11px !important;
  letter-spacing:.08em;
  color:rgba(255,255,255,.48) !important;
}
.audience-grid{
  max-width:var(--max);
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:0 !important;
  border-top:1px solid rgba(255,255,255,.12);
  position:relative;
  z-index:2;
}
.audience-card{
  min-height:190px !important;
  padding:34px 32px !important;
  border:none !important;
  border-bottom:1px solid rgba(255,255,255,.12) !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
}
.audience-card:nth-child(odd){
  border-right:1px solid rgba(255,255,255,.12) !important;
}
.audience-card::before{
  width:42px !important;
  height:1px !important;
  background:var(--red) !important;
  margin-bottom:28px !important;
}
.audience-card strong{
  color:#fff8f0 !important;
  font-size:clamp(26px,2.4vw,42px) !important;
  font-weight:700 !important;
}
.audience-card em{
  color:rgba(255,255,255,.60) !important;
  max-width:460px;
  margin-top:22px !important;
}
.audience-card:hover{
  transform:none !important;
  background:rgba(255,255,255,.035) !important;
  box-shadow:none !important;
}

/* work: light grey, subtle cards */
.work-section{
  background:#d1cdc7 !important;
  padding-block:118px !important;
}
.work-section::before{
  display:none !important;
}
.work-card{
  background:#dedad5 !important;
  border:1px solid rgba(20,17,15,.10) !important;
  border-radius:28px !important;
  box-shadow:0 20px 54px rgba(0,0,0,.10) !important;
}

/* moments: black/red split but controlled */
.moments-section{
  background:
    linear-gradient(90deg,#080808 0%,#080808 72%,#21090b 72%,#21090b 100%) !important;
  color:#fff8f0 !important;
  padding-block:118px !important;
}
.moments-section::before{
  display:none !important;
}
.moments-copy h2,
.moments-copy p,
.moments-copy .section-kicker{
  color:#fff8f0 !important;
}
.moments-cards article{
  background:rgba(255,255,255,.035) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  border-radius:24px !important;
  box-shadow:none !important;
}

/* process: keep strong, cleaner panels */
.process-showcase{
  background:#090909 !important;
}
.process-stage{
  background:rgba(255,255,255,.025) !important;
  border:1px solid rgba(255,255,255,.11) !important;
  box-shadow:0 30px 90px rgba(0,0,0,.28) !important;
}
.process-panel li{
  font-family:Inter, ui-sans-serif, system-ui, sans-serif !important;
  font-size:15px !important;
  line-height:1.5 !important;
  letter-spacing:.02em !important;
  font-style:normal !important;
}

/* founder: keep special, not gimmicky */
.founder-section{
  background:#d3d0ca !important;
  padding-block:124px !important;
}

/* contact: form-led */
.brief-section{
  background:
    linear-gradient(90deg,#070707 0%,#070707 70%,#1d080a 70%,#1d080a 100%) !important;
  padding:110px clamp(28px,5vw,72px) 96px !important;
}
.brief-section::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.026) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.026) 1px, transparent 1px);
  background-size:96px 96px;
  opacity:.6;
  pointer-events:none;
}
.brief-section::after{
  display:none !important;
}
#brief{
  max-width:1420px !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:minmax(0,.88fr) minmax(520px,1.12fr) !important;
  gap:48px !important;
  align-items:start !important;
}
#brief .brief-copy h2{
  max-width:640px !important;
  font-size:clamp(56px,5vw,84px) !important;
}
#brief .brief-copy p{
  max-width:570px !important;
  font-size:18px !important;
  color:rgba(255,255,255,.78) !important;
}
.brief-form{
  background:#d6d2cc !important;
  color:#14110f !important;
  border:1px solid rgba(20,17,15,.10) !important;
  border-radius:34px !important;
  box-shadow:0 28px 80px rgba(0,0,0,.24) !important;
  width:100%;
  min-height:640px;
  padding:30px !important;
  transform:none !important;
}
.brief-form input,
.brief-form textarea{
  background:#cfcac4 !important;
  border:1px solid rgba(20,17,15,.12) !important;
}
.brief-form textarea{
  min-height:220px !important;
}
.brief-note,
.brief-quote-note{
  display:none !important;
}

/* popups: subtle professional */
.modal-topbar-logo img{
  height:48px !important;
}
.fullscreen-modal .work-modal-close{
  width:auto !important;
  min-width:0 !important;
  height:44px !important;
  padding:0 20px !important;
  border-radius:999px !important;
  background:rgba(255,248,240,.025) !important;
  border:1px solid rgba(255,248,240,.18) !important;
  color:#fff8f0 !important;
}
.fullscreen-modal .work-modal-close:hover{
  background:rgba(255,248,240,.08) !important;
}
.stage-primary,
.stage-secondary{
  background:#d6d2cc !important;
}
.stage-detail{
  background:var(--red) !important;
}

/* footer */
.footer{
  background:#020202 !important;
}

/* responsive */
@media (max-width:1120px){
  .intro-grid,
  #brief{
    grid-template-columns:1fr !important;
  }
  .service-row{
    grid-template-columns:1fr !important;
    gap:14px !important;
    padding:28px 0 !important;
  }
  .audience-grid{
    grid-template-columns:1fr !important;
  }
  .audience-card:nth-child(odd){
    border-right:none !important;
  }
  .brief-form{
    min-height:auto !important;
  }
}
@media (max-width:640px){
  .brand img{height:48px !important}
  .site-header.scrolled .brand img{height:40px !important}
  .hero-link{font-size:12px}
  .logo-marquee-track{gap:28px;padding-right:28px}
  .logo-item img{max-width:112px !important;max-height:30px !important}
  .audience-card{padding:28px 0 !important}
  #brief .brief-copy h2{font-size:44px !important}
}
