/* ============================================================
   WebRota V2 — Premium Design (Sankhya-inspired)
   Dark corporate, video hero, glassmorphism, micro-interactions
   ============================================================ */

/* --- Design Tokens ----------------------------------------- */
:root {
  --wr-primary: #f58634;
  --wr-primary-hover: #e0751f;
  --wr-primary-light: #fff4eb;
  --wr-primary-100: #fde8d3;
  --wr-accent: #1a7a4c;
  --wr-accent-light: #e6f5ee;
  --wr-bg: #f4f5f7;
  --wr-surface: #ffffff;
  --wr-border: #e2e4e9;
  --wr-border-light: #eff0f3;
  --wr-text: #1C1F26;
  --wr-text-secondary: #4B5563;
  --wr-muted: #8b8fa3;
  --wr-dark: #111827;
  --wr-dark-soft: #1F2937;
  --wr-dark-surface: #1F2937;
  --wr-dark-card: #1F2937;
  --wr-success: #22c55e;
  --wr-warning: #f59e0b;
  --wr-danger: #ef4444;
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-pill: 999px;
  --shadow-sm: 0 1px 3px rgba(17,24,39,.04), 0 1px 2px rgba(17,24,39,.06);
  --shadow-md: 0 4px 16px rgba(17,24,39,.06), 0 1px 3px rgba(17,24,39,.04);
  --shadow-lg: 0 12px 40px rgba(17,24,39,.08), 0 4px 12px rgba(17,24,39,.04);
  --shadow-xl: 0 20px 60px rgba(17,24,39,.1), 0 8px 20px rgba(17,24,39,.06);
  --shadow-card: 0 2px 8px rgba(17,24,39,.04);
  --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px;
  --space-5: 24px; --space-6: 32px; --space-7: 48px; --space-8: 64px;
  --space-9: 80px; --space-10: 96px;
  --font-body: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --font-heading: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
}

/* --- Reset / Base ------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { font-family: var(--font-body); font-weight: 400; color: var(--wr-text); background-color: #fff; line-height: 1.7; overflow-x: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--wr-primary); text-decoration: none; transition: color .2s; }
a:hover { color: var(--wr-primary-hover); }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-heading); font-weight: 600; line-height: 1.2; color: var(--wr-text); }
h1 { font-size: clamp(2.2rem, 5vw, 3.2rem); font-weight: 600; }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.75rem); font-weight: 600; }
h3 { font-size: clamp(1.15rem, 2vw, 1.45rem); font-weight: 600; }
h4 { font-size: 1.1rem; font-weight: 500; }
button, input, select, textarea, label, nav, footer { font-family: var(--font-body); }
p { margin-bottom: 1rem; }
ul, ol { padding-left: 1.25rem; }

/* --- Container --------------------------------------------- */
.container { width: 100%; max-width: 1440px; margin: 0 auto; padding: 0 var(--space-5); }
.container--md { max-width: 1200px; }
.container--sm { max-width: 720px; }

