/* ============================================================
   Capacity Manager — Thomson Reuters Brand Stylesheet
   Brand reference: TR Brand Guidelines 2024
   ============================================================

   TR COLOR PALETTE
   ─────────────────────────────────────────────────────────────
   Primary
     TR Orange        #D64000   (mandatory in all assets)
     TR Racing Green  #123015   (pairs with orange)
     TR White         #FFFFFF

   Neutral
     TR Graphite      #212223   (body copy, headlines)
     TR Gray 1        #E5E5E5   (borders, backgrounds)
     TR Gray 2        #9F9F9F   (secondary text)
     TR Gray 3        #7A7A7A   (muted text)

   Functional alerts
     TR Alert Red     #DC0A0A   (failure / danger)
     TR Alert Green   #387C2B   (success)

   Secondary (Sky pair — openness, clarity, calm)
     TR Dark Sky      #0874E3   (links, info accents)
     TR Light Sky     #E3F1FD   (info backgrounds)

   Secondary (Gold pair — warmth, value)
     TR Dark Gold     #E9B045   (warning accents)
     TR Light Gold    #FCF2DA   (warning backgrounds)

   TYPOGRAPHY
   ─────────────────────────────────────────────────────────────
   Font: Clario (custom TR font, available on TR-issued devices)
   Fallback: 'Segoe UI', system-ui, sans-serif
   Clario Medium  → headlines, titles
   Clario Regular → body copy, captions
   ============================================================ */

/* ── CSS Custom Properties ─────────────────────────────────── */
:root {
    --tr-orange:        #D64000;
    --tr-orange-dark:   #b33600;
    --tr-orange-light:  #f5e8e3;
    --tr-green:         #123015;
    --tr-green-mid:     #1e4f22;
    --tr-green-light:   #e8f0e8;
    --tr-white:         #FFFFFF;
    --tr-graphite:      #212223;
    --tr-gray1:         #E5E5E5;
    --tr-gray2:         #9F9F9F;
    --tr-gray3:         #7A7A7A;
    --tr-alert-red:     #DC0A0A;
    --tr-alert-green:   #387C2B;
    --tr-sky-dark:      #0874E3;
    --tr-sky-light:     #E3F1FD;
    --tr-gold-dark:     #E9B045;
    --tr-gold-light:    #FCF2DA;

    /* Bootstrap override via CSS vars */
    --bs-primary:           var(--tr-orange);
    --bs-primary-rgb:       214, 64, 0;
    --bs-success:           var(--tr-alert-green);
    --bs-success-rgb:       56, 124, 43;
    --bs-danger:            var(--tr-alert-red);
    --bs-danger-rgb:        220, 10, 10;
    --bs-warning:           var(--tr-gold-dark);
    --bs-warning-rgb:       233, 176, 69;
    --bs-info:              var(--tr-sky-dark);
    --bs-info-rgb:          8, 116, 227;
    --bs-secondary:         var(--tr-gray3);
    --bs-body-color:        var(--tr-graphite);
    --bs-body-font-family:  'Clario', 'Segoe UI', system-ui, -apple-system, sans-serif;
    --bs-link-color:        var(--tr-sky-dark);
    --bs-link-hover-color:  #0560bf;
    --bs-border-color:      var(--tr-gray1);
    --bs-border-radius:     6px;
    --bs-border-radius-lg:  10px;
}

/* ── Global Typography ─────────────────────────────────────── */
body {
    font-family: 'Clario', 'Segoe UI', system-ui, -apple-system, sans-serif;
    color: var(--tr-graphite);
    background-color: #f7f7f7;
    font-size: 0.9rem;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: 'Clario', 'Segoe UI', system-ui, sans-serif;
    font-weight: 500; /* Clario Medium */
    color: var(--tr-graphite);
}

/* ── Bootstrap Primary Color Overrides ────────────────────── */
.btn-primary {
    background-color: var(--tr-orange);
    border-color: var(--tr-orange);
    color: #fff;
}
.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--tr-orange-dark);
    border-color: var(--tr-orange-dark);
    color: #fff;
}
.btn-outline-primary {
    color: var(--tr-orange);
    border-color: var(--tr-orange);
}
.btn-outline-primary:hover {
    background-color: var(--tr-orange);
    border-color: var(--tr-orange);
    color: #fff;
}

.text-primary  { color: var(--tr-orange) !important; }
/* Use rgba so Bootstrap's bg-opacity-* modifier works correctly */
.bg-primary    { background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity, 1)) !important; }
.border-primary { border-color: var(--tr-orange) !important; }

