@import url("custom-colors.css");

html {
    font-size: 15px;
}

:root {
    --eixo-card-border: #4f79ad;
    --eixo-card-border-soft: #dce9f9;
    --eixo-surface-shadow: 0 8px 18px rgba(11, 31, 58, 0.08);
}

body {
    background: var(--bs-light-bg-subtle, #f8f9fa);
}

.app-header {
    background: linear-gradient(180deg, #0b1f3a 0%, #123763 100%);
    box-shadow: 0 8px 24px rgba(11, 31, 58, 0.18);
    z-index: 1040;
}

.app-topbar {
    padding: 0.65rem 1rem 0.35rem;
}

.app-topbar .container-fluid,
.app-navbar .container-fluid {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-left: 0;
    padding-right: 0;
}

.app-navbar {
    padding: 0 1rem 0.5rem;
}

.brand {
    color: #fff;
    font-size: 1.125rem;
    font-weight: 700;
    text-decoration: none;
    margin-right: 1rem;
}

.brand:hover {
    color: #fff;
    text-decoration: none;
}

.app-userbar {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.userbar {
    color: rgba(255, 255, 255, 0.82);
    font-size: 0.875rem;
    white-space: nowrap;
}

.app-nav-list {
    gap: 0.4rem;
    flex-wrap: wrap;
}

.app-nav-link {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.45rem 0.9rem;
    color: rgba(255, 255, 255, 0.88);
    border: 1px solid transparent;
    border-radius: var(--bs-border-radius-pill);
}

.app-navbar .navbar-nav .app-nav-link:hover,
.app-navbar .navbar-nav .app-nav-link:focus {
    color: #fff;
    text-decoration: none;
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.16);
}

.app-navbar .navbar-nav .app-nav-link.active,
.app-navbar .navbar-nav .app-nav-link.active:hover,
.app-navbar .navbar-nav .app-nav-link.active:focus {
    color: #fff;
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.24);
}

.app-nav-dropdown .dropdown-toggle::after {
    margin-left: 0.55rem;
}

.app-dropdown-menu {
    margin-top: 0.35rem;
    padding: 0.45rem;
    min-width: 14rem;
    border: 1px solid var(--eixo-card-border-soft);
    border-radius: var(--bs-border-radius-lg);
    box-shadow: var(--eixo-surface-shadow);
}

.app-dropdown-menu .dropdown-item {
    border-radius: var(--bs-border-radius);
    padding: 0.55rem 0.75rem;
    color: #102a43;
}

.app-dropdown-menu .dropdown-item:hover,
.app-dropdown-menu .dropdown-item:focus,
.app-dropdown-menu .dropdown-item.active {
    background: rgba(13, 110, 253, 0.08);
    color: #102a43;
}

.app-navbar-toggler {
    border-color: rgba(255, 255, 255, 0.35);
}

.app-navbar .navbar-toggler-icon {
    filter: invert(1) grayscale(100%);
}

.nav-icon {
    width: 18px;
    text-align: center;
}

.layout {
    min-height: 100vh;
    padding-top: 94px;
}

.content {
    padding: 1rem 1.25rem 1.5rem;
}

.page-title {
    margin-bottom: 15px;
    color: #102a43;
}

.panel,
.toolbar,
.grid-wrap,
.chart-box,
.table-card,
.content .card,
.submenu-card,
.modal-content {
    background: #fff;
    border: 1.5px solid var(--eixo-card-border);
    box-shadow: var(--eixo-surface-shadow);
}

.panel,
.toolbar,
.grid-wrap,
.chart-box,
.table-card,
.content .card,
.submenu-card {
    border-radius: var(--bs-border-radius-xl);
}

.panel,
.toolbar,
.chart-box,
.submenu-card {
    padding: 1rem;
    margin-bottom: 1rem;
}

.grid-wrap {
    overflow-x: auto;
    margin-bottom: 1rem;
    padding: 0;
}

.grid-wrap > .h6,
.grid-wrap > h2,
.chart-box > .h6,
.chart-box > h2 {
    margin: 0;
    padding: 1rem 1rem 0;
}

.grid {
    width: 100%;
    margin-bottom: 0;
    border-collapse: collapse;
    color: var(--bs-body-color);
    background-color: transparent;
}

.grid th,
.grid td {
    padding: 0.75rem;
    vertical-align: top;
    border-bottom: 1px solid var(--bs-border-color);
}

.grid th {
    font-weight: 600;
    color: var(--bs-emphasis-color);
    background: var(--bs-tertiary-bg);
}

.table-grid-head thead th {
    padding: 0.75rem;
    background: var(--bs-tertiary-bg);
}

.grid tr:last-child td {
    border-bottom: 0;
}

.grid tbody tr:hover td {
    background: rgba(13, 110, 253, 0.04);
}

.form-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(190px, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.actions,
.action-buttons {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.actions {
    margin-top: 1rem;
}

.action-buttons > .btn,
.action-buttons > a.btn,
.action-buttons > input.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.color-chip {
    display: inline-block;
    width: 14px;
    height: 14px;
    margin-right: 0.5rem;
    border: 1px solid rgba(11, 31, 58, 0.2);
    border-radius: 999px;
    vertical-align: -2px;
}

.form-section-title {
    margin-bottom: 1rem;
    color: var(--bs-heading-color);
}

.message {
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
    border: 1px solid #9decf9;
    border-radius: var(--bs-border-radius);
    background: #e3f8ff;
    color: #044e54;
}

.error {
    background: #ffe3e3;
    color: #8a041a;
    border-color: #ffbdbd;
}

.cards {
    display: grid;
    grid-template-columns: repeat(4, minmax(160px, 1fr));
    gap: 1rem;
}

.submenu-title {
    margin-bottom: 0.75rem;
    color: #102a43;
    font-size: 0.875rem;
    font-weight: 600;
}

.submenu-card .nav {
    gap: 0.5rem;
}

.submenu-card .nav-link {
    white-space: nowrap;
}

.modal-content {
    border-radius: var(--bs-border-radius-xl);
}

.modal-header,
.modal-footer {
    border-color: var(--eixo-card-border-soft);
}

.login-page {
    min-height: 100vh;
    background:
        linear-gradient(135deg, rgba(11, 31, 58, 0.96), rgba(18, 55, 99, 0.92)),
        linear-gradient(180deg, #f8fbfc, #e9f1f3);
}

.login-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(360px, 0.95fr) minmax(420px, 1.05fr);
}

.login-brand-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    color: #fff;
}

.login-brand-content {
    width: min(460px, 100%);
}

.login-brand-mark {
    width: 78px;
    height: 78px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 2rem;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 22px 60px rgba(0, 0, 0, 0.18);
}

.login-brand-icon {
    color: #0b1f3a;
    font-size: 2.4rem;
}

.login-eyebrow {
    margin: 0 0 0.6rem;
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
}

.login-title {
    margin: 0;
    max-width: 430px;
    color: #fff;
    font-size: 2.15rem;
    line-height: 1.12;
    font-weight: 700;
}

.login-text {
    max-width: 420px;
    margin-top: 1rem;
    color: rgba(255, 255, 255, 0.78);
    font-size: 1rem;
    line-height: 1.6;
}

.login-form-panel {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    background: #f5f8f9;
}

.login-card {
    width: min(430px, 100%);
    padding: 2rem;
    background: #fff;
    border: 1px solid #dfe7ea;
    border-radius: var(--bs-border-radius-lg);
    box-shadow: 0 22px 60px rgba(11, 31, 58, 0.13);
}

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

.login-card-icon {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 44px;
    border-radius: 8px;
    color: #0b1f3a;
    background: #e8eef8;
    font-size: 1.25rem;
}

.login-input-group {
    border: 1px solid #d7e1e8;
    border-radius: var(--bs-border-radius);
    overflow: hidden;
    background: #fff;
}

.login-input-group .input-group-text {
    border: 0;
    background: #f2f6f8;
    color: #486581;
}

.login-input-group .form-control {
    border: 0;
    box-shadow: none;
}

.login-input-group:focus-within {
    border-color: #86b7fe;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.15);
}

.btn-login {
    font-weight: 700;
}

@media (max-width: 900px) {
    .form-row {
        grid-template-columns: 1fr;
    }

    .cards {
        grid-template-columns: repeat(2, minmax(140px, 1fr));
    }

    .login-shell {
        display: block;
    }

    .login-brand-panel {
        display: none;
    }

    .login-form-panel {
        min-height: 100vh;
        padding: 1.5rem;
    }
}

@media (max-width: 991.98px) {
    .app-topbar {
        padding: 0.65rem 0.75rem 0.35rem;
    }

    .app-navbar {
        padding: 0 0.75rem 0.5rem;
    }

    .layout {
        padding-top: 92px;
    }

    .content {
        padding: 0.875rem;
    }

    .app-topbar .container-fluid,
    .app-navbar .container-fluid {
        align-items: flex-start;
    }

    .app-userbar {
        gap: 0.5rem;
        align-items: center;
        flex-wrap: wrap;
        justify-content: flex-end;
    }

    .app-nav-list {
        padding-top: 0.5rem;
        width: 100%;
    }

    .app-nav-dropdown {
        width: 100%;
    }

    .app-dropdown-menu {
        position: static !important;
        float: none;
        margin-top: 0.5rem;
        background: rgba(255, 255, 255, 0.98);
    }
}

@media (min-width: 992px) {
    .app-nav-dropdown:hover > .app-dropdown-menu,
    .app-nav-dropdown:focus-within > .app-dropdown-menu {
        display: block;
    }
}
