:root{
  --bg: #000000;
  --bg2:#000000;
  --panel:#061a36;
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.68);
  --muted2: rgba(255,255,255,.52);

  --accent: #1f5ecb;
  --accent2:#08326b;

  --radius: 18px;
  --radius2: 26px;

  --shadow: 0 18px 55px rgba(0,0,0,.55);
  --shadow2: 0 10px 40px rgba(0,0,0,.45);

  --max: 1180px;
  --ease: cubic-bezier(.2,.8,.2,1);
  --ease2: cubic-bezier(.16,1,.3,1);

  --h1: clamp(2.1rem, 4vw, 3.6rem);
  --h2: clamp(1.6rem, 2.6vw, 2.4rem);
  --p: 1.03rem;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: 'Inter', sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:
    radial-gradient(1000px 520px at 18% 0%, rgba(31,94,203,.22), transparent 60%),
    radial-gradient(900px 520px at 88% 12%, rgba(8,50,107,.26), transparent 55%),
    radial-gradient(700px 420px at 55% 85%, rgba(31,94,203,.10), transparent 60%),
    linear-gradient(180deg, var(--bg2), var(--bg));
  color: var(--text);
  overflow-x:hidden;
}

h1, h2, h3, .hero__title, .hero-badge {
  font-family: 'Sora', sans-serif;
  letter-spacing: -0.02em;
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
code{font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}

/* Accessibility / UX */
:focus-visible{ outline: 2px solid rgba(31,94,203,.85); outline-offset: 3px; }
.skip{
  position:fixed; left:16px; top:16px; z-index:10000;
  padding:10px 14px; border-radius:999px;
  background: rgba(10,11,15,.86);
  border: 1px solid rgba(255,255,255,.14);
  color: #fff;
  transform: translateY(-140%);
  transition: transform .25s var(--ease);
}
.skip:focus{ transform: translateY(0); }

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

.container{
  width: min(var(--max), calc(100% - 40px));
  margin: 0 auto;
}

/* Loader cinematic */
.loader{
  position:fixed; inset:0; z-index:999;
  display:grid; place-items:center;
  background: radial-gradient(900px 420px at 30% 20%, rgba(31,94,203,.10), transparent 60%),
              linear-gradient(180deg, #07080B, #07080B);
  transition: opacity .45s var(--ease2), visibility .45s var(--ease2);
}
.loader.is-off{opacity:0; visibility:hidden}
.loader__inner{display:grid; gap:14px; place-items:center}
.loader__mark{
  width:54px; height:54px; border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.18), rgba(255,255,255,.05));
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
}
.loader__line{
  width:180px; height:10px; border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: linear-gradient(90deg, transparent, rgba(31,94,203,.26), transparent);
  background-size: 220px 10px;
  animation: shimmer 1.1s linear infinite;
  opacity:.8;
}
@keyframes shimmer{
  from{background-position:-220px 0}
  to{background-position:220px 0}
}

/* Cursor glow (desktop only) */
.cursor-glow{
  position:fixed;
  width: 520px; height: 520px;
  left:0; top:0;
  transform: translate(-50%, -50%);
  border-radius:999px;
  background: radial-gradient(circle at 30% 30%, rgba(31,94,203,.14), transparent 60%);
  filter: blur(18px);
  mix-blend-mode: screen;
  pointer-events:none;
  opacity:0;
  transition: opacity .25s var(--ease);
  z-index:2;
}
@media (hover:hover) and (pointer:fine){ .cursor-glow{opacity:.65} }
@media (prefers-reduced-motion: reduce){ .cursor-glow{display:none} }

/* Ambient */
.ambient{
  position:fixed; inset:0; pointer-events:none; z-index:-1; overflow:hidden;
  filter: blur(24px) saturate(120%);
  opacity:.9;
}
.ambient__orb{
  position:absolute; border-radius:999px;
  background: radial-gradient(circle at 30% 30%, rgba(31,94,203,.45), transparent 62%);
  mix-blend-mode: screen;
}
.ambient__orb--1{ width:520px; height:520px; left:-180px; top:120px; opacity:.45}
.ambient__orb--2{ width:640px; height:640px; right:-260px; top:-220px; opacity:.35}
.ambient__orb--3{ width:420px; height:420px; right:18%; bottom:-180px; opacity:.22}

/* Header */
.header{
  position:fixed; top:0; left:0; right:0;
  z-index:50;
  backdrop-filter: blur(10px);
  transition: background .35s var(--ease), border-color .35s var(--ease);
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(5,6,10,.55), rgba(5,6,10,.20));
}
.header.is-solid{ background: rgba(8,9,13,.82); border-bottom-color: rgba(255,255,255,.10); }
.header__inner{ height: 76px; display:flex; align-items:center; justify-content:space-between; gap:18px; }

.brand{ display:flex; align-items:center; gap:12px; min-width: 220px; }
.brand__mark{
  width:40px; height:40px; border-radius:12px;
  background: radial-gradient(circle at 25% 25%, rgba(255,255,255,.22), transparent 55%),
              linear-gradient(135deg, rgba(220,235,255,.18), rgba(255,255,255,.05));
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 12px 34px rgba(0,0,0,.45), 0 0 0 1px rgba(31,94,203,.08) inset;
  position:relative;
}
.brand__mark::after{
  content:"";
  position:absolute; inset:-1px;
  border-radius:12px;
  background: radial-gradient(280px 120px at 30% 10%, rgba(31,94,203,.30), transparent 60%);
  opacity:.9;
}
.brand__text{display:flex; flex-direction:column; line-height:1.1}
.brand__name img{width: 100px; height: 54px;}
.brand__tag{font-size:.98rem; color:rgba(255,255,255,.55); margin-top:4px}

