/* ===========================================================================
   impeccable.css — refinamentos de design (mdist.pt)
   Direcao: industrial refinado + acabamento de e-commerce premium.
   Carregado DEPOIS de style.css -> faz override. Escopo .ck-* (ou seletores
   especificos) para nao quebrar o tema base. Fontes mantidas: DM Sans + Roboto.
   =========================================================================== */

:root {
    /* ---- Marca ---- */
    --ck-blue: #1e70b5;
    --ck-blue-600: color-mix(in oklch, var(--ck-blue), black 10%);
    --ck-blue-700: color-mix(in oklch, var(--ck-blue), black 24%);
    --ck-blue-800: color-mix(in oklch, var(--ck-blue), black 38%);
    --ck-blue-900: color-mix(in oklch, var(--ck-blue), black 54%);
    --ck-blue-050: color-mix(in oklch, var(--ck-blue), white 92%);
    --ck-blue-100: color-mix(in oklch, var(--ck-blue), white 84%);

    /* ---- Acento comercial (promo/preco) — usar com parcimonia (~10%) ---- */
    --ck-accent: oklch(0.72 0.16 58);
    --ck-accent-ink: oklch(0.45 0.14 52);

    /* ---- Neutros tingidos para o azul da marca ---- */
    --ck-ink:      oklch(0.24 0.02 250);   /* texto principal */
    --ck-ink-soft: oklch(0.47 0.02 250);   /* texto secundario */
    --ck-line:     oklch(0.90 0.008 250);  /* bordas */
    --ck-surface:  oklch(0.985 0.004 250); /* fundo suave */
    --ck-white:    oklch(0.995 0.002 250);

    /* ---- Espaco (escala 4pt) ---- */
    --ck-space-2: .5rem;  --ck-space-3: .75rem; --ck-space-4: 1rem;
    --ck-space-6: 1.5rem; --ck-space-8: 2rem;   --ck-space-12: 3rem;
    --ck-space-16: 4rem;  --ck-space-24: 6rem;

    /* ---- Raio + sombra ---- */
    --ck-radius: 14px;
    --ck-radius-sm: 10px;
    --ck-shadow:    0 1px 2px oklch(0.4 0.03 250 / .06), 0 8px 24px oklch(0.4 0.05 250 / .08);
    --ck-shadow-lg: 0 2px 6px oklch(0.4 0.03 250 / .08), 0 18px 40px oklch(0.4 0.06 250 / .12);

    --ck-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ===========================================================================
   Botoes
   =========================================================================== */
.ck-btn {
    display: inline-flex; align-items: center; gap: .5rem;
    font-family: "DM Sans", sans-serif; font-weight: 700; font-size: 1rem;
    line-height: 1; letter-spacing: .01em;
    padding: .95rem 1.5rem; border-radius: var(--ck-radius-sm);
    border: 1.5px solid transparent; cursor: pointer; text-decoration: none;
    transition: transform .25s var(--ck-ease), background-color .25s var(--ck-ease),
                color .25s var(--ck-ease), border-color .25s var(--ck-ease);
}
.ck-btn i { transition: transform .25s var(--ck-ease); }
.ck-btn:hover i { transform: translateX(3px); }
.ck-btn--primary { background: var(--ck-white); color: var(--ck-blue-800); }
.ck-btn--primary:hover { transform: translateY(-2px); color: var(--ck-blue-900); box-shadow: var(--ck-shadow); }
.ck-btn--ghost { background: transparent; color: var(--ck-white); border-color: color-mix(in oklch, white, transparent 58%); }
.ck-btn--ghost:hover { background: color-mix(in oklch, white, transparent 88%); }

/* ===========================================================================
   HERO — hero tipografico sobre painel azul de marca (substitui banners IG)
   =========================================================================== */
.ck-hero { margin-top: clamp(70px, 8vw, 92px); }
.ck-hero__swiper { overflow: hidden; }

.ck-hero__slide {
    position: relative; overflow: hidden; isolation: isolate;
    min-height: clamp(380px, 42vw, 520px);
    display: grid; grid-template-columns: 1.05fr .95fr; align-items: center;
    gap: clamp(1rem, 4vw, 3rem);
    padding: clamp(2rem, 5vw, 4.25rem) clamp(1.25rem, 6vw, 5rem);
    color: var(--ck-white);
    background-color: #16517f; /* fallback */
    background:
        radial-gradient(120% 150% at 88% 12%, var(--ck-blue-600), transparent 55%),
        linear-gradient(135deg, var(--ck-blue-800), var(--ck-blue-900));
}
/* losango subtil a ecoar o logotipo MDIST, atras da imagem */
.ck-hero__slide::after {
    content: ""; position: absolute; z-index: 0; right: 8%; top: 50%;
    width: min(34vw, 430px); aspect-ratio: 1;
    transform: translateY(-50%) rotate(45deg); border-radius: 32px;
    border: 1px solid color-mix(in oklch, white, transparent 82%);
    background: color-mix(in oklch, white, transparent 95%);
    pointer-events: none;
}
.ck-hero__content { position: relative; z-index: 2; max-width: 36rem; }
.ck-hero__media {
    position: relative; z-index: 1; align-self: stretch;
    display: flex; align-items: center; justify-content: center;
}
.ck-hero__media img {
    max-width: 100%; max-height: clamp(280px, 34vw, 470px);
    object-fit: contain; border-radius: 16px; position: relative; z-index: 1;
    filter: drop-shadow(0 30px 52px oklch(0.15 0.05 250 / .5));
    animation: ck-hero-float 6s ease-in-out infinite;
}
@keyframes ck-hero-float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-12px); }
}
/* glow de profundidade atras do produto */
.ck-hero__media::before {
    content: ""; position: absolute; z-index: 0; inset: 0; margin: auto;
    width: min(40vw, 460px); height: min(40vw, 460px); border-radius: 50%;
    background: radial-gradient(circle, color-mix(in oklch, var(--ck-blue-100), transparent 55%), transparent 62%);
    filter: blur(26px); opacity: .5; pointer-events: none;
}

