/* ==================== CSS VARIABLES ==================== */
:root {
    --primary: #FF6419;
    --primary-hover: #e55a16;
    --dark: #111111;
    --dark-alt: #1a1a1a;
    --gray-dark: #555555;
    --gray-light: #f8f8f8;
    --white: #ffffff;
    --border: #e8e8e8;
    --font-sans: 'Inter', sans-serif;
    --font-heading: 'Montserrat', sans-serif;
    --transition: all 0.3s ease;
    --shadow-sm: 0 2px 10px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 8px 30px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 20px 60px rgba(0, 0, 0, 0.15);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    font-family: var(--font-sans);
    color: var(--gray-dark);
    line-height: 1.6;
    background-color: var(--white);
    overflow-x: hidden;
    padding-top: 100px;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    color: var(--dark);
    font-weight: 700;
    line-height: 1.2;
}

a { text-decoration: none; color: inherit; transition: var(--transition); }
ul { list-style: none; }
img { max-width: 100%; height: auto; display: block; }

/* ==================== LAYOUT ==================== */
.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.section { 
    padding: 5rem 0; 
    position: relative;
}

.text-white { color: var(--white) !important; }
.text-dark { color: var(--dark) !important; }
.text-dark-light { color: var(--gray-dark) !important; }
.text-center { text-align: center; }
.mx-auto { margin-left: auto; margin-right: auto; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 2rem; }
.mt-4 { margin-top: 3rem; }

/* ==================== TYPOGRAPHY ==================== */
.section-title {
    font-size: 2.8rem;
    margin-bottom: 1rem;
    font-weight: 800;
}

.section-desc {
    font-size: 1.1rem;
    margin-bottom: 1.5rem;
    max-width: 700px;
    line-height: 1.7;
}

.highlight { color: var(--primary); }

.badge-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.9rem;
    background: linear-gradient(135deg, #e8e8e8 0%, #f0f0f0 100%);
    color: var(--dark);
    border-radius: 50px;
    font-weight: 600;
    font-size: 0.65rem;
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    border: 1px solid #ddd;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

.badge-tag::before {
    content: '';
    width: 6px;
    height: 6px;
    background: var(--primary);
    border-radius: 50%;
    display: inline-block;
}

.opacity-90 { opacity: 0.9; }

/* ==================== BUTTONS ==================== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    border-radius: 0.5rem;
    font-weight: 600;
    transition: var(--transition);
    cursor: pointer;
    text-decoration: none;
    border: none;
    font-size: 1rem;
}

.btn-primary {
    background-color: var(--primary);
    color: var(--white);
    box-shadow: 0 4px 6px rgba(255, 100, 25, 0.2);
}

.btn-primary:hover {
    background-color: var(--primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(255, 100, 25, 0.3);
    color: var(--white);
}

.btn-outline {
    background-color: transparent;
    border: 2px solid var(--primary);
    color: var(--primary);
}

.btn-outline:hover {
    background-color: var(--primary);
    color: var(--white);
}

.btn-sm {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
}

.btn-lg {
    padding: 1rem 2rem;
    font-size: 1.125rem;
}

/* ==================== WHATSAPP BUTTON ==================== */
.whatsapp-btn {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    width: 60px;
    height: 60px;
    background-color: #25D366;
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
    z-index: 999;
    transition: all 0.3s ease;
    text-decoration: none;
}

.whatsapp-btn:hover {
    background-color: #128C7E;
    transform: translateY(-5px) scale(1.05);
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.4);
    color: white;
}

/* Pulse Animation */
.whatsapp-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 50%;
    border: 2px solid #25D366;
    animation: pulse 2s infinite;
    z-index: -1;
}

@keyframes pulse {
    0% {
        transform: scale(1);
        opacity: 1;
    }
    100% {
        transform: scale(1.5);
        opacity: 0;
    }
}

@media (max-width: 768px) {
    .whatsapp-btn {
        bottom: 1.5rem;
        right: 1.5rem;
        width: 50px;
        height: 50px;
        font-size: 1.75rem;
    }
}

.btn-light:hover {
    background-color: var(--gray-light);
}

.btn-dark {
    background-color: var(--dark);
    color: var(--white);
}

.btn-dark:hover {
    background-color: var(--dark-alt);
}

.btn-sm { padding: 0.5rem 1.1rem; font-size: 0.75rem; }
.btn-lg { padding: 0.95rem 2.2rem; font-size: 0.95rem; }
.btn-icon { gap: 0.5rem; }
.btn-icon i { font-size: 1.3rem; }

/* ==================== HEADER MODERNO ==================== */
.header {
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    padding: 0.7rem 0;
    transition: var(--transition);
}

.header.scrolled {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    padding: 0.5rem 0;
}

.header.scrolled .logo img {
    height: 44px;
}

.header-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.logo img { 
    height: 62px;
    transition: var(--transition);
}

.nav-menu {
    flex: 1;
    display: flex;
    justify-content: center;
}

.nav-header,
.nav-close,
.nav-footer {
    display: none;
}

.nav-list {
    display: flex;
    gap: 0;
    align-items: center;
    background: rgba(17, 17, 17, 0.02);
    padding: 0.2rem;
    border-radius: 50px;
}

.nav-link {
    font-weight: 500;
    font-size: 0.72rem;
    color: var(--dark-alt);
    padding: 0.45rem 0.7rem;
    border-radius: 50px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.nav-link::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--primary);
    border-radius: 50px;
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.3s ease;
    z-index: -1;
}

.nav-link:hover::before,
.nav-link.active::before {
    transform: scaleX(1);
    transform-origin: left;
}

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

.header-actions {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    flex-shrink: 0;
}

.header-actions .btn {
    background: var(--primary);
    color: var(--white);
    border: none;
    padding: 0.6rem 1.2rem;
    font-size: 0.7rem;
    font-weight: 600;
    white-space: nowrap;
}

.header-actions .btn:hover {
    background: var(--primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(255, 100, 25, 0.35);
}

.menu-toggle {
    display: none;
    background: none;
    border: none;
    font-size: 1.6rem;
    color: var(--dark);
    cursor: pointer;
    padding: 0.4rem;
    border-radius: 8px;
    transition: var(--transition);
}

.menu-toggle:hover {
    background: rgba(255, 100, 25, 0.1);
    color: var(--primary);
}

/* ==================== HERO CAROUSEL ==================== */
.hero-carousel {
    width: 100%;
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
}

.heroSwiper {
    width: 100%;
    height: 100%;
}

.swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
}

.banner-img {
    width: 100%;
    height: auto;
    max-height: none;
    object-fit: contain;
    object-position: center top;
    display: block;
}

.hero-carousel {
    width: 100%;
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
    background: var(--dark);
}

.heroSwiper {
    width: 100%;
    height: auto;
}

.swiper-slide {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    overflow: hidden;
    background: var(--dark);
}

.swiper-button-next,
.swiper-button-prev {
    color: var(--white) !important;
    background: var(--primary);
    width: 55px;
    height: 55px;
    border-radius: 50%;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    transition: var(--transition);
}

.swiper-button-next:hover,
.swiper-button-prev:hover {
    background: var(--primary-hover);
    transform: scale(1.1);
}

.swiper-button-next:after,
.swiper-button-prev:after {
    font-size: 1.3rem !important;
    font-weight: bold;
}

.swiper-pagination {
    bottom: 30px !important;
}

.swiper-pagination-bullet {
    width: 14px;
    height: 14px;
    background: rgba(255, 255, 255, 0.5);
    opacity: 1;
    margin: 0 8px !important;
}

.swiper-pagination-bullet-active {
    background: var(--primary) !important;
    transform: scale(1.2);
}

/* ==================== BACKGROUND OVERLAYS ==================== */
.section-bg-img {
    position: relative;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    min-height: 600px;
    display: flex;
    align-items: center;
}

.overlay-dark {
    position: absolute;
    inset: 0;
    background: rgba(17, 17, 17, 0.88);
    z-index: 1;
}

.overlay-orange {
    position: absolute;
    inset: 0;
    background: rgba(255, 100, 25, 0.94);
    z-index: 1;
}

.overlay-gradient-dark {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(17,17,17,0.96) 0%, rgba(17,17,17,0.75) 100%);
    z-index: 1;
}

.overlay-gradient-dark-right {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(17,17,17,0.97) 0%, rgba(17,17,17,0.85) 40%, rgba(17,17,17,0.4) 100%);
    z-index: 1;
}

.z-10 {
    position: relative;
    z-index: 10;
}

/* ==================== SOBRE NOS ==================== */
.sobre-box {
    background: var(--white);
    padding: 3.5rem;
    border-radius: 24px;
    max-width: 580px;
    box-shadow: var(--shadow-lg);
    margin-left: auto;
}

.icon-circle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 55px;
    height: 55px;
    background: linear-gradient(135deg, rgba(255, 100, 25, 0.15) 0%, rgba(255, 100, 25, 0.25) 100%);
    color: var(--primary);
    border-radius: 50%;
    font-size: 1.6rem;
    flex-shrink: 0;
}

.sobre-features {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    margin: 2.5rem 0;
}

.feature-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-weight: 600;
    color: var(--dark);
    font-size: 1rem;
}

/* ==================== PRODUTOS 3D MODERNO ==================== */
#produtos {
    background: linear-gradient(180deg, #f0f0f0 0%, var(--white) 50%, #f5f5f5 100%);
}

.produtos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
    gap: 3rem;
    margin-top: 3rem;
}

.produto-card {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 200px;
    transition: var(--transition);
}

.produto-img {
    position: relative;
    width: 50%;
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}

.produto-img img {
    max-height: 200px;
    max-width: 110%;
    object-fit: contain;
    filter: drop-shadow(0 15px 30px rgba(0,0,0,0.2));
    transition: var(--transition);
}

.produto-card:hover .produto-img img {
    transform: scale(1.1) rotate(-3deg);
    filter: drop-shadow(0 25px 40px rgba(0,0,0,0.25));
}

.produto-info {
    flex: 1;
    background: var(--white);
    border-radius: 16px;
    padding: 1.2rem 1.5rem;
    margin-left: -2.5rem;
    box-shadow: 0 8px 30px rgba(0,0,0,0.08);
    display: flex;
    flex-direction: column;
    justify-content: center;
    z-index: 1;
    position: relative;
}

.produto-cat {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--gray-dark);
    font-weight: 600;
    margin-bottom: 0.6rem;
}

.produto-cat::before {
    content: '';
    width: 4px;
    height: 4px;
    background: var(--primary);
    border-radius: 50%;
    display: inline-block;
}

.produto-title {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 0.6rem;
    color: var(--dark);
    line-height: 1.3;
}

.produto-desc {
    font-size: 0.8rem;
    margin-bottom: 1rem;
    color: var(--gray-dark);
    line-height: 1.5;
}

.produto-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--primary);
    font-weight: 600;
    font-size: 0.8rem;
    transition: var(--transition);
    margin-top: auto;
}

.produto-link i {
    font-size: 0.9rem;
    transition: var(--transition);
}

.produto-link:hover {
    color: var(--primary-hover);
    gap: 0.6rem;
}

.produto-link:hover i {
    transform: translateX(3px);
}

/* ==================== CERTIFICACOES ==================== */
.certificacoes-container {
    display: flex;
    align-items: center;
}

.certificacoes-text-modern {
    max-width: 750px;
}

.cert-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.5rem;
    margin-top: 3rem;
}

.cert-card {
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 2.5rem 1.5rem;
    border-radius: 20px;
    text-align: center;
    transition: var(--transition);
    backdrop-filter: blur(5px);
}

.cert-card:hover {
    background: rgba(255, 255, 255, 0.15);
    transform: translateY(-8px);
    border-color: var(--primary);
}

.cert-card i {
    font-size: 3rem;
    margin-bottom: 1.2rem;
    display: block;
}

.cert-card h4 {
    color: var(--white);
    font-size: 1.2rem;
    margin-bottom: 0.8rem;
}

.cert-card p {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.9rem;
    line-height: 1.5;
}

/* ==================== DIFERENCIAIS COM FUNDO CLARO ==================== */
.diferenciais {
    background: linear-gradient(180deg, var(--gray-light) 0%, var(--white) 50%, var(--gray-light) 100%);
    position: relative;
    overflow: hidden;
    padding: 5rem 0;
}

.diferenciais::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: 
        url('../imagens/Argamassa%20AC-I%20(Uso%20Interno)%20.webp'),
        url('../imagens/Argamassa%20AC-II%20(Uso%20Interno%20e%20Externo)%20.webp'),
        url('../imagens/Argamassa%20AC-III%20(Alta%20Performance)%20.webp'),
        url('../imagens/Argamassa%20SuperFormatos.webp');
    background-position: 5% 20%, 95% 30%, 10% 80%, 90% 70%;
    background-size: 120px auto, 100px auto, 110px auto, 130px auto;
    background-repeat: no-repeat;
    opacity: 0.08;
    filter: grayscale(100%) blur(1px);
    pointer-events: none;
}

.highlight-dark {
    color: var(--primary);
    font-weight: 800;
}

.dif-grid-modern {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-top: 3rem;
    position: relative;
    z-index: 2;
}

.dif-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    background: var(--white);
    padding: 1.5rem;
    border-radius: 16px;
    border: 1px solid var(--border);
    box-shadow: 0 8px 25px rgba(0,0,0,0.06);
    transition: var(--transition);
}

.dif-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 35px rgba(0,0,0,0.1);
    border-color: var(--primary);
}

.dif-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    background: linear-gradient(135deg, var(--primary) 0%, #ff7a3d 100%);
    border-radius: 12px;
    flex-shrink: 0;
}

.dif-icon i {
    font-size: 1.5rem;
    color: var(--white);
}

.dif-content h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 0.4rem;
}

.dif-content p {
    font-size: 0.8rem;
    line-height: 1.5;
    color: var(--gray-dark);
}

/* ==================== REPRESENTANTE ==================== */
.representante-modern-container {
    min-height: 600px;
    display: flex;
    align-items: center;
}

.rep-text {
    max-width: 650px;
}

.rep-stats {
    display: flex;
    gap: 2.5rem;
    margin: 3rem 0;
    padding: 2.5rem;
    background: rgba(255, 255, 255, 0.12);
    border-radius: 20px;
    border-left: 5px solid var(--primary);
    backdrop-filter: blur(10px);
}

.stat-item {
    display: flex;
    flex-direction: column;
    flex: 1;
}

.stat-num {
    font-size: 3rem;
    color: var(--white);
    font-family: var(--font-heading);
    line-height: 1;
    margin-bottom: 0.8rem;
    font-weight: 800;
}

.stat-item span {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.9);
    line-height: 1.4;
}