.nav{ display:flex; align-items:center; gap:22px; }
.nav a{ font-size:.95rem; color: var(--muted); transition: color .25s var(--ease); }
.nav a:hover{color: var(--text)}
.nav a.is-active{ color: var(--text); position:relative; }
.nav a.is-active::after{
  content:"";
  position:absolute;
  left:0; right:0;
  bottom:-10px;
  height:2px;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(31,94,203,.05), rgba(31,94,203,.85), rgba(31,94,203,.05));
}

.header__cta{ display:flex; align-items:center; gap:10px; }

/* Buttons */
.btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  height:44px;
  padding:0 16px;
  border-radius: 999px;
  font-weight:600;
  font-size:.95rem;
  border: 1px solid rgba(255,255,255,.12);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
  user-select:none;
  will-change: transform;
}
.btn:active{transform: translateY(1px)}
.btn--ghost{ background: rgba(255,255,255,.04); color: var(--text); }
.btn--ghost:hover{ background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.18); }
.btn--primary{
  background: linear-gradient(135deg, rgba(8,50,107,.95), rgba(31,94,203,.92));
  border-color: rgba(31,94,203,.42);
  box-shadow: 0 14px 44px rgba(0,0,0,.58), 0 0 0 1px rgba(31,94,203,.18) inset;
}
.btn--primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 55px rgba(0,0,0,.66), 0 0 0 1px rgba(31,94,203,.22) inset, 0 0 44px rgba(31,94,203,.30);
}
.btn--big{height:54px; padding:0 22px; font-size:1rem}
.btn--block{width:100%}
.btn__shine{ position:absolute; inset:-2px; border-radius:999px; background: radial-gradient(180px 60px at 20% 10%, rgba(255,255,255,.20), transparent 60%); opacity:.9; pointer-events:none; }

/* Burger + Mobile */
.burger{
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  display:none;
  place-items:center;
  gap:6px;
}
.burger span{ width:18px; height:2px; background: rgba(255,255,255,.75); display:block; border-radius:99px; }
.mobile{ border-top: 1px solid rgba(255,255,255,.08); background: rgba(8,9,13,.92); backdrop-filter: blur(14px); }
.mobile__inner{ padding: 18px 0 22px; display:grid; gap:10px; }
.mobile__link{ padding: 12px 10px; border-radius: 14px; border: 1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.04); color: var(--text); }

/* HERO */
.hero{ position:relative; min-height: 92vh; display:grid; align-items:center; padding-top: 92px; }
.hero__bg{ position:absolute; inset:0; overflow:hidden; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; transform: scale(1.04); filter: brightness(.30) contrast(1.1) saturate(.9); }
.hero__vignette{
  position:absolute; inset:0;
  background: radial-gradient(1000px 500px at 20% 10%, rgba(31,94,203,.14), transparent 60%),
              radial-gradient(900px 500px at 85% 20%, rgba(210,230,255,.08), transparent 55%),
              linear-gradient(180deg, rgba(7,8,12,.25), rgba(7,8,12,.92));
}
.hero__grid{
  position:absolute; inset:0;
  background-image: linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 46px 46px;
  opacity:.12;
  mask-image: radial-gradient(circle at 40% 20%, black 30%, transparent 70%);
}
.hero__inner{ position:relative; display:grid; grid-template-columns: 1.2fr .8fr; gap: 40px; align-items:center; padding: 42px 0 30px; }
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  font-size:.92rem;
}
.kicker__dot{ width:8px; height:8px; border-radius:999px; background: rgba(31,94,203,.65); box-shadow: 0 0 26px rgba(31,94,203,.35); }
.hero__title{ font-size: var(--h1); letter-spacing: -0.02em; margin: 18px 0 10px; }
.hero__subtitle{ margin: 0 0 18px; color: var(--muted); font-size: clamp(1.02rem, 1.3vw, 1.12rem); line-height:1.6; max-width: 58ch; }
.hero__subtitle .subtle{ display:inline-block; margin-left:6px; color: rgba(255,255,255,.78); }
.hero__actions{ display:flex; gap:12px; flex-wrap:wrap; margin: 16px 0 18px; }

.hero__facts{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 10px;
  margin-top: 12px;
}
.fact{
  padding: 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.fact__label{color: rgba(255,255,255,.55); font-size:.86rem}
.fact__value{margin-top:6px; font-weight:700}

.note{
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.82);
  line-height:1.6;
}
.note code{color: rgba(31,94,203,.9)}

.hero__panel .panel{
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
  overflow:hidden;
  padding: 18px;
  transform: translateY(12px);
}
.panel__top{display:flex; gap:10px; flex-wrap:wrap; margin-bottom: 14px}
.panel__chip{
  border-radius:999px;
  padding: 8px 10px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.86);
  font-size:.9rem;
}
.panel__bottom{
  border-top:1px solid rgba(255,255,255,.10);
  padding-top: 14px;
}
.panel__hint{color: var(--muted); font-size:.95rem; line-height:1.6}