/* faixa de confianca integrada no hero */
.ck-hero__trust {
    background: var(--ck-blue-900);
    border-top: 1px solid color-mix(in oklch, white, transparent 88%);
}
.ck-hero__trust-list {
    list-style: none; margin: 0; padding: .9rem 0;
    display: flex; flex-wrap: wrap; justify-content: space-between; gap: .75rem 2rem;
}
.ck-hero__trust-list li {
    display: inline-flex; align-items: center; gap: .6rem;
    color: color-mix(in oklch, white, transparent 12%);
    font-family: "DM Sans", sans-serif; font-weight: 600; font-size: .9rem;
}
.ck-hero__trust-list i { color: var(--ck-blue-100); font-size: .95rem; }
@media (prefers-reduced-motion: reduce) { .ck-hero__media img { animation: none; } }
@media (max-width: 767px) {
    .ck-hero__trust-list { justify-content: flex-start; gap: .55rem 1.5rem; }
    .ck-hero__trust-list li { font-size: .82rem; }
}
.ck-hero__eyebrow {
    display: inline-block; font-family: "DM Sans", sans-serif; font-weight: 700;
    font-size: .78rem; letter-spacing: .14em; text-transform: uppercase;
    color: color-mix(in oklch, white, transparent 22%);
    margin-bottom: .85rem;
}
.ck-hero__title {
    font-family: "DM Sans", sans-serif; font-weight: 700; color: var(--ck-white);
    font-size: clamp(2rem, 1.2rem + 3.4vw, 3.6rem); line-height: 1.04;
    letter-spacing: -.02em; margin: 0 0 1rem;
}
.ck-hero__subtitle {
    font-family: "Roboto", sans-serif; font-weight: 400;
    font-size: clamp(1rem, .95rem + .35vw, 1.2rem); line-height: 1.5;
    color: color-mix(in oklch, white, transparent 14%);
    max-width: 46ch; margin: 0 0 1.85rem;
}
.ck-hero__actions { display: flex; flex-wrap: wrap; gap: .75rem; }

.ck-hero__dots {
    position: absolute; left: 0; right: 0; bottom: 1.4rem;
    display: flex; justify-content: center; gap: .5rem; z-index: 5;
}
.ck-hero__dots .swiper-pagination-bullet {
    width: 8px; height: 8px; border-radius: 99px; margin: 0 !important;
    background: color-mix(in oklch, white, transparent 55%); opacity: 1;
    transition: width .3s var(--ck-ease), background-color .3s var(--ck-ease);
}
.ck-hero__dots .swiper-pagination-bullet-active { width: 28px; background: var(--ck-white); }

@media (max-width: 767px) {
    .ck-hero__slide {
        grid-template-columns: 1fr; min-height: auto;
        padding: 2.25rem 1.5rem 3rem; text-align: left;
    }
    .ck-hero__slide::after { display: none; }
    .ck-hero__media { margin-top: 1.5rem; }
    .ck-hero__media img { max-height: 240px; }
    .ck-hero__media::before { width: 60%; height: 60%; }
}

/* Banner SEM titulo = imagem completa (texto/MDIST embutido) — mostrar inteira, sem corte */
.ck-hero__slide--image { padding: 0; display: flex; align-items: center; justify-content: center; }
.ck-hero__slide--image::after { display: none; }
.ck-hero__image-link { display: flex; width: 100%; height: 100%; align-items: center; justify-content: center; }
.ck-hero__slide--image img { width: 100%; height: auto; max-height: clamp(380px, 42vw, 520px); object-fit: contain; }

/* ===========================================================================
   Cabecalhos de seccao (carrosseis) — mais contraste e hierarquia
   =========================================================================== */
.section-head.style-2 { align-items: flex-end; margin-bottom: 1.35rem; }
.section-head.style-2 .title {
    font-family: "DM Sans", sans-serif; font-weight: 700; color: var(--ck-ink);
    font-size: clamp(1.35rem, 1.08rem + .9vw, 1.9rem);
    letter-spacing: -.015em; line-height: 1.1;
}
.section-head.style-2 > a {
    font-weight: 600; white-space: nowrap; color: var(--ck-blue-700) !important;
}
.section-head.style-2 > a:hover { color: var(--ck-blue-900) !important; }

/* ===========================================================================
   Ritmo de seccoes (homepage) — alternar fundo para quebrar a monotonia
   =========================================================================== */
.ck-band--alt { background: var(--ck-surface); }
.ck-band--alt .content-inner-1 { background: transparent; }

/* ===========================================================================
   Setores — tiles a partir de dados (traduzem): foto + overlay + nome
   =========================================================================== */
.ck-section { padding-block: clamp(2.5rem, 5vw, 4.5rem); }
.ck-sectors .section-head.style-2 { margin-bottom: 1.5rem; }
.ck-sectors__grid {
    display: grid; gap: clamp(.75rem, 1.4vw, 1.25rem);
    grid-template-columns: repeat(3, 1fr);
}
.ck-sector-tile {
    position: relative; display: block; overflow: hidden; isolation: isolate;
    border-radius: var(--ck-radius); aspect-ratio: 16 / 10;
    background: var(--ck-blue-900); box-shadow: var(--ck-shadow);
    text-decoration: none;
}
.ck-sector-tile__media { position: absolute; inset: 0; z-index: 0; }
.ck-sector-tile__media img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .55s var(--ck-ease);
}
.ck-sector-tile:hover .ck-sector-tile__media img { transform: scale(1.06); }
.ck-sector-tile__overlay {
    position: absolute; inset: 0; z-index: 1;
    display: flex; align-items: flex-end; justify-content: space-between; gap: .5rem;
    padding: clamp(1rem, 2vw, 1.5rem);
    background: linear-gradient(to top,
        oklch(0.17 0.04 250 / .85) 0%, oklch(0.17 0.04 250 / .35) 42%, transparent 72%);
}
.ck-sector-tile__name {
    font-family: "DM Sans", sans-serif; font-weight: 700; color: #fff;
    font-size: clamp(1.05rem, .9rem + .55vw, 1.4rem); line-height: 1.1;
    letter-spacing: .01em; text-transform: uppercase;
}
.ck-sector-tile__arrow {
    color: #fff; font-size: 1.3rem; flex: none; margin-bottom: 2px;
    transform: translateX(-6px); opacity: 0;
    transition: transform .3s var(--ck-ease), opacity .3s var(--ck-ease);
}
.ck-sector-tile:hover .ck-sector-tile__arrow { transform: translateX(0); opacity: 1; }

@media (max-width: 991px) { .ck-sectors__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) {
    .ck-sectors__grid { grid-template-columns: 1fr; }
    .ck-sector-tile { aspect-ratio: 16 / 9; }
}

/* ===========================================================================
   Cartoes de produto (.shop-card) — moldura premium + hierarquia preco/titulo
   Aplica-se em todo o lado: home, categoria, pesquisa, populares, relacionados.
   =========================================================================== */