/* --- Section ----------------------------------------------- */
.section { padding: var(--space-10) 0; }
.section--dark { background: var(--wr-dark-card); color: #fff; }
.section--dark h2, .section--dark h3, .section--dark h4 { color: #fff; }
.section--dark p, .section--dark li { color: #cbd5e1; }
.section--gradient { background: linear-gradient(180deg, var(--wr-dark-card) 0%, var(--wr-dark) 100%); color: #fff; }
.section--gradient h2, .section--gradient h3, .section--gradient h4 { color: #fff; }
.section--gradient p, .section--gradient li { color: #cbd5e1; }
.section--surface { background: var(--wr-surface); }
.section--alt { background: var(--wr-bg); }
.section--white { background: #fff; }

/* Section badge */
.section-badge {
  display: inline-block; font-size: .68rem; font-weight: 600;
  letter-spacing: .02em; text-transform: none; color: var(--wr-primary);
  background: var(--wr-primary-light); border: 1px solid var(--wr-primary-100);
  padding: 5px 14px; border-radius: var(--radius-pill); margin-bottom: var(--space-4);
}
.section--dark .section-badge,
.section--gradient .section-badge {
  background: rgba(245,134,52,.1); border-color: rgba(245,134,52,.18);
}
.section-header { max-width: 640px; margin-bottom: var(--space-7); }
.section-header.centered { text-align: center; margin-left: auto; margin-right: auto; }
.section-header p { color: var(--wr-text-secondary); font-size: 1.05rem; margin-top: var(--space-3); }

/* ============================================================
   HEADER / NAVBAR — White fixed bar
   ============================================================ */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 60;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(15,23,42,.06);
  box-shadow: 0 8px 28px rgba(15,23,42,.06);
}
.site-header .container {
  max-width: 1440px;
  padding: 0 var(--space-6);
}

.header-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
  background: transparent;
  padding: 0 4px;
  gap: 2.5rem;
}

.site-header .logo img { height: 22px; width: auto; transition: opacity .25s; }

/* Nav links */
.nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  list-style: none;
  padding: 0; margin: 0;
}
.nav-links > li { position: relative; height: 48px; display: flex; align-items: center; }
.nav-links a {
  font-size: .875rem;
  font-weight: 500;
  color: var(--wr-text-secondary);
  transition: color .25s;
  text-decoration: none;
  position: relative;
  padding: 6px 10px;
  border-radius: 999px;
}
.nav-links a:not(.btn):hover,
.nav-links a.active { color: var(--wr-text); }
.nav-links a:not(.btn):hover { background: rgba(15,23,42,.04); }

/* Underline animation on hover (Sankhya style) */
.nav-links > li > a:not(.btn)::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 0;
  height: 2px;
  background: var(--wr-primary);
  transition: width .3s ease;
}
.nav-links > li:hover > a:not(.btn)::after { width: 100%; }
.site-header .nav-links .btn--primary:hover {
  box-shadow: 0 12px 28px rgba(245,134,52,.28);
  border-color: rgba(255,255,255,.18);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-size: .875rem; font-weight: 500;
  padding: 12px 24px; border-radius: var(--radius-pill);
  border: 1.5px solid transparent; cursor: pointer;
  transition: all .25s cubic-bezier(.4,0,.2,1);
  text-decoration: none; line-height: 1.4; position: relative;
  text-transform: none; letter-spacing: 0;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0) scale(.98); }
.btn--primary {
  background: linear-gradient(135deg, #f58d3a 0%, #e37424 100%);
  color: #fff;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 10px 24px rgba(245,134,52,.22), inset 0 1px 0 rgba(255,255,255,.25);
  text-transform: none;
  letter-spacing: .01em;
}
.btn--primary:hover {
  background: linear-gradient(135deg, #f79a52 0%, #e77a2b 100%);
  border-color: rgba(255,255,255,.3);
  color: #fff;
  box-shadow: 0 12px 28px rgba(245,134,52,.28), inset 0 1px 0 rgba(255,255,255,.3);
  filter: none;
}
.btn--ghost {
  background: transparent; color: var(--wr-text); border-color: var(--wr-border);
}
.btn--ghost:hover { border-color: var(--wr-text); color: var(--wr-text); background: rgba(17,24,39,.02); }
.btn--ghost-light {
  background: transparent; color: var(--wr-text);
  border-color: var(--wr-border);
}
.btn--ghost-light:hover { border-color: var(--wr-text); color: var(--wr-text); background: rgba(17,24,39,.03); }
.btn--outline-primary {
  background: #fff;
  color: var(--wr-primary);
  border-color: var(--wr-primary);
}
.btn--outline-primary:hover {
  background: var(--wr-primary-light);
  color: var(--wr-primary);
  border-color: var(--wr-primary-hover);
}
/* Ghost-light in dark contexts (CTA, footer, etc.) */
.cta-section .btn--ghost-light,
.section--dark .btn--ghost-light,
.section--gradient .btn--ghost-light {
  background: rgba(255,255,255,.06); color: rgba(255,255,255,.8);
  border-color: rgba(255,255,255,.15);
}
.cta-section .btn--ghost-light:hover,
.section--dark .btn--ghost-light:hover,
.section--gradient .btn--ghost-light:hover {
  border-color: rgba(255,255,255,.4); color: #fff; background: rgba(255,255,255,.1);
}
.btn--sm { padding: 7px 16px; font-size: .8125rem; }
.btn--dark { background: var(--wr-dark); color: #fff; border-color: var(--wr-dark); }
.btn--dark:hover { background: #2a2d38; border-color: #2a2d38; color: #fff; }
.btn--white { background: #fff; color: var(--wr-text); border-color: rgba(255,255,255,.8); box-shadow: 0 2px 8px rgba(17,24,39,.08); }
.btn--white:hover { background: #f8f9fa; color: var(--wr-text); }
.btn--full { width: 100%; justify-content: center; }

/* Mobile toggle */
.mobile-toggle {
  display: none; background: none; border: none; cursor: pointer; padding: 8px;
}
.mobile-toggle span {
  display: block; width: 24px; height: 2px; background: var(--wr-text);
  margin: 5px 0; border-radius: 2px; transition: all .3s;
}

@media (max-width: 768px) {
  .mobile-toggle { display: block; }
  html.menu-open,
  body.menu-open {
    height: 100dvh;
    overflow: hidden;
    overscroll-behavior: none;
    touch-action: none;
  }
  .nav-links {
    display: flex; position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    flex-direction: column; background: rgba(255,255,255,.97);
    backdrop-filter: blur(24px);
    padding: calc(84px + env(safe-area-inset-top, 0px)) var(--space-6) calc(var(--space-6) + env(safe-area-inset-bottom, 0px));
    gap: 0;
    overflow: hidden;
    overscroll-behavior: contain;
    height: 100dvh;
    z-index: 110;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateX(100%);
    transition: transform .28s ease, opacity .2s ease;
  }
  .nav-links.open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(0);
  }
  .nav-links > li {
    width: 100%;
    height: auto;
    border-bottom: 1px solid rgba(148, 163, 184, .22);
  }
  .nav-links > li:last-child { border-bottom: 0; }
  .nav-links a {
    width: 100%;
    padding: 14px 0;
    font-size: 1rem;
    color: var(--wr-text-secondary);
  }
  .nav-links .btn {
    margin-top: var(--space-3);
    justify-content: center;
  }
  .nav-links > li > a:not(.btn)::after { display: none; }
  .header-bar { height: 68px; }
}

/* ============================================================
   HERO — Boxed video
   ============================================================ */
.hero {
  padding-top: calc(56px + var(--space-5));
  padding-bottom: var(--space-7);
  background: #fff;
}

/* Boxed container for the video */
.hero__boxed {
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 16 / 7;
  background:
    radial-gradient(circle at 18% 22%, rgba(245,134,52,.18) 0%, transparent 28%),
    radial-gradient(circle at 78% 32%, rgba(26,122,76,.18) 0%, transparent 26%),
    linear-gradient(135deg, #111827 0%, #1f2937 55%, #111827 100%);
}

/* Video background */
.hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0;
  transition: opacity .8s ease;
}
.hero__video.is-ready {
  opacity: .42;
}

/* Dark overlay over video */
.hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(17,24,39,.64);
  z-index: 1;
}

/* Hero background image fallback */
.hero__bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(15,23,42,.12) 0%, rgba(15,23,42,.46) 100%),
    radial-gradient(circle at 20% 20%, rgba(245,134,52,.18) 0%, transparent 24%),
    radial-gradient(circle at 80% 30%, rgba(255,255,255,.08) 0%, transparent 18%),
    radial-gradient(circle at 60% 78%, rgba(26,122,76,.12) 0%, transparent 20%);
  z-index: 0;
}

/* Reusable glass card */
.glass-card {
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 24px rgba(17,24,39,.12);
}

/* Hero content — anchored bottom-left */
.hero__content {
  position: absolute;
  z-index: 10;
  left: var(--space-6);
  bottom: var(--space-6);
}
/* Card — title + description */
.hero__card-main {
  max-width: 560px;
  padding: var(--space-5);
}
.hero__eyebrow {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .02em;
  color: rgba(255,255,255,.72);
  margin-bottom: var(--space-3);
}
.hero__card-main h1 {
  color: #fff;
  font-size: clamp(1.25rem, 2.5vw, 1.6rem);
  font-weight: 600;
  text-transform: none;
  line-height: 1.2;
  letter-spacing: -.01em;
  margin-bottom: var(--space-3);
}
.hero__card-main h1 strong {
  color: var(--wr-primary);
  font-weight: 600;
}
.hero__text {
  font-size: .875rem;
  color: rgba(255,255,255,.65);
  line-height: 1.6;
  margin: 0;
}
.hero__text strong { color: var(--wr-primary); font-weight: 600; }
.hero__actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-5);
}
.hero__actions .btn--ghost-light,
.contact-location-actions .btn--ghost-light {
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.88);
  border-color: rgba(255,255,255,.16);
}
.hero__actions .btn--ghost-light:hover,
.contact-location-actions .btn--ghost-light:hover {
  background: rgba(255,255,255,.12);
  color: #fff;
  border-color: rgba(255,255,255,.28);
}
.hero__proof {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
  padding: 0;
  margin: var(--space-5) 0 0;
}
.hero__proof li {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: var(--space-3);
  border-top: 1px solid rgba(255,255,255,.12);
}
.hero__proof strong {
  color: #fff;
  font-size: .95rem;
  font-weight: 600;
}
.hero__proof span {
  color: rgba(255,255,255,.62);
  font-size: .74rem;
  line-height: 1.45;
}

@media (max-width: 768px) {
  .hero { padding-top: calc(68px + var(--space-4)); padding-bottom: var(--space-5); }
  .hero__boxed { min-height: 520px; aspect-ratio: auto; margin: 0 var(--space-4); border-radius: var(--radius-lg); }
  .hero__content { position: absolute; left: var(--space-4); bottom: var(--space-4); right: var(--space-4); }
  .hero__card-main { max-width: 100%; padding: var(--space-4); }
  .hero__eyebrow { font-size: .68rem; }
  .hero__card-main h1 { font-size: 1.15rem; text-transform: none; }
  .hero__text { font-size: .8rem; }
  .hero__actions { flex-direction: column; }
  .hero__actions .btn { width: 100%; justify-content: center; }
  .hero__proof { display: none; }
}

/* ============================================================
   LOGO MARQUEE — infinite scroll (Sankhya style)
   ============================================================ */
.logo-marquee {
  padding: var(--space-7) 0;
  background: var(--wr-bg);
  overflow: hidden;
}
.logo-marquee .container { overflow: hidden; }
.logo-marquee__title {
  text-align: center;
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, 3rem);
  font-weight: 600;
  text-transform: none;
  color: var(--wr-text);
  max-width: 900px;
  margin: 0 auto var(--space-7);
  padding: 0;
  line-height: 1.15;
}
.logo-marquee__track {
  display: flex;
  width: max-content;
  animation: marquee-scroll var(--marquee-duration, 45s) linear infinite;
  will-change: transform;
  opacity: 1;
  overflow: hidden;
  cursor: grab;
  user-select: none;
  touch-action: pan-y;
}
.logo-marquee__group {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-7);
  padding: 0 var(--space-6);
  flex: 0 0 auto;
  width: max-content;
}
.logo-marquee__track { position: relative; }
.logo-marquee__track.is-dragging { cursor: grabbing; }
.logo-marquee__group img {
  width: auto;
  max-width: clamp(120px, 10vw, 154px);
  height: clamp(54px, 5vw, 72px);
  object-fit: contain;
  object-position: center;
  opacity: .66;
  filter: grayscale(80%);
  border-radius: 12px;
  padding: 4px 6px;
  background: transparent;
  border: 0;
  box-shadow: none;
  transition: opacity .3s, filter .3s, transform .3s;
  user-select: none;
  -webkit-user-drag: none;
}
.logo-marquee__group img:hover {
  opacity: 1;
  filter: grayscale(0%);
  transform: translateY(-1px) scale(1.03);
}
@media (max-width: 768px) {
  .logo-marquee__group { gap: var(--space-5); padding: 0 var(--space-4); }
  .logo-marquee__group img {
    width: auto;
    max-width: clamp(96px, 28vw, 128px);
    height: clamp(44px, 13vw, 58px);
    border-radius: 10px;
    padding: 2px 4px;
  }
}
.logo-marquee--partners {
  padding: 0;
  background: transparent;
  --marquee-duration: 70s;
}
.logo-marquee--partners .logo-marquee__group {
  gap: var(--space-5);
  padding: 0 var(--space-4);
}
.logo-marquee--partners .logo-marquee__group img {
  width: auto;
  max-width: clamp(106px, 8.8vw, 140px);
  height: clamp(48px, 4.4vw, 62px);
  opacity: .62;
  filter: grayscale(82%);
  border-radius: 12px;
}
.logo-marquee--partners .logo-marquee__group img:hover {
  opacity: .98;
  filter: grayscale(0%);
  transform: translateY(-1px) scale(1.03);
}
@media (max-width: 768px) {
  .logo-marquee--partners .logo-marquee__group img {
    width: auto;
    max-width: clamp(90px, 24vw, 118px);
    height: clamp(40px, 10vw, 52px);
    border-radius: 10px;
  }
}
/* Center spotlight glow — logos in center appear brighter */
.logo-marquee__glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(ellipse 30% 100% at 50% 50%, rgba(245,134,52,.12) 0%, transparent 70%);
  z-index: 2;
  mix-blend-mode: screen;
}
@keyframes marquee-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .logo-marquee__track { animation: none; }
}

