/* ============================================================
   Cursos — cards, modal e slide hero
   Autoescola Itamarati
   ============================================================ */

/* ── tokens de cor ────────────────────────────────────────── */
:root {
    --course-tcp-accent:   #ffcc00;
    --course-tcp-accent-2: #ffd700;
    --course-mopp-accent:  #b21f1f;
    --course-mopp-green:   #1b4332;
    --course-pro-accent:   #2070ac;
    --course-pro-accent-2: #0a5a7a;
}

/* ── grade ────────────────────────────────────────────────── */
#courses .courses-grid > [class*="col"] {
    display: flex;
}

/* ── card ─────────────────────────────────────────────────── */
#courses .course-card {
    background: #fff;
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 0.5rem 1.5rem rgba(15, 23, 42, 0.08);
    width: 100%;
    min-height: 100%;
    border: 1px solid rgba(15, 23, 42, 0.06);
    transition:
        transform       0.28s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow      0.28s ease,
        border-color    0.25s ease;
}
#courses .course-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 1.125rem 2.75rem rgba(15, 23, 42, 0.14);
    border-color: rgba(32, 112, 172, 0.22);
}
#courses .course-card:focus-within {
    border-color: rgba(32, 112, 172, 0.35);
    box-shadow: 0 0 0 0.2rem rgba(32, 112, 172, 0.18),
                0 0.75rem 1.75rem rgba(15, 23, 42, 0.1);
}
@media (prefers-reduced-motion: reduce) {
    #courses .course-card { transition: border-color 0.2s ease; }
    #courses .course-card:hover { transform: none; }
}

/* ── mídia ────────────────────────────────────────────────── */
#courses .course-card-media {
    position: relative;
    aspect-ratio: 1 / 1;
    background: linear-gradient(145deg, #1e293b 0%, #0f172a 100%);
    overflow: hidden;
    flex-shrink: 0;
}
#courses .course-card-media::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(
        to top,
        rgba(15, 23, 42, 0.55) 0%,
        rgba(15, 23, 42, 0.10) 42%,
        transparent 65%
    );
}
#courses .course-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
    position: relative;
    z-index: 0;
    transform: scale(1);
    transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1), filter 0.35s ease;
    will-change: transform;
}
#courses .course-card:hover .course-card-media img {
    transform: scale(1.045);
    filter: saturate(1.08) contrast(1.03);
}
@media (prefers-reduced-motion: reduce) {
    #courses .course-card-media img { transition: none; }
    #courses .course-card:hover .course-card-media img { transform: none; filter: none; }
}

/* ── badges / pills ───────────────────────────────────────── */
#courses .course-card-badges {
    position: absolute;
    top:   0.875rem;
    left:  0.875rem;
    right: 0.875rem;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    align-items: flex-start;
}
#courses .course-pill {
    font-size:      0.6875rem;
    font-weight:    800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding:        0.35rem 0.75rem;
    border-radius:  50rem;
    border:         2px solid rgba(255, 255, 255, 0.85);
    color:          #0f172a;
    background:     rgba(255, 255, 255, 0.97);
    box-shadow:     0 2px 10px rgba(0, 0, 0, 0.18);
    line-height:    1.2;
}
/* variante TCP — amarelo */
#courses .course-card--tcp .course-pill {
    border-color: var(--course-tcp-accent);
    color: #111;
}
/* variante MOPP — vermelho */
#courses .course-card--mopp .course-pill {
    border-color: var(--course-mopp-accent);
    color: #3a0a0a;
    background: rgba(255, 248, 248, 0.98);
}
/* todos os demais — azul */
#courses .course-card:not(.course-card--tcp):not(.course-card--mopp) .course-pill {
    border-color: var(--course-pro-accent);
    color: #062436;
}

/* ── corpo do card ────────────────────────────────────────── */
#courses .course-card-body {
    flex: 1 1 auto;
}
#courses .course-card-title {
    font-family:    Montserrat, Raleway, sans-serif;
    font-weight:    700;
    letter-spacing: -0.02em;
    color:          #0f172a;
    line-height:    1.3;
}
#courses .course-card-desc {
    color:       #475569;
    line-height: 1.6;
    font-size:   0.9375rem;
}
@media (min-width: 768px) {
    #courses .course-card-desc { font-size: 0.90625rem; }
}

