﻿/* ==============================
   RESET GENERAL
================================ */
* {
    box-sizing: border-box;
}

html, body {
    height: 100%;
}

/* ==============================
   BASE / BODY
================================ */
.body_partido,
.body_partidoSIG {
    font-family: gotham, sans-serif;
    position: relative;
    min-height: 100vh;
    background-image: url(images/Colombia.jpg);
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
}

    /* Overlay */
    .body_partido::before,
    .body_partidoSIG::before {
        content: "";
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.35);
        z-index: 0;
        pointer-events: none;
    }

/* Asegura que contenido esté encima */
.navbar,
.navbar-partido,
.navbar-partidoSIG,
.navbar-partido-inverse,
.container,
.container-fluid,
.body-content,
.banner,
.banner-footer,
#toast-container {
    position: relative;
    z-index: 1;
}

/* ==============================
   CONTENIDO
================================ */
.body-content {
    padding: 12px;
    margin: 0 auto;
    margin-bottom: 70px;
    max-width: 1400px;
    background-color: transparent;
}

/* ==============================
   IMÁGENES
================================ */
.img-responsive-center {
    max-width: 100%;
    height: auto;
    margin: 0 auto;
}

.logo-sistema {
    height: 50px;
    width: auto;
    max-width: 100%;
}

/* ==============================
   NAVBAR
================================ */
.navbar-partido,
.navbar-partidoSIG {
    background-color: #FFFFFF;
    border-bottom: 1px solid #E0E0E0;
    padding: 6px 0;
}

    .navbar-partido .navbar-brand {
        color: #C62828;
        font-weight: 700;
        font-size: 18px;
    }

    .navbar-partido .navbar-nav > li > a {
        color: #000000;
        font-weight: 500;
        padding: 8px 12px;
    }

    .navbar-partido .navbar-nav > .active > a {
        color: #C62828;
        background-color: #FFFFFF;
    }

/* Barra secundaria */
.navbar-partido-inverse {
    background-color: #f5f5f5;
    padding: 6px 0;
}

    .navbar-partido-inverse h3 {
        margin: 6px 0 !important;
        font-size: 20px;
    }

/* ==============================
   BOTONES
================================ */
.btn-partido {
    color: #FFFFFF;
    background-color: #C62828;
    border: none;
}

    .btn-partido:hover {
        background-color: #B71C1C;
    }

.btn-partido-inverse {
    color: #C62828;
    background-color: #FFFFFF;
    border: 1px solid #C62828;
}

/* ==============================
   FORMULARIOS
================================ */
input,
select,
textarea {
    max-width: 100%;
}

/* ==============================
   PANELES
================================ */
.panel-body {
    color: #000000;
}

.panel-footer {
    color: #FFFFFF;
}

.panel-partido {
    border-color: #FFFFFF;
}

    .panel-partido > .panel-heading {
        color: #C62828;
        background-color: #FFFFFF;
        border-color: #DDDDDD;
        font-weight: 700;
    }

/* ==============================
   BANNER
================================ */
.banner {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 15px 0;
}

.banner-asi {
    width: min(95%, 1600px);
    height: auto;
}

/* ==============================
   CARDS
================================ */
.row-cards {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

    .row-cards > [class*='col-'] {
        display: flex;
    }

.card-mini {
    border: none;
    border-radius: 14px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.08);
    padding: 14px;
    transition: 0.2s ease;
    display: flex;
    flex-direction: column;
    width: 100%;
}

    .card-mini:hover {
        transform: translateY(-3px);
    }

    .card-mini h5 {
        font-size: 15px;
        font-weight: 600;
    }

    .card-mini p {
        font-size: 13px;
    }

    .card-mini .btn {
        margin-top: auto;
        font-size: 13px;
    }

/* Colores */
.card-light {
    background: #f4f4f4;
    color: #000;
}

.card-red {
    background: linear-gradient(135deg, #C62828, #8E0000);
    color: #fff;
}

.card-yellow {
    background: linear-gradient(135deg, #E0B84C, #C9A227);
    color: #000;
}

.card-green {
    background: linear-gradient(135deg, #2e7d32, #1b5e20);
    color: #fff;
}

    .card-green .btn {
        background-color: #ffffff;
        color: #1b5e20;
        font-weight: 600;
    }

/* ==============================
   FOOTER
================================ */
.banner-footer {
    background-color: #FFFFFF;
    width: 100%;
    position: fixed;
    bottom: 0;
    z-index: 150;
    padding: 10px 12px;
    border-top: 1px solid #E0E0E0;
}

/* ==============================
   LOADING OVERLAY
================================ */
.loading-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}

.loading-img {
    width: 280px;
    height: auto;
    max-width: 90%;
}

/* ==============================
   TOASTR RESPONSIVE
================================ */
#toast-container {
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
}

    #toast-container > div {
        width: min(420px, calc(100vw - 24px)) !important;
        border-radius: 10px !important;
        box-shadow: 0 10px 30px rgba(0,0,0,0.35) !important;
    }

/* ==============================
   RESPONSIVE
================================ */
@media (max-width: 992px) {
    .body-content {
        max-width: 960px;
    }
}

@media (max-width: 768px) {

    .body_partido,
    .body_partidoSIG {
        background-attachment: scroll;
    }

    .logo-sistema {
        height: 42px;
    }

    .navbar-partido-inverse .col-md-10,
    .navbar-partido-inverse .col-md-2 {
        width: 100%;
    }

    .navbar-partido-inverse .text-right {
        text-align: left;
        margin-top: 5px;
    }

    .row-cards {
        gap: 12px;
    }

    .loading-img {
        width: 220px;
    }
}

@media (max-width: 420px) {
    .card-mini {
        padding: 10px;
    }

        .card-mini h5 {
            font-size: 14px;
        }

        .card-mini p {
            font-size: 12px;
        }
}