/* ============================================================
   SOLUTION CARDS — Sankhya "dobra-2" style (expand on hover)
   ============================================================ */
.solutions-section {
  width: 100%;
  background: #fff;
  padding: var(--space-9) 0;
}
.solutions-section__intro {
  max-width: 820px;
  margin-bottom: var(--space-7);
}
.solutions-grid {
  width: 100%;
  display: flex;
  align-items: stretch;
  justify-content: flex-start;
  gap: var(--space-4);
}
.products-carousel {
  position: relative;
  width: 100%;
  padding: 0;
}
.products-viewport {
  overflow: hidden;
}
.products-track {
  display: flex;
  gap: var(--space-4);
  will-change: transform;
  width: max-content;
}
.products-track.is-animating {
  transition: transform .45s cubic-bezier(.25,.1,.25,1);
}
.products-track .sol-card-wrap {
  flex: 0 0 var(--card-w, 300px);
  height: 520px;
  transition: none;
}
.products-track .sol-card-wrap:hover {
  flex-basis: var(--card-w, 300px);
}
.products-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(15,23,42,.12);
  background: #fff;
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 2;
  transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}
.products-nav:hover { transform: translateY(-50%) scale(1.03); box-shadow: var(--shadow-md); }
.products-nav.prev { left: -20px; }
.products-nav.next { right: -20px; }
.products-nav svg {
  width: 16px; height: 16px;
  stroke: var(--wr-text);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Each solution card wrapper */
.sol-card-wrap {
  flex: 0 0 340px;
  height: 520px;
  transition: flex-basis .5s cubic-bezier(.25,.1,.25,1);
}
.sol-card-wrap:hover {
  flex-basis: 470px;
}
.sol-card {
  width: 100%;
  height: 100%;
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: var(--wr-dark);
  transition: box-shadow .5s cubic-bezier(.25,.1,.25,1);
  text-decoration: none;
}
.sol-card:hover {
  box-shadow: 0 25px 70px -10px rgba(17,24,39,.8);
}

/* Default state — dark with bg image and title */
.sol-card__default {
  position: absolute;
  inset: 0;
  transition: opacity .5s ease-in-out;
  background-size: cover;
  background-position: center;
}
.sol-card--rastreamento .sol-card__default,
.sol-card--monitriip .sol-card__default {
  background-image:
    linear-gradient(180deg, rgba(10,12,20,.35) 0%, rgba(10,12,20,.88) 100%),
    url('../img/products/rastreamento/main.webp');
}
.sol-card--fleet .sol-card__default,
.sol-card--videotelemetria .sol-card__default {
  background-image:
    linear-gradient(180deg, rgba(10,12,20,.35) 0%, rgba(10,12,20,.88) 100%),
    url('../img/products/fleet/main.webp');
}
.sol-card--routing .sol-card__default {
  background-image:
    linear-gradient(180deg, rgba(10,12,20,.35) 0%, rgba(10,12,20,.88) 100%),
    url('../img/products/routing/main.webp');
}
.sol-card--checklist .sol-card__default,
.sol-card--fines .sol-card__default {
  background-image:
    linear-gradient(180deg, rgba(10,12,20,.35) 0%, rgba(10,12,20,.88) 100%),
    url('../img/products/checklist/main.webp');
}
.sol-card:hover .sol-card__default { opacity: 0; }

.sol-card__default .sol-card__bar {
  width: 28px;
  height: 3px;
  background: var(--wr-primary);
  margin-bottom: 20px;
}
.sol-card__default .sol-card__title-wrap {
  position: absolute;
  top: 75px;
  left: 40px;
  z-index: 4;
}
.sol-card__default h3 {
  max-width: 200px;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.35;
  word-wrap: break-word;
}

/* Hover state — white card with slide-in text */
.sol-card__hover {
  position: absolute;
  inset: 0;
  z-index: 5;
  background: #fff;
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  opacity: 0;
  transition: opacity .5s ease-in-out;
  padding: 24px 40px 32px;
  overflow: hidden;
}
.sol-card:hover .sol-card__hover { opacity: 1; }

.sol-card__hover-text {
  opacity: 0;
  transform: translateX(-40px);
}
.sol-card:hover .sol-card__hover-text {
  animation: slideIn .6s cubic-bezier(.25,.1,.25,1) forwards;
}
.sol-card__hover-title {
  color: var(--wr-text);
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.35;
  padding-top: 16px;
  padding-bottom: 8px;
  margin: 0;
}
.sol-card__hover p {
  color: var(--wr-text-secondary);
  font-size: .875rem;
  line-height: 1.5;
}
.sol-card__hover ul {
  list-style: none;
  padding: 0;
  margin-top: var(--space-3);
}
.sol-card__hover ul li {
  font-size: .82rem;
  color: var(--wr-text-secondary);
  padding: 3px 0 3px 18px;
  position: relative;
}
.sol-card__hover ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 10px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--wr-primary);
}

