/* 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;
}

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%)}

.projects-panel{display:grid;grid-template-columns:1.1fr 1fr;align-items:center;gap:24px;margin-top:40px}
.projects-panel .panel-copy h3{font-size:32px;margin:6px 0 10px}
.projects-panel .panel-copy p{color:#cfd6df}

/* Carousel */
.carousel{position:relative;overflow:hidden}
.carousel-track{display:flex;gap:16px;transform:translateX(0);transition:transform .35s ease}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:#fff;border:1px solid var(--ink-200);width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-size:22px;color:var(--ink-700);box-shadow:var(--shadow)}
.carousel-btn:hover{background:var(--bg)}
.carousel-btn.prev{left:8px}
.carousel-btn.next{right:8px}

.media-card{min-width:320px;max-width:360px;background:#111;border-radius:16px;overflow:hidden;border:1px solid #333}
.media-card img{aspect-ratio:16/10;width:100%;object-fit:cover}
.media-card figcaption{padding:12px 14px;color:#cfd6df}
.carousel .media-card figcaption{color:#000}

.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:none;
}
.mascot-floating img{
  width:140px;
  height:auto;
}

@keyframes mascot-slide-in{
  0%{transform:translateX(-60px);opacity:0}
  100%{transform:translateX(0);opacity: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}
  .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;
  }
}