/* ==================== WORKSHOP ==================== */
.workshop-section {
    position: relative;
    min-height: 620px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

/* Ken Burns Slideshow */
.workshop-kenburns {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.kb-slide {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0;
    animation: kbCycle 24s infinite;
}

.kb-slide-1 { background-image: url('../../imagens/palestraworkshop.webp');          animation-delay: 0s; }
.kb-slide-2 { background-image: url('../../imagens/entregadecertificadoworkshop.webp'); animation-delay: 6s; }
.kb-slide-3 { background-image: url('../../imagens/workshopvariosfuncionarios.webp');   animation-delay: 12s; }
.kb-slide-4 { background-image: url('../../imagens/eventocomfuncionarios.webp');        animation-delay: 18s; }

@keyframes kbCycle {
    0%   { opacity: 0; transform: scale(1.08); }
    5%   { opacity: 1; }
    25%  { opacity: 1; transform: scale(1.18); }
    30%  { opacity: 0; transform: scale(1.18); }
    100% { opacity: 0; transform: scale(1.08); }
}

.workshop-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: center;
    padding: 2rem 0;
}

.workshop-header {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1.2rem;
}

.workshop-header .section-title {
    margin-bottom: 0;
}

.workshop-header .section-desc {
    margin-bottom: 0;
}

.workshop-cards {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.topic-card-dark {
    display: flex;
    align-items: flex-start;
    gap: 1.2rem;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 16px;
    padding: 1.5rem 1.8rem;
    backdrop-filter: blur(8px);
    transition: var(--transition);
}

.topic-card-dark:hover {
    background: rgba(255, 255, 255, 0.11);
    border-color: rgba(255, 100, 25, 0.5);
    transform: translateX(6px);
}

.topic-icon-dark {
    width: 52px;
    height: 52px;
    min-width: 52px;
    background: linear-gradient(135deg, var(--primary) 0%, #e05510 100%);
    color: var(--white);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    font-size: 1.4rem;
}

.topic-card-dark strong {
    display: block;
    font-size: 1.05rem;
    color: var(--white);
    margin-bottom: 0.3rem;
}

.topic-card-dark p {
    font-size: 0.9rem;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.7);
    margin: 0;
}

@media (max-width: 900px) {
    .workshop-layout {
        grid-template-columns: 1fr;
        gap: 3rem;
    }
    .workshop-header {
        align-items: flex-start;
        text-align: left;
    }
    .topic-card-dark:hover {
        transform: translateY(-4px);
    }
}

@media (max-width: 768px) {
    .workshop-cards {
        gap: 1rem;
    }

    .topic-card-dark {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.8rem;
        padding: 1.2rem 1.4rem;
    }
}

/* ==================== COMUNIDADE ==================== */
.comunidade {
    padding: 6rem 0;
    background: var(--dark);
    position: relative;
}

.comunidade::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23FF6419' fill-opacity='0.03' fill-rule='evenodd'%3E%3Cpath d='M0 40L40 0H20L0 20M40 40V20L20 40'/%3E%3C/g%3E%3C/svg%3E");
}

/* ==================== FOOTER ==================== */
.footer {
    background-color: var(--dark);
    padding-top: 5rem;
}

.footer-container {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1.5fr;
    gap: 3rem;
    margin-bottom: 3rem;
}

.footer-logo img {
    height: 75px;
    margin-bottom: 1.5rem;
}

.brand p {
    margin-bottom: 1.5rem;
    font-size: 0.95rem;
    color: #aaa;
    line-height: 1.7;
}

.social-links {
    display: flex;
    gap: 1rem;
}

.social-links a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 45px;
    height: 45px;
    background: rgba(255, 255, 255, 0.1);
    color: var(--white);
    border-radius: 50%;
    font-size: 1.3rem;
    transition: var(--transition);
}

.social-links a:hover {
    background: var(--primary);
    transform: translateY(-3px);
}

.footer h4 {
    color: var(--white);
    margin-bottom: 1.5rem;
    font-size: 1.1rem;
    font-weight: 600;
    position: relative;
    padding-bottom: 0.8rem;
}

.footer h4::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 40px;
    height: 3px;
    background: var(--primary);
    border-radius: 3px;
}

.footer ul {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.footer ul li a {
    color: #aaa;
    font-size: 0.9rem;
}

.footer ul li a:hover {
    color: var(--primary);
    padding-left: 0.5rem;
}

.footer .contato ul li {
    display: flex;
    gap: 0.8rem;
    align-items: flex-start;
    color: #aaa;
    font-size: 0.9rem;
    line-height: 1.5;
}

.footer .contato i {
    color: var(--primary);
    font-size: 1.2rem;
    margin-top: 0.2rem;
    flex-shrink: 0;
}

.footer-bottom {
    background-color: rgba(0, 0, 0, 0.3);
    padding: 2rem 0;
    text-align: center;
    font-size: 0.85rem;
    color: #777;
}

/* ==================== RESPONSIVE ==================== */
@media (max-width: 1024px) {
    .sobre-box {
        max-width: 100%;
        margin: 0 auto;
    }
    
    .rep-stats {
        flex-direction: column;
        gap: 1.5rem;
    }
}

@media (max-width: 992px) {
    .footer-container {
        grid-template-columns: 1fr 1fr;
        gap: 2.5rem;
    }
    
    .section-title {
        font-size: 2.2rem;
    }
}

@media (max-width: 768px) {
    .logo img {
        height: 50px;
    }

    .header.scrolled .logo img {
        height: 35px;
    }

    .section {
        padding: 3rem 0;
    }

    .diferenciais {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }
    
    .section-title {
        font-size: 1.8rem;
    }
    
    .section-desc {
        font-size: 1rem;
    }
    
    .banner-img {
        max-height: 60vh;
        min-height: 350px;
    }
    
    .swiper-button-next,
    .swiper-button-prev {
        display: none;
    }
    
    .nav-menu {
        position: fixed;
        top: 0;
        right: -100%;
        width: min(320px, 85vw);
        height: 100dvh;
        background: var(--dark);
        flex-direction: column;
        justify-content: flex-start;
        padding: 0;
        transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: -8px 0 40px rgba(0,0,0,0.35);
        z-index: 1100;
        overflow-y: auto;
        overflow-x: hidden;
    }

    .nav-menu.active {
        right: 0;
    }

    /* Overlay escuro atrás do menu */
    .nav-menu::before {
        content: '';
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,0);
        z-index: -1;
        pointer-events: none;
        transition: background 0.35s ease;
    }

    .nav-menu.active::before {
        background: rgba(0,0,0,0.6);
        pointer-events: auto;
        right: min(320px, 85vw);
        left: 0;
    }

    .nav-header,
    .nav-footer {
        display: flex;
    }

    .nav-close {
        display: flex;
    }

    /* Cabeçalho do painel */
    .nav-menu .nav-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 1.4rem 1.6rem;
        border-bottom: 1px solid rgba(255,255,255,0.08);
    }

    .nav-menu .nav-header-logo {
        height: 96px;
        filter: brightness(0) invert(1);
    }

    .nav-menu .nav-close {
        background: rgba(255,255,255,0.08);
        border: none;
        color: var(--white);
        font-size: 1.4rem;
        width: 38px;
        height: 38px;
        border-radius: 10px;
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        transition: var(--transition);
    }

    .nav-menu .nav-close:hover {
        background: var(--primary);
    }

    .nav-list {
        flex-direction: column;
        gap: 0;
        align-items: stretch;
        background: none;
        padding: 0.5rem 0;
        border-radius: 0;
        flex-shrink: 0;
    }

    .nav-link {
        font-size: 1.1rem;
        font-weight: 600;
        padding: 0.85rem 1.6rem;
        color: rgba(255,255,255,0.85);
        border-radius: 0;
        text-transform: none;
        letter-spacing: 0;
        display: flex;
        align-items: center;
        gap: 0.8rem;
        border-left: 3px solid transparent;
        transition: all 0.2s ease;
    }

    .nav-link::before {
        display: none;
    }

    .nav-link:hover,
    .nav-link.active {
        color: var(--white);
        background: rgba(255,100,25,0.12);
        border-left-color: var(--primary);
    }

    /* Rodapé do menu mobile */
    .nav-menu .nav-footer {
        padding: 1.2rem 1.6rem;
        border-top: 1px solid rgba(255,255,255,0.08);
        flex-shrink: 0;
    }

    .nav-menu .nav-footer-contacts {
        display: flex;
        flex-direction: column;
        gap: 0.6rem;
        margin-bottom: 1.2rem;
    }

    .nav-menu .nav-footer-contacts a {
        display: flex;
        align-items: center;
        gap: 0.6rem;
        color: rgba(255,255,255,0.6);
        font-size: 0.8rem;
        transition: color 0.2s;
    }

    .nav-menu .nav-footer-contacts a:hover {
        color: var(--primary);
    }

    .nav-menu .nav-footer-contacts i {
        color: var(--primary);
        font-size: 1rem;
    }

    .nav-menu .nav-footer-social {
        display: flex;
        gap: 0.6rem;
    }

    .nav-menu .nav-footer-social a {
        width: 36px;
        height: 36px;
        border-radius: 10px;
        background: rgba(255,255,255,0.08);
        color: rgba(255,255,255,0.7);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 1rem;
        transition: var(--transition);
    }

    .nav-menu .nav-footer-social a:hover {
        background: var(--primary);
        color: var(--white);
    }

    .header-actions .btn {
        display: none;
    }

    .menu-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 42px;
        height: 42px;
        border-radius: 12px;
        background: rgba(255,100,25,0.08);
        font-size: 1.5rem;
        color: var(--dark);
    }
    
    .sobre-box {
        padding: 2.5rem;
    }
    
    .cert-grid,
    .dif-grid,
    .modern-topics {
        grid-template-columns: 1fr;
    }
    
    .footer-container {
        grid-template-columns: 1fr;
    }
    
    .produtos-grid {
        grid-template-columns: 1fr;
    }
    
    .overlay-gradient-dark-right {
        background: rgba(17, 17, 17, 0.92);
    }
    
    .rep-stats {
        padding: 1.5rem;
    }
    
    .stat-num {
        font-size: 2.2rem;
    }
}

/* ==================== SOBRE SPLIT LAYOUT ==================== */
#sobre {
    background: var(--gray-light);
    overflow: hidden;
    isolation: isolate;
}

.sobre-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

.sobre-texto {
    max-width: 540px;
}

.sobre-texto .section-title {
    font-size: 2.2rem;
    line-height: 1.3;
}

.sobre-texto .section-desc {
    font-size: 1rem;
    margin-bottom: 1.2rem;
}

.sobre-features-compact {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin: 1.5rem 0;
}

.feature-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--white);
    padding: 0.5rem 1rem;
    border-radius: 50px;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--dark);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border);
}

.feature-pill i {
    color: var(--primary);
    font-size: 1.1rem;
}

/* Grid de Imagens Sobrepostas */
.sobre-imagens-grid {
    position: relative;
    height: 450px;
}

.img-grid-item {
    position: absolute;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: var(--shadow-md);
    transition: var(--transition);
}

.img-grid-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.img-grid-item:hover {
    transform: scale(1.03);
    z-index: 10;
}

.img-main {
    width: 70%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1;
}

.img-float-1 {
    width: 45%;
    height: 55%;
    bottom: 0;
    right: 0;
    z-index: 2;
    border: 4px solid var(--white);
}

.img-float-2 {
    width: 35%;
    height: 40%;
    top: 10%;
    right: 5%;
    z-index: 3;
    border: 4px solid var(--white);
}

/* ==================== FONTES MENORES ==================== */
.section-title {
    font-size: 2rem;
}

.section-desc {
    font-size: 0.95rem;
    line-height: 1.6;
}

.produto-title {
    font-size: 1.2rem;
}

.produto-desc {
    font-size: 0.85rem;
}

.cert-card h4 {
    font-size: 1rem;
}

.cert-card p {
    font-size: 0.8rem;
}

.modern-card h3 {
    font-size: 1.1rem;
}

.modern-card p {
    font-size: 0.85rem;
}

.topic-card strong {
    font-size: 1rem;
}

.topic-card p {
    font-size: 0.85rem;
}

.stat-num {
    font-size: 2.5rem;
}

.stat-item span {
    font-size: 0.8rem;
}

.rep-text .section-title {
    font-size: 2rem;
}

.rep-text .section-desc {
    font-size: 0.95rem;
}

/* ==================== RESPONSIVE SOBRE ==================== */
@media (max-width: 992px) {
    .sobre-split {
        grid-template-columns: 1fr;
        gap: 3rem;
    }
    
    .sobre-texto {
        max-width: 100%;
        text-align: left;
    }
    
    .sobre-features-compact {
        justify-content: flex-start;
    }
    
    .sobre-imagens-grid {
        height: 350px;
        max-width: 500px;
        margin: 0 auto;
    }
}

@media (max-width: 768px) {
    .sobre-imagens-grid {
        position: relative;
        height: auto;
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto auto;
        gap: 0.6rem;
        margin-bottom: 1rem;
    }
    
    .img-grid-item {
        position: relative;
        width: 100% !important;
        height: 160px !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        bottom: auto !important;
        border-width: 3px;
    }

    .img-main {
        grid-column: 1 / -1;
        height: 200px !important;
    }
    
    .sobre-texto {
        text-align: left;
    }

    .sobre-features-compact {
        justify-content: flex-start;
    }
    
    .sobre-texto .section-title {
        font-size: 1.6rem;
    }
    
    .feature-pill {
        font-size: 0.75rem;
        padding: 0.4rem 0.8rem;
    }
}

/* ==================== TOP BAR ==================== */
.top-bar {
    background: var(--primary);
    padding: 0.5rem 0;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1001;
}

.top-bar-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.top-bar-links {
    display: flex;
    gap: 2rem;
}

.top-bar-links a {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: rgba(255, 255, 255, 0.95);
    font-size: 0.8rem;
    font-weight: 500;
    transition: var(--transition);
}

.top-bar-links a:hover {
    color: var(--white);
}

.top-bar-links i {
    font-size: 1rem;
    color: var(--white);
}

.top-bar-social {
    display: flex;
    gap: 0.6rem;
}

.top-bar-social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    background: rgba(255, 255, 255, 0.2);
    color: var(--white);
    border-radius: 50%;
    font-size: 0.95rem;
    transition: var(--transition);
}

.top-bar-social a:hover {
    background: var(--white);
    color: var(--primary);
    transform: translateY(-2px);
}

/* ==================== RESPONSIVE HEADER ==================== */
@media (max-width: 1024px) {
    .header-container {
        gap: 1rem;
    }
    
    .nav-link {
        padding: 0.5rem 0.8rem;
        font-size: 0.7rem;
    }
    
    .header-actions .btn {
        padding: 0.5rem 1rem;
        font-size: 0.65rem;
    }
}

@media (max-width: 768px) {
    body {
        padding-top: 70px;
    }

    .header {
        top: 0;
    }
}

/* Badge específico para seção Sobre - mais minimalista */
.sobre-texto .badge-tag {
    background: #f5f5f5;
    border: 1px solid #e0e0e0;
    font-size: 0.6rem;
    padding: 0.3rem 0.8rem;
    letter-spacing: 2px;
    color: var(--gray-dark);
}

.sobre-texto .badge-tag::before {
    width: 5px;
    height: 5px;
}

/* ==================== PRODUTOS RESPONSIVE ==================== */
@media (max-width: 768px) {
    .produtos-grid {
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
    }
    
    .produto-card {
        flex-direction: column;
        align-items: stretch;
        min-height: unset;
        border-radius: 16px;
        overflow: hidden;
    }
    
    .produto-img {
        width: 100%;
        min-height: 160px;
        border-radius: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--gray-light);
        padding: 1rem;
    }
    
    .produto-img img {
        max-height: 130px;
        width: auto;
        margin: 0 auto;
        display: block;
    }
    
    .produto-info {
        padding: 1rem;
        margin-left: 0;
        text-align: left;
        width: 100%;
        border-radius: 0 0 16px 16px;
    }
    
    .produto-title {
        font-size: 0.95rem;
    }
    
    .produto-desc {
        font-size: 0.75rem;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .produto-cat {
        font-size: 0.65rem;
    }
}

@media (max-width: 480px) {
    .produtos-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .produto-card {
        flex-direction: row;
        align-items: center;
        border-radius: 16px;
        overflow: hidden;
    }

    .produto-img {
        width: 38%;
        min-height: 140px;
        flex-shrink: 0;
        border-radius: 0;
        padding: 0.8rem;
    }

    .produto-img img {
        max-height: 120px;
    }

    .produto-info {
        flex: 1;
        padding: 1rem;
        margin-left: 0;
        text-align: left;
        border-radius: 0;
        width: auto;
    }

    .produto-link {
        justify-content: flex-start;
    }
}

