/* Motorola Global Brand Identity — Core palette (Nov 2025). Cool pairings: Black/Slate Blue on Frost; Warm: Black/Sandstone on Pearl */
:root {
    --moto-black: #131417;
    --white: #FFFFFF;
    --frost: #E9EAF2;
    --pearl: #F0EDE9;
    --slate-blue: #636880;
    --sandstone: #7A7670;
    --moto-indigo: var(--slate-blue);
    --text-color: var(--moto-black);
    --text-muted: var(--sandstone);
    --bg-light: var(--frost);
    --focus-ring: 2px solid var(--slate-blue);
    /* Regra universal: tamanho das fotos no bloco comparativo (tela) */
    --comparativo-frame-w: 160px;
    --comparativo-frame-h: 228px;
    --comparativo-multi-height: 228px;
    --comparativo-img-max-h: 200px;
    /* Regra universal: tamanho das fotos na exportação PDF/PNG */
    --pdf-img-box-w: 120px;
    --pdf-img-box-h: 140px;
}
@media (min-width: 768px) {
    :root {
        --comparativo-frame-w: 200px;
        --comparativo-frame-h: 280px;
        --comparativo-multi-height: 280px;
        --comparativo-img-max-h: 260px;
    }
}



html {
    overflow-x: hidden;
    -webkit-text-size-adjust: 100%;
}
body {
    font-family: 'Gotham Medium', system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    color: var(--text-color);
    line-height: 1.15;
    background: radial-gradient(900px 520px at 70% 5%, rgba(99,104,128,.08), transparent 60%), var(--bg-light);
    overflow-x: hidden;
    -webkit-tap-highlight-color: transparent;
}

/* Espaço para o header fixo — evita sobreposição do título */
.app-shell {
    padding-top: 92px !important;
}
@media (max-width: 768px) {
    .app-shell { padding-top: 76px !important; }
}
@media (max-width: 430px) {
    .app-shell { padding-top: 76px !important; }
}
.hero-title-block {
    margin-top: 0 !important;
}
.hero-premium {
    background: linear-gradient(152deg, #f8f8fc 0%, rgba(255,255,255,0.98) 35%, #f5f3f0 100%);
    box-shadow: 0 4px 24px rgba(99,104,128,0.06), 0 1px 0 rgba(255,255,255,0.8) inset;
}
.hero-compact .relative.px-4 { padding-left: 1rem; padding-right: 1rem; }
@media (min-width: 768px) {
    .hero-compact .relative.px-4 { padding-left: 3.5rem; padding-right: 3.5rem; }
}

.hero-nav-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    padding: 0.85rem 1.5rem;
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid rgba(255, 255, 255, 0.8);
    border-radius: 999px;
    font-family: 'moto sans', sans-serif;
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--moto-black);
    text-transform: lowercase;
    transition: all 0.25s ease;
    cursor: pointer;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: 0 4px 12px rgba(99, 104, 128, 0.05);
}
.hero-nav-btn:hover {
    background: white;
    border-color: rgba(99, 104, 128, 0.15);
    box-shadow: 0 8px 20px rgba(99, 104, 128, 0.1);
    transform: translateY(-2px);
}
.hero-nav-btn:active {
    transform: translateY(0);
    box-shadow: 0 4px 10px rgba(99, 104, 128, 0.08);
}
/* Estado ativo: botão preto, indica qual modo de comparativo está aberto. */
.hero-nav-btn.is-active {
    background: var(--moto-black, #131417);
    color: #ffffff;
    border-color: var(--moto-black, #131417);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.18);
}
.hero-nav-btn.is-active i {
    color: rgba(255, 255, 255, 0.85) !important;
    opacity: 1 !important;
}
.hero-nav-btn.is-active:hover {
    background: rgba(19, 20, 23, 0.92);
    color: #ffffff;
    border-color: var(--moto-black, #131417);
    transform: translateY(-2px);
}

/* Botão "selecione um aparelho": fundo lilás Motorola para destaque; mobile: evita que "aparelho" quebre sozinho */
.btn-ir-aparelhos:hover span {
    text-decoration: underline;
}
@media (max-width: 430px) {
    .btn-ir-aparelhos { flex-wrap: wrap; justify-content: center; }
    .btn-ir-aparelhos > span { display: block; width: 100%; }
}

/* Headlines e subheadlines: moto sans (Brand VI — primary typeface); sempre minúsculas */
h1, h2, h3, h4, .moto-headline,
h1 *, h2 *, h3 *, h4 *, .moto-headline * {
    font-family: 'moto sans', system-ui, sans-serif !important;
    text-transform: lowercase !important;
    letter-spacing: -0.01em;
    line-height: 0.84;
}
/* Body, captions, links, CTAs: Gotham (Brand VI — secondary typeface); parágrafos e pre = Gotham Medium */
p, pre, .phone-column, .chart-spec-label, .chart-detail-values, .spec-value,
footer, .scroll-arrow, .hero-subtitle {
    font-family: 'Gotham Medium', system-ui, sans-serif !important;
    line-height: 1.15;
}
/* UI em destaque: moto sans (títulos de card, abas, botões, sticky header); sempre minúsculas */
.moto-sans-text, .moto-sans-destaque, .selector-btn, .view-selector-btn,
.category-tabs button, #download-btn, #download-dropdown button,
.sticky-header-name, .loading-overlay-title,
.moto-sans-text *, .moto-sans-destaque *, .selector-btn *, .view-selector-btn *,
.category-tabs button *, #download-btn *, #download-dropdown button *,
.sticky-header-name *, .loading-overlay-title * {
    font-family: 'moto sans', system-ui, sans-serif !important;
    text-transform: lowercase !important;
}

/* Fallback caso as fontes não carreguem */
@supports not (font-display: swap) {
    h1, h2, h3, h4, .moto-headline,
    .moto-sans-text, .moto-sans-destaque, .selector-btn, .view-selector-btn,
    .category-tabs button, #download-btn, #download-dropdown button,
    .sticky-header-name, .loading-overlay-title {
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
    }
}

/* Novo Hero Title blindado (forçando pesos iguais e tamanho responsivo equivalente) */
.moto-comp-hero-title {
    font-family: 'moto sans', system-ui, sans-serif !important;
    text-transform: lowercase !important;
    letter-spacing: -0.01em;
    line-height: 0.9;
    font-weight: 400 !important; /* FORÇA 400 em todos os elementos */
    margin: 0;
    
    /* Responsividade imitando o Tailwind que foi removido */
    font-size: 1.875rem; /* text-3xl */
}
@media (min-width: 640px) { .moto-comp-hero-title { font-size: 2.25rem; } } /* sm:text-4xl */
@media (min-width: 768px) { .moto-comp-hero-title { font-size: 3.75rem; } } /* md:text-6xl */
@media (min-width: 1024px) { .moto-comp-hero-title { font-size: 4.5rem; } } /* lg:text-7xl */

.moto-comp-motorola,
.moto-comp-vs {
    font-weight: 400 !important;
    color: var(--moto-black);
}

.moto-comp-concorrentes {
    font-weight: 400 !important;
    color: var(--moto-indigo);
}

.moto-comp-header-label {
    font-family: 'moto sans', system-ui, sans-serif !important;
    font-weight: 400 !important;
    font-size: 11px; /* levemente maior pra compensar a perda do extrabold */
    letter-spacing: 0.1em;
    color: #9ca3af;
    text-transform: lowercase !important;
    line-height: 1;
}

b, strong, .font-bold, .font-extrabold, [class*="font-bold"], [class*="font-extrabold"] {
    font-family: inherit;
}

/* Acessibilidade: leitura e contraste */
body { font-size: 1rem; line-height: 1.5; }
.spec-value, .chart-spec-label, .chart-detail-values { font-size: 0.9375rem; line-height: 1.45; }
@media (min-width: 768px) { .spec-value, .chart-spec-label { font-size: 1rem; } }
/* Foco visível para teclado (WCAG 2.4.7) */
button:focus-visible, a:focus-visible, input:focus-visible, [tabindex]:focus-visible {
    outline: var(--focus-ring);
    outline-offset: 2px;
}
input::placeholder { color: var(--text-muted); opacity: 1; }
/* PDF: container usa Gotham; títulos e labels em moto sans */
.pdf-report, .pdf-report .pdf-report-one {
    font-family: 'Gotham Medium', system-ui, sans-serif !important;
}
.pdf-report .pdf-title,
.pdf-report .pdf-header,
.pdf-report .pdf-header *,
.pdf-report .pdf-context,
.pdf-report .pdf-section-title,
.pdf-report .pdf-hero-card-head,
.pdf-report .pdf-phone .kicker,
.pdf-report .pdf-phone .name,
.pdf-report .metric .label,
.pdf-report .metric .value,
.pdf-report .pdf-table th,
.pdf-report .win {
    font-family: 'moto sans', system-ui, sans-serif !important;
    text-transform: lowercase !important;
}
.pdf-report .pdf-subtitle,
.pdf-report .pdf-phone .meta,
.pdf-report .metric .hint,
.pdf-report .pdf-table td,
.pdf-report .pdf-summary,
.pdf-report .pdf-summary strong,
.pdf-report .pdf-footer-inline {
    font-family: 'Gotham Medium', system-ui, sans-serif !important;
}
/* Resumos extraídos (PNG/PDF): todo texto em moto sans deve sair em minúsculas */
.pdf-report .pdf-summary,
.pdf-report .pdf-summary *,
.pdf-report .pdf-resumo-body,
.pdf-report .pdf-resumo-body * {
    text-transform: lowercase !important;
}

/* Animações sutis (estilo referência) */
.fade-in-up {
    opacity: 0;
    transform: translateY(18px);
}

/* Estilo do Seletor (Brand VI — Frost + Moto Indigo) */
.selector-container {
    position: relative;
    display: flex;
    background-color: var(--frost);
    border-radius: 9999px;
    padding: 4px;
}
.selector-btn {
    flex: 1;
    text-align: center;
    padding: 8px 16px;
    font-weight: 600;
    color: var(--slate-blue);
    cursor: pointer;
    transition: color 0.3s;
    position: relative;
    z-index: 10;
}
.selector-btn.active {
    color: var(--moto-indigo);
}
.selector-slider {
    position: absolute;
    top: 4px;
    bottom: 4px;
    width: calc(50% - 4px);
    background-color: var(--white);
    border-radius: 9999px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    transition: transform 0.3s ease-in-out;
    z-index: 5;
}
/* Seletor Visualização com 3 opções (Tabela | Gráfico | Resumo) */
#view-selector-slider {
    width: calc(33.333% - 4px);
}

/* Abas de Categoria: tópicos sempre centralizados */
.category-tabs button {
    transition: color 0.3s, border-color 0.3s;
    border-bottom: 3px solid transparent;
    text-align: center;
}
.category-tabs button.active {
    color: var(--moto-indigo);
    font-weight: 700;
    border-color: var(--moto-indigo);
}

/* Vencedor: destaque com cor de marca + fundo para melhor leitura da comparação */
.winner {
    font-weight: 700;
    color: var(--moto-black);
    background: rgba(99, 104, 128, 0.14);
}
.spec-value.winner { color: var(--moto-black); }
.winner-icon {
    color: var(--slate-blue);
    font-weight: bold;
    display: inline-flex;
    align-items: center;
    vertical-align: middle;
}
/* Coluna do rótulo (especificação): Frost para separar das colunas Moto/concorrente */
.spec-label-cell {
    background: var(--frost);
    color: var(--moto-black);
    font-weight: 700;
}

/* Utilitários de Scroll */
.category-tabs-container {
    position: relative;
}
.category-tabs {
    -ms-overflow-style: none;
    scrollbar-width: none;
    scroll-behavior: smooth;
}
.category-tabs::-webkit-scrollbar {
    display: none;
}
.scroll-arrow {
    background: var(--white);
    border-radius: 50%;
    width: 36px;
    height: 36px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.15);
    z-index: 30;
}

.aparelho-card {
    scroll-snap-align: center;
    cursor: pointer;
    transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1), box-shadow 0.3s cubic-bezier(0.25, 1, 0.5, 1);
}