/* ── botão "Saiba mais" ───────────────────────────────────── */
#courses .btn.btn-saiba-mais {
    font-weight:    800;
    letter-spacing: 0.03em;
    font-size:      0.8125rem;
    text-transform: uppercase;
    border-radius:  50rem;
    padding:        0.65rem 1.25rem;
    border:         none !important;
    width:          100%;
    min-height:     2.75rem;
    line-height:    1.25;
    box-shadow:     0 4px 14px rgba(15, 23, 42, 0.12);
    transition:
        transform  0.22s ease,
        box-shadow 0.22s ease,
        filter     0.20s ease;
}
/* TCP */
#courses .course-card--tcp .btn.btn-saiba-mais {
    background: linear-gradient(135deg, var(--course-tcp-accent), var(--course-tcp-accent-2));
    color: #111;
}
/* MOPP */
#courses .course-card--mopp .btn.btn-saiba-mais {
    background: linear-gradient(180deg, #c42a2a 0%, var(--course-mopp-accent) 100%);
    color: #fff;
}
/* todos os demais */
#courses .course-card:not(.course-card--tcp):not(.course-card--mopp) .btn.btn-saiba-mais {
    background: linear-gradient(135deg, var(--course-pro-accent), var(--course-pro-accent-2));
    color: #fff;
}
#courses .btn.btn-saiba-mais:hover {
    filter: brightness(1.07);
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.2);
}
#courses .btn.btn-saiba-mais:active {
    transform: translateY(0);
    filter: brightness(0.98);
}
@media (prefers-reduced-motion: reduce) {
    #courses .btn.btn-saiba-mais { transition: filter 0.15s ease; }
    #courses .btn.btn-saiba-mais:hover { transform: none; }
}
#courses .btn.btn-saiba-mais:focus-visible {
    outline: 3px solid #2070ac;
    outline-offset: 3px;
}

/* ============================================================
   Modal de detalhes do curso
   ============================================================ */
.itam-modal .modal-content {
    border: none;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.28);
}
.itam-modal .itam-modal__header {
    background: linear-gradient(135deg, #062436 0%, #2070ac 52%, #0a5a7a 100%);
    color: #fff;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    padding: 1.15rem 1.4rem;
    align-items: flex-start;
    gap: 0.75rem;
}
.itam-modal .itam-modal__header .modal-title {
    color: #fff;
    font-weight: 700;
    line-height: 1.35;
}
.itam-modal .itam-modal__header-title-wrap {
    flex: 1 1 auto;
    min-width: 0;
    padding-right: 0.75rem;
}
.itam-modal .itam-modal__body {
    padding: 1.35rem 1.5rem 1.5rem;
    color: #333;
}
.itam-modal .itam-modal__body h4,
.itam-modal .itam-modal__body h5 {
    font-weight: 700;
    color: #1a1a1a;
    margin-top: 1.15rem;
    margin-bottom: 0.65rem;
}
.itam-modal .itam-modal__body h4:first-child,
.itam-modal .itam-modal__body h5:first-of-type { margin-top: 0; }
.itam-modal .itam-modal__body .text-modal-all {
    text-align: left;
    line-height: 1.65;
    color: #444;
    margin-bottom: 0.85rem;
}
.itam-modal .itam-modal__footer {
    padding: 1rem 1.5rem 1.35rem;
    background: #f4f6f8;
    border-top: 1px solid #e5e8ec;
    gap: 0.65rem;
}
.itam-modal .btn-itam-fechar {
    min-height: 44px;
    padding: 0.5rem 1.25rem;
    font-weight: 600;
    border-radius: 999px;
}
.itam-modal .btn-itam-maps,
.itam-modal .btn-course-cta-modal {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    min-height: 48px;
    padding: 0.72rem 1.65rem;
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 0.02em;
    border-radius: 999px;
    border: none;
    text-decoration: none;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
    transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}
.itam-modal .btn-itam-maps {
    background: #2070ac;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(32, 112, 172, 0.35);
}
.itam-modal .btn-itam-maps:hover,
.itam-modal .btn-course-cta-modal:hover {
    filter: brightness(1.05);
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.22);
}
.itam-modal .btn-itam-maps:hover { color: #fff !important; }
#courseDetailModal.course-modal--tcp  .btn-course-cta-modal:hover { color: #111; }
#courseDetailModal.course-modal--mopp .btn-course-cta-modal:hover { color: #fff; }
#courseDetailModal.course-modal--pro  .btn-course-cta-modal:hover { color: #fff; }
.itam-modal .btn-itam-maps:focus-visible,
.itam-modal .btn-course-cta-modal:focus-visible {
    outline: 3px solid #2070ac;
    outline-offset: 3px;
}
.itam-modal .btn-itam-maps--wa {
    background: #25d366;
    box-shadow: 0 4px 14px rgba(37, 211, 102, 0.4);
}
.itam-modal .btn-itam-maps--wa:hover {
    box-shadow: 0 8px 22px rgba(37, 211, 102, 0.45);
    color: #fff !important;
}

/* kicker */
#courseDetailModal.course-modal--tcp  .course-modal-kicker { color: var(--course-tcp-accent); }
#courseDetailModal.course-modal--mopp .course-modal-kicker { color: #ffb4b4; }
#courseDetailModal.course-modal--pro  .course-modal-kicker { color: #b8d9f5; }

/* fatos */
#courseDetailModal .course-modal-facts {
    display: grid;
    gap: 0.75rem;
    margin: 1rem 0 1.25rem;
}
@media (min-width: 576px) {
    #courseDetailModal .course-modal-facts { grid-template-columns: repeat(3, 1fr); }
}
#courseDetailModal .course-modal-fact {
    border: 1px solid #e8e8e8;
    border-radius: 10px;
    padding: 0.75rem 0.85rem;
    background: #fafafa;
}
#courseDetailModal .course-modal-fact i           { color: #2070ac; margin-right: 0.35rem; }
#courseDetailModal .course-modal-fact .label {
    display:        block;
    font-size:      0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color:          #666;
    margin-bottom:  0.2rem;
}
#courseDetailModal .course-modal-fact .value { font-weight: 600; color: #222; font-size: 0.9rem; }