/* Arrow icon top-right of hover card */
.sol-card__arrow {
  position: absolute;
  top: 28px;
  right: 20px;
  width: 40px; height: 40px;
  background: var(--wr-primary);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sol-card__arrow svg {
  width: 16px; height: 16px;
  stroke: #fff; fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* SVG icon in default state */
.sol-card__icon {
  position: absolute;
  bottom: 40px;
  left: 40px;
  z-index: 4;
  width: 48px; height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.06);
  border-radius: var(--radius-sm);
}
.sol-card__icon svg {
  width: 24px; height: 24px;
  stroke: var(--wr-primary);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Border overlay for default state */
.sol-card__border {
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-md);
  pointer-events: none;
  z-index: 3;
}

@keyframes slideIn {
  0% { opacity: 0; transform: translateX(-40px); }
  60% { opacity: 1; transform: translateX(5px); }
  100% { opacity: 1; transform: translateX(0); }
}

@media (max-width: 768px) {
  .products-carousel { padding: 0; }
  .products-viewport {
    overflow: visible;
    overflow-y: visible;
  }
  .products-track {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-4);
    padding-right: 0;
    transform: none !important;
  }
  .products-track .sol-card-wrap {
    flex: 1 1 auto;
    width: 100%;
    max-width: none;
    height: auto;
    scroll-snap-align: none;
  }
  .products-track .sol-card-wrap:hover { flex-basis: auto; }
  .products-nav { display: none; }
  .sol-card-wrap { height: auto; margin: 0; }
  .sol-card {
    height: auto;
    min-height: 320px;
    overflow: hidden;
    position: relative;
  }
  .sol-card__default {
    display: block;
    opacity: 1 !important;
  }
  .sol-card__default .sol-card__title-wrap,
  .sol-card__default .sol-card__icon,
  .sol-card__default .sol-card__border {
    display: none;
  }
  .sol-card__hover {
    opacity: 1;
    position: relative;
    padding: 24px;
    overflow: visible;
    min-height: 320px;
    background: linear-gradient(180deg, rgba(15, 23, 42, .28) 0%, rgba(15, 23, 42, .86) 100%);
    color: #fff;
  }
  .sol-card__hover-title { color: #fff; }
  .sol-card__hover p { color: rgba(255, 255, 255, .86); }
  .sol-card__hover ul li { color: rgba(255, 255, 255, .86); }
  .sol-card__hover-text { opacity: 1; transform: none; animation: none !important; }
  .stagger-item,
  .fade-in {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
}
@media (min-width: 769px) and (max-width: 1024px) {
  .products-carousel { padding: 0; }
  .products-nav.prev { left: -14px; }
  .products-nav.next { right: -14px; }
}

/* ============================================================
   SEGMENTS
   ============================================================ */
.segment-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}
.segment-card {
  background: #fff;
  border: 1px solid rgba(226,232,240,.6);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-5);
  text-align: center;
  transition: transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s, border-color .35s, background .35s;
  position: relative;
  overflow: hidden;
  cursor: default;
  box-shadow: 0 1px 3px rgba(17,24,39,.03);
}
.segment-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: var(--wr-primary);
  transform: scaleX(0);
  transition: transform .4s cubic-bezier(.4,0,.2,1);
}
.segment-card:hover::after { transform: scaleX(1); }
.segment-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-5px);
  border-color: rgba(245,134,52,.15);
  background: #fff;
}
.segment-card .segment-icon {
  width: 52px; height: 52px;
  margin: 0 auto var(--space-4);
  display: flex; align-items: center; justify-content: center;
  background: rgba(245,134,52,.1);
  border-radius: var(--radius-md);
  transition: transform .3s, background .3s;
}
.segment-card:hover .segment-icon { transform: scale(1.1); background: rgba(245,134,52,.18); }
.segment-card .segment-icon svg {
  width: 24px; height: 24px;
  stroke: var(--wr-primary); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.segment-card h4 { margin-bottom: var(--space-2); color: var(--wr-text); }
.segment-card p { font-size: .85rem; color: var(--wr-text-secondary); margin: 0; }

@media (max-width: 768px) { .segment-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .segment-grid { grid-template-columns: 1fr; } }

/* ============================================================
   CASES SECTION — video background with glass card (Sankhya style)
   ============================================================ */
.cases-section {
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: var(--radius-lg);
  max-width: 1440px;
  margin: 0 auto;
}
.cases-section__video {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
.cases-section__overlay {
  position: absolute;
  inset: 0;
  background: rgba(17,24,39,.68);
  z-index: 1;
}
.cases-section__content {
  position: relative;
  z-index: 10;
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-7);
  padding: 60px var(--space-7);
  color: #fff;
  text-align: center;
}
.cases-section__left {
  max-width: 680px;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  align-items: center;
}
.cases-section__left .cases-tag {
  color: var(--wr-primary);
  font-size: 1rem;
  font-weight: 600;
}
.cases-section__left h2 {
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 600;
  text-transform: none;
  line-height: 1.15;
  color: #fff;
}
.cases-section__left p { font-size: 1rem; color: rgba(255,255,255,.8); max-width: 556px; }

/* Glass card on the right */
/* Glass card styles kept for potential reuse but not used in cases */
.cases-glass-card { display: none; }

@media (max-width: 992px) {
  .cases-section__content { padding: var(--space-7) var(--space-5); }
  .cases-section__left { max-width: 100%; }
}

/* ============================================================
   METRICS — corporate cards with hover
   ============================================================ */
.metrics-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
.metric-card {
  background: #fff;
  border: 1px solid var(--wr-border-light);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  transition: transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s, border-color .35s, background .35s;
  cursor: default;
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.metric-card::after {
  content: '';
  position: absolute;
  left: 0; bottom: 0;
  width: 100%; height: 3px;
  background: var(--wr-primary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .4s cubic-bezier(.4,0,.2,1);
}
.metric-card:hover::after { transform: scaleX(1); }
.metric-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(245,134,52,.15);
  background: #fff;
}
.metric-card .metric-value {
  font-family: var(--font-heading);
  font-size: 2.2rem;
  font-weight: 600;
  color: var(--wr-text);
  line-height: 1.1;
  transition: color .3s, font-size .4s ease;
}
.metric-card:hover .metric-value { color: var(--wr-primary); }
.metric-card .metric-label {
  font-size: .68rem; font-weight: 600;
  letter-spacing: 0; text-transform: none;
  color: var(--wr-muted);
  margin-top: var(--space-2); margin-bottom: var(--space-3);
  transition: font-size .4s ease, letter-spacing .4s ease;
}
.metric-card p { font-size: .82rem; color: var(--wr-text-secondary); margin: 0; transition: font-size .4s ease; }

/* Light variant for white sections */
.section--white .metric-card,
.section--alt .metric-card,
.section--surface .metric-card {
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(255,255,255,.45);
  backdrop-filter: saturate(150%) blur(20px);
  box-shadow: 0 2px 8px rgba(17,24,39,.04), inset 0 1px 0 rgba(255,255,255,.5);
}
.section--white .metric-card .metric-value,
.section--alt .metric-card .metric-value,
.section--surface .metric-card .metric-value { color: var(--wr-text); }
.section--white .metric-card .metric-label,
.section--alt .metric-card .metric-label,
.section--surface .metric-card .metric-label { color: var(--wr-muted); }
.section--white .metric-card p,
.section--alt .metric-card p,
.section--surface .metric-card p { color: var(--wr-text-secondary); }
.section--white .metric-card:hover,
.section--alt .metric-card:hover,
.section--surface .metric-card:hover {
  box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,.6);
  border-color: rgba(245,134,52,.15);
  background: rgba(255,255,255,.7);
}
.metric-card.is-active {
  border-color: rgba(245,134,52,.25);
  box-shadow: 0 18px 40px rgba(15,23,42,.1), 0 6px 16px rgba(245,134,52,.12);
  background: #fff;
  animation: metricPulse 2s ease-in-out;
}
.metric-card.is-active::after { transform: scaleX(1); }
.metric-card.is-active .metric-value {
  color: var(--wr-primary);
  font-size: clamp(2.8rem, 4.6vw, 4.4rem);
}
.metric-card.is-active .metric-label {
  font-size: .82rem;
  letter-spacing: 0;
}
.metric-card.is-active p { font-size: .95rem; }
.metrics-grid.is-cycling .metric-card:not(.is-active) .metric-value { font-size: 1.7rem; }
.metrics-grid.is-cycling .metric-card:not(.is-active) .metric-label { font-size: .62rem; letter-spacing: 0; }
.metrics-grid.is-cycling .metric-card:not(.is-active) p { font-size: .76rem; }
@keyframes metricPulse {
  0% { transform: translateY(0); }
  35% { transform: translateY(-6px); }
  70% { transform: translateY(-3px); }
  100% { transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .metric-card.is-active { animation: none; }
}

/* ============================================================
   SPLIT (two columns)
   ============================================================ */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  align-items: center;
}
#contato .split { align-items: end; }
@media (max-width: 768px) { .split { grid-template-columns: 1fr; } }

/* ============================================================
   MONITORAMENTO
   ============================================================ */
.monitoramento-media {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  isolation: isolate;
  background: #0b1222;
  box-shadow: var(--shadow-xl);
  min-height: 320px;
  border: 1px solid var(--wr-border-light);
  transition: border-color .35s, transform .35s, box-shadow .35s;
}
.monitoramento-media::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(160deg, rgba(8,15,34,.42) 0%, rgba(8,15,34,.64) 100%);
  opacity: .72;
  transition: opacity .35s;
}
.monitoramento-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(.78) saturate(.92) contrast(1.02);
  transform: scale(1.01);
  transition: transform .45s cubic-bezier(.4,0,.2,1), filter .45s cubic-bezier(.4,0,.2,1);
}
.monitoramento-media:hover {
  border-color: rgba(245,134,52,.22);
  transform: translateY(-3px);
  box-shadow: 0 20px 48px rgba(15,23,42,.22), 0 8px 22px rgba(245,134,52,.16);
}
.monitoramento-media:hover::after {
  opacity: .56;
}
.monitoramento-media:hover img {
  transform: scale(1.045);
  filter: brightness(.85) saturate(1) contrast(1.03);
}
.monitoramento-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: center;
  margin-top: var(--space-5);
}
.monitoramento-note {
  font-size: .82rem;
  color: var(--wr-muted);
  margin-top: var(--space-3);
  margin-bottom: 0;
}
@media (max-width: 768px) {
  .monitoramento-media { min-height: 220px; }
  .monitoramento-actions .btn { width: 100%; justify-content: center; }
}
@media (prefers-reduced-motion: reduce) {
  .monitoramento-media,
  .monitoramento-media::after,
  .monitoramento-media img {
    transition: none;
  }
  .monitoramento-media:hover {
    transform: none;
  }
  .monitoramento-media:hover img {
    transform: none;
  }
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonial-card {
  background: #fff;
  border: 1px solid var(--wr-border-light);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: border-color .35s, transform .35s, box-shadow .35s;
  box-shadow: var(--shadow-sm);
}
.testimonial-card:hover {
  border-color: rgba(245,134,52,.15);
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
}
.testimonial-card .quote {
  font-size: .93rem; color: var(--wr-text-secondary);
  line-height: 1.75; margin-bottom: var(--space-5); font-style: italic;
}
.testimonial-card .author { display: flex; align-items: center; gap: var(--space-3); }
.testimonial-card .avatar {
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--wr-primary);
  display: flex; align-items: center; justify-content: center;
  font-size: .75rem; font-weight: 600; color: #fff;
  transition: transform .3s;
}
.testimonial-card:hover .avatar { transform: scale(1.06); }
.testimonial-card .author-name { font-weight: 600; color: var(--wr-text); font-size: .875rem; }
.testimonial-card .author-role { font-size: .75rem; color: var(--wr-muted); }

/* ============================================================
   LOGOS GRID
   ============================================================ */
.logos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: var(--space-5);
  align-items: center;
  justify-items: center;
}
.logos-grid img {
  max-height: 55px; width: auto;
  opacity: .5; filter: grayscale(100%);
  transition: opacity .3s, filter .3s, transform .3s;
}
.logos-grid img:hover {
  opacity: 1; filter: grayscale(0%); transform: scale(1.06);
}

/* Partners showcase — bigger logos with center glow */
.partners-showcase {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--space-7);
  max-width: 900px;
  margin: 0 auto;
  padding: var(--space-6) 0;
}
.partners-showcase img {
  max-height: 80px;
  width: auto;
  opacity: .45;
  filter: grayscale(100%);
  transition: opacity .4s, filter .4s, transform .4s;
}
.partners-showcase img:hover {
  opacity: 1;
  filter: grayscale(0%);
  transform: scale(1.15);
}
.partners-showcase__glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(ellipse 40% 80% at 50% 50%, rgba(245,134,52,.1) 0%, transparent 70%);
  z-index: -1;
}

