
.hero-image-container {
  min-height: 220px !important;
  height: 220px !important;
}
@media (min-width: 768px) {
  .hero-image-container {
    min-height: 280px !important;
    height: 280px !important;
  }
}
/* Tipografia: moto sans (headlines) + Gotham (body) — Brand VI section 06 */
    @font-face { font-family: 'moto sans'; src: url('../fonts/MotoSans-Regular.woff2') format('woff2'), url('../fonts/MotoSans-Regular.woff') format('woff'); font-weight: 400; font-style: normal; font-display: swap; }
    @font-face { font-family: 'moto sans'; src: url('../fonts/MotoSans-Italic.woff2') format('woff2'), url('../fonts/MotoSans-Italic.woff') format('woff'); font-weight: 400; font-style: italic; font-display: swap; }
    @font-face { font-family: 'Gotham Medium'; src: url('../fonts/gotham-medium.woff') format('woff'); font-weight: 500; font-style: normal; font-display: swap; }

    /* Motorola Global Brand Identity — Core palette (Nov 2025) */
    :root {
      --moto-black: #131417;
      --white: #FFFFFF;
      --frost: #E9EAF2;
      --pearl: #F0EDE9;
      --slate-blue: #636880;
      --sandstone: #7A7670;
      --moto-indigo: var(--slate-blue);
      --header-h: 88px;
    }

    html {
      overflow-x: hidden;
      -webkit-text-size-adjust: 100%;
    }
    body {
      font-family: 'Gotham Medium', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
      font-size: 1rem;
      line-height: 1.5;
      background: radial-gradient(900px 520px at 70% 5%, rgba(99,104,128,.10), transparent 60%), #fff;
      color: var(--moto-black);
      overflow-x: hidden;
      -webkit-tap-highlight-color: transparent;
    }
    
    /* Fallback caso a fonte não carregue */
    @supports not (font-display: swap) {
        body {
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
        }
    }
    h1, h2, h3, h4, .moto-headline, .nav-link { 
        font-family: 'moto sans', system-ui, sans-serif !important; 
        letter-spacing: -0.01em; 
        text-transform: lowercase !important; 
        line-height: 0.84;
    }
    
    /* Forçar lowercase em todos os elementos que usam motosans - sobrescreve qualquer uppercase */
    .moto-headline, h1, h2, h3, h4, h5, h6,
    .moto-headline.uppercase,
    h1.uppercase, h2.uppercase, h3.uppercase, h4.uppercase, h5.uppercase, h6.uppercase,
    [class*="moto-headline"],
    [class*="uppercase"].moto-headline,
    .text-uppercase.moto-headline,
    span.moto-headline, div.moto-headline, a.moto-headline,
    .moto-headline[class*="uppercase"],
    *[class*="moto-headline"][class*="uppercase"] {
      text-transform: lowercase !important;
    }

    /* Layout global */
    .app-shell {
      padding-top: calc(var(--header-h) + env(safe-area-inset-top));
      padding-bottom: env(safe-area-inset-bottom);
    }
    .section-hidden { display: none; }

    @media (max-width: 640px) {
      :root { --header-h: 72px; }
    }

    /* Tabelas: acessibilidade e destaque de comparação (brand) */
    .table-spec thead tr { background: var(--frost); }
    .table-spec th { color: var(--moto-black); }
    .table-spec .th-destaque { color: var(--slate-blue); }
    .table-spec tbody tr { transition: background 0.15s ease; }
    .table-spec tbody tr:hover { background: rgba(99,104,128,0.06); }
    .table-spec .cell-evolucao { background: rgba(99,104,128,0.14); color: var(--moto-black); font-weight: 600; }
    .table-spec td, .table-spec th { font-size: 0.9375rem; line-height: 1.45; }
    button:focus-visible, a:focus-visible, input:focus-visible, [tabindex]:focus-visible { outline: 2px solid var(--slate-blue); outline-offset: 2px; }

    /* Header: modo compacto (telas bem estreitas, ex.: iPhone 14) */
    @media (max-width: 420px) {
      header .header-inner { padding-left: 12px !important; padding-right: 12px !important; }
      header .moto-logo { height: 24px !important; }
      header .header-actions .home-text { display: none !important; }
      header .header-actions .home-icon { display: inline-flex !important; }
      header #comparativo-select {
        max-width: 210px;
        padding-left: 12px;
        padding-right: 12px;
        font-size: 11px;
        text-overflow: ellipsis;
        overflow: hidden;
        white-space: nowrap;
      }
    }

    /* Android “largura intermediária”: evita comprimir logo */
    @media (max-width: 520px) {
      header .moto-logo { flex-shrink: 0; width: auto; }
      header .header-actions #btn-home { padding-left: 12px; padding-right: 12px; }
      /* se estiver apertando, prioriza ícone no botão Início */
      header .header-actions .home-text { display: none; }
      header .header-actions .home-icon { display: inline-flex; }
      header #comparativo-select { max-width: min(60vw, 260px); }
    }

    /* --- G17 vs G15, G67 vs G56 e Edge 70 Fusion vs Edge 60 Fusion (namespaced) --- */
    #g17-root .fade-in-up, #g47-root .fade-in-up, #g67-root .fade-in-up, #edge-fusion-root .fade-in-up, #edge-fusion-plus-root .fade-in-up { animation: g17_fadeInUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards; opacity: 0; transform: translateY(30px); }
    #g17-root .delay-100, #g47-root .delay-100, #g67-root .delay-100, #edge-fusion-root .delay-100, #edge-fusion-plus-root .delay-100 { animation-delay: 0.1s; }
    #g17-root .delay-200, #g47-root .delay-200, #g67-root .delay-200, #edge-fusion-root .delay-200, #edge-fusion-plus-root .delay-200 { animation-delay: 0.2s; }
    @keyframes g17_fadeInUp { to { opacity: 1; transform: translateY(0); } }

    /* Animação fade-in-up genérica para comparativos do renderer (razr70, edge70, futuros) */
    .evo-shell .fade-in-up { animation: g17_fadeInUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards; opacity: 0; transform: translateY(30px); }

    #g17-root .compare-container,
    #g47-root .compare-container,
    #g67-root .compare-container,
    #edge-fusion-root .compare-container,
    #edge-fusion-plus-root .compare-container {
      position: relative;
      height: clamp(340px, 70vh, 520px);
      overflow: hidden;
      border-radius: 24px;
      box-shadow: 0 20px 50px rgba(0,0,0,0.10);
      cursor: ew-resize;
      background: #f0f0f0;
      user-select: none;
      /* permite scroll vertical no mobile */
      touch-action: pan-y;
    }
    #g17-root .compare-container.compare-tall,
    #g47-root .compare-container.compare-tall,
    #g67-root .compare-container.compare-tall,
    #edge-fusion-root .compare-container.compare-tall,
    #edge-fusion-plus-root .compare-container.compare-tall { height: clamp(420px, 78vh, 620px); }
    #g17-root .layer-base, #g47-root .layer-base, #g67-root .layer-base, #edge-fusion-root .layer-base, #edge-fusion-plus-root .layer-base { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; z-index: 1; }
    #g17-root .layer-base img, #g47-root .layer-base img, #g67-root .layer-base img, #edge-fusion-root .layer-base img, #edge-fusion-plus-root .layer-base img { height: 88%; width: auto; max-width: 92%; object-fit: contain; }
    #g17-root .img-overlay, #g47-root .img-overlay, #g67-root .img-overlay, #edge-fusion-root .img-overlay, #edge-fusion-plus-root .img-overlay { position: absolute; top: 0; left: 0; bottom: 0; width: 100%; overflow: hidden; background: white; border-right: 2px solid white; z-index: 10; will-change: clip-path; clip-path: inset(0 50% 0 0); }
    #g17-root .overlay-inner-wrapper, #g47-root .overlay-inner-wrapper, #g67-root .overlay-inner-wrapper, #edge-fusion-root .overlay-inner-wrapper, #edge-fusion-plus-root .overlay-inner-wrapper { position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
    #g17-root .overlay-inner-wrapper img, #g47-root .overlay-inner-wrapper img, #g67-root .overlay-inner-wrapper img, #edge-fusion-root .overlay-inner-wrapper img, #edge-fusion-plus-root .overlay-inner-wrapper img { height: 88%; width: auto; max-width: 92%; object-fit: contain; }
    #g17-root .photo-fit, #g47-root .photo-fit, #g67-root .photo-fit, #edge-fusion-root .photo-fit, #edge-fusion-plus-root .photo-fit { width: 100%; height: 100%; object-fit: cover; }
    #g17-root .slider-handle, #g47-root .slider-handle, #g67-root .slider-handle, #edge-fusion-root .slider-handle, #edge-fusion-plus-root .slider-handle { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 48px; height: 48px; background: var(--moto-indigo); border: 4px solid white; border-radius: 50%; display: flex; align-items: center; justify-content: center; z-index: 20; box-shadow: 0 8px 22px rgba(0,0,0,0.28); pointer-events: none; will-change: left; }
    #g17-root .label-badge, #g47-root .label-badge, #g67-root .label-badge, #edge-fusion-root .label-badge, #edge-fusion-plus-root .label-badge { position: absolute; bottom: 18px; padding: 8px 14px; border-radius: 10px; font-weight: 800; font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; z-index: 15; }
    #g17-root .compare-container.is-idle .slider-handle, #g47-root .compare-container.is-idle .slider-handle, #g67-root .compare-container.is-idle .slider-handle, #edge-fusion-root .compare-container.is-idle .slider-handle, #edge-fusion-plus-root .compare-container.is-idle .slider-handle { animation: g17_handlePulse 1.6s ease-in-out infinite; }
    @keyframes g17_handlePulse { 0%, 100% { transform: translate(-50%, -50%) scale(1); } 50% { transform: translate(-50%, -50%) scale(1.06); } }
    #g17-root .quality-low::after,
    #g47-root .quality-low::after,
    #g67-root .quality-low::after {
      content: "";
      position: absolute;
      inset: 0;
      background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='140'%20height='140'%3E%3Crect%20width='140'%20height='140'%20fill='transparent'/%3E%3Cg%20fill='%23ffffff'%20opacity='0.22'%3E%3Ccircle%20cx='8'%20cy='14'%20r='1'/%3E%3Ccircle%20cx='22'%20cy='48'%20r='1'/%3E%3Ccircle%20cx='41'%20cy='31'%20r='1'/%3E%3Ccircle%20cx='63'%20cy='76'%20r='1'/%3E%3Ccircle%20cx='91'%20cy='23'%20r='1'/%3E%3Ccircle%20cx='112'%20cy='64'%20r='1'/%3E%3Ccircle%20cx='129'%20cy='101'%20r='1'/%3E%3Ccircle%20cx='18'%20cy='112'%20r='1'/%3E%3Ccircle%20cx='58'%20cy='118'%20r='1'/%3E%3Ccircle%20cx='99'%20cy='124'%20r='1'/%3E%3Ccircle%20cx='74'%20cy='12'%20r='1'/%3E%3Ccircle%20cx='6'%20cy='86'%20r='1'/%3E%3Ccircle%20cx='132'%20cy='38'%20r='1'/%3E%3C/g%3E%3C/svg%3E");
      background-size: 140px 140px;
      mix-blend-mode: overlay;
      opacity: 0.7;
      pointer-events: none;
    }
    /* ===== PDF padrão (A4 em px) =====
       1122x1587 ≈ A4 em ~96dpi. Isso evita “folha sobrando” no canvas. */
    .pdf-report {
      display: none;
      width: 1122px;
      background: white;
      padding: 0;
      box-sizing: border-box;
      position: fixed;
      top: 0;
      left: -9999px;
      z-index: 99999;
    }
    @media (max-width: 640px) {
      #g17-root .label-badge, #g47-root .label-badge, #g67-root .label-badge, #edge-fusion-root .label-badge, #edge-fusion-plus-root .label-badge { bottom: 12px; padding: 6px 10px; font-size: 10px; border-radius: 9px; }
    }

    /* iOS/Safari: evita jumps com 100vh e toolbar (usa dvh quando suportado) */
    @supports (height: 70dvh) {
      #g17-root .compare-container, #g47-root .compare-container, #g67-root .compare-container, #edge-fusion-root .compare-container, #edge-fusion-plus-root .compare-container { height: clamp(340px, 70dvh, 520px); }
      #g17-root .compare-container.compare-tall, #g47-root .compare-container.compare-tall, #g67-root .compare-container.compare-tall, #edge-fusion-root .compare-container.compare-tall, #edge-fusion-plus-root .compare-container.compare-tall { height: clamp(420px, 78dvh, 620px); }
    }

    /* Mobile: evita badge cortar/ficar sob barras do navegador */
    @media (max-width: 640px) {
      #g17-root .label-badge, #g47-root .label-badge, #g67-root .label-badge, #edge-fusion-root .label-badge, #edge-fusion-plus-root .label-badge {
        top: 12px;
        bottom: auto;
        max-width: 46%;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
      }
    #g17-root .label-badge.left-6, #g47-root .label-badge.left-6, #g67-root .label-badge.left-6, #edge-fusion-root .label-badge.left-6, #edge-fusion-plus-root .label-badge.left-6 { left: 12px !important; }
    #g17-root .label-badge.right-6, #g47-root .label-badge.right-6, #g67-root .label-badge.right-6, #edge-fusion-root .label-badge.right-6, #edge-fusion-plus-root .label-badge.right-6 { right: 12px !important; }
    }

    @media (max-width: 380px) {
      #g17-root .compare-container, #g47-root .compare-container, #g67-root .compare-container, #edge-fusion-root .compare-container, #edge-fusion-plus-root .compare-container {
        height: clamp(300px, 62dvh, 460px);
        border-radius: 16px;
      }
      #g17-root .compare-container.compare-tall, #g47-root .compare-container.compare-tall, #g67-root .compare-container.compare-tall, #edge-fusion-root .compare-container.compare-tall, #edge-fusion-plus-root .compare-container.compare-tall {
        height: clamp(360px, 68dvh, 540px);
      }
      #g17-root .slider-handle, #g47-root .slider-handle, #g67-root .slider-handle, #edge-fusion-root .slider-handle, #edge-fusion-plus-root .slider-handle {
        width: 42px;
        height: 42px;
        border-width: 3px;
      }
      #g17-root .label-badge, #g47-root .label-badge, #g67-root .label-badge, #edge-fusion-root .label-badge, #edge-fusion-plus-root .label-badge {
        font-size: 9px;
        padding: 5px 8px;
        max-width: calc(50% - 14px);
      }
    }

    /* Métricas G67 / Fusion: barras não estouram em ecrãs estreitos */
    @media (max-width: 480px) {
      #g67-root #g67-tela .flex.items-center.gap-3 .flex-1,
      #edge-fusion-root #ef-comparativo .flex.items-center.gap-3 .flex-1,
      #edge-fusion-plus-root #efp-comparativo .flex.items-center.gap-3 .flex-1 {
        min-width: 0;
      }
      #g67-root #g67-tela .flex.items-center.gap-3,
      #edge-fusion-root #ef-comparativo .border-2.rounded-2xl .flex.items-center.gap-3,
      #edge-fusion-plus-root #efp-comparativo .border-2.rounded-2xl .flex.items-center.gap-3 {
        flex-wrap: wrap;
        row-gap: 6px;
      }
    }

    /* Edge Fusion: animação das barras de evolução */
    #edge-fusion-root .ef-metric-bar,
    #edge-fusion-plus-root .ef-plus-metric-bar { transition: width 1s cubic-bezier(0.22, 1, 0.36, 1); }

    /* Edge Fusion: visual 120 Hz vs 144 Hz — linha vai até o final; menos passos = mais travado */
    @keyframes ef-hz-scan {
      0% { left: 0; }
      100% { left: 90%; }
    }
    #edge-fusion-root .ef-hz-screen {
      position: relative;
      height: 64px;
      border-radius: 12px;
      overflow: hidden;
      background: linear-gradient(180deg, #1a1a2e 0%, #16213e 100%);
    }
    #edge-fusion-root .ef-hz-scan-line {
      position: absolute;
      top: 0;
      bottom: 0;
      width: 10%;
      left: 0;
      background: linear-gradient(90deg, transparent, rgba(255,255,255,0.5), transparent);
      box-shadow: 0 0 24px rgba(255,255,255,0.25);
    }
    /* 120 Hz: 24 passos = movimento mais "travado" e visível */
    #edge-fusion-root .ef-hz-120 .ef-hz-scan-line {
      animation: ef-hz-scan 2.4s steps(24, end) infinite;
    }
    /* 144 Hz: 72 passos = mais fluido (diferença bem visível) */
    #edge-fusion-root .ef-hz-144 .ef-hz-scan-line {
      animation: ef-hz-scan 2.4s steps(72, end) infinite;
    }

    /* Edge Fusion: overlay referência (diferença sutil — evolução visível sem depreciar o 700C) */
    #edge-fusion-root .ef-sensor-inferior {
      filter: brightness(0.90) contrast(0.98) saturate(0.97);
    }
    #edge-fusion-root .ef-sensor-grain {
      position: absolute;
      inset: 0;
      pointer-events: none;
      opacity: 0.06;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
      background-repeat: repeat;
    }
    /* Slider do sensor: barra superior (aparelhos) + corpo com imagens */
    #edge-fusion-root .ef-sensor-slider-container {
      display: flex;
      flex-direction: column;
    }
    #edge-fusion-root .ef-sensor-slider-body {
      flex: 1;
      min-height: 0;
      position: relative;
    }
    #edge-fusion-root .ef-sensor-slider-container .layer-base img,
    #edge-fusion-root .ef-sensor-slider-container .overlay-inner-wrapper img {
      height: 100%;
      width: 100%;
      max-width: none;
      object-fit: cover;
    }
    #edge-fusion-root .ef-sensor-slider-container .overlay-inner-wrapper {
      width: 100%;
      left: 0;
    }

    /* Edge Fusion+: 120/144 Hz, sensor slider, KV */
    #edge-fusion-plus-root .ef-plus-hz-screen {
      position: relative;
      height: 52px;
      max-height: 64px;
      border-radius: 10px;
      overflow: hidden;
      background: linear-gradient(180deg, #1a1a2e 0%, #16213e 100%);
    }
    #edge-fusion-plus-root .ef-plus-hz-scan-line {
      position: absolute;
      top: 0;
      bottom: 0;
      width: 10%;
      left: 0;
      background: linear-gradient(90deg, transparent, rgba(255,255,255,0.5), transparent);
      box-shadow: 0 0 24px rgba(255,255,255,0.25);
    }
    #edge-fusion-plus-root .ef-plus-hz-120 .ef-plus-hz-scan-line {
      animation: ef-hz-scan 2.4s steps(24, end) infinite;
    }
    #edge-fusion-plus-root .ef-plus-hz-144 .ef-plus-hz-scan-line {
      animation: ef-hz-scan 2.4s steps(72, end) infinite;
    }
    #edge-fusion-plus-root .efp-sensor-inferior {
      filter: brightness(0.90) contrast(0.98) saturate(0.97);
    }
    #edge-fusion-plus-root .efp-sensor-grain {
      position: absolute;
      inset: 0;
      pointer-events: none;
      opacity: 0.06;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
      background-repeat: repeat;
    }
    #edge-fusion-plus-root .efp-sensor-slider-container {
      display: flex;
      flex-direction: column;
    }
    #edge-fusion-plus-root .efp-sensor-slider-body {
      flex: 1;
      min-height: 0;
      position: relative;
    }
    #edge-fusion-plus-root .efp-sensor-slider-container .layer-base img,
    #edge-fusion-plus-root .efp-sensor-slider-container .overlay-inner-wrapper img {
      height: 100%;
      width: 100%;
      max-width: none;
      object-fit: cover;
    }
    #edge-fusion-plus-root .efp-sensor-slider-container .overlay-inner-wrapper {
      width: 100%;
      left: 0;
    }
    #edge-fusion-plus-root .efp-card-destaque {
      transition: transform 0.25s ease, box-shadow 0.25s ease;
    }
    #edge-fusion-plus-root .efp-card-destaque:hover {
      transform: translateY(-2px);
      box-shadow: 0 12px 28px rgba(99,104,128,0.12);
    }
    /* KV Fusion+: tamanho controlado + marcadores tipo alvo nas câmeras */
    #edge-fusion-plus-root .efp-kv-wrap {
      max-width: 100%;
      width: 100%;
    }
    #edge-fusion-plus-root .efp-kv-wrap img {
      display: block;
      width: 100%;
      height: auto;
      max-height: 380px;
      object-fit: contain;
    }
    /* Carrossel de fotos tiradas com o aparelho */
    #edge-fusion-plus-root .efp-gallery-carousel {
      position: relative;
      border-radius: 16px;
      overflow: hidden;
      background: #f8f9fa;
    }
    /* No mobile, o KV de marketing duplica o aparelho do hero — esconde pra
       não criar sequência repetitiva de fotos. No desktop fica ao lado da galeria. */
    @media (max-width: 1023px) {
      .evo-galeria-kv { display: none; }
    }
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-track {
      display: flex;
      transition: transform 0.4s ease;
    }
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-slide {
      flex: 0 0 100%;
      padding: 12px;
      box-sizing: border-box;
    }
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-slide img {
      width: 100%;
      aspect-ratio: 16 / 9;
      height: auto;
      object-fit: cover;
      border-radius: 12px;
      display: block;
    }
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-prev,
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-next {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 40px;
      height: 40px;
      border-radius: 50%;
      background: rgba(255,255,255,0.95);
      border: 2px solid #e5e7eb;
      color: #636880;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      z-index: 10;
      box-shadow: 0 4px 12px rgba(0,0,0,0.08);
      transition: background 0.2s, color 0.2s;
    }
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-prev:hover,
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-next:hover {
      background: #636880;
      color: white;
      border-color: #636880;
    }
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-prev { left: 8px; }
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-next { right: 8px; }
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-dots {
      display: flex;
      justify-content: center;
      gap: 8px;
      padding: 12px;
    }
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-dots button {
      width: 8px;
      height: 8px;
      border-radius: 50%;
      border: none;
      background: #d1d5db;
      cursor: pointer;
      transition: background 0.2s, transform 0.2s;
    }
    #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-dots button.active {
      background: #636880;
      transform: scale(1.2);
    }

    /* Edge Fusion+: mobile e telas pequenas */
    @media (max-width: 768px) {
      #edge-fusion-plus-root main { padding-left: 1rem; padding-right: 1rem; }
      #edge-fusion-plus-root .efp-kv-wrap img { max-height: 300px !important; }
      #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-slide img { aspect-ratio: 16 / 9; height: auto; }
      #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-prev,
      #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-next {
        width: 32px; height: 32px; min-width: 32px; min-height: 32px;
        font-size: 14px;
      }
      #edge-fusion-plus-root #efp-especificacoes .overflow-x-auto { -webkit-overflow-scrolling: touch; }
      #edge-fusion-plus-root #efp-especificacoes table { font-size: 12px; }
      #edge-fusion-plus-root #efp-especificacoes td, #edge-fusion-plus-root #efp-especificacoes th { padding: 10px 12px; }
      #edge-fusion-plus-root .efp-card-destaque { padding: 14px 12px; }
      #edge-fusion-plus-root .compare-container.compare-tall { min-height: 280px; }
    }
    @media (max-width: 480px) {
      #edge-fusion-plus-root .grid.lg\:grid-cols-2 { gap: 1rem; }
      #edge-fusion-plus-root .efp-gallery-carousel .efp-gallery-slide img { aspect-ratio: 16 / 9; height: auto; }
      #edge-fusion-plus-root .efp-destaques .text-lg { font-size: 1rem; }
    }

    /* G47: sensor slider (barra superior + corpo com imagens, mesmo padrão Edge) */
    #g47-root .g47-sensor-slider-container {
      display: flex;
      flex-direction: column;
    }
    #g47-root .g47-sensor-slider-body {
      flex: 1;
      min-height: 0;
      position: relative;
    }
    #g47-root .g47-sensor-slider-container .layer-base img,
    #g47-root .g47-sensor-slider-container .overlay-inner-wrapper img {
      height: 100%;
      width: 100%;
      max-width: none;
      object-fit: cover;
    }
    #g47-root .g47-sensor-slider-container .overlay-inner-wrapper {
      width: 100%;
      left: 0;
    }

    /* G67: responsividade mobile e telas menores */
    @media (max-width: 640px) {
      #g67-root main { padding-left: 1rem; padding-right: 1rem; }
      #g67-root .compare-container { border-radius: 16px; }
      #g67-root video { max-height: 50vh; }
    }
    @media (max-width: 480px) {
      #g67-root h1 img.moto-headline { height: 2.5rem; }
      #g67-root #g67-overview .rounded-3xl img.h-64 { height: 12rem; }
    }

    /* --- Edge 60 Pro vs Edge 70 (namespaced) --- */
    #edge-root { background-color: #FAFAFA; }
    #edge-root .hero-clean-bg { background: radial-gradient(circle at 70% 30%, #f3f4ff 0%, #ffffff 60%); }
    #edge-root .product-visual-wrapper { position: relative; width: 100%; max-width: 450px; height: 550px; margin: 0 auto; display: flex; align-items: center; justify-content: center; }
    #edge-root .product-img-main { width: 100%; height: 100%; object-fit: contain; }
    #edge-root .slim-badge-hero {
      position: absolute; top: 10%; right: 0;
      background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px);
      padding: 12px 24px; border-radius: 16px;
      box-shadow: 0 15px 40px rgba(0,0,0,0.12);
      border-left: 5px solid #636880;
      animation: edge_float 4s ease-in-out infinite;
      z-index: 20;
    }
    @keyframes edge_float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }

    #edge-root .comparison-wrapper {
      position: relative;
      width: 100%;
      max-width: 800px;
      height: 500px;
      margin: 0 auto;
      border-radius: 24px;
      overflow: hidden;
      background: #ffffff;
      box-shadow: 0 20px 50px rgba(0,0,0,0.08);
      user-select: none;
      border: 1px solid #f0f0f0;
      touch-action: pan-y;
    }
    #edge-root .edge-layer-base { position: absolute; inset: 0; display: flex; justify-content: center; align-items: center; z-index: 1; }
    #edge-root .edge-layer-base img { height: 80%; width: auto; object-fit: contain; }
    #edge-root .edge-layer-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; overflow: hidden; z-index: 2; border-right: 3px solid #636880; background: #f8f9fa; will-change: clip-path; clip-path: inset(0 50% 0 0); }
    #edge-root .edge-overlay-inner-wrapper { position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex; justify-content: center; align-items: center; }
    #edge-root .edge-overlay-inner-wrapper img { height: 80%; width: auto; object-fit: contain; }
    #edge-root .slider-handle-btn {
      position: absolute; top: 50%; left: 50%;
      width: 44px; height: 44px;
      background: #636880; color: white;
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      cursor: ew-resize; transform: translate(-50%, -50%);
      box-shadow: 0 4px 15px rgba(99,104,128,0.4);
      z-index: 20; font-size: 16px; border: 3px solid white; pointer-events: auto;
    }
    #edge-root .comp-badge { position: absolute; top: 25px; padding: 8px 16px; border-radius: 30px; font-size: 11px; font-weight: bold; text-transform: uppercase; letter-spacing: 0.5px; z-index: 10; pointer-events: auto; cursor: pointer; box-shadow: 0 4px 10px rgba(0,0,0,0.1); user-select: none; }
    #edge-root .comp-badge:focus-visible { outline: 3px solid rgba(99,104,128,0.35); outline-offset: 3px; }
    #edge-root .badge-old { left: 25px; background: #e5e7eb; color: #555; }
    #edge-root .badge-new { right: 25px; background: #131417; color: white; }

    #edge-root .custom-chart-row { display: flex; align-items: center; margin-bottom: 16px; gap: 10px; position: relative; }
    #edge-root .chart-label { width: 110px; font-size: 11px; font-weight: bold; color: #666; flex-shrink: 0; text-transform: uppercase; letter-spacing: 0.5px; }
    #edge-root .chart-track { flex-grow: 1; background: #f3f4f6; height: 36px; border-radius: 8px; overflow: visible; display: flex; align-items: center; position: relative; }
    #edge-root .chart-bar-inner { height: 100%; border-radius: 8px; width: 0; background: #636880; display: flex; align-items: center; justify-content: flex-end; padding-right: 12px; white-space: nowrap; transition: width 1.5s cubic-bezier(0.22, 1, 0.36, 1); overflow: hidden; }
    #edge-root .bg-gray-bar { background: #9ca3af; }
    #edge-root .chart-value { color: white; font-weight: bold; font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; line-height: 1; margin-top: 1px; }
    #edge-root .gain-badge { background: #dcfce7; color: #166534; font-size: 10px; padding: 4px 8px; border-radius: 6px; font-weight: bold; margin-left: 10px; white-space: nowrap; opacity: 0; transform: translateX(-10px); }
    #edge-root .progress-track { background-color: #E5E7EB; height: 6px; border-radius: 99px; overflow: hidden; }

    /* Seções customizadas do Edge 70 (Snapdragon/Hardware/Swarovski) na tipografia
       da marca: texto em moto sans (ícones .ph/.fa preservados, têm fonte própria)
       e SEM caixa-alta (moto sans nunca em maiúsculas) — alinha com as outras páginas. */
    #edge-snapdragon-performance, #edge-bi-data, #edge-swarovski-collection {
      font-family: 'moto sans', system-ui, sans-serif;
    }
    #edge-snapdragon-performance, #edge-snapdragon-performance *,
    #edge-bi-data, #edge-bi-data *,
    #edge-swarovski-collection, #edge-swarovski-collection * {
      text-transform: lowercase !important;
    }
    #edge-root .progress-fill { height: 100%; width: 0; border-radius: 99px; transition: width 1.5s cubic-bezier(0.22, 1, 0.36, 1); }
    #edge-root .camera-feature-box { background: #131417; color: white; border-radius: 16px; padding: 25px; margin-top: 30px; display: grid; grid-template-columns: auto 1fr; gap: 20px; align-items: center; }
    #edge-root .cam-icon-big { font-size: 32px; color: #636880; background: rgba(255,255,255,0.1); width: 60px; height: 60px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
    #edge-root .cam-info h4 { font-size: 18px; font-weight: bold; margin-bottom: 5px; color: white; }
    #edge-root .cam-info p { font-size: 12px; color: #aaa; margin-bottom: 10px; }
    #edge-root .cam-tags { display: flex; gap: 10px; }
    #edge-root .cam-tag { font-size: 10px; font-weight: bold; background: #636880; padding: 4px 10px; border-radius: 4px; color: white; }
    #edge-root .web-footer { text-align: center; padding: 40px 20px; background-color: #fff; border-top: 1px solid #eee; color: #999; font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; }

    /* PDF styles compartilhados (usado por todos os comparativos) */
    .pdf-report .print-body { padding: 40px 60px 50px 60px; }
    .pdf-report .print-header { background: #131417; padding: 25px 60px; display: flex; justify-content: space-between; align-items: center; color: white; border-bottom: 4px solid #636880; }
    .pdf-report .print-context-bar { background: #f3f4f6; padding: 10px 60px; font-size: 11px; text-transform: uppercase; letter-spacing: 1px; font-weight: bold; color: #131417; border-bottom: 1px solid #e5e7eb; display: flex; justify-content: center; align-items: center; gap: 10px; }
    .pdf-report .print-hero-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 50px; margin-bottom: 30px; align-items: center; }
    .pdf-report .visual-thickness-bar { background: #f8f9fa; border: 1px solid #eee; border-radius: 12px; padding: 20px; display: flex; flex-direction: column; gap: 15px; }
    .pdf-report .v-bar-row { display: flex; align-items: center; justify-content: space-between; }
    .pdf-report .v-bar-label { font-size: 10px; font-weight: bold; color: #555; width: 120px; }
    .pdf-report .v-bar-track { flex-grow: 1; height: 30px; display: flex; align-items: center; }
    .pdf-report .v-bar-fill { height: 100%; background: #ddd; border-radius: 4px; display: flex; align-items: center; padding-left: 10px; font-size: 10px; font-weight: bold; color: #555; }
    .pdf-report .v-bar-fill.highlight { background: linear-gradient(90deg, #636880, #8a90ab); color: white; box-shadow: 0 4px 10px rgba(99,104,128,0.2); }
    .pdf-report .print-camera-highlight { background: #fdfcff; border: 2px solid #636880; border-radius: 12px; padding: 20px; margin-bottom: 30px; display: grid; grid-template-columns: 1fr 1.5fr; gap: 30px; align-items: center; }
    .pdf-report .cam-text h4 { color: #636880; font-weight: bold; font-size: 14px; margin-bottom: 5px; text-transform: uppercase; }
    .pdf-report .cam-text p { font-size: 10px; color: #666; margin-bottom: 10px; }
    .pdf-report .cam-stat-row { display: flex; justify-content: space-between; border-bottom: 1px solid #eee; padding: 6px 0; font-size: 10px; }
    .pdf-report .print-compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin-bottom: 28px; }
    .pdf-report .compare-col { display: flex; flex-direction: column; }
    .pdf-report .compare-header { padding: 15px; border-radius: 8px 8px 0 0; text-align: center; font-weight: bold; text-transform: uppercase; letter-spacing: 1px; font-size: 12px; }
    .pdf-report .header-old { background: #f3f4f6; color: #666; }
    .pdf-report .header-new { background: #636880; color: white; }
    .pdf-report .compare-body { border: 1px solid #e5e7eb; border-top: none; border-radius: 0 0 8px 8px; padding: 20px; background: white; flex-grow: 1; }
    .pdf-report .spec-row { display: flex; justify-content: space-between; border-bottom: 1px solid #f9f9f9; padding: 10px 0; font-size: 11px; }
    .pdf-report .spec-row:last-child { border-bottom: none; }
    .pdf-report .spec-label { color: #888; font-weight: 500; }
    .pdf-report .spec-val { font-weight: bold; color: #131417; }
    .pdf-report .spec-val.highlight { color: #636880; }
    .pdf-report .pdf-chart-row { display: flex; align-items: center; margin-bottom: 12px; gap: 10px; }
    .pdf-report .pdf-chart-label { width: 130px; font-size: 11px; font-weight: bold; color: #444; }
    .pdf-report .pdf-chart-track { flex-grow: 1; height: 22px; background: #f3f4f6; border-radius: 4px; overflow: hidden; display: flex; align-items: center; }
    .pdf-report .pdf-chart-bar { height: 100%; display: flex; align-items: center; justify-content: flex-end; padding-right: 12px; color: white; font-size: 9px; font-weight: bold; border-radius: 4px; white-space: nowrap; }
    .pdf-report .footer-grid-box { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 25px; margin-top: 20px; border-top: 1px solid #eee; padding-top: 25px; }
    .pdf-report .footer-card { background: #fff; padding-right: 10px; }
    .pdf-report .fc-icon { font-size: 18px; color: #636880; margin-bottom: 8px; }
    .pdf-report .fc-title { font-size: 11px; font-weight: bold; text-transform: uppercase; color: #636880; margin-bottom: 4px; display: flex; align-items: center; gap: 8px; }
    .pdf-report .fc-desc { font-size: 10px; color: #444; line-height: 1.4; }

    /* Overlay de loading Edge */

    /* Vídeo de fundo no hero do Edge 70 */
    #edge-overview {
      position: relative;
      min-height: 500px;
      background: rgba(255, 255, 255, 0.92);
      backdrop-filter: blur(1px);
    }
    #edge-hero-video {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      opacity: 0.08;
      filter: blur(0.5px);
      pointer-events: none;
      z-index: 0;
      transition: opacity 0.3s ease;
    }
    #edge-overview > div.grid {
      position: relative;
      z-index: 10;
    }
    @media (max-width: 768px) {
      #edge-overview {
        min-height: auto;
        background: rgba(255, 255, 255, 0.95);
      }
      #edge-hero-video {
        opacity: 0.05;
      }
    }

    /* iOS/Safari: 100vh pode “pular” com a toolbar */
    @supports (min-height: 100dvh) {
      #edge-root #edge-hero { min-height: 100dvh; }
    }

    
    
    /* Edge: Seção Swarovski Collection - Mobile */
    @media (max-width: 768px) {
      #edge-swarovski-collection {
        padding-top: 3rem;
        padding-bottom: 3rem;
      }
      #edge-swarovski-collection video {
        max-height: 400px !important;
      }
      #edge-swarovski-collection img {
        max-height: 500px !important;
      }
      #edge-swarovski-collection .space-y-5 > * + * {
        margin-top: 1.25rem;
      }
    }
    @media (max-width: 480px) {
      #edge-swarovski-collection h2 {
        font-size: 1.75rem;
        line-height: 1.2;
      }
      #edge-swarovski-collection video {
        max-height: 300px !important;
      }
      #edge-swarovski-collection img {
        max-height: 400px !important;
      }
    }

    /* Edge: Seção Snapdragon Performance - Mobile */
    @media (max-width: 768px) {
      #edge-snapdragon-performance .container {
        padding-left: 1rem;
        padding-right: 1rem;
      }
      #edge-snapdragon-performance h2 {
        font-size: 1.75rem;
        line-height: 1.2;
      }
      #edge-snapdragon-performance .space-y-4 > * + * {
        margin-top: 1rem;
      }
    }
    @media (max-width: 480px) {
      #edge-snapdragon-performance {
        padding-top: 3rem;
        padding-bottom: 3rem;
      }
      #edge-snapdragon-performance img {
        max-height: 400px !important;
      }
      #edge-snapdragon-performance .flex-wrap {
        flex-direction: column;
        align-items: flex-start;
      }
      #edge-snapdragon-performance .flex-wrap > * {
        width: 100%;
        margin-bottom: 0.5rem;
      }
    }

    /* Edge: mobile (evita barra "encolher" por causa do badge +65%) */
    @media (max-width: 640px) {
      #edge-root .custom-chart-row { flex-wrap: wrap; align-items: flex-start; overflow-x: hidden; max-width: 100%; }
      #edge-root .chart-label { width: 100%; margin-bottom: 6px; }
      #edge-root .chart-track { width: 100%; max-width: 100%; min-width: 0; }
      /* o badge vira uma "linha" abaixo da barra, sem roubar largura do track */
      #edge-root .gain-badge { margin-left: 0; margin-top: 8px; align-self: stretch; text-align: center; max-width: 100%; box-sizing: border-box; }
    }
    

    /* Edge: badges do slider sem sobreposição no mobile */
    @media (max-width: 640px) {
      #edge-root .comp-badge { top: 12px; padding: 6px 10px; font-size: 9px; line-height: 1.2; }
      #edge-root .badge-old,
      #edge-root .badge-new {
        max-width: calc(50% - 20px);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
      }
      #edge-root .badge-old { left: 10px; }
      #edge-root .badge-new { right: 10px; }
      #edge-root .comparison-wrapper {
        height: min(420px, 52vh);
        max-height: 440px;
        border-radius: 16px;
      }
      #edge-root .slider-handle-btn {
        width: 40px;
        height: 40px;
        font-size: 14px;
      }
      #edge-root .edge-layer-base img,
      #edge-root .edge-overlay-inner-wrapper img {
        height: 72%;
      }
    }

    @media (max-width: 380px) {
      #edge-root .comparison-wrapper {
        height: min(360px, 48vh);
      }
      #edge-root .comp-badge { font-size: 8px; padding: 5px 8px; top: 10px; }
      #edge-root .badge-old { left: 8px; }
      #edge-root .badge-new { right: 8px; }
    }

    /* Cards espessura: nada “vaza” para fora do raio (evita manchas tipo glow no canto) */
    #edge-root .edge-thickness-cards-grid {
      display: grid;
      gap: 1rem;
    }
    @media (min-width: 768px) {
      #edge-root .edge-thickness-cards-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 2.5rem 3rem;
        align-items: stretch;
      }
    }
    #edge-root .edge-card-thickness {
      min-width: 0;
      overflow: hidden;
    }
    #edge-root .edge-card-thickness-highlight {
      position: relative;
      isolation: isolate;
    }
    #edge-root .edge-card-thickness-highlight .edge-progress-glow {
      box-shadow: none;
    }
    @media (min-width: 768px) {
      #edge-root .edge-card-thickness-highlight {
        transform: scale(1.05);
      }
    }

    /* Garantir que todos os textos em motosans sejam lowercase */
    .moto-headline,
    h1.moto-headline, h2.moto-headline, h3.moto-headline, h4.moto-headline, h5.moto-headline, h6.moto-headline,
    span.moto-headline, div.moto-headline, a.moto-headline, p.moto-headline,
    [class*="moto-headline"] {
      text-transform: lowercase !important;
    }

    /* Menu Hambúrguer de Navegação */
    .hamburger-menu {
      position: relative;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .hamburger-btn {
      background: none;
      border: none;
      cursor: pointer;
      padding: 8px;
      display: flex;
      flex-direction: column;
      gap: 4px;
      z-index: 100;
      transition: opacity 0.2s ease;
      -webkit-tap-highlight-color: transparent;
    }
    @media (max-width: 640px) {
      .hamburger-btn {
        min-width: 44px;
        min-height: 44px;
        padding: 12px;
        touch-action: manipulation;
      }
    }
    .hamburger-btn:hover {
      opacity: 0.7;
    }
    .hamburger-label {
      font-family: 'Gotham Medium', sans-serif;
      font-size: 10px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: var(--moto-black);
      display: none;
    }
    @media (min-width: 640px) {
      .hamburger-label {
        display: block;
      }
    }
    .hamburger-btn span {
      width: 24px;
      height: 2px;
      background: var(--moto-black);
      transition: all 0.3s ease;
      display: block;
    }
    .hamburger-btn.active span:nth-child(1) {
      transform: rotate(45deg) translate(6px, 6px);
    }
    .hamburger-btn.active span:nth-child(2) {
      opacity: 0;
    }
    .hamburger-btn.active span:nth-child(3) {
      transform: rotate(-45deg) translate(6px, -6px);
    }
    .hamburger-menu-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(0, 0, 0, 0.5);
      z-index: 99;
      opacity: 0;
      visibility: hidden;
      transition: opacity 0.3s ease, visibility 0.3s ease;
    }
    .hamburger-menu-overlay.active {
      opacity: 1;
      visibility: visible;
    }
    .hamburger-menu-panel {
      position: fixed;
      top: 0;
      right: -100%;
      width: 280px;
      max-width: 85vw;
      height: 100vh;
      height: 100dvh;
      background: white;
      box-shadow: -2px 0 10px rgba(0, 0, 0, 0.1);
      z-index: 100;
      transition: right 0.3s ease;
      padding: 88px 24px calc(24px + env(safe-area-inset-bottom));
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
    }
    .hamburger-menu-panel.active {
      right: 0;
    }
    .hamburger-menu-panel a {
      display: flex;
      align-items: center;
      min-height: 44px;
      padding: 16px 20px;
      margin-bottom: 8px;
      border-radius: 12px;
      font-family: 'moto sans', system-ui, sans-serif;
      font-weight: 600;
      font-size: 14px;
      color: var(--moto-black);
      -webkit-tap-highlight-color: transparent;
      touch-action: manipulation;
      text-decoration: none;
      text-transform: lowercase;
      transition: background 0.2s ease, color 0.2s ease;
      border: 1px solid transparent;
    }
    .hamburger-menu-panel a:hover {
      background: var(--frost);
      color: var(--moto-indigo);
      border-color: var(--moto-indigo);
    }
    .hamburger-menu-panel a.active {
      background: var(--moto-indigo);
      color: white;
    }
    .hamburger-menu-panel .menu-title {
      font-family: 'Gotham Medium', sans-serif;
      font-size: 10px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: #888;
      margin-bottom: 16px;
      padding-bottom: 12px;
      border-bottom: 1px solid #eee;
    }
    @media (max-width: 640px) {
      .hamburger-menu-panel {
        padding-top: 72px;
      }
    }
    
    /* Dropdown de Download */
    #download-dropdown-wrap {
      position: relative;
    }
    #download-dropdown {
      position: absolute;
      right: 0;
      top: calc(100% + 8px);
      width: 240px;
      background: white;
      border-radius: 16px;
      box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
      border: 1px solid #e5e7eb;
      padding: 8px;
      z-index: 1000;
      display: none;
    }
    #download-dropdown:not(.hidden) {
      display: block;
    }
    #download-dropdown button {
      width: 100%;
      text-align: left;
      padding: 12px 16px;
      min-height: 44px;
      font-size: 13px;
      font-weight: 700;
      color: #1f2937;
      background: transparent;
      border: none;
      border-radius: 10px;
      cursor: pointer;
      display: flex;
      align-items: center;
      gap: 12px;
      transition: background 0.2s ease;
      font-family: 'Gotham Medium', sans-serif;
      -webkit-tap-highlight-color: transparent;
    }
    #download-dropdown button:hover {
      background: rgba(99, 104, 128, 0.1);
    }
    #download-dropdown button i {
      color: var(--moto-indigo);
      font-size: 16px;
    }
    @media (max-width: 1024px) {
      #download-dropdown {
        right: 0;
        width: 200px;
      }
    }
    @media (max-width: 430px) {
      
      
      /* Melhorias para iPhone 14 e telas pequenas */
      header .header-inner {
        padding-left: 12px !important;
        padding-right: 12px !important;
        height: 72px !important;
      }
      .hamburger-label {
        font-size: 10px;
      }
      .hero-image-container {
        min-height: 200px !important;
        height: 200px !important;
      }
    }
    @media (max-width: 390px) {
      /* iPhone 14 e telas pequenas */
      header .header-inner {
        padding-left: 10px !important;
        padding-right: 10px !important;
      }
      .moto-logo {
        height: 20px !important;
      }
      .hero-image-container {
        min-height: 180px !important;
        height: 180px !important;
      }
      #hub-root main {
        padding-left: 12px;
        padding-right: 12px;
      }
      #hub-list {
        padding-left: 12px !important;
        padding-right: 12px !important;
      }
    }

    /* Hub: mobile e telas pequenas — alvos de toque e overflow */
    @media (max-width: 640px) {
      #hero-prev, #hero-next {
        width: 44px !important;
        height: 44px !important;
        min-width: 44px !important;
        min-height: 44px !important;
        -webkit-tap-highlight-color: transparent;
        touch-action: manipulation;
      }
      #hub-list button {
        min-width: 0;
        touch-action: manipulation;
        -webkit-tap-highlight-color: transparent;
      }
      #hub-list button .text-sm {
        display: -webkit-box;
        -webkit-line-clamp: 3;
        line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
      }
    }
    
    /* Safe area para iPhone 14 (notch/Dynamic Island) */
    @supports (padding: env(safe-area-inset-top)) {
      header.fixed.top-0 {
        padding-top: env(safe-area-inset-top);
      }
      .app-shell {
        padding-top: calc(var(--header-h) + env(safe-area-inset-top));
      }
    }

