﻿/* 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;
}

/* 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);
    }
}