.shop-card {
    border: 1px solid var(--ck-line);
    border-radius: var(--ck-radius);
    background: var(--ck-white);
    transition: transform .3s var(--ck-ease), box-shadow .3s var(--ck-ease),
                border-color .3s var(--ck-ease);
}
.shop-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--ck-shadow-lg);
    border-color: color-mix(in oklch, var(--ck-blue), transparent 72%);
}
.shop-card .dz-media {
    background: var(--ck-surface);
    border-bottom: 1px solid var(--ck-line);
}
.shop-card .dz-content {
    background: transparent;
    padding: 14px 16px 16px;
}
.shop-card .dz-content .title {
    font-family: "DM Sans", sans-serif;
    font-size: 15px; line-height: 1.35; font-weight: 600 !important;
    letter-spacing: -.01em; color: var(--ck-ink); margin-bottom: 8px;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden; min-height: 2.7em;
}
.shop-card .price {
    color: var(--ck-blue-700);
    font-weight: 800 !important; letter-spacing: -.02em !important;
    font-size: 20px !important;
}
.shop-card .price sup { font-size: 10px; font-weight: 600; color: var(--ck-ink-soft); letter-spacing: 0; }
.shop-card .price del { color: var(--ck-ink-soft); font-weight: 400; }
.shop-card .price-small, .shop-card .price-small sup { color: var(--ck-ink-soft); }
.shop-card .attr-prod { color: var(--ck-ink-soft); }
.shop-card .attr-prod .fw-bold { color: var(--ck-ink); }

/* botao "adicionar ao carrinho" no card -> azul de marca, cantos suaves */
.shop-card .shop-meta .meta-icon {
    background-color: var(--ck-blue) !important;
    border-radius: var(--ck-radius-sm);
    width: 36px; min-width: 36px; height: 36px;
}
.shop-card .shop-meta > a:hover,
.shop-card .shop-meta .meta-icon:hover { background-color: var(--ck-blue-700) !important; }
.shop-card .product-tag .badge { border-radius: 999px; padding: .42em .72em; font-weight: 700; }

/* cards de IGUAL altura nos carrosseis (mesmo com info diferente: REF, 1 ou 2 linhas).
   O <a> que envolve o card nao estica por defeito -> forcar flex em toda a cadeia
   e empurrar o bloco de precos para o fundo para alinhar entre todos. */
.swiper-slide > a { display: flex; width: 100%; height: 100%; }
.swiper-slide .shop-card { display: flex; flex-direction: column; width: 100%; height: 100%; }
.swiper-slide .shop-card .dz-content { flex: 1 1 auto; display: flex; flex-direction: column; }
.swiper-slide .shop-card .dz-content > .d-flex { margin-top: auto; }

@media (max-width: 575px) {
    .shop-card .price { font-size: 16px !important; }
    .shop-card .dz-content .title { font-size: 14px; }
}

/* ===========================================================================
   Botoes — azul de marca consistente + cantos menos "datados" (tema usa 2px)
   =========================================================================== */
.btn-primary,
.btn-secondary,
.btn-dark,
.btn-outline-primary,
.btn-outline-secondary { border-radius: var(--ck-radius-sm); }

.btn-primary {
    background-color: var(--ck-blue); border-color: var(--ck-blue);
    --bs-btn-bg: var(--ck-blue); --bs-btn-border-color: var(--ck-blue);
    --bs-btn-hover-bg: var(--ck-blue-700); --bs-btn-hover-border-color: var(--ck-blue-700);
    --bs-btn-active-bg: var(--ck-blue-800); --bs-btn-active-border-color: var(--ck-blue-800);
}
.btn-primary:hover,
.btn-primary:focus-visible {
    background-color: var(--ck-blue-700); border-color: var(--ck-blue-700);
}

/* foco visivel acessivel (usa o azul de marca) */
a:focus-visible,
.btn:focus-visible {
    outline: 2px solid color-mix(in oklch, var(--ck-blue), transparent 25%);
    outline-offset: 2px;
}

/* ===========================================================================
   Pagina de produto — breadcrumb slim, galeria emoldurada, titulo H1, buy box
   =========================================================================== */
.ck-product-breadcrumb { padding: clamp(96px, 10vw, 116px) 0 .25rem; }
.ck-product-breadcrumb .breadcrumb { margin: 0; font-size: .875rem; }
.ck-product-breadcrumb .breadcrumb-item a { color: var(--ck-ink-soft); }
.ck-product-breadcrumb .breadcrumb-item a:hover { color: var(--ck-blue-700); }
.ck-product-breadcrumb .breadcrumb-item.active { color: var(--ck-ink); font-weight: 600; }

/* titulo do produto agora e H1 (era H4) */
.ck-product-title {
    font-family: "DM Sans", sans-serif; font-weight: 700;
    font-size: clamp(1.5rem, 1.2rem + 1.1vw, 2.05rem); line-height: 1.15;
    letter-spacing: -.02em; color: var(--ck-ink); margin-bottom: .5rem;
}

/* galeria: imagem cheia, sem moldura/borda visivel (so cantos arredondados) */
.dz-product-detail .product-gallery-swiper2 .dz-media {
    background: var(--ck-white);
    border: none;
    border-radius: var(--ck-radius);
    overflow: hidden;
    padding: 0;
}
.dz-product-detail .product-gallery-swiper2 .dz-media img {
    object-fit: contain !important;
    width: 100% !important;
    height: auto !important;
    max-height: 560px;
    display: block;
}
.dz-product-detail .product-gallery-swiper .swiper-slide img {
    border: 1px solid var(--ck-line); border-radius: var(--ck-radius-sm);
}

/* linha quantidade + adicionar ao carrinho — espacamento consistente, botao preenche e centra */
.ck-buy-row { gap: 1rem; margin-top: 1.5rem; }
.ck-buy-row .product-num { margin: 0 !important; }
.ck-buy-btn {
    flex: 1 1 auto;
    display: inline-flex; align-items: center; justify-content: center;
    padding-top: .95rem; padding-bottom: .95rem;
}

/* ===========================================================================
   Homepage — seccoes extra para dar ritmo/vida (USP, CTA, marcas, blog)
   =========================================================================== */
/* USP / barra de confianca (sob o hero) */
.ck-usp { padding: 1.5rem 0; border-bottom: 1px solid var(--ck-line); }
.ck-usp__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.ck-usp__item { display: flex; align-items: center; gap: .75rem; justify-content: center; }
.ck-usp__icon {
    flex: none; width: 42px; height: 42px; border-radius: 11px;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--ck-blue-050); color: var(--ck-blue-700); font-size: 1.05rem;
}
.ck-usp__label {
    font-family: "DM Sans", sans-serif; font-weight: 600; color: var(--ck-ink);
    font-size: .92rem; line-height: 1.25;
}
@media (max-width: 991px) { .ck-usp__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .ck-usp__grid { grid-template-columns: 1fr; } .ck-usp__item { justify-content: flex-start; } }

