:root{}

body{
    background:var(--bg);
    font-family:'Cairo',sans-serif;
    color:var(--text);
}

.main-shell{
    min-height:100vh;
    display:flex;
    flex-direction:column;
}

.page-wrap{
    padding:30px 0;
    flex:1;
}

.page-container{
    width:95%;
    max-width:1400px;
    margin:auto;
}

.app-footer{
    padding:0 0 24px;
}

.app-footer-text{
    margin:0;
    text-align:center;
    color:var(--muted);
    font-size:13px;
    font-weight:600;
    letter-spacing:.04em;
}

.app-navbar{
    background:var(--navbar-bg);
    box-shadow:var(--shadow);
    border-bottom:1px solid #eee;
}

.brand-wrap{
    display:flex;
    gap:12px;
    align-items:center;
}

.brand-mark{
    width:46px;
    height:46px;
    background:var(--brand-soft);
    border-radius:12px;
    display:flex;
    align-items:center;
    justify-content:center;
    color:var(--brand);
}

.brand-title{
    margin:0;
    font-weight:800;
}

.brand-subtitle{
    margin:0;
    font-size:12px;
    color:var(--muted);
}

.nav-pills-wrap{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.nav-chip{
    background:#f1f5f9;
    padding:8px 14px;
    border-radius:999px;
    text-decoration:none;
    color:#334155;
    font-weight:600;
    transition:.2s;
}

.nav-chip:hover{
    background:#e2e8f0;
}

.nav-chip.is-active{
    background:var(--brand);
    color:white;
}

.nav-chip-danger{
    background:#fde8e8;
    color:#b91c1c;
}

.card{
    border:none;
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    background:var(--card);
    color:var(--text);
    border:1px solid rgba(148,163,184,.2);
}

.section-title{
    font-weight:800;
    margin-bottom:15px;
}

.table-shell{
    overflow:hidden;
}

.table{
    --bs-table-bg: transparent;
    --bs-table-color: var(--text);
    --bs-table-border-color: rgba(148,163,184,.28);
    --bs-table-hover-bg: rgba(148,163,184,.12);
    --bs-table-hover-color: var(--text);
    --bs-table-active-bg: rgba(148,163,184,.16);
    --bs-table-active-color: var(--text);
    color:var(--text);
}

.table > :not(caption) > * > *{
    background-color:transparent;
    color:var(--text);
    border-bottom-color:rgba(148,163,184,.28);
}

.table thead th{
    color:var(--muted);
    font-weight:700;
}

.table-responsive{
    border:1px solid rgba(148,163,184,.22);
    border-radius:calc(var(--radius) - 4px);
}

.btn-brand{
    background:var(--brand);
    color:white;
    border-radius:10px;
}

.btn-brand:hover{
    background:#163a5c;
}

.btn-soft-primary,
.btn-soft-secondary,
.btn-soft-danger{
    border-radius:10px;
    transition:background-color .2s, border-color .2s, color .2s, box-shadow .2s;
}

.btn-soft-primary{
    color:var(--brand);
    background-color:color-mix(in srgb, var(--brand) 14%, var(--card));
    border-color:color-mix(in srgb, var(--brand) 28%, var(--card));
    --bs-btn-color: color-mix(in srgb, var(--brand) 82%, black);
    --bs-btn-bg: color-mix(in srgb, var(--brand) 14%, var(--card));
    --bs-btn-border-color: color-mix(in srgb, var(--brand) 28%, var(--card));
    --bs-btn-hover-color: color-mix(in srgb, var(--brand) 88%, black);
    --bs-btn-hover-bg: color-mix(in srgb, var(--brand) 20%, var(--card));
    --bs-btn-hover-border-color: color-mix(in srgb, var(--brand) 42%, var(--card));
    --bs-btn-active-color: color-mix(in srgb, var(--brand) 90%, black);
    --bs-btn-active-bg: color-mix(in srgb, var(--brand) 24%, var(--card));
    --bs-btn-active-border-color: color-mix(in srgb, var(--brand) 50%, var(--card));
}

.btn-soft-secondary{
    color:var(--text);
    background-color:color-mix(in srgb, var(--muted) 12%, var(--card));
    border-color:color-mix(in srgb, var(--muted) 26%, var(--card));
    --bs-btn-color: var(--text);
    --bs-btn-bg: color-mix(in srgb, var(--muted) 12%, var(--card));
    --bs-btn-border-color: color-mix(in srgb, var(--muted) 26%, var(--card));
    --bs-btn-hover-color: var(--text);
    --bs-btn-hover-bg: color-mix(in srgb, var(--muted) 18%, var(--card));
    --bs-btn-hover-border-color: color-mix(in srgb, var(--muted) 36%, var(--card));
    --bs-btn-active-color: var(--text);
    --bs-btn-active-bg: color-mix(in srgb, var(--muted) 22%, var(--card));
    --bs-btn-active-border-color: color-mix(in srgb, var(--muted) 42%, var(--card));
}

.btn-soft-danger{
    color:var(--danger);
    background-color:color-mix(in srgb, var(--danger) 14%, var(--card));
    border-color:color-mix(in srgb, var(--danger) 30%, var(--card));
    --bs-btn-color: color-mix(in srgb, var(--danger) 84%, black);
    --bs-btn-bg: color-mix(in srgb, var(--danger) 14%, var(--card));
    --bs-btn-border-color: color-mix(in srgb, var(--danger) 30%, var(--card));
    --bs-btn-hover-color: color-mix(in srgb, var(--danger) 90%, black);
    --bs-btn-hover-bg: color-mix(in srgb, var(--danger) 20%, var(--card));
    --bs-btn-hover-border-color: color-mix(in srgb, var(--danger) 42%, var(--card));
    --bs-btn-active-color: color-mix(in srgb, var(--danger) 92%, black);
    --bs-btn-active-bg: color-mix(in srgb, var(--danger) 24%, var(--card));
    --bs-btn-active-border-color: color-mix(in srgb, var(--danger) 52%, var(--card));
}

.badge-soft{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:.45rem .7rem;
    border-radius:999px;
    font-size:.82rem;
    font-weight:700;
    border:1px solid transparent;
}

.badge-soft-primary{
    color:color-mix(in srgb, var(--brand) 82%, black);
    background:color-mix(in srgb, var(--brand) 14%, var(--card));
    border-color:color-mix(in srgb, var(--brand) 28%, var(--card));
}

.badge-soft-secondary{
    color:var(--text);
    background:color-mix(in srgb, var(--muted) 12%, var(--card));
    border-color:color-mix(in srgb, var(--muted) 24%, var(--card));
}

.badge-soft-success{
    color:#1f6b3a;
    background:#eaf7ee;
    border-color:#b8dfc2;
}

.badge-soft-warning{
    color:#7a5a00;
    background:#fff6db;
    border-color:#f3df9b;
}

.badge-soft-danger{
    color:color-mix(in srgb, var(--danger) 84%, black);
    background:color-mix(in srgb, var(--danger) 14%, var(--card));
    border-color:color-mix(in srgb, var(--danger) 30%, var(--card));
}


/* ===== Reports Metrics ===== */

.metrics-link{
    text-decoration:none;
    display:block;
}

.metrics-card{
    background:var(--card);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    padding:22px;
    text-align:center;
    transition:.2s;
    height:100%;
}

.metrics-card:hover{
    transform:translateY(-3px);
}

.metrics-card.metrics-warning{
    background:#fff6db;
    border:1px solid #f3df9b;
}

.metrics-card.metrics-warning .metrics-label,
.metrics-card.metrics-warning .metrics-value{
    color:#7a5a00;
}

.metrics-card.metrics-success{
    background:#eaf7ee;
    border:1px solid #b8dfc2;
}

.metrics-card.metrics-success .metrics-label,
.metrics-card.metrics-success .metrics-value{
    color:#1f6b3a;
}

.metrics-card.metrics-danger{
    background:#fdecec;
    border:1px solid #efb5b5;
}

.metrics-card.metrics-danger .metrics-label,
.metrics-card.metrics-danger .metrics-value{
    color:#a63a3a;
}

.metrics-label{
    font-size:14px;
    color:var(--muted);
    margin-bottom:6px;
    font-weight:600;
}

.metrics-value{
    font-size:28px;
    font-weight:800;
    line-height:1.1;
    color:var(--brand);
}