.scrollhint{
  position:absolute; left:50%; bottom: 18px; transform: translateX(-50%);
  width: 26px; height: 44px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.04);
  display:grid; place-items:center;
}
.scrollhint__dot{
  width:6px; height:6px; border-radius:999px;
  background: rgba(255,255,255,.70);
  animation: scrollDot 1.45s var(--ease) infinite;
}
@keyframes scrollDot{
  0%{transform: translateY(-8px); opacity:.6}
  50%{transform: translateY(8px); opacity:1}
  100%{transform: translateY(-8px); opacity:.6}
}

/* Sections */
.section{padding: 88px 0}
.section--tight{padding: 70px 0}
.section--soft{
  background: radial-gradient(900px 400px at 30% 20%, rgba(31,94,203,.08), transparent 60%),
              linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.section__head{ max-width: 760px; margin-bottom: 26px; }
.section__title{ font-size: var(--h2); margin: 0 0 10px; letter-spacing: -0.02em; }
.section__desc{ margin: 0; color: var(--muted); font-size: var(--p); line-height:1.7; }


/* Google Reviews (white cards + edge fade + marquee) */
.reviews-marquee{
  position: relative;
  overflow: hidden;
  padding: 6px 0 2px;
  border-radius: 22px;
}
/* Smooth disappearing edges */
.reviews-marquee{
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%);
}
.reviews-marquee::before,
.reviews-marquee::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width: 110px;
  z-index: 2;
  pointer-events:none;
}
.reviews-marquee::before{
  left:0;
  background: linear-gradient(90deg, rgba(10,11,16,1), rgba(10,11,16,0));
}
.reviews-marquee::after{
  right:0;
  background: linear-gradient(270deg, rgba(10,11,16,1), rgba(10,11,16,0));
}

.reviews-track{
  display:flex;
  gap: 14px;
  padding: 8px 12px 14px;
  will-change: transform;
}

/* Keep duplicated tracks on the same line (overlapped) */
.marquee-stage{
  position: relative;
}
.marquee-stage.is-static{ overflow:auto; -webkit-overflow-scrolling: touch; }
.marquee-stage.is-static > .reviews-track{ position:relative; }
.marquee-stage > .reviews-track{
  position: absolute;
  top: 0;
  left: 0;
}

.review-card{
  min-width: 340px;
  max-width: 340px;
  background: #FFFFFF;
  color: #0A0B10;
  border-radius: 18px;
  padding: 16px 16px 14px;
  box-shadow: 0 22px 70px rgba(0,0,0,.38);
  border: 1px solid rgba(0,0,0,.06);
  transform: translateZ(0);
  transition: transform .28s var(--ease), box-shadow .28s var(--ease);
}
.review-card:hover{ transform: translateY(-4px); box-shadow: 0 30px 90px rgba(0,0,0,.44); }

.review-head{display:flex; align-items:center; justify-content:space-between; gap: 12px;}
.review-person{display:flex; align-items:center; gap: 10px; min-width: 0;}
.review-avatar{
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  font-weight: 800;
  letter-spacing: .02em;
  color: #0A0B10;
  background: linear-gradient(135deg, rgba(31,94,203,.18), rgba(120,255,210,.18));
  border: 1px solid rgba(0,0,0,.08);
}
.review-name{font-weight: 800; line-height:1.1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.review-meta{font-size: 12px; color: rgba(10,11,16,.65); margin-top: 2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}

.review-badge{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap: 4px;
  flex: 0 0 auto;
}
.review-stars {
  font-size: 14px; 
  letter-spacing: 1px;
  color: #FBBC04; /* Amarelo padrão do Google */
}

.review-source{font-size: 12px; color: rgba(16, 16, 10, 0.62); font-weight: 700;}

.review-text{margin: 12px 0 0; color: rgba(10,11,16,.84); line-height: 1.55;}

@media (max-width: 720px){
  .review-card{min-width: 300px; max-width: 300px;}
  .reviews-marquee::before, .reviews-marquee::after{ width: 70px; }
}



@media (max-width: 520px){
  .review{ min-width: 300px; max-width: 300px; height: 420px; }
  .marquee{position:relative; overflow:hidden; padding: 16px 18px 18px; min-height: 320px;}
}


/* Grids */
.grid{display:grid; gap:14px}
.services{grid-template-columns: repeat(3, 1fr)}
@media (max-width: 980px){.services{grid-template-columns: repeat(2, 1fr)}}
@media (max-width: 640px){.services{grid-template-columns: 1fr}}
.diffs{grid-template-columns: repeat(2, 1fr); gap:16px}


/* Service Cards (premium) */
.service-card{
  display: flex;
  flex-direction: column;
  position: relative;
  border-radius: calc(var(--radius2) + 6px);
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.015));
  backdrop-filter: blur(10px);
  overflow: hidden;
  box-shadow: var(--shadow2);
  transform: translateZ(0);
  transition: transform .28s var(--ease), box-shadow .28s var(--ease), border-color .28s var(--ease);
  isolation: isolate;
}
.service-card__media{
  height: 168px;
  border-bottom: 1px solid rgba(255,255,255,.10);
  background: radial-gradient(1000px 260px at 20% -20%, rgba(255, 255, 255, 0.973), rgba(255, 255, 255, 0)),
              radial-gradient(700px 220px at 120% 10%, rgba(120,255,210,.14), rgba(0,0,0,0)),
              rgba(255,255,255,.02);
  overflow: hidden;
}
.service-card__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform .45s var(--ease2), filter .45s var(--ease2);
  filter: saturate(1.05) contrast(1.03);
}
.service-card__placeholder{
  width: 100%;
  height: 100%;
  background:
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,0)),
    radial-gradient(500px 180px at 25% 35%, rgba(31,94,203,.20), rgba(0,0,0,0)),
    radial-gradient(420px 160px at 80% 60%, rgba(120,255,210,.12), rgba(0,0,0,0));
}
.service-card__body{ 
  padding: 16px 16px 14px; 
  background-color: white;
  display: flex;
  flex-direction: column;
  flex-grow: 1;}