/* Banda CTA a cor (meio da pagina) */
.ck-cta { padding: clamp(2rem, 4vw, 3.5rem) 0; }
.ck-cta__inner {
    position: relative; overflow: hidden; isolation: isolate;
    display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap;
    background-color: #16517f;
    background: radial-gradient(120% 160% at 90% 10%, var(--ck-blue-600), transparent 55%),
        linear-gradient(135deg, var(--ck-blue-800), var(--ck-blue-900));
    border-radius: var(--ck-radius); color: var(--ck-white);
    padding: clamp(1.75rem, 4vw, 3rem) clamp(1.5rem, 4vw, 3.25rem);
}
/* losangos decorativos (ecoam o hero) para dar vida */
.ck-cta__inner::after {
    content: ""; position: absolute; z-index: 0; right: -50px; top: 50%;
    width: 300px; height: 300px; transform: translateY(-50%) rotate(45deg); border-radius: 34px;
    border: 1px solid color-mix(in oklch, white, transparent 80%);
    background: color-mix(in oklch, white, transparent 94%); pointer-events: none;
}
.ck-cta__inner::before {
    content: ""; position: absolute; z-index: 0; right: 175px; bottom: -70px;
    width: 150px; height: 150px; transform: rotate(45deg); border-radius: 22px;
    border: 1px solid color-mix(in oklch, white, transparent 82%); pointer-events: none;
}
.ck-cta__text, .ck-cta__inner > a { position: relative; z-index: 1; }
.ck-cta__eyebrow {
    display: inline-flex; align-items: center; gap: .5rem;
    font-family: "DM Sans", sans-serif; font-weight: 700; font-size: .76rem; letter-spacing: .12em;
    text-transform: uppercase; color: color-mix(in oklch, white, transparent 16%); margin-bottom: .7rem;
}
.ck-cta__title {
    font-family: "DM Sans", sans-serif; font-weight: 700; color: #fff;
    font-size: clamp(1.4rem, 1.1rem + 1.2vw, 2rem); line-height: 1.15;
    letter-spacing: -.02em; margin: 0 0 .4rem;
}
.ck-cta__subtitle { color: color-mix(in oklch, white, transparent 16%); margin: 0; max-width: 52ch; }
.ck-cta__btn { box-shadow: 0 10px 30px oklch(0.2 0.05 250 / .35); }