/* ==================== CERTIFICAÇÕES FULL BACKGROUND ==================== */
.certificacoes-fullbg {
    background-size: cover;
    background-position: center;
    min-height: 450px;
    position: relative;
    padding: 3rem 0;
    isolation: isolate;
}

.certificacoes-fullbg::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.25);
    z-index: 1;
}

.certificacoes-content-wrapper {
    position: relative;
    z-index: 2;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    min-height: 350px;
}

.certificacoes-glass {
    background: rgba(255, 255, 255, 0.75);
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(30px);
    border-radius: 20px;
    padding: 1.8rem 2rem;
    max-width: 420px;
    box-shadow: 0 20px 40px rgba(0,0,0,0.1);
    border: 1px solid rgba(255,255,255,0.6);
}

.certificacoes-glass .badge-tag {
    margin-bottom: 0.8rem;
}

.certificacoes-glass .section-title {
    font-size: 1.6rem;
    line-height: 1.3;
    margin-bottom: 0.8rem;
}

.certificacoes-glass .section-desc {
    font-size: 0.85rem;
    margin-bottom: 1rem;
    color: var(--gray-dark);
    line-height: 1.5;
}

.cert-features-compact {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1.2rem;
}

.cert-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    background: rgba(255,255,255,0.9);
    padding: 0.4rem 0.9rem;
    border-radius: 50px;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--dark);
    border: 1px solid rgba(0,0,0,0.08);
    box-shadow: 0 2px 6px rgba(0,0,0,0.04);
}

.cert-pill i {
    color: var(--primary);
    font-size: 0.85rem;
}

/* ==================== RESPONSIVE CERTIFICAÇÕES ==================== */
@media (max-width: 992px) {
    .certificacoes-fullbg {
        min-height: auto;
    }
    
    .certificacoes-content-wrapper {
        justify-content: center;
        min-height: auto;
    }
    
    .certificacoes-glass {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 1.5rem;
    }
}

@media (max-width: 768px) {
    .certificacoes-fullbg {
        padding: 2rem 0;
        min-height: 400px;
    }
    
    .certificacoes-glass {
        padding: 1.2rem;
        border-radius: 16px;
    }
    
    .certificacoes-glass .section-title {
        font-size: 1.4rem;
    }
    
    .cert-pill {
        font-size: 0.65rem;
        padding: 0.35rem 0.7rem;
    }
}

/* ==================== DIFERENCIAIS RESPONSIVE ==================== */
@media (max-width: 992px) {
    .dif-grid-modern {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.2rem;
    }
}

@media (max-width: 768px) {
    .dif-grid-modern {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    
    .dif-item {
        padding: 1.2rem;
    }
    
    .dif-icon {
        width: 45px;
        height: 45px;
    }
    
    .dif-icon i {
        font-size: 1.3rem;
    }
    
    .dif-content h3 {
        font-size: 0.95rem;
    }
    
    .dif-content p {
        font-size: 0.75rem;
    }
}

/* ==================== REPRESENTANTE COM MAPA ==================== */
.representante-section {
    background: linear-gradient(135deg, var(--gray-light) 0%, var(--white) 50%, #f0f0f0 100%);
    padding: 5rem 0;
    position: relative;
}

.representante-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

.representante-content {
    max-width: 500px;
}

.representante-content .section-title {
    font-size: 2rem;
    line-height: 1.3;
    margin-bottom: 1rem;
}

.representante-content .section-desc {
    font-size: 0.95rem;
    margin-bottom: 1.5rem;
}

.rep-stats-modern {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin: 2rem 0;
}

.rep-stat-box {
    background: var(--white);
    padding: 1rem;
    border-radius: 12px;
    text-align: center;
    border: 1px solid var(--border);
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
    transition: var(--transition);
}

.rep-stat-box:hover {
    transform: translateY(-3px);
    border-color: var(--primary);
}

.rep-stat-box strong {
    display: block;
    font-size: 1.5rem;
    color: var(--primary);
    font-weight: 800;
    margin-bottom: 0.3rem;
}

.rep-stat-box span {
    font-size: 0.7rem;
    color: var(--gray-dark);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Mapa do Brasil */
.mapa-brasil-container {
    background: var(--white);
    border-radius: 24px;
    padding: 2rem;
    box-shadow: 0 20px 50px rgba(0,0,0,0.1);
}

.mapa-titulo {
    text-align: center;
    font-size: 1.2rem;
    margin-bottom: 1.5rem;
    color: var(--dark);
}

.mapa-titulo .highlight {
    color: var(--primary);
}

.mapa-wrapper {
    position: relative;
}

.mapa-brasil {
    width: 100%;
    max-width: 350px;
    margin: 0 auto;
    display: block;
}

.mapa-brasil .estado {
    fill: #e0e0e0;
    stroke: var(--white);
    stroke-width: 2;
    transition: all 0.3s ease;
    cursor: pointer;
}

.mapa-brasil .estado:hover {
    fill: var(--primary);
    filter: drop-shadow(0 4px 10px rgba(255,100,25,0.3));
}

.mapa-brasil .estado.nordeste {
    fill: #ffccb3;
}

.mapa-brasil .estado.nordeste:hover {
    fill: var(--primary);
}

.mapa-tooltip {
    position: absolute;
    background: var(--dark);
    color: var(--white);
    padding: 0.8rem 1rem;
    border-radius: 8px;
    font-size: 0.8rem;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s;
    z-index: 10;
    white-space: nowrap;
}

.mapa-tooltip.visible {
    opacity: 1;
}

.mapa-tooltip::after {
    content: '';
    position: absolute;
    bottom: -5px;
    left: 50%;
    transform: translateX(-50%);
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 5px solid var(--dark);
}

.mapa-legenda {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
}

.legenda-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.75rem;
    color: var(--gray-dark);
}

.legenda-cor {
    width: 12px;
    height: 12px;
    border-radius: 3px;
}

.legenda-cor.ativo {
    background: #ffccb3;
    border: 1px solid var(--primary);
}

.legenda-cor.expansao {
    background: #e0e0e0;
}

/* ==================== RESPONSIVE REPRESENTANTE ==================== */
@media (max-width: 992px) {
    .representante-wrapper {
        grid-template-columns: 1fr;
        gap: 3rem;
    }
    
    .representante-content {
        max-width: 100%;
        text-align: center;
    }
    
    .rep-stats-modern {
        max-width: 500px;
        margin: 2rem auto;
    }
    
    .mapa-brasil-container {
        max-width: 500px;
        margin: 0 auto;
    }
}

@media (max-width: 768px) {
    .representante-section {
        padding: 3rem 0;
    }
    
    .rep-stats-modern {
        grid-template-columns: 1fr;
        gap: 0.8rem;
    }
    
    .rep-stat-box {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0.8rem 1rem;
    }
    
    .rep-stat-box strong {
        font-size: 1.3rem;
        margin-bottom: 0;
    }
    
    .mapa-brasil-container {
        padding: 1.5rem;
    }
    
    .mapa-brasil {
        max-width: 280px;
    }
}

/* ==================== INTRO SPLASH ==================== */
.intro-splash {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.intro-splash.active {
    pointer-events: all;
}

.intro-slides {
    position: absolute;
    inset: 0;
}

.intro-slide {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transform: scale(1.1);
    transition: opacity 0.8s ease, transform 6s ease;
}

.intro-slide.active {
    opacity: 1;
    transform: scale(1.18);
}

.intro-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(17,17,17,0.88) 0%, rgba(17,17,17,0.7) 100%);
    z-index: 1;
}

.intro-content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.2rem;
    text-align: center;
    animation: introContentIn 0.8s ease forwards;
}

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

.intro-logo {
    width: 220px;
    filter: drop-shadow(0 4px 20px rgba(0,0,0,0.4));
}

.intro-tagline {
    color: rgba(255,255,255,0.85);
    font-family: var(--font-sans);
    font-size: 1rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    font-weight: 500;
}

.intro-bar {
    width: 200px;
    height: 3px;
    background: rgba(255,255,255,0.15);
    border-radius: 10px;
    overflow: hidden;
}

.intro-bar-fill {
    height: 100%;
    width: 0%;
    background: var(--primary);
    border-radius: 10px;
    animation: introBarFill 2.5s ease forwards;
    animation-delay: 0.3s;
}

@keyframes introBarFill {
    to { width: 100%; }
}

/* Saída do splash */
.intro-splash.outro {
    animation: introOut 0.7s ease forwards;
}

@keyframes introOut {
    to { opacity: 0; transform: scale(1.04); }
}

/* ==================== AVALIAÇÕES ==================== */
.avaliacoes-section {
    background: var(--white);
    padding: 5rem 0;
}

.avaliacoes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
}

.avaliacao-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 2rem;
    transition: all 0.3s ease;
    position: relative;
}

.avaliacao-card:hover {
    border-color: var(--primary);
    box-shadow: 0 12px 40px rgba(255, 100, 25, 0.1);
    transform: translateY(-5px);
}

.avaliacao-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.avaliacao-foto {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    border: 2px solid var(--primary);
}

.avaliacao-foto img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.avaliacao-info {
    flex: 1;
}

.avaliacao-nome {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 0.2rem;
}

.avaliacao-data {
    font-size: 0.85rem;
    color: var(--gray-dark);
}

.avaliacao-estrelas {
    display: flex;
    gap: 0.25rem;
    margin-bottom: 1rem;
}

.avaliacao-estrelas i {
    font-size: 1.2rem;
    color: #ffc107;
}

.avaliacao-texto {
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--gray-dark);
    font-style: italic;
}

.avaliacao-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 1rem;
    font-size: 0.85rem;
    color: var(--primary);
    font-weight: 600;
    transition: all 0.3s ease;
}

.avaliacao-link:hover {
    gap: 0.8rem;
}

.avaliacao-link i {
    font-size: 1rem;
}

@media (max-width: 768px) {
    .avaliacoes-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .avaliacao-card {
        padding: 1.5rem;
    }
}

/* ==================== CLIENTES (LEGADO) ==================== */
.cliente-logo a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    text-decoration: none;
}

/* ==================== SCROLL REVEAL ==================== */
.reveal {
    opacity: 0;
    transition: opacity 0.7s ease var(--reveal-delay, 0s),
                transform 0.7s ease var(--reveal-delay, 0s);
}

.reveal.revealed {
    opacity: 1;
    transform: none !important;
}

.reveal-up    { transform: translateY(40px); }
.reveal-left  { transform: translateX(-40px); }
.reveal-right { transform: translateX(40px); }

/* ==================== QUEM SOMOS ==================== */

/* Hero */
.qs-hero {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.qs-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center top;
    transform: scale(1.05);
}

.qs-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(17,17,17,0.9) 0%, rgba(255,100,25,0.75) 100%);
}

.qs-hero-content {
    position: relative;
    z-index: 1;
    padding: 5rem 1.5rem 4rem;
}

.qs-hero-title {
    font-size: 3rem;
    color: var(--white);
    margin: 0.8rem 0 1rem;
    line-height: 1.15;
}

.qs-hero-desc {
    font-size: 1.1rem;
    color: rgba(255,255,255,0.8);
    max-width: 500px;
}

/* Intro Grid */
.qs-intro-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: center;
}

.qs-intro-texto .section-desc {
    margin-bottom: 1.2rem;
}

.qs-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 2rem;
}

.qs-badge {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 50px;
    padding: 0.5rem 1.1rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--dark);
    box-shadow: var(--shadow-sm);
}

.qs-badge i {
    color: var(--primary);
    font-size: 1rem;
}

.qs-intro-imagens {
    position: relative;
    height: 420px;
}

.qs-img-main {
    position: absolute;
    top: 0;
    left: 0;
    width: 72%;
    height: 100%;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.qs-img-main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.qs-img-float {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 48%;
    height: 52%;
    border-radius: 16px;
    overflow: hidden;
    border: 4px solid var(--white);
    box-shadow: var(--shadow-md);
}

.qs-img-float img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* MVV */
.qs-mvv-section {
    background: var(--gray-light);
    padding: 5rem 0;
}

.qs-mvv-dark-bg {
    padding: 0;
}

.qs-mvv-header {
    text-align: center;
    margin-bottom: 3rem;
}

.badge-tag--light {
    background: rgba(255,255,255,0.1);
    border-color: rgba(255,255,255,0.2);
    color: rgba(255,255,255,0.8);
}

.badge-tag--light::before {
    background: var(--primary);
}

.qs-mvv-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.qs-mvv-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 2.5rem 2rem;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}

.qs-mvv-card::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--primary);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease;
}

.qs-mvv-card:hover::after {
    transform: scaleX(1);
}

.qs-mvv-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
}

.qs-mvv-icon {
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, rgba(255,100,25,0.12) 0%, rgba(255,100,25,0.06) 100%);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    color: var(--primary);
    margin-bottom: 1.4rem;
}

.qs-mvv-card h3 {
    font-size: 1.2rem;
    margin-bottom: 0.8rem;
    color: var(--dark);
}

.qs-mvv-card p {
    font-size: 0.9rem;
    line-height: 1.7;
    color: var(--gray-dark);
}

/* Timeline Horizontal */
.qs-timeline {
    position: relative;
    margin-top: 3.5rem;
    display: flex;
    align-items: flex-start;
    gap: 0;
    overflow-x: auto;
    padding-bottom: 1rem;
}

/* Linha horizontal */
.qs-timeline::before {
    content: '';
    position: absolute;
    top: 26px;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(to right, var(--primary), rgba(255,100,25,0.2));
    pointer-events: none;
}

.qs-timeline-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    min-width: 180px;
    position: relative;
}

.qs-timeline-ano {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 1.2rem;
    position: relative;
    z-index: 1;
}

.qs-timeline-bolinha {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--primary);
    color: var(--white);
    font-family: var(--font-heading);
    font-size: 0.72rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 0 5px rgba(255,100,25,0.15);
    flex-shrink: 0;
    line-height: 1.2;
    text-align: center;
}

.qs-timeline-conteudo {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 1.2rem 1.4rem;
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
    width: 100%;
    text-align: center;
}

.qs-timeline-conteudo:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-3px);
}

.qs-timeline-conteudo h4 {
    font-size: 0.95rem;
    color: var(--dark);
    margin-bottom: 0.4rem;
}

.qs-timeline-conteudo p {
    font-size: 0.82rem;
    line-height: 1.6;
    color: var(--gray-dark);
    margin: 0;
}

.qs-timeline-vazio {
    display: none;
}

/* Full BG Section */
.qs-fullbg-section {
    position: relative;
    min-height: 380px;
    display: flex;
    align-items: center;
    background-size: cover;
    background-position: center;
}

.qs-fullbg-overlay {
    position: absolute;
    inset: 0;
    background: rgba(17,17,17,0.72);
}

.qs-fullbg-content {
    position: relative;
    z-index: 1;
    text-align: center;
    padding: 4rem 1.5rem;
}

.qs-fullbg-quote {
    font-family: var(--font-heading);
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--white);
    max-width: 780px;
    margin: 0 auto;
    line-height: 1.5;
}

/* Fotos Grid */
.qs-fotos-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.8rem;
    margin-top: 3rem;
}

.qs-foto-item {
    border-radius: 16px;
    overflow: hidden;
    height: 220px;
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
    cursor: pointer;
    position: relative;
}

.qs-foto-item::after {
    content: '\2197';
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: var(--white);
    opacity: 0;
    transition: all 0.25s ease;
}

.qs-foto-item:hover {
    transform: scale(1.02);
    box-shadow: var(--shadow-md);
}

.qs-foto-item:hover::after {
    background: rgba(0,0,0,0.30);
    opacity: 1;
}

/* Lightbox */
.qs-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0,0,0,0.92);
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
}

.qs-lightbox.open { display: flex; }

.qs-lightbox img {
    max-width: 92vw;
    max-height: 88vh;
    object-fit: contain;
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}

