/* SOS Casa Express — Landing Page Styles */
:root{
  --brand:#ff5a2c;
  --brand-600:#ff3d0a;
  --brand-700:#e53805;
  --ink-900:#121418;
  --ink-800:#1b1f24;
  --ink-700:#242a31;
  --ink-600:#2f3742;
  --ink-500:#3b4654;
  --ink-400:#586373;
  --ink-300:#8b96a5;
  --ink-200:#c7ced8;
  --ink-100:#e8eef6;
  --bg:#f7f8fb;
  --white:#fff;
  --radius:16px;
  --shadow: 0 10px 30px rgba(27, 31, 36, 0.08);
  --hero-overlay-top: .60;
  --hero-overlay-bottom: .78;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  color:var(--ink-800);
  background:var(--bg);
  line-height:1.55;
}
body.no-scroll{overflow:hidden}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}

.skip-link{position:absolute;left:-9999px;top:auto}
.skip-link:focus{left:16px;top:16px;z-index:10;background:#000;color:#fff;padding:8px 12px;border-radius:8px}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.container{width:min(1120px, 92vw);margin-inline:auto}

/* Header */
.site-header{position:sticky;top:0;background:rgba(255,255,255,.85);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid #eee;z-index:20}
.header-row{display:flex;align-items:center;gap:20px;min-height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-0.02em}
.brand-logo{gap:0}
.brand .brand-mark{background:var(--brand);color:#fff;padding:8px 10px;border-radius:8px}
.brand .brand-name{color:var(--ink-800)}
.brand-logo .logo-img{height:180px;width:auto;display:block}
.site-header .brand-logo .logo-img{height:72px}
.brand-logo .logo-avatar{height:72px;width:auto;display:block}
.nav{margin-left:auto}
.nav-toggle{display:none;background:transparent;border:0;font-size:24px;cursor:pointer}
.menu{display:flex;gap:24px;align-items:center}
.menu a{color:var(--ink-600);font-weight:500}
.menu a:hover{color:var(--ink-800)}
.cta-header{margin-left:8px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:700;border-radius:12px;padding:12px 18px;transition:.2s ease;cursor:pointer}
.btn.small{padding:8px 12px;font-weight:600}
.btn-block{width:100%}
.btn-primary{background:var(--brand);color:#fff;box-shadow: 0 6px 20px rgba(255,90,44,.35)}
.btn-primary:hover{background:var(--brand-600)}
.btn-ghost{border:1px solid var(--ink-200);background:#fff;color:var(--ink-700)}
.btn-ghost:hover{border-color:var(--ink-400)}

.eyebrow{color:var(--brand);font-weight:800;letter-spacing:.02em;margin:0 0 8px}
.lead{color:var(--ink-600)}

/* Hero */
.hero{position:relative;isolation:isolate}
.hero-media{position:absolute;inset:0;background:#0c0f14;z-index:-1;overflow:hidden}
.hero-media::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg, rgba(0,0,0,var(--hero-overlay-top)), rgba(0,0,0,var(--hero-overlay-bottom)))}
.hero-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(110%) contrast(105%)}
  .hero-inner{padding:72px 0 24px}
  .hero-copy{max-width:720px;color:#fff}
.hero h1{font-size:clamp(32px, 5vw, 56px);line-height:1.05;margin:0 0 12px}
.hero .lead{color:#e9eef6;font-size:18px}
.hero-ctas{display:flex;gap:12px;margin:22px 0 12px}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
  .hero-badges li{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);padding:8px 10px;border-radius:999px;font-size:13px}

/* Removido fallback de reduzir movimento para manter o vídeo ativo no mobile */

/* Why */
.why{padding:72px 0 24px}
.why h2{font-size:clamp(26px,3.5vw,40px);margin:0}
.why-header{display:flex;align-items:center;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.why-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 12px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(255,255,255,.4), rgba(255,255,255,.18));
  border:1px solid rgba(255,255,255,.85);
  box-shadow:0 8px 20px rgba(27,31,36,.12);
  backdrop-filter:saturate(150%) blur(14px);
  -webkit-backdrop-filter:saturate(150%) blur(14px);
  transition:transform .2s ease, box-shadow .2s ease;
}
.why-badge:hover{
  box-shadow:0 16px 32px rgba(27,31,36,.18);
  transform:translateY(-2px);
}
.why-badge-avatar{height:32px;width:auto;display:block}
.why-badge-logo{height:26px;width:auto;display:block}
.services .why-header,
.cta-contact .why-header,
.team .why-header,
.clients .why-header,
.partners .why-header{
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:24px}
.why-item{
  background:linear-gradient(135deg, rgba(255,255,255,.35), rgba(255,255,255,.12));
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 10px 26px rgba(27,31,36,.14);
  backdrop-filter:saturate(150%) blur(18px);
  -webkit-backdrop-filter:saturate(150%) blur(18px);
  padding:28px 32px;
  border-radius:18px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.why-item:hover{
  box-shadow:0 18px 40px rgba(27,31,36,.18);
  transform:translateY(-4px);
}
.why-item .icon{width:44px;height:44px;object-fit:contain;display:block;margin-inline:auto}
.why-item h3{margin:8px 0 8px;text-align:center}
.why-item p{color:var(--ink-600);margin:0}

.panel{background:#2b2f35;color:#fff;border-radius:18px;padding:28px;box-shadow:var(--shadow)}
.panel.-gradient{background:linear-gradient(135deg,#2b2f35 0%, #3a2b27 60%, #2d2f33 100%)}

.panel.projects-panel{
  position:relative;
  overflow:visible;
  border:1px solid rgba(255,255,255,.06);
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(255,90,44,.18), rgba(43,47,53,.92) 55%),
    linear-gradient(135deg,#2b2f35 0%, #2d2f33 100%);
}
.projects-panel{display:grid;grid-template-columns:1fr 1.2fr;align-items:start;gap:32px;margin-top:40px}
.projects-panel .panel-copy h3{font-size:32px;margin:6px 0 10px}
.projects-panel .panel-copy p{color:#cfd6df}

.carousel-filters{
  display:flex;
  flex-wrap:nowrap;
  gap:10px;
  margin:0 0 14px;
  padding:4px 2px 6px;
  overflow-x:auto;
  scroll-behavior:smooth;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.2) transparent;
}
.carousel-filters::-webkit-scrollbar{height:6px}
.carousel-filters::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:999px}
.carousel-filters::-webkit-scrollbar-track{background:transparent}
.filter-chip{
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.1);
  color:#f4f6fa;
  padding:7px 14px;
  border-radius:999px;
  font-size:11px;
  font-weight:700;
  line-height:1.2;
  letter-spacing:.03em;
  white-space:nowrap;
  cursor:pointer;
  transition:background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.filter-chip:hover{border-color:rgba(255,255,255,.4);transform:translateY(-1px)}
.filter-chip.is-active{
  background:var(--brand);
  color:#fff;
  border-color:transparent;
  box-shadow:0 10px 24px rgba(255,90,44,.35);
}
.filter-chip:focus-visible{outline:2px solid var(--brand);outline-offset:2px}

/* Carousel */
.carousel{position:relative;overflow:hidden;padding:6px 48px}
.carousel-track{display:flex;gap:20px;transform:translateX(0);transition:transform .35s ease}
.carousel-progress{
  position:absolute;
  right:48px;
  bottom:-18px;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.carousel-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.4);
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-size:22px;
  color:var(--ink-800);
  box-shadow:0 14px 30px rgba(0,0,0,.2);
  backdrop-filter:blur(10px);
  opacity:.1;
  transition:opacity .2s ease, transform .2s ease;
}
.carousel:hover .carousel-btn{opacity:1}
.carousel-btn:hover{transform:translateY(-50%) scale(1.05)}
.carousel-btn:disabled{opacity:.4;cursor:not-allowed}
.carousel-btn.prev{left:8px}
.carousel-btn.next{right:8px}

.media-card{
  min-width:280px;
  max-width:360px;
  background:#0f1114;
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  position:relative;
  box-shadow:0 18px 45px rgba(0,0,0,.35);
  transition:transform .25s ease, box-shadow .25s ease;
  cursor:pointer;
}
.media-card:hover,
.media-card:focus-within{transform:translateY(-6px);box-shadow:0 26px 60px rgba(0,0,0,.42)}
.media-card:focus-visible{outline:2px solid var(--brand);outline-offset:3px}
.media-card img{aspect-ratio:16/10;width:100%;object-fit:cover;display:block;transition:transform .35s ease}
.media-card:hover img,
.media-card:focus-within img{transform:scale(1.04)}
.media-card figcaption{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:10px;
  padding:16px;
  color:#fff;
  background:linear-gradient(180deg, rgba(10,12,16,0) 35%, rgba(10,12,16,.72) 100%);
}
.media-tag{
  align-self:flex-start;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  color:#111;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  border:1px solid rgba(255,255,255,.7);
}

.media-badge{
  position:absolute;
  top:14px;
  right:14px;
  padding:6px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  box-shadow:0 10px 24px rgba(0,0,0,.25);
  pointer-events:none;
}
.media-badge.is-before{background:rgba(255,255,255,.92);color:#111}
.media-badge.is-after{background:var(--brand);color:#fff}

.media-text{
  font-size:14px;
  font-weight:600;
  color:#f4f7fb;
  text-shadow:0 8px 18px rgba(0,0,0,.55);
}

.lightbox{
  position:fixed;
  inset:0;
  display:grid;
  place-items:center;
  background:rgba(10,12,16,.72);
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
  z-index:60;
  padding:24px;
}
.lightbox.is-open{opacity:1;pointer-events:auto}
.lightbox-content{
  position:relative;
  max-width:min(1100px, 92vw);
  width:100%;
  display:grid;
  gap:12px;
  justify-items:center;
}
.lightbox-content img{
  width:auto;
  max-width:100%;
  max-height:82vh;
  border-radius:18px;
  box-shadow:0 30px 70px rgba(0,0,0,.45);
  background:#fff;
}
.lightbox-caption{
  color:#e9edf3;
  font-weight:600;
  text-align:center;
  max-width:720px;
}
.lightbox-close{
  position:absolute;
  top:-10px;
  right:-10px;
  width:40px;
  height:40px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.4);
  background:rgba(255,255,255,.9);
  color:var(--ink-800);
  font-size:24px;
  display:grid;
  place-items:center;
  cursor:pointer;
  box-shadow:0 12px 26px rgba(0,0,0,.25);
}
.lightbox-close:hover{transform:scale(1.05)}
.lightbox-close:focus-visible{outline:2px solid var(--brand);outline-offset:2px}

.page-bg-wrap{
  background-image:url("../assets/background-left.svg"),url("../assets/background.svg");
  background-repeat:no-repeat,no-repeat;
  background-position:left top,right top;
  background-size:50% auto,50% auto;
  background-attachment:fixed;
}

/* Services */
.services{padding:72px 0 24px}
.section-lead{color:var(--ink-600);max-width:780px}
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:22px}
.card{background:#fff;border:1px solid #eee;border-radius:16px;padding:20px;box-shadow:var(--shadow)}
.service-card .icon{width:48px;height:48px;object-fit:contain;display:block;margin:2px auto 8px}
.service-card h3{text-align:center}
.service-card h3{margin:10px 0}
.service-card p{color:var(--ink-600)}
.service-card .btn{display:flex;margin-inline:auto}

.services .card{
  background:linear-gradient(135deg, rgba(255,255,255,.35), rgba(255,255,255,.12));
  border:1px solid rgba(255,255,255,.8);
  backdrop-filter:saturate(150%) blur(18px);
  -webkit-backdrop-filter:saturate(150%) blur(18px);
  border-radius:18px;
  box-shadow:0 10px 26px rgba(27,31,36,.14);
  transition:transform .2s ease, box-shadow .2s ease;
}
.services .card:hover{
  box-shadow:0 18px 40px rgba(27,31,36,.18);
  transform:translateY(-4px);
}

.mascot-floating{
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:40;
  pointer-events:auto;
  border:0;
  background:transparent;
  padding:0;
  -webkit-appearance:none;
  appearance:none;
  cursor:pointer;
}
.mascot-floating:focus-visible{outline:2px solid var(--brand);outline-offset:4px}
.mascot-floating img{
  width:140px;
  height:auto;
  animation:mascot-float 4s ease-in-out infinite;
  will-change:transform;
}
.mascot-floating.is-animating img{
  animation:mascot-float 4s ease-in-out infinite, mascot-pop .6s ease;
}

@keyframes mascot-slide-in{
  0%{transform:translateX(-60px);opacity:0}
  100%{transform:translateX(0);opacity:1}
}
@keyframes mascot-float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
@keyframes mascot-pop{
  0%{transform:scale(1)}
  40%{transform:scale(1.12) rotate(-4deg)}
  70%{transform:scale(.98) rotate(2deg)}
  100%{transform:scale(1)}
}
.mascot-floating.mascot-floating--enter{
  animation:mascot-slide-in .6s ease-out forwards;
}

/* CTA Contact */
.cta-contact{padding:72px 0 24px}
.cta-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:start}
.ticks{display:grid;gap:8px;margin:14px 0 0}
.ticks li::before{content:"✔";color:var(--brand);margin-right:8px}
.form{display:grid;gap:12px}
.field{display:grid;gap:6px}
.field span{font-weight:600;color:var(--ink-700)}
.field input,.field select{border:1px solid var(--ink-200);border-radius:12px;padding:12px 14px;font:inherit}
.field input:focus,.field select:focus{outline:3px solid color-mix(in oklab, var(--brand) 20%, white 0%)}
.form-note{color:var(--ink-400);font-size:12px;margin:0}

.cta-contact .card{
  background:linear-gradient(135deg, rgba(255,255,255,.35), rgba(255,255,255,.12));
  border:1px solid rgba(255,255,255,.8);
  backdrop-filter:saturate(150%) blur(18px);
  -webkit-backdrop-filter:saturate(150%) blur(18px);
  border-radius:18px;
  box-shadow:0 10px 26px rgba(27,31,36,.14);
  transition:transform .2s ease, box-shadow .2s ease;
}
.cta-contact .card:hover{
  box-shadow:0 18px 40px rgba(27,31,36,.18);
  transform:translateY(-4px);
}

/* Social proof */
.social-proof{padding:72px 0 24px}
.testimonials{display:grid;grid-template-columns:.9fr 1.1fr;gap:26px;align-items:start}
.quote{font-size:20px;margin:6px 0 12px}
.quote-meta{display:flex;align-items:center;gap:12px}
.quote-meta img{width:44px;height:44px;border-radius:50%}
.stats{display:flex;gap:18px;margin-top:12px}
.stat strong{display:block;font-size:24px}
.stat span{color:var(--ink-500)}

.cards-grid.-team{grid-template-columns:repeat(3,1fr);padding:72px 0 24px}
.person{padding:0;overflow:hidden}
.person img{aspect-ratio:4/3;width:100%;object-fit:cover}
.person-body{padding:16px}
.team .card{
  background:linear-gradient(135deg, rgba(255,255,255,.35), rgba(255,255,255,.12));
  border:1px solid rgba(255,255,255,.8);
  backdrop-filter:saturate(150%) blur(18px);
  -webkit-backdrop-filter:saturate(150%) blur(18px);
  border-radius:18px;
  box-shadow:0 10px 26px rgba(27,31,36,.14);
  transition:transform .2s ease, box-shadow .2s ease;
}
.team .card:hover{
  box-shadow:0 18px 40px rgba(27,31,36,.18);
  transform:translateY(-4px);
}
.unit-contact-badge{
  display:inline-flex;
  align-items:center;
  margin-top:10px;
  padding:6px 10px;
  border-radius:999px;
  background:var(--ink-800);
  color:#fff;
  font-size:14px;
}
.unit-contact-name{
  font-weight:600;
  font-size:15px;
}
.unit-contact-line{
  display:flex;
  align-items:center;
  gap:6px;
  margin-top:6px;
  color:var(--ink-700);
}
.unit-contact-icons{display:inline-flex;gap:4px}
.unit-contact-icons a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  border-radius:999px;
  background:var(--ink-100);
  color:var(--ink-700);
}
.unit-contact-icons a i{
  font-size:26px;
}

.coverage{padding:72px 0 24px}
.coverage h3{margin:10px 0}
.coverage-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:10px}
.map-card{padding:14px}
.map-card header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.map-card .tag{background:var(--ink-100);color:var(--ink-600);padding:4px 8px;border-radius:999px;font-size:12px}
.map-card iframe{width:100%;aspect-ratio:16/10;border:0;border-radius:12px}
.map-notes{color:var(--ink-600);margin:10px 0 0;display:grid;gap:4px}

.partners{margin:56px 0 40px}
.cards-grid.-partners{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:18px}
.partner-card{
  position:relative;
  background:linear-gradient(135deg, rgba(255,255,255,.35), rgba(255,255,255,.12));
  border:1px solid rgba(255,255,255,.8);
  backdrop-filter:saturate(150%) blur(18px);
  -webkit-backdrop-filter:saturate(150%) blur(18px);
  border-radius:18px;
  box-shadow:0 10px 26px rgba(27,31,36,.14);
  transition:transform .2s ease,box-shadow .2s ease;
}
.partner-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.partner-logo{
  width:42px;
  height:42px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-700) 100%);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:18px;
  letter-spacing:.04em;
}
.partner-logo img{
  width:24px;
  height:auto;
  display:block;
}
.partner-pill{
  padding:4px 10px;
  border-radius:999px;
  background:var(--ink-100);
  color:var(--ink-700);
  font-size:12px;
  font-weight:600;
}
.partner-card h3{margin:4px 0 6px}
.partner-tagline{margin:0 0 8px;color:var(--ink-600);font-weight:500}
.partner-highlights{margin:6px 0 0;display:grid;gap:4px;color:var(--ink-600);font-size:14px}
.partner-card-footer{margin-top:12px}
.partner-cta{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-weight:600;
  color:var(--brand-700);
  text-decoration:none;
}
.partner-cta-icon{transition:transform .2s ease}
.partner-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 40px rgba(27,31,36,.18);
}
.partner-cta:focus-visible{
  outline:2px solid var(--brand-600);
  outline-offset:3px;
}
.partner-card:hover .partner-cta-icon{
  transform:translateX(3px);
}

