/* ============================================================
   ji-catalogo.css — catálogo, produto, orçamento, contato, mini-cart.
   Carregado depois de ji.css. Usa as variáveis --ji-*.
   ============================================================ */

/* Cabeçalho de página */
.ji-pagehead { background: linear-gradient(125deg, var(--ji-navy) 0%, #244f67 100%); color: #fff; padding: 56px 0; }
.ji-pagehead--slim { padding: 30px 0; }
.ji-pagehead h1 { color: #fff; font-size: clamp(1.9rem, 3.6vw, 2.8rem); margin: 8px 0 12px; font-weight: 900; }
.ji-pagehead p { color: #d4def0; max-width: 760px; margin: 0; font-size: 1.08rem; }
.ji-bread { font-size: .95rem; color: #aebbd8; }
.ji-bread a { color: #cdd8ee; }
.ji-bread a:hover { color: var(--ji-amarelo); }
.ji-bread span { margin: 0 6px; opacity: .6; }

/* Cabeçalho de seção em linha */
.ji-sec__head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.ji-vermais { font-weight: 700; color: var(--ji-azul); white-space: nowrap; }
.secao--alt { background: #f4f6fa; }

/* Grid de produtos */
.prod-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.prod-card { display: flex; flex-direction: column; background: #fff; border: 1px solid #e4e8f0; border-radius: 14px; overflow: hidden; transition: transform .15s ease, box-shadow .15s ease; }
.prod-card:hover { transform: translateY(-5px); box-shadow: 0 16px 34px rgba(3,19,43,.12); }
.prod-card__foto { display: block; aspect-ratio: 1 / 1; background: #fff; overflow: hidden; padding: 8px; }
.prod-card__foto img { width: 100%; height: 100%; object-fit: contain; }
.prod-card__corpo { padding: 18px 18px 20px; display: flex; flex-direction: column; flex: 1 1 auto; }
.prod-card__nome { font-size: 1.12rem; margin: 0 0 10px; line-height: 1.25; }
.prod-card__nome a { color: var(--ji-navy); }
.prod-card__nome a:hover { color: var(--ji-azul); }
.prod-card__selos { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.prod-card__selos span { background: #eef3fb; color: var(--ji-azul); font-size: .76rem; font-weight: 700; padding: 4px 9px; border-radius: 20px; }
.prod-card__add { margin-top: auto; font-size: .95rem; padding: 11px 14px; }
.btn.add-ok { background: #1f9d55 !important; }

/* Página de produto */
.produto { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: start; }
.produto__galeria { border: 1px solid #e4e8f0; border-radius: 14px; overflow: hidden; background: #eef1f6; }
.produto__galeria img { width: 100%; display: block; }
.produto__nome { font-size: clamp(1.7rem, 3vw, 2.4rem); color: var(--ji-navy); margin: 0 0 18px; font-weight: 900; }
.produto__selos { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 20px; }
.produto__selos span { display: inline-flex; align-items: center; gap: 6px; background: #eef3fb; color: var(--ji-azul); font-weight: 700; font-size: .9rem; padding: 7px 13px; border-radius: 20px; }
.produto__desc { font-size: 1.1rem; color: #45505f; margin: 0 0 26px; }
.produto__form { display: flex; gap: 14px; align-items: flex-end; flex-wrap: wrap; margin-bottom: 14px; }
.produto__qtd label { display: block; font-size: .85rem; color: var(--ji-navy); font-weight: 700; margin-bottom: 6px; }
.produto__qtd input { width: 90px; padding: 13px; border: 1px solid #cfd6e2; border-radius: 10px; font-size: 1rem; }
.btn-grande { padding: 15px 28px; font-size: 1.05rem; }
.produto__whats { display: inline-block; margin-bottom: 24px; color: #1f9d55; font-weight: 700; }
.produto__specs { width: 100%; border-collapse: separate; border-spacing: 0; border: 1px solid #e4e8f0; border-radius: 12px; overflow: hidden; }
.produto__specs th, .produto__specs td { text-align: left; padding: 15px 18px; border-bottom: 1px solid #eef1f6; vertical-align: middle; line-height: 1.4; }
.produto__specs tr:last-child th, .produto__specs tr:last-child td { border-bottom: 0; }
.produto__specs th { color: #5b6470; font-weight: 600; width: 150px; background: #f7f9fc; border-right: 1px solid #eef1f6; }
.produto__specs td { color: var(--ji-navy); font-weight: 500; }
.produto__specs td a { color: var(--ji-azul); font-weight: 700; }

/* Mini-cart (badge) */
.ji-cart { position: relative; color: var(--ji-navy); font-size: 1.5rem; display: inline-flex; align-items: center; }
.ji-cart:hover { color: var(--ji-azul); }
.ji-cart__badge { position: absolute; top: -8px; right: -10px; min-width: 18px; height: 18px; padding: 0 5px; background: #cfd6e2; color: #fff; border-radius: 10px; font-size: .72rem; font-weight: 800; display: grid; place-items: center; line-height: 1; }
.ji-cart__badge.tem { background: var(--ji-vermelho); }
.ji-mobile__acoes { display: flex; align-items: center; gap: 16px; }

/* Página de orçamento */
.container--orc { max-width: 980px; }
.orc-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 34px; align-items: start; }
.orc-h2 { font-size: 1.3rem; color: var(--ji-navy); margin: 0 0 18px; }
.orc-item { display: grid; grid-template-columns: 1fr auto auto; align-items: center; gap: 14px; padding: 14px 0; border-bottom: 1px solid #e4e8f0; }
.orc-item__nome { font-weight: 600; color: var(--ji-navy); }
.orc-item__qtd { display: inline-flex; align-items: center; border: 1px solid #cfd6e2; border-radius: 10px; overflow: hidden; }
.orc-item__qtd button { background: #f4f6fa; border: 0; width: 34px; height: 38px; font-size: 1.2rem; cursor: pointer; color: var(--ji-navy); }
.orc-item__qtd input { width: 48px; height: 38px; border: 0; text-align: center; font-size: 1rem; color: var(--ji-navy); background: #fff; font-weight: 600; -moz-appearance: textfield; }
.orc-item__qtd input::-webkit-outer-spin-button, .orc-item__qtd input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.orc-item__remover { background: none; border: 0; font-size: 1.5rem; color: #b8c0cc; cursor: pointer; line-height: 1; }
.orc-item__remover:hover { color: var(--ji-vermelho); }
.orc-form { background: #f4f6fa; border: 1px solid #e4e8f0; border-radius: 14px; padding: 26px; }
.orc-form label { display: block; font-weight: 700; color: var(--ji-navy); font-size: .9rem; margin-bottom: 14px; }
.orc-form input, .orc-form select, .orc-form textarea { width: 100%; margin-top: 6px; padding: 12px; border: 1px solid #cfd6e2; border-radius: 10px; font-size: 1rem; font-weight: 400; font-family: inherit; }
.btn-full { width: 100%; }
.orc-form__nota { font-size: .82rem; color: #7a8699; margin: 12px 0 0; text-align: center; }
.orc-vazio { text-align: center; padding: 60px 0; }
.orc-vazio .icon { font-size: 3.4rem; color: #c4cdda; }
.orc-vazio p { font-size: 1.15rem; color: #5b6470; margin: 14px 0 22px; }

/* Sobre / Contato */
.sobre-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 44px; align-items: center; }
.sobre-lista { list-style: none; margin: 0; padding: 0; display: grid; gap: 14px; }
.sobre-lista li { position: relative; padding-left: 32px; font-weight: 600; color: var(--ji-navy); }
.sobre-lista li::before { content: "\2713"; position: absolute; left: 0; top: -1px; width: 22px; height: 22px; background: var(--ji-azul); color: #fff; border-radius: 50%; display: grid; place-items: center; font-size: .8rem; }
.contato-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.contato-card { display: flex; flex-direction: column; gap: 6px; padding: 28px; background: #fff; border: 1px solid #e4e8f0; border-radius: 14px; color: var(--ji-navy); text-decoration: none; transition: .15s; }
a.contato-card:hover { transform: translateY(-4px); box-shadow: 0 14px 30px rgba(3,19,43,.10); border-color: var(--ji-azul); }
.contato-card .icon { font-size: 2.2rem; color: var(--ji-azul); }
.contato-card h3 { margin: 6px 0 2px; font-size: 1.1rem; }
.contato-card p { margin: 0; color: #5b6470; }

@media (max-width: 1100px) { .prod-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 820px) {
    .prod-grid { grid-template-columns: 1fr 1fr; }
    .produto { grid-template-columns: 1fr; gap: 28px; }
    .orc-grid { grid-template-columns: 1fr; }
    .sobre-grid { grid-template-columns: 1fr; gap: 28px; }
    .contato-grid { grid-template-columns: 1fr 1fr; }
}
/* Mobile: 1 produto por linha (card grande, um embaixo do outro) em TODO o catálogo */
@media (max-width: 600px) { .prod-grid { grid-template-columns: 1fr; gap: 18px; } .contato-grid { grid-template-columns: 1fr; } }

/* ---------- Depoimentos (home) ---------- */
.depo-sec { background: #f4f6fa; }
.depo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.depo { background: #fff; border: 1px solid #e4e8f0; border-radius: 14px; padding: 30px; margin: 0; display: flex; flex-direction: column; gap: 14px; box-shadow: 0 6px 18px rgba(3,19,43,.05); }
.depo__estrelas { color: #ffc400; font-size: 1.05rem; letter-spacing: 1px; }
.depo__texto { margin: 0; color: #45505f; font-size: 1.04rem; line-height: 1.65; font-style: italic; flex: 1 1 auto; }
.depo__autor { font-weight: 800; color: var(--ji-navy); display: flex; flex-direction: column; }
.depo__autor span { font-weight: 500; color: #7a8699; font-size: .9rem; margin-top: 2px; }
@media (max-width: 900px) { .depo-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .depo-grid { grid-template-columns: 1fr; } }

/* Busca no catálogo */
.ji-busca { display: flex; align-items: center; gap: 10px; background: #fff; border-radius: 12px; padding: 6px 6px 6px 16px; max-width: 560px; margin-top: 24px; box-shadow: 0 10px 28px rgba(0,0,0,.18); }
.ji-busca .icon { color: #7a8699; font-size: 1.3rem; }
.ji-busca input { flex: 1; border: 0; outline: 0; font-size: 1rem; padding: 11px 4px; color: var(--ji-navy); background: transparent; }
.ji-busca button { background: var(--ji-azul); color: #fff; border: 0; border-radius: 9px; padding: 12px 24px; font-weight: 700; cursor: pointer; }
.ji-busca button:hover { background: #1f4f86; }
@media (max-width: 560px) { .ji-busca button { padding: 12px 16px; } }

/* Galeria do produto (principal + miniaturas) */
.produto__galeria { border: 0; background: transparent; border-radius: 0; overflow: visible; }
.produto__principal { border: 1px solid #e4e8f0; border-radius: 14px; overflow: hidden; background: #fff; padding: 10px; }
.produto__principal img { width: 100%; display: block; aspect-ratio: 1 / 1; object-fit: contain; }
.produto__thumbs { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.produto__thumb { width: 76px; height: 60px; border-radius: 8px; overflow: hidden; border: 2px solid transparent; background: #fff; cursor: pointer; padding: 4px; transition: border-color .12s; }
.produto__thumb img { width: 100%; height: 100%; object-fit: contain; display: block; }
.produto__thumb:hover { border-color: #c5cee0; }
.produto__thumb.ativo { border-color: var(--ji-azul); }

/* Páginas legais (Termos / Política) */
.ji-legal { max-width: 820px; }
.ji-legal h2 { color: var(--ji-navy); font-size: 1.3rem; margin: 34px 0 12px; }
.ji-legal p, .ji-legal li { color: #45505f; line-height: 1.7; font-size: 1.02rem; }
.ji-legal ul { padding-left: 20px; margin: 0 0 12px; }
.ji-legal a { color: var(--ji-azul); font-weight: 600; }
.ji-legal__data { color: #8a93a8; font-size: .9rem; margin-bottom: 22px; }

/* ============================================================
   CORREÇÕES MOBILE — precisam ficar AQUI (ji-catalogo.css carrega por
   ÚLTIMO, então vence o ji.css). Carrossel e cards de produto.
   ============================================================ */
@media (max-width: 600px) {
    /* Carrossel "Para cada setor": empilha título + setas, ambos centralizados */
    .ji-sec__head--row { flex-direction: column; align-items: center; text-align: center; gap: 16px; }
    .ji-sec__head--row > div:first-child { width: 100%; }
    .ji-carousel__nav { justify-content: center; }
    .ji-vermais { align-self: center; }

    /* Card de produto em 1 COLUNA (full-width): botão completo e confortável */
    .prod-card__add-extra { display: inline; }
    .prod-card__add { font-size: 1.02rem; padding: 14px 16px; }
    .prod-card__nome { font-size: 1.2rem; }
    .prod-card__foto { aspect-ratio: 16 / 10; }
}

/* ============================================================
   CARRINHO no mobile: item em 2 linhas, × visível, sem overflow
   ============================================================ */
@media (max-width: 600px) {
    .orc-item { grid-template-columns: 1fr auto; gap: 10px 12px; min-width: 0; }
    .orc-item__nome { grid-column: 1 / -1; font-size: 1.05rem; }
    .orc-item__qtd { justify-self: start; }
    .orc-item__remover { justify-self: end; font-size: 1.7rem; color: #5b6470; padding: 2px 6px; }
    .orc-item__remover:hover { color: var(--ji-vermelho); }
    .orc-itens, .orc-form, .orc-grid { min-width: 0; }
    .orc-h2 { text-align: left; }
}

/* Produtos em destaque: 1 grande (esquerda) + 4 pequenos 2x2 (direita) */
.ji-destaque { display: grid; grid-template-columns: 1.05fr 1fr; gap: 24px; align-items: stretch; }
.ji-destaque__big { display: flex; }
.ji-destaque__big .prod-card { width: 100%; }
.ji-destaque__big .prod-card__foto { aspect-ratio: auto; flex: 1 1 auto; min-height: 360px; }
.ji-destaque__big .prod-card__corpo { flex: 0 0 auto; padding: 24px 24px 26px; }
.ji-destaque__big .prod-card__nome { font-size: 1.55rem; }
.ji-destaque__big .prod-card__add { font-size: 1.05rem; padding: 14px 18px; }
.ji-destaque__mini { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-content: stretch; }
@media (max-width: 820px) {
    .ji-destaque { grid-template-columns: 1fr; }
    .ji-destaque__big .prod-card__foto { min-height: 260px; }
}
@media (max-width: 600px) { .ji-destaque__mini { grid-template-columns: 1fr; } }

/* ============================================================
   JUSTO INOX — componentes adicionais (hero selos, blog, mini-LP de produto)
   ============================================================ */

/* Selos sob o hero */
.ji-hero__selos { list-style: none; display: flex; flex-wrap: wrap; gap: 10px 14px; padding: 0; margin: 30px 0 0; }
.ji-hero__selos li { display: inline-flex; align-items: baseline; gap: 6px; padding: 7px 14px; border-radius: 30px; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.18); color: #fff; font-size: .92rem; }
.ji-hero__selos strong { color: #fff; font-weight: 800; }
.ji-hero__selos span { color: #d4def0; }
@media (max-width: 760px) { .ji-hero__selos { justify-content: center; } }

/* Micro-confiança e eyebrow na página de produto */
.produto__eyebrow { text-transform: uppercase; letter-spacing: 1.4px; font-weight: 700; font-size: .9rem; margin: 0 0 8px; }
.produto__micro { margin-top: 16px; font-size: .9rem; color: #5b6470; border-top: 1px solid #e7ebf0; padding-top: 14px; }

/* Diferenciais técnicos + specs lado a lado */
.produto-dif { display: grid; grid-template-columns: 1.2fr .8fr; gap: 40px; align-items: start; }
.ji-checklist { list-style: none; padding: 0; margin: 0; }
.ji-checklist li { position: relative; padding: 10px 0 10px 32px; border-bottom: 1px solid #eef1f5; line-height: 1.5; }
.ji-checklist li i { position: absolute; left: 0; top: 12px; color: var(--ji-azul); }
.ji-checklist strong { color: var(--ji-navy); }
.ji-fabrica__stats--center { justify-content: center; margin-top: 28px; border-color: #e4e8f0; }
/* Versão sobre fundo CLARO (página de produto): números escuros, legíveis */
.ji-fabrica__stats--center strong { color: var(--ji-navy); }
.ji-fabrica__stats--center span { color: #5b6470; }
@media (max-width: 820px) { .produto-dif { grid-template-columns: 1fr; gap: 28px; } }

/* Foto da seção "fabricação" (substitui vídeo enquanto PENDENTE) */
.ji-fabrica__foto, .ji-sobre-foto { width: 100%; height: auto; border-radius: 14px; display: block; box-shadow: 0 12px 34px rgba(3,19,43,.14); }

/* ============================ BLOG ============================ */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.blog-card { background: #fff; border: 1px solid #e7ebf0; border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; transition: box-shadow .2s, transform .2s; }
.blog-card:hover { box-shadow: 0 14px 34px rgba(3,19,43,.12); transform: translateY(-3px); }
.blog-card__foto { display: block; aspect-ratio: 16/10; overflow: hidden; background: #f4f6f8; }
.blog-card__foto img { width: 100%; height: 100%; object-fit: cover; }
.blog-card__corpo { padding: 20px 22px 24px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.blog-card__data { font-size: .82rem; color: #8a93a0; text-transform: uppercase; letter-spacing: .6px; }
.blog-card__titulo { font-size: 1.2rem; line-height: 1.3; margin: 0; }
.blog-card__titulo a { color: var(--ji-navy); }
.blog-card__titulo a:hover { color: var(--ji-azul); }
.blog-card__resumo { color: #5b6470; font-size: .96rem; line-height: 1.55; margin: 0; flex: 1; }
.blog-card__link { color: var(--ji-azul); font-weight: 700; }
@media (max-width: 980px) { .blog-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px)  { .blog-grid { grid-template-columns: 1fr; } }

/* ===================== POST INDIVIDUAL ===================== */
.post__wrap { max-width: 820px; }
.post__head { margin-bottom: 22px; }
.post__data { font-size: .85rem; color: #8a93a0; text-transform: uppercase; letter-spacing: .6px; }
.post__titulo { font-size: clamp(1.8rem, 4vw, 2.6rem); line-height: 1.18; color: var(--ji-navy); margin: 8px 0 0; font-weight: 900; }
.post__capa { border-radius: 14px; overflow: hidden; margin: 0 0 28px; background: #f4f6f8; }
.post__capa img { width: 100%; height: auto; display: block; }
.post__tldr { background: #f1f6fc; border-left: 4px solid var(--ji-azul); border-radius: 8px; padding: 18px 22px; margin: 0 0 30px; }
.post__tldr strong { display: block; text-transform: uppercase; letter-spacing: 1px; font-size: .8rem; color: var(--ji-azul); margin-bottom: 6px; }
.post__tldr p { margin: 0; color: #2b3038; line-height: 1.6; }
.post__corpo h2 { font-size: 1.5rem; color: var(--ji-navy); margin: 34px 0 14px; font-weight: 800; }
.post__corpo p { line-height: 1.75; color: #333a44; margin: 0 0 16px; }
.post__corpo ul { line-height: 1.7; color: #333a44; margin: 0 0 18px; padding-left: 22px; }
.post__corpo li { margin-bottom: 8px; }
.post__corpo a { color: var(--ji-azul); font-weight: 600; text-decoration: underline; }
.post-tabela { width: 100%; border-collapse: collapse; margin: 6px 0 24px; font-size: .96rem; }
.post-tabela th, .post-tabela td { border: 1px solid #e1e6ec; padding: 10px 14px; text-align: left; vertical-align: top; }
.post-tabela thead th { background: var(--ji-navy); color: #fff; font-weight: 700; }
.post-tabela tbody tr:nth-child(even) { background: #f7f9fb; }
.post__faq { margin-top: 36px; }
.post__faq h2 { font-size: 1.5rem; color: var(--ji-navy); margin: 0 0 16px; }
.post__cta { margin-top: 38px; padding: 26px; background: #f4f6f8; border-radius: 14px; text-align: center; }
.post__cta p { font-size: 1.12rem; font-weight: 600; color: var(--ji-navy); margin: 0 0 16px; }
.post__cta-acoes { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   JUSTO INOX — passe de ARREDONDAMENTO (visual mais macio, menos quadrado)
   Carregado por último: vence os raios definidos antes.
   ============================================================ */

/* Botões em formato pílula (CTAs) */
.btn, .btn-ji, .btn-ji-outline, .btn-hero-ghost, .btn-grande, .btn-full,
.ji-header__cta, .produto__whats, .ji-vermais {
    border-radius: 50px !important;
}

/* Cards e blocos: cantos bem macios (20px) */
.ji-cat, .porque, .ji-feat, .ji-feat__info, .seg-card, .ji-historia__card,
.blog-card, .ji-review, .contato-card, .ji-confianca__item,
.orc2-card, .orc2-trust, .post__tldr, .post__cta, .ji-faq details,
.produto-dif__specs, .admin-x-none {
    border-radius: 20px !important;
}

/* Imagens e mídias: 18px */
.ji-feat__foto, .ji-feat__foto img, .prod-card, .prod-card__foto,
.blog-card__foto, .post__capa, .produto__principal, .produto__principal img,
.ji-fabrica__foto, .ji-sobre-foto, .ji-cat__ico, .porque__ico,
.seg-card__ico, .ji-historia__ico {
    border-radius: 18px !important;
    overflow: hidden;
}

/* Thumbs de produto: menores, ainda arredondadas */
.produto__thumb, .produto__thumb img, .galeria-thumb { border-radius: 12px !important; }

/* Ícones redondos (círculo perfeito) das seções */
.ji-cat__ico, .porque__ico, .seg-card__ico, .ji-passo__ico, .contato-card > .icon, .ji-historia__ico {
    border-radius: 50% !important;
}

/* Campos de formulário e busca: cantos macios */
.ji-busca, .ji-busca input,
.orc2-form input, .orc2-form select, .orc2-form textarea,
.ji-modal__box, .ji-modal__box input,
.produto__qtd input, #prod-qtd {
    border-radius: 14px !important;
}
.ji-busca { overflow: hidden; }

/* Tabelas de specs / post: borda externa arredondada */
.produto__specs, .post-tabela { border-radius: 16px; overflow: hidden; }

/* Selos do hero, chips e badges já são pílula — reforço de consistência */
.ji-hero__selos li, .produto__selos span, .prod-card__selos span,
.ji-feat__tag, .seg-selo, .ji-cookies, .whats-float {
    border-radius: 50px !important;
}
.ji-cookies { border-radius: 18px !important; }

/* Caixas de destaque (CTA final, faixas) um pouco mais suaves nas bordas */
.ji-cta-final, .secao--alt .ji-confianca { border-radius: 0; } /* faixas full-bleed seguem retas */

/* Vídeo VERTICAL da seção "Fábrica": respeita o formato retrato, centralizado,
   altura limitada (não fica gigante) e sem cortar (contain). */
.ji-fabrica__media { display: flex; justify-content: center; align-items: center; }
.ji-fabrica__video {
    width: auto !important;
    height: auto !important;
    max-height: 580px !important;
    max-width: 100% !important;
    object-fit: contain !important;
    margin: 0 auto;
    display: block;
    background: #0b0f14;
}
@media (max-width: 760px) { .ji-fabrica__video { max-height: 70vh !important; } }

/* ===== Clientes atendidos (carrossel infinito de logos, coloridas) ===== */
.ji-clientes { background: #fff; }
.ji-clientes__viewport {
    width: 100%; overflow: hidden; margin-top: 8px;
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
    mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.ji-clientes__track {
    display: flex; gap: 20px; width: max-content; align-items: center;
    animation: ji-scroll 42s linear infinite;
}
.ji-clientes__viewport:hover .ji-clientes__track { animation-play-state: paused; }
.ji-clientes__item {
    flex: 0 0 auto; width: 200px; min-height: 130px;
    display: flex; align-items: center; justify-content: center;
    padding: 12px 16px; background: #fff; border: 1px solid #eef1f5; border-radius: 18px;
}
.ji-clientes__item img {
    max-width: 100%; max-height: 100px; width: auto; height: auto; object-fit: contain;
}
@media (max-width: 600px) { .ji-clientes__item { width: 160px; min-height: 110px; padding: 10px 14px; } .ji-clientes__item img { max-height: 84px; } }

/* Segmentos: centralizar os cards (são 3 e não preenchem a linha de 4) */
.ji-segmentos { display: flex !important; flex-wrap: wrap; justify-content: center; gap: 22px; }
.ji-segmentos .seg-card { flex: 0 1 280px; max-width: 320px; }

/* ============================================================
   MOBILE — refino de centralização (página de produto e Sobre)
   ============================================================ */
@media (max-width: 820px) {
    /* Página de produto: tudo centralizado quando empilha */
    .produto__info { text-align: center; }
    .produto__eyebrow { text-align: center; }
    .produto__selos { justify-content: center; }
    .produto__desc { margin-left: auto; margin-right: auto; }
    .produto__micro { text-align: center; border-top: 0; }
    .produto__whats { display: inline-block; }
    .produto-dif__lista .ji-sec__head { text-align: center; }
    .produto__specs { margin-left: auto; margin-right: auto; }
    .ji-checklist { display: inline-block; text-align: left; }

    /* Sobre: bloco de história empilha e centraliza */
    .ji-historia__top { grid-template-columns: 1fr; gap: 28px; text-align: center; }
    .ji-historia__nums { max-width: 440px; margin: 0 auto; }
}
/* Sobre: cards de diferenciais (5 col) acompanham o mobile */
@media (max-width: 860px) { .ji-historia__cards { grid-template-columns: 1fr 1fr 1fr; } }
@media (max-width: 600px) { .ji-historia__cards { grid-template-columns: 1fr 1fr; } }
@media (max-width: 400px) { .ji-historia__cards { grid-template-columns: 1fr; } }
