:root{
  --brand-orange:#E8851E;
  --brand-magenta:#E8398B;
  --ink:#121011;
  --cream:#FBF1E9;
  --surface:#FFFFFF;
  --text-on-dark:#FBF1E9;
  --text-muted:#6B635E;
  --grad:linear-gradient(90deg,#E8851E,#E8398B);
  --header-h:74px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Poppins',system-ui,-apple-system,Helvetica,Arial,sans-serif;
  background:var(--cream);
  color:var(--ink);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img,svg,video,iframe{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none;margin:0;padding:0}
p{overflow-wrap:break-word}

/* Scroll offset for fixed header */
[id]{scroll-margin-top:calc(var(--header-h) + 1rem)}

.skip-link{
  position:absolute;left:-999px;top:0;z-index:1000;
  background:var(--ink);color:var(--cream);
  padding:.6rem 1rem;border-radius:0 0 8px 0;
}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--brand-magenta);outline-offset:3px;border-radius:4px}

/* Shared width-constrained containers */
.container,
.about-grid,
.process-inner,
.svc-grid,
.work-inner,
.quote-grid,
.closing-grid,
.footer-top,
.header-inner{
  width:min(1240px,100% - 2.6rem);
  margin-inline:auto;
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:600;font-size:.95rem;border:none;cursor:pointer;
  border-radius:999px;padding:.85rem 1.5rem;
  transition:transform .25s ease,box-shadow .25s ease,filter .25s ease;
  font-family:inherit;
}
.btn-cta{
  background:var(--grad);color:#fff;
  box-shadow:0 8px 24px rgba(232,57,139,.28);
}
.btn-cta:hover{transform:translateY(-2px);filter:brightness(1.06);box-shadow:0 12px 32px rgba(232,57,139,.42)}
.cta-icon{
  display:inline-grid;place-items:center;
  width:22px;height:22px;border-radius:50%;
  background:rgba(255,255,255,.25);font-size:.8rem;
}

/* ============ HEADER ============ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s ease,box-shadow .3s ease;
  padding:.4rem 0;
}
.site-header.scrolled{
  background:rgba(18,16,17,.86);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:0 1px 0 rgba(255,255,255,.07);
}
.header-inner{display:flex;align-items:center;gap:1rem;min-height:var(--header-h)}
.logo img{height:42px;width:auto}
.primary-nav{margin-left:auto}
.nav-list{display:flex;align-items:center;gap:.3rem}
.nav-link{
  display:inline-flex;align-items:center;gap:.35rem;
  color:var(--cream);font-weight:500;font-size:.95rem;
  padding:.55rem .75rem;border-radius:999px;position:relative;
  transition:color .2s;
}
.nav-link::after{
  content:"";position:absolute;left:.75rem;right:.75rem;bottom:.3rem;
  height:2px;background:var(--grad);
  transform:scaleX(0);transform-origin:left;
  transition:transform .25s ease;border-radius:2px;
}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}
.caret{
  width:7px;height:7px;
  border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg);margin-top:-3px;transition:transform .25s;
}
.has-dropdown{position:relative}
.dropdown{
  position:absolute;top:100%;left:0;min-width:270px;
  background:rgba(18,16,17,.96);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.08);border-radius:14px;
  padding:.5rem;box-shadow:0 20px 50px rgba(0,0,0,.5);
  opacity:0;visibility:hidden;transform:translateY(10px);
  transition:all .25s ease;
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(8px)}
.has-dropdown:hover .caret{transform:rotate(225deg)}
.dropdown li a{
  display:block;color:var(--cream);
  padding:.7rem .85rem;border-radius:9px;
  font-size:.9rem;transition:background .2s,color .2s;
}
.dropdown li a:hover{background:rgba(232,133,30,.15);color:var(--brand-orange)}
.header-cta{margin-left:.5rem}

.menu-toggle{
  display:none;background:none;border:none;cursor:pointer;
  width:46px;height:46px;border-radius:12px;
  flex-direction:column;gap:5px;align-items:center;justify-content:center;
  margin-left:auto;
}
.menu-toggle span{width:24px;height:2px;background:var(--cream);border-radius:2px;transition:.3s}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============ MOBILE MENU ============ */
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:var(--ink);
  padding:calc(var(--header-h) + 1.5rem) 1.5rem 2rem;
  transform:translateX(100%);
  transition:transform .4s cubic-bezier(.7,0,.2,1);
  overflow-y:auto;
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu ul li a,.m-acc{
  display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;
  color:var(--cream);font-family:inherit;font-size:1.3rem;font-weight:600;
  padding:.85rem 0;border-bottom:1px solid rgba(255,255,255,.1);
}
.m-acc{display:flex;align-items:center;gap:.5rem;justify-content:space-between}
.m-acc .caret{margin-top:0}
.m-acc[aria-expanded="true"] .caret{transform:rotate(225deg)}
.m-sub{max-height:0;overflow:hidden;transition:max-height .35s ease}
.m-sub.open{max-height:500px}
.m-sub li a{
  font-size:1rem;font-weight:400;color:#cbbfb6;
  padding:.6rem 0 .6rem 1rem;border-bottom:1px solid rgba(255,255,255,.05);
}
.m-cta{margin-top:1.6rem;width:100%;justify-content:center;font-size:1.05rem}