.aparelho-card:hover {
    transform: translateY(-4px);
}

.aparelho-card button {
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    background: linear-gradient(180deg, #ffffff 0%, #f9f9fc 100%);
    border: 1px solid rgba(99,104,128,0.08);
    box-shadow: 0 8px 24px rgba(99,104,128,0.04);
    transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

.aparelho-card:hover button {
    box-shadow: 0 16px 40px rgba(99,104,128,0.12);
    border-color: rgba(99,104,128,0.15);
}

.aparelho-indicator {
    transition: all 0.3s ease;
    cursor: pointer;
}

.aparelho-indicator:hover {
    background-color: var(--moto-indigo) !important;
}

#aparelhos-carousel {
    touch-action: pan-x;
    position: relative;
}

#aparelhos-container {
    scroll-snap-type: x mandatory;
    scroll-padding: 0 32px;
    scroll-padding-inline: 32px;
    padding-left: 32px;
    padding-right: 32px;
    -webkit-overflow-scrolling: touch;
}
/* Títulos longos (Safari + telas estreitas: Razr capa, iPhone, etc.) */
#aparelhos-container .aparelho-card .aparelho-card-texto h3 {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    overflow: hidden;
    word-break: break-word;
    overflow-wrap: anywhere;
    hyphens: auto;
    -webkit-hyphens: auto;
    line-height: 1.2;
    min-height: 0;
    text-wrap: balance;
}
.aparelho-card-storage {
    font-weight: 600;
    color: rgb(75 85 99);
    letter-spacing: 0.02em;
}
.aparelho-card-cta {
    box-sizing: border-box;
}
#btn-fechar-comparativos {
    -webkit-tap-highlight-color: transparent;
}
@media (min-width: 768px) {
    #aparelhos-container {
        padding-left: 40px;
        padding-right: 40px;
        scroll-padding: 0 40px;
    }
}
/* Evita que o primeiro card seja cortado ao “snapar” (em vez de centralizar) */
#aparelhos-container .aparelho-card {
    scroll-snap-align: start;
}
#aparelhos-container .aparelho-card:last-child {
    scroll-snap-align: end;
}

/* Setas fora da área dos cards: não sobrepõem */
#aparelhos-prev,
#aparelhos-next {
    transition: all 0.2s ease;
    cursor: pointer;
    flex-shrink: 0;
}

#aparelhos-prev:hover,
#aparelhos-next:hover {
    transform: scale(1.08);
}

#aparelhos-prev:active,
#aparelhos-next:active {
    transform: scale(0.98);
}

#comparativos-aparelho-wrapper {
    animation: fadeInUp 0.4s ease-out;
    background: linear-gradient(180deg, rgba(99, 104, 128, 0.04) 0%, transparent 100%);
    border-radius: 24px;
    padding: 1.5rem;
    border: 1px solid rgba(99, 104, 128, 0.12);
}

#comparativos-aparelho-wrapper.comparativos-aparelho-destaque {
    animation: destaqueComparativos 2s ease-out;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes destaqueComparativos {
    0% {
        box-shadow: 0 0 0 0 rgba(99, 104, 128, 0.4);
        border-color: rgba(99, 104, 128, 0.35);
    }
    40% {
        box-shadow: 0 0 0 12px rgba(99, 104, 128, 0.15);
        border-color: rgba(99, 104, 128, 0.25);
    }
    70% {
        box-shadow: 0 0 0 8px rgba(99, 104, 128, 0.08);
    }
    100% {
        box-shadow: 0 4px 24px rgba(99, 104, 128, 0.08);
        border-color: rgba(99, 104, 128, 0.12);
    }
}

/* Modo busca: foto do aparelho em destaque (maior) */
#aparelhos-carousel.modo-busca .aparelho-card {
    width: 200px !important;
}
@media (min-width: 768px) {
    #aparelhos-carousel.modo-busca .aparelho-card {
        width: 260px !important;
    }
}
#aparelhos-carousel.modo-busca .aparelho-card button {
    height: 340px !important;
    padding: 1rem !important;
}
@media (min-width: 768px) {
    #aparelhos-carousel.modo-busca .aparelho-card button {
        height: 400px !important;
    }
}
#aparelhos-carousel.modo-busca .aparelho-card .aparelho-card-foto-only {
    flex: 1;
}
#aparelhos-carousel.modo-busca .aparelho-card .aparelho-card-foto-only img {
    max-height: 260px !important;
}
@media (min-width: 768px) {
    #aparelhos-carousel.modo-busca .aparelho-card .aparelho-card-foto-only img {
        max-height: 320px !important;
    }
}
/* Modo busca: foto em destaque e nome dos aparelhos abaixo */
#aparelhos-carousel.modo-busca .aparelho-card .aparelho-card-texto {
    margin-top: 0.5rem;
}
#aparelhos-carousel.modo-busca .aparelho-card .aparelho-card-texto h3 {
    font-size: 0.875rem;
}
@media (min-width: 768px) {
    #aparelhos-carousel.modo-busca .aparelho-card .aparelho-card-texto h3 {
        font-size: 1rem;
    }
}
#aparelhos-container {
    min-height: 200px;
}
#aparelhos-carousel.modo-busca #aparelhos-container {
    min-height: 360px;
}
@media (min-width: 768px) {
    #aparelhos-carousel.modo-busca #aparelhos-container {
        min-height: 420px;
    }
}
/* Celular centralizado após o resultado da busca; evita corte nas bordas */
#aparelhos-carousel.modo-busca {
    display: flex;
    flex-direction: column;
    align-items: center;
}
#aparelhos-carousel.modo-busca .flex.items-stretch {
    width: 100%;
}
#aparelhos-carousel.modo-busca #aparelhos-container {
    padding-left: 40px;
    padding-right: 40px;
}
@media (min-width: 768px) {
    #aparelhos-carousel.modo-busca #aparelhos-container {
        padding-left: 48px;
        padding-right: 48px;
    }
}
@media (max-width: 767px) {
    #aparelhos-carousel.modo-busca #aparelhos-container {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }
}
@media (max-width: 430px) {
    #aparelhos-carousel.modo-busca #aparelhos-container {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }
}

/* Sinalização: indicador para os comparativos abaixo (modo busca) */
.comparativos-sinal {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    margin-top: 0.5rem;
    margin-bottom: 0.25rem;
    background: linear-gradient(180deg, rgba(99, 104, 128, 0.08) 0%, rgba(99, 104, 128, 0.04) 100%);
    border: 1px dashed rgba(99, 104, 128, 0.35);
    border-radius: 12px;
    color: var(--moto-indigo);
    font-size: 0.8125rem;
    font-weight: 600;
    font-family: 'moto sans', system-ui, sans-serif;
    text-transform: lowercase;
}
.comparativos-sinal svg {
    flex-shrink: 0;
    animation: bounceArrow 2s ease-in-out infinite;
}
@keyframes bounceArrow {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(4px); }
}

/* Mobile: setas ocultas, navegação por swipe — menos padding = mais largura útil no card */
@media (max-width: 768px) {
    #aparelhos-container {
        scroll-padding: 0 14px;
        scroll-padding-inline: 14px;
        padding-left: 14px;
        padding-right: 14px;
        gap: 0.75rem;
    }
}
@media (max-width: 640px) {
    #aparelhos-container {
        scroll-padding: 0 12px;
        scroll-padding-inline: 12px;
        padding-left: 12px;
        padding-right: 12px;
        gap: 0.625rem;
    }
    #aparelhos-carousel-viewport {
        padding-left: 0.25rem;
        padding-right: 0.25rem;
    }
}
@media (max-width: 430px) {
    #aparelhos-container {
        scroll-padding: 0 10px;
        scroll-padding-inline: 10px;
        padding-left: 10px;
        padding-right: 10px;
        gap: 0.5rem;
    }
}
@media (max-width: 360px) {
    #aparelhos-container {
        scroll-padding: 0 8px;
        scroll-padding-inline: 8px;
        padding-left: 8px;
        padding-right: 8px;
    }
}

@media (max-width: 640px) {
    #aparelhos-carousel {
        max-width: 100%;
    }
    
    .aparelho-card {
        width: 180px !important;
    }
    
    .aparelho-card button {
        height: 320px !important;
        padding: 1rem !important;
    }
    
    .aparelho-card img {
        max-height: 160px !important;
    }
    
    .aparelho-card h3 {
        font-size: 0.875rem;
    }
    
    .aparelho-card p,
    .aparelho-card-storage {
        font-size: 0.75rem;
    }
}

@media (max-width: 430px) {
    .aparelho-card {
        width: 160px !important;
    }
    
    .aparelho-card button {
        height: 300px !important;
    }
    
    .aparelho-card img {
        max-height: 140px !important;
    }
}

@media (max-width: 390px) {
    #aparelhos-carousel {
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }
    
    .aparelho-card {
        width: 150px !important;
    }
    
    .aparelho-card button {
        height: 280px !important;
        padding: 0.75rem !important;
    }
    
    .aparelho-card img {
        max-height: 120px !important;
    }
}

/* Estilos para posicionamento das imagens do Razr */
.moto-img {
    position: absolute;
    transition: transform 0.3s ease-in-out;
}
.moto-img-left {
    z-index: 10;
    transform: translateX(-25%);
}
.moto-img-center {
    z-index: 20;
    transform: translateX(0);
}
.moto-img-right {
    z-index: 10;
    transform: translateX(25%);
}

