﻿/* ---- Page Background (matches Flutter app) ---- */
body
{
    background-color: var(--surface-page);
}

/* ---- Reporting Container (wider than standard container) ---- */
.reporting-container
{
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 1rem;
}

/* ---- Header & Footer ---- */
.navbar
{
    background-color: var(--surface-card);
    box-shadow: 0 1px 8px rgba(0, 0, 0, 0.06);
}

[data-bs-theme='dark'] .navbar
{
    box-shadow: 0 1px 8px rgba(0, 0, 0, 0.2);
}

.footer
{
    background-color: var(--surface-card);
    box-shadow: 0 -1px 8px rgba(0, 0, 0, 0.04);
}

[data-bs-theme='dark'] .footer
{
    box-shadow: 0 -1px 8px rgba(0, 0, 0, 0.15);
}

/* ---- Navbar Links (matches csium.us) ---- */
/* ---- Navbar Links (matches csium.us) ---- */
.navbar-nav .nav-link
{
    color: var(--csium-dark-blue);
    font-weight: 700;
    text-transform: uppercase;
    text-decoration: none !important;
    transition: all 0.3s ease;
}

.navbar-nav .nav-link:hover
{
    color: var(--csium-mid-blue);
    transform: scale(1.2);
}

.navbar-nav .nav-link.active
{
    color: var(--csium-pink);
    font-weight: 700;
}

.navbar-nav .nav-link.active::after
{
    display: none !important;
}

[data-bs-theme='dark'] .navbar-nav .nav-link
{
    color: rgba(255, 255, 255, 0.85);
}

[data-bs-theme='dark'] .navbar-nav .nav-link:hover
{
    color: var(--csium-light-blue);
}

[data-bs-theme='dark'] .navbar-nav .nav-link.active
{
    color: var(--csium-pink);
}

/* ---- Page Titles (all patterns) ---- */
.portal-page-header-text h1,
.portal-welcome h1,
.page-header h1
{
    text-transform: uppercase;
    color: var(--csium-dark-blue);
}

[data-bs-theme='dark'] .portal-page-header-text h1,
[data-bs-theme='dark'] .portal-welcome h1,
[data-bs-theme='dark'] .page-header h1
{
    color: var(--csium-mid-blue);
}

/* Common Card Header Styles */
.card-header
{
    background-color: var(--surface-sidebar);
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-color);
    font-size: 1.15rem;
    font-weight: 500;
    padding: 1rem 1.25rem;
}

/* Common Card Body Headings */
.card-body h4,
.card-body h5
{
    color: var(--text-primary);
}

