/* ==========================================================================
   Método — 5 Pilares (Protocolos de Engenharia)
   ========================================================================== */

.metodo-pilares {
    position: relative;
    z-index: 1;
    background: #EFF4FF;
    overflow: hidden;
    margin-top: calc(-1 * var(--hero-clip-v));
    padding: calc(clamp(56px, 4.2vw, 80px) + var(--hero-clip-v)) 0 var(--section-pad-xl);
    clip-path: polygon(
        var(--hero-clip-h) 0,
        calc(100% - var(--hero-clip-h)) 0,
        100% var(--hero-clip-v),
        100% 100%,
        0 100%,
        0 var(--hero-clip-v)
    );
}

.metodo-pilares__header {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: clamp(6px, 0.42vw, 8px);
    margin-bottom: clamp(32px, 2.9vw, 56px);
}

.metodo-pilares__label {
    display: flex;
    align-items: center;
    gap: clamp(10px, 0.63vw, 12px);
    font-family: var(--font-text);
    font-size: var(--fs-body);
    color: #212121;
}

.metodo-pilares__line {
    width: var(--line-width);
    height: 0;
    border-top: 1px solid var(--color-primary);
    flex-shrink: 0;
}

.metodo-pilares__title {
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: var(--fs-section-lg);
    line-height: 1.2;
    color: #212121;
    margin: clamp(6px, 0.42vw, 8px) 0 var(--gap-content);
    max-width: min(100%, clamp(320px, 90vw, 960px));
}

@media (min-width: 769px) {
    .metodo-pilares__title {
        white-space: nowrap;
    }
}

.metodo-pilares__intro {
    max-width: min(100%, clamp(300px, 75vw, 960px));
    font-family: var(--font-text);
    font-size: var(--fs-body);
    line-height: 1.7;
    color: #454545;
}

/* ===== Item / Pilar individual ===== */
.metodo-pilares__item {
    padding: clamp(16px, 1.25vw, 24px) 0;
}

.metodo-pilares__item-inner {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
    gap: clamp(12px, 1.5vw, 20px);
    align-items: center;
}

.metodo-pilares__item--media-right .metodo-pilares__item-inner {
    grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
}

.metodo-pilares__item--media-right .metodo-pilares__media { order: 2; justify-self: end; }
.metodo-pilares__item--media-right .metodo-pilares__body  { order: 1; }

.metodo-pilares__media {
    position: relative;
    isolation: isolate;
    width: 100%;
    max-width: 100%;
    aspect-ratio: 599 / 509;
    justify-self: start;
}

/* Moldura externa — viewBox 556×509 com proporção fixa para preservar o ângulo do corte */
.metodo-pilares__media::before {
    content: '';
    position: absolute;
    top: 0;
    left: -5.342%;
    width: 92.821%;
    aspect-ratio: 556 / 509;
    height: auto;
    max-height: 100%;
    background: url('../images/metodo/pilares-frame-left.svg') center / 100% 100% no-repeat;
    pointer-events: none;
    z-index: 0;
}

.metodo-pilares__item--media-right .metodo-pilares__media::before {
    left: auto;
    right: -5.342%;
    background-image: url('../images/metodo/pilares-frame-right.svg');
}

/* Imagem interna — mesma proporção 556×509, menor que a moldura, mesma curva */
.metodo-pilares__media img {
    display: block;
    position: absolute;
    top: 6.287%;
    left: 0;
    width: 88%;
    aspect-ratio: 556 / 509;
    height: auto;
    max-height: 87.426%;
    object-fit: cover;
    z-index: 1;
    box-shadow: 0 clamp(16px, 1.25vw, 24px) clamp(32px, 2.5vw, 48px) -28px rgba(19, 38, 78, 0.25);
    -webkit-mask-image: url('../images/metodo/pilares-mask-left.svg');
    mask-image: url('../images/metodo/pilares-mask-left.svg');
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
}

.metodo-pilares__item--media-right .metodo-pilares__media img {
    left: auto;
    right: 0;
    -webkit-mask-image: url('../images/metodo/pilares-mask-right.svg');
    mask-image: url('../images/metodo/pilares-mask-right.svg');
}

.metodo-pilares__body { max-width: 100%; }

.metodo-pilares__num {
    display: flex;
    align-items: center;
    gap: clamp(10px, 0.63vw, 12px);
    font-family: var(--font-text);
    font-size: var(--fs-body-sm);
    color: #555;
    margin-bottom: clamp(10px, 0.63vw, 12px);
    letter-spacing: 0.04em;
}

.metodo-pilares__num-line {
    width: clamp(32px, 2.08vw, 40px);
    height: 0;
    border-top: 1px solid var(--color-primary);
    flex-shrink: 0;
}

.metodo-pilares__item-title {
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: var(--fs-heading-md);
    line-height: 1.25;
    color: #212121;
    margin-bottom: var(--gap-content);
}

.metodo-pilares__paragraph {
    font-family: var(--font-text);
    font-size: var(--fs-body);
    line-height: 1.7;
    color: #454545;
    margin-bottom: clamp(12px, 0.73vw, 14px);
}