/* Linha dos nomes dos aparelhos sempre visível ao rolar (sticky) */
.dynamic-header-container {
    max-height: 120px;
    overflow: visible;
    opacity: 1;
    transition: box-shadow 0.2s ease-in-out;
}
.dynamic-header-container.is-visible {
    /* Mantido para compatibilidade com JS; nomes sempre visíveis */
    opacity: 1;
}
#sticky-wrapper {
    transition: box-shadow 0.3s ease-in-out;
    top: 72px; /* Gruda logo abaixo do header fixo (logo + Download) */
}
@media (min-width: 768px) {
    #sticky-wrapper { top: 88px; }
}
@supports (padding: env(safe-area-inset-top)) {
    #sticky-wrapper { top: calc(72px + env(safe-area-inset-top)); }
}
@media (min-width: 768px) {
    @supports (padding: env(safe-area-inset-top)) {
        #sticky-wrapper { top: calc(88px + env(safe-area-inset-top)); }
    }
}

/* Estilos para telas maiores (desktop) e orientação paisagem (landscape) */
@media (min-width: 768px), (orientation: landscape) {
    .moto-img-left {
        transform: translateX(-60%);
    }
    .moto-img-right {
        transform: translateX(60%);
    }
    #main-comparison-block #moto-image-container.comparativo-moto-multi .moto-img-left {
        transform: translateX(-60%) scale(0.85);
    }
    #main-comparison-block #moto-image-container.comparativo-moto-multi .moto-img-right {
        transform: translateX(60%) scale(0.85);
    }
}

/* ===== Relatório exportável (Brand VI — cores e tipografia) ===== */
.pdf-report {
    display: none;
    position: fixed;
    top: 0;
    left: -9999px;
    z-index: 99999;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Gotham Medium', system-ui, sans-serif !important;
}

.pdf-report-one {
    width: 1122px;
    min-height: 100%;
    background: var(--white);
    box-sizing: border-box;
}

.pdf-report .pdf-header {
    background: var(--moto-black);
    color: var(--white);
    padding: 22px 54px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 4px solid var(--moto-indigo);
}
.pdf-report .pdf-context {
    background: var(--frost);
    padding: 10px 54px;
    font-size: 12px;
    text-transform: lowercase;
    letter-spacing: 0.08em;
    font-weight: 700;
    color: var(--moto-black);
    border-bottom: 1px solid var(--frost);
}
.pdf-report .pdf-body {
    padding: 36px 54px 46px 54px;
}
.pdf-report-one .pdf-footer-inline {
    margin-top: 24px;
    padding: 14px 54px 24px;
    border-top: 1px solid var(--frost);
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--slate-blue);
    font-size: 9px;
}
.pdf-report .pdf-title {
    font-size: 40px;
    font-weight: 700;
    line-height: 0.84;
    margin: 0 0 8px 0;
    color: var(--moto-black);
}
.pdf-report .pdf-subtitle {
    font-size: 15px;
    color: var(--slate-blue);
    margin: 0 0 18px 0;
    max-width: 680px;
}
.pdf-report .pdf-hero {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: 34px;
    align-items: start;
    margin-bottom: 18px;
}
.pdf-report .pdf-hero-card {
    border: 1px solid var(--frost);
    border-radius: 14px;
    overflow: hidden;
    background: var(--white);
}
.pdf-report .pdf-hero-card-head {
    padding: 12px 14px;
    background: var(--frost);
    border-bottom: 1px solid rgba(0,0,0,0.06);
    font-size: 10px;
    font-weight: 700;
    text-transform: lowercase;
    letter-spacing: 0.08em;
    color: var(--slate-blue);
}
.pdf-report .pdf-hero-card-body {
    padding: 14px;
}
.pdf-report .pdf-phones {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.pdf-report .pdf-phone {
    border: 1px solid var(--frost);
    border-radius: 12px;
    padding: 12px;
    background: var(--white);
}
.pdf-report .pdf-phone .kicker {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--slate-blue);
}
.pdf-report .pdf-phone .name {
    font-size: 17px;
    font-weight: 700;
    margin-top: 4px;
    color: var(--moto-black);
}
.pdf-report .pdf-phone .meta {
    margin-top: 8px;
    font-size: 12px;
    color: var(--slate-blue);
    line-height: 1.45;
}
/* Regra universal: tamanho das fotos na exportação PDF/PNG (usa --pdf-img-box-* do :root) */
.pdf-report .pdf-img-box {
    width: var(--pdf-img-box-w);
    height: var(--pdf-img-box-h);
    min-width: var(--pdf-img-box-w);
    min-height: var(--pdf-img-box-h);
    max-width: var(--pdf-img-box-w);
    max-height: var(--pdf-img-box-h);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--frost);
    border-radius: 12px;
    margin-top: 10px;
    overflow: hidden;
}
.pdf-report .pdf-img-box img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain;
    object-position: center;
    display: block;
}
.pdf-report .pdf-metrics {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
    margin-top: 12px;
    border-top: 1px solid var(--frost);
    padding-top: 12px;
}
.pdf-report .metric {
    border: 1px solid var(--frost);
    border-radius: 12px;
    padding: 10px 12px;
    background: var(--white);
}
.pdf-report .metric .label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--slate-blue);
}
.pdf-report .metric .value {
    margin-top: 6px;
    font-size: 22px;
    font-weight: 700;
    color: var(--moto-black);
}
.pdf-report .metric .hint {
    margin-top: 4px;
    font-size: 11px;
    color: var(--slate-blue);
    line-height: 1.3;
}
.pdf-report .pdf-section {
    margin-top: 16px;
    border: 1px solid var(--frost);
    border-radius: 14px;
    overflow: hidden;
}
.pdf-report .pdf-section-title {
    background: var(--moto-black);
    color: var(--white);
    padding: 10px 14px;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.pdf-report .pdf-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.pdf-report .pdf-table th {
    text-align: left;
    padding: 12px 15px;
    background: var(--frost);
    border-bottom: 1px solid rgba(0,0,0,0.06);
    color: var(--moto-black);
    font-weight: 700;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}
.pdf-report .pdf-table td {
    padding: 12px 15px;
    border-bottom: 1px solid var(--frost);
    vertical-align: top;
}
.pdf-report .pdf-table tr:last-child td { border-bottom: 0; }
.pdf-report .win {
    color: var(--moto-indigo);
    font-weight: 700;
}
.pdf-report .pdf-summary {
    background: rgba(99,104,128,0.08);
    border-top: 1px solid var(--frost);
    padding: 12px 14px;
    font-size: 13px;
    line-height: 1.55;
    color: var(--moto-black);
}

.one-page-view { width: 100%; max-width: 1122px; box-sizing: border-box; }

/* Layout legado (não usado na exportação; PDF e PNG usam .export-mobile-pdf) */
.pdf-report-one.export-readable {
    width: 1320px;
}
.pdf-report-one.export-readable .pdf-title { font-size: 40px; }
.pdf-report-one.export-readable .pdf-subtitle { font-size: 14px; }
.pdf-report-one.export-readable .pdf-section-title { font-size: 13px; }
.pdf-report-one.export-readable .pdf-table { font-size: 12.5px; }
.pdf-report-one.export-readable .pdf-table th,
.pdf-report-one.export-readable .pdf-table td { padding: 12px 15px; }
.pdf-report-one.export-readable .pdf-summary { font-size: 13px; line-height: 1.5; }
.pdf-report-one.export-readable .pdf-phone .name { font-size: 16px; }
.pdf-report-one.export-readable .pdf-phone .meta { font-size: 11px; }
.pdf-report-one.export-readable .metric .value { font-size: 22px; }

/* PDF e PNG na exportação: página 900px + tipografia + padding (leitura mobile) */
.pdf-report-one.export-mobile-pdf {
    width: 900px;
}
.pdf-report-one.export-mobile-pdf .pdf-body {
    padding: 28px 34px 34px 34px;
}
.pdf-report-one.export-mobile-pdf .pdf-title { font-size: 48px; }
.pdf-report-one.export-mobile-pdf .pdf-subtitle { font-size: 18px; }
.pdf-report-one.export-mobile-pdf .pdf-section-title { font-size: 15px; }
.pdf-report-one.export-mobile-pdf .pdf-table { font-size: 14.5px; }
.pdf-report-one.export-mobile-pdf .pdf-table th,
.pdf-report-one.export-mobile-pdf .pdf-table td { padding: 14px 16px; }
.pdf-report-one.export-mobile-pdf .pdf-summary { font-size: 14px; line-height: 1.6; }
.pdf-report-one.export-mobile-pdf .pdf-phone .name { font-size: 18px; }
.pdf-report-one.export-mobile-pdf .pdf-phone .meta { font-size: 13px; line-height: 1.5; }
.pdf-report-one.export-mobile-pdf .metric .value { font-size: 24px; }

/* ===== Visualização em Gráfico (Brand VI) ===== */
.chart-view-summary-bar {
    display: flex;
    height: 32px;
    border-radius: 12px;
    overflow: hidden;
    background: var(--frost);
    margin-bottom: 20px;
}
.chart-view-summary-bar .segment-moto {
    background: var(--moto-indigo);
    transition: width 0.4s ease;
}
.chart-view-summary-bar .segment-rival {
    background: var(--slate-blue);
    transition: width 0.4s ease;
}
.chart-view-summary-bar .segment-empate {
    background: var(--sandstone);
    transition: width 0.4s ease;
}
.chart-spec-row {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--frost);
    min-height: 52px;
}
.chart-spec-row:last-of-type { border-bottom: 0; }
/* Tabela comparativa: Motorola à esquerda, tópicos ao centro, concorrente à direita (sempre por coluna, independente de vencer) */
#category-content .grid.grid-cols-3 > div:first-child,
#category-content .col-moto { text-align: left !important; }
#category-content .grid.grid-cols-3 > div:first-child .spec-value,
#category-content .col-moto.spec-value { justify-content: flex-start !important; }
#category-content .grid.grid-cols-3 > div:nth-child(2) { text-align: center !important; }
#category-content .grid.grid-cols-3 > div:last-child,
#category-content .col-rival { text-align: right !important; }
#category-content .grid.grid-cols-3 > div:last-child .spec-value,
#category-content .col-rival.spec-value { justify-content: flex-end !important; }
#category-content .grid.grid-cols-3 .spec-value { min-width: 0; word-wrap: break-word; }
#category-content .grid.grid-cols-3 .spec-value.winner { display: flex; align-items: center; }
#category-content .grid.grid-cols-3 .spec-value .winner-cell-content { display: inline-flex; align-items: center; gap: 6px; max-width: 100%; min-width: 0; }
#category-content .grid.grid-cols-3 .spec-value .winner-cell-content .winner-icon { flex-shrink: 0; }
#category-content .grid.grid-cols-3 .spec-value .winner-cell-content .winner-text { min-width: 0; word-wrap: break-word; }
.chart-spec-label {
    font-weight: 600;
    color: var(--moto-black);
    font-size: 14px;
    text-align: center;
}