.service-card__title{ margin: 0 0 8px; letter-spacing: -.01em; color: black;}
.service-card__desc{ margin: 0; color: var(--muted); line-height: 1.65; color: black;}
.service-card__footer{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 14px;
  color: black;
  margin-top: auto; /* <-- Isso empurra o rodapé pro fundo */
}
.service-card__tags{ display:flex; gap:8px; flex-wrap:wrap; color: rgba(0, 0, 0, 0.82);}
.service-card__arrow{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.14);
  display:grid;
  place-items:center;
  color: rgba(0, 0, 0, 0.82);
  transform: translateX(0);
  transition: transform .28s var(--ease), border-color .28s var(--ease), box-shadow .28s var(--ease);
  flex: 0 0 auto;
}
.service-card__shine{
  position:absolute;
  inset:-2px;
  pointer-events:none;
  opacity:0;
  background: radial-gradient(520px 200px at 20% 0%, rgba(31,94,203,.14), rgba(0,0,0,0)),
              linear-gradient(115deg, rgba(255,255,255,0) 25%, rgba(255,255,255,.10) 45%, rgba(255,255,255,0) 65%);
  transform: translateX(-18%);
  transition: opacity .28s var(--ease), transform .55s var(--ease2);
  mix-blend-mode: screen;
  z-index: 1;
}
.service-card:hover{
  transform: translateY(-5px);
  border-color: rgba(31,94,203,.24);
  box-shadow: 0 22px 70px rgba(0,0,0,.66), 0 0 46px rgba(31,94,203,.16);
}
.service-card:hover .service-card__shine{ opacity: 1; transform: translateX(10%); }
.service-card:hover .service-card__media img{ transform: scale(1.08); }
.service-card:hover .service-card__arrow{
  transform: translateX(3px);
  border-color: rgba(31,94,203,.28);
  box-shadow: 0 10px 26px rgba(0,0,0,.45), 0 0 22px rgba(31,94,203,.16);
}
@media (prefers-reduced-motion: reduce){
  .service-card, .service-card *{ transition: none !important; }
}

/* Cards */
.card{
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
  backdrop-filter: blur(10px);
  padding: 18px 18px 16px;
  box-shadow: var(--shadow2);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.card h3{margin: 0 0 8px; letter-spacing:-.01em}
.card p{margin:0; color: var(--muted); line-height:1.65}
.card__meta{display:flex; gap:8px; margin-top: 14px; flex-wrap:wrap}
.pill{ border-radius:999px; padding: 7px 10px; border:1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.14); color: var(--muted); font-size:.88rem; }
.card:hover{
  transform: translateY(-3px);
  border-color: rgba(31,94,203,.22);
  box-shadow: 0 18px 58px rgba(0,0,0,.62), 0 0 38px rgba(31,94,203,.14);
}

/* Gallery */
.gallery{ display:grid; grid-template-columns: repeat(12, 1fr); gap: 12px; }
.shot{
  grid-column: span 4;
  border-radius: 22px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  box-shadow: var(--shadow2);
  transform: translateZ(0);
  padding:0;
}
.shot{ cursor: default; }
.shot img{
  pointer-events: none;
  user-select: none;
  width:100%; height: 280px;
  object-fit: cover;
  transition: transform .55s var(--ease2), filter .55s var(--ease2);
  filter: brightness(.92) contrast(1.05);
}
.shot:hover img{ transform: scale(1.06); filter: brightness(.98) contrast(1.08); }
.shot:focus-visible{ outline:none; box-shadow: 0 0 0 2px rgba(31,94,203,.22), 0 18px 58px rgba(0,0,0,.62); }