/* Faixa de marcas — marquee (scroll infinito), 2 linhas em direcoes opostas */
.ck-brands__rows { display: flex; flex-direction: column; gap: 0; }
.ck-brands__marquee {
    overflow: hidden; position: relative; padding: 13px 0;
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
    mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.ck-brands__track {
    display: flex; gap: clamp(.6rem, 1vw, 1rem); width: max-content;
    animation: ck-marquee 55s linear infinite;
}
.ck-brands__track--reverse { animation-direction: reverse; }
.ck-brands__marquee:hover .ck-brands__track { animation-play-state: paused; }
@keyframes ck-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.ck-brand-logo {
    flex: none; width: clamp(150px, 16vw, 190px); aspect-ratio: 5 / 3;
    display: flex; align-items: center; justify-content: center;
    padding: .75rem 1rem; border: 1px solid var(--ck-line); border-radius: var(--ck-radius);
    background: var(--ck-white);
    transition: border-color .25s var(--ck-ease), box-shadow .25s var(--ck-ease), transform .25s var(--ck-ease);
}
.ck-brand-logo img {
    max-width: 100%; max-height: 90px; object-fit: contain;
    filter: grayscale(1); opacity: .72;
    transition: filter .25s var(--ck-ease), opacity .25s var(--ck-ease);
}
.ck-brand-logo:hover {
    border-color: color-mix(in oklch, var(--ck-blue), transparent 65%);
    box-shadow: var(--ck-shadow); transform: translateY(-2px);
}
.ck-brand-logo:hover img { filter: grayscale(0); opacity: 1; }

@media (prefers-reduced-motion: reduce) { .ck-brands__track { animation: none; } }

/* Teaser do blog */
.ck-blog__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.5rem); }
.ck-blog-card {
    display: flex; flex-direction: column; overflow: hidden; text-decoration: none;
    background: var(--ck-surface); border: 1px solid var(--ck-line); border-radius: var(--ck-radius);
    box-shadow: var(--ck-shadow);
    transition: transform .3s var(--ck-ease), box-shadow .3s var(--ck-ease), border-color .3s var(--ck-ease);
}
.ck-blog-card:hover { transform: translateY(-4px); box-shadow: var(--ck-shadow-lg); border-color: transparent; }
.ck-blog-card__media { aspect-ratio: 16 / 10; overflow: hidden; background: var(--ck-surface); }
.ck-blog-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ck-ease); }
.ck-blog-card:hover .ck-blog-card__media img { transform: scale(1.05); }
.ck-blog-card__body { padding: 1.1rem 1.25rem 1.35rem; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.ck-blog-card__title {
    font-family: "DM Sans", sans-serif; font-weight: 700; color: var(--ck-ink);
    font-size: 1.05rem; line-height: 1.3; margin: 0;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.ck-blog-card__excerpt {
    color: var(--ck-ink-soft); font-size: .88rem; line-height: 1.5; margin: 0;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.ck-blog-card__more {
    margin-top: auto; color: var(--ck-blue-700); font-weight: 600; font-size: .88rem;
    display: inline-flex; align-items: center; gap: .35rem;
}
@media (max-width: 767px) { .ck-blog__grid { grid-template-columns: 1fr; } }

/* Botao solido (CTA em fundos claros) */
.ck-btn--solid { background: var(--ck-blue); color: #fff; }
.ck-btn--solid:hover { background: var(--ck-blue-700); color: #fff; transform: translateY(-2px); box-shadow: var(--ck-shadow); }

/* ===========================================================================
   Seccao de contacto (fecho da homepage) — clara, com imagem (contrasta o hero)
   =========================================================================== */
.ck-contact__inner {
    display: grid; grid-template-columns: 1fr 1fr; align-items: stretch;
    gap: clamp(1.5rem, 4vw, 3.5rem);
    background: var(--ck-surface); border: 1px solid var(--ck-line);
    border-radius: var(--ck-radius); overflow: hidden;
}
.ck-contact__media { position: relative; min-height: 320px; }
.ck-contact__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ck-contact__body { align-self: center; padding: clamp(1.75rem, 4vw, 3rem) clamp(1.5rem, 4vw, 3rem) clamp(1.75rem, 4vw, 3rem) 0; }
.ck-contact__eyebrow {
    display: inline-block; font-family: "DM Sans", sans-serif; font-weight: 700;
    font-size: .76rem; letter-spacing: .12em; text-transform: uppercase;
    color: var(--ck-blue-700); margin-bottom: .7rem;
}
.ck-contact__title {
    font-family: "DM Sans", sans-serif; font-weight: 700; color: var(--ck-ink);
    font-size: clamp(1.5rem, 1.2rem + 1.1vw, 2.1rem); line-height: 1.15; letter-spacing: -.02em; margin: 0 0 .6rem;
}
.ck-contact__text { color: var(--ck-ink-soft); font-size: 1rem; line-height: 1.6; max-width: 46ch; margin: 0 0 1.25rem; }
.ck-contact__info { list-style: none; padding: 0; margin: 0 0 1.5rem; display: grid; gap: .6rem; }
.ck-contact__info li { display: flex; align-items: center; gap: .7rem; color: var(--ck-ink); font-weight: 600; }
.ck-contact__info i { color: var(--ck-blue-700); width: 18px; text-align: center; }
.ck-contact__info a { color: var(--ck-ink); text-decoration: none; }
.ck-contact__info a:hover { color: var(--ck-blue-700); }
@media (max-width: 767px) {
    .ck-contact__inner { grid-template-columns: 1fr; }
    .ck-contact__media { min-height: 200px; }
    .ck-contact__body { padding: clamp(1.5rem, 5vw, 2rem); }
}

/* preco em destaque na buy box */
.dz-product-detail .price-num {
    font-size: clamp(1.6rem, 1.3rem + 1vw, 2rem); font-weight: 800;
    color: var(--ck-blue-700) !important; letter-spacing: -.02em;
}
.dz-product-detail .price-num del { color: var(--ck-ink-soft); font-weight: 400; }

/* faixa de confianca (dentro da buy box) — icones azuis, sem caixas aninhadas */
.ck-trust {
    display: grid; gap: 1rem;
    margin-top: 1.5rem; padding-top: 1.5rem;
    border-top: 1px solid var(--ck-line);
}
.ck-trust__item { display: flex; align-items: center; gap: .9rem; }
.ck-trust__icon {
    flex: none; width: 44px; height: 44px; border-radius: 12px;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--ck-blue-050); color: var(--ck-blue-700); font-size: 1.05rem;
}
.ck-trust__title {
    display: block; font-family: "DM Sans", sans-serif; font-weight: 700;
    color: var(--ck-ink); font-size: .94rem; line-height: 1.2;
}
.ck-trust__text { display: block; color: var(--ck-ink-soft); font-size: .82rem; line-height: 1.4; }

.ck-share { display: flex; align-items: center; gap: .55rem; margin-top: 1.5rem; }
.ck-share__label { font-weight: 600; color: var(--ck-ink); margin-right: .3rem; }
.ck-share a {
    width: 36px; height: 36px; border-radius: 9px;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--ck-surface); border: 1px solid var(--ck-line); color: var(--ck-ink-soft);
    transition: transform .2s var(--ck-ease), background-color .2s var(--ck-ease),
                color .2s var(--ck-ease), border-color .2s var(--ck-ease);
}
.ck-share a:hover {
    background: var(--ck-blue); border-color: var(--ck-blue); color: #fff; transform: translateY(-2px);
}

/* ===========================================================================
   Pagina institucional "Sobre Nos" (/sobre-nos, /en/about-us)
   Editorial B2B, industrial refinado, COMPACTO e coerente.
   Conteudo (texto/imagens/links) editavel no BO; o design vive aqui (.ck-about).
   =========================================================================== */
.ck-about { color: var(--ck-ink); font-family: "Roboto", sans-serif; }
.ck-about .ck-wrap { width: 100%; max-width: 1320px; margin-inline: auto; padding-inline: clamp(1rem, 4vw, 2rem); }
.ck-about .ck-hl-blue { color: var(--ck-blue-700); font-weight: 600; }
.ck-about .ck-seclink { color: var(--ck-blue-700); font-weight: 700; text-decoration: none; }
.ck-about .ck-seclink:hover { text-decoration: underline; }
.ck-about__eyebrow { display: inline-block; font-family: "DM Sans", sans-serif; font-weight: 700; font-size: .74rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ck-blue-700); margin: 0 0 .7rem; }
.ck-about__h { font-family: "DM Sans", sans-serif; font-weight: 700; color: var(--ck-ink); letter-spacing: -.02em; line-height: 1.12; margin: 0; }

/* Cabecalho em faixa (igual a produtos/setores/blog) */
.ck-about__head { padding-top: clamp(96px, 11vw, 118px); }

/* Intro 2-col (titulo + texto) */
.ck-about__intro { padding-block: clamp(2rem, 4vw, 3.25rem); }
.ck-about__intro-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1.5rem, 4vw, 3.5rem); align-items: stretch; }
.ck-about__intro .ck-about__lead { margin-top: 1.1rem; }
.ck-about__subh { font-family: "DM Sans", sans-serif; font-weight: 700; color: var(--ck-ink); font-size: clamp(1.12rem, 1rem + .55vw, 1.35rem); line-height: 1.25; margin: 1.5rem 0 .7rem; }
.ck-about__intro-media { border-radius: var(--ck-radius); overflow: hidden; box-shadow: var(--ck-shadow); min-height: 260px; }
.ck-about__intro-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ck-about__title { font-family: "DM Sans", sans-serif; font-weight: 800; font-size: clamp(1.45rem, 1.05rem + 1.5vw, 2.05rem); line-height: 1.15; letter-spacing: -.02em; max-width: 22ch; }
.ck-about__lead { color: var(--ck-ink-soft); font-size: 1.04rem; line-height: 1.65; }
.ck-about__lead p { margin: 0 0 .9rem; }
.ck-about__lead p:last-child { margin-bottom: 0; }
.ck-about__lead p:first-child { font-size: clamp(1.08rem, 1rem + .5vw, 1.25rem); color: var(--ck-ink); line-height: 1.55; }
.ck-about__cta { display: flex; flex-wrap: wrap; gap: .7rem; }
.ck-about__btn { display: inline-flex; align-items: center; gap: .5rem; text-decoration: none; font-family: "DM Sans", sans-serif; font-weight: 600; font-size: .95rem; padding: .8rem 1.5rem; border-radius: 10px; transition: transform .2s var(--ck-ease), background-color .2s var(--ck-ease), box-shadow .2s var(--ck-ease), color .2s var(--ck-ease), border-color .2s var(--ck-ease); }
.ck-about__btn--primary { background: var(--ck-blue); color: #fff; }
.ck-about__btn--primary:hover { background: var(--ck-blue-700); color: #fff; transform: translateY(-2px); box-shadow: var(--ck-shadow); }
.ck-about__btn--ghost { background: transparent; color: var(--ck-ink); border: 1px solid var(--ck-line); }
.ck-about__btn--ghost:hover { border-color: var(--ck-blue); color: var(--ck-blue-700); transform: translateY(-2px); }

/* Faixa de numeros (placeholders editaveis no BO) */
.ck-about__stats { background: var(--ck-white); border-bottom: 1px solid var(--ck-line); }
.ck-about__stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--ck-line); }
.ck-about__stat { background: var(--ck-white); padding: clamp(1.25rem, 2.5vw, 1.9rem) 1rem; text-align: center; }
.ck-about__stat-n { font-family: "DM Sans", sans-serif; font-weight: 800; color: var(--ck-blue-700); font-size: clamp(1.7rem, 1.2rem + 1.6vw, 2.6rem); line-height: 1; letter-spacing: -.02em; }
.ck-about__stat-l { display: block; margin-top: .5rem; color: var(--ck-ink-soft); font-size: .84rem; line-height: 1.3; }