/* ============ HERO ============ */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background-color:var(--ink); /* fallback when video/poster not loaded */
}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:50% 40%;
}
/* Cinematic scrim: heavy at top & bottom, light in center to let gala footage breathe */
.hero-scrim{
  position:absolute;inset:0;
  background:linear-gradient(
    180deg,
    rgba(18,16,17,.68) 0%,
    rgba(18,16,17,.22) 28%,
    rgba(18,16,17,.18) 60%,
    rgba(18,16,17,.82) 100%
  );
}
.hero-content{
  position:relative;z-index:2;
  width:min(1240px,100% - 2.6rem);
  margin-inline:auto;
  padding-top:calc(var(--header-h) + 1rem);
  padding-bottom:5rem;
  /* Editorial left-alignment — the tier-jump vs the centered live site */
  text-align:left;
}
.eyebrow{
  color:var(--cream);font-weight:600;letter-spacing:.28em;
  text-transform:uppercase;font-size:.72rem;margin:0 0 1.2rem;opacity:.85;
}
/* Massive oversized display headline — the hero OF the page */
.hero-title{
  font-weight:800;
  line-height:.88;
  letter-spacing:-.03em;
  margin:0;
  font-size:clamp(3.2rem,12vw,9.5rem);
}
.hero-line-1{display:block;color:var(--cream)}
.hero-line-2{
  display:block;
  background:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  background-size:200% auto;
  animation:gradShift 6s ease infinite;
}
@keyframes gradShift{0%,100%{background-position:0 50%}50%{background-position:100% 50%}}
.hero-cats{
  display:flex;gap:1rem;justify-content:flex-start;
  flex-wrap:wrap;margin-top:2.4rem;
}
.pill{
  border:1.5px solid rgba(251,241,233,.5);color:var(--cream);
  padding:.85rem 1.8rem;border-radius:999px;font-weight:600;font-size:.95rem;
  backdrop-filter:blur(4px);transition:all .25s;
}
.pill:hover{background:var(--grad);border-color:transparent;transform:translateY(-2px)}
.hero-scroll{
  position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);
  z-index:2;color:var(--cream);opacity:.65;
}
.hero-scroll span{
  font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;
  animation:bob 2s ease-in-out infinite;display:block;
}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}

/* ============ CLIENTS MARQUEE ============ */
.clients{
  background:var(--cream);
  padding:3rem 0 3.4rem;
  text-align:center;
  overflow:hidden;
}
.clients-label{
  text-transform:uppercase;letter-spacing:.2em;font-size:.72rem;
  font-weight:600;color:var(--text-muted);margin:0 0 1.6rem;
}
.marquee{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.marquee-track{
  display:inline-flex;align-items:center;gap:1.6rem;white-space:nowrap;
  animation:scroll 28s linear infinite;padding-left:1.6rem;
}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-weight:700;font-size:clamp(1.1rem,2.8vw,1.6rem);color:var(--ink);letter-spacing:-.01em}
.marquee-track .dot{color:var(--brand-orange);font-weight:400}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ SECTION TITLES ============ */
.sec-title{font-weight:800;letter-spacing:-.02em;line-height:1;font-size:clamp(2rem,6vw,4rem);margin:0}
.sec-title.light{color:var(--cream)}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.kicker{text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;font-weight:600;color:var(--brand-magenta);margin:0 0 1rem}
.light-kicker{color:var(--brand-orange)}