/* Common Card Body Paragraphs */
.card-body p
{
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

    .card-body p strong
    {
        color: var(--text-primary);
    }

/* Common Table Styles within Cards */
.table
{
    --bs-table-bg: var(--surface-card);
    --bs-table-color: var(--text-primary);
    --bs-table-striped-bg: var(--hover-bg);
    --bs-table-hover-bg: rgba(var(--text-primary-rgb), 0.05);
    --bs-table-border-color: var(--border-color);
}

    .table thead th
    {
        border-bottom-width: 1px;
        border-bottom-color: var(--border-color);
        text-transform: uppercase;
        font-size: 0.85rem;
        letter-spacing: 0.05em;
        color: var(--text-secondary);
    }

    .table td, .table th
    {
        vertical-align: middle;
    }

/* Common Badge Styles */
.badge.bg-success
{
    background-color: var(--bs-success) !important;
    color: var(--bs-white) !important;
}

.badge.bg-warning
{
    background-color: var(--bs-warning) !important;
    color: var(--bs-black) !important;
}

.badge.bg-secondary
{
    background-color: var(--bs-secondary) !important;
    color: var(--bs-white) !important;
}

/* Common Small Button Styles for Tables */
.table .btn-sm
{
    padding: 0.25rem 0.5rem;
    font-size: 0.8rem;
}

/* Common Alert Styles */
.custom-success-alert
{
    background-color: var(--bs-success);
    color: var(--bs-white);
    border-color: var(--bs-success);
}

    .custom-success-alert .btn-close
    {
        color: var(--bs-white) !important;
        filter: invert(1);
    }

.custom-danger-alert
{
    background-color: var(--csium-red);
    color: white;
    border-color: var(--csium-red);
}

    .custom-danger-alert .btn-close
    {
        color: white !important;
        filter: invert(1);
    }

.custom-warning-alert
{
    background-color: var(--bs-warning);
    color: var(--bs-dark);
    border-color: var(--bs-warning);
}

    .custom-warning-alert .btn-close
    {
        color: var(--bs-dark) !important;
        filter: none;
    }

/* Common Button Styles using Csium colors or Bootstrap defaults */
.btn-outline-secondary
{
    color: var(--text-secondary);
    border-color: var(--border-color);
}

    .btn-outline-secondary:hover
    {
        background-color: var(--hover-bg);
        color: var(--text-secondary);
        border-color: var(--border-color);
    }

.btn-outline-danger
{
    color: var(--csium-red);
    border-color: var(--csium-red);
}

    .btn-outline-danger:hover
    {
        background-color: var(--csium-red);
        color: white;
        border-color: var(--csium-red);
    }

.btn-lg, .btn-sm
{
    white-space: nowrap;
}

/* Base style for REQUIRED/OPTIONAL tags (from data-import-page) */
.status-tag
{
    font-weight: bold;
    font-size: 0.7rem;
    padding: 3px 8px;
    border-radius: 5px;
    text-transform: uppercase;
    color: white;
    margin: 0 4px;
    display: inline-block;
    vertical-align: middle;
}

    .status-tag.required
    {
        background-color: var(--csium-red);
    }

    .status-tag.optional
    {
        background-color: #28a745; /* A pleasant green */
    }

/* Common Link Styling within instructions card (from data-import-page) */
.instructions-card a
{
    color: var(--csium-blue);
    font-weight: 500;
    text-decoration: none;
}

    .instructions-card a:hover
    {
        text-decoration: underline;
    }

/* Common Code block styling (from data-import-page) */
.instructions-card code
{
    background-color: var(--bs-secondary-bg);
    color: var(--bs-body-color);
    padding: 0.2em 0.4em;
    margin: 0;
    font-size: 85%;
    border-radius: 6px;
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

/* ---- Branded Page Header (reusable) ---- */
.portal-page-header
{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 2rem;
}

.portal-page-header-text h1
{
    display: inline-block;
    font-size: 1.75rem;
    font-weight: 700;
    margin: 0;
}

.portal-page-header-text h1::after
{
    content: '';
    display: block;
    width: 100%;
    height: 3px;
    margin-top: 0.4rem;
    border-radius: 2px;
    background: linear-gradient(90deg, var(--csium-mid-blue), var(--csium-blue), var(--csium-light-blue));
}

.portal-page-header-text p
{
    font-size: 0.925rem;
    color: var(--text-secondary);
    margin: 0.4rem 0 0;
    line-height: 1.5;
}

.portal-page-header-icon
{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    min-width: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--csium-dark-blue), var(--csium-blue));
}

    .portal-page-header-icon .material-symbols-outlined
    {
        font-size: 1.4rem;
        color: #ffffff;
    }

.portal-page-header-icon--blue
{
    background: linear-gradient(135deg, var(--csium-mid-blue), var(--csium-blue));
}

.portal-page-header-icon--teal
{
    background: linear-gradient(135deg, var(--csium-blue), var(--csium-light-blue));
}

.portal-page-header-icon--dark
{
    background: linear-gradient(135deg, var(--csium-dark-blue), var(--csium-mid-blue));
}

.portal-page-header-icon--red
{
    background: linear-gradient(135deg, #b71c1c, var(--csium-red));
}

/* ---- Branded Panel Card (reusable) ---- */
.portal-panel
{
    background-color: var(--surface-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 2rem;
    position: relative;
    overflow: hidden;
}

[data-bs-theme='light'] .portal-panel
{
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
}

[data-bs-theme='dark'] .portal-panel
{
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
}

.portal-panel::before
{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--csium-dark-blue), var(--csium-blue), var(--csium-light-blue));
}

.portal-panel-title
{
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--csium-mid-blue);
    margin-bottom: 1.75rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--border-color);
}

    .portal-panel-title .material-symbols-outlined
    {
        font-size: 1.25rem;
    }

/* ---- Branded Form Controls (reusable) ---- */
.portal-field
{
    margin-bottom: 1.25rem;
}