.qs-lightbox-close {
    position: fixed;
    top: 1.2rem;
    right: 1.5rem;
    background: none;
    border: none;
    color: var(--white);
    font-size: 2.2rem;
    cursor: pointer;
    line-height: 1;
    opacity: 0.8;
    transition: opacity 0.2s;
}

.qs-lightbox-close:hover { opacity: 1; }

.qs-foto-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.qs-foto-item:hover img {
    transform: scale(1.05);
}

/* CTA */
.qs-cta-section {
    background: var(--gray-light);
}

.qs-cta-buttons {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 2rem;
}

/* ==================== QUEM SOMOS RESPONSIVE ==================== */
@media (max-width: 992px) {
    .qs-intro-grid {
        grid-template-columns: 1fr;
        gap: 3rem;
    }

    .qs-intro-imagens {
        height: 320px;
        max-width: 500px;
        margin: 0 auto;
    }

    .qs-mvv-dark-bg {
        padding: 3.5rem 0;
    }

    .qs-mvv-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
}

@media (max-width: 768px) {
    .qs-hero-title {
        font-size: 2rem;
    }

    .qs-fullbg-quote {
        font-size: 1.2rem;
    }

    .qs-timeline {
        gap: 0;
        padding-bottom: 1.5rem;
    }

    .qs-timeline-item {
        min-width: 220px;
    }

    .qs-timeline-conteudo {
        text-align: left;
    }

    .qs-fotos-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .qs-foto-item {
        height: 220px;
    }

    .qs-intro-imagens {
        height: auto;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.6rem;
    }

    .qs-img-main,
    .qs-img-float {
        position: relative;
        width: 100%;
        height: 180px;
        border: none;
        inset: auto;
    }

    .qs-img-main {
        grid-column: 1 / -1;
        height: 200px;
    }

    .qs-cta-buttons {
        flex-direction: column;
        align-items: center;
    }
}

/* ==================== PÁGINA PRODUTOS ==================== */

/* Hero */
.prod-hero {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.prod-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transform: scale(1.05);
}

.prod-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(17,17,17,0.9) 0%, rgba(255,100,25,0.65) 100%);
}

.prod-hero-content {
    position: relative;
    z-index: 1;
    padding: 4.5rem 1.5rem 3.5rem;
}

.prod-hero-title {
    font-size: 2.6rem;
    color: var(--white);
    margin: 0.8rem 0 1rem;
    line-height: 1.2;
    max-width: 640px;
}

.prod-hero-desc {
    font-size: 1rem;
    color: rgba(255,255,255,0.78);
    max-width: 520px;
    margin-bottom: 2rem;
}

/* Toolbar filtros + busca */
.prod-toolbar-section {
    background: var(--white);
    border-bottom: 1px solid var(--border);
    padding: 1rem 0;
    position: static;
}

.prod-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.prod-filtros {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
}

.prod-filtro {
    background: var(--gray-light);
    border: 1px solid var(--border);
    border-radius: 50px;
    padding: 0.5rem 1.2rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--gray-dark);
    cursor: pointer;
    transition: var(--transition);
    font-family: var(--font-sans);
}

.prod-filtro:hover {
    border-color: var(--primary);
    color: var(--primary);
    background: rgba(255,100,25,0.05);
}

.prod-filtro.active {
    background: var(--primary);
    border-color: var(--primary);
    color: var(--white);
}

.prod-busca {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    background: var(--gray-light);
    border: 1px solid var(--border);
    border-radius: 50px;
    padding: 0.5rem 1.2rem;
    min-width: 220px;
    transition: var(--transition);
}

.prod-busca:focus-within {
    border-color: var(--primary);
    background: var(--white);
    box-shadow: 0 0 0 3px rgba(255,100,25,0.1);
}

.prod-busca i {
    color: var(--gray-dark);
    font-size: 1rem;
    flex-shrink: 0;
}

.prod-busca input {
    border: none;
    background: none;
    outline: none;
    font-size: 0.85rem;
    color: var(--dark);
    font-family: var(--font-sans);
    width: 100%;
}

.prod-busca input::placeholder {
    color: #aaa;
}

/* Grid de produtos */
.prod-grid-section {
    background: var(--gray-light);
}

.prod-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.prod-card {
    background: var(--white);
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid var(--border);
    transition: var(--transition);
    display: flex;
    flex-direction: column;
}

.prod-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
}

.prod-card-img {
    position: relative;
    background: var(--gray-light);
    height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    overflow: hidden;
}

.prod-card-img img {
    max-height: 180px;
    width: auto;
    object-fit: contain;
    transition: transform 0.4s ease;
}

.prod-card:hover .prod-card-img img {
    transform: scale(1.08) rotate(-2deg);
}

.prod-card-cat {
    position: absolute;
    top: 1rem;
    left: 1rem;
    background: var(--primary);
    color: var(--white);
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 0.3rem 0.8rem;
    border-radius: 50px;
}

.prod-card-body {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 0.8rem;
}

.prod-card-title {
    font-size: 1.1rem;
    color: var(--dark);
    margin: 0;
}

.prod-card-desc {
    font-size: 0.85rem;
    line-height: 1.6;
    color: var(--gray-dark);
    margin: 0;
    flex: 1;
}

.prod-card-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.prod-pill {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--primary);
    background: rgba(255,100,25,0.08);
    border-radius: 50px;
    padding: 0.25rem 0.7rem;
}

.prod-pill i {
    font-size: 0.85rem;
}

.prod-btn {
    align-self: flex-start;
    margin-top: 0.4rem;
    background: none;
    border: none;
    padding: 0;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--primary);
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    text-decoration: none;
    transition: gap 0.2s ease;
    cursor: pointer;
}

.prod-btn::after {
    content: '→';
    transition: transform 0.2s ease;
}

.prod-btn:hover {
    gap: 0.5rem;
    color: var(--primary-hover);
}

/* Diferenciais */
.prod-dif-section {
    background: var(--white);
}

.prod-dif-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-top: 3rem;
}

.prod-dif-item {
    text-align: center;
    padding: 2rem 1.5rem;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: var(--gray-light);
    transition: var(--transition);
}

.prod-dif-item:hover {
    background: var(--white);
    box-shadow: var(--shadow-md);
    transform: translateY(-4px);
}

.prod-dif-icon {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, rgba(255,100,25,0.12), rgba(255,100,25,0.05));
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    color: var(--primary);
    margin: 0 auto 1.2rem;
}

.prod-dif-item h4 {
    font-size: 1rem;
    color: var(--dark);
    margin-bottom: 0.5rem;
}

.prod-dif-item p {
    font-size: 0.85rem;
    line-height: 1.6;
    color: var(--gray-dark);
    margin: 0;
}

/* CTA Final */
.prod-cta-section {
    position: relative;
    background: var(--dark);
    padding: 5rem 0;
    text-align: center;
    overflow: hidden;
}

.prod-cta-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,100,25,0.15) 0%, transparent 60%);
}

.prod-cta-content {
    position: relative;
    z-index: 1;
}

.prod-cta-content .section-title {
    margin-bottom: 1rem;
}

.prod-cta-content .section-desc {
    max-width: 520px;
    margin: 0 auto 2rem;
}

.prod-cta-btns {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

.btn-outline-white {
    border: 2px solid rgba(255,255,255,0.4);
    color: var(--white);
    background: transparent;
    border-radius: 50px;
    padding: 0.75rem 1.8rem;
    font-weight: 600;
    font-size: 0.85rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: var(--transition);
}

.btn-outline-white:hover {
    background: rgba(255,255,255,0.1);
    border-color: var(--white);
}

/* ==================== PRODUTOS RESPONSIVE ==================== */
@media (max-width: 992px) {
    .prod-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .prod-dif-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .prod-hero-title {
        font-size: 2rem;
    }
}

@media (max-width: 768px) {
    .prod-grid {
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
    }

    .prod-card {
        flex-direction: column;
        border-radius: 16px;
    }

    .prod-card-img {
        width: 100%;
        height: 400px;
        flex-shrink: 0;
        border-radius: 0;
    }

    .prod-card-img img {
        max-height: 360px;
    }

    .prod-card-body {
        padding: 1rem;
    }

    .prod-dif-grid {
        grid-template-columns: 1fr 1fr;
    }

    .prod-cta-btns {
        flex-direction: column;
        align-items: center;
    }

    .prod-hero-title {
        font-size: 1.7rem;
    }
}

@media (max-width: 480px) {
    .prod-grid {
        grid-template-columns: 1fr;
    }
}

/* ==================== PÁGINA PRODUTO INDIVIDUAL ==================== */

/* Breadcrumb */
.pd-breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8rem;
    color: var(--gray-dark);
    margin-bottom: 2rem;
    flex-wrap: wrap;
}

.pd-breadcrumb a {
    color: var(--gray-dark);
    text-decoration: none;
    transition: color 0.2s;
}

.pd-breadcrumb a:hover { color: var(--primary); }

.pd-breadcrumb i { font-size: 0.7rem; opacity: 0.5; }

.pd-breadcrumb span { color: var(--dark); font-weight: 500; }

/* Hero */
.pd-hero {
    background: var(--gray-light);
    padding: 2.5rem 0 0;
    border-bottom: 1px solid var(--border);
}

.pd-hero-inner { padding-bottom: 0; }

.pd-hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

.pd-img-wrap {
    position: relative;
    background: var(--white);
    border-radius: 24px;
    padding: 3rem 2.5rem;
    border: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 320px;
}

.pd-img-wrap img {
    max-height: 280px;
    max-width: 100%;
    object-fit: contain;
    filter: drop-shadow(0 8px 24px rgba(0,0,0,0.12));
}

.pd-badge-novo {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: var(--primary);
    color: var(--white);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 0.3rem 0.9rem;
    border-radius: 50px;
}

.pd-titulo {
    font-size: 2.2rem;
    line-height: 1.2;
    color: var(--dark);
    margin: 0.8rem 0 0.8rem;
}

.pd-subtexto {
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--gray-dark);
    border-left: 3px solid var(--primary);
    padding-left: 1rem;
    margin: 1rem 0 1.5rem;
}

/* Specs rápidas */
.pd-specs {
    display: flex;
    gap: 1.5rem;
    margin-bottom: 1.2rem;
    flex-wrap: wrap;
}

.pd-spec-item {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.pd-spec-item i {
    font-size: 1.3rem;
    color: var(--primary);
    flex-shrink: 0;
}

.pd-spec-item div {
    display: flex;
    flex-direction: column;
    line-height: 1.3;
}

.pd-spec-item span {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--gray-dark);
}

.pd-spec-item strong {
    font-size: 0.9rem;
    color: var(--dark);
}

/* Certificações hero */
.pd-certs {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-bottom: 1.8rem;
}

.pd-cert {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--primary);
    background: rgba(255,100,25,0.08);
    border-radius: 50px;
    padding: 0.3rem 0.9rem;
}

/* Conteúdo */
.pd-content-section { background: var(--white); }

.pd-content-grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 3rem;
    align-items: start;
}

/* Blocos */
.pd-block {
    margin-bottom: 2.5rem;
    padding-bottom: 2.5rem;
    border-bottom: 1px solid var(--border);
}

.pd-block:last-child { border-bottom: none; }

.pd-block-title {
    font-size: 1.1rem;
    color: var(--dark);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.pd-block-title i { color: var(--primary); font-size: 1.2rem; }

.pd-block p {
    font-size: 0.92rem;
    line-height: 1.75;
    color: var(--gray-dark);
    margin: 0;
}

/* Indicações + Limitações */
.pd-ind-lim {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    margin-bottom: 2.5rem;
    padding-bottom: 2.5rem;
    border-bottom: 1px solid var(--border);
}

.pd-ind, .pd-lim {
    background: var(--gray-light);
    border-radius: 16px;
    padding: 1.5rem;
}

.pd-lim { background: #fff5f2; }

.pd-ind h3, .pd-lim h3 {
    font-size: 0.95rem;
    color: var(--dark);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.pd-ind h3 i { color: #22c55e; }
.pd-lim h3 i { color: #ef4444; }

.pd-ind ul, .pd-lim ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.pd-ind li, .pd-lim li {
    font-size: 0.85rem;
    color: var(--gray-dark);
    padding-left: 1.2rem;
    position: relative;
    line-height: 1.5;
}

.pd-ind li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: #22c55e;
    font-weight: 700;
    font-size: 0.75rem;
}

.pd-lim li::before {
    content: '×';
    position: absolute;
    left: 0;
    color: #ef4444;
    font-weight: 700;
}

/* Dimensional */
.pd-dim-obs {
    font-size: 0.88rem;
    color: var(--gray-dark);
    margin-bottom: 1.2rem;
}

.pd-dim-grid {
    display: flex;
    gap: 1rem;
    margin-bottom: 1rem;
}

.pd-dim-item {
    background: var(--gray-light);
    border-radius: 14px;
    padding: 1.2rem 1.8rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    flex: 1;
    border: 1px solid var(--border);
}

.pd-dim-item i { font-size: 1.5rem; color: var(--primary); }
.pd-dim-item strong { font-size: 0.85rem; color: var(--dark); }
.pd-dim-item span { font-size: 1.1rem; font-weight: 800; color: var(--primary); font-family: var(--font-heading); }

.pd-dim-nota {
    font-size: 0.8rem;
    color: var(--gray-dark);
    background: rgba(255,100,25,0.06);
    border-left: 3px solid var(--primary);
    padding: 0.6rem 0.8rem;
    border-radius: 0 8px 8px 0;
    display: flex;
    align-items: flex-start;
    gap: 0.4rem;
    margin: 0;
}

.pd-dim-nota i { flex-shrink: 0; color: var(--primary); margin-top: 0.1rem; }

/* Sidebar */
.pd-sidebar {
    position: sticky;
    top: 90px;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.pd-sidebar-card {
    background: var(--gray-light);
    border-radius: 16px;
    padding: 1.5rem;
    border: 1px solid var(--border);
}

.pd-sidebar-cert {
    background: var(--dark);
}

.pd-sidebar-cert .pd-sidebar-title,
.pd-sidebar-cert p { color: rgba(255,255,255,0.8); }

.pd-sidebar-title {
    font-size: 0.95rem;
    color: var(--dark);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.pd-sidebar-title i { color: var(--primary); }

.pd-caract-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.pd-caract-list li {
    font-size: 0.85rem;
    color: var(--gray-dark);
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    line-height: 1.5;
}

.pd-caract-list li i { color: var(--primary); flex-shrink: 0; margin-top: 0.1rem; }

.pd-composicao {
    font-size: 0.85rem;
    line-height: 1.65;
    color: var(--gray-dark);
    margin: 0;
}

.pd-cert-tags {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-top: 0.8rem;
}

.pd-cert-tags span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--white);
    background: rgba(255,100,25,0.25);
    border-radius: 50px;
    padding: 0.35rem 0.9rem;
    width: fit-content;
}

.pd-cert-tags span i { color: var(--primary); }

.pd-sidebar-cta {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    text-align: center;
}

.pd-sidebar-cta p {
    font-size: 0.88rem;
    color: var(--gray-dark);
    margin: 0;
}

.pd-back-link {
    font-size: 0.8rem;
    color: var(--gray-dark);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    transition: color 0.2s;
}

.pd-back-link:hover { color: var(--primary); }

/* Produtos relacionados */
.pd-relacionados-section { background: var(--gray-light); }

.pd-rel-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
    margin-top: 2.5rem;
}

.pd-rel-card {
    background: var(--white);
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid var(--border);
    text-decoration: none;
    display: flex;
    flex-direction: column;
    transition: var(--transition);
}

.pd-rel-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.pd-rel-img {
    background: var(--gray-light);
    height: 160px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.2rem;
}

.pd-rel-img img {
    max-height: 120px;
    object-fit: contain;
    transition: transform 0.3s ease;
}

.pd-rel-card:hover .pd-rel-img img { transform: scale(1.06); }

.pd-rel-info {
    padding: 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.pd-rel-cat {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--primary);
}

.pd-rel-info strong {
    font-size: 0.95rem;
    color: var(--dark);
    line-height: 1.3;
}

.pd-rel-link {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--primary);
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-top: 0.3rem;
}

/* ==================== PRODUTO INDIVIDUAL RESPONSIVE ==================== */
@media (max-width: 992px) {
    .pd-hero-grid { grid-template-columns: 1fr; gap: 2rem; }
    .pd-img-wrap { max-width: 400px; margin: 0 auto; }
    .pd-content-grid { grid-template-columns: 1fr; }
    .pd-sidebar { position: static; }
    .pd-rel-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .pd-titulo { font-size: 1.7rem; }
    .pd-ind-lim { grid-template-columns: 1fr; }
    .pd-specs { gap: 1rem; }
    .pd-rel-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 480px) {
    .pd-rel-grid { grid-template-columns: 1fr; }
    .pd-dim-grid { flex-direction: column; }
}

/* ==================== PRODUTO V2 — LANDING PAGE ==================== */

/* Breadcrumb bar */
.pd2-breadcrumb-bar {
    background: var(--white);
    border-bottom: 1px solid var(--border);
    padding: 0.9rem 0;
}

.pd2-breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8rem;
    flex-wrap: wrap;
}

.pd2-breadcrumb a { color: var(--gray-dark); text-decoration: none; transition: color 0.2s; }
.pd2-breadcrumb a:hover { color: var(--primary); }
.pd2-breadcrumb i { font-size: 0.65rem; opacity: 0.4; }
.pd2-breadcrumb span { color: var(--dark); font-weight: 600; }

/* Hero clean */
.pd2-hero {
    background: var(--gray-light);
    border-bottom: 1px solid var(--border);
    padding: 4rem 0;
}

.pd2-hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: center;
}