/* Process */
.process{ display:grid; gap: 14px; }
.step{
  display:flex; gap:16px; align-items:flex-start;
  padding: 18px;
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.step__num{
  width:54px; height:54px; border-radius: 18px;
  display:grid; place-items:center;
  border:1px solid rgba(31,94,203,.18);
  background: radial-gradient(circle at 30% 30%, rgba(31,94,203,.14), rgba(255,255,255,.03));
  color: rgba(255,255,255,.86);
  font-weight:800;
  letter-spacing:.12em;
}
.step h3{margin: 0 0 6px}
.step p{margin:0; color: var(--muted); line-height:1.7}

/* Diffs */
.diff{
  display:flex; gap:14px;
  padding: 18px;
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.diff__icon{
  width:48px; height:48px; border-radius: 18px;
  display:grid; place-items:center;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.14);
  color: rgba(31,94,203,.80);
  font-size: 18px;
}
.diff h3{margin: 0 0 6px}
.diff p{margin:0; color: var(--muted); line-height:1.7}

/* CTA */
.cta{
  padding: 88px 0;
  background: radial-gradient(900px 380px at 20% 10%, rgba(31,94,203,.12), transparent 60%),
              linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  border-top: 1px solid rgba(255,255,255,.06);
}
.cta__inner{
  border-radius: 30px;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
  padding: 28px;
  text-align:center;
}
.cta h2{ margin: 0 0 10px; font-size: clamp(1.6rem, 2.6vw, 2.3rem); letter-spacing:-.02em; }
.cta p{margin:0 0 18px; color: var(--muted); line-height:1.7}

/* Footer */
.footer{
  padding: 66px 0 36px;
  border-top: 1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.38));
}
.footer__grid{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 22px; align-items:start; }
.footer__desc{ margin: 14px 0 18px; color: var(--muted); max-width: 52ch; line-height:1.7; }
.footer__info{
  display:grid; gap:10px;
  padding: 16px;
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.footer__info .label{ display:inline-block; width: 78px; color: rgba(255,255,255,.55); }
.footer__actions{display:flex; gap:10px; flex-wrap:wrap; margin-top: 14px}
.footer__legal{ margin-top: 16px; color: rgba(255,255,255,.55); display:flex; gap:10px; flex-wrap:wrap; }
.footer__legal .dot{opacity:.6}

.map__frame{
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  overflow:hidden;
  box-shadow: var(--shadow2);
}
.map__frame iframe{
  width:100%;
  height: 380px;
  border:0;
  filter: contrast(1.08) saturate(.9) brightness(.92);
}
.map__hint{margin-top: 10px; color: rgba(255,255,255,.55); font-size:.95rem}

/* Reveal animations */
.reveal{
  opacity:0;
  transform: translateY(14px);
  transition: opacity .7s var(--ease2), transform .7s var(--ease2);
  transition-delay: var(--delay, 0ms);
}
.reveal.is-in{ opacity:1; transform: translateY(0); }

/* WhatsApp floating */
.wpp-float{
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 60;
  display:flex;
  align-items:center;
  gap:10px;
  height: 52px;
  padding: 0 14px 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(31,94,203,.22);
  background: rgba(10,11,16,.78);
  backdrop-filter: blur(14px);
  box-shadow: 0 16px 55px rgba(0,0,0,.55);
}
.wpp-float__icon{
  width:34px;height:34px;border-radius:999px;
  display:grid; place-items:center;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.9);
}
.wpp-float__text{font-weight:700; letter-spacing:.02em}
.wpp-float__pulse{
  position:absolute; inset:-6px;
  border-radius:999px;
  border:1px solid rgba(31,94,203,.16);
  animation: pulse 1.9s var(--ease) infinite;
  pointer-events:none;
}
@keyframes pulse{
  0%{transform: scale(.98); opacity:.5}
  50%{transform: scale(1.04); opacity:.20}
  100%{transform: scale(.98); opacity:.5}
}




/* Mobile sticky CTA bar */
.mobilebar{
  position:fixed;
  left: 10px;
  right: 10px;
  bottom: 10px;
  z-index: 80;
  display:none;
  gap:10px;
  padding: 10px;
  border-radius: 20px;
  border:1px solid rgba(31,94,203,.18);
  background: rgba(10,11,16,.78);
  backdrop-filter: blur(14px);
  box-shadow: 0 18px 55px rgba(0,0,0,.55);
}
.mobilebar__btn{
  flex:1;
  height: 46px;
  display:grid;
  place-items:center;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  font-weight: 700;
}
.mobilebar__btn--primary{
  background: linear-gradient(135deg, rgba(8,50,107,.95), rgba(31,94,203,.92));
  border-color: rgba(31,94,203,.22);
}

/* Performance hint */
.section, .social, .cta, .footer{ content-visibility: auto; contain-intrinsic-size: 900px; }

/* Responsive */
@media (max-width: 980px){
  .hero__inner{grid-template-columns: 1fr; gap: 18px}
  .services{grid-template-columns: repeat(2, 1fr)}
  .footer__grid{grid-template-columns: 1fr; }
  .shot{grid-column: span 6}
  .hero__facts{grid-template-columns: 1fr; }
}
@media (max-width: 720px){
  .nav{display:none}
  .burger{display:grid}
  .section{padding: 70px 0}
  .services{grid-template-columns: 1fr}
  .diffs{grid-template-columns: 1fr}
  .shot{grid-column: span 12}
  .shot img{height: 240px}
  .review{min-width: 300px}
  .wpp-float{display:none}
  .mobilebar{display:flex}
  body{padding-bottom: 84px;}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .reveal{transition:none}
  .scrollhint__dot{animation:none}
  .wpp-float__pulse{animation:none}
  .loader__line{animation:none}
}



/* === Hero right card (premium) === */
.hero-card{
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 28px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.hero-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  border-color: rgba(255,255,255,0.14);
}
.hero-badge{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-size: 12px;
  opacity: .75;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.hero-card h3{
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 22px;
  line-height: 1.2;
}
.hero-card p{
  margin: 0;
  opacity: .82;
  line-height: 1.55;
}
.hero-features{
  margin-top: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  opacity: .9;
}
.hero-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  margin-top: 18px;
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: .01em;
  color: #FFFFFF;
  background: linear-gradient(135deg, rgba(8,50,107,.96), rgba(31,94,203,.96));
  border: 1px solid rgba(31,94,203,.45);
  box-shadow: 0 16px 46px rgba(0,0,0,.55), 0 0 0 1px rgba(31,94,203,.18) inset, 0 0 36px rgba(31,94,203,.18);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), filter .25s var(--ease);
}
.hero-cta:hover{
  transform: translateY(-1px);
  filter: brightness(1.06);
  box-shadow: 0 22px 60px rgba(0,0,0,.62), 0 0 0 1px rgba(31,94,203,.22) inset, 0 0 54px rgba(31,94,203,.28);
}
.hero-cta:focus-visible{
  outline: 2px solid rgba(255,255,255,.35);
  outline-offset: 4px;
  border-radius: 10px;
}