.text-success  { color: var(--tr-alert-green) !important; }
.bg-success    { background-color: rgba(var(--bs-success-rgb), var(--bs-bg-opacity, 1)) !important; }

.text-danger   { color: var(--tr-alert-red) !important; }
.bg-danger     { background-color: rgba(var(--bs-danger-rgb), var(--bs-bg-opacity, 1)) !important; }

.text-info     { color: var(--tr-sky-dark) !important; }
.bg-info       { background-color: rgba(var(--bs-info-rgb), var(--bs-bg-opacity, 1)) !important; }

.text-warning  { color: var(--tr-gold-dark) !important; }
.bg-warning    { background-color: rgba(var(--bs-warning-rgb), var(--bs-bg-opacity, 1)) !important; }

/* Success/Danger/Info/Warning subtle backgrounds */
.bg-success-subtle { background-color: #d4edce !important; }
.bg-danger-subtle  { background-color: #fad5d5 !important; }
.bg-warning-subtle { background-color: var(--tr-gold-light) !important; }
.bg-info-subtle    { background-color: var(--tr-sky-light) !important; }
.bg-primary-subtle { background-color: var(--tr-orange-light) !important; }

/* ── Navbar ────────────────────────────────────────────────── */
.navbar-tr {
    background-color: var(--tr-green);
    border-bottom: 3px solid var(--tr-orange);
    box-shadow: 0 2px 8px rgba(0,0,0,0.25);
}
.navbar-tr .navbar-brand,
.navbar-tr .nav-link {
    color: rgba(255,255,255,0.92) !important;
}
.navbar-tr .nav-link:hover {
    color: var(--tr-orange) !important;
}
.navbar-tr .navbar-brand .tr-dot {
    color: var(--tr-orange);
}
.navbar-tr .dropdown-menu {
    border: none;
    box-shadow: 0 6px 20px rgba(0,0,0,0.15);
    border-top: 3px solid var(--tr-orange);
}
.navbar-tr .dropdown-item:hover,
.navbar-tr .dropdown-item:focus {
    background-color: var(--tr-orange-light);
    color: var(--tr-orange);
}
.navbar-tr .dropdown-item.active {
    background-color: var(--tr-orange);
    color: #fff;
}

/* User avatar circle */
.user-avatar {
    width: 32px;
    height: 32px;
    background: rgba(255,255,255,0.15);
    border: 1px solid rgba(255,255,255,0.3);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 600;
    color: #fff;
}

/* ── Sidebar ────────────────────────────────────────────────── */
#sidebar-wrapper {
    background-color: var(--tr-green) !important;
    border-right: none !important;
    min-width: 220px;
    max-width: 220px;
    min-height: calc(100vh - 56px);
    transition: width 0.2s ease;
}

#sidebar-wrapper .sidebar-section-label {
    color: rgba(255,255,255,0.45);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0 0.75rem;
}

#sidebar-wrapper hr {
    border-color: rgba(255,255,255,0.12);
    margin: 0.5rem 0.75rem;
}

.sidebar-link {
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.875rem;
    padding: 0.45rem 0.75rem;
    transition: background 0.15s, color 0.15s;
    display: flex;
    align-items: center;
    text-decoration: none;
    border-radius: 6px;
}

.sidebar-link i {
    color: rgba(255,255,255,0.55);
    transition: color 0.15s;
    width: 18px;
    text-align: center;
}

.sidebar-link:hover {
    background: rgba(255,255,255,0.10);
    color: #fff !important;
}
.sidebar-link:hover i {
    color: var(--tr-orange);
}

.sidebar-link.active {
    background: var(--tr-orange) !important;
    color: #fff !important;
    font-weight: 600;
}
.sidebar-link.active i {
    color: #fff !important;
}

/* ── Layout ─────────────────────────────────────────────────── */
#wrapper {
    min-height: calc(100vh - 56px);
}

#page-content-wrapper {
    background-color: #f7f7f7;
}

/* ── Cards ──────────────────────────────────────────────────── */
.card {
    border: 1px solid var(--tr-gray1);
    border-radius: 8px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.card-header {
    border-radius: 8px 8px 0 0 !important;
    border-bottom: 1px solid var(--tr-gray1);
}

/* Orange left-border accent on cards */
.card-accent-left {
    border-left: 4px solid var(--tr-orange) !important;
}

/* ── KPI Cards ───────────────────────────────────────────────── */
.kpi-card {
    transition: transform 0.15s, box-shadow 0.15s;
    border-top: 3px solid var(--tr-orange);
}
.kpi-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(214,64,0,0.15) !important;
}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn {
    font-weight: 500;
    transition: all 0.15s ease;
}

