/* Train Roster - Locomotive Speed Matching Tool - v3.5 - Refined */

/* THEME VARIABLES - Makes cleanup easier */
:root {
    --tr-dark-bg: #2C353E;
    --tr-medium-bg: #36414c;
    --tr-accent-yellow: #F7D500;
    --tr-border-gray: #6A7173;
    --tr-text-white: #FFFFFF;
}

/* MAIN CONTAINER STYLES */
.tr-smg-main-container {
    background: var(--tr-dark-bg) !important;
    border: 1px solid var(--tr-border-gray) !important;
    color: var(--tr-text-white) !important; 
    border-radius: 12px;
    margin: 20px auto !important;
    max-width: 1000px;
    display: block !important;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    overflow: hidden;
    box-shadow: 0 15px 35px rgba(0,0,0,0.4);
}

.tr-smg-print-header { display: none; }

/* HEADER BAR */
.tr-smg-header-bar {
    background: var(--tr-accent-yellow);
    color: var(--tr-dark-bg);
    padding: 15px;
    text-align: center;
    font-weight: 800;
    font-size: 1.2em;
    text-transform: uppercase;
    letter-spacing: 2px;
    border-bottom: 4px solid #63666A;
}

/* FORM STYLES */
.tr-smg-form-wrapper { padding: 25px; background: var(--tr-medium-bg); }
.tr-smg-input-grid { display: flex; flex-wrap: wrap; gap: 15px; align-items: flex-end; justify-content: center; }
.tr-smg-input-item label { font-size: 0.8em; color: var(--tr-accent-yellow) !important; text-transform: uppercase; margin-bottom: 8px; font-weight: 800; display: block; }
.tr-smg-input-item input, .tr-smg-input-item select { background: var(--tr-dark-bg) !important; color: var(--tr-text-white) !important; border: 2px solid var(--tr-border-gray) !important; padding: 10px !important; border-radius: 6px; font-weight: 700; }