/* Arrow is now a link */
.service-card__arrow{
  text-decoration: none;
  cursor: pointer;
}
.service-card__arrow:focus-visible{
  outline: 2px solid rgba(255,255,255,.35);
  outline-offset: 3px;
}



/* =========================
   TECHNIC GARAGE THEME v2
   (different vibe from ALXIS)
   ========================= */

:root{
  --radius: 12px;
  --radius2: 16px;
  --shadow: 0 16px 44px rgba(0,0,0,.62);
  --shadow2: 0 10px 26px rgba(0,0,0,.52);
}

/* Dark "industrial" background texture */
body{
  background:
    linear-gradient(180deg, #000000 0%, #030814 55%, #000000 100%),
    radial-gradient(900px 520px at 70% 10%, rgba(31,94,203,.18), transparent 60%),
    radial-gradient(700px 420px at 12% 55%, rgba(8,50,107,.22), transparent 62%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.035) 0 1px, transparent 1px 140px);
}

/* De-pill components (more sharp / technical) */
.pill, .chip, .badge, .hero-badge{
  border-radius: 10px !important;
}

/* Buttons: more "motorsport" / angular, less pill */
.btn{
  border-radius: 10px;
  border: 1px solid rgba(31,94,203,.35);
  background: rgba(255,255,255,.03);
  box-shadow: none;
  letter-spacing: .02em;
}

.btn--ghost{
  background: rgba(255,255,255,.03);
  border-color: rgba(255,255,255,.10);
}

.btn--ghost:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(31,94,203,.35);
}

.btn--primary{
  background: transparent;
  border-color: rgba(31,94,203,.55);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.btn--primary::before{
  content:"";
  position:absolute;
  inset:-2px;
  z-index:-1;
  background: linear-gradient(135deg, rgba(31,94,203,.95), rgba(8,50,107,.95));
  transform: translateX(-55%);
  transition: transform .45s var(--ease2);
  opacity:.9;
}

.btn--primary{ color:#fff; }
.btn--primary:hover::before{ transform: translateX(0%); }
.btn--primary:hover{
  box-shadow: 0 14px 34px rgba(0,0,0,.62), 0 0 0 1px rgba(31,94,203,.25) inset;
  transform: translateY(-1px);
}

/* HERO right card: technical, accent spine */
.hero-card{
  backdrop-filter: none;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 44px rgba(0,0,0,.55);
  border-radius: 16px;
}

.hero-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 22px 60px rgba(0,0,0,.65);
}

.hero-card h3{
  letter-spacing: .01em;
}

/* Highlight "Solicitar avaliação" as a true CTA button */
.hero-cta{
  border-radius: 12px;
  width: 100%;
  justify-content: center;
  padding: 13px 16px;
  background: linear-gradient(135deg, rgba(31,94,203,1), rgba(8,50,107,1));
  box-shadow: 0 18px 50px rgba(0,0,0,.62), 0 0 0 1px rgba(255,255,255,.10) inset;
  position: relative;
  overflow: hidden;
}

.hero-cta::after{
  content:"";
  position:absolute;
  top:-60%;
  left:-30%;
  width: 60%;
  height: 220%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.22), transparent);
  transform: rotate(18deg) translateX(-140%);
  transition: transform .7s var(--ease2);
}

.hero-cta:hover::after{
  transform: rotate(18deg) translateX(220%);
}

.hero-cta:hover{
  transform: translateY(-2px);
  filter: saturate(1.08);
  box-shadow: 0 22px 64px rgba(0,0,0,.68), 0 0 44px rgba(31,94,203,.22);
}

/* Service cards: add top stripe and reduce "glass" feel */
.service-card{
  backdrop-filter: none;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 14px;
  position: relative;
  overflow: hidden;
}

.service-card::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height: 3px;
  background: linear-gradient(90deg, rgba(31,94,203,.0), rgba(31,94,203,.95), rgba(8,50,107,.0));
  opacity:.9;
}

.service-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 22px 56px rgba(0,0,0,.62);
  border-color: rgba(31,94,203,.22);
}

/* Arrow CTA inside service cards: squared + accent */
.card-arrow{
  border-radius: 10px;
  border: 1px solid rgba(31,94,203,.30);
  background: rgba(0,0,0,.25);
}

.service-card:hover .card-arrow{
  background: rgba(31,94,203,.14);
  border-color: rgba(31,94,203,.48);
}

/* Subtle section separators (more "UI") */
.section, section{
  scroll-margin-top: 90px;
}


/* === NEW PREMIUM BUTTON EFFECT (Glow + Live Border) === */
.btn,
.hero-cta {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow:
    0 10px 28px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.08);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.btn::before,