/* ementa */
#courseDetailModal .course-modal-ementa    { padding-left: 1.1rem; margin: 0; }
#courseDetailModal .course-modal-ementa li { margin-bottom: 0.45rem; color: #333; }

/* botão CTA do modal */
#courseDetailModal.course-modal--tcp .btn-course-cta-modal {
    background: linear-gradient(135deg, var(--course-tcp-accent), var(--course-tcp-accent-2));
    color: #111;
}
#courseDetailModal.course-modal--mopp .btn-course-cta-modal {
    background: var(--course-mopp-accent);
    color: #fff;
}
#courseDetailModal.course-modal--pro .btn-course-cta-modal {
    background: linear-gradient(135deg, var(--course-pro-accent), var(--course-pro-accent-2));
    color: #fff;
}

/* contato */
#courseDetailModal .course-modal-contact {
    margin-top: 1rem;
    padding: 1rem 1.15rem;
    border-radius: 10px;
    background: var(--course-mopp-green);
    color: #fff;
    font-size: 0.95rem;
}
#courseDetailModal.course-modal--tcp  .course-modal-contact { background: #1b4332; }
#courseDetailModal.course-modal--pro  .course-modal-contact { background: #062436; }
#courseDetailModal .course-modal-contact a { color: #fff; font-weight: 700; text-decoration: underline; }
#courseDetailModal .course-modal-contact .course-modal-wa-quick {
    display: inline-block;
    margin-top: 0.65rem;
    font-size: 0.88rem;
    font-weight: 600;
    color: #fff;
    text-decoration: none;
    border-bottom: 1px dashed rgba(255, 255, 255, 0.65);
}
#courseDetailModal .course-modal-contact .course-modal-wa-quick:hover {
    color: rgba(255, 255, 255, 0.8);
    border-bottom-color: #fff;
}

/* capa do modal */
#courseDetailModal .course-modal-cover-wrap {
    max-width: min(100%, 380px);
    margin: 0 auto 1.25rem;
    aspect-ratio: 1 / 1;
    border-radius: 12px;
    overflow: hidden;
    background: linear-gradient(145deg, #1a1a1a 0%, #0d0d0d 100%);
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}
#courseDetailModal .course-modal-cover-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
}

/* ícone WhatsApp no CTA do modal */
.itam-modal .btn-course-cta-modal .fa-whatsapp           { font-size: 1.45rem; line-height: 1; }
#courseDetailModal.course-modal--tcp  .btn-course-cta-modal .fa-whatsapp { color: #128c7e; }
#courseDetailModal.course-modal--mopp .btn-course-cta-modal .fa-whatsapp { color: #fff; }
#courseDetailModal.course-modal--pro  .btn-course-cta-modal .fa-whatsapp { color: #fff; }

/* ============================================================
   Slide hero — cursos profissionalizantes
   ============================================================ */
.content-slide-cursos .slide-cursos-badge {
    display: inline-block;
    font-size:      0.72rem;
    font-weight:    800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color:       #111;
    background:  linear-gradient(135deg, #ffcc00, #ffd700);
    padding:     0.35rem 0.85rem;
    border-radius: 999px;
    margin-bottom: 0.75rem;
    box-shadow:  0 2px 12px rgba(0, 0, 0, 0.25);
}
.content-slide-cursos .title-slide {
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.45);
}
.content-slide-cursos .content-slides {
    max-width: 42rem;
    margin-left: auto;
    margin-right: auto;
}
.slide-cursos-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: center;
    align-items: center;
    margin-top: 0.5rem;
}
.slide-btn.slide-btn-cursos {
    background: linear-gradient(135deg, #ffcc00, #ffd700);
    color: #111 !important;
    font-weight: 800;
    border: 2px solid rgba(255, 255, 255, 0.35);
}
.slide-btn.slide-btn-cursos:hover { filter: brightness(1.06); color: #111 !important; }
.slide-btn.slide-btn-matricula-wa {
    background: #25d366;
    color: #fff !important;
    font-weight: 800;
    border: 2px solid rgba(255, 255, 255, 0.35);
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}
.slide-btn.slide-btn-matricula-wa .fa-whatsapp { font-size: 1.35rem; }
.slide-btn.slide-btn-matricula-wa:hover { filter: brightness(1.08); color: #fff !important; }

/* ============================================================
   Destaque de cursos no nav
   ============================================================ */
.nav-item-cursos-highlight .nav-link-cursos-pro {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
}
.nav-cursos-badge {
    font-size:      0.62rem;
    font-weight:    800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #111;
    background: linear-gradient(135deg, #ffcc00, #ffd700);
    padding: 0.15rem 0.45rem;
    border-radius: 6px;
    line-height: 1.2;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.12);
}
@media (min-width: 992px) {
    .nav-item-cursos-highlight { margin-right: 0.15rem; }
}