/* Seccoes (compactas) */
.ck-about__section { padding-block: clamp(2.25rem, 4vw, 3.5rem); }
.ck-about__section--alt { background: var(--ck-surface); }
.ck-about__section-head { max-width: 56ch; margin-bottom: clamp(1.25rem, 2.5vw, 1.75rem); }
.ck-about__section-head .ck-about__h { font-size: clamp(1.45rem, 1.1rem + 1.4vw, 2rem); }
.ck-about__prose { color: var(--ck-ink-soft); font-size: 1.04rem; line-height: 1.65; max-width: 66ch; }
.ck-about__prose p { margin: 0 0 .9rem; }
.ck-about__prose p:last-child { margin-bottom: 0; }
/* Quem somos + Onde atuamos lado a lado (uma so seccao) */
.ck-about__cols { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1.75rem, 5vw, 4rem); align-items: start; }
.ck-about__cols .ck-about__eyebrow { margin-bottom: .6rem; }
.ck-about__cols .ck-about__h { font-size: clamp(1.3rem, 1.05rem + 1vw, 1.75rem); margin-bottom: .9rem; }
.ck-about__cols .ck-about__prose { max-width: none; }
@media (max-width: 767px) { .ck-about__cols { grid-template-columns: 1fr; gap: 2rem; } }

/* Missao / Visao / Valores — uma so faixa coerente */
.ck-about__mvv { display: grid; gap: clamp(1.75rem, 3.5vw, 2.75rem); }
.ck-about__mv { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 3rem); }
.ck-about__mv-item .ck-about__eyebrow { margin-bottom: .5rem; }
.ck-about__mv-item .ck-about__h { font-size: clamp(1.2rem, 1.05rem + .8vw, 1.55rem); margin-bottom: .55rem; }
.ck-about__mv-item p { color: var(--ck-ink-soft); font-size: 1rem; line-height: 1.6; max-width: 48ch; margin: 0; }
/* Valores — lista numerada airy (sem caixas) — distinta dos setores */
.ck-about__vals { margin-top: clamp(2rem, 4vw, 3rem); }
.ck-about__vals .ck-about__eyebrow { display: block; margin-bottom: 1.1rem; }
.ck-about__values { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.1rem, 2.5vw, 1.75rem) clamp(1.5rem, 3vw, 2.5rem); }
.ck-about__value { display: flex; align-items: baseline; gap: .7rem; padding-top: .9rem; border-top: 1px solid var(--ck-line); }
.ck-about__value-n { font-family: "DM Sans", sans-serif; font-weight: 800; font-size: 1.05rem; color: var(--ck-blue-700); flex: none; }
.ck-about__value-t { font-family: "DM Sans", sans-serif; font-weight: 600; color: var(--ck-ink); font-size: 1.02rem; line-height: 1.25; }

/* Onde atuamos — pills (distinto dos valores) + link */
.ck-about__sectors { display: flex; flex-wrap: wrap; gap: .6rem; }
.ck-about__sector { display: inline-flex; align-items: center; padding: .6rem 1.15rem; border-radius: 999px; background: var(--ck-surface); border: 1px solid var(--ck-line); color: var(--ck-ink); text-decoration: none; font-family: "DM Sans", sans-serif; font-weight: 600; font-size: .95rem; transition: background-color .2s var(--ck-ease), border-color .2s var(--ck-ease), color .2s var(--ck-ease); }
.ck-about__sector:hover { background: var(--ck-blue-050); border-color: var(--ck-blue); color: var(--ck-blue-700); }
.ck-about__sectors-link { margin-top: clamp(1.25rem, 2.5vw, 1.75rem); display: inline-flex; align-items: center; gap: .45rem; color: var(--ck-blue-700); font-family: "DM Sans", sans-serif; font-weight: 600; font-size: .95rem; text-decoration: none; }
.ck-about__sectors-link i { transition: transform .25s var(--ck-ease); }
.ck-about__sectors-link:hover i { transform: translateX(4px); }