.hero-cta::before {
  content:"";
  position:absolute;
  inset:-2px;
  border-radius: inherit;
  background: radial-gradient(120px 80px at var(--mx, 50%) var(--my, 50%),
    rgba(255,255,255,.22),
    rgba(255,255,255,0) 60%);
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.btn::after,
.hero-cta::after {
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: inherit;
  background: radial-gradient(220px 140px at 50% 120%,
    rgba(0,120,255,.45),
    rgba(0,120,255,0) 60%);
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.btn:hover,
.hero-cta:hover {
  transform: translateY(-1px);
  box-shadow:
    0 14px 34px rgba(0,0,0,.45),
    0 0 0 1px rgba(0,120,255,.25),
    0 0 28px rgba(0,120,255,.22),
    inset 0 1px 0 rgba(255,255,255,.10);
  filter: saturate(1.05);
}
.btn:hover::before,
.hero-cta:hover::before,
.btn:hover::after,
.hero-cta:hover::after {
  opacity: 1;
}
.btn:active,
.hero-cta:active {
  transform: translateY(0px) scale(.99);
}
.brand-logo{
  display:block;
  height:18px;
  width:auto;
  object-fit:contain;
  margin-bottom:2px;
  filter: drop-shadow(0 6px 18px rgba(0,0,0,.35));
}


/* Buttons: keep a premium blue gradient (no hard overrides) */
:root{
  --accentStrong: #1f5ecb;
  --accentStrong2: #08326b;
}

.btn--primary,
.hero-cta{
  background: linear-gradient(135deg, rgba(8,50,107,.96), rgba(31,94,203,.94));
  border-color: rgba(31,94,203,.42);
  color:#fff;
}

.btn--primary:hover,
.hero-cta:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 55px rgba(0,0,0,.66), 0 0 0 1px rgba(31,94,203,.22) inset, 0 0 44px rgba(31,94,203,.30);
}


/* Service card image area */
.service-media{
  position: relative;
  height: 170px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  overflow: hidden;
}
.service-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
  filter: saturate(1.05) contrast(1.05);
}


/* === Header brand: logo replaces entire left block === */
/* === Header brand: logo replaces entire left block (ONLY in header) === */
.header .brand{ min-width: 0 !important; gap: 0 !important; }
.header .brand__mark,
.header .brand__text,
.header .brand__name,
.header .brand__tag,
.header .brand-logo{
  display:none !important;
}
.header .brand__logo{
  display:block;
  height:64px;
  width:auto;
  object-fit:contain;
  max-width:300px;
  filter: drop-shadow(0 10px 28px rgba(0,0,0,.45));
}

/* Keep CTA aligned and prevent wrapping (fix "Como chegar" quebrando) */
.header__cta{ flex-wrap: nowrap; flex-shrink: 0; }
.header__cta .btn{ white-space: nowrap; }
.btn--ghost{ min-width: 128px; }

/* Ensure service card media shows the image (replacing blue placeholder) */
.service-card__media{
  height: 170px;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.service-card__media img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.service-card__placeholder{ display:none !important; }

/* MOBILE ACTIONS */
.mobile-actions{
  display:none;
  align-items:center;
  gap:10px;
}
.mobile-btn{
  width:42px;
  height:42px;
  border-radius:50%;
  background:rgba(255,255,255,0.08);
  display:flex;
  align-items:center;
  justify-content:center;
  border:none;
  cursor:pointer;
}
.mobile-btn img{
  width:22px;
  height:22px;
}
@media(max-width:768px){
  .desktop-actions{
    display:none;
  }
  .mobile-actions{
    display:flex;
  }
}


/* ===== MOBILE HEADER FIX ALXIS ===== */
.mobile-actions{
  display:none;
  align-items:center;
  gap:10px;
}
.mobile-btn{
  width:42px;
  height:42px;
  border-radius:50%;
  background:rgba(255,255,255,0.08);
  display:flex;
  align-items:center;
  justify-content:center;
  border:none;
  cursor:pointer;
}
.mobile-btn img{
  width:22px;
  height:22px;
}

@media(max-width:768px){

  .desktop-actions{
    display:none !important;
  }

  .nav{
    display:none;
  }

  .mobile-actions{
    display:flex;
    margin-left:auto;
  }
}


/* Burger white icon fix */
.mobile-btn.burger{
  color:#ffffff;
  font-size:20px;
  line-height:1;
}


/* ===== MOBILE MENU OVERLAY (FIXED) ===== */
.mobile{
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(10, 11, 15, 0.86);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  overflow: auto;
  padding-top: calc(16px + env(safe-area-inset-top, 0px));
}

.mobile__inner{
  padding-top: 72px; /* space for header feel */
}

html.no-scroll, body.no-scroll{
  overflow: hidden;
}


/* ===== MOBILE CLOSE BUTTON ===== */
.mobile__close{
  position:absolute;
  top:18px;
  right:18px;
  width:42px;
  height:42px;
  border-radius:50%;
  border:none;
  background:rgba(255,255,255,0.08);
  color:#fff;
  font-size:22px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:10000;
}


/* =========================
   Services (Dark Blue) + Gradient Transitions
   ========================= */
.section--services{
  position: relative;
  overflow: hidden;
  background: black;
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 0;
}
.section--services::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-1px;
  height:140px;
  background: black;
  pointer-events:none;
  z-index:0;
}
.section--services > .container{ position: relative; z-index:1; }

/* =========================
   PPF Highlight (Light Section)
   ========================= */
.section--ppf{
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #FFFFFF 0%, #FBFCFF 60%, #FFFFFF 100%);
  color: #0A0B0F;
}
.section--ppf::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-1px;
  height:140px;
  background: rgb(255, 255, 255);
  pointer-events:none;
  z-index:0;
}
.section--ppf > .container{ position: relative; z-index:1; }

.ppf{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 34px;
  align-items: center;
}
.ppf__eyebrow{
  display:inline-flex;
  gap:8px;
  align-items:center;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(10,11,15,.66);
}
.ppf__title{
  margin: 10px 0 10px;
  font-size: clamp(28px, 3.2vw, 44px);
  letter-spacing: -0.02em;
  color: #0A0B0F;
}
.ppf__desc{
  margin: 0 0 16px;
  color: rgba(10,11,15,.74);
  font-size: 16px;
  line-height: 1.65;
  max-width: 60ch;
}
.ppf__list{
  margin: 0 0 22px;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}