.btn-tr-green {
    background-color: var(--tr-green);
    border-color: var(--tr-green);
    color: #fff;
}
.btn-tr-green:hover {
    background-color: var(--tr-green-mid);
    border-color: var(--tr-green-mid);
    color: #fff;
}

/* ── Tables ──────────────────────────────────────────────────── */
.table > :not(caption) > * > * {
    padding: 0.6rem 0.75rem;
}

.table thead th {
    font-weight: 600;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--tr-gray3);
    border-bottom: 2px solid var(--tr-gray1);
}

.table-hover > tbody > tr:hover > * {
    background-color: var(--tr-orange-light);
}

/* ── Badges ──────────────────────────────────────────────────── */
.badge {
    font-weight: 600;
    letter-spacing: 0.02em;
}

/* Status badges matching TR functional colors */
.badge-sobrecarga  { background-color: var(--tr-alert-red) !important; color: #fff; }
.badge-ideal       { background-color: var(--tr-alert-green) !important; color: #fff; }
.badge-subutilizacao { background-color: var(--tr-gold-dark) !important; color: #fff; }
.badge-ocioso      { background-color: var(--tr-gray3) !important; color: #fff; }

/* ── Progress Bars ───────────────────────────────────────────── */
.progress {
    border-radius: 6px;
    background-color: var(--tr-gray1);
}

.progress-bar {
    border-radius: 6px;
    transition: width 0.4s ease;
}

/* ── Alert Row Coloring (tables) ─────────────────────────────── */
.alert-row-danger  { background: rgba(220,10,10,0.04) !important; }
.alert-row-warning { background: rgba(233,176,69,0.08) !important; }
.alert-row-success { background: rgba(56,124,43,0.05) !important; }

/* ── Forms ───────────────────────────────────────────────────── */
.form-control:focus,
.form-select:focus {
    border-color: var(--tr-orange);
    box-shadow: 0 0 0 0.2rem rgba(214,64,0,0.15);
}

.form-check-input:checked {
    background-color: var(--tr-orange);
    border-color: var(--tr-orange);
}

/* ── Nav Tabs / Pills ────────────────────────────────────────── */
.nav-tabs .nav-link.active {
    color: var(--tr-orange);
    border-bottom-color: var(--tr-orange);
    font-weight: 600;
}

.nav-pills .nav-link.active {
    background-color: var(--tr-orange);
}

/* ── Links ───────────────────────────────────────────────────── */
a {
    color: var(--tr-sky-dark);
}
a:hover {
    color: #0560bf;
}

/* ── Dropzone ────────────────────────────────────────────────── */
.border-dashed {
    border-style: dashed !important;
}
.dropzone-area {
    border: 2px dashed var(--tr-orange) !important;
    background: var(--tr-orange-light);
    transition: background 0.2s;
}
.dropzone-area:hover,
.dropzone-area.dragover {
    background: #f0ddd6;
}

/* ── Chart Containers ────────────────────────────────────────── */
.chart-container {
    position: relative;
    height: 250px;
}

/* ── Heatmap ─────────────────────────────────────────────────── */
.heatmap-cell {
    transition: opacity 0.15s;
    cursor: default;
}
.heatmap-cell:hover {
    opacity: 0.75;
}

/* ── Loading Overlay ─────────────────────────────────────────── */
#loading-overlay {
    z-index: 9999;
    background: rgba(18,48,21,0.55);
}

/* ── DataTables Bootstrap integration ───────────────────────── */
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {
    background: var(--tr-orange) !important;
    border-color: var(--tr-orange) !important;
    color: #fff !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
    background: var(--tr-orange-light) !important;
    border-color: var(--tr-orange) !important;
    color: var(--tr-orange) !important;
}
.dt-buttons .btn {
    border-color: var(--tr-orange);
    color: var(--tr-orange);
}
.dt-buttons .btn:hover {
    background-color: var(--tr-orange);
    color: #fff;
}

/* ── TR Brand Orange accent line (top of page content) ──────── */
.page-content-header {
    border-left: 4px solid var(--tr-orange);
    padding-left: 0.75rem;
}

/* ── Responsive Sidebar ──────────────────────────────────────── */
@media (max-width: 768px) {
    #sidebar-wrapper {
        display: none !important;
    }
    #page-content-wrapper {
        width: 100%;
    }
}

/* ── Print ───────────────────────────────────────────────────── */
@media print {
    #sidebar-wrapper,
    .navbar,
    .btn,
    .no-print {
        display: none !important;
    }
    #page-content-wrapper {
        padding: 0 !important;
    }
}