.pd2-hero-img-wrap {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    min-height: 360px;
}

.pd2-hero-img-wrap img {
    max-height: 420px;
    max-width: 100%;
    object-fit: contain;
    filter: drop-shadow(0 12px 32px rgba(0,0,0,0.18));
}

.pd2-selo-iso {
    position: absolute;
    top: -1rem;
    right: -1rem;
    width: 110px;
    height: 110px;
    object-fit: contain;
    filter: none;
    z-index: 2;
    pointer-events: none;
}

.pd2-selo-iso--esq {
    right: auto;
    left: -1rem;
}

@media (max-width: 768px) {
    .pd2-selo-iso {
        width: 80px;
        height: 80px;
        top: -0.5rem;
        right: -0.5rem;
    }
    .pd2-selo-iso--esq {
        right: auto;
        left: -0.5rem;
    }
}

.pd2-badge-novo {
    position: absolute;
    top: 1.2rem;
    right: 1.2rem;
    background: var(--primary);
    color: var(--white);
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 0.3rem 0.9rem;
    border-radius: 50px;
}

.pd2-titulo {
    font-size: 2.4rem;
    color: var(--dark);
    line-height: 1.15;
    margin: 0.8rem 0 0.8rem;
}

.pd2-subtexto {
    font-size: 0.95rem;
    line-height: 1.75;
    color: var(--gray-dark);
    border-left: 3px solid var(--primary);
    padding-left: 1rem;
    margin: 1rem 0 1.8rem;
}

/* Specs inline no hero */
.pd2-hero-specs {
    display: flex;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.pd2-hspec {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 0.6rem 1rem;
}

.pd2-hspec i {
    font-size: 1.2rem;
    color: var(--primary);
    flex-shrink: 0;
}

.pd2-hspec div {
    display: flex;
    flex-direction: column;
    line-height: 1.25;
}

.pd2-hspec span {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--gray-dark);
}

.pd2-hspec strong {
    font-size: 0.85rem;
    color: var(--dark);
}

/* Certs no hero */
.pd2-hero-certs {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 2rem;
}

.pd2-hero-certs span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--primary);
    background: rgba(255,100,25,0.08);
    border-radius: 50px;
    padding: 0.3rem 0.9rem;
}

.pd2-hero-cta {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.pd2-hero-cta .btn {
    font-size: 0.78rem;
    padding: 0.55rem 1.2rem;
}

.pd2-fichas-downloads {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

.pd2-ficha-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.6rem 1rem;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.85rem;
    transition: all 0.25s;
    border: 2px solid transparent;
}

.pd2-ficha-btn i {
    font-size: 1.4rem;
    flex-shrink: 0;
}

.pd2-ficha-btn span {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
}

.pd2-ficha-btn small {
    font-size: 0.7rem;
    font-weight: 400;
    opacity: 0.75;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.pd2-ficha-btn--tecnica {
    background: rgba(220, 53, 69, 0.12);
    color: #dc3545;
    border-color: rgba(220, 53, 69, 0.3);
}

.pd2-ficha-btn--tecnica:hover {
    background: #dc3545;
    color: #fff;
    border-color: #dc3545;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(220, 53, 69, 0.3);
}

.pd2-ficha-btn--seguranca {
    background: rgba(40, 167, 69, 0.12);
    color: #28a745;
    border-color: rgba(40, 167, 69, 0.3);
}

.pd2-ficha-btn--seguranca:hover {
    background: #28a745;
    color: #fff;
    border-color: #28a745;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(40, 167, 69, 0.3);
}

.pd2-back-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--gray-dark);
    text-decoration: none;
    transition: color 0.2s;
}

.pd2-back-btn:hover { color: var(--primary); }

/* Seções gerais */
.pd2-section { padding: 5rem 0; }

/* O que é */
.pd2-oque-section { background: var(--white); }

.pd2-oque-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: center;
}

.pd2-oque-text p {
    font-size: 1rem;
    line-height: 1.8;
    color: var(--gray-dark);
    margin-top: 1.5rem;
}

.pd2-caract {
    background: var(--gray-light);
    border-radius: 24px;
    padding: 2.5rem;
    border: 1px solid var(--border);
}

.pd2-caract-title {
    font-size: 1rem;
    color: var(--dark);
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.pd2-caract-title i { color: var(--primary); }

.pd2-caract-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.pd2-caract-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
    font-size: 0.9rem;
    color: var(--dark);
    font-weight: 500;
    line-height: 1.5;
}

.pd2-caract-list li i {
    color: var(--primary);
    font-size: 1.1rem;
    flex-shrink: 0;
    margin-top: 0.05rem;
}

/* Indicações + Limitações */
.pd2-indlim-section { background: var(--gray-light); }

.pd2-indlim-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    margin-top: 3rem;
}

.pd2-ind-card, .pd2-lim-card {
    background: var(--white);
    border-radius: 20px;
    padding: 2rem;
    border: 1px solid var(--border);
}

.pd2-lim-card { background: #fff8f7; }

.pd2-card-icon {
    width: 56px;
    height: 56px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    margin-bottom: 1.2rem;
}

.pd2-icon-green { background: rgba(34,197,94,0.1); color: #22c55e; }
.pd2-icon-red   { background: rgba(239,68,68,0.1);  color: #ef4444; }

.pd2-ind-card h3, .pd2-lim-card h3 {
    font-size: 1rem;
    color: var(--dark);
    margin-bottom: 1.2rem;
}

.pd2-ind-card ul, .pd2-lim-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.pd2-ind-card li, .pd2-lim-card li {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 0.88rem;
    color: var(--gray-dark);
    line-height: 1.5;
}

.pd2-ind-card li i { color: #22c55e; flex-shrink: 0; margin-top: 0.15rem; }
.pd2-lim-card li i { color: #ef4444; flex-shrink: 0; margin-top: 0.15rem; }

/* Dimensional inline (dentro do card de indicações) */
.pd2-dim-inline {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border);
}

.pd2-dim-inline-title {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--gray-dark);
    margin-bottom: 1rem;
}

.pd2-dim-inline-title i { color: var(--primary); font-size: 0.95rem; }

.pd2-dim-inline-grid {
    display: flex;
    gap: 0.8rem;
}

.pd2-dim-inline-item {
    flex: 1;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 0.9rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.2rem;
    text-align: center;
}

.pd2-dim-inline-item i {
    font-size: 1.2rem;
    color: var(--primary);
}

.pd2-dim-inline-item span {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--gray-dark);
}

.pd2-dim-inline-item strong {
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--dark);
    font-family: var(--font-heading);
}

.pd2-dim-inline-nota {
    display: flex;
    align-items: flex-start;
    gap: 0.4rem;
    font-size: 0.75rem;
    color: var(--gray-dark);
    background: rgba(255,100,25,0.05);
    border-left: 2px solid var(--primary);
    border-radius: 0 6px 6px 0;
    padding: 0.5rem 0.7rem;
    margin-top: 0.8rem;
}

.pd2-dim-inline-nota i { color: var(--primary); flex-shrink: 0; margin-top: 0.05rem; }

/* Qualidade com foto de fundo */
.pd2-qual-foto-section {
    position: relative;
    padding: 5rem 0;
    overflow: hidden;
}

.pd2-qual-foto-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transform: scale(1.04);
}

.pd2-qual-foto-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(17,17,17,0.82) 0%, rgba(17,17,17,0.70) 100%);
}

.pd2-qual-foto-inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
}

.pd2-qual-foto-card {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
    backdrop-filter: blur(6px);
    border-radius: 20px;
    padding: 2.5rem;
}

.pd2-qual-foto-card--dark {
    background: rgba(255,100,25,0.12);
    border-color: rgba(255,100,25,0.25);
}

.pd2-qual-foto-icon {
    width: 52px;
    height: 52px;
    background: rgba(255,100,25,0.2);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--primary);
    margin-bottom: 1.2rem;
}

.pd2-qual-foto-card h3 {
    font-size: 1.05rem;
    color: var(--white);
    margin-bottom: 0.7rem;
}

.pd2-qual-foto-card p {
    font-size: 0.88rem;
    line-height: 1.7;
    color: rgba(255,255,255,0.68);
    margin: 0;
}

.pd2-qual-foto-badges {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-top: 1.2rem;
}

.pd2-qual-foto-badges span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--white);
    background: rgba(255,100,25,0.3);
    border-radius: 50px;
    padding: 0.35rem 0.9rem;
}

.pd2-qual-foto-badges span i { color: var(--primary); }

/* ==================== VÍDEOS ==================== */
.pd2-video-section {
    background: var(--white);
    padding: 4rem 0;
    border-top: 1px solid var(--border);
}

/* Cabeçalho esquerda (multi) */
.pd2-video-header { margin-bottom: 2rem; }
.pd2-video-header .badge-tag { margin-bottom: 0.5rem; }
.pd2-video-header .section-title { margin: 0 0 0.5rem; }
.pd2-video-desc {
    color: var(--text-muted, #666);
    font-size: 0.95rem;
    margin: 0.5rem 0 0;
    max-width: 560px;
}

/* --- SPLIT (1 vídeo) --- */
.pd2-video-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

.pd2-video-split-text .badge-tag { margin-bottom: 0.75rem; }
.pd2-video-split-text .section-title { margin: 0 0 1rem; }
.pd2-video-split-text .pd2-video-desc { max-width: 100%; margin-bottom: 1.25rem; }

.pd2-video-label {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--primary);
}

/* --- GRID (múltiplos) --- */
.pd2-video-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}

.pd2-video-card {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* --- THUMBNAIL CLICÁVEL --- */
.pd2-video-thumb {
    position: relative;
    aspect-ratio: 16 / 9;
    border-radius: 10px;
    overflow: hidden;
    cursor: pointer;
    background: #111;
    box-shadow: 0 3px 16px rgba(0,0,0,0.13);
}

.pd2-video-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.35s ease, filter 0.35s ease;
    filter: brightness(0.85);
}

.pd2-video-thumb:hover img {
    transform: scale(1.04);
    filter: brightness(0.7);
}

.pd2-video-play-btn {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
}

.pd2-video-play-btn svg {
    color: #fff;
    background: var(--primary);
    border-radius: 50%;
    width: 56px;
    height: 56px;
    padding: 14px;
    box-shadow: 0 4px 20px rgba(255,100,25,0.45);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    flex-shrink: 0;
}

.pd2-video-thumb:hover .pd2-video-play-btn svg {
    transform: scale(1.12);
    box-shadow: 0 6px 28px rgba(255,100,25,0.6);
}

.pd2-video-titulo {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--dark);
    margin: 0;
}

/* --- LIGHTBOX --- */
.pd2-video-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.88);
    z-index: 9999;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
}

.pd2-video-lightbox.active {
    display: flex;
}

.pd2-video-lightbox-inner {
    position: relative;
    width: 100%;
    max-width: 900px;
}

.pd2-video-lightbox-close {
    position: absolute;
    top: -2.5rem;
    right: 0;
    background: none;
    border: none;
    color: #fff;
    font-size: 1.5rem;
    cursor: pointer;
    line-height: 1;
    opacity: 0.8;
    transition: opacity 0.2s;
}

.pd2-video-lightbox-close:hover { opacity: 1; }

.pd2-video-lightbox-frame {
    position: relative;
    aspect-ratio: 16 / 9;
    border-radius: 10px;
    overflow: hidden;
    background: #000;
}

.pd2-video-lightbox-frame iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: none;
}

/* --- RESPONSIVE --- */
@media (max-width: 992px) {
    .pd2-video-split { grid-template-columns: 1fr; gap: 2rem; }
    .pd2-video-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
    .pd2-video-section { padding: 2.5rem 0; }
    .pd2-video-grid { grid-template-columns: 1fr; }
}

/* Relacionados */
.pd2-rel-section { background: var(--gray-light); }

.pd2-rel-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
    margin-top: 2.5rem;
}

.pd2-rel-card {
    background: var(--white);
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid var(--border);
    text-decoration: none;
    display: flex;
    flex-direction: column;
    transition: var(--transition);
}

.pd2-rel-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }

.pd2-rel-img {
    background: var(--gray-light);
    height: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    overflow: hidden;
}

.pd2-rel-img img {
    max-height: 140px;
    object-fit: contain;
    transition: transform 0.3s ease;
}

.pd2-rel-card:hover .pd2-rel-img img { transform: scale(1.07); }

.pd2-rel-body {
    padding: 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.pd2-rel-cat {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--primary);
}

.pd2-rel-body strong { font-size: 0.95rem; color: var(--dark); line-height: 1.3; }

.pd2-rel-link {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--primary);
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-top: 0.3rem;
}

/* ==================== RESPONSIVE PD2 ==================== */
@media (max-width: 992px) {
    .pd2-hero-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .pd2-hero-img-wrap { max-width: 420px; margin: 0 auto; min-height: 280px; }
    .pd2-oque-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .pd2-comp-grid { grid-template-columns: 1fr; gap: 1.5rem; }
    .pd2-rel-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .pd2-hero { padding: 2.5rem 0; }
    .pd2-titulo { font-size: 1.9rem; }
    .pd2-hero-specs { gap: 0.8rem; }
    .pd2-hspec { padding: 0.5rem 0.8rem; }
    .pd2-indlim-grid { grid-template-columns: 1fr; }
    .pd2-dim-cards { flex-direction: column; align-items: center; }
    .pd2-dim-card { min-width: unset; width: 100%; max-width: 300px; padding: 2rem; }
    .pd2-rel-grid { grid-template-columns: 1fr 1fr; }
    .pd2-section { padding: 3.5rem 0; }
    .pd2-qual-foto-inner { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .pd2-rel-grid { grid-template-columns: 1fr; }
    .pd2-titulo { font-size: 1.6rem; }
    .pd2-hero-cta { flex-direction: column; align-items: flex-start; }
    .pd2-hero-specs { flex-direction: column; gap: 0.6rem; }
}

/* ==================== PÁGINA DE CONTATO ==================== */

/* Hero */
.contato-hero {
    position: relative;
    min-height: 260px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.contato-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}

.contato-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, rgba(17,17,17,0.92) 50%, rgba(255,100,25,0.35) 100%);
}