.ppf__list li{
  position: relative;
  padding-left: 16px;
  color: rgba(10,11,15,.78);
}
.ppf__list li::before{
  content:"";
  position:absolute;
  left:0; top:.72em;
  width:6px; height:6px;
  border-radius:999px;
  background: linear-gradient(180deg, rgba(7,27,64,1), rgba(18,70,170,1));
  transform: translateY(-50%);
}
.ppf__actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items:center;
}

.ppf__media{
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(7,27,64,.12), rgba(7,27,64,0));
  border: 1px solid rgba(10,11,15,.10);
  box-shadow: 0 22px 70px rgba(10,11,15,.18);
}
.ppf__img{
  display:block;
  width:100%;
  height: 420px;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.05);
}

/* Buttons for light section */
.btn--dark{
  background: linear-gradient(135deg, #071B40, #1246AA);
  color: #fff;
  border: 1px solid rgba(7,27,64,.18);
}
.btn--dark:hover{ transform: translateY(-1px); }
.btn--ghost-dark{
  background: linear-gradient(180deg, rgba(10,11,15,.06), rgba(10,11,15,.02));
  color: rgba(10,11,15,.92);
  border: 1px solid rgba(10,11,15,.14);
}
.btn--ghost-dark:hover{ transform: translateY(-1px); }

/* Mobile */
@media (max-width: 860px){
  .ppf{ grid-template-columns: 1fr; }
  .ppf__img{ height: 320px; }
}

/* =========================
   Polish Highlight (Alternative Layout)
   ========================= */
.section--polish{ overflow: hidden; }
.polish{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: start;
}
.polish__content{ padding-right: 6px; }

.polish__levels{
  position: relative;
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(10,11,15,.10);
  background:
    linear-gradient(180deg, rgba(7,27,64,.10), rgba(255,255,255,0) 70%),
    #FFFFFF;
  box-shadow: 0 26px 70px rgba(10,11,15,.14);
  overflow: hidden;
}
.polish__levels::before{
  content: "";
  position: absolute;
  inset: -2px;
  background: radial-gradient(60% 60% at 65% 15%, rgba(18,70,170,.16), rgba(18,70,170,0) 60%),
              radial-gradient(65% 65% at 10% 90%, rgba(7,27,64,.14), rgba(7,27,64,0) 62%);
  pointer-events: none;
}
.polish__levels > *{ position: relative; z-index: 1; }

.polish-card{
  background: linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,1));
  border: 1px solid rgba(10,11,15,.10);
  border-radius: 18px;
  padding: 16px 16px 14px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.polish-card:hover{
  transform: translateY(-2px);
  border-color: rgba(18,70,170,.28);
  box-shadow: 0 18px 45px rgba(10,11,15,.14);
}
.polish-card__top{
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 6px;
}
.polish-card__num{
  font-weight: 800;
  letter-spacing: .08em;
  font-size: 12px;
  padding: 6px 9px;
  border-radius: 999px;
  color: #071B40;
  background: linear-gradient(135deg, rgba(7,27,64,.10), rgba(18,70,170,.10));
  border: 1px solid rgba(7,27,64,.14);
}
.polish-card__title{
  margin: 0;
  font-size: 18px;
  letter-spacing: -0.01em;
  color: #0A0B0F;
}
.polish-card__desc{
  margin: 0 0 10px;
  color: rgba(10,11,15,.72);
  line-height: 1.6;
  font-size: 14.5px;
}
.polish-card__meta{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.polish-chip{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: rgba(10,11,15,.86);
  background: linear-gradient(180deg, rgba(10,11,15,.06), rgba(10,11,15,.02));
  border: 1px solid rgba(10,11,15,.10);
}

@media (max-width: 980px){
  .polish{ grid-template-columns: 1fr; }
  .polish__levels{ padding: 14px; }
}

/* Muda a cor do texto das tags (Proteção, Durabilidade) para preto */
.service-card__tags .pill {
  color: #000000;
  font-weight: 500; /* Opcional: deixa a fonte um pouquinho mais grossa para ler melhor */
}

.polish {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: stretch;
}

.polish__content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.polish__image {
  margin-top: 30px;
  width: 100%;
  height: 280px; /* controla altura do retângulo */
  overflow: hidden;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}

.polish__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}


/* ================================
   POLIMENTO — FIX MOBILE (ANTI-BUG)
   Corrige cascade onde .polish base estava sobrescrevendo o breakpoint.
================================ */
@media (max-width: 980px){
  .polish{
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    align-items: start !important;
  }
  .polish__content{
    gap: 18px !important;
  }
  .ppf__actions{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 12px !important;
  }
  .ppf__actions .btn{
    width: 100% !important;
    justify-content: center !important;
  }
  .polish__image{
    height: 220px !important;
    margin-top: 18px !important;
    border-radius: 18px !important;
  }
  .polish__levels{
    padding: 14px !important;
    border-radius: 22px !important;
  }
  .polish-card{
    padding: 14px 14px 12px !important;
    border-radius: 18px !important;
  }
}

/* Ajuste fino para telas bem pequenas */
@media (max-width: 520px){
  .polish__image{ height: 200px !important; }
  .polish-card__title{ font-size: 17px !important; }
  .polish-card__desc{ font-size: 14px !important; }
}