/* CTA final — escuro limpo, com brilho azul (sem imagem) */
.ck-about__final { border-radius: var(--ck-radius); padding: clamp(2.25rem, 5vw, 3.5rem); text-align: center; color: #fff; background: radial-gradient(120% 150% at 50% -30%, var(--ck-blue-700), transparent 55%), var(--ck-ink); }
.ck-about__final .ck-about__h { color: #fff; font-size: clamp(1.5rem, 1.15rem + 1.4vw, 2.1rem); max-width: 22ch; margin-inline: auto; }
.ck-about__final p { color: rgba(255, 255, 255, .85); margin: .8rem auto 1.6rem; max-width: 52ch; line-height: 1.6; }
.ck-about__final .ck-about__cta { justify-content: center; }
.ck-about__final .ck-about__btn--ghost { color: #fff; border-color: rgba(255, 255, 255, .35); }
.ck-about__final .ck-about__btn--ghost:hover { border-color: #fff; color: #fff; background: rgba(255, 255, 255, .1); }

/* Responsive */
@media (max-width: 991px) {
    .ck-about__intro-grid { grid-template-columns: 1fr; gap: 1.5rem; }
    .ck-about__intro-media { min-height: 0; aspect-ratio: 16 / 10; }
    .ck-about__values { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575px) {
    .ck-about__stats-grid { grid-template-columns: repeat(2, 1fr); }
    .ck-about__mv { grid-template-columns: 1fr; gap: 1.5rem; }
    .ck-about__values { grid-template-columns: 1fr; }
}

/* ===========================================================================
   Cart drawer (modal, tema shop-4): iguala o cart ao da lojasmarias (shop-1) —
   classes em falta (fs-7/8, old-price), padding do conteudo, stepper de
   quantidade -[n]+ (injetado por polish.js) e botao azul MDIST arredondado.
   =========================================================================== */
/* drawer + backdrop acima do header (.site-header tem z-index:9999) — senao os
   icones do header (pesquisa/carrinho/conta/idioma) sobrepoem o topo do cart */
.drawer { z-index: 100000 !important; }
.drawer-cover, .cart-loader-cover { z-index: 99999 !important; }
.drawer .cart .fs-7 { font-size: 0.85em !important; }
.drawer .cart .fs-8 { font-size: 0.75em !important; }
.drawer .cart .old-price { color: #b0b0b0; text-decoration: line-through; font-style: normal; }

/* padding a toda a volta do conteudo (imagem/texto deixam de encostar as bordas) */
.drawer .cart .cart-content { padding: 6px 16px 0; }
.drawer .cart .cart-content .col-9 { padding-left: 12px; }

/* stepper de quantidade -[n]+ (polish.js embrulha o input em .ck-qty) */
.drawer .cart .ck-qty {
    display: inline-flex; align-items: center;
    border: 1px solid #dcdcdc; border-radius: 8px; overflow: hidden; background: #fff;
}
.drawer .cart .ck-qty__btn {
    width: 34px; height: 34px; border: 0; background: #fff; color: #222;
    font-size: 1.1rem; line-height: 1; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background-color .2s var(--ck-ease);
}
.drawer .cart .ck-qty__btn:hover { background: #f3f3f3; }
.drawer .cart .ck-qty__btn:disabled { opacity: .3; cursor: not-allowed; }
.drawer .cart .ck-qty .custom-input-quantity {
    width: 38px !important; height: 34px; margin: 0 !important; padding: 0 !important;
    border: 0 !important; border-left: 1px solid #eee !important; border-right: 1px solid #eee !important;
    border-radius: 0 !important; background: #fff !important; color: #222 !important;
    text-align: center; font-weight: 600; -moz-appearance: textfield; appearance: textfield;
}
.drawer .cart .ck-qty .custom-input-quantity::-webkit-outer-spin-button,
.drawer .cart .ck-qty .custom-input-quantity::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
/* fallback: input ainda nao embrulhado pelo stepper */
.drawer .cart .custom-input-quantity {
    width: 52px; height: 34px; text-align: center; font-weight: 600; font-size: .9rem;
    border: 1px solid #dcdcdc; border-radius: 6px; background: #fff; color: #222; margin: 0; padding: 0 0 0 6px;
}

/* botao finalizar: azul MDIST + cantos arredondados */
.drawer .cart .cart-footer .btn-success {
    --bs-btn-bg: var(--main-color, #1e70b5); --bs-btn-border-color: var(--main-color, #1e70b5);
    --bs-btn-hover-bg: #185c95; --bs-btn-hover-border-color: #185c95;
    background-color: var(--main-color, #1e70b5); border-color: var(--main-color, #1e70b5); color: #fff;
    border-radius: var(--ck-radius-sm, 10px); font-weight: 600; padding-top: 13px; padding-bottom: 13px;
}
.drawer .cart .cart-footer .btn-success:hover { background-color: #185c95; border-color: #185c95; color: #fff; }

/* ===========================================================================
   Hero "MDIST Direct" (bloco de editor id 2 da home) — compacto, 3 colunas:
   texto | imagem | bloco Mistolin (a direita, com botao). Conteudo editavel no BO.
   =========================================================================== */
.ck-mhero { padding: clamp(1.75rem, 3.5vw, 3.25rem) 0; font-family: "Roboto", sans-serif; }
.ck-mhero__wrap { width: 100%; max-width: 1320px; margin-inline: auto; padding-inline: clamp(1rem, 4vw, 2rem); display: grid; grid-template-columns: 1.15fr 0.95fr 1fr; gap: clamp(1.5rem, 3vw, 2.75rem); align-items: stretch; }
.ck-mhero__eyebrow { display: inline-block; font-family: "DM Sans", sans-serif; font-weight: 700; font-size: .76rem; letter-spacing: .16em; text-transform: uppercase; color: var(--ck-ink-soft); margin-bottom: .85rem; }
.ck-mhero__title { font-family: "DM Sans", sans-serif; font-weight: 800; color: var(--ck-ink); font-size: clamp(1.7rem, 1.1rem + 1.9vw, 2.6rem); line-height: 1.12; letter-spacing: -.02em; margin: 0; }
.ck-mhero__title span { color: var(--ck-blue); }
.ck-mhero__lead { color: var(--ck-ink-soft); font-size: clamp(.98rem, .94rem + .25vw, 1.1rem); line-height: 1.6; max-width: 42ch; margin: 1rem 0 0; }
.ck-mhero__cta { display: flex; flex-wrap: wrap; gap: .7rem; margin-top: 1.5rem; }
.ck-mhero__btn { display: inline-flex; align-items: center; gap: .5rem; text-decoration: none; font-family: "DM Sans", sans-serif; font-weight: 600; font-size: .94rem; padding: .78rem 1.5rem; border-radius: 10px; transition: transform .2s var(--ck-ease), background-color .2s var(--ck-ease), color .2s var(--ck-ease), border-color .2s var(--ck-ease); }
.ck-mhero__btn--primary { background: var(--ck-blue); color: #fff; }
.ck-mhero__btn--primary:hover { background: var(--ck-blue-700); color: #fff; transform: translateY(-2px); }
.ck-mhero__btn--ghost { background: transparent; color: var(--ck-ink); border: 1px solid var(--ck-line); }
.ck-mhero__btn--ghost:hover { border-color: var(--ck-blue); color: var(--ck-blue-700); transform: translateY(-2px); }
.ck-mhero__btn--dark { background: var(--ck-ink); color: #fff; }
.ck-mhero__btn--dark:hover { background: #000; color: #fff; transform: translateY(-2px); }
.ck-mhero__media { display: flex; justify-content: center; align-items: center; }
.ck-mhero__text { align-self: start; }
.ck-mhero__media img { width: auto; max-width: 100%; max-height: clamp(205px, 25vw, 280px); object-fit: contain; }
.ck-mhero__aside { display: flex; flex-direction: column; }
.ck-mhero__aside-title { font-family: "DM Sans", sans-serif; font-weight: 700; color: var(--ck-ink); font-size: clamp(1.1rem, 1rem + .5vw, 1.4rem); line-height: 1.22; margin: 0 0 .7rem; }
.ck-mhero__aside-text { color: var(--ck-ink-soft); font-size: .95rem; line-height: 1.55; margin: 0 0 1.15rem; max-width: 38ch; }
.ck-mhero__aside-cta { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: auto; }
@media (max-width: 992px) { .ck-mhero__aside-cta { margin-top: 1rem; } }
@media (max-width: 992px) {
    .ck-mhero__wrap { grid-template-columns: 1fr; gap: 1.5rem; }
    .ck-mhero__media { order: -1; }
    .ck-mhero__media img { max-height: 220px; }
}

/* ===========================================================================
   Pagina dos Setores (/setores) — cabecalho editorial (sem banner gigante) +
   cards de conteudo (foto, titulo, descricao, link "Ver setor"), altura igual,
   hover premium. Pagina coded; conteudo dinamico da BD.
   =========================================================================== */
.ck-sectors { font-family: "Roboto", sans-serif; color: var(--ck-ink); }
.ck-sectors__wrap { width: 100%; max-width: 1320px; margin-inline: auto; padding-inline: clamp(1rem, 4vw, 2rem); }
.ck-sectors__head { padding-top: clamp(96px, 11vw, 118px); padding-bottom: clamp(1.25rem, 3vw, 2.25rem); }
.ck-sectors__topbar { display: flex; align-items: center; gap: 16px; padding: 22px 0 6px; }
.ck-sectors__bc { flex: 1 1 0; min-width: 0; display: flex; align-items: center; gap: .4rem; font-size: 13px; color: #888; }
.ck-sectors__bc a { color: #888; text-decoration: none; }
.ck-sectors__bc a:hover { color: var(--ck-blue-700); }
.ck-sectors__bc b { color: #1a1a1a; font-weight: 500; }
.ck-sectors__bc:last-child { justify-content: flex-end; }
.ck-sectors__pagetitle { flex: 0 0 auto; text-align: center; font-family: "DM Sans", sans-serif; font-size: clamp(22px, 2.4vw, 30px); font-weight: 600; letter-spacing: -.5px; margin: 0; color: var(--ck-ink); }
.ck-sectors__sep { margin: 6px 0 clamp(1.5rem, 3vw, 2.5rem); border: 0; border-top: 1px solid #ededed; }
.ck-sectors__intro { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(1.5rem, 4vw, 3.5rem); align-items: start; }
.ck-sectors__intro-title { font-family: "DM Sans", sans-serif; font-weight: 800; color: var(--ck-ink); font-size: clamp(1.55rem, 1.1rem + 1.6vw, 2.2rem); line-height: 1.12; letter-spacing: -.02em; margin: 0; max-width: 18ch; }
.ck-sectors__lead { color: var(--ck-ink-soft); font-size: .98rem; line-height: 1.6; max-width: 60ch; }
.ck-sectors__lead p { margin: 0 0 .9rem; }
.ck-sectors__lead p:last-child { margin-bottom: 0; }
.ck-sectors__lead p:first-child { font-size: clamp(1.08rem, 1rem + .5vw, 1.28rem); color: var(--ck-ink); line-height: 1.5; }
.ck-hl-blue { color: var(--ck-blue-700); font-weight: 600; }

.ck-sectors__grid-sec { padding-block: clamp(2.5rem, 5vw, 4rem); }
.ck-sectors__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.25rem, 2.5vw, 1.75rem); }

.ck-sector-card { display: flex; flex-direction: column; height: 100%; background: var(--ck-white); border: 1px solid var(--ck-line); border-radius: var(--ck-radius); overflow: hidden; text-decoration: none; transition: transform .3s var(--ck-ease), box-shadow .3s var(--ck-ease), border-color .3s var(--ck-ease); }
.ck-sector-card:hover { transform: translateY(-4px); box-shadow: var(--ck-shadow-lg); border-color: transparent; }
.ck-sector-card__media { aspect-ratio: 16 / 10; overflow: hidden; background: var(--ck-surface); }
.ck-sector-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s var(--ck-ease); }
.ck-sector-card:hover .ck-sector-card__media img { transform: scale(1.06); }
.ck-sector-card__body { display: flex; flex-direction: column; flex: 1; padding: 1.3rem 1.4rem 1.4rem; }
.ck-sector-card__num { color: var(--ck-blue-700); font-weight: 700; font-size: .82em; letter-spacing: .04em; margin-right: .5rem; }
.ck-sector-card__title { font-family: "DM Sans", sans-serif; font-weight: 700; color: var(--ck-ink); font-size: 1.12rem; line-height: 1.3; text-transform: uppercase; letter-spacing: .02em; margin: 0 0 .55rem; }
.ck-sector-card__text { color: var(--ck-ink-soft); font-size: .93rem; line-height: 1.55; margin: 0; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.ck-sector-card__link { margin-top: auto; padding-top: 1.1rem; display: inline-flex; align-items: center; gap: .45rem; color: var(--ck-blue-700); font-family: "DM Sans", sans-serif; font-weight: 600; font-size: .92rem; }
.ck-sector-card__link i { transition: transform .25s var(--ck-ease); }
.ck-sector-card:hover .ck-sector-card__link i { transform: translateX(4px); }

.ck-sectors__cta { margin-top: clamp(1.75rem, 3.5vw, 2.75rem); background: var(--ck-ink); color: #fff; border-radius: var(--ck-radius); padding: clamp(1.6rem, 3.5vw, 2.5rem) clamp(1.5rem, 4vw, 3rem); display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; }
.ck-sectors__cta-txt strong { display: block; font-family: "DM Sans", sans-serif; font-weight: 700; font-size: clamp(1.2rem, 1rem + .8vw, 1.55rem); line-height: 1.2; margin-bottom: .35rem; }
.ck-sectors__cta-txt span { color: rgba(255, 255, 255, .8); font-size: .98rem; line-height: 1.5; }
.ck-sectors__cta-btn { flex: none; display: inline-flex; align-items: center; gap: .5rem; background: var(--ck-blue); color: #fff; text-decoration: none; font-family: "DM Sans", sans-serif; font-weight: 600; font-size: .95rem; padding: .85rem 1.6rem; border-radius: 10px; transition: transform .2s var(--ck-ease), background-color .2s var(--ck-ease); }
.ck-sectors__cta-btn:hover { background: var(--ck-blue-700); color: #fff; transform: translateY(-2px); }
.ck-sectors__cta-btn i { transition: transform .25s var(--ck-ease); }
.ck-sectors__cta-btn:hover i { transform: translateX(4px); }

@media (max-width: 991px) {
    .ck-sectors__intro { grid-template-columns: 1fr; gap: 1rem; }
    .ck-sectors__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .ck-sectors__topbar { flex-wrap: wrap; }
    .ck-sectors__pagetitle { order: -1; flex-basis: 100%; }
}

/* ===========================================================================
   Cabecalho de pagina generico (breadcrumb esq | titulo centro | separador) —
   estilo da pagina de Produtos. Usado no Blog; reutilizavel noutras paginas.
   =========================================================================== */
.ck-blog-page { padding-top: clamp(96px, 11vw, 118px); padding-bottom: clamp(2rem, 4vw, 3.5rem); }
.ck-pagehead__topbar { display: flex; align-items: center; gap: 16px; padding: 22px 0 6px; }
.ck-pagehead__bc { flex: 1 1 0; min-width: 0; display: flex; align-items: center; gap: .4rem; font-size: 13px; color: #888; }
.ck-pagehead__bc a { color: #888; text-decoration: none; }
.ck-pagehead__bc a:hover { color: var(--ck-blue-700); }
.ck-pagehead__bc b { color: #1a1a1a; font-weight: 500; }
.ck-pagehead__bc:last-child { justify-content: flex-end; }
.ck-pagehead__title { flex: 0 0 auto; text-align: center; font-family: "DM Sans", sans-serif; font-size: clamp(22px, 2.4vw, 30px); font-weight: 600; letter-spacing: -.5px; margin: 0; color: var(--ck-ink); }
.ck-pagehead__sep { margin: 6px 0 clamp(1.75rem, 3.5vw, 2.5rem); border: 0; border-top: 1px solid #ededed; }
@media (max-width: 640px) {
    .ck-pagehead__topbar { flex-wrap: wrap; }
    .ck-pagehead__title { order: -1; flex-basis: 100%; }
}
@media (max-width: 575px) {
    .ck-sectors__grid { grid-template-columns: 1fr; }
    .ck-sectors__cta { flex-direction: column; align-items: flex-start; }
}