/* BUTTONS */
.tr-smg-submit-button { background: #00519C; color: #fff; border: none; padding: 12px 35px; font-weight: 700; text-transform: uppercase; cursor: pointer; border-radius: 4px; transition: background 0.3s ease; }
.tr-smg-submit-button:hover { background: #66A3E5; }

.tr-smg-print-btn-wrapper { text-align: center; padding: 15px; background: var(--tr-medium-bg); border-top: 1px solid #444; }
.tr-smg-print-button { background: #63666A; color: white; border: 2px solid var(--tr-accent-yellow); padding: 8px 20px; font-weight: 700; text-transform: uppercase; cursor: pointer; border-radius: 4px; transition: all 0.3s ease; }
.tr-smg-print-button:hover { background: var(--tr-accent-yellow); color: var(--tr-dark-bg); }

/* RESULTS AREA */
.tr-smg-printable-area { display: flex; flex-direction: column; align-items: center; width: 100%; }

.tr-smg-results-area { text-align: center; padding: 15px 10px; background: var(--tr-dark-bg); border-top: 1px solid #444; width: 100%; }
.tr-smg-loco-header { font-size: 1.1em; color: var(--tr-accent-yellow) !important; font-weight: bold; }

/* CV Section */
.tr-smg-cv-wrapper {
    display: flex;
    justify-content: center; /* Center the whole block */
    margin: 5px 0;
}

.tr-smg-cv-container {
    display: flex;
    gap: 40px; /* Space between left and right columns */
}

.tr-smg-cv-column {
    display: flex;
    flex-direction: column;
    text-align: left; /* Left-align text inside each column */
    min-width: 200px; /* Optional: Set minimum width */
    font-size: 0.95em;
    line-height: 1.0; /* No extra space between lines */
    margin: 0;
    padding: 0;
}

/* Remove space below titles (strong) */
.tr-smg-cv-column strong {
    font-size: 1.1em;               /* Slightly larger font size */
    font-weight: 700;               /* Make it bolder */
    color: #F7D500;                /* Accent yellow color */
    margin-bottom: 1px;             /* Add some space below the title */
    text-transform: uppercase;      /* Uppercase text */
    letter-spacing: 1px;            /* Letter spacing for clarity */
    
    /* Optional: Add a background color or border for extra emphasis */
    background-color: #2C353E;      /* Dark background to contrast */
    padding: 5px;                   /* Add padding around the text */
    border-radius: 4px;             /* Rounded corners */
}

/* Remove space between span items */
.tr-smg-cv-column span {
    margin: 0 !important;  /* Zero margin */
    padding: 0 !important; /* Zero padding */
}




/* STATUS COLORS */
.tr-smg-a { color: #00FF00 !important; }
.tr-smg-b { color: #CCFF00 !important; }
.tr-smg-c { color: #00CCFF !important; }
.tr-smg-d { color: #FFA500 !important; }
.tr-smg-fail { color: #FF0000 !important; }

/* DIAGNOSTIC FOOTER */
.tr-smg-diag-footer { width: 100%; padding: 40px 20px; background: #232a31; text-align: center; border-top: 1px solid #444; }
.tr-smg-label { display: block; text-transform: uppercase; font-size: 1.2em; color: var(--tr-accent-yellow) !important; margin-bottom: 5px; font-weight: 800; letter-spacing: 1px; }
.tr-smg-big-grade-display { font-size: 7em !important; font-weight: 900; line-height: 0.9; margin: 0; text-transform: uppercase; }
.tr-smg-sub-accuracy { font-size: 1.8em; font-weight: 700; color: var(--tr-text-white) !important; margin-top: 5px; font-family: monospace; }
.tr-smg-verdict-text { margin-top: 15px; font-size: 1em; color: var(--tr-text-white); opacity: 0.8; }

.tr-smg-legal-footer { text-align: center; padding: 10px; color: var(--tr-text-white); font-size: 0.8em; font-style: italic; opacity: 0.6; }

/* LEGEND STYLES */
.tr-smg-legend-box { padding: 20px; background: var(--tr-medium-bg); border-top: 1px solid var(--tr-border-gray); }
.tr-smg-legend-header { color: var(--tr-accent-yellow) !important; font-size: 1em; font-weight: 900; text-transform: uppercase; margin-bottom: 15px; text-align: center; }
.tr-smg-legend-item { display: flex; flex-wrap: wrap; align-items: baseline; margin-bottom: 10px; font-size: 0.95em; border-left: 3px solid #63666A; padding-left: 15px; }
.tr-smg-leg-label { font-weight: 900; white-space: nowrap; margin-right: 12px; min-width: 210px; }

/* PRINT LAYOUT FIXES */
@media print {
    body { background: white !important; }
    .no-print { display: none !important; }
    .tr-smg-main-container { background: white !important; color: black !important; border: none !important; box-shadow: none !important; width: 100% !important; margin: 0 !important; }
    .tr-smg-print-header { display: block !important; padding: 20px; border-bottom: 2px solid #333; margin-bottom: 20px; }
    .tr-dynamic-logo { height: 60px !important; width: auto !important; display: inline-block; }
    .tr-print-brand-row { display: flex; justify-content: space-between; align-items: center; }
    .tr-print-brand-name { color: #000 !important; font-weight: 900; font-size: 1.5em; margin-left: 10px; }
    .tr-print-meta { color: #333 !important; font-size: 0.8em; text-align: right; }
    .tr-smg-results-area, .tr-smg-diag-footer, .tr-smg-audit-table { background: white !important; color: black !important; }
    .tr-smg-label, .tr-smg-sub-accuracy, .tr-smg-verdict-text { color: black !important; }
    .tr-smg-audit-table td, .tr-smg-audit-table th { border: 1px solid #ddd !important; color: black !important; }
    .tr-smg-audit-table th { background: #f0f0f0 !important; }
    .tr-smg-active-cell { background: #f9f9f9 !important; border: 2px solid black !important; }
    .tr-smg-a { color: #008000 !important; }
    .tr-smg-b { color: #808000 !important; }
    .tr-smg-fail { color: #b30000 !important; }
}