/* ============================================================
   CTA SECTION
   ============================================================ */
.cta-section {
  background: linear-gradient(135deg, var(--wr-dark) 0%, var(--wr-dark-card) 100%);
  border-radius: var(--radius-xl);
  padding: var(--space-9) var(--space-8);
  text-align: center;
  margin: 0 var(--space-5);
  position: relative;
  overflow: hidden;
}
.cta-section::before {
  content: '';
  position: absolute;
  top: -40%; left: 50%;
  transform: translateX(-50%);
  width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(245,134,52,.05) 0%, transparent 60%);
  pointer-events: none;
}
.cta-section h2 { color: #fff; margin-bottom: var(--space-3); position: relative; }
.cta-section p { color: rgba(255,255,255,.5); max-width: 560px; margin: 0 auto var(--space-6); position: relative; }
.cta-actions { display: flex; justify-content: center; gap: var(--space-3); flex-wrap: wrap; position: relative; }

/* Aggressive CTA variant */
.cta-section--aggressive {
  background: linear-gradient(145deg, var(--wr-dark) 0%, var(--wr-dark-soft) 100%);
  padding: var(--space-10) var(--space-8);
  border: 1px solid rgba(245,134,52,.15);
}
.cta-section--aggressive::before {
  width: 900px; height: 900px;
  background: radial-gradient(circle, rgba(245,134,52,.12) 0%, rgba(245,134,52,.03) 40%, transparent 65%);
}
.cta-section--aggressive::after {
  content: '';
  position: absolute;
  bottom: -20%; left: 50%;
  transform: translateX(-50%);
  width: 600px; height: 400px;
  background: radial-gradient(circle, rgba(245,134,52,.08) 0%, transparent 60%);
  pointer-events: none;
}
.cta-section--aggressive h2 {
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.1;
  margin-bottom: var(--space-4);
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
  letter-spacing: -0.01em;
  text-wrap: balance;
}
.cta-section--aggressive h2 strong { color: var(--wr-primary); }
.cta-subtitle {
  color: rgba(255,255,255,.6) !important;
  font-size: 1.1rem;
  max-width: 620px !important;
}
.cta-subtitle strong { color: var(--wr-primary); }

/* Subtle gradient shimmer */
.cta-shimmer {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    transparent 0%,
    transparent 40%,
    rgba(245,134,52,.06) 50%,
    transparent 60%,
    transparent 100%
  );
  background-size: 200% 100%;
  animation: ctaShimmer 6s ease-in-out infinite;
  pointer-events: none;
}
@keyframes ctaShimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* CTA urgency stats row */
.cta-urgency {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(16px, 4vw, 32px);
  margin-bottom: clamp(20px, 4vw, 40px);
  position: relative;
}
.cta-urgency__item { text-align: center; }
.cta-urgency__num {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 600;
  color: var(--wr-primary);
  line-height: 1;
  display: block;
  margin-bottom: var(--space-1);
}
.cta-urgency__label {
  font-size: .75rem;
  color: rgba(255,255,255,.4);
  text-transform: none;
  letter-spacing: 0;
  font-weight: 500;
}
.cta-urgency__divider {
  width: 1px; height: 40px;
  background: rgba(255,255,255,.1);
}
.btn--lg { padding: 16px 36px; font-size: .95rem; }
@media (max-width: 576px) {
  .cta-urgency { flex-direction: column; gap: var(--space-4); }
  .cta-urgency__divider { width: 40px; height: 1px; }
}

/* ============================================================
   BLOG CARDS
   ============================================================ */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 992px) { .cards-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 576px) { .cards-grid { grid-template-columns: 1fr; } }

.card {
  background: #fff;
  border: 1px solid var(--wr-border-light);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s, border-color .35s, background .35s;
  box-shadow: var(--shadow-sm);
}
.card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-5px);
  border-color: rgba(245,134,52,.15);
  background: #fff;
}
.card h3 { margin-bottom: var(--space-3); color: var(--wr-text); }
.card p { color: var(--wr-text-secondary); font-size: .9rem; line-height: 1.65; }
.card .card-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: .85rem; font-weight: 600; color: var(--wr-primary);
  margin-top: var(--space-4); transition: gap .25s;
}
.card .card-link:hover { gap: 12px; }

/* White card variant */
.section--white .card,
.section--alt .card,
.section--surface .card {
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(255,255,255,.45);
  backdrop-filter: saturate(150%) blur(20px);
  box-shadow: 0 2px 8px rgba(17,24,39,.04), inset 0 1px 0 rgba(255,255,255,.5);
}
.section--white .card h3,
.section--alt .card h3,
.section--surface .card h3 { color: var(--wr-text); }
.section--white .card p,
.section--alt .card p,
.section--surface .card p { color: var(--wr-text-secondary); }
.section--white .card:hover,
.section--alt .card:hover,
.section--surface .card:hover {
  box-shadow: var(--shadow-lg); border-color: rgba(245,134,52,.15);
  background: rgba(255,255,255,.7);
}

.card-img-top {
  margin: calc(-1 * var(--space-6)); margin-bottom: var(--space-5);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  overflow: hidden; background: #e8ecf0; aspect-ratio: 16/10;
  display: flex; align-items: center; justify-content: center;
}
.card-img-top img { width: 100%; height: 100%; object-fit: cover; }

.blog-card .card-meta {
  display: flex; align-items: center; gap: var(--space-3);
  font-size: .75rem; color: var(--wr-muted); margin-bottom: var(--space-3);
}
.blog-card .card-meta .tag {
  background: rgba(245,134,52,.1); color: var(--wr-primary);
  padding: 2px 10px; border-radius: var(--radius-pill); font-weight: 600;
}

/* ============================================================
   STEPS (vertical)
   ============================================================ */