/* ============ ABOUT ============ */
.about{padding:7rem 0 9rem;background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-grid>*{min-width:0}
.about-title{
  font-weight:800;letter-spacing:-.02em;line-height:1.02;
  font-size:clamp(1.9rem,5vw,3.4rem);margin:0 0 1.4rem;
}
.lead{font-size:clamp(1.05rem,1.8vw,1.22rem);color:var(--ink);margin:0 0 1rem;font-weight:400;line-height:1.65}
.body-muted{color:var(--text-muted);margin:0 0 2rem;line-height:1.65}

/* Stats — 3-column grid always prevents awkward wrapping */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-bottom:2.2rem}
.stat{display:flex;flex-direction:column}
.stat .num{
  font-size:clamp(1.8rem,4.5vw,2.8rem);font-weight:800;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline;
}
.stat .plus{font-size:1.2rem;font-weight:800;color:var(--brand-magenta);vertical-align:top;line-height:1.4}
.stat-label{
  font-size:.72rem;color:var(--text-muted);text-transform:uppercase;
  letter-spacing:.05em;margin-top:.4rem;overflow-wrap:break-word;
}
.about-media{position:relative;padding-bottom:3.5rem}
.about-team img{border-radius:18px;box-shadow:0 30px 60px rgba(18,16,17,.15);width:100%}
.about-bts{
  position:absolute;right:-0.5rem;bottom:0;
  width:52%;margin:0;border-radius:14px;overflow:hidden;
  box-shadow:0 20px 44px rgba(18,16,17,.26);
  border:5px solid var(--cream);
}
.about-bts img{border-radius:9px;aspect-ratio:4/3;object-fit:cover;width:100%}
.about-bts figcaption{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(transparent,rgba(18,16,17,.85));
  color:var(--cream);font-size:.72rem;padding:1.4rem .8rem .6rem;
}

/* ============ PROCESS ============ */
.process{
  background:var(--ink);color:var(--cream);
  padding:5.5rem 0;position:relative;overflow:hidden;
}
.process::before{
  content:"";position:absolute;
  width:540px;height:540px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,57,139,.2),transparent 70%);
  top:-200px;right:-150px;filter:blur(20px);pointer-events:none;
}
.process-inner{position:relative;z-index:1}
.process .sec-title{color:var(--cream);margin-bottom:2.8rem}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.steps>*{min-width:0}
.step{border-top:2px solid rgba(232,133,30,.6);padding-top:1.4rem}
.step-no{font-size:.9rem;font-weight:700;color:var(--brand-orange);letter-spacing:.1em}
.step h3{font-size:1.5rem;font-weight:700;margin:.6rem 0 .5rem;color:var(--cream)}
.step p{color:#c5b9b0;margin:0;line-height:1.6}

/* ============ SERVICES ============ */
.services{background:var(--ink);padding:1rem 0 6rem}
.svc-heading{
  width:min(1240px,100% - 2.6rem);
  margin:0 auto 2.4rem;
}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.8rem}
.svc-grid>*{min-width:0}
.svc-card{
  position:relative;border-radius:18px;overflow:hidden;
  aspect-ratio:5/4;display:block;
}
.svc-card img{width:100%;height:100%;object-fit:cover;transition:transform .65s ease}
.svc-card:hover img{transform:scale(1.07)}
.svc-overlay{
  position:absolute;inset:0;display:flex;flex-direction:column;
  justify-content:flex-end;padding:2rem;
  background:linear-gradient(transparent 25%,rgba(18,16,17,.88));
  color:var(--cream);
}
.svc-overlay h3{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;margin:0 0 .4rem}
.svc-overlay p{margin:0 0 1rem;color:#e0d4cb;font-size:.95rem;max-width:34ch}
.svc-link{font-weight:600;color:var(--brand-orange);transition:letter-spacing .2s}
.svc-card:hover .svc-link{letter-spacing:.03em}

/* ============ WORK GALLERY ============ */
/* FIXED: section is full-viewport-width dark bg; inner div is width-constrained */
.work-section{background:var(--ink);padding:6rem 0}
.work-inner{} /* width set by shared container rule above */
.work-head{margin-bottom:2.6rem}
.bento{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;
  gap:1rem;
}
.bento>*{min-width:0}
.tile{position:relative;margin:0;border-radius:16px;overflow:hidden}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.tile:hover img{transform:scale(1.08)}
.tile figcaption{
  position:absolute;left:0;bottom:0;padding:.7rem 1rem;z-index:2;
}
.tile figcaption span{
  background:rgba(18,16,17,.72);backdrop-filter:blur(4px);
  color:var(--cream);font-size:.7rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  padding:.4rem .75rem;border-radius:999px;
}
.tile::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(transparent 50%,rgba(18,16,17,.45));
  opacity:0;transition:opacity .3s;
}
.tile:hover::after{opacity:1}
.b1{grid-column:span 2;grid-row:span 2}
.b2{grid-column:span 2;grid-row:span 1}
.b3{grid-column:span 2;grid-row:span 1}
.b4{grid-column:span 1;grid-row:span 1}
.b5{grid-column:span 1;grid-row:span 1}
.b6{grid-column:span 2;grid-row:span 1}