/* Centralizar verticalmente os tópicos (célula do meio) na visão em tabela */
.spec-label-cell {
    display: flex;
    align-items: center;
    justify-content: center;
}
.chart-spec-bar-wrap {
    flex-shrink: 0;
    width: 100%;
    max-width: 200px;
    height: 24px;
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    background: var(--frost);
}
.chart-spec-bar-wrap .part {
    height: 100%;
    transition: flex 0.35s ease;
}
.chart-spec-bar-wrap .part.moto { background: rgba(99,104,128,0.22); }
.chart-spec-bar-wrap .part.moto.winner { background: var(--slate-blue); }
.chart-spec-bar-wrap .part.rival { background: rgba(99,104,128,0.22); }
.chart-spec-bar-wrap .part.rival.winner { background: var(--slate-blue); }
.chart-spec-bar-wrap .part.equal { background: var(--sandstone); }
@media (max-width: 640px) {
    .chart-spec-row { grid-template-columns: 1fr; gap: 8px; }
    .chart-spec-bar-wrap { max-width: 100%; }
}

/* Botão Download Melhorado */
.download-btn-header {
    min-width: 140px;
    height: 44px;
    background: var(--moto-indigo);
    color: white;
    border-radius: 22px;
    padding: 0 20px;
    box-sizing: border-box;
    display: inline-flex;
    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);
    position: relative;
}

/* Garantir que os ícones Font Awesome sejam renderizados corretamente */
.download-btn-header i::before,
#download-dropdown i::before {
    font-family: "Font Awesome 6 Free" !important;
    font-weight: 900 !important;
    -webkit-font-smoothing: antialiased !important;
    display: inline-block !important;
    font-style: normal !important;
    font-variant: normal !important;
    text-rendering: auto !important;
    line-height: 1 !important;
}
/* Evita distorção do ícone no mobile (ex.: Razr) */
#download-btn i,
#download-btn i::before {
    font-family: "Font Awesome 6 Free" !important;
    font-weight: 900 !important;
    font-style: normal !important;
    font-variant: normal !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    line-height: 1 !important;
    display: inline-block !important;
    -webkit-font-smoothing: antialiased !important;
    text-rendering: auto !important;
}
.download-btn-header:hover {
    background: #52586f;
    box-shadow: 0 6px 24px rgba(99, 104, 128, 0.4);
    transform: translateY(-2px);
}
.download-btn-header:active {
    transform: translateY(0);
}
.download-btn-header i,
.download-btn-header .fa-download,
.download-btn-header .fa-chevron-down {
    font-family: "Font Awesome 6 Free" !important;
    font-weight: 900 !important;
    font-style: normal !important;
    font-variant: normal !important;
    text-rendering: auto !important;
    -webkit-font-smoothing: antialiased !important;
    display: inline-block !important;
}
.download-btn-header .fa-download {
    font-size: 14px;
}
.download-btn-header .fa-chevron-down {
    font-size: 10px;
    transition: transform 0.3s ease;
}
.download-btn-header[aria-expanded="true"] .fa-chevron-down {
    transform: rotate(180deg);
}
.download-dropdown-menu {
    width: 320px;
    max-width: calc(100vw - 16px);
}
.download-menu-group {
    padding: 4px 8px;
}
.download-menu-title {
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--sandstone);
    padding: 6px 10px 4px;
}
.download-menu-item {
    width: 100%;
    text-align: left;
    padding: 10px 12px;
    font-size: 12px;
    font-weight: 700;
    color: #20222a;
    border-radius: 10px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.download-menu-item:hover {
    background: rgba(99, 104, 128, 0.1);
}
.download-menu-divider {
    height: 1px;
    background: #ececf2;
    margin: 4px 10px;
}
/* Em telas touch menores, o botão vira ícone centralizado (um só glifo; chevron só a partir de sm) */
@media (max-width: 639.98px) {
    .download-btn-header {
        min-width: 46px;
        width: 46px;
        max-width: 46px;
        height: 46px;
        padding: 0;
        gap: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-wrap: nowrap;
        border-radius: 999px;
    }
    .download-btn-header span:not(.fa) {
        display: none !important;
    }
    .download-btn-header .fa-chevron-down,
    #download-chevron {
        display: none !important;
    }
    .download-btn-header > i.fa-download:first-of-type {
        font-size: 1.125rem !important;
        line-height: 1 !important;
        margin: 0;
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: auto;
        height: auto;
        min-width: 0;
        -webkit-font-smoothing: antialiased;
    }
}
@media (max-width: 430px) {
    .download-btn-header {
        min-width: 44px;
        width: 44px;
        max-width: 44px;
        height: 44px;
    }
}

/* Comparativo: colunas iguais */
#main-comparison-block {
    grid-template-columns: 1fr 1fr;
}
#main-comparison-block .phone-column {
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
}
/* ===== Regra universal: bloco comparativo (tela) =====
 * Motorola e concorrente usam as mesmas variáveis (--comparativo-frame-*).
 * 1 foto: frame fixo. 3 fotos (Razr): lado Moto com largura flexível, mesma altura; concorrente = frame fixo. */
#main-comparison-block .comparativo-photo-box,
#main-comparison-block #moto-image-container,
#main-comparison-block #samsung-image-container {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--comparativo-frame-w) !important;
    height: var(--comparativo-frame-h) !important;
    min-width: var(--comparativo-frame-w) !important;
    min-height: var(--comparativo-frame-h) !important;
    max-width: var(--comparativo-frame-w) !important;
    max-height: var(--comparativo-frame-h) !important;
    margin: 0 auto;
    overflow: hidden;
    box-sizing: border-box;
    flex-shrink: 0;
}
/* 3 fotos (Razr): container Moto com mesma altura, largura flexível */
#main-comparison-block #moto-image-container.comparativo-moto-multi {
    width: 100% !important;
    max-width: 420px !important;
    min-width: 280px !important;
    height: var(--comparativo-multi-height) !important;
    min-height: var(--comparativo-multi-height) !important;
    max-height: var(--comparativo-multi-height) !important;
    overflow: visible !important;
}
@media (min-width: 768px) {
    #main-comparison-block #moto-image-container.comparativo-moto-multi {
        max-width: 480px !important;
        min-width: 360px !important;
    }
}
#main-comparison-block #moto-image-container.comparativo-moto-multi .moto-img {
    max-height: var(--comparativo-img-max-h);
    width: auto;
    object-fit: contain;
}
#main-comparison-block #moto-image-container.comparativo-moto-multi .moto-img-left {
    transform: translateX(-25%) scale(0.85);
}
#main-comparison-block #moto-image-container.comparativo-moto-multi .moto-img-center {
    transform: scale(0.85);
}
#main-comparison-block #moto-image-container.comparativo-moto-multi .moto-img-right {
    transform: translateX(25%) scale(0.85);
}
/* Concorrente: sempre frame único com tamanho universal (igual 1 foto) */
#main-comparison-block .comparativo-photo-frame {
    width: var(--comparativo-frame-w) !important;
    height: var(--comparativo-frame-h) !important;
    min-width: var(--comparativo-frame-w) !important;
    min-height: var(--comparativo-frame-h) !important;
    max-width: var(--comparativo-frame-w) !important;
    max-height: var(--comparativo-frame-h) !important;
    flex-shrink: 0;
    overflow: hidden;
    display: flex !important;
    align-items: center;
    justify-content: center;
}
#main-comparison-block .comparativo-photo-frame img {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    object-position: center center;
}

/* Impressão: mesmo tamanho universal */
@media print {
    #main-comparison-block .phone-column {
        min-width: 0;
        width: 50%;
    }
    #main-comparison-block #moto-image-container,
    #main-comparison-block #samsung-image-container {
        width: var(--comparativo-frame-w) !important;
        height: var(--comparativo-frame-h) !important;
        min-width: var(--comparativo-frame-w) !important;
        max-width: var(--comparativo-frame-w) !important;
        max-height: var(--comparativo-frame-h) !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
    #main-comparison-block .comparativo-photo-frame {
        width: var(--comparativo-frame-w) !important;
        height: var(--comparativo-frame-h) !important;
        min-width: var(--comparativo-frame-w) !important;
        max-width: var(--comparativo-frame-w) !important;
        max-height: var(--comparativo-frame-h) !important;
    }
    #main-comparison-block .comparativo-photo-frame img {
        width: 100% !important;
        height: 100% !important;
        object-fit: contain !important;
    }
}

/* ===== Mobile / iPhone 14 (390px) e telas pequenas ===== */
@media (max-width: 640px) {
    /* Busca otimizada para mobile */
    #busca-comparativo {
        font-size: 14px;
        padding: 12px 16px 12px 44px;
    }
    
    /* Lista de comparativos - grid responsivo */
    #lista-comparativos {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    
    .comparativo-card {
        padding: 14px 16px;
        font-size: 13px;
    }
    
    /* Botão ver comparativos */
    #btn-ver-comparativos svg {
        width: 16px;
        height: 16px;
    }
    
    #btn-ver-comparativos {
        width: 100%;
        max-width: 320px;
        padding: 14px 20px;
        font-size: 13px;
    }
}