.steps-vertical { counter-reset: step; }
.step-item {
  display: flex; gap: var(--space-5);
  margin-bottom: var(--space-6); align-items: flex-start;
}
.step-item::before {
  counter-increment: step; content: counter(step);
  flex-shrink: 0; width: 40px; height: 40px; border-radius: 50%;
  background: var(--wr-primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem; font-weight: 600;
  box-shadow: 0 4px 14px rgba(245,134,52,.25);
  transition: transform .3s;
}
.step-item:hover::before { transform: scale(1.08); }
.step-item h4 { margin-bottom: var(--space-2); }
.step-item p { font-size: .9rem; color: var(--wr-text-secondary); }

/* ============================================================
   SCROLL ANIMATIONS (fade in on scroll)
   ============================================================ */
.fade-in {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .65s ease-out, transform .65s ease-out;
}
.fade-in.is-visible { opacity: 1; transform: translateY(0); }
.fade-in-delay-1 { transition-delay: .1s; }
.fade-in-delay-2 { transition-delay: .2s; }
.fade-in-delay-3 { transition-delay: .3s; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background: var(--wr-dark);
  border-top: 1px solid rgba(255,255,255,.06);
  padding: var(--space-9) 0 var(--space-6);
  color: #fff;
}
.footer-top {
  display: grid;
  grid-template-columns: 1.5fr repeat(4, 1fr);
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}
.footer-brand p { font-size: .85rem; color: rgba(255,255,255,.35); margin-top: var(--space-3); max-width: 280px; }
.footer-brand .footer-logo { display: inline-flex; align-items: center; }
.footer-brand .footer-logo-mark {
  width: 130px; height: 26px; display: none;
  background: linear-gradient(135deg, #ffffff 0%, #e2e8f0 55%, #ffffff 100%);
  -webkit-mask: url('../img/logo.svg') no-repeat center / contain;
  mask: url('../img/logo.svg') no-repeat center / contain;
  filter: drop-shadow(0 6px 16px rgba(15,23,42,.35));
  opacity: .7;
}
.footer-brand .footer-logo-fallback {
  height: 30px; width: auto;
  filter: brightness(0) invert(1);
  opacity: .7;
}
@supports ((-webkit-mask: url("")) or (mask: url(""))) {
  .footer-brand .footer-logo-mark { display: inline-block; }
  .footer-brand .footer-logo-fallback { display: none; }
}
.footer-socials { display: flex; gap: var(--space-3); margin-top: var(--space-4); }
.footer-socials a {
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.5);
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem; transition: all .25s; text-decoration: none;
}
.footer-socials a:hover {
  background: var(--wr-primary); border-color: var(--wr-primary);
  color: #fff; transform: translateY(-2px);
}
.footer-col h4 {
  font-size: .8rem; font-weight: 600; text-transform: none;
  letter-spacing: 0; color: rgba(255,255,255,.5); margin-bottom: var(--space-4);
}
.footer-col ul { list-style: none; padding: 0; }
.footer-col li { margin-bottom: var(--space-2); }
.footer-col a {
  font-size: .85rem; color: rgba(255,255,255,.35);
  transition: color .25s, padding-left .25s; text-decoration: none;
}
.footer-col a:hover { color: var(--wr-primary); padding-left: 4px; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: var(--space-5);
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: var(--space-3);
  font-size: .78rem; color: rgba(255,255,255,.25);
}
.footer-bottom a { color: rgba(255,255,255,.25); margin-left: var(--space-4); }
.footer-bottom a:hover { color: var(--wr-primary); }

@media (max-width: 768px) {
  .footer-top { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 480px) { .footer-top { grid-template-columns: 1fr; } }

/* ============================================================
   FORMS
   ============================================================ */
.form-group { margin-bottom: var(--space-4); }
.form-label { display: block; font-size: .78rem; font-weight: 500; margin-bottom: var(--space-2); color: var(--wr-text); }
.form-input, .form-select, .form-textarea {
  width: 100%; padding: 11px 14px; font-size: .9rem; font-family: var(--font-body);
  border: 1.5px solid var(--wr-border); border-radius: var(--radius-sm);
  background: var(--wr-surface); color: var(--wr-text);
  transition: border-color .25s, box-shadow .25s; outline: none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--wr-primary); box-shadow: 0 0 0 3px rgba(245,134,52,.1);
}
.form-input.error, .form-textarea.error, .form-select.error { border-color: var(--wr-danger); }
.form-error { font-size: .75rem; color: var(--wr-danger); margin-top: 4px; display: none; }
.form-error.show { display: block; }
.form-textarea { resize: vertical; min-height: 100px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
@media (max-width: 576px) { .form-row { grid-template-columns: 1fr; } }
.hp-field { display: none !important; }

.form-card {
  background: #fff;
  border: 1px solid var(--wr-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-lg);
}
.form-success { display: none; text-align: center; padding: var(--space-6); }
.form-success.show { display: block; }
.form-success .checkmark {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--wr-accent-light); color: var(--wr-accent);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; margin: 0 auto var(--space-4);
}
.form-feedback {
  display: none;
  text-align: center;
  padding: var(--space-6);
  margin-top: var(--space-4);
  border-radius: var(--radius-lg);
  border: 1px solid var(--wr-border);
  background: var(--wr-surface);
  box-shadow: var(--shadow-lg);
}
.form-feedback.show { display: block; animation: feedbackIn .45s ease; }
.form-feedback__icon {
  width: 56px; height: 56px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; margin: 0 auto var(--space-4);
}
.form-feedback__title { font-size: 1.1rem; margin-bottom: var(--space-2); }
.form-feedback__text { color: var(--wr-text-secondary); margin-bottom: var(--space-4); }
.form-feedback--success .form-feedback__icon { background: var(--wr-accent-light); color: var(--wr-accent); }
.form-feedback--error { border-color: rgba(239,68,68,.25); background: #fff5f5; }
.form-feedback--error .form-feedback__icon { background: rgba(239,68,68,.12); color: var(--wr-danger); }
.form-feedback--error.show { animation: feedbackIn .45s ease, feedbackShake .4s ease .2s; }
.form-feedback__actions { display: flex; justify-content: center; gap: var(--space-3); flex-wrap: wrap; }
.form-checkbox {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: .82rem;
  color: var(--wr-text-secondary);
  line-height: 1.5;
}
.form-checkbox input[type="checkbox"] {
  margin-top: 2px;
  accent-color: var(--wr-primary);
}

/* ============================================================
   MODAL
   ============================================================ */
.wr-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-5);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .25s ease, visibility .25s ease;
}
.wr-modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.wr-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .6);
  backdrop-filter: blur(4px);
}
.wr-modal__panel {
  position: relative;
  width: min(640px, 100%);
  max-height: min(90dvh, 780px);
  overflow: auto;
  border-radius: var(--radius-xl);
  background: #fff;
  border: 1px solid var(--wr-border);
  box-shadow: var(--shadow-xl);
  transform: translateY(18px) scale(.98);
  transition: transform .25s ease;
}
.wr-modal.is-open .wr-modal__panel { transform: translateY(0) scale(1); }
.wr-modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--wr-border);
  background: #fff;
  color: var(--wr-text-secondary);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
}
.wr-modal__close:hover { color: var(--wr-text); border-color: var(--wr-text-secondary); }
.wr-modal__header {
  padding: var(--space-6) var(--space-6) var(--space-4);
  border-bottom: 1px solid var(--wr-border-light);
}
.wr-modal__header h3 {
  font-size: clamp(1.35rem, 3vw, 1.75rem);
  margin-bottom: var(--space-2);
}
.wr-modal__header p {
  margin: 0;
  color: var(--wr-text-secondary);
  font-size: .95rem;
}
.wr-modal__body {
  padding: var(--space-5) var(--space-6) var(--space-6);
}
body.modal-open,
html.modal-open {
  overflow: hidden;
}
@media (max-width: 768px) {
  .wr-modal { padding: var(--space-3); }
  .wr-modal__header { padding: var(--space-5) var(--space-5) var(--space-4); }
  .wr-modal__body { padding: var(--space-4) var(--space-5) var(--space-5); }
}
@media (prefers-reduced-motion: reduce) {
  .wr-modal, .wr-modal__panel { transition: none; }
}

@keyframes feedbackIn {
  0% { opacity: 0; transform: translateY(6px) scale(.98); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes feedbackShake {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-6px); }
  40%, 80% { transform: translateX(6px); }
}


.contact-location-card {
  position: relative;
  overflow: hidden;
  padding: clamp(24px, 4vw, 36px);
  border-radius: var(--radius-lg);
  background: var(--panel-bg);
  border: 1px solid rgba(148, 163, 184, .12);
  box-shadow: var(--shadow-lg);
  color: #fff;
}
.contact-location-card::before {
  content: '';
  position: absolute;
  right: -12%;
  bottom: -18%;
  width: 260px;
  height: 260px;
  background: radial-gradient(circle, rgba(245,134,52,.18) 0%, rgba(245,134,52,0) 72%);
  pointer-events: none;
}
.contact-location-card > * {
  position: relative;
  z-index: 1;
}
.contact-location-card h3 {
  color: #fff;
  font-size: clamp(1.2rem, 2.6vw, 1.55rem);
  margin-bottom: var(--space-3);
}
.contact-location-card p {
  color: rgba(255,255,255,.72);
  margin-bottom: 0;
}
.contact-location-card__eyebrow {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .02em;
  color: rgba(255,255,255,.74) !important;
  margin-bottom: var(--space-3) !important;
}
.contact-location-list {
  list-style: none;
  padding: 0;
  margin: var(--space-5) 0 0;
  display: grid;
  gap: var(--space-3);
}
.contact-location-list li {
  position: relative;
  padding-left: 22px;
  color: rgba(255,255,255,.86);
  font-size: .88rem;
  line-height: 1.55;
}
.contact-location-list li::before {
  content: '\2713';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--wr-primary);
  font-weight: 700;
}
.contact-location-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-6);
}
.contact-location-actions .btn {
  flex: 1 1 220px;
  justify-content: center;
}

/* ============================================================
   UTILITIES
   ============================================================ */