/* ============ TESTIMONIAL ============ */
.testimonial{background:var(--cream);padding:7rem 0}
.quote-grid{display:grid;grid-template-columns:.8fr 1.5fr;gap:4rem;align-items:center}
.quote-grid>*{min-width:0}
.quote-img{
  margin:0;
  border-radius:280px 280px 16px 16px;
  overflow:hidden;
  box-shadow:0 30px 60px rgba(18,16,17,.18);
}
.quote-img img{width:100%;aspect-ratio:3/4;object-fit:cover}
.quote-mark{
  font-size:6rem;line-height:.3;color:var(--brand-orange);
  font-weight:800;display:block;margin-bottom:1.2rem;
}
.quote{margin:0}
/* Enlarged quote for impact */
.quote p{
  font-size:clamp(1.5rem,3.2vw,2.5rem);
  line-height:1.35;font-weight:500;
  letter-spacing:-.02em;margin:0 0 1.8rem;color:var(--ink);
}
.quote footer{font-weight:600;color:var(--brand-magenta);font-size:1.05rem}

/* ============ CLOSING CTA — dark section for better rhythm ============ */
.closing{padding:6rem 0;background:var(--ink);position:relative;overflow:hidden}
.closing::before{
  content:"";position:absolute;
  width:600px;height:400px;
  background:radial-gradient(ellipse,rgba(232,133,30,.15),transparent 70%);
  left:-100px;bottom:-80px;filter:blur(30px);pointer-events:none;
}
.closing-grid{
  display:grid;grid-template-columns:.72fr 1.6fr;
  gap:1.8rem;align-items:stretch;position:relative;z-index:1;
}
.closing-grid>*{min-width:0}
.closing-card{
  background:var(--brand-orange);color:#fff;border-radius:20px;
  padding:2.4rem;display:flex;flex-direction:column;justify-content:flex-end;
  box-shadow:0 28px 60px rgba(232,133,30,.45);
}
.closing-arrow{font-size:2.2rem;margin-bottom:auto;display:block;line-height:1}
.closing-card h2{
  font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800;
  margin:1.6rem 0 .6rem;line-height:1;color:#fff;
}
.closing-card p{margin:0 0 1.8rem;color:#ffebd9;line-height:1.5}
.btn-closing{
  background:#fff;color:var(--brand-orange);align-self:flex-start;
  border:2px solid #fff;font-size:.95rem;
}
.btn-closing:hover{background:transparent;color:#fff;transform:translateY(-2px)}
.closing-img{margin:0;border-radius:20px;overflow:hidden;box-shadow:0 28px 56px rgba(18,16,17,.35)}
.closing-img img{width:100%;height:100%;object-fit:cover;min-height:300px}

/* ============ FOOTER ============ */
.site-footer{background:var(--cream);padding-top:3rem;border-top:1px solid rgba(18,16,17,.08)}
.footer-top{
  display:grid;grid-template-columns:1.2fr .9fr 1.1fr;
  gap:3rem;padding-bottom:3rem;
}
.footer-top>*{min-width:0}
.footer-logo{height:40px;width:auto;margin-bottom:1.8rem}
.follow{font-size:1.4rem;font-weight:700;margin:0 0 1rem}
.socials{display:flex;gap:.7rem;margin-bottom:1.6rem;flex-wrap:wrap}
.socials a{
  display:grid;place-items:center;width:44px;height:44px;
  border-radius:50%;background:var(--ink);color:var(--cream);
  transition:transform .2s,background .2s;
}
.socials a:hover{transform:translateY(-3px);background:var(--brand-magenta)}
.footer-contact{display:flex;flex-direction:column;gap:.5rem}
.footer-contact a{color:var(--text-muted);font-size:.95rem;transition:color .2s}
.footer-contact a:hover{color:var(--brand-orange)}
.footer-nav ul{columns:2;column-gap:1.5rem}
.footer-nav li{break-inside:avoid;margin-bottom:.55rem}
.footer-nav a{color:var(--ink);font-size:.92rem;font-weight:500;transition:color .2s}
.footer-nav a:hover{color:var(--brand-magenta)}
.footer-nav li.sub a{color:var(--text-muted);font-weight:400;font-size:.84rem;padding-left:.6rem}
.footer-news h3{
  font-size:clamp(1.5rem,2.8vw,2rem);font-weight:800;
  letter-spacing:-.01em;margin:0 0 1.2rem;line-height:1.05;
}
.news-form{display:flex;flex-direction:column;gap:.65rem;max-width:420px}
.news-form label{font-size:.85rem;font-weight:500}
.news-form input[type="email"]{
  padding:.85rem 1rem;border:1.5px solid rgba(18,16,17,.2);
  border-radius:10px;font-family:inherit;font-size:1rem;background:#fff;
  transition:border-color .2s;
}
.news-form input[type="email"]:focus{border-color:var(--brand-orange);outline:none}
.checkbox-label{
  display:flex;align-items:center;gap:.6rem;
  color:var(--text-muted);font-size:.9rem;font-weight:400;
}
.checkbox-label input{width:18px;height:18px;accent-color:var(--brand-orange);flex-shrink:0}
.btn-news{
  background:var(--brand-orange);color:#fff;justify-content:center;margin-top:.4rem;
}
.btn-news:hover{background:var(--brand-magenta);transform:translateY(-2px)}
.field-error{color:#c0392b;font-size:.82rem;margin:0}
.news-ok{color:#1f8a4c;font-weight:600;font-size:.9rem;margin:.3rem 0 0}

/* Footer bottom bar with d30d2953 small logo */
.footer-bottom{border-top:1px solid rgba(18,16,17,.08);padding:1.4rem 0}
.footer-bottom-inner{
  width:min(1240px,100% - 2.6rem);
  margin-inline:auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;flex-wrap:wrap;
}
.footer-wordmark{height:26px;width:auto;opacity:.6;transition:opacity .2s}
.footer-wordmark:hover{opacity:1}
.copyright{color:var(--text-muted);font-size:.85rem;margin:0}

/* ============ STICKY CTA (mobile) ============ */
.sticky-cta{
  display:none;position:fixed;z-index:90;bottom:1rem;right:1rem;
  background:var(--grad);color:#fff;font-weight:700;font-size:.95rem;
  padding:.9rem 1.5rem;border-radius:999px;
  box-shadow:0 10px 30px rgba(232,57,139,.5);
  font-family:inherit;
}

/* ============ SCROLL REVEAL ============ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ============ RESPONSIVE ============ */
@media (max-width:1000px){
  .primary-nav,.header-cta{display:none}
  .menu-toggle{display:flex}
  .quote-grid{grid-template-columns:1fr;gap:2rem}
  .quote-img{max-width:320px}
  .footer-top{grid-template-columns:1fr 1fr;gap:2.2rem}
}

@media (max-width:780px){
  .about{padding:5rem 0 4rem}
  .about-grid{grid-template-columns:1fr;gap:2rem}
  .about-media{padding-bottom:0}
  .about-bts{position:relative;right:0;bottom:0;width:65%;margin:1.5rem auto 0}
  .svc-grid{grid-template-columns:1fr}
  .svc-heading{margin-bottom:1.8rem}
  .steps{grid-template-columns:1fr;gap:0}
  .step{border-top:none;border-left:2px solid rgba(232,133,30,.6);padding:0 0 1.6rem 1.2rem}
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:165px}
  .b1,.b2,.b3,.b6{grid-column:span 2}
  .b1{grid-row:span 2}
  .b4,.b5{grid-column:span 1}
  .closing-grid{grid-template-columns:1fr}
  .closing-img img{min-height:240px}
  .footer-top{grid-template-columns:1fr}
  .sticky-cta{display:inline-block}
  .hero-title{font-size:clamp(3rem,13vw,6rem)}
}

@media (max-width:480px){
  .container,
  .about-grid,
  .process-inner,
  .svc-grid,
  .work-inner,
  .quote-grid,
  .closing-grid,
  .footer-top,
  .header-inner{width:min(1240px,100% - 2rem)}
  .hero-content{width:min(1240px,100% - 2rem);padding-bottom:4rem}
  .stats{gap:.8rem}
  .stat .num{font-size:clamp(1.6rem,7vw,2.2rem)}
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px}
  .b1{grid-column:span 2;grid-row:span 2}
  .b2,.b3,.b6{grid-column:span 2;grid-row:span 1}
  .b4,.b5{grid-column:span 1;grid-row:span 1}
  .footer-nav ul{columns:1}
  .quote p{font-size:clamp(1.25rem,5vw,1.8rem)}
  .footer-bottom-inner{flex-direction:column;align-items:flex-start;gap:.6rem}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
    scroll-behavior:auto!important;
  }
  .reveal{opacity:1;transform:none}
  .hero-line-2{animation:none}
  .marquee-track{animation:none}
}