.contato-hero-inner {
    position: relative;
    z-index: 1;
    padding: 2.5rem 0;
    text-align: left;
}

.contato-hero-title {
    font-size: 2.6rem;
    color: var(--white);
    line-height: 1.15;
    margin: 0.8rem 0 0.8rem;
}

.contato-hero-desc {
    font-size: 0.97rem;
    color: rgba(255,255,255,0.7);
    line-height: 1.7;
    max-width: 500px;
}

/* Layout duas colunas */
.contato-section { background: var(--gray-light); }

.contato-layout {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 3rem;
    align-items: start;
}

/* Coluna esquerda */
.contato-info-col {
    position: sticky;
    top: 100px;
}

.contato-info-title {
    font-size: 1.9rem;
    line-height: 1.2;
    color: var(--dark);
    margin: 0.8rem 0 1rem;
}

.contato-info-desc {
    font-size: 0.9rem;
    color: var(--gray-dark);
    line-height: 1.7;
    margin-bottom: 2rem;
}

.contato-cards {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    margin-bottom: 2rem;
}

.contato-card {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 1.1rem 1.2rem;
    transition: var(--transition);
}

.contato-card:hover {
    border-color: var(--primary);
    box-shadow: var(--shadow-sm);
}

.contato-card-icon {
    width: 40px;
    height: 40px;
    background: rgba(255,100,25,0.1);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    color: var(--primary);
    flex-shrink: 0;
}

.contato-card-body {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.contato-card-body strong {
    font-size: 0.85rem;
    color: var(--dark);
    font-family: var(--font-heading);
}

.contato-card-body span {
    font-size: 0.82rem;
    color: var(--gray-dark);
}

.contato-social {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.contato-social span {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--gray-dark);
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.contato-social-links {
    display: flex;
    gap: 0.5rem;
}

.contato-social-links a {
    width: 36px;
    height: 36px;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: var(--dark);
    transition: var(--transition);
}

.contato-social-links a:hover {
    background: var(--primary);
    border-color: var(--primary);
    color: var(--white);
}

/* Coluna direita — form card */
.contato-form-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 24px;
    box-shadow: var(--shadow-md);
    overflow: hidden;
}

.contato-form-header {
    background: var(--dark);
    padding: 1.8rem 2rem;
}

.contato-form-header h3 {
    font-size: 1.2rem;
    color: var(--white);
    margin-bottom: 0.25rem;
}

.contato-form-header p {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.55);
}

/* Feedback */
.contato-feedback {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
    margin: 1.5rem 2rem 0;
    padding: 1rem 1.2rem;
    border-radius: 12px;
    font-size: 0.85rem;
}

.contato-feedback i { font-size: 1.4rem; flex-shrink: 0; margin-top: 0.1rem; }

.contato-feedback div { display: flex; flex-direction: column; gap: 0.15rem; }
.contato-feedback strong { font-size: 0.9rem; }
.contato-feedback span { color: var(--gray-dark); }

.contato-feedback--ok {
    background: rgba(34,197,94,0.08);
    border: 1px solid rgba(34,197,94,0.25);
    color: #166534;
}
.contato-feedback--ok i { color: #22c55e; }

.contato-feedback--err {
    background: rgba(239,68,68,0.07);
    border: 1px solid rgba(239,68,68,0.2);
    color: #991b1b;
}
.contato-feedback--err i { color: #ef4444; }

/* Form */
.contato-form {
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.contato-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.contato-field {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.contato-field label {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--dark);
}

.contato-field label span { color: var(--primary); }

.contato-field input,
.contato-field select,
.contato-field textarea {
    background: var(--gray-light);
    border: 1.5px solid var(--border);
    border-radius: 10px;
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
    color: var(--dark);
    font-family: var(--font-sans);
    outline: none;
    transition: border-color 0.2s;
    width: 100%;
}

.contato-field input:focus,
.contato-field select:focus,
.contato-field textarea:focus {
    border-color: var(--primary);
    background: var(--white);
}

.contato-field textarea { resize: vertical; min-height: 130px; }

.contato-btn-submit {
    width: 100%;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

/* Mapa */
.contato-mapa {
    width: 100%;
    line-height: 0;
    filter: grayscale(20%);
}

/* Responsive */
@media (max-width: 768px) {
    .contato-layout { grid-template-columns: 1fr; gap: 2rem; }
    .contato-info-col { position: static; }
    .contato-hero-title { font-size: 1.9rem; }
    .contato-form-row { grid-template-columns: 1fr; }
    .contato-form { padding: 1.5rem; }
    .contato-form-header { padding: 1.4rem 1.5rem; }
}

/* Submenu nav */
.nav-item--has-sub { position: relative; }

.nav-link--has-sub { display: flex; align-items: center; gap: 0.3rem; }

.nav-caret {
    font-size: 0.7rem;
    transition: transform 0.2s;
}

.nav-submenu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 0 0 12px 12px;
    box-shadow: var(--shadow-md);
    min-width: 220px;
    padding: 0.5rem 0.5rem 0.5rem;
    padding-top: 0.8rem;
    z-index: 200;
    list-style: none;
}

.nav-item--has-sub:hover .nav-submenu,
.nav-item--has-sub.open .nav-submenu { display: block; }
.nav-item--has-sub:hover .nav-caret,
.nav-item--has-sub.open .nav-caret { transform: rotate(180deg); }

.nav-submenu li a {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.7rem 1rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--dark);
    text-decoration: none;
    border-radius: 8px;
    transition: all 0.15s;
}

.nav-submenu li a:hover {
    background: rgba(255,100,25,0.07);
    color: var(--primary);
}

.nav-submenu li a i { color: var(--primary); font-size: 1rem; }

/* ==================== CALCULADORA DE REJUNTE ==================== */

/* Hero com foto */
.calc-hero {
    position: relative;
    min-height: 260px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.calc-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transform: scale(1.03);
}

.calc-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, rgba(17,17,17,0.92) 50%, rgba(255,100,25,0.35) 100%);
}

.calc-hero-inner {
    position: relative;
    z-index: 1;
    padding: 2.5rem 0;
    width: 100%;
    text-align: left;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.calc-hero-inner .calc-hero-title,
.calc-hero-inner .calc-hero-desc,
.calc-hero-inner .calc-hero-stats,
.calc-hero-inner .badge-tag {
    max-width: 600px;
}

.calc-hero-title {
    font-size: 2.6rem;
    color: var(--white);
    line-height: 1.15;
    margin: 0.8rem 0 1rem;
}

.calc-hero-desc {
    font-size: 0.97rem;
    color: rgba(255,255,255,0.7);
    line-height: 1.7;
    margin-bottom: 2rem;
}

.calc-hero-stats {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.calc-hero-stat {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: rgba(255,255,255,0.8);
}

.calc-hero-stat i { color: var(--primary); font-size: 1rem; }

/* Seção principal */
.calc-section { background: var(--gray-light); }

.calc-layout {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 3rem;
    align-items: start;
}

/* Coluna esquerda — informações */
.calc-info-col {
    position: sticky;
    top: 100px;
}

.calc-info-title {
    font-size: 2rem;
    line-height: 1.2;
    color: var(--dark);
    margin: 0.8rem 0 1rem;
}

.calc-info-desc {
    font-size: 0.92rem;
    color: var(--gray-dark);
    line-height: 1.7;
    margin-bottom: 2rem;
}

.calc-info-items {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    margin-bottom: 2rem;
}

.calc-info-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.calc-info-icon {
    width: 40px;
    height: 40px;
    background: rgba(255,100,25,0.1);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    color: var(--primary);
    flex-shrink: 0;
}

.calc-info-item div {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.calc-info-item strong {
    font-size: 0.9rem;
    color: var(--dark);
}

.calc-info-item span {
    font-size: 0.8rem;
    color: var(--gray-dark);
    line-height: 1.5;
}

.calc-info-nota {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.8rem;
    color: var(--gray-dark);
    background: rgba(255,100,25,0.05);
    border-left: 3px solid var(--primary);
    border-radius: 0 10px 10px 0;
    padding: 0.8rem 1rem;
}

.calc-info-nota i { color: var(--primary); flex-shrink: 0; margin-top: 0.1rem; }

/* Coluna direita — form */
.calc-form-col { width: 100%; }

.calc-card {
    background: var(--white);
    border-radius: 24px;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-md);
    overflow: hidden;
}

/* Steps indicator */
.calc-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 2rem 0;
    gap: 0;
}

.calc-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    opacity: 0.4;
    transition: opacity 0.3s;
}

.calc-step.active { opacity: 1; }

.calc-step-num {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--gray-light);
    border: 2px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--gray-dark);
    transition: all 0.3s;
}

.calc-step.active .calc-step-num {
    background: var(--primary);
    border-color: var(--primary);
    color: var(--white);
}

.calc-step.done .calc-step-num {
    background: rgba(255,100,25,0.12);
    border-color: var(--primary);
    color: var(--primary);
}

.calc-step span {
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--gray-dark);
}

.calc-step.active span { color: var(--primary); }

.calc-step-line {
    flex: 1;
    height: 2px;
    background: var(--border);
    margin-bottom: 1rem;
    min-width: 40px;
    max-width: 80px;
}

/* Panels */
.calc-step-panel {
    display: none;
    padding: 2.5rem 3rem 3rem;
    text-align: center;
    animation: fadeInUp 0.3s ease;
}

.calc-step-panel.active { display: block; }

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

.calc-step-icon {
    width: 64px;
    height: 64px;
    background: rgba(255,100,25,0.08);
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: var(--primary);
    margin: 0 auto 1.5rem;
}

.calc-step-title {
    font-size: 1.5rem;
    color: var(--dark);
    margin-bottom: 0.5rem;
}

.calc-step-desc {
    font-size: 0.9rem;
    color: var(--gray-dark);
    margin-bottom: 2rem;
}

/* Inputs */
.calc-input-wrap {
    display: flex;
    align-items: center;
    background: var(--gray-light);
    border: 2px solid var(--border);
    border-radius: 14px;
    overflow: hidden;
    max-width: 280px;
    margin: 0 auto;
    transition: border-color 0.2s;
}

.calc-input-wrap:focus-within { border-color: var(--primary); }

.calc-input {
    border: none;
    background: none;
    outline: none;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--dark);
    font-family: var(--font-heading);
    padding: 0.9rem 1rem;
    width: 100%;
    text-align: center;
}

.calc-input--error { border-color: #ef4444 !important; animation: shake 0.3s ease; }

@keyframes shake {
    0%,100% { transform: translateX(0); }
    25%      { transform: translateX(-6px); }
    75%      { transform: translateX(6px); }
}

.calc-input-unit {
    padding: 0 1rem;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--primary);
    border-left: 1px solid var(--border);
    background: rgba(255,100,25,0.05);
    white-space: nowrap;
    height: 100%;
    display: flex;
    align-items: center;
}

/* Dims grid */
.calc-dims-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.calc-input-group label {
    display: block;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--gray-dark);
    margin-bottom: 0.5rem;
}

.calc-dims-grid .calc-input-wrap { max-width: 100%; margin: 0; }
.calc-dims-grid .calc-input { font-size: 1.1rem; padding: 0.7rem 0.5rem; }

/* Presets */
.calc-preset-label {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--gray-dark);
    margin-bottom: 0.7rem;
}

.calc-presets {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 2rem;
}

.calc-preset {
    background: var(--gray-light);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 0.45rem 0.9rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--dark);
    cursor: pointer;
    transition: all 0.2s;
}

.calc-preset:hover, .calc-preset.active {
    background: var(--primary);
    border-color: var(--primary);
    color: var(--white);
}

/* Junta options */
.calc-junta-options {
    display: flex;
    gap: 0.8rem;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}

.calc-junta-opt {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.2rem;
    border: 2px solid var(--border);
    border-radius: 16px;
    background: var(--gray-light);
    cursor: pointer;
    transition: all 0.2s;
    min-width: 90px;
}

.calc-junta-opt:hover, .calc-junta-opt.selected {
    border-color: var(--primary);
    background: rgba(255,100,25,0.06);
}

.calc-junta-visual {
    display: flex;
    gap: 3px;
    align-items: flex-end;
}

.calc-junta-visual::before,
.calc-junta-visual::after {
    content: '';
    width: 18px;
    height: 18px;
    background: var(--dark);
    border-radius: 3px;
    opacity: 0.15;
}

.calc-junta-opt.selected .calc-junta-visual::before,
.calc-junta-opt.selected .calc-junta-visual::after { opacity: 0.35; }

.calc-junta-opt strong {
    font-size: 1rem;
    color: var(--dark);
}

.calc-junta-opt span {
    font-size: 0.7rem;
    color: var(--gray-dark);
    white-space: nowrap;
}

.calc-junta-custom {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    font-size: 0.82rem;
    color: var(--gray-dark);
    margin-bottom: 2rem;
}

.calc-junta-custom .calc-input-wrap { margin: 0; }
.calc-junta-custom .calc-input { font-size: 1rem; padding: 0.5rem 0.5rem; }

/* Nav */
.calc-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 2rem;
}

/* Resultado */
.calc-result-wrap {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

/* Chips de parâmetros */
.calc-params {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.calc-param-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: var(--gray-light);
    border: 1px solid var(--border);
    border-radius: 50px;
    padding: 0.35rem 0.9rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--dark);
}

.calc-param-chip i { color: var(--primary); font-size: 0.85rem; }

/* Big numbers */
.calc-bignums {
    display: grid;
    grid-template-columns: 1fr 1.3fr 1fr;
    gap: 0.8rem;
}

.calc-bignum {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    background: var(--gray-light);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 1.4rem 1rem;
    gap: 0.4rem;
}

.calc-bignum--main {
    background: var(--primary);
    border-color: var(--primary);
    transform: scale(1.04);
    box-shadow: 0 8px 24px rgba(255,100,25,0.25);
}

.calc-bignum-val {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--dark);
    font-family: var(--font-heading);
    line-height: 1;
}

.calc-bignum--main .calc-bignum-val { color: var(--white); font-size: 1.8rem; }

.calc-bignum-label {
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--gray-dark);
}

.calc-bignum--main .calc-bignum-label { color: rgba(255,255,255,0.8); }

.calc-result-nota {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.8rem;
    color: var(--gray-dark);
    background: rgba(255,100,25,0.05);
    border-left: 3px solid var(--primary);
    border-radius: 0 10px 10px 0;
    padding: 0.8rem 1rem;
}

.calc-result-nota i { color: var(--primary); flex-shrink: 0; margin-top: 0.1rem; }

/* Produtos recomendados */
.calc-result-produtos {
    border-top: 1px solid var(--border);
    padding-top: 1.5rem;
    text-align: left;
}

