/* 
 * Customizações gerais do Bootstrap
 * Arquivo: assets/css/custom-fe.css
 */

/* Estilos base para tema dark */
body {
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
    background-image: linear-gradient(45deg, var(--pattern-color) 25%, transparent 25%), 
                      linear-gradient(-45deg, var(--pattern-color) 25%, transparent 25%), 
                      linear-gradient(45deg, transparent 75%, var(--pattern-color) 75%), 
                      linear-gradient(-45deg, transparent 75%, var(--pattern-color) 75%);
    background-size: var(--pattern-size) var(--pattern-size);
    background-position: 0 0, 0 var(--pattern-position-offset), var(--pattern-position-offset) calc(-1 * var(--pattern-position-offset)), calc(-1 * var(--pattern-position-offset)) 0px;
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
}

/* Customização de componentes Bootstrap */

/* Cards */
.card {
    border-radius: var(--border-radius-lg);
    box-shadow: var(--box-shadow-md);
    margin-bottom: var(--margin-component);
    border: var(--border-width) solid var(--bs-card-border-color);
    background-color: var(--bs-card-bg);
    transition: var(--transition-base);
}

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

.card-header {
    border-radius: var(--border-radius-lg) var(--border-radius-lg) 0 0;
    font-weight: var(--font-weight-bold);
    padding: var(--spacing-2) var(--spacing-3);
    background-color: var(--bs-dark);
    border-bottom: var(--border-width) solid var(--bs-border-color);
}

.card-body {
    padding: var(--padding-card);
}

.card-footer {
    background-color: var(--bs-dark);
    border-top: var(--border-width) solid var(--bs-border-color);
    padding: var(--spacing-2) var(--spacing-3);
}

/* Botões */
.btn {
    border-radius: var(--border-radius-md);
    font-weight: var(--font-weight-medium);
    padding: var(--padding-button);
    transition: var(--transition-base);
}

.btn:hover {
    transform: var(--translateY-sm);
    box-shadow: var(--box-shadow-sm);
}

.btn-primary {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.btn-primary:hover {
    background-color: var(--bs-primary-hover);
    border-color: var(--bs-primary-hover);
}

.btn-success {
    background-color: var(--bs-success);
    border-color: var(--bs-success);
}

.btn-success:hover {
    background-color: var(--bs-success-hover);
    border-color: var(--bs-success-hover);
}

.btn-outline-primary {
    color: var(--bs-primary);
    border-color: var(--bs-primary);
}

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

.btn-outline-light {
    color: var(--bs-body-color);
    border-color: var(--bs-body-color);
}

.btn-outline-light:hover {
    background-color: var(--bs-body-color);
    color: var(--bs-dark);
}

/* Badges */
.badge {
    font-weight: var(--font-weight-medium);
    padding: var(--spacing-1) var(--spacing-2);
    border-radius: var(--border-radius-sm);
}

/* Formulários */
.form-control {
    border-radius: var(--border-radius-md);
    padding: var(--padding-input);
    border: var(--border-width) solid var(--input-border);
    background-color: var(--input-bg);
    color: var(--bs-body-color);
    transition: var(--transition-base);
}

.form-control:focus {
    border-color: var(--input-focus-border);
    box-shadow: var(--input-focus-shadow);
    background-color: var(--input-bg);
    color: var(--bs-body-color);
}

.input-group-text {
    background-color: var(--input-bg);
    border-color: var(--input-border);
    color: var(--bs-body-color);
}

/* Tabelas */
.table {
    border-radius: var(--border-radius-lg);
    overflow: hidden;
    box-shadow: var(--box-shadow-sm);
    color: var(--bs-body-color);
}

.table thead th {
    background-color: var(--bs-dark);
    border-bottom: var(--border-width-thick) solid var(--bs-border-color);
    font-weight: var(--font-weight-bold);
    padding: var(--spacing-2) var(--spacing-3);
}

.table td, .table th {
    border-color: var(--bs-border-color);
    padding: var(--spacing-2) var(--spacing-3);
}

.table-hover tbody tr:hover {
    background-color: rgba(var(--bs-body-color-rgb), 0.05);
}

/* Alertas */
.alert {
    border-radius: var(--border-radius-lg);
    border: none;
    box-shadow: var(--box-shadow-sm);
    padding: var(--spacing-3);
}

/* Modals */
.modal-content {
    border-radius: var(--border-radius-lg);
    border: none;
    box-shadow: var(--box-shadow-lg);
    background-color: var(--bs-card-bg);
}

.modal-header {
    border-bottom: var(--border-width) solid var(--bs-border-color);
    padding: var(--spacing-3) var(--spacing-4);
}

.modal-footer {
    border-top: var(--border-width) solid var(--bs-border-color);
    padding: var(--spacing-3) var(--spacing-4);
}

/* List Group */
.list-group-item {
    background-color: var(--bs-card-bg);
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
    padding: var(--spacing-2) var(--spacing-3);
}

.list-group-item-action:hover {
    background-color: rgba(var(--bs-body-color-rgb), 0.05);
}

/* Utilities */
.bg-gradient-primary {
    background: linear-gradient(135deg, var(--bs-primary) 0%, var(--bs-primary-hover) 100%);
    color: var(--bs-white);
}

.text-chess {
    color: var(--chess-dark-square);
}

.bg-chess-light {
    background-color: var(--chess-light-square);
}

.bg-chess-dark {
    background-color: var(--chess-dark-square);
    color: var(--bs-white);
}

.text-muted {
    color: var(--bs-text-muted) !important;
}

/* Links */
a {
    color: var(--bs-link-color);
    text-decoration: none;
    transition: var(--transition-base);
}

a:hover {
    color: var(--bs-link-hover-color);
    text-decoration: underline;
}

/* Dropdown */
.dropdown-menu {
    background-color: var(--bs-card-bg);
    border-color: var(--bs-border-color);
    border-radius: var(--border-radius-md);
    box-shadow: var(--box-shadow-md);
    padding: var(--spacing-1) 0;
}

.dropdown-item {
    color: var(--bs-body-color);
    transition: var(--transition-fast);
    padding: var(--spacing-2) var(--spacing-3);
}

.dropdown-item:hover, .dropdown-item:focus {
    background-color: rgba(var(--bs-body-color-rgb), 0.05);
    color: var(--bs-body-color);
}

/* Progress Bar */
.progress {
    background-color: var(--input-bg);
    border-radius: var(--border-radius-pill);
    height: var(--progress-height);
    margin: var(--spacing-2) 0;
} 