.cards-grid.-clients{grid-template-columns:repeat(3,1fr)}
.client-card .icon{width:44px;height:44px;object-fit:contain;display:block;margin:2px auto 8px}
.client-card h3{margin:8px 0}
.client-card p{color:var(--ink-600)}

.clients .card{
  background:linear-gradient(135deg, rgba(255,255,255,.35), rgba(255,255,255,.12));
  border:1px solid rgba(255,255,255,.8);
  backdrop-filter:saturate(150%) blur(18px);
  -webkit-backdrop-filter:saturate(150%) blur(18px);
  border-radius:18px;
  box-shadow:0 10px 26px rgba(27,31,36,.14);
  transition:transform .2s ease, box-shadow .2s ease;
}
.clients .card:hover{
  box-shadow:0 18px 40px rgba(27,31,36,.18);
  transform:translateY(-4px);
}

/* Blog */
.contact-final{padding:72px 0 24px}

/* Footer */
.site-footer{background:var(--ink-800);color:#fff;padding:40px 0 24px}
.footer-cta{display:grid;grid-template-columns:1.1fr .9fr;gap:20px;margin-bottom:24px;background:#2b2f35}
.footer-cta .contact{display:grid;gap:8px}
.footer-cta .contact li span{color:#cfd6df}
.footer-bottom{display:flex;flex-wrap:wrap;align-items:center;gap:16px;justify-content:space-between;padding-top:16px}
.brand-footer .brand-mark{background:#fff;color:var(--ink-800)}
.brand-footer.brand-logo .logo-img{height:44px}
.site-footer nav a{color:#cfd6df;margin-right:14px}
.legal{color:#9fb0c3}

/* Responsive */
@media (max-width: 980px){
  .nav{margin-left:auto;position:relative}
  .menu{
    position:absolute;
    top:100%;
    right:0;
    margin-top:8px;
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
    padding:12px 16px 16px;
    background:rgba(255,255,255,.96);
    border-radius:16px;
    box-shadow:0 18px 40px rgba(27,31,36,.16);
    backdrop-filter:saturate(150%) blur(12px);
    -webkit-backdrop-filter:saturate(150%) blur(12px);
    display:none;
    min-width:200px;
  }
  .menu.menu--open{display:flex}
  .nav-toggle{display:inline-flex}
  .projects-panel{grid-template-columns:1fr}
  .carousel{padding:6px 0}
  .carousel-btn{opacity:1}
  .carousel-progress{right:12px;bottom:-20px}
  .carousel-filters{flex-wrap:wrap;overflow:visible}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .cta-grid,.testimonials,.footer-cta{grid-template-columns:1fr}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .cards-grid.-blog{grid-template-columns:1fr 1fr}
  .cards-grid.-team{grid-template-columns:1fr 1fr}
  .coverage-grid{grid-template-columns:1fr}
  .cards-grid.-clients{grid-template-columns:1fr 1fr}
  .cards-grid.-partners{grid-template-columns:repeat(2,1fr)}
  .site-header .brand-logo .logo-img{height:56px}
}

@media (max-width: 640px){
  .hero-inner{padding:72px 0 24px}
  .hero-ctas{flex-wrap:wrap}
  .cards-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .cards-grid.-blog{grid-template-columns:1fr}
  .cards-grid.-team{grid-template-columns:1fr}
  .cards-grid.-clients{grid-template-columns:1fr}
  .cards-grid.-partners{grid-template-columns:1fr}
  .page-bg-wrap{
    background:none;
  }
  body::before{
    content:"";
    position:fixed;
    inset:0;
    z-index:-1;
    background-image:url("../assets/background.svg");
    background-repeat:no-repeat;
    background-position:center top;
    background-size:cover;
  }
  .mascot-floating img{
    width:110px;
  }
}

@media (prefers-reduced-motion: reduce){
  .carousel-track,
  .media-card,
  .media-card img,
  .filter-chip,
  .carousel-btn,
  .lightbox{
    transition:none !important;
  }
  .mascot-floating img{
    animation:none !important;
  }
}