.text-center { text-align: center; }
.text-muted { color: var(--wr-muted); }
.mt-1 { margin-top: var(--space-1); } .mt-2 { margin-top: var(--space-2); }
.mt-3 { margin-top: var(--space-3); } .mt-4 { margin-top: var(--space-4); }
.mt-5 { margin-top: var(--space-5); } .mt-6 { margin-top: var(--space-6); }
.mt-7 { margin-top: var(--space-7); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-5 { margin-bottom: var(--space-5); }
.mb-6 { margin-bottom: var(--space-6); }

/* Skip link */
.skip-link {
  position: absolute; top: -100px; left: var(--space-4);
  background: var(--wr-primary); color: #fff;
  padding: 8px 16px; border-radius: var(--radius-sm);
  z-index: 10000; font-size: .85rem; font-weight: 600;
}
.skip-link:focus { top: var(--space-3); color: #fff; }
:focus-visible { outline: 2px solid var(--wr-primary); outline-offset: 2px; }

/* ============================================================
   INNER PAGES — BEM aliases & components
   ============================================================ */
.page-hero {
  padding: calc(56px + var(--space-9)) 0 var(--space-7);
  background: var(--wr-bg);
  color: var(--wr-text);
}
.page-hero h1 { color: var(--wr-text); margin-bottom: var(--space-3); }
.page-hero__subtitle { font-size: 1.05rem; color: var(--wr-text-secondary); max-width: 640px; }
@media (max-width: 768px) {
  .page-hero { padding: calc(68px + var(--space-9)) 0 var(--space-7); }
}
.section__title { font-family: var(--font-heading); font-size: clamp(1.4rem,2.5vw,1.8rem); font-weight: 600; margin-bottom: var(--space-3); }
.section__subtitle { color: var(--wr-text-secondary); font-size: .95rem; margin-bottom: var(--space-5); }
.form { max-width: 640px; }
.form__group { margin-bottom: var(--space-4); }
.form__group label { display: block; font-size: .78rem; font-weight: 500; margin-bottom: var(--space-2); color: var(--wr-text); }
.form__group input, .form__group select, .form__group textarea {
  width: 100%; padding: 10px 14px; font-size: .9rem; font-family: var(--font-body);
  border: 1.5px solid var(--wr-border); border-radius: var(--radius-sm);
  background: var(--wr-surface); color: var(--wr-text); outline: none;
  transition: border-color .25s, box-shadow .25s;
}
.form__group input:focus, .form__group select:focus, .form__group textarea:focus {
  border-color: var(--wr-primary); box-shadow: 0 0 0 3px rgba(245,134,52,.1);
}
.form__group textarea { resize: vertical; min-height: 80px; }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
@media (max-width: 576px) { .form__row { grid-template-columns: 1fr; } }
.form__note { font-size: .78rem; color: var(--wr-muted); }
.form__group--check { display: flex; align-items: flex-start; gap: var(--space-2); font-size: .85rem; color: var(--wr-text-secondary); }
.form__group--check input[type="checkbox"] { margin-top: 3px; accent-color: var(--wr-primary); }
.required { color: var(--wr-danger); }
fieldset { border: none; padding: 0; margin: 0 0 var(--space-5); }
legend { font-family: var(--font-heading); font-weight: 600; font-size: 1rem; margin-bottom: var(--space-4); color: var(--wr-text); }

.card-grid { display: grid; gap: var(--space-5); }
.card-grid--2 { grid-template-columns: repeat(2, 1fr); }
.card-grid--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 768px) { .card-grid--2, .card-grid--3 { grid-template-columns: 1fr; } }

.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-5); }
.step { text-align: center; padding: var(--space-5); }
.step__number {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--wr-primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; font-weight: 600; margin: 0 auto var(--space-4);
  box-shadow: 0 4px 14px rgba(245,134,52,.25);
}
.rules-box {
  margin-top: var(--space-6); padding: var(--space-5);
  background: var(--wr-primary-light); border: 1px solid var(--wr-primary-100); border-radius: var(--radius-md);
}
.rules-box h3 { margin-bottom: var(--space-3); font-size: 1rem; }
.rules-box li { font-size: .9rem; color: var(--wr-text-secondary); margin-bottom: var(--space-2); }
.contact-info { margin-top: var(--space-4); }
.contact-info p { margin-bottom: var(--space-2); color: var(--wr-text-secondary); }

.job-list { display: flex; flex-direction: column; gap: var(--space-3); }
.job-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-4) var(--space-5); border: 1px solid var(--wr-border);
  border-radius: var(--radius-md); background: #fff;
  transition: box-shadow .3s, border-color .3s, transform .3s;
}
.job-item:hover { box-shadow: var(--shadow-md); border-color: rgba(245,134,52,.15); transform: translateY(-2px); }
.job-item__info h3 { font-size: 1rem; margin-bottom: var(--space-1); }
.job-item__area, .job-item__location { font-size: .78rem; color: var(--wr-muted); margin-right: var(--space-3); }
.job-item__type { font-size: .78rem; color: var(--wr-text-secondary); font-weight: 500; white-space: nowrap; }
@media (max-width: 576px) { .job-item { flex-direction: column; align-items: flex-start; gap: var(--space-2); } }

.check-list { list-style: none; padding: 0; }
.check-list li { padding: var(--space-2) 0; padding-left: 24px; position: relative; font-size: .9rem; color: var(--wr-text-secondary); }
.check-list li::before { content: '\2713'; position: absolute; left: 0; color: var(--wr-primary); font-weight: 600; }

/* Legal / Prose */
.prose { max-width: 800px; margin: 0 auto; }
.prose h2 { font-size: 1.4rem; margin: var(--space-7) 0 var(--space-4); padding-top: var(--space-5); border-top: 1px solid var(--wr-border-light); }
.prose h2:first-of-type { border-top: none; margin-top: 0; }
.prose h3 { font-size: 1.1rem; margin: var(--space-5) 0 var(--space-3); }
.prose p { color: var(--wr-text-secondary); line-height: 1.8; }
.prose ul, .prose ol { margin-bottom: 1rem; color: var(--wr-text-secondary); }
.prose li { margin-bottom: .5rem; }
.prose address { font-style: normal; color: var(--wr-text-secondary); }
.toc { background: var(--wr-bg); border: 1px solid var(--wr-border); border-radius: var(--radius-md); padding: var(--space-5); margin-bottom: var(--space-7); }
.toc h3 { font-size: .9rem; margin-bottom: var(--space-3); }
.toc ul { list-style: none; padding: 0; }
.toc li { margin-bottom: var(--space-2); }
.toc a { font-size: .85rem; color: var(--wr-text-secondary); }
.toc a:hover { color: var(--wr-primary); }

/* Blog post */
.post-header { padding: calc(56px + var(--space-8)) 0 var(--space-6); text-align: center; }
@media (max-width: 768px) {
  .post-header { padding: calc(68px + var(--space-8)) 0 var(--space-6); }
}
.post-header .post-meta { display: flex; justify-content: center; gap: var(--space-4); font-size: .85rem; color: var(--wr-muted); margin-bottom: var(--space-4); }
.post-content { max-width: 720px; margin: 0 auto; padding: var(--space-7) var(--space-5); }
.post-content p { line-height: 1.85; color: var(--wr-text-secondary); margin-bottom: 1.5rem; }
.post-content h2 { margin: var(--space-7) 0 var(--space-4); font-size: 1.5rem; }

/* Cards grid aliases */
.cards-grid--2 { grid-template-columns: repeat(2, 1fr); }
.cards-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 992px) { .cards-grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 576px) { .cards-grid--2, .cards-grid--4 { grid-template-columns: 1fr; } }

/* ============================================================
   V2 Inline Overrides (Standalone)
   ============================================================ */
.section-kicker,
.section-header .section-kicker,
.cases-section__left .section-kicker,
.cta-section .section-kicker {
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: .02em;
  text-transform: none;
  color: #64748b;
  margin: 0 0 var(--space-4);
  max-width: none;
}
.section-kicker--light,
.cases-section__left .section-kicker--light,
.cta-section .section-kicker--light {
  color: rgba(226, 232, 240, .75);
}

.card-kicker {
  font-size: .75rem;
  font-weight: 500;
  color: var(--wr-muted);
}

.nav-links a,
.nav-links a:visited {
  color: var(--wr-text-secondary);
  opacity: 1;
  font-weight: 500;
}
.nav-links a:not(.btn):hover { color: var(--wr-text); }
.nav-links .btn--primary,
.nav-links .btn--primary:visited {
  color: #fff;
}
.nav-links .btn--outline-primary,
.nav-links .btn--outline-primary:visited {
  color: var(--wr-primary);
}
.nav-links .btn--outline-primary:hover {
  color: var(--wr-primary);
}

.hero__boxed {
  max-width: 100%;
  width: 100%;
  margin: 0;
  aspect-ratio: 16 / 9;
}
@media (max-width: 768px) {
  .hero__boxed { margin: 0; aspect-ratio: 4 / 3; }
}

:root {
  --panel-bg: linear-gradient(135deg, var(--wr-dark-soft) 0%, var(--wr-dark) 100%);
}

.cases-section {
  background: var(--wr-dark-soft);
  border: 1px solid rgba(148, 163, 184, .12);
  border-radius: var(--radius-lg);
}
.cases-section__overlay {
  background: var(--panel-bg);
  opacity: .92;
  background-size: 200% 200%;
  animation: panelSheen 24s ease-in-out infinite;
}

.cta-section { margin: 0; }
.cta-section::before,
.cta-section--aggressive::before,
.cta-section--aggressive::after {
  content: none !important;
}
.cta-shimmer { display: none; }
.cta-section--aggressive {
  background: var(--panel-bg);
  background-size: 200% 200%;
  animation: panelSheen 24s ease-in-out infinite;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(148, 163, 184, .12);
  padding-block: clamp(36px, 5vw, 64px);
  padding-inline: clamp(20px, 4vw, 56px);
  box-shadow: none;
}

