/* =========================================================
       LA TRANSPORTES — LANDING PAGE
       ========================================================= */

    :root {
      --blue: #0868f2;
      --blue-bright: #009dff;
      --cyan: #39d5ff;
      --navy: #071426;
      --dark: #040b16;
      --dark-soft: #0c1c32;
      --white: #ffffff;
      --gray-50: #f8fafc;
      --gray-100: #eef3f8;
      --gray-200: #d9e3ee;
      --gray-500: #667085;
      --gray-700: #344054;
      --success: #25d366;
      --max-width: 1240px;
      --header-height: 76px;
      --radius-sm: 14px;
      --radius-md: 22px;
      --radius-lg: 32px;
      --shadow-soft: 0 18px 50px rgba(7, 20, 38, 0.12);
      --shadow-dark: 0 24px 80px rgba(0, 0, 0, 0.28);
      --transition: 320ms cubic-bezier(.2, .7, .2, 1);
      --font-display: "Sora", "Montserrat", "Segoe UI", Arial, sans-serif;
      --font-body: "Inter", "Roboto", "Segoe UI", Arial, sans-serif;
    }

    *,
    *::before,
    *::after {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
      scroll-padding-top: calc(var(--header-height) + 20px);
    }

    body {
      margin: 0;
      min-width: 320px;
      overflow-x: hidden;
      color: var(--navy);
      background: var(--white);
      font-family: var(--font-body);
      font-size: 16px;
      line-height: 1.6;
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
    }

    body.menu-open {
      overflow: hidden;
    }

    img,
    svg {
      display: block;
      max-width: 100%;
    }

    img {
      height: auto;
    }

    button,
    input,
    textarea,
    select {
      font: inherit;
    }

    button,
    a {
      -webkit-tap-highlight-color: transparent;
    }

    a {
      color: inherit;
      text-decoration: none;
    }

    ul {
      margin: 0;
      padding: 0;
      list-style: none;
    }

    h1,
    h2,
    h3,
    p {
      margin-top: 0;
    }

    h1,
    h2,
    h3 {
      color: inherit;
      font-family: var(--font-display);
      line-height: 1.05;
      letter-spacing: -0.035em;
    }

    :focus-visible {
      outline: 3px solid var(--cyan);
      outline-offset: 4px;
    }

    ::selection {
      color: var(--white);
      background: var(--blue);
    }

    .container {
      width: min(100% - 32px, var(--max-width));
      margin-inline: auto;
    }

    .skip-link {
      position: fixed;
      top: 10px;
      left: 10px;
      z-index: 9999;
      padding: 12px 16px;
      color: var(--white);
      background: var(--blue);
      border-radius: 10px;
      transform: translateY(-150%);
      transition: transform var(--transition);
    }

    .skip-link:focus {
      transform: translateY(0);
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 18px;
      color: var(--blue);
      font-family: var(--font-display);
      font-size: 0.78rem;
      font-weight: 800;
      letter-spacing: 0.14em;
      text-transform: uppercase;
    }

    .eyebrow::before {
      width: 28px;
      height: 3px;
      background: currentColor;
      content: "";
    }

    .section-title {
      max-width: 880px;
      margin-bottom: 20px;
      font-size: clamp(1.9rem, 4.2vw, 3.75rem);
      font-weight: 900;
      text-transform: uppercase;
    }

    .section-lead {
      max-width: 760px;
      margin-bottom: 0;
      color: var(--gray-500);
      font-size: clamp(1rem, 2vw, 1.18rem);
    }

    .text-blue {
      color: var(--blue-bright);
    }

    .btn {
      position: relative;
      display: inline-flex;
      min-height: 52px;
      align-items: center;
      justify-content: center;
      gap: 10px;
      overflow: hidden;
      padding: 14px 20px;
      border: 1px solid transparent;
      border-radius: 999px;
      font-family: var(--font-display);
      font-size: 0.82rem;
      font-weight: 850;
      letter-spacing: 0.05em;
      line-height: 1;
      text-align: center;
      text-transform: uppercase;
      cursor: pointer;
      transition:
        transform var(--transition),
        box-shadow var(--transition),
        color var(--transition),
        background var(--transition),
        border-color var(--transition);
      isolation: isolate;
    }

    .btn::before {
      position: absolute;
      inset: 0;
      z-index: -1;
      background: linear-gradient(110deg, transparent 25%, rgba(255,255,255,.24) 50%, transparent 75%);
      content: "";
      transform: translateX(-120%);
      transition: transform 650ms ease;
    }

    .btn:hover::before {
      transform: translateX(120%);
    }

    .btn:hover {
      transform: translateY(-3px);
    }

    .btn-primary {
      color: var(--white);
      background: linear-gradient(135deg, var(--blue), var(--blue-bright));
      box-shadow: 0 14px 28px rgba(0, 157, 255, 0.28);
    }

    .btn-primary:hover {
      box-shadow: 0 20px 38px rgba(0, 157, 255, 0.38);
    }

    .btn-outline {
      color: var(--white);
      background: rgba(255, 255, 255, 0.06);
      border-color: rgba(255, 255, 255, 0.24);
      backdrop-filter: blur(10px);
    }

    .btn-outline:hover {
      background: rgba(255, 255, 255, 0.12);
      border-color: rgba(255, 255, 255, 0.5);
    }

    .btn-light {
      color: var(--navy);
      background: var(--white);
      box-shadow: 0 16px 34px rgba(7, 20, 38, 0.14);
    }

    .btn-light:hover {
      color: var(--blue);
      box-shadow: 0 20px 42px rgba(7, 20, 38, 0.22);
    }

    .btn svg {
      width: 20px;
      height: 20px;
      flex: 0 0 auto;
    }

    .reveal {
      opacity: 0;
      transform: translateY(28px);
      transition:
        opacity 700ms ease,
        transform 700ms cubic-bezier(.2, .75, .2, 1);
    }

    .reveal.is-visible {
      opacity: 1;
      transform: none;
    }

    .delay-1 { transition-delay: 90ms; }
    .delay-2 { transition-delay: 180ms; }
    .delay-3 { transition-delay: 270ms; }
    .delay-4 { transition-delay: 360ms; }

    /* ========================= CABEÇALHO ========================= */

    .site-header {
      position: fixed;
      top: 0;
      right: 0;
      left: 0;
      z-index: 1000;
      height: var(--header-height);
      color: var(--white);
      background: linear-gradient(to bottom, rgba(4, 11, 22, 0.72), transparent);
      transition:
        background var(--transition),
        box-shadow var(--transition),
        backdrop-filter var(--transition);
    }

    .site-header.scrolled,
    .site-header.menu-active {
      background: rgba(4, 11, 22, 0.94);
      box-shadow: 0 12px 36px rgba(0, 0, 0, 0.24);
      backdrop-filter: blur(18px);
    }

    .header-inner {
      display: flex;
      height: 100%;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }

    .brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      flex: 0 0 auto;
    }

    .brand-mark {
      position: relative;
      width: 43px;
      height: 43px;
      overflow: hidden;
      border: 1px solid rgba(255,255,255,.16);
      border-radius: 13px;
      background: linear-gradient(145deg, var(--blue), var(--blue-bright));
      box-shadow: inset 0 1px 0 rgba(255,255,255,.25);
    }

    .brand-mark::before,
    .brand-mark::after {
      position: absolute;
      content: "";
      transform: skewX(-24deg);
    }

    .brand-mark::before {
      top: 8px;
      left: 9px;
      width: 10px;
      height: 26px;
      background: var(--white);
    }

    .brand-mark::after {
      right: 7px;
      bottom: 8px;
      width: 22px;
      height: 8px;
      background: var(--cyan);
      box-shadow: -8px -11px 0 var(--white);
    }

    .brand-copy {
      display: grid;
      line-height: 0.88;
    }

    .brand-copy strong {
      font-family: var(--font-display);
      font-size: 1.45rem;
      font-weight: 950;
      letter-spacing: -0.06em;
    }

    .brand-copy span {
      color: rgba(255,255,255,.72);
      font-family: var(--font-display);
      font-size: 0.58rem;
      font-weight: 800;
      letter-spacing: 0.16em;
      text-transform: uppercase;
    }

    .desktop-nav {
      display: none;
    }

    .header-cta {
      display: none;
    }

    .menu-toggle {
      display: inline-grid;
      width: 48px;
      height: 48px;
      place-items: center;
      padding: 0;
      color: var(--white);
      background: rgba(255,255,255,.08);
      border: 1px solid rgba(255,255,255,.16);
      border-radius: 14px;
      cursor: pointer;
    }

    .menu-icon {
      position: relative;
      width: 22px;
      height: 16px;
    }

    .menu-icon span {
      position: absolute;
      left: 0;
      width: 100%;
      height: 2px;
      border-radius: 999px;
      background: currentColor;
      transition: transform var(--transition), opacity var(--transition), top var(--transition);
    }

    .menu-icon span:nth-child(1) { top: 0; }
    .menu-icon span:nth-child(2) { top: 7px; }
    .menu-icon span:nth-child(3) { top: 14px; }

    .menu-toggle[aria-expanded="true"] .menu-icon span:nth-child(1) {
      top: 7px;
      transform: rotate(45deg);
    }

    .menu-toggle[aria-expanded="true"] .menu-icon span:nth-child(2) {
      opacity: 0;
    }

    .menu-toggle[aria-expanded="true"] .menu-icon span:nth-child(3) {
      top: 7px;
      transform: rotate(-45deg);
    }

    .mobile-menu {
      position: fixed;
      top: var(--header-height);
      right: 0;
      left: 0;
      z-index: 999;
      display: grid;
      gap: 8px;
      padding: 20px 16px calc(26px + env(safe-area-inset-bottom));
      background: rgba(4, 11, 22, 0.98);
      border-top: 1px solid rgba(255,255,255,.08);
      box-shadow: 0 24px 60px rgba(0,0,0,.32);
      opacity: 0;
      visibility: hidden;
      transform: translateY(-12px);
      transition: opacity var(--transition), visibility var(--transition), transform var(--transition);
    }

    .mobile-menu.is-open {
      opacity: 1;
      visibility: visible;
      transform: none;
    }

    .mobile-menu a:not(.btn) {
      min-height: 48px;
      padding: 12px 4px;
      color: var(--white);
      border-bottom: 1px solid rgba(255,255,255,.08);
      font-family: var(--font-display);
      font-weight: 750;
    }

    .mobile-menu .btn {
      margin-top: 10px;
    }

    /* ============================= HERO ============================= */

    .hero {
      position: relative;
      min-height: 100svh;
      display: grid;
      align-items: center;
      overflow: hidden;
      padding: calc(var(--header-height) + 56px) 0 64px;
      color: var(--white);
      background:
        radial-gradient(circle at 80% 20%, rgba(0,157,255,.28), transparent 26%),
        linear-gradient(125deg, #040b16 0%, #071426 48%, #0a2240 100%);
      isolation: isolate;
    }

    .hero::before {
      position: absolute;
      inset: 0;
      z-index: -3;
      opacity: .22;
      background-image:
        linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
      background-size: 54px 54px;
      content: "";
      mask-image: linear-gradient(to bottom, black, transparent 88%);
    }

    .hero::after {
      position: absolute;
      right: -14vw;
      bottom: -26vh;
      z-index: -2;
      width: 80vw;
      height: 55vh;
      background: linear-gradient(90deg, rgba(8,104,242,.12), rgba(0,157,255,.38));
      clip-path: polygon(24% 0, 100% 0, 74% 100%, 0 100%);
      content: "";
      transform: rotate(-8deg);
    }

    .hero-route {
      position: absolute;
      top: 19%;
      right: -7%;
      z-index: -1;
      width: min(56vw, 720px);
      height: 8px;
      opacity: .5;
      border-top: 2px dashed var(--cyan);
      transform: rotate(-15deg);
      animation: routeFloat 7s ease-in-out infinite;
    }

    .hero-route::before,
    .hero-route::after {
      position: absolute;
      top: -7px;
      width: 12px;
      height: 12px;
      border: 3px solid var(--cyan);
      border-radius: 50%;
      background: var(--navy);
      content: "";
    }

    .hero-route::before { left: 0; }
    .hero-route::after { right: 0; }

    @keyframes routeFloat {
      50% { transform: rotate(-14deg) translate3d(-10px, 8px, 0); }
    }

    .hero-grid {
      display: grid;
      gap: 42px;
      align-items: center;
    }

    .hero-content {
      position: relative;
      z-index: 3;
    }

    .hero-badge {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 22px;
      padding: 9px 12px;
      color: var(--cyan);
      background: rgba(0,157,255,.1);
      border: 1px solid rgba(57,213,255,.28);
      border-radius: 999px;
      font-family: var(--font-display);
      font-size: .7rem;
      font-weight: 850;
      letter-spacing: .12em;
      text-transform: uppercase;
      backdrop-filter: blur(10px);
    }

    .hero-badge::before {
      width: 8px;
      height: 8px;
      background: var(--cyan);
      border-radius: 50%;
      box-shadow: 0 0 0 6px rgba(57,213,255,.1);
      content: "";
    }

    .hero h1 {
      max-width: 880px;
      margin-bottom: 24px;
      font-size: clamp(2.45rem, 7.2vw, 5.25rem);
      font-weight: 950;
      text-wrap: balance;
      text-transform: uppercase;
    }

    .hero h1 .line-accent {
      position: relative;
      display: inline-block;
      color: var(--blue-bright);
    }

    .hero h1 .line-accent::after {
      position: absolute;
      right: 0;
      bottom: .04em;
      left: 0;
      z-index: -1;
      height: .12em;
      background: linear-gradient(90deg, transparent, var(--cyan), transparent);
      content: "";
      transform: skewX(-20deg);
    }

    .hero-copy {
      max-width: 690px;
      margin-bottom: 28px;
      color: rgba(255,255,255,.72);
      font-size: clamp(1rem, 1.8vw, 1.12rem);
    }

    .hero-actions {
      display: grid;
      gap: 12px;
      margin-bottom: 30px;
    }

    .hero-proof {
      display: grid;
      grid-template-columns: 1fr;
      gap: 12px;
    }

    .proof-item {
      display: flex;
      min-height: 58px;
      align-items: center;
      gap: 12px;
      padding: 11px 13px;
      background: rgba(255,255,255,.055);
      border: 1px solid rgba(255,255,255,.1);
      border-radius: 15px;
      backdrop-filter: blur(10px);
    }

    .proof-icon {
      display: grid;
      width: 36px;
      height: 36px;
      place-items: center;
      flex: 0 0 auto;
      color: var(--cyan);
      background: rgba(0,157,255,.12);
      border-radius: 11px;
    }

    .proof-icon svg {
      width: 19px;
      height: 19px;
    }

    .proof-item span {
      color: rgba(255,255,255,.82);
      font-size: .86rem;
      line-height: 1.25;
    }

    .proof-item strong {
      display: block;
      color: var(--white);
      font-family: var(--font-display);
      font-size: .94rem;
    }

    .hero-media {
      position: relative;
      z-index: 2;
      min-height: 420px;
    }

    .truck-frame {
      position: absolute;
      inset: 24px 0 0 0;
      overflow: hidden;
      background: #0d213b;
      border: 1px solid rgba(255,255,255,.13);
      border-radius: 28px;
      box-shadow: var(--shadow-dark);
      clip-path: polygon(0 8%, 86% 0, 100% 14%, 100% 100%, 9% 100%, 0 86%);
    }

    .truck-frame::before {
      position: absolute;
      inset: 0;
      z-index: 1;
      background:
        linear-gradient(180deg, rgba(4,11,22,.04), rgba(4,11,22,.38)),
        linear-gradient(90deg, rgba(7,20,38,.2), transparent 45%);
      content: "";
      pointer-events: none;
    }

    .truck-frame img {
      width: 100%;
      height: 100%;
      min-height: 420px;
      object-fit: cover;
      object-position: center;
      filter: brightness(1.06) contrast(1.12) saturate(1.08);
      transform: scale(1.02);
    }

    .location-tag {
      position: absolute;
      top: 0;
      left: 18px;
      z-index: 4;
      display: inline-flex;
      align-items: center;
      gap: 9px;
      padding: 11px 14px;
      color: var(--navy);
      background: var(--white);
      border-radius: 999px;
      box-shadow: 0 12px 30px rgba(0,0,0,.22);
      font-family: var(--font-display);
      font-size: .74rem;
      font-weight: 850;
      letter-spacing: .06em;
      text-transform: uppercase;
    }

    .location-tag svg {
      width: 17px;
      color: var(--blue);
    }

    .hero-model {
      position: absolute;
      right: 14px;
      bottom: 12px;
      z-index: 4;
      max-width: 180px;
      padding: 13px 15px;
      color: var(--white);
      background: rgba(4,11,22,.82);
      border: 1px solid rgba(255,255,255,.14);
      border-radius: 16px;
      backdrop-filter: blur(12px);
    }

    .hero-model small {
      display: block;
      margin-bottom: 2px;
      color: var(--cyan);
      font-size: .65rem;
      font-weight: 800;
      letter-spacing: .1em;
      text-transform: uppercase;
    }

    .hero-model strong {
      font-family: var(--font-display);
      font-size: .92rem;
      line-height: 1.15;
    }

    .hero-stripe {
      position: absolute;
      right: -24px;
      bottom: 30px;
      z-index: 3;
      width: 170px;
      height: 14px;
      background: linear-gradient(90deg, var(--blue), var(--cyan));
      clip-path: polygon(12% 0, 100% 0, 88% 100%, 0 100%);
      transform: rotate(-7deg);
    }

    /* ======================= SEÇÃO 2: SERVIÇOS ======================= */

    .services-section {
      position: relative;
      overflow: hidden;
      padding: 86px 0;
      background: var(--gray-50);
    }

    .services-section::before {
      position: absolute;
      top: 54px;
      right: -150px;
      width: 360px;
      height: 100px;
      opacity: .06;
      background: repeating-linear-gradient(90deg, var(--blue) 0 36px, transparent 36px 54px);
      content: "";
      transform: rotate(-35deg);
    }

    .services-header {
      margin-bottom: 40px;
    }

    .service-grid {
      display: grid;
      gap: 16px;
      margin-bottom: 56px;
    }

    .service-card {
      position: relative;
      min-height: 275px;
      overflow: hidden;
      padding: 26px;
      background: var(--white);
      border: 1px solid var(--gray-200);
      border-radius: var(--radius-md);
      box-shadow: 0 10px 30px rgba(7,20,38,.05);
      transition:
        transform var(--transition),
        box-shadow var(--transition),
        border-color var(--transition),
        background var(--transition);
    }

    .service-card::after {
      position: absolute;
      right: -18px;
      bottom: -18px;
      width: 90px;
      height: 90px;
      opacity: .08;
      background: var(--blue);
      clip-path: polygon(0 0, 100% 0, 100% 100%);
      content: "";
      transition: transform var(--transition), opacity var(--transition);
    }

    .service-card:hover {
      border-color: rgba(8,104,242,.42);
      box-shadow: 0 24px 55px rgba(7,20,38,.12);
      transform: translateY(-7px);
    }

    .service-card:hover::after {
      opacity: .16;
      transform: scale(1.18);
    }

    .service-icon {
      display: grid;
      width: 56px;
      height: 56px;
      place-items: center;
      margin-bottom: 36px;
      color: var(--blue);
      background: linear-gradient(145deg, rgba(8,104,242,.12), rgba(0,157,255,.07));
      border: 1px solid rgba(8,104,242,.12);
      border-radius: 17px;
    }

    .service-icon svg {
      width: 28px;
      height: 28px;
    }

    .service-card h3 {
      margin-bottom: 13px;
      font-size: 1.35rem;
      font-weight: 850;
    }

    .service-card p {
      margin-bottom: 0;
      color: var(--gray-500);
    }

    .structure-panel {
      position: relative;
      display: grid;
      gap: 28px;
      overflow: hidden;
      padding: 24px;
      color: var(--white);
      background:
        radial-gradient(circle at 80% 10%, rgba(0,157,255,.25), transparent 30%),
        linear-gradient(130deg, var(--navy), var(--dark));
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-soft);
      isolation: isolate;
    }

    .structure-panel::before {
      position: absolute;
      inset: 0;
      z-index: -1;
      opacity: .11;
      background-image: linear-gradient(115deg, transparent 0 47%, var(--blue) 47% 49%, transparent 49% 100%);
      background-size: 62px 62px;
      content: "";
    }

    .structure-photo {
      position: relative;
      min-height: 320px;
      overflow: hidden;
      background: #10223a;
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 22px;
    }

    .structure-photo::after {
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, transparent 45%, rgba(4,11,22,.7));
      content: "";
      pointer-events: none;
    }

    .structure-photo img {
      width: 100%;
      height: 100%;
      min-height: 320px;
      object-fit: cover;
      object-position: center;
      filter: brightness(1.04) contrast(1.1) saturate(1.08);
    }

    .vehicle-tag {
      position: absolute;
      right: 14px;
      bottom: 14px;
      left: 14px;
      z-index: 2;
      padding: 13px 15px;
      background: rgba(4,11,22,.78);
      border: 1px solid rgba(255,255,255,.14);
      border-radius: 14px;
      backdrop-filter: blur(12px);
    }

    .vehicle-tag small {
      display: block;
      color: var(--cyan);
      font-size: .62rem;
      font-weight: 800;
      letter-spacing: .12em;
      text-transform: uppercase;
    }

    .vehicle-tag strong {
      font-family: var(--font-display);
      font-size: 1rem;
    }

    .structure-copy {
      display: flex;
      flex-direction: column;
      justify-content: center;
    }

    .structure-copy .eyebrow {
      color: var(--cyan);
    }

    .structure-copy h3 {
      max-width: 620px;
      margin-bottom: 25px;
      font-size: clamp(1.85rem, 4vw, 3.15rem);
      font-weight: 900;
      text-transform: uppercase;
    }

    .spec-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
      margin-bottom: 24px;
    }

    .spec {
      min-height: 105px;
      padding: 15px;
      background: rgba(255,255,255,.065);
      border: 1px solid rgba(255,255,255,.11);
      border-radius: 16px;
      backdrop-filter: blur(8px);
    }

    .spec strong {
      display: block;
      margin-bottom: 5px;
      color: var(--white);
      font-family: var(--font-display);
      font-size: clamp(1.45rem, 5vw, 2.3rem);
      font-weight: 900;
      letter-spacing: -.055em;
      line-height: 1;
    }

    .spec span {
      display: block;
      color: rgba(255,255,255,.66);
      font-size: .76rem;
      line-height: 1.35;
    }

    .structure-note {
      margin-bottom: 22px;
      color: rgba(255,255,255,.65);
      font-size: .9rem;
    }

    .structure-copy .btn {
      align-self: flex-start;
    }

    /* ==================== SEÇÃO 3: CONFIANÇA ==================== */

    .trust-section {
      position: relative;
      overflow: hidden;
      padding: 86px 0;
      background: var(--white);
    }

    .trust-section::after {
      position: absolute;
      top: 70px;
      left: -90px;
      width: 220px;
      height: 220px;
      opacity: .055;
      border: 38px solid var(--blue);
      border-radius: 50%;
      content: "";
    }

    .trust-grid {
      position: relative;
      z-index: 1;
      display: grid;
      gap: 36px;
      align-items: start;
      margin-bottom: 52px;
    }

    .trust-copy .section-title {
      font-size: clamp(1.9rem, 4vw, 3.35rem);
    }

    .trust-copy > p {
      max-width: 710px;
      color: var(--gray-500);
      font-size: 1.05rem;
    }

    .driver-profile {
      position: relative;
      display: grid;
      grid-template-columns: 108px minmax(0, 1fr);
      gap: 16px;
      align-items: stretch;
      overflow: hidden;
      margin: 28px 0 30px;
      padding: 12px;
      color: var(--white);
      background:
        radial-gradient(circle at 100% 0, rgba(57,213,255,.2), transparent 36%),
        linear-gradient(135deg, var(--navy), #0b2b50);
      border: 1px solid rgba(8,104,242,.18);
      border-radius: 24px;
      box-shadow: 0 18px 46px rgba(7,20,38,.15);
      isolation: isolate;
    }

    .driver-profile::before {
      position: absolute;
      right: -35px;
      bottom: -48px;
      z-index: -1;
      width: 145px;
      height: 145px;
      opacity: .13;
      border: 24px solid var(--cyan);
      border-radius: 50%;
      content: "";
    }

    .driver-photo {
      position: relative;
      min-height: 154px;
      overflow: hidden;
      background: var(--dark-soft);
      border: 1px solid rgba(255,255,255,.14);
      border-radius: 17px;
    }

    .driver-photo::after {
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, transparent 62%, rgba(4,11,22,.24));
      content: "";
      pointer-events: none;
    }

    .driver-photo img {
      width: 100%;
      height: 100%;
      min-height: 154px;
      object-fit: cover;
      object-position: center 18%;
      filter: brightness(1.03) contrast(1.04) saturate(1.03);
      transition: transform 500ms ease, filter 500ms ease;
    }

    .driver-profile:hover .driver-photo img {
      filter: brightness(1.06) contrast(1.06) saturate(1.05);
      transform: scale(1.025);
    }

    .driver-profile-copy {
      align-self: center;
      padding: 8px 7px 8px 0;
    }

    .driver-role {
      display: inline-flex;
      margin-bottom: 7px;
      color: var(--cyan);
      font-family: var(--font-display);
      font-size: .64rem;
      font-weight: 850;
      letter-spacing: .11em;
      text-transform: uppercase;
    }

    .driver-profile h3 {
      margin-bottom: 8px;
      color: var(--white);
      font-size: clamp(1.25rem, 4vw, 1.75rem);
      font-weight: 900;
    }

    .driver-profile p {
      margin-bottom: 13px;
      color: rgba(255,255,255,.72);
      font-size: .82rem;
      line-height: 1.48;
    }

    .driver-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 7px;
    }

    .driver-meta span {
      display: inline-flex;
      min-height: 28px;
      align-items: center;
      padding: 5px 8px;
      color: rgba(255,255,255,.82);
      background: rgba(255,255,255,.08);
      border: 1px solid rgba(255,255,255,.1);
      border-radius: 999px;
      font-size: .66rem;
      font-weight: 700;
      line-height: 1.2;
    }

    .benefit-list {
      display: grid;
      gap: 12px;
      margin: 28px 0;
    }

    .benefit-list li {
      display: flex;
      align-items: flex-start;
      gap: 12px;
      color: var(--gray-700);
    }

    .check-icon {
      display: grid;
      width: 25px;
      height: 25px;
      place-items: center;
      flex: 0 0 auto;
      margin-top: 1px;
      color: var(--white);
      background: var(--blue);
      border-radius: 8px;
    }

    .check-icon svg {
      width: 14px;
      height: 14px;
    }

    .authority-note {
      position: relative;
      overflow: hidden;
      max-width: 760px;
      padding: 22px 22px 22px 26px;
      color: var(--navy);
      background: var(--gray-100);
      border: 1px solid var(--gray-200);
      border-radius: 18px;
    }

    .authority-note::before {
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      width: 5px;
      background: linear-gradient(var(--blue), var(--cyan));
      content: "";
    }

    .authority-note strong {
      display: block;
      margin-bottom: 6px;
      font-family: var(--font-display);
      font-size: .78rem;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    .authority-note p {
      margin-bottom: 0;
      color: var(--gray-500);
      font-size: .92rem;
    }

    .quote-card {
      position: relative;
      overflow: hidden;
      padding: 28px;
      color: var(--white);
      background:
        radial-gradient(circle at 100% 0, rgba(57,213,255,.22), transparent 35%),
        linear-gradient(145deg, var(--blue), #0751c5 72%);
      border-radius: var(--radius-lg);
      box-shadow: 0 24px 60px rgba(8,104,242,.26);
      isolation: isolate;
    }

    .quote-card::after {
      position: absolute;
      right: -45px;
      bottom: -65px;
      z-index: -1;
      width: 180px;
      height: 180px;
      opacity: .17;
      border: 28px solid var(--white);
      border-radius: 50%;
      content: "";
    }

    .quote-card .eyebrow {
      color: var(--white);
      opacity: .78;
    }

    .quote-card h3 {
      margin-bottom: 15px;
      font-size: clamp(1.7rem, 3.5vw, 2.55rem);
      font-weight: 900;
      text-transform: uppercase;
    }

    .quote-card > p {
      margin-bottom: 24px;
      color: rgba(255,255,255,.82);
    }

    .quote-data {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 9px;
      margin-bottom: 24px;
    }

    .quote-data li {
      display: flex;
      align-items: center;
      gap: 8px;
      min-height: 48px;
      padding: 9px 10px;
      color: rgba(255,255,255,.84);
      background: rgba(255,255,255,.09);
      border: 1px solid rgba(255,255,255,.13);
      border-radius: 12px;
      font-size: .76rem;
      line-height: 1.3;
    }

    .quote-data svg {
      width: 16px;
      height: 16px;
      flex: 0 0 auto;
      color: var(--cyan);
    }

    .quote-card .btn {
      width: 100%;
    }

    .gallery-heading {
      display: flex;
      align-items: end;
      justify-content: space-between;
      gap: 20px;
      margin-bottom: 18px;
    }

    .gallery-heading h3 {
      margin: 0;
      font-size: clamp(1.4rem, 3vw, 2rem);
      font-weight: 850;
      text-transform: uppercase;
    }

    .gallery-heading span {
      display: none;
      color: var(--gray-500);
      font-size: .85rem;
    }

    .truck-gallery {
      display: flex;
      gap: 14px;
      overflow-x: auto;
      padding: 4px 2px 16px;
      scroll-snap-type: x mandatory;
      scrollbar-width: thin;
      scrollbar-color: var(--blue) var(--gray-100);
      overscroll-behavior-inline: contain;
    }

    .truck-gallery::-webkit-scrollbar {
      height: 7px;
    }

    .truck-gallery::-webkit-scrollbar-track {
      background: var(--gray-100);
      border-radius: 999px;
    }

    .truck-gallery::-webkit-scrollbar-thumb {
      background: var(--blue);
      border-radius: 999px;
    }

    .gallery-item {
      position: relative;
      min-width: min(86vw, 360px);
      min-height: 270px;
      overflow: hidden;
      flex: 1 0 auto;
      background: var(--navy);
      border: 1px solid var(--gray-200);
      border-radius: 20px;
      box-shadow: 0 12px 35px rgba(7,20,38,.08);
      scroll-snap-align: start;
    }

    .gallery-item::after {
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, transparent 55%, rgba(4,11,22,.45));
      content: "";
      pointer-events: none;
    }

    .gallery-item img {
      width: 100%;
      height: 100%;
      min-height: 270px;
      object-fit: cover;
      object-position: center;
      filter: brightness(1.04) contrast(1.1) saturate(1.08);
      transition: transform 500ms ease, filter 500ms ease;
    }

    .gallery-item:hover img {
      filter: brightness(1.08) contrast(1.12) saturate(1.12);
      transform: scale(1.035);
    }

    /* ============================= RODAPÉ ============================= */

    .site-footer {
      padding: 48px 0 calc(26px + env(safe-area-inset-bottom));
      color: rgba(255,255,255,.68);
      background: var(--dark);
      border-top: 1px solid rgba(255,255,255,.06);
    }

    .footer-grid {
      display: grid;
      gap: 28px;
      padding-bottom: 28px;
      border-bottom: 1px solid rgba(255,255,255,.1);
    }

    .footer-brand .brand {
      margin-bottom: 15px;
    }

    .footer-brand p {
      max-width: 460px;
      margin-bottom: 0;
      font-size: .92rem;
    }

    .footer-info {
      display: grid;
      gap: 9px;
      font-size: .9rem;
    }

    .footer-info strong {
      color: var(--white);
    }

    .footer-info a {
      color: var(--cyan);
      font-weight: 750;
    }

    .footer-info a:hover {
      text-decoration: underline;
    }

    .cargo-limits {
      margin-top: 24px;
      padding: 14px 16px;
      color: rgba(255,255,255,.52);
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.07);
      border-radius: 13px;
      font-size: .75rem;
      line-height: 1.55;
    }

    .footer-bottom {
      display: flex;
      flex-direction: column;
      gap: 8px;
      padding-top: 22px;
      font-size: .76rem;
    }

    /* ======================= WHATSAPP FLUTUANTE ======================= */

    .whatsapp-float {
      position: fixed;
      right: max(16px, env(safe-area-inset-right));
      bottom: max(16px, env(safe-area-inset-bottom));
      z-index: 900;
      display: grid;
      width: 56px;
      height: 56px;
      place-items: center;
      color: var(--white);
      background: var(--success);
      border: 3px solid rgba(255,255,255,.9);
      border-radius: 50%;
      box-shadow: 0 16px 34px rgba(37,211,102,.36);
      transition: transform var(--transition), box-shadow var(--transition);
    }

    .whatsapp-float::before {
      position: absolute;
      inset: -5px;
      z-index: -1;
      opacity: .55;
      border: 2px solid rgba(37,211,102,.65);
      border-radius: inherit;
      content: "";
      animation: whatsappPulse 2.2s ease-out infinite;
    }

    .whatsapp-float:hover {
      box-shadow: 0 20px 42px rgba(37,211,102,.48);
      transform: translateY(-4px) scale(1.03);
    }

    .whatsapp-float svg {
      width: 29px;
      height: 29px;
    }

    .whatsapp-tooltip {
      position: absolute;
      right: calc(100% + 12px);
      width: max-content;
      padding: 8px 10px;
      color: var(--white);
      background: var(--navy);
      border-radius: 8px;
      box-shadow: 0 8px 20px rgba(0,0,0,.24);
      font-size: .72rem;
      font-weight: 750;
      opacity: 0;
      visibility: hidden;
      transform: translateX(6px);
      transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
    }

    .whatsapp-float:hover .whatsapp-tooltip,
    .whatsapp-float:focus-visible .whatsapp-tooltip {
      opacity: 1;
      visibility: visible;
      transform: none;
    }

    @keyframes whatsappPulse {
      0% { opacity: .65; transform: scale(.92); }
      70%, 100% { opacity: 0; transform: scale(1.35); }
    }

    /* ============================ BREAKPOINTS ============================ */

    @media (min-width: 520px) {
      .hero-actions {
        display: flex;
        flex-wrap: wrap;
      }

      .hero-proof {
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }

      .proof-item {
        align-items: flex-start;
      }

      .quote-data {
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }

      .footer-bottom {
        flex-direction: row;
        justify-content: space-between;
      }
    }

    @media (min-width: 760px) {
      :root {
        --header-height: 84px;
      }

      .container {
        width: min(100% - 48px, var(--max-width));
      }

      .hero {
        padding-bottom: 82px;
      }

      .hero-media {
        min-height: 520px;
      }

      .truck-frame img,
      .truck-frame {
        min-height: 500px;
      }

      .service-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }

      .service-card:nth-child(2) {
        transform: translateY(18px);
      }

      .service-card:nth-child(2):hover {
        transform: translateY(11px);
      }

      .structure-panel {
        padding: 32px;
      }

      .spec-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }

      .gallery-heading span {
        display: inline;
      }

      .gallery-item {
        min-width: 360px;
      }

      .footer-grid {
        grid-template-columns: 1.5fr 1fr;
        align-items: start;
      }
    }

    @media (min-width: 980px) {
      .desktop-nav {
        display: flex;
        align-items: center;
        gap: 30px;
      }

      .desktop-nav a {
        position: relative;
        color: rgba(255,255,255,.76);
        font-family: var(--font-display);
        font-size: .8rem;
        font-weight: 760;
        letter-spacing: .035em;
        text-transform: uppercase;
        transition: color var(--transition);
      }

      .desktop-nav a::after {
        position: absolute;
        right: 0;
        bottom: -8px;
        left: 0;
        height: 2px;
        background: var(--cyan);
        content: "";
        transform: scaleX(0);
        transition: transform var(--transition);
      }

      .desktop-nav a:hover,
      .desktop-nav a.active {
        color: var(--white);
      }

      .desktop-nav a:hover::after,
      .desktop-nav a.active::after {
        transform: scaleX(1);
      }

      .header-cta {
        display: inline-flex;
        min-height: 46px;
        padding: 12px 18px;
      }

      .menu-toggle,
      .mobile-menu {
        display: none;
      }

      .hero-grid {
        grid-template-columns: minmax(0, 1.05fr) minmax(420px, .95fr);
        gap: 36px;
      }

      .hero h1 {
        font-size: clamp(3.1rem, 5.2vw, 5.25rem);
      }

      .hero-proof {
        max-width: 760px;
      }

      .structure-panel {
        grid-template-columns: minmax(350px, .8fr) minmax(0, 1.2fr);
        gap: 42px;
        padding: 38px;
      }

      .structure-photo,
      .structure-photo img {
        min-height: 610px;
      }

      .trust-grid {
        grid-template-columns: minmax(0, 1.15fr) minmax(400px, .85fr);
        gap: 54px;
      }

      .driver-profile {
        grid-template-columns: 164px minmax(0, 1fr);
        gap: 22px;
        padding: 16px;
      }

      .driver-photo,
      .driver-photo img {
        min-height: 208px;
      }

      .driver-profile-copy {
        padding-right: 16px;
      }

      .driver-profile p {
        max-width: 520px;
        font-size: .9rem;
      }

      .quote-card {
        position: sticky;
        top: calc(var(--header-height) + 28px);
      }

      .truck-gallery {
        display: grid;
        grid-template-columns: 1.15fr .85fr .85fr;
        overflow: visible;
        padding-bottom: 0;
      }

      .gallery-item {
        min-width: 0;
        min-height: 320px;
      }

      .gallery-item img {
        min-height: 320px;
      }

      .gallery-item:first-child {
        min-height: 380px;
      }

      .gallery-item:first-child img {
        min-height: 380px;
      }

      .gallery-item:nth-child(2) {
        transform: translateY(22px);
      }
    }

    @media (min-width: 1280px) {
      .hero-grid {
        gap: 56px;
      }

      .hero-media {
        min-height: 600px;
      }

      .truck-frame,
      .truck-frame img {
        min-height: 570px;
      }

      .service-card {
        padding: 32px;
      }

      .quote-card {
        padding: 36px;
      }
    }

    @media (min-width: 1700px) {
      :root {
        --max-width: 1420px;
      }

      .hero-grid {
        grid-template-columns: 1.05fr .95fr;
      }

      .hero h1 {
        max-width: 980px;
      }
    }

    @media (max-width: 420px) {
      .hero h1 {
        font-size: clamp(2.35rem, 12vw, 3.3rem);
      }

      .hero-actions .btn,
      .structure-copy .btn {
        width: 100%;
      }

      .proof-item {
        min-height: 54px;
      }

      .hero-media {
        min-height: 360px;
      }

      .truck-frame,
      .truck-frame img {
        min-height: 350px;
      }

      .hero-model {
        max-width: 150px;
      }

      .spec-grid {
        grid-template-columns: 1fr;
      }

      .spec {
        min-height: 90px;
      }

      .quote-data {
        grid-template-columns: 1fr;
      }

      .driver-profile {
        grid-template-columns: 94px minmax(0, 1fr);
        gap: 12px;
        padding: 10px;
        border-radius: 20px;
      }

      .driver-photo,
      .driver-photo img {
        min-height: 148px;
      }

      .driver-profile-copy {
        padding-right: 3px;
      }

      .driver-profile h3 {
        font-size: 1.18rem;
      }

      .driver-profile p {
        font-size: .75rem;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      html {
        scroll-behavior: auto;
      }

      *,
      *::before,
      *::after {
        scroll-behavior: auto !important;
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
      }

      .reveal {
        opacity: 1;
        transform: none;
      }
    }

    /* ===================== BLOCO DO MOTORISTA ===================== */

    .driver-highlight {
      display: grid;
      gap: 18px;
      align-items: center;
      margin: 28px 0 30px;
      padding: 18px;
      background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
      border: 1px solid var(--gray-200);
      border-radius: 22px;
      box-shadow: 0 14px 34px rgba(7,20,38,.08);
    }

    .driver-photo {
      position: relative;
      overflow: hidden;
      min-height: 320px;
      background: var(--gray-100);
      border-radius: 18px;
    }

    .driver-photo::after {
      position: absolute;
      inset: auto 0 0 0;
      height: 40%;
      background: linear-gradient(180deg, transparent, rgba(7,20,38,.08));
      content: "";
      pointer-events: none;
    }

    .driver-photo img {
      width: 100%;
      height: 100%;
      min-height: 320px;
      object-fit: cover;
      object-position: center top;
      filter: contrast(1.05) saturate(1.03);
    }

    .driver-info h3 {
      margin-bottom: 10px;
      font-size: clamp(1.6rem, 4vw, 2.3rem);
      font-weight: 900;
      text-transform: uppercase;
    }

    .driver-label {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 12px;
      color: var(--blue);
      font-family: var(--font-display);
      font-size: .76rem;
      font-weight: 850;
      letter-spacing: .12em;
      text-transform: uppercase;
    }

    .driver-label::before {
      width: 10px;
      height: 10px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--blue), var(--cyan));
      content: "";
      box-shadow: 0 0 0 6px rgba(8,104,242,.08);
    }

    .driver-info p {
      margin-bottom: 14px;
      color: var(--gray-500);
    }

    .driver-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
    }

    .driver-meta span {
      display: inline-flex;
      align-items: center;
      min-height: 38px;
      padding: 8px 12px;
      color: var(--gray-700);
      background: var(--gray-100);
      border: 1px solid var(--gray-200);
      border-radius: 999px;
      font-size: .8rem;
      font-weight: 700;
      line-height: 1.2;
    }

    @media (min-width: 760px) {
      .driver-highlight {
        grid-template-columns: 260px minmax(0, 1fr);
        padding: 20px;
      }

      .driver-photo,
      .driver-photo img {
        min-height: 360px;
      }
    }

    @media (min-width: 980px) {
      .driver-highlight {
        grid-template-columns: 280px minmax(0, 1fr);
        gap: 22px;
      }
    }


    /* =========================================================
       AJUSTES DE HIERARQUIA, CARDS DO MOTORISTA E GALERIA FINAL
       ========================================================= */

    .trust-heading {
      max-width: 980px;
      margin-bottom: 34px;
    }

    .trust-heading .section-title {
      max-width: 920px;
      margin-bottom: 18px;
    }

    .trust-heading > p {
      max-width: 760px;
      margin-bottom: 0;
      color: var(--gray-500);
      font-size: 1.02rem;
    }

    .driver-cards-grid {
      display: grid;
      gap: 20px;
      margin-bottom: 54px;
    }

    .driver-highlight {
      margin: 0;
      height: 100%;
    }

    .benefits-card {
      position: relative;
      height: 100%;
      overflow: hidden;
      padding: 24px;
      color: var(--white);
      background:
        radial-gradient(circle at 100% 0, rgba(57,213,255,.2), transparent 34%),
        linear-gradient(145deg, var(--navy), var(--dark-soft));
      border: 1px solid rgba(255,255,255,.1);
      border-radius: 22px;
      box-shadow: 0 18px 46px rgba(7,20,38,.18);
      isolation: isolate;
    }

    .benefits-card::after {
      position: absolute;
      right: -54px;
      bottom: -70px;
      z-index: -1;
      width: 190px;
      height: 190px;
      opacity: .13;
      border: 30px solid var(--cyan);
      border-radius: 50%;
      content: "";
    }

    .benefits-label {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      margin-bottom: 14px;
      color: var(--cyan);
      font-family: var(--font-display);
      font-size: .74rem;
      font-weight: 850;
      letter-spacing: .12em;
      text-transform: uppercase;
    }

    .benefits-label::before {
      width: 26px;
      height: 3px;
      background: currentColor;
      content: "";
    }

    .benefits-card h3 {
      max-width: 560px;
      margin-bottom: 22px;
      font-size: clamp(1.55rem, 3vw, 2.25rem);
      font-weight: 900;
      text-transform: uppercase;
    }

    .benefits-grid {
      display: grid;
      gap: 10px;
    }

    .benefit-card-item {
      display: flex;
      align-items: flex-start;
      gap: 11px;
      min-height: 58px;
      padding: 13px 14px;
      color: rgba(255,255,255,.86);
      background: rgba(255,255,255,.065);
      border: 1px solid rgba(255,255,255,.1);
      border-radius: 14px;
      line-height: 1.35;
    }

    .benefit-card-item .check-icon {
      margin-top: 0;
      background: linear-gradient(135deg, var(--blue), var(--blue-bright));
      box-shadow: 0 8px 18px rgba(8,104,242,.28);
    }

    .gallery-block {
      margin-top: 0;
    }

    .truck-gallery .quote-card {
      min-width: min(86vw, 360px);
      min-height: 320px;
      flex: 1 0 auto;
      scroll-snap-align: start;
    }

    .quote-card-gallery {
      display: flex;
      flex-direction: column;
      justify-content: center;
    }

    .quote-card-gallery .quote-data {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    @media (min-width: 760px) {
      .driver-cards-grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        align-items: stretch;
      }

      .driver-highlight {
        grid-template-columns: 220px minmax(0, 1fr);
      }

      .driver-photo,
      .driver-photo img {
        min-height: 100%;
      }

      .benefits-card {
        padding: 28px;
      }

      .benefits-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media (min-width: 980px) {
      .trust-grid {
        display: block;
        margin-bottom: 0;
      }

      .driver-cards-grid {
        grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
        gap: 24px;
      }

      .driver-highlight {
        grid-template-columns: 250px minmax(0, 1fr);
      }

      .truck-gallery {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        align-items: stretch;
      }

      .truck-gallery .quote-card {
        position: relative;
        top: auto;
        min-width: 0;
        min-height: 380px;
        align-self: stretch;
        padding: 28px;
      }

      .quote-card-gallery h3 {
        font-size: clamp(1.65rem, 2vw, 2.15rem);
      }

      .quote-card-gallery .quote-data {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media (max-width: 759px) {
      .driver-highlight {
        padding: 16px;
      }

      .driver-photo,
      .driver-photo img {
        min-height: 290px;
      }

      .benefits-card {
        padding: 22px;
      }
    }

    /* =========================================================
       AJUSTES FINAIS DE ESCALA, CARDS E FOTO DO MOTORISTA
       ========================================================= */

    /* Títulos principais mais equilibrados */
    .hero h1 {
      max-width: 760px;
      font-size: clamp(2.1rem, 5.4vw, 4.15rem);
      line-height: 1.02;
      letter-spacing: -0.045em;
    }

    .services-header .section-title {
      max-width: 760px;
      font-size: clamp(1.75rem, 3.6vw, 3.15rem);
      line-height: 1.06;
    }

    /* Cards de serviço mais compactos */
    .service-grid {
      gap: 14px;
      margin-bottom: 42px;
    }

    .service-card {
      min-height: 220px;
      padding: 21px;
      border-radius: 18px;
    }

    .service-icon {
      width: 48px;
      height: 48px;
      margin-bottom: 23px;
      border-radius: 14px;
    }

    .service-icon svg {
      width: 24px;
      height: 24px;
    }

    .service-card h3 {
      margin-bottom: 9px;
      font-size: 1.12rem;
      line-height: 1.12;
    }

    .service-card p {
      font-size: .9rem;
      line-height: 1.48;
    }

    /* Painel de estrutura e especificações em escala menor */
    .structure-panel {
      gap: 22px;
      padding: 20px;
      border-radius: 25px;
    }

    .structure-copy h3 {
      margin-bottom: 20px;
      font-size: clamp(1.65rem, 3.7vw, 2.85rem);
    }

    .spec-grid {
      gap: 8px;
      margin-bottom: 18px;
    }

    .spec {
      min-height: 88px;
      padding: 12px;
      border-radius: 13px;
    }

    .spec strong {
      font-size: clamp(1.25rem, 3.6vw, 1.9rem);
    }

    .spec span {
      font-size: .71rem;
    }

    /* Cards do motorista e diferenciais */
    .trust-heading {
      margin-bottom: 27px;
    }

    .trust-heading .section-title {
      max-width: 790px;
      font-size: clamp(1.8rem, 3.8vw, 3.25rem);
    }

    .driver-cards-grid {
      gap: 16px;
      margin-bottom: 40px;
    }

    .driver-highlight {
      gap: 14px;
      padding: 14px;
      border-radius: 18px;
    }

    /* Remove o espaço cinza: a foto passa a preencher integralmente o quadro */
    .driver-photo {
      width: 100%;
      min-height: 0;
      aspect-ratio: 4 / 5;
      background: transparent;
      border-radius: 15px;
    }

    .driver-photo img {
      display: block;
      width: 100%;
      height: 100%;
      min-height: 0;
      object-fit: cover;
      object-position: center 18%;
    }

    .driver-info h3 {
      margin-bottom: 7px;
      font-size: clamp(1.35rem, 3vw, 1.9rem);
    }

    .driver-label {
      margin-bottom: 9px;
      font-size: .68rem;
    }

    .driver-info p {
      margin-bottom: 11px;
      font-size: .88rem;
      line-height: 1.48;
    }

    .driver-meta {
      gap: 7px;
    }

    .driver-meta span {
      min-height: 32px;
      padding: 6px 9px;
      font-size: .72rem;
    }

    .benefits-card {
      padding: 20px;
      border-radius: 18px;
    }

    .benefits-card h3 {
      margin-bottom: 16px;
      font-size: clamp(1.35rem, 2.5vw, 1.85rem);
    }

    .benefits-label {
      margin-bottom: 10px;
      font-size: .68rem;
    }

    .benefits-grid {
      gap: 8px;
    }

    .benefit-card-item {
      min-height: 48px;
      gap: 9px;
      padding: 10px 11px;
      border-radius: 12px;
      font-size: .84rem;
    }

    .benefit-card-item .check-icon {
      width: 22px;
      height: 22px;
    }

    /* Galeria e orçamento mais compactos */
    .gallery-heading {
      margin-bottom: 14px;
    }

    .gallery-heading h3 {
      font-size: clamp(1.25rem, 2.4vw, 1.7rem);
    }

    .gallery-item {
      min-height: 245px;
      border-radius: 17px;
    }

    .gallery-item img {
      min-height: 245px;
    }

    .truck-gallery .quote-card {
      min-height: 300px;
      padding: 21px;
      border-radius: 20px;
    }

    .quote-card-gallery h3 {
      margin-bottom: 11px;
      font-size: clamp(1.4rem, 2.6vw, 1.85rem);
    }

    .quote-card-gallery > p {
      margin-bottom: 16px;
      font-size: .88rem;
      line-height: 1.45;
    }

    .quote-card-gallery .quote-data {
      gap: 7px;
      margin-bottom: 17px;
    }

    .quote-card-gallery .quote-data li {
      min-height: 42px;
      padding: 7px 8px;
      font-size: .7rem;
    }

    @media (min-width: 760px) {
      .driver-highlight {
        grid-template-columns: 190px minmax(0, 1fr);
        align-items: stretch;
      }

      .driver-photo {
        height: 100%;
        min-height: 300px;
        aspect-ratio: auto;
      }

      .benefits-card {
        padding: 22px;
      }
    }

    @media (min-width: 980px) {
      .hero h1 {
        font-size: clamp(3rem, 4.4vw, 4.45rem);
      }

      .driver-cards-grid {
        grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
        gap: 18px;
      }

      .driver-highlight {
        grid-template-columns: 210px minmax(0, 1fr);
      }

      .structure-panel {
        grid-template-columns: minmax(320px, .78fr) minmax(0, 1.22fr);
        gap: 32px;
        padding: 28px;
      }

      .structure-photo,
      .structure-photo img {
        min-height: 500px;
      }

      .truck-gallery .quote-card {
        min-height: 330px;
        padding: 22px;
      }

      .gallery-item,
      .gallery-item img,
      .gallery-item:first-child,
      .gallery-item:first-child img {
        min-height: 330px;
      }
    }

    @media (max-width: 759px) {
      .driver-highlight {
        padding: 12px;
      }

      .driver-photo,
      .driver-photo img {
        min-height: 0;
      }

      .benefits-card {
        padding: 18px;
      }
    }