@media (max-width: 430px) {
    .app-shell { padding-top: 156px; }
    .fixed.top-0 .max-w-6xl { padding-left: 12px; padding-right: 12px; min-height: 64px; height: auto; padding-top: 12px; padding-bottom: 12px; }
    .fixed.top-0 .max-w-6xl > .flex.gap-3 { gap: 8px; }
    .fixed.top-0 .max-w-6xl > .flex.gap-2 { gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
    .hero-title-block h1 { font-size: 1.75rem; line-height: 1.1; }
    .hero-title-block .max-w-md { max-width: 100%; padding-left: 8px; padding-right: 8px; }
    .selector-container { padding: 3px; }
    .selector-btn { padding: 10px 12px; font-size: 12px; }
    #main-comparison-block { padding: 16px 12px; gap: 12px; }
    .category-tabs button { padding: 12px 14px; font-size: 13px; }
    .chart-spec-row { padding: 10px 12px; min-height: 48px; }
    .chart-spec-label { font-size: 13px; }
    .chart-view-summary-bar { height: 28px; margin-bottom: 16px; }
    .pdf-report-one { width: 100%; max-width: 100%; box-sizing: border-box; }
    
    /* Carrossel mobile */
    #aparelhos-carousel {
        margin-left: 0.5rem;
        margin-right: 0.5rem;
    }
}
/* iPhone 14 (390px) e telas muito estreitas */
@media (max-width: 390px) {
    .app-shell { padding-top: 148px; }
    .app-shell.container { padding-left: 12px; padding-right: 12px; }
    .hero-title-block h1 { font-size: 1.5rem; line-height: 1.15; }
    .hero-title-block .relative.px-6 { padding-left: 1rem; padding-right: 1rem; padding-top: 1.5rem; padding-bottom: 1.5rem; }
    .hero-premium .relative.px-6 { padding-left: 1rem; padding-right: 1rem; }
    
    /* Carrossel muito pequeno */
    #aparelhos-carousel {
        margin-left: 0.75rem;
        margin-right: 0.75rem;
    }
    
    #aparelhos-carousel .aparelho-slide h3 {
        font-size: 1rem;
    }
    
    #aparelhos-carousel .aparelho-slide p {
        font-size: 0.7rem;
    }
    
    /* Lista de comparativos - uma coluna */
    #lista-comparativos {
        gap: 10px;
    }
    
    .comparativo-card {
        padding: 12px 14px;
        font-size: 12px;
    }
    .hero-title-block .inline-block.px-4 { padding-left: 10px; padding-right: 10px; font-size: 9px; letter-spacing: 0.15em; }
    .selector-container { padding: 2px; max-width: 100%; }
    .selector-btn { font-size: 11px; padding: 8px 10px; min-height: 44px; }
    .view-selector-container { max-width: 100%; }
    #main-comparison-block { padding: 12px 10px; gap: 10px; }
    #moto-name, #samsung-name { font-size: 0.95rem; }
    .sticky-header-name { font-size: 11px; padding: 8px 6px; overflow: visible; white-space: normal; text-overflow: clip; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; line-height: 1.2; }
    #moto-name, #samsung-name { min-width: 0; word-break: break-word; }
    .category-tabs { padding-left: 40px; padding-right: 40px; }
    .category-tabs button { padding: 10px 12px; font-size: 12px; min-height: 44px; }
    .scroll-arrow { width: 32px; height: 32px; font-size: 14px; }
    .chart-spec-row { padding: 8px 10px; min-height: 44px; }
    .chart-spec-label { font-size: 12px; }
    .chart-view-summary-bar { height: 24px; margin-bottom: 12px; }
    #busca-comparativo { padding-top: 0.875rem; padding-bottom: 0.875rem; font-size: 16px; min-height: 48px; }
    #lista-comparativos { gap: 10px; }
    #lista-comparativos-footer button { width: 100%; max-width: 100%; padding: 14px 1rem; min-height: 48px; }
    .fixed.top-0 .max-w-6xl { padding-left: 10px; padding-right: 10px; }
}

/* Melhorias específicas para iPhone 14 (390px) - abas horizontais e tabela */
@media (max-width: 430px) {
    .category-tabs-container { position: relative; padding-left: 0; padding-right: 0; }
    .category-tabs { padding-left: 36px; padding-right: 36px; scroll-padding-left: 36px; scroll-padding-right: 36px; }
    .scroll-arrow { display: flex !important; }
    .scroll-arrow.hidden { display: none !important; }
    #category-content .grid.grid-cols-3 { gap: 0; }
    #category-content .grid.grid-cols-3 .spec-value { padding: 10px 8px; font-size: 13px; }
    #category-content .grid.grid-cols-3 .spec-value.winner { align-items: center; }
}
/* Scroll alvo: deixa espaço para o header fixo ao clicar no card (fora do @media para aplicar em todos os breakpoints) */
.scroll-target-comparison { scroll-margin-top: 100px; }
@media (min-width: 768px) { .scroll-target-comparison { scroll-margin-top: 110px; } }
/* Safe area: iPhone 14 (notch/Dynamic Island) e barra inferior do browser */
@supports (padding: env(safe-area-inset-top)) {
    .app-shell { padding-top: calc(192px + env(safe-area-inset-top)); }
    header.fixed.top-0 { padding-top: env(safe-area-inset-top); }
}
@supports (padding: env(safe-area-inset-bottom)) {
    .app-shell { padding-bottom: env(safe-area-inset-bottom); }
    #main-comparison-block { padding-bottom: calc(1.5rem + env(safe-area-inset-bottom)); }
    #category-content { padding-bottom: calc(1rem + env(safe-area-inset-bottom)); }
    #comparativos-aparelho-wrapper,
    #lista-comparativos-wrapper {
        padding-bottom: max(1.5rem, calc(1rem + env(safe-area-inset-bottom)));
    }
}
@media (max-width: 768px) {
    @supports (padding: env(safe-area-inset-top)) {
        .app-shell { padding-top: calc(176px + env(safe-area-inset-top)); }
    }
}
@media (max-width: 430px) {
    @supports (padding: env(safe-area-inset-top)) {
        .app-shell { padding-top: calc(156px + env(safe-area-inset-top)); }
    }
}
@media (max-width: 390px) {
    @supports (padding: env(safe-area-inset-top)) {
        .app-shell { padding-top: calc(148px + env(safe-area-inset-top)); }
    }
}
/* Touch targets mínimos (44px) para acessibilidade — inclui cards da lista */
@media (pointer: coarse) {
    .selector-btn, .view-selector-btn, .category-tabs button,
    #download-btn, #download-dropdown button,
    .scroll-arrow { min-height: 44px; }
    .comparativo-card { min-height: 48px; }
    .aparelho-card-cta {
        min-height: 44px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding-left: 1rem;
        padding-right: 1rem;
    }
    #btn-fechar-comparativos {
        min-width: 44px;
        min-height: 44px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 10px;
        border-radius: 12px;
    }
}

/* Overlay de loading do PDF */
#pdf-loading {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: none;
}

/* 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;
    touch-action: manipulation;
}
@media (max-width: 768px) {
    .hamburger-btn { min-width: 44px; min-height: 44px; padding: 12px; }
}
.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;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
    margin-bottom: 8px;
    border-radius: 12px;
    font-family: 'moto sans', system-ui, sans-serif;
    font-weight: 600;
    font-size: 14px;
    color: var(--moto-black);
    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;
    }
}
/* Responsividade do menu hambúrguer para iPhone 14 e telas pequenas */
@media (max-width: 430px) {
    .hamburger-menu-panel {
        width: 85vw;
        max-width: 320px;
        padding: 24px 20px;
    }
    .hamburger-menu-panel .menu-title {
        font-size: 9px !important;
        margin-bottom: 12px !important;
        padding-bottom: 10px !important;
    }
    .hamburger-menu-panel a {
        padding: 14px 16px;
        font-size: 15px;
    }
    .hamburger-menu-panel input {
        font-size: 16px !important; /* Evita zoom no iOS */
        padding: 12px 12px 12px 40px !important;
    }
}
@media (max-width: 390px) {
    .hamburger-menu-panel {
        width: 90vw;
        max-width: 300px;
        padding: 20px 16px;
    }
    .hamburger-menu-panel a {
        padding: 12px 14px;
        font-size: 14px;
    }
}
/* ============== Comparador personalizado (público) ============== */

.perso-card {
    background: linear-gradient(165deg, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0.65) 100%);
    backdrop-filter: blur(32px) saturate(1.5);
    -webkit-backdrop-filter: blur(32px) saturate(1.5);
    border: 1px solid rgba(255,255,255,0.95);
    border-radius: 28px;
    /* Sombra de elevação em 3 camadas: deep (lifts da página), médio (cushion)
       e highlight inset (sobre o vidro). Ancora o card como elemento principal
       sem ficar pesado/dramático. */
    box-shadow:
        0 32px 64px rgba(99, 104, 128, 0.14),
        0 12px 24px rgba(99, 104, 128, 0.08),
        0 1px 0 rgba(255, 255, 255, 0.9) inset,
        0 -1px 0 rgba(99, 104, 128, 0.04) inset;
    padding: 1.5rem 1.25rem 1.75rem;
    /* backdrop-filter cria um stacking context — o dropdown do combobox
       (filho do card) fica preso dentro dele. Elevamos o card quando há
       qualquer foco interno pra que o dropdown possa flutuar acima do
       conteúdo subsequente da página (divisor "ou" + #home-comparativos). */
    position: relative;
    z-index: 1;
}
/* z-index 40 fica acima de #home-comparativos (sem z-index = 0) pra o
   dropdown do combobox flutuar livre, MAS abaixo do header fixo (z-index 50)
   pra não cobrir o título "motorola vs concorrentes" quando o card recebe
   foco. Valores tipo 9999 antes vazavam pra cima do header. */
.perso-card:focus-within { z-index: 40; }
@media (min-width: 768px) {
    .perso-card { padding: 2rem 2.25rem 2.25rem; }
}
/* .perso-card__title e .perso-card__subtitle removidos — agora vivem fora do
   card como .eyebrow + .eyebrow-sub (mais premium, menos verboso). */