@keyframes panelSheen {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.logo-marquee__glow,
.partners-showcase__glow {
  display: none !important;
}

#contato .split { align-items: stretch; }
#contato .contact-info {
  display: flex;
  flex-direction: column;
  height: 100%;
  margin-top: 0;
}
#contato .contact-form {
  display: flex;
  flex-direction: column;
  height: 100%;
}
#contato .contact-details p { margin-bottom: var(--space-3); }
#contato .contact-details p:last-child { margin-bottom: 0; }
#contato .contact-location-card {
  display: flex;
  flex-direction: column;
  flex: 1;
  justify-content: space-between;
}
#contato .form-card {
  flex: 1;
  display: flex;
  flex-direction: column;
  height: 100%;
}
#contato .form-card form {
  flex: 1;
  display: flex;
  flex-direction: column;
}
#contato .form-card form .btn { margin-top: auto; }

/* ============================================================
   SCROLL ANIMATIONS — stagger with blur
   ============================================================ */
.stagger-item {
  opacity: 0;
  transform: translateY(20px);
  filter: blur(4px);
  transition: opacity .5s cubic-bezier(.4,0,.2,1), transform .5s cubic-bezier(.4,0,.2,1), filter .5s cubic-bezier(.4,0,.2,1);
}
.stagger-item.is-visible {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
/* Keep solution cards visible even if observer/init fails on mobile */
.solutions-grid .stagger-item {
  opacity: 1;
  transform: none;
  filter: none;
}
.solutions-grid .stagger-item:not(.is-visible) {
  opacity: 1;
  transform: none;
  filter: none;
}
@media (prefers-reduced-motion: reduce) {
  .stagger-item { opacity: 1; transform: none; filter: none; transition: none; }
}

/* ============================================================
   SCROLL SPY — active nav link
   ============================================================ */
.nav-links > li > a:not(.btn).active {
  color: var(--wr-text);
}
.nav-links > li > a:not(.btn).active::after {
  width: 100%;
}

/* ============================================================
   CASES SECTION — metrics directly on navy (no white card)
   ============================================================ */
.cases-metrics-direct {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
.cases-metric-item-direct {
  text-align: center;
  padding: var(--space-5);
}
.cases-metric-item-direct .metric-num {
  font-family: var(--font-heading);
  font-size: 2.4rem;
  font-weight: 700;
  color: #fff;
  line-height: 1;
  margin-bottom: var(--space-2);
}
.cases-metric-item-direct .metric-label {
  font-size: .85rem;
  color: rgba(255,255,255,.6);
  line-height: 1.4;
}
@media (max-width: 576px) {
  .cases-metrics-direct { grid-template-columns: 1fr; }
  .contact-location-actions .btn { width: 100%; }
}

/* ============================================================
   SLOT MACHINE — vertical number roller
   ============================================================ */
.slot-machine {
  display: inline-flex;
  align-items: center;
  gap: var(--space-4);
}
.slot-roller {
  position: relative;
  width: 56px;
  height: 64px;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background: rgba(245,134,52,.1);
}
.slot-roller__track {
  display: flex;
  flex-direction: column;
  transition: transform .9s cubic-bezier(.22,.61,.36,1);
  will-change: transform;
}
.slot-roller__item {
  width: 56px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 700;
  color: var(--wr-primary);
  flex-shrink: 0;
}
.slot-text {
  font-size: 1.05rem;
  color: var(--wr-text-secondary);
  max-width: 320px;
  line-height: 1.5;
  transition: opacity .45s ease, transform .45s ease;
  will-change: opacity, transform;
}
.slot-text.is-switching {
  opacity: 0;
  transform: translateY(10px);
}

/* ============================================================
   FEEDBACKS / TESTIMONIALS SECTION
   ============================================================ */
.feedbacks-section {
  padding: var(--space-9) 0;
  background: var(--wr-bg);
}
.feedbacks-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
.feedback-card {
  background: #fff;
  border: 1px solid var(--wr-border-light);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: border-color .35s, transform .35s, box-shadow .35s;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  height: 100%;
}
.feedback-card:hover {
  border-color: rgba(245,134,52,.12);
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
}
.feedback-card__quote {
  position: relative;
  font-size: .9rem;
  color: var(--wr-text-secondary);
  line-height: 1.75;
  margin-bottom: var(--space-5);
  font-style: italic;
  padding-top: var(--space-5);
}
.feedback-card__quote::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 32px;
  height: 24px;
  opacity: .15;
  background: var(--wr-primary);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 24'%3E%3Cpath d='M0 24V14.4C0 6.08 4.48.96 13.44 0l1.28 3.2C9.6 4.48 7.36 8 7.04 12H13.44V24H0zm18.56 0V14.4C18.56 6.08 23.04.96 32 0l1.28 3.2c-5.12 1.28-7.36 4.8-7.68 8.8h6.4V24H18.56z'/%3E%3C/svg%3E") no-repeat center / contain;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 24'%3E%3Cpath d='M0 24V14.4C0 6.08 4.48.96 13.44 0l1.28 3.2C9.6 4.48 7.36 8 7.04 12H13.44V24H0zm18.56 0V14.4C18.56 6.08 23.04.96 32 0l1.28 3.2c-5.12 1.28-7.36 4.8-7.68 8.8h6.4V24H18.56z'/%3E%3C/svg%3E") no-repeat center / contain;
}
.feedback-card__author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: auto;
}
.feedback-card__avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--wr-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .75rem;
  font-weight: 600;
  color: #fff;
  flex-shrink: 0;
}
.feedback-card__name {
  font-weight: 600;
  color: var(--wr-text);
  font-size: .875rem;
}
.feedback-card__role {
  font-size: .75rem;
  color: var(--wr-muted);
}
@media (max-width: 992px) {
  .feedbacks-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   NA MÍDIA — Media Cards
   ============================================================ */
.media-section {
  padding: var(--space-9) 0;
  background: var(--wr-bg);
}
.media-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
.media-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--wr-border-light);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: border-color .35s, transform .35s, box-shadow .35s;
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  color: inherit;
  height: 100%;
}
.media-card:hover {
  border-color: rgba(245,134,52,.18);
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
  color: inherit;
}
.media-card__icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: var(--wr-primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-4);
  flex-shrink: 0;
}
.media-card__icon svg {
  width: 20px;
  height: 20px;
  color: var(--wr-primary);
}
.media-card__icon--g1 {
  background: #fef2f2;
  width: 56px;
  height: 32px;
  border-radius: 6px;
}
.media-card__icon--g1 svg {
  width: 44px;
  height: 22px;
}
.media-card__eyebrow {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .02em;
  color: var(--wr-primary);
  margin-bottom: var(--space-2);
}
.media-card__title {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--wr-text);
  line-height: 1.35;
  margin-bottom: var(--space-3);
}
.media-card__desc {
  font-size: .875rem;
  color: var(--wr-text-secondary);
  line-height: 1.65;
  margin-bottom: var(--space-5);
  flex-grow: 1;
}
.media-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--wr-primary);
  margin-top: auto;
  transition: gap .25s;
}
.media-card:hover .media-card__cta {
  gap: 10px;
  color: var(--wr-primary-hover);
}
@media (max-width: 992px) {
  .media-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .media-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   SVG ICON ANIMATIONS (scroll-triggered)
   ============================================================ */
@keyframes svgDraw {
  from { stroke-dashoffset: 100; }
  to { stroke-dashoffset: 0; }
}
.svg-animate svg path,
.svg-animate svg circle,
.svg-animate svg polyline,
.svg-animate svg line,
.svg-animate svg rect {
  stroke-dasharray: 100;
  stroke-dashoffset: 100;
}
.svg-animate.is-visible svg path,
.svg-animate.is-visible svg circle,
.svg-animate.is-visible svg polyline,
.svg-animate.is-visible svg line,
.svg-animate.is-visible svg rect {
  animation: svgDraw .8s cubic-bezier(.4,0,.2,1) forwards;
}
@media (prefers-reduced-motion: reduce) {
  .svg-animate svg path,
  .svg-animate svg circle,
  .svg-animate svg polyline,
  .svg-animate svg line,
  .svg-animate svg rect {
    stroke-dasharray: none;
    stroke-dashoffset: 0;
    animation: none;
  }
}

/* ============================================================
   CTA ROLETA — rotating phrases in title
   ============================================================ */
.cta-roleta {
  display: inline-block;
  position: relative;
  height: 1.15em;
  overflow: hidden;
  vertical-align: baseline;
  min-width: 0;
  max-width: 100%;
}
.cta-roleta__track {
  display: flex;
  flex-direction: column;
  transition: transform .9s cubic-bezier(.22,.61,.36,1);
  will-change: transform;
}
.cta-roleta__item {
  height: 1.15em;
  display: flex;
  align-items: center;
  color: var(--wr-primary);
  flex-shrink: 0;
  white-space: nowrap;
}

@media (prefers-reduced-motion: reduce) {
  .slot-roller__track,
  .cta-roleta__track,
  .slot-text {
    transition: none !important;
  }
}