.calc-result-produtos h3 {
    font-size: 0.9rem;
    color: var(--dark);
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.calc-prod-list {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.calc-prod-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.8rem 1rem;
    border: 1px solid var(--border);
    border-radius: 12px;
    text-decoration: none;
    transition: all 0.2s;
    background: var(--white);
}

.calc-prod-item:hover {
    border-color: var(--primary);
    background: rgba(255,100,25,0.04);
    transform: translateX(4px);
}

.calc-prod-item img {
    width: 48px;
    height: 48px;
    object-fit: contain;
}

.calc-prod-item div {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.calc-prod-item strong { font-size: 0.88rem; color: var(--dark); }
.calc-prod-item span   { font-size: 0.75rem; color: var(--gray-dark); }
.calc-prod-item > i    { color: var(--primary); font-size: 1.1rem; flex-shrink: 0; }

/* Responsive */
@media (max-width: 768px) {
    .calc-hero-inner { padding: 3.5rem 0 2.5rem; }
    .calc-hero-title { font-size: 1.9rem; }
    .calc-layout { grid-template-columns: 1fr; gap: 2rem; }
    .calc-info-col { position: static; }
    .calc-step-panel { padding: 2rem 1.5rem; }
    .calc-dims-grid { grid-template-columns: 1fr; }
    .calc-junta-options { gap: 0.5rem; }
    .calc-junta-opt { min-width: 75px; padding: 0.8rem 0.8rem; }
    .calc-bignums { grid-template-columns: 1fr; }
    .calc-bignum--main { transform: none; }
    .calc-steps { gap: 0; }
    .calc-step-line { min-width: 20px; }
}

@media (max-width: 480px) {
    .calc-junta-options { justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; padding-bottom: 0.5rem; }
    .calc-nav { flex-direction: column; }
    .calc-nav .btn { width: 100%; justify-content: center; }
}

/* ==================== TABS PARA CALCULADORAS ==================== */
.calc-tabs {
    display: flex;
    gap: 0.5rem;
    padding: 1.5rem 2rem 0;
    border-bottom: 1px solid var(--border);
}

.calc-tab {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.8rem 1.2rem;
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--gray-dark);
    cursor: pointer;
    transition: all 0.2s;
}

.calc-tab:hover {
    color: var(--primary);
    background: rgba(255,100,25,0.05);
}

.calc-tab.active {
    color: var(--primary);
    border-bottom-color: var(--primary);
}

.calc-tab i {
    font-size: 1.1rem;
}

/* Container das calculadoras */
.calc-type-container {
    display: none;
}

.calc-type-container.active {
    display: block;
}

/* ==================== OPÇÕES DE ARGAMASSA ==================== */
.calc-argamassa-options {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.8rem;
    margin-bottom: 1.5rem;
}

.calc-argamassa-opt {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    padding: 1rem 0.8rem;
    border: 2px solid var(--border);
    border-radius: 12px;
    background: var(--white);
    cursor: pointer;
    transition: all 0.2s;
}

.calc-argamassa-opt:hover {
    border-color: var(--primary);
    background: rgba(255,100,25,0.04);
}

.calc-argamassa-opt.selected {
    border-color: var(--primary);
    background: rgba(255,100,25,0.08);
}

.calc-argamassa-img {
    width: 60px;
    height: 60px;
    object-fit: contain;
    margin-bottom: 0.5rem;
    border-radius: 8px;
}

.calc-argamassa-opt strong {
    font-size: 0.85rem;
    color: var(--dark);
}

.calc-argamassa-opt span {
    font-size: 0.7rem;
    color: var(--gray-dark);
}

.calc-argamassa-opt small {
    font-size: 0.65rem;
    color: var(--gray);
    margin-top: 0.2rem;
}

/* ==================== OPÇÕES DE ESPESSURA ==================== */
.calc-espessura-options {
    display: flex;
    gap: 0.8rem;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}

.calc-espessura-opt {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.2rem;
    border: 2px solid var(--border);
    border-radius: 12px;
    background: var(--white);
    cursor: pointer;
    transition: all 0.2s;
    min-width: 90px;
}

.calc-espessura-opt:hover {
    border-color: var(--primary);
    background: rgba(255,100,25,0.04);
}

.calc-espessura-opt.selected {
    border-color: var(--primary);
    background: rgba(255,100,25,0.08);
}

.calc-espessura-visual {
    width: 32px;
    background: var(--dark);
    border-radius: 2px;
}

.calc-espessura-opt strong {
    font-size: 0.9rem;
    color: var(--dark);
}

.calc-espessura-opt span {
    font-size: 0.7rem;
    color: var(--gray-dark);
}

.calc-espessura-custom {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 2rem;
}

.calc-espessura-custom span {
    font-size: 0.8rem;
    color: var(--gray-dark);
}

/* Responsive para argamassa */
@media (max-width: 768px) {
    .calc-tabs {
        padding: 1rem 1rem 0;
    }
    .calc-tab {
        padding: 0.6rem 0.8rem;
        font-size: 0.8rem;
    }
    .calc-argamassa-options {
        grid-template-columns: repeat(2, 1fr);
    }
    .calc-espessura-options {
        gap: 0.5rem;
    }
    .calc-espessura-opt {
        min-width: 75px;
        padding: 0.8rem;
    }
}

@media (max-width: 480px) {
    .calc-argamassa-options {
        grid-template-columns: 1fr;
    }
    .calc-espessura-options {
        justify-content: flex-start;
        overflow-x: auto;
        flex-wrap: nowrap;
        padding-bottom: 0.5rem;
    }
    .calc-espessura-custom {
        flex-direction: column;
        gap: 0.5rem;
    }
}

/* ==================== PÁGINA SEJA REPRESENTANTE ==================== */

/* Hero - Texto alinhado à esquerda */
.rep-hero {
    position: relative;
    min-height: 380px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.rep-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: brightness(0.6);
    transform: scale(1.03);
}

.rep-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(17,17,17,0.95) 40%, rgba(17,17,17,0.7) 70%, rgba(255,100,25,0.2) 100%);
}

.rep-hero-inner {
    position: relative;
    z-index: 1;
    padding: 4rem 0;
    width: 100%;
}

.rep-hero-content {
    max-width: 650px;
    text-align: left;
}

.rep-hero-title {
    font-size: 3rem;
    color: var(--white);
    line-height: 1.1;
    margin: 1rem 0;
}

.rep-hero-desc {
    font-size: 1.1rem;
    color: rgba(255,255,255,0.85);
    line-height: 1.6;
    max-width: 500px;
}

/* Seções divididas (texto + foto) */
.rep-section-split {
    padding: 6rem 0;
    overflow: hidden;
}

.rep-split-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: center;
}

.rep-split-reverse {
    direction: rtl;
}

.rep-split-reverse > * {
    direction: ltr;
}

.rep-split-text {
    opacity: 0;
    transform: translateX(-30px);
    animation: repSlideInLeft 0.8s ease forwards;
}

.rep-split-reverse .rep-split-text {
    transform: translateX(30px);
    animation: repSlideInRight 0.8s ease forwards;
}

@keyframes repSlideInLeft {
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes repSlideInRight {
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.rep-split-text .section-title {
    font-size: 2.4rem;
    line-height: 1.2;
    margin: 0.8rem 0 1.2rem;
}

.rep-split-text .section-desc {
    font-size: 1.05rem;
    color: var(--gray-dark);
    line-height: 1.8;
    margin-bottom: 2.5rem;
}

.rep-split-image {
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 25px 60px rgba(0,0,0,0.12);
    opacity: 0;
    position: relative;
    transform: translateX(30px);
    animation: repImageSlide 1s ease 0.2s forwards;
    aspect-ratio: 4/5;
    width: 100%;
    height: 100%;
}

.rep-split-reverse .rep-split-image {
    transform: translateX(-30px);
    animation: repImageSlideLeft 1s ease 0.2s forwards;
}

.rep-split-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.rep-image-zoom img {
    transform: scale(1.4) !important;
    object-position: center top !important;
}

.rep-split-image:hover {
    box-shadow: 0 30px 70px rgba(255,100,25,0.15);
}

.rep-split-image:hover img {
    transform: scale(1.05);
}

.rep-image-zoom:hover img {
    transform: scale(1.45) !important;
}

/* Lista de benefícios na seção split */
.rep-beneficios-lista {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.rep-beneficio-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem;
    border-radius: 12px;
    background: transparent;
    transition: all 0.3s ease;
    opacity: 0;
    transform: translateX(-20px);
    animation: repItemIn 0.5s ease forwards;
}

.rep-beneficio-item:nth-child(1) { animation-delay: 0.3s; }
.rep-beneficio-item:nth-child(2) { animation-delay: 0.4s; }
.rep-beneficio-item:nth-child(3) { animation-delay: 0.5s; }
.rep-beneficio-item:nth-child(4) { animation-delay: 0.6s; }

@keyframes repItemIn {
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.rep-beneficio-item:hover {
    background: var(--white);
    box-shadow: 0 4px 20px rgba(0,0,0,0.08);
    transform: translateX(5px);
}

.rep-beneficio-item i {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: rgba(255,100,25,0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    color: var(--primary);
    flex-shrink: 0;
    transition: all 0.3s ease;
}

.rep-beneficio-item:hover i {
    background: var(--primary);
    color: var(--white);
    transform: scale(1.1);
}

.rep-beneficio-item strong {
    display: block;
    font-size: 1.05rem;
    color: var(--dark);
    margin-bottom: 0.3rem;
    transition: color 0.3s ease;
}

.rep-beneficio-item:hover strong {
    color: var(--primary);
}

.rep-beneficio-item span {
    font-size: 0.9rem;
    color: var(--gray-dark);
}

/* Estatísticas inline na seção 3 */
.rep-stats-inline {
    display: flex;
    gap: 3rem;
    margin-top: 2.5rem;
    padding-top: 2rem;
    border-top: 2px solid var(--border);
}

.rep-stat-inline {
    display: flex;
    flex-direction: column;
    opacity: 0;
    transform: translateY(20px);
    animation: repStatIn 0.6s ease forwards;
}

.rep-stat-inline:nth-child(1) { animation-delay: 0.4s; }
.rep-stat-inline:nth-child(2) { animation-delay: 0.5s; }
.rep-stat-inline:nth-child(3) { animation-delay: 0.6s; }

@keyframes repStatIn {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.rep-stat-inline .rep-stat-num {
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--primary);
    font-family: var(--font-heading);
    line-height: 1;
    transition: transform 0.3s ease;
}

.rep-stat-inline:hover .rep-stat-num {
    transform: scale(1.1);
}

.rep-stat-inline .rep-stat-label {
    font-size: 0.85rem;
    color: var(--gray-dark);
    margin-top: 0.4rem;
    font-weight: 500;
}

/* Formulário */
.rep-form-section { background: var(--gray-light); }

.rep-form-layout {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 3rem;
}

.rep-info-col {
    position: sticky;
    top: 100px;
    height: fit-content;
}

.rep-info-title {
    font-size: 2rem;
    line-height: 1.2;
    color: var(--dark);
    margin: 0.8rem 0 1rem;
}

.rep-info-desc {
    font-size: 0.95rem;
    color: var(--gray-dark);
    line-height: 1.7;
    margin-bottom: 1.5rem;
}

.rep-info-cards {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 2rem;
}

.rep-info-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: var(--white);
    border-radius: 12px;
    border: 1px solid var(--border);
}

.rep-info-card i {
    font-size: 1.4rem;
    color: var(--primary);
}

.rep-info-card strong {
    display: block;
    font-size: 0.85rem;
    color: var(--dark);
}

.rep-info-card span {
    font-size: 0.8rem;
    color: var(--gray-dark);
}

.rep-faq h4 {
    font-size: 1rem;
    color: var(--dark);
    margin-bottom: 1rem;
}

.rep-faq-item {
    padding: 0.8rem 0;
    border-bottom: 1px solid var(--border);
}

.rep-faq-item strong {
    display: block;
    font-size: 0.85rem;
    color: var(--dark);
    margin-bottom: 0.3rem;
}

.rep-faq-item span {
    font-size: 0.8rem;
    color: var(--gray-dark);
}

/* Formulário */
.rep-form-col {
    background: var(--white);
    border-radius: 24px;
    border: 1px solid var(--border);
    padding: 2.5rem;
    box-shadow: 0 4px 20px rgba(0,0,0,0.04);
}

.rep-form-group {
    margin-bottom: 1.2rem;
}

.rep-form-group label {
    display: block;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    color: var(--gray-dark);
    margin-bottom: 0.4rem;
}

.rep-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.rep-form-input,
.rep-form-select,
.rep-form-textarea {
    width: 100%;
    padding: 0.9rem 1rem;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--gray-light);
    font-size: 0.95rem;
    color: var(--dark);
    transition: all 0.2s;
}

.rep-form-input:focus,
.rep-form-select:focus,
.rep-form-textarea:focus {
    outline: none;
    border-color: var(--primary);
    background: var(--white);
}

.rep-form-select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    padding-right: 2.5rem;
}

.rep-form-textarea {
    resize: vertical;
    min-height: 100px;
}

.btn-full {
    width: 100%;
    justify-content: center;
    padding: 1rem;
    font-size: 1rem;
}

.rep-form-note {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.75rem;
    color: var(--gray-dark);
    margin-top: 1rem;
}

.rep-form-note i {
    color: var(--primary);
    flex-shrink: 0;
}

/* Estatísticas */
.rep-stats-section {
    background: var(--dark);
    padding: 3rem 0;
}

.rep-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    text-align: center;
}

.rep-stat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
}

.rep-stat-num {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--primary);
    font-family: var(--font-heading);
}

.rep-stat-label {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.7);
}

/* Responsive */
@media (max-width: 768px) {
    .rep-hero-title { font-size: 2.2rem; }
    .rep-hero-content { max-width: 100%; }
    .rep-split-layout {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    .rep-split-reverse {
        direction: ltr;
    }
    .rep-split-image {
        order: -1;
        max-height: 300px;
    }
    .rep-split-text .section-title {
        font-size: 1.8rem;
    }
    .rep-stats-inline {
        flex-wrap: wrap;
        gap: 1.5rem;
    }
    .rep-beneficio-item i {
        width: 40px;
        height: 40px;
        font-size: 1.2rem;
    }
    .rep-form-layout { grid-template-columns: 1fr; }
    .rep-info-col { position: static; }
    .rep-form-row { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .rep-hero-title { font-size: 1.8rem; }
    .rep-split-image { max-height: 250px; }
    .rep-beneficio-item { gap: 0.8rem; }
    .rep-beneficio-item i {
        width: 36px;
        height: 36px;
        font-size: 1rem;
    }
    .rep-stats-inline {
        gap: 1.5rem;
    }
    .rep-stat-inline .rep-stat-num {
        font-size: 1.5rem;
    }
    .rep-form-col { padding: 1.5rem; }
}

/* ==================== PÁGINA CERTIFICAÇÕES ==================== */

/* Hero */
.cert-hero {
    position: relative;
    min-height: 380px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.cert-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: brightness(0.6);
    transform: scale(1.03);
}

.cert-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(17,17,17,0.95) 40%, rgba(17,17,17,0.7) 70%, rgba(255,100,25,0.2) 100%);
}

.cert-hero-inner {
    position: relative;
    z-index: 1;
    padding: 4rem 0;
    width: 100%;
}

.cert-hero-content {
    max-width: 650px;
    text-align: left;
}

.cert-hero-title {
    font-size: 3rem;
    color: var(--white);
    line-height: 1.1;
    margin: 1rem 0;
}

.cert-hero-desc {
    font-size: 1.1rem;
    color: rgba(255,255,255,0.85);
    line-height: 1.6;
    max-width: 500px;
}

/* Seções divididas */
.cert-section-split {
    padding: 6rem 0;
    overflow: hidden;
}

.cert-split-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: center;
}

.cert-split-text {
    opacity: 0;
    transform: translateX(-30px);
    animation: repSlideInLeft 0.8s ease forwards;
}

.cert-section-split:nth-child(even) .cert-split-text {
    transform: translateX(30px);
    animation: repSlideInRight 0.8s ease forwards;
}

.cert-split-text .section-title {
    font-size: 2.4rem;
    line-height: 1.2;
    margin: 0.8rem 0 1.2rem;
}

.cert-split-text .section-desc {
    font-size: 1.05rem;
    color: var(--gray-dark);
    line-height: 1.8;
    margin-bottom: 2.5rem;
}