/* --- BOTAO PDF --- */
.btn-baixar {
  min-width: 140px;
  width: max-content !important;
  height: 44px;
  background: #1d1d1f !important;
  color: white !important;
  border-radius: 22px;
  padding: 0 20px !important;
  box-sizing: border-box;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 700;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border: none;
  transition: all 0.3s ease;
  box-shadow: 0 4px 16px rgba(99, 104, 128, 0.3);
  font-family: 'Gotham Medium', sans-serif;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.btn-baixar:hover {
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.4);
  transform: translateY(-2px);
}
.btn-baixar:active {
  transform: translateY(0);
}
.btn-baixar .fa-download {
  font-size: 14px;
  display: inline-block !important;
}
.btn-baixar .fa-chevron-down {
  font-size: 10px;
  transition: transform 0.3s ease;
  display: inline-block !important;
}
.btn-baixar[aria-expanded='true'] .fa-chevron-down {
  transform: rotate(180deg);
}
.btn-baixar span:not(.fa) {
  display: inline !important;
  white-space: nowrap !important;
}

@media (max-width: 1024px) {
  #btn-baixar-header { min-width: 44px !important; width: 44px !important; padding: 0 !important; justify-content: center !important; border-radius: 50% !important; }
  #btn-baixar-header span { display: none !important; }
  #btn-baixar-header .fa-chevron-down { display: none !important; }
}