.perso-form {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.85rem;
    align-items: end;
    margin-bottom: 1.25rem;
}
@media (min-width: 720px) {
    .perso-form {
        grid-template-columns: 1fr auto 1fr;
        gap: 1rem;
    }
}
.perso-form__field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}
.perso-form__label {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding-left: 0.15rem;
}
.perso-form__label--moto { color: var(--slate-blue); }
.perso-form__label--rival { color: var(--slate-blue, #636880); }

.perso-form__select {
    width: 100%;
    padding: 1rem 1.25rem;
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(99,104,128,0.22);
    border-radius: 16px;
    color: var(--moto-black, #131417);
    font: inherit;
    font-size: 1rem;
    transition: border-color 0.15s, box-shadow 0.15s;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23636880' d='M6 8L0 0h12z'/></svg>");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    padding-right: 2.5rem;
}

/* ============================================================
   Combobox: substitui visualmente o <select> nativo por um input
   com autocomplete + dropdown filtrável. O <select> continua no
   DOM (escondido) como fonte de verdade pra sync e a11y.
   ============================================================ */
.perso-combobox {
    position: relative;
    width: 100%;
    /* z-index baixo no estado normal pra não roubar do header/menu; alto
       quando o dropdown está aberto (regra com :focus-within abaixo).
       Mantemos < 50 (header) pra não cobrir o título quando há foco. */
    z-index: 5;
}
.perso-combobox:focus-within { z-index: 40; }
.perso-combobox__source {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    white-space: nowrap;
}
.perso-combobox__input {
    width: 100%;
    padding: 1rem 2.5rem 1rem 1.25rem;
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(99,104,128,0.22);
    border-radius: 16px;
    color: var(--moto-black, #131417);
    font: inherit;
    font-size: 1rem;
    transition: border-color 0.15s, box-shadow 0.15s;
    cursor: text;
}
.perso-combobox__input::placeholder {
    color: rgba(99,104,128,0.62);
}
.perso-combobox__input:focus {
    outline: none;
    border-color: var(--slate-blue);
    box-shadow: 0 0 0 4px rgba(99,104,128,0.12);
}
.perso-combobox__caret {
    position: absolute;
    top: 50%;
    right: 0.35rem;
    transform: translateY(-50%);
    /* 44x44px atende WCAG 2.5.5 (target size) em touch — antes era 32x32. */
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 0;
    border-radius: 10px;
    color: var(--slate-blue, #636880);
    cursor: pointer;
    transition: background 0.12s;
}
.perso-combobox__caret:hover { background: rgba(99,104,128,0.08); }
.perso-combobox__dropdown {
    position: absolute;
    top: calc(100% + 0.35rem);
    left: 0;
    right: 0;
    /* Em mobile com teclado aberto, 320px estoura a tela. min(...) garante
       que nunca passa de 60% do viewport visível. */
    max-height: min(320px, 60vh);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    /* z-index bem alto porque o dropdown precisa flutuar acima do divisor "ou"
       e do card "comparativos oficiais" que vêm depois no DOM. O combobox e
       o card que o envolve também recebem z-index pra forçar um stacking
       context favorável (regra abaixo). */
    z-index: 9999;
    background: #fff;
    border: 1px solid rgba(99,104,128,0.22);
    border-radius: 14px;
    box-shadow: 0 18px 36px rgba(19,20,23,0.16), 0 4px 12px rgba(19,20,23,0.06);
    padding: 0.35rem;
    animation: persoComboFade 0.14s ease;
}
@keyframes persoComboFade {
    0% { opacity: 0; transform: translateY(-4px); }
    100% { opacity: 1; transform: translateY(0); }
}
.perso-combobox__item {
    display: block;
    width: 100%;
    /* min-height 44px = WCAG target em touch; padding extra em mobile. */
    min-height: 44px;
    text-align: left;
    padding: 0.7rem 0.9rem;
    background: transparent;
    border: 0;
    border-radius: 10px;
    font: inherit;
    font-size: 0.95rem;
    color: var(--moto-black, #131417);
    cursor: pointer;
    transition: background 0.1s, color 0.1s;
}
@media (max-width: 480px) {
    .perso-combobox__item {
        padding: 0.85rem 1rem;
        font-size: 1rem;
    }
}
.perso-combobox__item:hover,
.perso-combobox__item:focus {
    outline: none;
    background: rgba(99,104,128,0.10);
}
.perso-combobox__item.is-selected {
    background: var(--moto-black, #131417);
    color: #fff;
    font-weight: 600;
}
.perso-combobox__empty {
    padding: 1rem 0.9rem;
    color: var(--slate-blue, #636880);
    font-size: 0.88rem;
    text-align: center;
}
/* Item de MARCA no drill-down (dropdown do concorrente, modo agrupado).
   Layout: nome à esquerda, contador + "›" à direita. */
.perso-combobox__item--brand {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    font-weight: 600;
}
.perso-combobox__brand-name {
    flex: 1 1 auto;
}
.perso-combobox__brand-count {
    flex: 0 0 auto;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--slate-blue, #636880);
    letter-spacing: 0.02em;
}
.perso-combobox__item--brand:hover .perso-combobox__brand-count,
.perso-combobox__item--brand:focus .perso-combobox__brand-count {
    color: inherit;
}
/* Header "← Marca" no topo do drill-down (volta pra lista de marcas). */
.perso-combobox__back {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    min-height: 40px;
    padding: 0.55rem 0.9rem;
    margin-bottom: 0.25rem;
    background: rgba(99, 104, 128, 0.06);
    color: var(--slate-blue, #636880);
    font-size: 0.85rem;
    font-weight: 500;
}
.perso-combobox__back:hover,
.perso-combobox__back:focus {
    background: rgba(99, 104, 128, 0.14);
    color: var(--moto-black, #131417);
}
@media (prefers-reduced-motion: reduce) {
    .perso-combobox__dropdown { animation: none; }
}
.perso-form__select:focus {
    outline: none;
    border-color: var(--slate-blue);
    box-shadow: 0 0 0 4px rgba(104,91,199,0.12);
}
.perso-form__select:disabled {
    background-color: rgba(99,104,128,0.04);
    cursor: not-allowed;
    opacity: 0.6;
}
.perso-form__vs {
    text-align: center;
    font-size: 1rem;
    font-weight: 700;
    color: var(--slate-blue, #636880);
    text-transform: lowercase;
    padding-bottom: 0.85rem;
    user-select: none;
}
@media (min-width: 720px) {
    .perso-form__vs { font-size: 1.1rem; }
}
/* Botão Comparar — hierarquia visual reage ao estado.
   - Desabilitado (sem seleção): ghost discreto, baixo contraste.
     Não disputa atenção com o resto da página.
   - Habilitado: gradient indigo + sombra colorida + ícone — vira o CTA
     mais óbvio da seção sem precisar de "olha pra mim".
   - Hover: lift + sombra mais marcada + intensifica o gradient. */
.perso-form__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    width: 100%;
    padding: 0.95rem 1.5rem;
    border-radius: 14px;
    font: inherit;
    font-weight: 700;
    font-size: 0.95rem;
    letter-spacing: 0.01em;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease,
                box-shadow 0.25s ease, transform 0.18s ease;
    will-change: transform;
}
/* Estado desabilitado: ghost discreto. */
.perso-form__btn:disabled,
.perso-form__btn[disabled] {
    background: rgba(99, 104, 128, 0.06);
    color: rgba(99, 104, 128, 0.65);
    border: 1.5px dashed rgba(99, 104, 128, 0.28);
    box-shadow: none;
    cursor: not-allowed;
    transform: none;
}
/* Estado habilitado (sem hover): preto premium do site + ícone indigo (accent
   sutil) — mesma cor do botão "baixar" no header. Indigo aparece só no detalhe
   da seta, mantendo o padrão visual da página. */
.perso-form__btn:not(:disabled) {
    background: linear-gradient(135deg, #1d1d1f 0%, #000000 100%);
    color: white;
    border: 1px solid rgba(255,255,255,0.1);
    box-shadow: 0 12px 28px rgba(19, 20, 23, 0.22),
                0 4px 10px rgba(19, 20, 23, 0.12),
                inset 0 1px 0 rgba(255, 255, 255, 0.15);
    border-radius: 16px;
}
/* Hover: ligeiro lift e sombra mais marcada. */
.perso-form__btn:not(:disabled):hover {
    background: linear-gradient(135deg, #2a2a2d 0%, #131417 100%);
    transform: translateY(-3px);
    box-shadow: 0 18px 40px rgba(19, 20, 23, 0.28),
                0 6px 14px rgba(19, 20, 23, 0.15),
                inset 0 1px 0 rgba(255, 255, 255, 0.2);
}
/* Active (pressed): comprime. */
.perso-form__btn:not(:disabled):active {
    transform: translateY(0);
    box-shadow: 0 6px 14px rgba(19, 20, 23, 0.28),
                inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
/* Focus visível para teclado. */
.perso-form__btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 4px rgba(99, 104, 128, 0.22),
                0 12px 28px rgba(19, 20, 23, 0.30);
}
/* Ícone interno — indigo como accent de marca. */
.perso-form__btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    font-size: 0.95rem;
    color: var(--slate-blue);
    transition: transform 0.2s ease;
}
.perso-form__btn:not(:disabled):hover .perso-form__btn-icon {
    transform: translateX(3px);
}
.perso-form__btn:disabled .perso-form__btn-icon {
    color: rgba(99, 104, 128, 0.45);
}

/* Screen-reader only — hint do botão "Comparar" não vaza visualmente. */
.adm-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Resultado: tabela neutra side-by-side */
.perso-result {
    background: white;
    border-radius: 22px;
    border: 1px solid rgba(99,104,128,0.12);
    box-shadow: 0 12px 30px rgba(99,104,128,0.08);
    overflow: hidden;
}
.perso-notice {
    padding: 0.75rem 1.25rem;
    background: rgba(104,91,199,0.06);
    color: var(--slate-blue);
    font-size: 0.82rem;
    line-height: 1.4;
    border-bottom: 1px solid rgba(104,91,199,0.12);
}
.perso-notice strong {
    font-weight: 700;
    color: var(--moto-black, #131417);
}
.perso-notice i { margin-right: 0.4rem; }

.perso-header {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.25rem;
    border-bottom: 1px solid rgba(99,104,128,0.12);
}
@media (max-width: 520px) {
    .perso-header {
        gap: 0.5rem;
        padding: 0.75rem 0.75rem;
    }
    .perso-header__side img {
        width: 56px;
        height: 68px;
        border-radius: 8px;
    }
    .perso-header__name {
        font-size: 0.72rem;
        line-height: 1.2;
    }
    .perso-header__vs {
        font-size: 0.8rem;
    }
}
.perso-header__side {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
}
.perso-header__side img {
    width: 90px;
    height: 110px;
    object-fit: contain;
    background: rgba(99,104,128,0.04);
    border-radius: 12px;
}
@media (min-width: 720px) {
    .perso-header__side img { width: 120px; height: 150px; }
}
.perso-header__img-placeholder {
    width: 90px;
    height: 110px;
    background: rgba(99,104,128,0.06);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--slate-blue, #636880);
    font-size: 2rem;
    opacity: 0.4;
}
@media (min-width: 720px) {
    .perso-header__img-placeholder { width: 120px; height: 150px; font-size: 2.5rem; }
}
@media (max-width: 520px) {
    .perso-header__img-placeholder { width: 56px; height: 68px; font-size: 1.4rem; border-radius: 8px; }
}
.perso-header__name {
    text-align: center;
    font-weight: 700;
    font-size: 0.9rem;
    line-height: 1.25;
    color: var(--moto-black, #131417);
}
.perso-header__name--moto { color: var(--slate-blue); }
.perso-header__name--rival { color: var(--slate-blue, #636880); }
.perso-header__vs {
    font-size: 1.1rem;
    font-weight: 700;
    color: rgba(99,104,128,0.4);
    text-transform: lowercase;
}

/* Seções da tabela — stagger animation pra sensação de "construção".
   Cada seção entra com fade + translateY suave, escalonadas em 80ms.
   Limite no 12º item: depois disso, todos entram com o último delay
   (evita esperar demais em tabelas longas). */
@keyframes persoSectionEnter {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}
.perso-section {
    border-bottom: 1px solid rgba(99,104,128,0.08);
    opacity: 0;
    animation: persoSectionEnter 0.45s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
/* Estrutura: filho 1 = .perso-header; filhos 2..N = .perso-section;
   último = .perso-actions. Começa a contar do índice 2. */
.perso-section:nth-child(2)  { animation-delay: 0.08s; }
.perso-section:nth-child(3)  { animation-delay: 0.16s; }
.perso-section:nth-child(4)  { animation-delay: 0.24s; }
.perso-section:nth-child(5)  { animation-delay: 0.32s; }
.perso-section:nth-child(6)  { animation-delay: 0.40s; }
.perso-section:nth-child(7)  { animation-delay: 0.48s; }
.perso-section:nth-child(8)  { animation-delay: 0.56s; }
.perso-section:nth-child(9)  { animation-delay: 0.64s; }
.perso-section:nth-child(10) { animation-delay: 0.72s; }
.perso-section:nth-child(11) { animation-delay: 0.80s; }
.perso-section:nth-child(12) { animation-delay: 0.88s; }
.perso-section:nth-child(n+13) { animation-delay: 0.96s; }
.perso-section:last-child { border-bottom: 0; }
/* Respeita preferência de redução de movimento. */
@media (prefers-reduced-motion: reduce) {
    .perso-section {
        animation: none;
        opacity: 1;
    }
}
.perso-section__title {
    margin: 0;
    padding: 0.85rem 1.25rem;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--slate-blue);
    background: rgba(104,91,199,0.07);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-left: 3px solid var(--slate-blue);
    /* Evita que o sticky header cubra o título ao rolar com âncora */
    scroll-margin-top: 180px;
}
.perso-row {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: 0.5rem 1.5rem;
    padding: 0.65rem 1.25rem;
    border-top: 1px solid rgba(99,104,128,0.06);
    font-size: 0.85rem;
    line-height: 1.4;
    align-items: start;
}
.perso-row--head {
    background: rgba(99,104,128,0.04);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 0.7rem;
    letter-spacing: 0.07em;
    color: var(--slate-blue, #636880);
}
.perso-row__label {
    font-weight: 600;
    color: var(--moto-black, #131417);
    padding-right: 0.5rem;
}
.perso-row__moto {
    color: var(--moto-black, #131417);
    padding-left: 0.75rem;
    border-left: 2px solid var(--slate-blue);
}
.perso-row--head .perso-row__moto { color: var(--slate-blue); border-left-color: transparent; }
.perso-row__rival {
    color: var(--moto-black, #131417);
    padding-left: 0.75rem;
    border-left: 2px solid rgba(99,104,128,0.2);
}
.perso-row--head .perso-row__rival { color: var(--slate-blue, #636880); border-left-color: transparent; }

/* ============================================================
   Comparativo Automático: winner highlights + score panel
   ============================================================ */

/* Célula vencedora: fundo verde-suave + border-left mais grosso + bold */
.perso-row__moto.is-winner,
.perso-row__rival.is-winner {
    background: rgba(34, 197, 94, 0.10);
    border-left-color: rgba(34, 197, 94, 0.85);
    border-left-width: 3px;
    font-weight: 600;
    color: var(--moto-black, #131417);
    position: relative;
}
.perso-winner-icon {
    color: rgba(22, 163, 74, 0.95);
    margin-right: 0.35rem;
    font-size: 0.78rem;
    vertical-align: middle;
}

/* Mini-placar ao lado do título da seção (ex.: "Câmera  3 · 1") */
.perso-section__score {
    margin-left: 0.6rem;
    display: inline-flex;
    gap: 0.25rem;
    align-items: center;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: rgba(99, 104, 128, 0.8);
    text-transform: none;
}
.perso-section__score-moto {
    background: rgba(34, 197, 94, 0.14);
    color: rgba(22, 163, 74, 1);
    padding: 0.1rem 0.4rem;
    border-radius: 999px;
}
.perso-section__score-rival {
    background: rgba(99, 104, 128, 0.14);
    color: var(--slate-blue, #636880);
    padding: 0.1rem 0.4rem;
    border-radius: 999px;
}

/* Painel de score geral no topo do comparativo automático */
.perso-auto-score {
    margin: 1.25rem 0 1.5rem;
    padding: 1.25rem 1.5rem;
    background: linear-gradient(135deg, rgba(255,255,255,0.85) 0%, rgba(255,255,255,0.65) 100%);
    backdrop-filter: blur(20px) saturate(1.4);
    -webkit-backdrop-filter: blur(20px) saturate(1.4);
    border: 1px solid rgba(255,255,255,0.95);
    border-radius: 20px;
    box-shadow: 0 12px 32px rgba(99,104,128,0.10), 0 4px 12px rgba(19,20,23,0.04);
    position: relative;
}
.perso-auto-score__title {
    text-align: center;
    font-size: 0.95rem;
    color: var(--moto-black, #131417);
    margin-bottom: 1rem;
}
.perso-auto-score__title i {
    color: rgba(234, 179, 8, 1);
    margin-right: 0.4rem;
}
.perso-auto-score__title strong {
    font-weight: 700;
}
.perso-auto-score__bars {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-bottom: 0.85rem;
}
.perso-auto-score__side {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;             /* era 0.35rem — pequeno demais, fazia "16 pts" colar na barra/label */
    padding: 0.85rem 1rem;    /* padding maior pra respirar */
    background: rgba(255, 255, 255, 0.5);
    border: 1px solid rgba(99, 104, 128, 0.12);
    border-radius: 14px;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.perso-auto-score__side.is-winner {
    border-color: rgba(34, 197, 94, 0.55);
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.12);
    background: rgba(220, 252, 231, 0.40);
}
.perso-auto-score__label {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--slate-blue, #636880);
    text-transform: lowercase;
    letter-spacing: 0.01em;
    line-height: 1.3;
    word-break: break-word;
}
.perso-auto-score__bar {
    width: 100%;
    height: 8px;
    background: rgba(99, 104, 128, 0.12);
    border-radius: 4px;
    overflow: hidden;
}
.perso-auto-score__fill {
    height: 100%;
    background: linear-gradient(90deg, var(--slate-blue) 0%, var(--moto-black) 100%);
    transition: width 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.perso-auto-score__side.is-winner .perso-auto-score__fill {
    background: linear-gradient(90deg, rgba(34, 197, 94, 0.78) 0%, rgba(22, 163, 74, 1) 100%);
}
.perso-auto-score__points {
    font-family: 'moto sans', Inter, system-ui, sans-serif;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--moto-black, #131417);
    line-height: 1;
}
.perso-auto-score__points span {
    font-size: 0.7rem;
    font-weight: 500;
    color: var(--slate-blue, #636880);
    margin-left: 0.15rem;
}
.perso-auto-score__meta {
    text-align: center;
    font-size: 0.78rem;
    color: var(--slate-blue, #636880);
    line-height: 1.5;
}
.perso-auto-score__badge {
    position: absolute;
    top: -0.7rem;
    left: 50%;
    transform: translateX(-50%);
    background: var(--moto-black, #131417);
    color: white;
    font-size: 0.7rem;
    font-weight: 700;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    text-transform: lowercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}


@media (max-width: 560px) {
    .perso-auto-score { padding: 1.5rem 1rem 1rem; }
    .perso-auto-score__bars { grid-template-columns: 1fr; gap: 0.6rem; }
    .perso-auto-score__points { font-size: 1.2rem; }
}

.perso-empty {
    padding: 2rem 1.25rem;
    text-align: center;
    color: var(--slate-blue, #636880);
    font-size: 0.9rem;
}
.perso-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3.5rem 1.5rem;
    background: rgba(255, 255, 255, 0.45);
    border: 1.5px dashed rgba(99, 104, 128, 0.25);
    border-radius: 24px;
    color: var(--slate-blue);
    text-align: center;
    font-size: 0.95rem;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.perso-empty-state__icon {
    font-size: 2.8rem;
    margin-bottom: 1rem;
    color: rgba(99, 104, 128, 0.25);
}
.perso-empty-state__title {
    font-family: 'moto sans', Inter, system-ui, sans-serif;
    font-weight: 700;
    font-size: 1.05rem;
    color: var(--moto-black, #131417);
    margin-bottom: 0.5rem;
    text-transform: lowercase;
    letter-spacing: -0.005em;
}
.perso-empty-state__text {
    max-width: 460px;
    margin: 0 auto;
    line-height: 1.55;
    color: var(--slate-blue, #636880);
}
.perso-empty-state__text strong {
    color: var(--moto-black, #131417);
    font-weight: 600;
}
.fade-in-staggered {
    opacity: 0;
    animation: persoSectionFadeIn 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@keyframes persoSectionFadeIn {
    0% { opacity: 0; transform: translateY(15px); }
    100% { opacity: 1; transform: translateY(0); }
}

@media (max-width: 520px) {
    .perso-section__title {
        font-size: 0.78rem;
        padding: 0.75rem 1rem;
        background: rgba(104,91,199,0.06);
        border-left: 3px solid var(--slate-blue);
        letter-spacing: 0.1em;
    }
    .perso-row {
        grid-template-columns: 1fr 1fr;
        gap: 0.15rem 0.75rem;
        padding: 0.75rem 1rem;
        border-top: 1px solid rgba(99,104,128,0.06);
        align-items: stretch;
    }
    .perso-row__label {
        grid-column: 1 / -1;
        font-weight: 700;
        color: var(--slate-blue);
        font-size: 0.7rem;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        margin-bottom: 0.15rem;
    }
    .perso-row__moto,
    .perso-row__rival {
        font-size: 0.82rem;
        line-height: 1.35;
        padding: 0.45rem 0.6rem;
        border-radius: 8px;
        background: rgba(99,104,128,0.03);
        display: flex;
        align-items: center;
    }
    .perso-row__moto {
        border-left: 2px solid var(--slate-blue);
    }
    .perso-row__rival {
        border-left: 2px solid rgba(99,104,128,0.25);
    }
    .perso-row__moto::before,
    .perso-row__rival::before {
        display: none;
    }
    .perso-row--head { display: none; }
}

/* Ações do resultado personalizado (Baixar PDF + Compartilhar) */
.perso-actions {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.75rem;
    padding: 1.25rem;
    border-top: 1px solid rgba(99,104,128,0.10);
    background: rgba(255,255,255,0.6);
}
.perso-actions__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.85rem 1.75rem;
    background: var(--moto-black, #131417);
    color: white;
    border: 0;
    border-radius: 14px;
    font: inherit;
    font-weight: 700;
    font-size: 0.9rem;
    cursor: pointer;
    transition: background 0.15s, transform 0.15s, box-shadow 0.15s;
}
.perso-actions__btn:hover:not(:disabled) {
    background: var(--slate-blue);
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(99,104,128,0.25);
}
.perso-actions__btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}
.perso-actions__btn i {
    font-size: 0.95rem;
}
/* Variante secundária — visual mais leve para Compartilhar, mantendo paridade premium. */
.perso-actions__btn--secondary {
    background: transparent;
    color: var(--moto-black, #131417);
    border: 1.5px solid rgba(19,20,23,0.18);
}
.perso-actions__btn--secondary:hover:not(:disabled) {
    background: rgba(19,20,23,0.04);
    border-color: rgba(19,20,23,0.32);
    color: var(--moto-black, #131417);
    box-shadow: 0 6px 14px rgba(99,104,128,0.12);
}

/* Indicador "análise editorial disponível" no card de seleção. */
.perso-editorial-hint {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    margin: 0 1.25rem 1rem 1.25rem;
    padding: 0.75rem 1rem;
    background: linear-gradient(135deg, rgba(99,104,128,0.06), rgba(99,104,128,0.02));
    border: 1px solid rgba(99,104,128,0.18);
    border-radius: 12px;
    color: var(--moto-black, #131417);
    font-size: 0.85rem;
    line-height: 1.4;
    text-align: center;
    animation: persoHintFadeIn 0.32s ease;
}
.perso-editorial-hint__icon {
    color: var(--slate-blue, #636880);
    font-size: 0.95rem;
    flex: 0 0 auto;
}
.perso-editorial-hint__text strong {
    font-weight: 700;
    color: var(--moto-black, #131417);
}
@keyframes persoHintFadeIn {
    0% { opacity: 0; transform: translateY(-4px); }
    100% { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
    .perso-editorial-hint { animation: none; }
}

/* Toast leve para feedback de "Link copiado" e similares. */
.perso-toast {
    position: fixed;
    left: 50%;
    bottom: 24px;
    transform: translateX(-50%) translateY(16px);
    z-index: 10000;
    padding: 0.7rem 1.1rem;
    background: var(--moto-black, #131417);
    color: white;
    border-radius: 12px;
    font-size: 0.85rem;
    font-weight: 600;
    box-shadow: 0 12px 28px rgba(19,20,23,0.25);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.18s ease, transform 0.18s ease;
    max-width: calc(100% - 32px);
    text-align: center;
}
.perso-toast--visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}
@media (prefers-reduced-motion: reduce) {
    .perso-toast { transition: opacity 0.12s ease; transform: translateX(-50%); }
    .perso-toast--visible { transform: translateX(-50%); }
}

/* Overlay "Gerando PDF…" do comparador personalizado */
.perso-pdf-loading {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(19, 20, 23, 0.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    animation: persoLoadingFade 0.18s ease;
}
.perso-pdf-loading[hidden] { display: none; }
@keyframes persoLoadingFade {
    from { opacity: 0; }
    to { opacity: 1; }
}
.perso-pdf-loading__box {
    background: white;
    border-radius: 20px;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
    padding: 2rem 2.5rem;
    text-align: center;
    max-width: 320px;
}
.perso-pdf-loading__spinner {
    width: 48px;
    height: 48px;
    margin: 0 auto 1rem;
    border: 4px solid rgba(99, 104, 128, 0.15);
    border-top-color: var(--slate-blue);
    border-radius: 50%;
    animation: persoSpin 0.85s linear infinite;
}
@keyframes persoSpin {
    to { transform: rotate(360deg); }
}
.perso-pdf-loading__title {
    font-family: 'moto sans', sans-serif;
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--moto-black, #131417);
    margin-bottom: 0.4rem;
    letter-spacing: -0.01em;
    /* Regra da marca: moto sans sempre em minúsculas. */
    text-transform: lowercase;
}
.perso-pdf-loading__hint {
    font-size: 0.85rem;
    color: var(--slate-blue, #636880);
    line-height: 1.4;
}

/* Preview do aparelho selecionado (antecipação visual após escolha no dropdown).
   Aparece com fade-slide assim que o usuário escolhe — dá feedback imediato
   e gera "antecipação" do resultado antes mesmo de clicar Comparar. */
.perso-preview {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.55rem 0.65rem 0.55rem 0.55rem;
    background: rgba(255, 255, 255, 0.55);
    border: 1px solid rgba(99, 104, 128, 0.10);
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(99, 104, 128, 0.06);
    animation: persoPreviewSlide 0.25s cubic-bezier(0.16, 1, 0.3, 1);
    will-change: transform, opacity;
}
.perso-preview[hidden] { display: none; }
@keyframes persoPreviewSlide {
    from { opacity: 0; transform: translateY(-4px) scale(0.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
.perso-preview__thumb {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 10px;
    background: white;
    border: 1px solid rgba(99, 104, 128, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.perso-preview__thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.perso-preview__thumb--placeholder {
    color: rgba(99, 104, 128, 0.35);
    font-size: 1.1rem;
}
.perso-preview__body {
    flex: 1;
    min-width: 0;
}
.perso-preview__name {
    font-weight: 700;
    font-size: 0.82rem;
    line-height: 1.25;
    color: var(--moto-black, #131417);
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.perso-preview__sub {
    display: block;
    font-size: 0.7rem;
    color: var(--slate-blue, #636880);
    margin-top: 0.1rem;
    letter-spacing: 0.02em;
}
.perso-preview--moto {
    border-color: rgba(99, 104, 128, 0.18);
    background: linear-gradient(135deg, rgba(99, 104, 128, 0.06), rgba(255, 255, 255, 0.45));
}
.perso-preview--moto .perso-preview__name {
    color: var(--slate-blue);
}
.perso-preview--rival {
    border-color: rgba(99, 104, 128, 0.16);
    background: linear-gradient(135deg, rgba(99, 104, 128, 0.06), rgba(255, 255, 255, 0.45));
}

/* Eyebrow — kicker discreto para introduzir cada seção. Vocabulário visual
   premium (Apple, Aesop): texto em uppercase com letterspacing wide, traço
   curto antes, peso moderado. Não disputa atenção com o conteúdo abaixo. */
.eyebrow {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    margin-bottom: 0.85rem;
    padding: 0 1.25rem;
}
.eyebrow__line {
    flex-shrink: 0;
    width: 32px;
    height: 1px;
    background: var(--slate-blue);
    opacity: 0.55;
}
.eyebrow__text {
    font-family: 'moto sans', sans-serif;
    font-weight: 700;
    font-size: 0.82rem;
    line-height: 1;
    color: var(--slate-blue);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    text-align: center;
    white-space: nowrap;
}
@media (max-width: 430px) {
    .eyebrow {
        gap: 0.5rem;
        padding: 0 1rem;
    }
    .eyebrow__line { width: 20px; }
    .eyebrow__text {
        font-size: 0.68rem;
        letter-spacing: 0.12em;
        white-space: normal;
        text-align: center;
    }
}
@media (min-width: 768px) {
    .eyebrow { padding: 0; }
    .eyebrow__line { width: 42px; }
    .eyebrow__text { font-size: 0.9rem; letter-spacing: 0.2em; }
}
.eyebrow-sub {
    margin: 0 auto 1.5rem;
    color: var(--slate-blue);
    font-size: 0.9rem;
    line-height: 1.55;
    max-width: 38rem;
    opacity: 0.85;
    text-align: center;
    padding: 0 1.25rem;
}
@media (max-width: 430px) {
    .eyebrow-sub {
        font-size: 0.85rem;
        padding: 0 1rem;
    }
}
@media (min-width: 768px) {
    .eyebrow-sub { font-size: 0.95rem; margin-bottom: 1.75rem; padding: 0; }
}

/* Separador "ou" entre as duas seções — comunica que são caminhos paralelos
   (alternativas), não passos sequenciais. Centralizado, hairline em ambos os
   lados, texto pequeno no meio. */
.section-divider {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    max-width: 30rem;
    margin: 3rem auto;
    padding: 0 1rem;
}
@media (min-width: 768px) {
    .section-divider { margin: 4rem auto; }
}
.section-divider__line {
    flex: 1;
    height: 1px;
    background: var(--slate-blue);
    opacity: 0.25;
}
.section-divider__text {
    font-family: 'moto sans', sans-serif;
    font-weight: 600;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--slate-blue);
    opacity: 0.75;
    flex-shrink: 0;
}

/* Toggle entre Comparativos Personalizados e Recomendados.
   Os 2 .hero-nav-btn[data-mode] no topo são as tabs. Body recebe
   data-comparativos-mode="auto|editorial" e os blocos de conteúdo com
   data-mode correspondente são mostrados via seletores CSS abaixo.
   :not(.hero-nav-btn) é essencial — sem isso o CSS esconderia também os
   próprios botões do toggle (eles têm data-mode pra indicar qual modo
   acionam). */
body[data-comparativos-mode="auto"] [data-mode="editorial"]:not(.mode-selector-btn) { display: none !important; }
body[data-comparativos-mode="editorial"] [data-mode="auto"]:not(.mode-selector-btn) { display: none !important; }

/* Utilitário para esconder barras de rolagem mantendo a funcionalidade */
.scrollbar-hide {
    -ms-overflow-style: none !important;  /* IE e Edge */
    scrollbar-width: none !important;  /* Firefox */
}
.scrollbar-hide::-webkit-scrollbar {
    display: none !important;  /* Chrome, Safari, Opera */
}

/* Novo Segmented Control do Hero (Toggle Premium) */
.mode-selector-container {
    position: relative;
    display: flex;
    background: rgba(220, 222, 235, 0.45);
    border: 1px solid rgba(255, 255, 255, 0.85);
    border-radius: 9999px;
    padding: 5px;
    box-shadow: 0 4px 15px rgba(99, 104, 128, 0.06), 0 1px 0 rgba(255, 255, 255, 0.95) inset;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    width: 100%;
    max-width: 520px;
    margin: 0 auto;
}
@media (max-width: 640px) {
    .mode-selector-container {
        flex-direction: column;
        border-radius: 20px;
        padding: 6px;
    }
}

.mode-selector-btn {
    position: relative;
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.8rem 1.2rem;
    font-family: 'moto sans', system-ui, sans-serif !important;
    font-weight: 600;
    font-size: 0.82rem;
    color: var(--slate-blue);
    text-transform: lowercase !important;
    cursor: pointer;
    transition: color 0.3s cubic-bezier(0.25, 1, 0.5, 1);
    z-index: 10;
    border: none;
    background: none;
    -webkit-tap-highlight-color: transparent;
}
@media (max-width: 640px) {
    .mode-selector-btn {
        width: 100%;
        padding: 0.65rem 1rem;
        font-size: 0.78rem;
    }
}

.mode-selector-btn i {
    font-size: 0.95rem;
    transition: transform 0.3s ease;
}
.mode-selector-btn:hover i {
    transform: scale(1.1);
}

.mode-selector-btn.is-active {
    color: var(--white) !important;
}
.mode-selector-btn.is-active i {
    color: var(--white) !important;
}

.mode-selector-slider {
    position: absolute;
    top: 5px;
    bottom: 5px;
    left: 5px;
    width: calc(50% - 5px);
    background-color: var(--moto-black, #131417);
    border-radius: 9999px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    transition: transform 0.35s cubic-bezier(0.25, 1, 0.5, 1);
    z-index: 5;
}
@media (max-width: 640px) {
    .mode-selector-slider {
        position: absolute;
        top: 6px;
        left: 6px;
        right: 6px;
        width: calc(100% - 12px);
        height: calc(50% - 6px);
        transition: transform 0.35s cubic-bezier(0.25, 1, 0.5, 1);
    }
    body[data-comparativos-mode="auto"] .mode-selector-slider {
        transform: translateY(0);
    }
    body[data-comparativos-mode="editorial"] .mode-selector-slider {
        transform: translateY(100%);
    }
}
@media (min-width: 641px) {
    body[data-comparativos-mode="auto"] .mode-selector-slider {
        transform: translateX(0);
    }
    body[data-comparativos-mode="editorial"] .mode-selector-slider {
        transform: translateX(100%);
    }
}