.portal-field-row
{
    display: flex;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.portal-field--half
{
    flex: 1;
    margin-bottom: 0;
}

.portal-label
{
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 0.5rem;
}

.portal-label-icon
{
    font-size: 1.1rem;
    color: var(--csium-blue);
}

.portal-select
{
    border-radius: 10px;
    padding: 0.625rem 1rem;
    font-size: 0.95rem;
    border: 1px solid var(--border-color);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

    .portal-select:focus
    {
        border-color: var(--csium-blue);
        box-shadow: 0 0 0 3px rgba(40, 134, 196, 0.15);
    }

.portal-alert
{
    border-radius: 10px;
    margin-bottom: 1.25rem;
}

/* ---- Branded Buttons (reusable) ---- */
.portal-btn
{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    font-size: 0.95rem;
    font-weight: 600;
    border: none;
    border-radius: 50px;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.2s ease, opacity 0.2s ease;
    white-space: nowrap;
}

    .portal-btn:hover
    {
        transform: translateY(-1px);
    }

    .portal-btn:active
    {
        transform: translateY(0);
    }

    .portal-btn:disabled
    {
        opacity: 0.6;
        cursor: not-allowed;
        transform: none;
    }

    .portal-btn .material-symbols-outlined
    {
        font-size: 1.2rem;
    }

.portal-btn--primary
{
    background: linear-gradient(135deg, var(--csium-dark-blue), var(--csium-blue));
    color: #ffffff;
    box-shadow: 0 2px 8px rgba(40, 134, 196, 0.3);
}

    .portal-btn--primary:hover
    {
        box-shadow: 0 4px 16px rgba(40, 134, 196, 0.4);
        color: #ffffff;
    }

.portal-btn--outline
{
    background-color: var(--surface-card);
    color: var(--csium-mid-blue);
    border: 2px solid var(--csium-mid-blue);
}

    .portal-btn--outline:hover
    {
        background-color: var(--csium-mid-blue);
        color: #ffffff;
        box-shadow: 0 2px 8px rgba(43, 122, 181, 0.3);
    }

.portal-btn--success
{
    background: linear-gradient(135deg, #1a7f37, #2da44e);
    color: #ffffff;
    box-shadow: 0 2px 8px rgba(45, 164, 78, 0.3);
}

    .portal-btn--success:hover
    {
        box-shadow: 0 4px 16px rgba(45, 164, 78, 0.4);
        color: #ffffff;
    }

/* ---- Branded responsive form ---- */
@media (max-width: 576px)
{
    .portal-page-header-text h1
    {
        font-size: 1.35rem;
    }

    .portal-page-header-icon
    {
        width: 38px;
        height: 38px;
        min-width: 38px;
    }

        .portal-page-header-icon .material-symbols-outlined
        {
            font-size: 1.2rem;
        }

    .portal-panel
    {
        padding: 1.25rem;
        border-radius: 12px;
    }

    .portal-field-row
    {
        flex-direction: column;
        gap: 0;
    }

    .portal-field--half
    {
        margin-bottom: 1.25rem;
    }
}

/* Responsive Table CSS for Mobile Devices (from data-grid.css) */
@media screen and (max-width: 768px)
{
    .table-responsive-container table
    {
        border: 0;
    }

    .table-responsive-container thead
    {
        display: none;
    }

    .table-responsive-container tr
    {
        display: block;
        margin-bottom: 1.5rem;
        border: 1px solid var(--border-color);
        border-radius: 4px;
        box-shadow: 0 2px 4px rgba(0,0,0,0.05);
    }

    .table-responsive-container td
    {
        display: block;
        text-align: right;
        padding: 0.75rem 1rem;
        border-bottom: 1px solid #eee;
        position: relative;
    }

    [data-bs-theme='dark'] .table-responsive-container td
    {
        border-bottom: 1px solid var(--bs-gray-700);
    }

    .table-responsive-container td:last-child
    {
        border-bottom: 0;
    }

    .table-responsive-container td::before
    {
        content: attr(data-label);
        position: absolute;
        left: 1rem;
        font-weight: bold;
        text-align: left;
        white-space: nowrap;
        color: var(--bs-secondary-color);
    }
}