@media (max-width: 480px) {
  #btn-baixar-header { min-width: 36px !important; width: 36px !important; height: 36px !important; }
}

/* Correcao de overflow removida */
@media (max-width: 768px) {
  #btn-back-evolucao { min-width: 36px !important; width: 36px !important; height: 36px !important; min-height: 36px !important; margin-right: 0 !important; }
}

@media (max-width: 768px) {
  .select-mobile-wrap { width: 36px !important; height: 36px !important; min-width: 36px !important; border-radius: 50% !important; border: 1px solid #e5e7eb; background: #fff; position: relative; display: flex !important; align-items: center; justify-content: center; padding: 0 !important; }
  .select-mobile-wrap::before { content: '\f078'; font-family: 'Font Awesome 6 Free'; font-weight: 900; font-size: 14px; color: #374151; position: absolute; pointer-events: none; z-index: 1; }
  #comparativo-select { direction: rtl !important; position: absolute !important; top: 0 !important; left: 0 !important; width: 100% !important; height: 100% !important; opacity: 0 !important; z-index: 10; cursor: pointer; }
}

/* ============================================================
   Componentes partilhados do renderer de Evolucao (Fase 1)
   - Classes utilizadas pelo evolucao-renderer.js (Fase 3+).
   - Aceitam tema escuro/claro via tokens ja existentes.
   - Nao mudam o visual de nada que ja exista; sao puramente
     novas classes para uso futuro do motor de comparativos.
   ============================================================ */
.evo-section { display: block; }
.evo-section.section-hidden { display: none; }

/* Container principal de cada secao */
.evo-shell {
  padding-bottom: 4rem;
  margin-left: auto;
  margin-right: auto;
  max-width: 72rem;
  padding-left: 1rem;
  padding-right: 1rem;
}
@media (min-width: 640px) { .evo-shell { padding-left: 1.5rem; padding-right: 1.5rem; } }
@media (min-width: 768px) { .evo-shell { padding-bottom: 5rem; } }

/* ----- Hero (cabecalho de cada comparativo) ----- */
.evo-hero { margin-bottom: 5rem; }
.evo-hero__grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: center; }
@media (min-width: 1024px) { .evo-hero__grid { grid-template-columns: repeat(12, minmax(0, 1fr)); } }
.evo-hero__col-text { grid-column: span 12 / span 12; }
.evo-hero__col-image { grid-column: span 12 / span 12; }
@media (min-width: 1024px) {
  .evo-hero__col-text { grid-column: span 7 / span 7; }
  .evo-hero__col-image { grid-column: span 5 / span 5; }
}
.evo-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.25rem 0.75rem;
  background: #f3f4f6;
  border-radius: 9999px;
  font-size: 10px; font-weight: 700; letter-spacing: 0.15em;
  color: #6b7280; text-transform: uppercase;
  margin-bottom: 1rem;
}
.evo-hero__eyebrow::before {
  content: ""; display: inline-block;
  width: 0.5rem; height: 0.5rem; border-radius: 9999px;
  background: var(--slate-blue);
}
.evo-hero__headline {
  font-size: clamp(2rem, 4vw, 3.75rem);
  font-weight: 800; letter-spacing: -0.01em; line-height: 1.05;
  color: var(--moto-black);
}
.evo-hero__headline em { color: var(--slate-blue); font-style: normal; }
.evo-hero__subhead {
  display: block;
  font-size: clamp(1.25rem, 2vw, 1.875rem);
  font-weight: 800; color: #1f2937; margin-top: 0.75rem;
}
.evo-hero__lead { margin-top: 1.25rem; color: #4b5563; font-size: 1rem; max-width: 42rem; }
@media (min-width: 768px) { .evo-hero__lead { font-size: 1.125rem; } }

/* Linha "a evolução do ..." — entre o logo e o subhead (replica o inline) */
.evo-hero__headline-text {
  display: block;
  margin-top: 1rem;
  font-size: clamp(1.125rem, 1.8vw, 1.5rem);
  font-weight: 700;
  color: var(--slate-blue);
  font-family: 'moto sans', system-ui, sans-serif;
  text-transform: lowercase;
  letter-spacing: -0.01em;
  line-height: 1.15;
}

/* Mobile polish (renderer-only .evo-*): aproxima o comportamento visual das
   páginas antigas (cards mais compactos, melhor quebra de texto, menos “vazio”). */
@media (max-width: 640px) {
  .evo-hero { margin-bottom: 3.25rem; }
  .evo-hero__eyebrow { margin-bottom: 0.75rem; font-size: 9px; letter-spacing: 0.12em; }
  .evo-hero__headline { line-height: 1.02; }
  .evo-hero__subhead { margin-top: 0.6rem; line-height: 1.1; }
  .evo-hero__lead { margin-top: 0.9rem; font-size: 0.95rem; }

  .evo-hero__grid { gap: 1.25rem; }
  /* PDPs têm muito espaço transparente; no mobile preferimos recortar para não
     parecer um \"buraco\" branco enorme abaixo dos destaques. */
  .evo-hero__col-image {
    border-radius: 18px;
    border: 1px solid #e5e7eb;
    background: linear-gradient(135deg, #f3f4f6 0%, #e9eaf2 100%);
    overflow: hidden;
  }
  .evo-hero__col-image img {
    display: block;
    width: 100%;
    height: 240px;
    object-fit: contain;
    object-position: center center;
  }

  .evo-destaques { padding: 1rem; border-radius: 1rem; }
  .evo-destaques__title { margin-bottom: 0.75rem; font-size: 0.625rem; letter-spacing: 0.15em; }
  .evo-destaques__grid { gap: 0.5rem; grid-template-columns: repeat(2, minmax(0, 1fr)); }

  /* Replica o inline: gap-2 p-2.5 w-8 h-8 text-[10px] — sem line-clamp */
  .evo-destaque-card { padding: 0.625rem; gap: 0.5rem; align-items: flex-start; }
  .evo-destaque-card__icon { width: 2rem; height: 2rem; border-radius: 0.5rem; }
  .evo-destaque-card__icon i { font-size: 1rem; }
  .evo-destaque-card__label { font-size: 0.625rem; font-weight: 700; line-height: 1.2; }
  .evo-destaque-card__value {
    font-size: 0.625rem;
    line-height: 1.3;
    word-break: break-word;
  }
}

@media (max-width: 380px) {
  .evo-destaques__grid { grid-template-columns: 1fr; }
  .evo-hero__col-image img { height: 200px; }
}

/* ----- Painel de destaques (caixa branca com 6 cards) ----- */
.evo-destaques {
  margin-top: 1.5rem;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 1rem;
  padding: 1.25rem;
  box-shadow: 0 1px 3px rgba(0,0,0,.05);
}
.evo-destaques__title {
  font-size: 0.75rem; font-weight: 700; letter-spacing: 0.15em;
  color: #9ca3af; text-transform: uppercase;
  margin-bottom: 1rem;
}
.evo-destaques__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}
@media (min-width: 640px) { .evo-destaques__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

.evo-destaque-card {
  display: flex; align-items: flex-start; gap: 0.75rem;
  padding: 0.75rem;
  background: rgba(99, 104, 128, 0.05);
  border-radius: 0.75rem;
}
.evo-destaque-card__icon {
  width: 2.25rem; height: 2.25rem; border-radius: 0.5rem;
  background: rgba(99, 104, 128, 0.10);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--slate-blue);
}
.evo-destaque-card__icon i { font-size: 1.125rem; line-height: 1; }
.evo-destaque-card__label { font-size: 0.75rem; font-weight: 700; color: #1f2937; }
.evo-destaque-card__value { font-size: 11px; color: var(--slate-blue); font-weight: 700; margin-top: 2px; word-break: break-word; }

/* Variante "anterior" (cinza, indica modelo antigo) */
.evo-destaque-card--prev { background: #f3f4f6; }
.evo-destaque-card--prev .evo-destaque-card__icon { background: #e5e7eb; color: #6b7280; }
.evo-destaque-card--prev .evo-destaque-card__label { color: #4b5563; }
.evo-destaque-card--prev .evo-destaque-card__value { color: #6b7280; }

/* ----- Bloco generico (cada subseccao do comparativo) ----- */
.evo-block { margin-top: 2.5rem; }
.evo-block__eyebrow {
  display: inline-block;
  font-size: 10px; font-weight: 700; letter-spacing: 0.15em;
  color: #9ca3af; text-transform: uppercase;
  margin-bottom: 0.5rem;
}
.evo-block__title {
  font-size: clamp(1.5rem, 2.5vw, 2.25rem);
  font-weight: 800; color: var(--moto-black); line-height: 1.1;
  margin-bottom: 0.75rem;
}
.evo-block__subtitle { color: #4b5563; font-size: 1rem; max-width: 48rem; }

/* ----- Slider Antes/Depois (versao "evo-": classe-partilhada) ----- */
/* Replica o que ja existe em #g17-root .compare-container, mas
   por classe (sem depender do id da seccao). O motor JS aceita
   esta classe ou os IDs antigos. */
.evo-slider-ad {
  position: relative;
  height: clamp(340px, 70vh, 520px);
  overflow: hidden;
  border-radius: 24px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.10);
  cursor: ew-resize;
  /* Lado "novo" (base): gradiente sutil em vez de cinza chapado */
  background: linear-gradient(180deg, #f7f8fb 0%, #e9eaf2 100%);
  user-select: none;
  touch-action: pan-y;
  /* Card contido e centrado — sem sobrar deserto nas laterais em telas largas */
  width: min(880px, 100%);
  margin-left: auto;
  margin-right: auto;
}
.evo-slider-ad.is-tall { height: clamp(420px, 78vh, 620px); }
.evo-slider-ad__layer-base {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  z-index: 1;
}
.evo-slider-ad__layer-base img {
  height: 88%; width: auto; max-width: 92%; object-fit: contain;
}
.evo-slider-ad__overlay {
  position: absolute; top: 0; left: 0; bottom: 0;
  width: 100%; overflow: hidden;
  /* Lado "antigo": branco com leve gradiente — contraste suave com o lado novo */
  background: linear-gradient(180deg, #ffffff 0%, #f3f4f8 100%);
  border-right: 2px solid white;
  z-index: 10; will-change: clip-path;
  clip-path: inset(0 50% 0 0);
}
.evo-slider-ad__overlay-inner {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
}
.evo-slider-ad__overlay-inner img {
  height: 88%; width: auto; max-width: 92%; object-fit: contain;
}
.evo-slider-ad__handle {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 48px; height: 48px;
  background: var(--moto-indigo);
  border: 4px solid white; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  z-index: 20;
  box-shadow: 0 8px 22px rgba(0,0,0,0.28);
  pointer-events: none; will-change: left;
}
.evo-slider-ad__badge {
  position: absolute; bottom: 18px;
  padding: 8px 14px; border-radius: 10px;
  font-weight: 800; font-size: 12px;
  /* Brand: moto sans NUNCA em maiúsculas — força lowercase via CSS */
  font-family: 'moto sans', system-ui, sans-serif;
  text-transform: lowercase; letter-spacing: 0.04em;
  z-index: 15;
}
.evo-slider-ad.is-idle .evo-slider-ad__handle { animation: g17_handlePulse 1.6s ease-in-out infinite; }

/* Modo FOTO (`photo: true` no bloco): para fotos reais (selfies/paisagens) a
   imagem PREENCHE o card (cover) e o container vira um cartão retrato centrado —
   sem faixas sobrando nas laterais. Produtos com fundo transparente continuam
   no modo padrão (contain). */
.evo-slider-ad.is-photo {
  height: auto;
  aspect-ratio: 4 / 5;
  width: min(560px, 100%);
  max-height: 660px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 640px) {
  /* Mobile: card mais baixo (3/4) pra não tomar a tela inteira,
     badges compactos pra não disputar espaço com a foto. */
  .evo-slider-ad.is-photo { aspect-ratio: 3 / 4; border-radius: 16px; }
  .evo-slider-ad.is-photo .evo-slider-ad__badge { font-size: 10px; padding: 5px 9px; letter-spacing: 0.04em; }
  .evo-slider-ad.is-photo .evo-slider-ad__badge[style*="left"] { left: 10px !important; }
  .evo-slider-ad.is-photo .evo-slider-ad__badge[style*="right"] { right: 10px !important; }
}
.evo-slider-ad.is-photo .evo-slider-ad__layer-base img,
.evo-slider-ad.is-photo .evo-slider-ad__overlay-inner img {
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
}

/* Variante: o lado "antigo" recebe filter + grain para ficar visivelmente
   pior face ao novo. Aplicada quando bloco tem `qualityHint: 'old-worse'`. */
.evo-slider-ad__overlay--quality-low { background: #f1f1f3; }
.evo-slider-ad__overlay--quality-low .evo-slider-ad__overlay-inner img {
  filter: brightness(0.84) contrast(0.90) saturate(0.72);
}
.evo-slider-ad__overlay--quality-low::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 11;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.42'/></svg>");
  background-size: 180px 180px;
  mix-blend-mode: overlay;
  opacity: 0.55;
}
@supports (height: 70dvh) {
  .evo-slider-ad { height: clamp(340px, 70dvh, 520px); }
  .evo-slider-ad.is-tall { height: clamp(420px, 78dvh, 620px); }
}
@media (max-width: 640px) {
  .evo-slider-ad__badge {
    top: 12px; bottom: auto;
    max-width: 46%;
    white-space: normal;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 6px 10px;
    font-size: 9px;
    border-radius: 9px;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
}
@media (max-width: 380px) {
  .evo-slider-ad { height: clamp(300px, 62dvh, 460px); border-radius: 16px; }
  .evo-slider-ad.is-tall { height: clamp(360px, 68dvh, 540px); }
  .evo-slider-ad__handle { width: 42px; height: 42px; border-width: 3px; }
  .evo-slider-ad__badge { font-size: 8px; padding: 5px 8px; max-width: calc(50% - 14px); }
}

/* ----- Barras de metricas ----- */
.evo-metric-bar {
  height: 100%; border-radius: 9999px; width: 0;
  background: var(--slate-blue);
  transition: width 1s cubic-bezier(0.22, 1, 0.36, 1);
}
.evo-metric-track {
  background: #e5e7eb; height: 0.5rem; border-radius: 9999px; overflow: hidden;
}
.evo-metric-row { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.75rem; }
.evo-metric-row__label {
  width: 7.5rem; font-size: 0.6875rem; font-weight: 700;
  color: #4b5563; text-transform: uppercase; letter-spacing: 0.05em;
  flex-shrink: 0;
}
.evo-metric-row__value {
  font-size: 0.75rem; font-weight: 700; color: var(--moto-black);
  white-space: nowrap;
}

@media (max-width: 640px) {
  .evo-metric-row__label { font-size: 0.65rem; }
  .evo-metric-row__value { font-size: 0.7rem; }
}

/* ----- Tabela de specs (alias de .table-spec, mas com nome do renderer) ----- */
.evo-spec-table { width: 100%; border-collapse: collapse; }
.evo-spec-table thead tr { background: var(--frost); }
.evo-spec-table th, .evo-spec-table td {
  font-size: 0.9375rem; line-height: 1.45;
  padding: 0.75rem 1rem;
  text-align: left;
}
.evo-spec-table th { color: var(--moto-black); font-weight: 700; }
.evo-spec-table .th-destaque { color: var(--slate-blue); }
.evo-spec-table tbody tr { transition: background 0.15s ease; border-top: 1px solid #f3f4f6; }
.evo-spec-table tbody tr:hover { background: rgba(99,104,128,0.06); }
.evo-spec-table .cell-evolucao {
  background: rgba(99,104,128,0.14);
  color: var(--moto-black); font-weight: 600;
}

/* ===== Metric Cards (renderer) ===== */
.evo-metric-card {
  background: #fff;
  border: 1.5px solid rgba(99,104,128,.15);
  border-radius: 1rem;
  padding: 1.25rem 1.25rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  transition: box-shadow .2s ease, border-color .2s ease;
}
.evo-metric-card:hover {
  border-color: rgba(99,104,128,.35);
  box-shadow: 0 4px 20px rgba(99,104,128,.10);
}

.evo-metric-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}
.evo-metric-card__label {
  font-family: 'moto sans', system-ui, sans-serif;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: lowercase;
  color: var(--slate-blue);
}
.evo-metric-card__badge {
  font-family: 'moto sans', system-ui, sans-serif;
  font-size: 0.6875rem;
  font-weight: 800;
  color: #fff;
  background: var(--slate-blue);
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  white-space: nowrap;
  line-height: 1.4;
}

/* Row: label + bar + value */
.evo-metric-card__row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.evo-metric-card__model {
  font-size: 0.6875rem;
  font-weight: 700;
  width: 3.5rem;
  flex-shrink: 0;
  line-height: 1.2;
}
.evo-metric-card__model--old { color: #9ca3af; }
.evo-metric-card__model--new { color: var(--slate-blue); }

.evo-metric-card__track {
  flex: 1;
  height: 1.375rem;
  background: #f3f4f6;
  border-radius: 999px;
  overflow: hidden;
}
.evo-metric-card__bar {
  height: 100%;
  border-radius: 999px;
  transition: width .6s cubic-bezier(.4,0,.2,1);
}
.evo-metric-card__bar--old { background: #c5c7d0; }
.evo-metric-card__bar--new { background: var(--slate-blue); }

.evo-metric-card__value {
  font-size: 0.8125rem;
  font-weight: 800;
  min-width: 3.75rem;
  text-align: right;
  white-space: nowrap;
}
.evo-metric-card__value--old { color: #6b7280; }
.evo-metric-card__value--new { color: var(--moto-black); }
.evo-metric-card__value small {
  font-size: 0.625rem;
  font-weight: 600;
  opacity: .65;
}

@media (max-width: 480px) {
  .evo-metric-card { padding: 1rem; }
  .evo-metric-card__model { width: 3rem; font-size: 0.625rem; }
  .evo-metric-card__value { min-width: 3.25rem; font-size: 0.75rem; }
  .evo-metric-card__track { height: 1.125rem; }
}

/* ===== Video Thumbnail (YouTube fallback) ===== */
.evo-video-thumb {
  display: block;
  position: relative;
  width: 100%;
  border-radius: 18px;
  overflow: hidden;
  background: #000;
  text-decoration: none;
  cursor: pointer;
}
.evo-video-thumb:hover .evo-video-thumb__play {
  transform: translate(-50%, -50%) scale(1.12);
  opacity: 1;
}
.evo-video-thumb:hover .evo-video-thumb__img {
  opacity: .85;
}
.evo-video-thumb__img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  transition: opacity .25s ease;
}
.evo-video-thumb__play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 5rem;
  color: #fff;
  opacity: .85;
  transition: transform .25s ease, opacity .25s ease;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.4));
  line-height: 1;
}
.evo-video-thumb__badge {
  position: absolute;
  bottom: 1rem;
  right: 1rem;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  font-family: 'moto sans', system-ui, sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.evo-video-thumb__badge i {
  font-size: 1.1rem;
  color: #ff0000;
}
.evo-video-thumb--active {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  cursor: default;
}

/* Header: esconde o titulo "evolução • 2026" SO no mobile — o hero da pagina
   ja mostra o nome. Desktop mantem. */
@media (max-width: 767px) {
  .hub-header-title, .hub-header-divider { display: none !important; }
}