.metodo-pilares__paragraph strong {
    color: #212121;
    font-weight: 600;
}

.metodo-pilares__paragraph:last-child { margin-bottom: 0; }

@media (max-width: 1024px) {
    .metodo-pilares {
        padding: calc(var(--section-pad-md) + var(--hero-clip-v)) 0 var(--section-pad-lg);
    }

    .metodo-pilares__item-inner,
    .metodo-pilares__item--media-right .metodo-pilares__item-inner {
        grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
        gap: clamp(12px, 2vw, 20px);
    }

    .metodo-pilares__item--media-right .metodo-pilares__item-inner {
        grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
    }
}

@media (max-width: 768px) {
    .metodo-pilares {
        margin-top: 0;
        padding: clamp(36px, 2.6vw, 48px) 0 clamp(48px, 3.65vw, 56px);
        clip-path: none;
    }

    .metodo-pilares__header {
        align-items: center;
        text-align: center;
    }

    .metodo-pilares__label {
        justify-content: center;
    }

    .metodo-pilares__item-inner,
    .metodo-pilares__item--media-right .metodo-pilares__item-inner {
        grid-template-columns: 1fr;
        gap: clamp(20px, 1.67vw, 24px);
        justify-items: center;
    }

    .metodo-pilares__media,
    .metodo-pilares__item--media-right .metodo-pilares__media {
        width: min(100%, clamp(280px, 90vw, 420px));
        max-width: 100%;
        margin-inline: auto;
        justify-self: center;
    }

    /*
     * Mobile: bloco centralizado, com o mesmo recuo lateral do desktop
     * (5.342% ≈ 6.287% vertical em proporção) para igualar a folga da moldura.
     */
    .metodo-pilares__media::before,
    .metodo-pilares__item--media-right .metodo-pilares__media::before {
        left: calc(50% - 46.4105%);
        right: auto;
        transform: none;
        background-image: url('../images/metodo/pilares-frame-left.svg');
    }

    .metodo-pilares__media img,
    .metodo-pilares__item--media-right .metodo-pilares__media img {
        left: calc(50% - 41.0685%);
        right: auto;
        transform: none;
        -webkit-mask-image: url('../images/metodo/pilares-mask-left.svg');
        mask-image: url('../images/metodo/pilares-mask-left.svg');
    }

    .metodo-pilares__item--media-right .metodo-pilares__media { order: 0; }
    .metodo-pilares__item--media-right .metodo-pilares__body  { order: 1; }

    .metodo-pilares__intro {
        width: min(100%, clamp(300px, 92vw, 520px));
        max-width: none;
    }

    .metodo-pilares__body {
        width: min(100%, clamp(300px, 92vw, 520px));
        max-width: none;
        margin-inline: auto;
        text-align: center;
    }

    .metodo-pilares__num {
        justify-content: center;
    }
}

/* ==========================================================================
   Pilar II — duas fotos sobrepostas (duo), no estilo das fotos do timeline.
   Cada foto usa moldura (::before) + imagem mascarada na MESMA caixa, então o
   corte diagonal da moldura bate com o da foto. Regras no fim do arquivo para
   vencer a cascata da imagem única (inclusive nos media queries acima).
   ========================================================================== */
.metodo-pilares__item--media-right .metodo-pilares__media--duo::before,
.metodo-pilares__media--duo::before {
    display: none;
}

.metodo-pilares__duo-photo {
    position: absolute;
}

.metodo-pilares__duo-photo::before {
    content: '';
    position: absolute;
    inset: -4%;
    background-repeat: no-repeat;
    background-size: 100% 100%;
    pointer-events: none;
    z-index: 0;
}

.metodo-pilares__media--duo .metodo-pilares__duo-photo img {
    position: absolute;
    inset: 0;
    top: 0;
    left: 0;
    right: auto;
    width: 100%;
    height: 100%;
    max-height: none;
    aspect-ratio: auto;
    object-fit: cover;
    box-shadow: none;
    z-index: 1;
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
}

.metodo-pilares__duo-photo--main {
    left: 6%;
    top: 0;
    width: 46%;
    height: 82%;
    z-index: 1;
}

.metodo-pilares__duo-photo--main::before {
    background-image: url('../images/timeline/timeline-frame-left.svg');
}

.metodo-pilares__media--duo .metodo-pilares__duo-photo--main img {
    -webkit-mask-image: url('../images/timeline/timeline-mask-left.svg');
    mask-image: url('../images/timeline/timeline-mask-left.svg');
}

.metodo-pilares__duo-photo--sec {
    left: 46%;
    top: 10%;
    width: 50%;
    height: 86%;
    z-index: 2;
}

.metodo-pilares__duo-photo--sec::before {
    background-image: url('../images/timeline/timeline-frame-right.svg');
}

.metodo-pilares__media--duo .metodo-pilares__duo-photo--sec img {
    -webkit-mask-image: url('../images/timeline/timeline-mask-right.svg');
    mask-image: url('../images/timeline/timeline-mask-right.svg');
}