.cert-split-image {
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 25px 60px rgba(0,0,0,0.12);
    position: relative;
    opacity: 0;
    transform: translateX(30px);
    animation: repImageSlide 1s ease 0.2s forwards;
    aspect-ratio: 4/5;
    width: 100%;
    height: 100%;
}

.cert-section-split:nth-child(even) .cert-split-image {
    transform: translateX(-30px);
    animation: repImageSlideLeft 1s ease 0.2s forwards;
}

@keyframes repImageSlide {
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes repImageSlideLeft {
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.cert-split-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.cert-image-zoom img {
    transform: scale(1.4) !important;
    object-position: center top !important;
}

.cert-split-image:hover {
    box-shadow: 0 30px 70px rgba(255,100,25,0.15);
}

.cert-split-image:hover img {
    transform: scale(1.05);
}

.cert-image-zoom:hover img {
    transform: scale(1.45) !important;
}

.cert-image-caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1rem 1.5rem;
    background: linear-gradient(to top, rgba(17,17,17,0.8), transparent);
}

.cert-image-caption span {
    color: var(--white);
    font-size: 0.9rem;
    font-weight: 500;
}

/* Features lista (ISO) */
.cert-features-lista {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 2rem;
}

.cert-feature-item {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
}

.cert-feature-item i {
    font-size: 1.5rem;
    color: var(--primary);
    flex-shrink: 0;
    margin-top: 0.1rem;
}

.cert-feature-item strong {
    display: block;
    font-size: 1rem;
    color: var(--dark);
    margin-bottom: 0.2rem;
}

.cert-feature-item span {
    font-size: 0.9rem;
    color: var(--gray-dark);
}

/* ISO Badge */
.cert-iso-badge {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.2rem;
    background: rgba(255,100,25,0.08);
    border: 1px solid rgba(255,100,25,0.2);
    border-radius: 12px;
    border-left: 4px solid var(--primary);
}

.cert-iso-icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--primary);
    display: flex;
    align-items: center;
    justify-content: center;
}

.cert-iso-icon i {
    font-size: 1.5rem;
    color: var(--white);
}

.cert-iso-info strong {
    display: block;
    font-size: 1rem;
    color: var(--dark);
}

.cert-iso-info span {
    font-size: 0.85rem;
    color: var(--gray-dark);
}

/* Botão download certificado */
.cert-download-btn {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
    margin-top: 1rem;
    background: var(--white);
    border: 1.5px solid #e0e0e0;
    border-radius: 12px;
    text-decoration: none;
    color: var(--dark);
    transition: border-color .2s, box-shadow .2s, transform .2s;
    cursor: pointer;
}
.cert-download-btn:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 18px rgba(255,100,25,.12);
    transform: translateY(-2px);
    color: var(--dark);
}
.cert-download-btn > .ph-file-pdf {
    font-size: 2rem;
    color: #dc2626;
    flex-shrink: 0;
}
.cert-download-btn > div {
    flex: 1;
}
.cert-download-btn > div strong {
    display: block;
    font-size: .95rem;
    color: var(--dark);
}
.cert-download-btn > div span {
    font-size: .8rem;
    color: var(--gray-dark);
}
.cert-download-arrow {
    font-size: 1.3rem;
    color: var(--primary);
    flex-shrink: 0;
}

/* Normas ABNT cards */
.cert-normas-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-top: 1.5rem;
}

.cert-norma-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 1.5rem 1.2rem;
    text-align: center;
    transition: all 0.3s ease;
}

.cert-norma-card:hover {
    border-color: var(--primary);
    box-shadow: 0 8px 24px rgba(255,100,25,0.1);
    transform: translateY(-4px);
    background: var(--white);
}

.cert-norma-card i {
    font-size: 1.8rem;
    color: var(--primary);
    margin-bottom: 0.8rem;
}

.cert-norma-card strong {
    display: block;
    font-size: 1rem;
    color: var(--dark);
    margin-bottom: 0.3rem;
}

.cert-norma-card span {
    font-size: 0.8rem;
    color: var(--gray-dark);
    line-height: 1.4;
}

/* Processos (Nova Seção sem foto) */
.cert-section-processos {
    padding: 6rem 0;
    background: transparent;
}

.cert-section-processos .section-header {
    margin-bottom: 4rem;
}

.cert-processos-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
}

.cert-processo-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 2.5rem 1.5rem;
    text-align: center;
    position: relative;
    transition: all 0.3s ease;
}

.cert-processo-card:hover {
    transform: translateY(-8px);
    border-color: var(--primary);
    box-shadow: 0 15px 35px rgba(255,100,25,0.1);
}

.cert-processo-card .cert-processo-num {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: rgba(255,100,25,0.1);
    color: var(--primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    font-weight: 800;
    margin: 0 auto 1.5rem;
    transition: all 0.3s ease;
}

.cert-processo-card:hover .cert-processo-num {
    background: var(--primary);
    color: var(--white);
    transform: scale(1.1);
}

.cert-processo-card strong {
    display: block;
    font-size: 1.1rem;
    color: var(--dark);
    margin-bottom: 0.8rem;
}

.cert-processo-card span {
    font-size: 0.95rem;
    color: var(--gray-dark);
    line-height: 1.6;
}

/* Estatísticas */
.cert-stats-section {
    background: var(--dark);
    padding: 3rem 0;
}

.cert-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    text-align: center;
}

.cert-stat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
}

.cert-stat-num {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--primary);
    font-family: var(--font-heading);
}

.cert-stat-label {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.7);
}

/* CTA Section */
.cert-cta-section {
    background: var(--gray-light);
    padding: 4rem 0;
}

.cert-cta-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    background: var(--white);
    border-radius: 20px;
    padding: 2.5rem 3rem;
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
}

.cert-cta-text h2 {
    font-size: 1.6rem;
    color: var(--dark);
    margin-bottom: 0.5rem;
}

.cert-cta-text p {
    font-size: 1rem;
    color: var(--gray-dark);
}

/* Responsive */
@media (max-width: 992px) {
    .cert-processos-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .cert-hero-title { font-size: 2.2rem; }
    .cert-hero .container {
        padding-left: 24px;
        padding-right: 24px;
    }
    .cert-hero-inner {
        padding: 2rem 0;
    }
    .cert-hero-content {
        text-align: left;
    }
    .cert-split-layout {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    .cert-split-reverse {
        direction: ltr;
    }
    .cert-split-image {
        order: -1;
        max-height: 300px;
    }
    .cert-normas-grid {
        grid-template-columns: 1fr;
    }
    .cert-stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .cert-cta-box {
        flex-direction: column;
        text-align: center;
        padding: 2rem;
    }
}

@media (max-width: 480px) {
    .cert-hero-title { font-size: 1.8rem; }
    .cert-stat-num { font-size: 2rem; }
    .cert-stats-grid {
        grid-template-columns: 1fr 1fr;
        gap: 1.5rem;
    }
    .cert-processos-grid {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   MAOS A OBRA
   ============================================ */
.mao-hero { position:relative; min-height:75vh; display:flex; align-items:center; overflow:hidden; }
.mao-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.mao-hero-overlay { position:absolute; inset:0; background:linear-gradient(100deg,rgba(15,15,15,.85) 0%,rgba(15,15,15,.45) 60%,transparent 100%); }
.mao-hero-content { position:relative; z-index:2; max-width:640px; padding:5rem 0 4rem; }
.mao-hero-logo { height:72px; width:auto; display:block; margin-bottom:1.5rem; }
.mao-hero-title { font-family:var(--font-heading); font-size:2.6rem; font-weight:800; color:#fff; line-height:1.2; margin:0 0 1rem; }
.mao-hero-title .highlight { color:var(--primary); }
.mao-hero-desc { color:rgba(255,255,255,.85); font-size:1rem; line-height:1.7; margin-bottom:2rem; }
.mao-hero-cta { font-size:.95rem; }

.mao-pilares { display:flex; flex-direction:column; gap:1rem; margin-top:1.75rem; }
.mao-pilar { display:flex; gap:1rem; align-items:flex-start; background:#f8f9fa; border-radius:12px; padding:.9rem 1rem; border-left:4px solid var(--primary); }
.mao-pilar-icon { width:40px; height:40px; border-radius:10px; background:var(--primary); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.mao-pilar-icon i { font-size:1.2rem; color:#fff; }
.mao-pilar strong { display:block; font-size:.92rem; color:var(--dark); margin-bottom:.15rem; }
.mao-pilar span { font-size:.82rem; color:var(--gray-dark); }
.mao-proximos-lista { display:flex; flex-direction:column; gap:1.25rem; margin-top:2.5rem; }
.mao-evento-card { display:flex; gap:1.5rem; align-items:flex-start; background:#fff; border-radius:16px; padding:1.5rem; border:1px solid #e9ecef; box-shadow:0 2px 12px rgba(0,0,0,.05); position:relative; transition:box-shadow .2s, transform .2s; }
.mao-evento-card:hover { box-shadow:0 6px 28px rgba(0,0,0,.1); transform:translateY(-2px); }
.mao-evento-destaque { border-color:var(--primary); box-shadow:0 4px 24px rgba(255,100,25,.15); }
.mao-evento-ribbon { position:absolute; top:-1px; right:18px; background:var(--primary); color:#fff; font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; padding:.2rem .7rem; border-radius:0 0 8px 8px; }
.mao-evento-data { display:flex; flex-direction:column; align-items:center; justify-content:center; background:var(--primary); color:#fff; border-radius:12px; padding:.75rem 1rem; min-width:68px; flex-shrink:0; }
.mao-data-dia { font-size:2rem; font-weight:800; line-height:1; font-family:var(--font-heading); }
.mao-data-mes { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; margin-top:.1rem; }
.mao-data-ano { font-size:.65rem; opacity:.8; }
.mao-evento-info { flex:1; }
.mao-evento-info h3 { font-size:1.05rem; font-weight:700; color:var(--dark); margin:0 0 .4rem; }
.mao-evento-meta { display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom:.6rem; }
.mao-evento-meta span { font-size:.8rem; color:var(--gray-dark); display:flex; align-items:center; gap:.25rem; }
.mao-evento-desc { font-size:.88rem; color:var(--gray-dark); line-height:1.55; margin:0; }
.mao-evento-thumb { width:140px; height:90px; border-radius:10px; overflow:hidden; flex-shrink:0; }
.mao-evento-thumb img { width:100%; height:100%; object-fit:cover; }

.mao-realizados-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.mao-realizado-card { background:#fff; border-radius:16px; overflow:hidden; border:1px solid #e9ecef; cursor:pointer; transition:box-shadow .2s, transform .2s; }
.mao-realizado-card:hover { box-shadow:0 8px 32px rgba(0,0,0,.12); transform:translateY(-4px); }
.mao-realizado-img { position:relative; aspect-ratio:16/9; overflow:hidden; background:#f0f0f0; }
.mao-realizado-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.mao-realizado-card:hover .mao-realizado-img img { transform:scale(1.05); }
.mao-realizado-sem-img { width:100%; height:100%; display:flex; align-items:center; justify-content:center; color:#ccc; font-size:3rem; }
.mao-fotos-badge { position:absolute; bottom:8px; right:8px; background:rgba(0,0,0,.6); color:#fff; font-size:.72rem; padding:.2rem .5rem; border-radius:6px; display:flex; align-items:center; gap:.25rem; }
.mao-realizado-info { padding:1.1rem; }
.mao-realizado-data { font-size:.75rem; color:var(--gray-dark); margin-bottom:.3rem; }
.mao-realizado-info h3 { font-size:.95rem; font-weight:700; color:var(--dark); margin:0 0 .4rem; }
.mao-realizado-info p { font-size:.82rem; color:var(--gray-dark); line-height:1.5; margin:0 0 .6rem; }
.mao-ver-fotos { font-size:.78rem; font-weight:600; color:var(--primary); display:flex; align-items:center; gap:.3rem; }

.mao-cta-section { padding:4rem 0; }
.mao-cta-inner { display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.mao-cta-text h2 { font-size:1.6rem; font-weight:800; color:#fff; margin:0 0 .4rem; font-family:var(--font-heading); }
.mao-cta-text p { color:rgba(255,255,255,.85); font-size:.95rem; margin:0; }
.mao-cta-btn { display:inline-flex; align-items:center; gap:.5rem; background:#fff; color:var(--primary); font-weight:700; padding:.9rem 2rem; border-radius:10px; text-decoration:none; font-size:1rem; white-space:nowrap; transition:background .2s, transform .2s; }
.mao-cta-btn:hover { background:#fff3ee; transform:scale(1.03); }

/* Galeria modal */
.mao-galeria-modal { display:none; position:fixed; inset:0; z-index:2000; align-items:center; justify-content:center; }
.mao-galeria-modal.open { display:flex; }
.mao-galeria-overlay { position:absolute; inset:0; background:rgba(0,0,0,.7); }
.mao-galeria-container { position:relative; z-index:1; background:#fff; border-radius:16px; width:min(90vw,900px); max-height:85vh; display:flex; flex-direction:column; overflow:hidden; }
.mao-galeria-head { display:flex; align-items:center; justify-content:space-between; padding:1.1rem 1.4rem; border-bottom:1px solid #e9ecef; flex-shrink:0; }
.mao-galeria-head h3 { margin:0; font-size:1rem; font-weight:700; }
.mao-galeria-close { background:none; border:none; cursor:pointer; font-size:1.3rem; color:#666; width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.mao-galeria-close:hover { background:#f0f0f0; }
.mao-galeria-grid { flex:1; overflow-y:auto; padding:1rem; display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:.75rem; }
.mao-galeria-item { aspect-ratio:1; border-radius:10px; overflow:hidden; cursor:pointer; border:1px solid #e0e0e0; }
.mao-galeria-item img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.mao-galeria-item:hover img { transform:scale(1.08); }
.mao-galeria-item-leg { font-size:.7rem; color:#666; padding:.2rem .4rem; text-align:center; background:#fafafa; }

/* Lightbox */
.mao-lightbox { display:none; position:fixed; inset:0; z-index:3000; align-items:center; justify-content:center; }
.mao-lightbox.open { display:flex; }
.mao-lightbox-overlay { position:absolute; inset:0; background:rgba(0,0,0,.92); }
.mao-lightbox-img-wrap { position:relative; z-index:1; max-width:88vw; max-height:88vh; display:flex; flex-direction:column; align-items:center; }
.mao-lightbox-img-wrap img { max-width:100%; max-height:80vh; object-fit:contain; border-radius:8px; }
.mao-lightbox-legenda { color:rgba(255,255,255,.75); font-size:.82rem; margin-top:.6rem; }
.mao-lightbox-counter { color:rgba(255,255,255,.5); font-size:.75rem; margin-top:.2rem; }
.mao-lightbox-prev, .mao-lightbox-next { position:absolute; top:50%; transform:translateY(-50%); z-index:2; background:rgba(255,255,255,.15); border:none; color:#fff; width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.3rem; cursor:pointer; transition:background .2s; }
.mao-lightbox-prev { left:1rem; }
.mao-lightbox-next { right:1rem; }
.mao-lightbox-prev:hover, .mao-lightbox-next:hover { background:rgba(255,255,255,.28); }
.mao-lightbox-close { position:absolute; top:1rem; right:1rem; z-index:2; background:rgba(255,255,255,.15); border:none; color:#fff; width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.1rem; cursor:pointer; }

/* Responsive */
@media (max-width:900px) {
    .mao-hero-title { font-size:2rem; }
    .mao-realizados-grid { grid-template-columns:repeat(2,1fr); }
    .mao-cta-inner { flex-direction:column; text-align:center; }
}
@media (max-width:600px) {
    .mao-hero-title { font-size:1.6rem; }
    .mao-hero-logo { height:54px; }
    .mao-evento-card { flex-direction:column; }
    .mao-evento-thumb { width:100%; height:160px; }
    .mao-realizados-grid { grid-template-columns:1fr; }
}
