/* ==========================================================================
   MEDiscuss CDSS Master Stylesheet v8.1 (Unified Architecture & App Mode)
   Architecture: Adaptive Grid, Pure iOS, Strict Theme Overrides
   ========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Merriweather:wght@400;700;900&display=swap');

:root {
    --mc-primary: #800000; --mc-primary-hover: #660000; --mc-gold: #d97706; --mc-blue: #007aff;
    --mc-bg-app: #f2f2f7; --mc-bg-card: #ffffff; --mc-bg-pill: #e5e5ea;
    --mc-dark: #1c1c1e; --mc-text-main: #3a3a3c; --mc-text-muted: #8e8e93;
    --mc-border-light: #e5e5ea; --mc-border: #d1d1d6;
    --mc-shadow-sm: 0 1px 2px rgba(0,0,0,0.04); --mc-shadow-card: 0 4px 12px rgba(0,0,0,0.05); --mc-shadow-pill: 0 3px 8px rgba(0,0,0,0.12);
}

#mc-core-app, #mc-core-app * { box-sizing: border-box !important; }
#mc-core-app, #mc-core-app p, #mc-core-app span, #mc-core-app div, #mc-core-app li, #mc-core-app a, #mc-core-app details, #mc-core-app summary, #mc-core-app input, #mc-core-app select, #mc-core-app button, #mc-core-app label { font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, Helvetica, Arial, sans-serif !important; }

#mc-core-app .mc-header { background: linear-gradient(135deg, var(--mc-primary), #4a0000); padding: 28px 24px; text-align: center; color: #fff; position: relative;}
#mc-core-app .mc-title, #mc-core-app .mc-heading, #mc-core-app .mc-heading-lg, #mc-core-app .mc-pearl-title { font-family: 'Merriweather', serif !important; display: block; }
#mc-core-app .mc-title { font-size: 24px !important; font-weight: 900; margin-bottom: 6px; color: #fff !important; }
#mc-core-app .mc-subtitle { font-size: 15px; font-weight: 400; color: #fff !important; display: block; }

/* ==========================================================================
   SEO HEADING RESET (Added for v7.0/v8.2 architecture)
   Ensures H1, H2, H3 tags do not inherit unwanted browser default margins
   ========================================================================== */
#mc-core-app h1.mc-title, 
#mc-core-app h2.mc-heading, 
#mc-core-app h2.mc-heading-lg, 
#mc-core-app h3.mc-pearl-title {
    margin-top: 0 !important;
    line-height: 1.3 !important;
}
/* ==========================================================================
   GLOBAL LIST ALIGNMENT FIX
   Ensures all lists remain left-aligned even inside centered result cards
   ========================================================================== */
#mc-core-app ul, 
#mc-core-app ol li {
    text-align: left !important;
    width: 100% !important; /* Forces the list block to span the full container width */
    padding-left: 24px !important; /* Ensures bullets have breathing room from the left edge */
    box-sizing: border-box !important;
}

#mc-core-app li {
    text-align: left !important;
}
#mc-core-app .mc-pearl-title { font-size: 17px !important; font-weight: 700; color: var(--mc-dark) !important; margin-top: 24px; margin-bottom: 8px; }
#mc-core-app .mc-pearl-text { font-size: 15px !important; color: var(--mc-text-main) !important; line-height: 1.6 !important; margin-top: 0; margin-bottom: 16px; }
#mc-core-app .mc-card ul, #mc-core-app .mc-card ol { padding-left: 20px !important; margin-top: 8px !important; margin-bottom: 16px !important; }
#mc-core-app .mc-card li { font-size: 15px !important; color: var(--mc-text-main) !important; line-height: 1.6 !important; margin-bottom: 8px !important; }

/* ==========================================================================
   MANUAL DARK MODE (ROOT & FORTRESS)
   ========================================================================== */
#mc-core-app.mc-dark-mode {
    --mc-primary: #ff5252; --mc-primary-hover: #ff7675; --mc-blue: #0a84ff;
    --mc-bg-app: #121212; --mc-bg-card: #1e1e1e; --mc-bg-pill: #2c2c2e;
    --mc-dark: #ffffff; --mc-text-main: #ebebf5; 
    --mc-text-muted: #a1a1aa; 
    --mc-border-light: #2c2c2e; --mc-border: #38383a; --mc-shadow-card: 0 4px 12px rgba(0,0,0,0.4);
}

#mc-core-app.mc-dark-mode .mc-header { background: #1e1e1e !important; border-bottom: 1px solid var(--mc-border); }
#mc-core-app.mc-dark-mode .mc-title { color: #fff !important; }
#mc-core-app.mc-dark-mode .mc-icon-moon { display: none !important; }
#mc-core-app.mc-dark-mode .mc-icon-sun { display: block !important; }

#mc-core-app.mc-dark-mode p[style], #mc-core-app.mc-dark-mode span[style], #mc-core-app.mc-dark-mode font[style], #mc-core-app.mc-dark-mode div[style], #mc-core-app.mc-dark-mode li { color: var(--mc-text-main) !important; }
#mc-core-app.mc-dark-mode .mc-result-white-box, #mc-core-app.mc-dark-mode .mc-result-white-box[style], #mc-core-app.mc-dark-mode .mc-result-card, #mc-core-app.mc-dark-mode .mc-result-card[style] { background: rgba(255,255,255,0.05) !important; border-color: var(--mc-border) !important; color: var(--mc-text-main) !important; }
#mc-core-app.mc-dark-mode .mc-result-desc, #mc-core-app.mc-dark-mode .mc-result-desc * { color: var(--mc-text-main) !important; }

.mc-theme-toggle { position: absolute !important; top: 16px !important; right: 16px !important; background: rgba(255, 255, 255, 0.15) !important; border: none !important; border-radius: 50% !important; width: 36px !important; height: 36px !important; display: flex !important; align-items: center !important; justify-content: center !important; color: #fff !important; cursor: pointer !important; padding: 0 !important; outline: none !important; box-shadow: none !important; z-index: 10; transition: all 0.2s; }
.mc-theme-toggle:hover { background: rgba(255, 255, 255, 0.3) !important; transform: scale(0.95); }
.mc-theme-toggle svg { width: 20px !important; height: 20px !important; fill: none !important; stroke: currentColor !important; border: none !important; background: transparent !important; }
.mc-icon-moon { display: block !important; }
.mc-icon-sun { display: none !important; }

/* ==========================================================================
   LAYOUT, GRID, SEPARATORS & CLEAR BUTTON
   ========================================================================== */
#mc-core-app { 
    width: 100%; 
    max-width: 800px; 
    margin: 20px auto; 
    background: var(--mc-bg-app); 
    border-radius: 20px !important; 
    box-shadow: var(--mc-shadow-card) !important; 
    overflow: hidden; 
    color: var(--mc-text-main); 
    line-height: 1.5; 
    font-size: 16px; 
}

.mc-body { padding: 0 16px 24px 16px; }
.mc-card { position: relative; background: var(--mc-bg-card); border: none !important; border-radius: 16px !important; padding: 24px; margin-bottom: 20px; box-shadow: var(--mc-shadow-card) !important; width: 100%; }

.mc-btn-clear { position: absolute; top: 20px; right: 20px; background: transparent !important; color: var(--mc-text-muted) !important; font-size: 13px !important; padding: 6px 14px !important; border: 1px solid var(--mc-border) !important; border-radius: 8px !important; font-weight: 600 !important; cursor: pointer; transition: all 0.2s; z-index: 10; box-shadow: none !important;}
.mc-btn-clear:hover { background: var(--mc-bg-pill) !important; color: var(--mc-dark) !important; }
#mc-core-app.mc-dark-mode .mc-btn-clear { color: #71717a !important; border-color: #38383a !important; }
#mc-core-app.mc-dark-mode .mc-btn-clear:hover { color: #ebebf5 !important; background: rgba(255,255,255,0.1) !important; }

.mc-divider { height: 1px; background: var(--mc-border-light); width: 100%; margin: 24px 0; border: none; }
.mc-heading, .mc-heading-lg { font-size: 19px !important; font-weight: 700; color: var(--mc-dark) !important; margin-bottom: 14px; border-bottom: 2px solid var(--mc-gold); padding-bottom: 8px; padding-right: 80px; }
.mc-row { display: flex; flex-direction: column; gap: 16px; margin-bottom: 20px; }
.mc-field { flex: 1; }
.mc-v-stack { display: flex; flex-direction: column; gap: 12px; }

@media (min-width: 600px) { .mc-row { flex-direction: row; } .mc-v-stack-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; } .mc-segmented-control { max-width: 400px; } }

/* ==========================================================================
   SEAMLESS STICKY TABS & TOOLTIPS
   ========================================================================== */
.mc-tabs-container { position: sticky; top: 0; z-index: 50; background: var(--mc-bg-app); padding: 24px 16px 8px 16px; margin: 0; }
.mc-tabs { display: flex; background: rgba(0,0,0,0.06) !important; border-radius: 10px !important; padding: 4px; border: none !important; margin: 0 auto; max-width: 500px; } 
.mc-tab { flex: 1; padding: 8px 10px; background: transparent; border: none !important; border-radius: 8px !important; font-size: 15px !important; font-weight: 600 !important; color: var(--mc-text-muted) !important; cursor: pointer; transition: all 0.2s; outline: none; }
.mc-tab.active { background: #ffffff !important; color: var(--mc-dark) !important; box-shadow: var(--mc-shadow-pill) !important; font-weight: 700 !important; }
.mc-panel { display: none; animation: mcFadeIn 0.3s ease; padding-top: 16px; }
.mc-panel.active { display: block; }
@keyframes mcFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

#mc-core-app.mc-dark-mode .mc-tabs { background: rgba(255,255,255,0.1) !important; }
#mc-core-app.mc-dark-mode .mc-tab { color: rgba(255,255,255,0.5) !important; background: transparent !important; box-shadow: none !important; }
#mc-core-app.mc-dark-mode .mc-tab.active { background: #3a3a3c !important; color: #ffffff !important; box-shadow: 0 2px 8px rgba(0,0,0,0.5) !important; }

.mc-tooltip-trigger { display: inline-flex; align-items: center; justify-content: center; width: 16px; height: 16px; border-radius: 50%; background: var(--mc-bg-pill); color: var(--mc-text-muted); font-size: 11px; font-weight: 800; margin-left: 6px; cursor: help; position: relative; vertical-align: middle; }
.mc-tooltip-trigger::after { content: attr(data-tooltip); position: absolute; bottom: 130%; left: 50%; transform: translateX(-50%); width: max-content; max-width: 220px; padding: 8px 12px; background: #1c1c1e !important; color: #ffffff !important; font-size: 12px; font-weight: 500; border-radius: 8px; box-shadow: 0 4px 12px rgba(0,0,0,0.3) !important; opacity: 0; pointer-events: none; transition: opacity 0.2s; z-index: 9999; text-transform: none; line-height: 1.4; text-align: center; }
.mc-tooltip-trigger:hover::after, .mc-tooltip-trigger:focus::after { opacity: 1; }
.mc-tooltip-trigger:focus { outline: 2px solid var(--mc-blue); outline-offset: 2px; }
#mc-core-app.mc-dark-mode .mc-tooltip-trigger::after { background: #f2f2f7 !important; color: #1c1c1e !important; box-shadow: 0 4px 12px rgba(0,0,0,0.8) !important; }

/* ==========================================================================
   INPUTS, LABELS & RADIO/CHECKBOX CARDS
   ========================================================================== */
.mc-label { display: block; font-size: 13px; font-weight: 700; color: var(--mc-text-muted) !important; margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.5px; }
.mc-label span, .mc-label font { color: inherit !important; font-weight: normal !important; text-transform: none !important; opacity: 0.7; letter-spacing: 0; margin-left: 4px;}
#mc-core-app.mc-dark-mode .mc-label { color: #d1d1d6 !important; }

.mc-input-wrapper { position: relative; display: flex; align-items: center; width: 100%; }
.mc-input-wrapper .mc-input { padding-right: 48px !important; }
.mc-input-unit { position: absolute; right: 16px; color: var(--mc-text-muted); font-size: 15px; font-weight: 600; pointer-events: none; }
.mc-input, .mc-select { width: 100%; padding: 14px 16px; border: 1px solid var(--mc-border) !important; border-radius: 10px !important; font-size: 17px !important; color: var(--mc-dark) !important; background: var(--mc-bg-card) !important; min-height: 48px; box-shadow: var(--mc-shadow-sm) !important; transition: border-color 0.2s, box-shadow 0.2s; }
.mc-input:focus, .mc-select:focus { border-color: var(--mc-primary) !important; outline: none; box-shadow: 0 0 0 3px rgba(128,0,0,0.1) !important; }
input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
input[type="number"] { -moz-appearance: textfield; }

.mc-select { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%238e8e93%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E") !important; background-repeat: no-repeat !important; background-position: right 16px top 50% !important; background-size: 12px auto !important; }

/* Hide native inputs inside custom UI controls */
.mc-segmented-control input[type="radio"], .mc-v-card input[type="radio"], .mc-v-card input[type="checkbox"], .mc-v-stack input[type="radio"] { position: absolute !important; opacity: 0 !important; width: 0 !important; height: 0 !important; margin: 0 !important; pointer-events: none !important; appearance: none !important; }
.mc-btn:active, .mc-segment-btn:active, .mc-v-card:active { transform: scale(0.97); transition: transform 0.1s !important; }

.mc-segmented-control { display: flex !important; align-items: stretch !important; background: var(--mc-bg-pill) !important; border-radius: 10px !important; padding: 4px !important; width: 100% !important; }
.mc-segmented-control label { flex: 1 1 0% !important; display: flex !important; margin: 0 !important; padding: 0 !important; cursor: pointer !important; width: 100% !important; }
.mc-segment-btn { width: 100% !important; flex: 1 1 0% !important; text-align: center !important; padding: 10px 8px !important; border-radius: 8px !important; font-size: 15px !important; font-weight: 500 !important; color: var(--mc-text-muted) !important; cursor: pointer !important; transition: all 0.2s !important; min-height: 44px !important; display: flex !important; align-items: center !important; justify-content: center !important; user-select: none !important; margin: 0 !important; border: none !important; background: transparent !important; }
.mc-segmented-control input[type="radio"]:checked + .mc-segment-btn { background: var(--mc-bg-card) !important; color: var(--mc-primary) !important; box-shadow: var(--mc-shadow-pill) !important; font-weight: 700 !important; }

#mc-core-app.mc-dark-mode .mc-segment-btn { color: #71717a !important; }
#mc-core-app.mc-dark-mode .mc-segmented-control input[type="radio"]:checked + .mc-segment-btn { color: var(--mc-primary) !important; }

/* Unified styling for Radio and Checkbox cards (.mc-v-card) */
.mc-v-card { display: flex; align-items: flex-start; padding: 16px; background: var(--mc-bg-card); border: 2px solid var(--mc-border-light) !important; border-radius: 12px !important; cursor: pointer; transition: all 0.2s; user-select: none; margin: 0 !important; box-shadow: var(--mc-shadow-sm) !important; position: relative; height: 100%; }
.mc-v-radio-circle { position: relative; width: 24px; height: 24px; border-radius: 50% !important; border: 2px solid var(--mc-border) !important; margin-right: 16px; margin-top: 2px; flex-shrink: 0; background: transparent; transition: all 0.2s; }
.mc-v-card:has(input[type="radio"]:checked), .mc-v-card:has(input[type="checkbox"]:checked) { border-color: var(--mc-primary) !important; background: rgba(128, 0, 0, 0.03) !important; }
.mc-v-card input[type="radio"]:checked ~ .mc-v-radio-circle, .mc-v-card input[type="checkbox"]:checked ~ .mc-v-radio-circle { border-color: var(--mc-primary) !important; background: var(--mc-primary) !important; }
.mc-v-card input[type="radio"]:checked ~ .mc-v-radio-circle::after, .mc-v-card input[type="checkbox"]:checked ~ .mc-v-radio-circle::after { content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 10px; height: 10px; background-color: #fff !important; border-radius: 50% !important; display: block !important; }

.mc-v-card-content { display: flex; flex-direction: column; }
.mc-v-title { font-size: 16px; font-weight: 700; color: var(--mc-dark); margin-bottom: 4px; }
.mc-v-desc { font-size: 13px; color: var(--mc-text-muted); line-height: 1.4; }
.mc-action-row { margin-top: 24px; margin-bottom: 24px; }

/* ==========================================================================
   ADVANCED LIST CONTROLS (.mc-check-field) - For AFib, VTE, Antimicrobial
   ========================================================================== */
.mc-check-field { display: flex !important; align-items: center !important; gap: 10px !important; padding: 12px 16px !important; background: var(--mc-bg-card) !important; border: 1px solid var(--mc-border-light) !important; border-radius: 10px !important; cursor: pointer !important; transition: all 0.2s !important; margin-bottom: 12px !important; }
.mc-check-field:hover { border-color: var(--mc-border) !important; }
.mc-check-field input[type="checkbox"] { width: 20px !important; height: 20px !important; accent-color: var(--mc-primary) !important; cursor: pointer !important; flex-shrink: 0 !important; }
.mc-check-field span { font-size: 15px !important; font-weight: 600 !important; color: var(--mc-text-main) !important; }
.mc-check-label { flex: 1 !important; }
.mc-check-pts { margin-left: auto !important; font-size: 14px !important; font-weight: 900 !important; color: var(--mc-primary) !important; flex-shrink: 0 !important; white-space: nowrap !important; }

/* Semantic variants for List Controls */
.mc-check-highlight { background: #eff6ff !important; border-color: #bfdbfe !important; }
.mc-check-highlight span { color: var(--mc-blue) !important; }
.mc-check-valvular, .mc-check-danger { background: #fef2f2 !important; border-color: #fca5a5 !important; }
.mc-check-valvular span.mc-check-label, .mc-check-danger span { color: #991b1b !important; }
.mc-check-r2 { background: #fefbf0 !important; border-color: #fde047 !important; }
.mc-check-r2 span.mc-check-label { color: #854d0e !important; }
.mc-check-success { background: #f0fdf4 !important; border-color: #86efac !important; }
.mc-check-success span:not(.mc-check-pts), .mc-check-success .mc-check-pts { color: #166534 !important; }

/* Pathway Score Tags (AFib) */
.mc-score-tag { display: inline-flex !important; align-items: center !important; font-weight: 800 !important; padding: 4px 8px !important; border-radius: 4px !important; font-size: 12px !important; white-space: nowrap !important; margin-left: auto !important; flex-shrink: 0 !important; }
.mc-score-tag + .mc-score-tag { margin-left: 4px !important; }
.mc-score-tag-stroke { color: #991b1b !important; background: #fdf2f2 !important; border: 1px solid #fca5a5 !important; }
.mc-score-tag-bleed { color: #1e3a8a !important; background: #eff6ff !important; border: 1px solid #bfdbfe !important; }

/* Dark Mode Overrides for List Controls */
#mc-core-app.mc-dark-mode .mc-check-field { background: var(--mc-bg-card) !important; border-color: var(--mc-border) !important; }
#mc-core-app.mc-dark-mode .mc-check-field span { color: var(--mc-text-main) !important; }
#mc-core-app.mc-dark-mode .mc-check-highlight { background: rgba(59, 130, 246, 0.1) !important; border-color: rgba(59, 130, 246, 0.3) !important; }
#mc-core-app.mc-dark-mode .mc-check-highlight span { color: #93c5fd !important; }
#mc-core-app.mc-dark-mode .mc-check-valvular, #mc-core-app.mc-dark-mode .mc-check-danger { background: rgba(239, 68, 68, 0.1) !important; border-color: rgba(239, 68, 68, 0.3) !important; }
#mc-core-app.mc-dark-mode .mc-check-valvular span.mc-check-label, #mc-core-app.mc-dark-mode .mc-check-danger span { color: #fca5a5 !important; }
#mc-core-app.mc-dark-mode .mc-check-r2 { background: rgba(253, 224, 71, 0.1) !important; border-color: rgba(253, 224, 71, 0.3) !important; }
#mc-core-app.mc-dark-mode .mc-check-r2 span.mc-check-label { color: #fcd34d !important; }
#mc-core-app.mc-dark-mode .mc-check-success { background: rgba(34, 197, 94, 0.1) !important; border-color: rgba(34, 197, 94, 0.3) !important; }
#mc-core-app.mc-dark-mode .mc-check-success span:not(.mc-check-pts), #mc-core-app.mc-dark-mode .mc-check-success .mc-check-pts { color: #86efac !important; }
#mc-core-app.mc-dark-mode .mc-score-tag-stroke { background: rgba(239, 68, 68, 0.15) !important; color: #fca5a5 !important; border-color: rgba(239, 68, 68, 0.3) !important; }
#mc-core-app.mc-dark-mode .mc-score-tag-bleed { background: rgba(59, 130, 246, 0.15) !important; color: #93c5fd !important; border-color: rgba(59, 130, 246, 0.3) !important; }

/* =========================================================
   DARK MODE FIX FOR TOOL RESULT BOXES
   ========================================================= */
#mc-core-app.mc-dark-mode .mc-result-box,
#mc-core-app.mc-dark-mode .mc-result-card,
#mc-core-app.mc-dark-mode .mc-result-group,
#mc-core-app.mc-dark-mode .mc-data-box {
    background-color: #1e1e1e !important;
    border-color: #38383a !important;
}

/* Ensure inner borders inside the results also turn dark */
#mc-core-app.mc-dark-mode .mc-result-box hr,
#mc-core-app.mc-dark-mode .mc-result-card hr {
    border-color: #38383a !important;
}

/* ==========================================================================
   BUTTONS & RESULTS
   ========================================================================== */
.mc-btn { display: inline-block; padding: 16px 24px; border-radius: 12px !important; font-size: 17px !important; font-weight: 700 !important; text-align: center; cursor: pointer; transition: all 0.2s; border: none !important; user-select: none; min-height: 52px; width: 100%; box-sizing: border-box; }
.mc-btn-primary { background: var(--mc-primary) !important; color: #fff !important; box-shadow: var(--mc-shadow-card) !important; }
.mc-btn-primary:disabled { background: var(--mc-border) !important; color: var(--mc-text-muted) !important; cursor: not-allowed; box-shadow: none !important; opacity: 0.7; }
.mc-btn-copy { background: var(--mc-bg-pill) !important; color: var(--mc-dark) !important; font-size: 14px !important; padding: 10px 16px !important; border-radius: 8px !important; margin-top: 16px; display: inline-flex; align-items: center; justify-content: center; width: auto; font-weight: 700 !important; border: none !important; cursor: pointer; }

/* RESULT BOXES */
.mc-result { padding: 24px; background: var(--mc-bg-card); border: none !important; border-radius: 16px !important; box-shadow: var(--mc-shadow-card) !important; margin-top: 24px; animation: mcFadeIn 0.4s ease; width: 100%; }
.mc-result-white-box { background: #ffffff !important; border: 1px solid var(--mc-border); padding: 20px; border-radius: 12px; margin-bottom: 16px; box-shadow: var(--mc-shadow-sm); }
.mc-result-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; margin-bottom: 24px; }
.mc-result-card { background: #ffffff !important; border: 1px solid var(--mc-border); border-radius: 12px; padding: 20px; text-align: center; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.mc-result-card-full { grid-column: 1 / -1; }
.mc-result-header { font-size: 14px; font-weight: 700; color: var(--mc-text-muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px; }
.mc-result-value-group { display: flex; align-items: baseline; justify-content: center; margin-bottom: 12px; }
.mc-value-lg { font-size: 36px !important; font-weight: 800 !important; color: var(--mc-dark) !important; line-height: 1; transition: color 0.3s ease; }
.mc-unit { font-size: 16px; font-weight: 600; color: var(--mc-text-muted); margin-left: 6px; }
.mc-result-desc { font-size: 13px !important; color: var(--mc-text-main) !important; margin: 0; line-height: 1.5; }
.mc-result-desc-highlight { font-weight: 700 !important; font-size: 15px !important; margin-bottom: 8px !important; }

.mc-data-row { display: flex; justify-content: space-between; align-items: center; padding: 12px 0; border-bottom: 1px dashed var(--mc-border-light); }
.mc-data-row:last-child { border-bottom: none; }
.mc-data-label { font-size: 15px; font-weight: 600; color: var(--mc-text-main); }
.mc-data-value { font-size: 16px; font-weight: 700; color: var(--mc-dark); text-align: right; }

/* ==========================================================================
   BADGES, ALERTS, & SEMANTIC COLORS
   ========================================================================== */
.mc-badge { display: inline-flex; align-items: center; justify-content: center; padding: 6px 12px; border-radius: 8px; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; }
.mc-badge-success { background: #dcfce7 !important; color: #166534 !important; }
.mc-badge-warning { background: #fef08a !important; color: #854d0e !important; }
.mc-badge-alert { background: #ffedd5 !important; color: #c2410c !important; }
.mc-badge-danger { background: #fee2e2 !important; color: #b91c1c !important; }
/* Info Badge Semantic Colors */
.mc-badge-info { background: #e5f0ff !important; color: #0056b3 !important; }
.mc-text-success { color: #166534 !important; font-weight: 700 !important; }
.mc-text-warning { color: #c2410c !important; font-weight: 700 !important; }
.mc-text-alert { color: #c2410c !important; font-weight: 700 !important; }
.mc-text-danger { color: #b91c1c !important; font-weight: 700 !important; }
.mc-text-info { color: var(--mc-blue) !important; font-weight: 700 !important; }

#mc-core-app.mc-dark-mode .mc-text-success { color: #4ade80 !important; }
#mc-core-app.mc-dark-mode .mc-text-warning { color: #fb923c !important; }
#mc-core-app.mc-dark-mode .mc-text-alert { color: #fdba74 !important; }
#mc-core-app.mc-dark-mode .mc-text-danger { color: #f87171 !important; }
#mc-core-app.mc-dark-mode .mc-text-info { color: #60a5fa !important; }
#mc-core-app.mc-dark-mode .mc-badge-info { background: rgba(59, 130, 246, 0.15) !important; color: #93c5fd !important; }


/* Pure iOS Alerts */
.mc-alert, .mc-alert[style], div[style*="border-left"] { padding: 16px; border-radius: 12px !important; font-size: 15px; margin-bottom: 20px; line-height: 1.6; border: 1px solid var(--mc-border) !important; border-left: none !important; }
.mc-alert-info, .mc-alert-info[style] { background: #e5f0ff !important; color: #0056b3 !important; }
.mc-alert-success, .mc-alert-success[style] { background: #f0fdf4 !important; color: #14532d !important; }
.mc-alert-warning, .mc-alert-warning[style] { background: #fff4ce !important; color: #8a6d3b !important; }
.mc-alert-danger, .mc-alert-danger[style] { background: #ffebeb !important; color: #b30000 !important; }

#mc-core-app.mc-dark-mode .mc-alert-info, #mc-core-app.mc-dark-mode .mc-alert-info[style] { background: rgba(59, 130, 246, 0.15) !important; color: #93c5fd !important; }
#mc-core-app.mc-dark-mode .mc-alert-success, #mc-core-app.mc-dark-mode .mc-alert-success[style] { background: rgba(34, 197, 94, 0.15) !important; color: #86efac !important; }
#mc-core-app.mc-dark-mode .mc-alert-warning, #mc-core-app.mc-dark-mode .mc-alert-warning[style] { background: rgba(245, 158, 11, 0.15) !important; color: #fcd34d !important; }
#mc-core-app.mc-dark-mode .mc-alert-danger, #mc-core-app.mc-dark-mode .mc-alert-danger[style] { background: rgba(239, 68, 68, 0.15) !important; color: #fca5a5 !important; }

/* ==========================================================================
   GLOBAL TABLE STYLING
   ========================================================================== */
#mc-core-app table { width: 100%; border-collapse: collapse; margin-bottom: 20px; color: var(--mc-text-main) !important; background: transparent !important; }
#mc-core-app th, #mc-core-app td { padding: 12px; border: 1px solid var(--mc-border) !important; text-align: left; background: transparent !important; }
#mc-core-app th { background: var(--mc-bg-pill) !important; font-weight: 700; color: var(--mc-dark) !important; }
#mc-core-app.mc-dark-mode table, #mc-core-app.mc-dark-mode tr, #mc-core-app.mc-dark-mode td, #mc-core-app.mc-dark-mode th { background-color: transparent !important; }
#mc-core-app.mc-dark-mode td { color: var(--mc-text-main) !important; }

/* Mobile-Safe Table Scroll Wrapper (Added v8.1) */
.mc-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-bottom: 20px;
}
.mc-table-scroll table {
    min-width: 360px;
    margin-bottom: 0;
}
#mc-core-app.mc-dark-mode .mc-table-scroll::-webkit-scrollbar { height: 6px; }
#mc-core-app.mc-dark-mode .mc-table-scroll::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.2); border-radius: 3px; }
#mc-core-app.mc-dark-mode .mc-table-scroll::-webkit-scrollbar-track { background: transparent; }


/* ==========================================================================
   GLOBAL FOOTERS & REFERENCES
   ========================================================================== */
#mc-core-app .mc-references, #mc-core-app .mc-fixed-box { padding: 16px; border-radius: 12px !important; margin-bottom: 16px; box-shadow: var(--mc-shadow-sm) !important; background: var(--mc-bg-card); border: 1px solid var(--mc-border) !important; width: 100%; font-size: 14px; line-height: 1.6; }
#mc-core-app .mc-references summary { font-weight: 700; cursor: pointer; color: var(--mc-dark) !important; margin-bottom: 8px; outline: none; }
#mc-core-app .mc-references ol { margin: 8px 0 0 20px !important; padding: 0 !important; }
#mc-core-app .mc-references li { font-size: 13px !important; margin-bottom: 6px !important; line-height: 1.4 !important; color: var(--mc-text-main) !important; }
#mc-core-app .mc-references p { font-size: 13px !important; margin-top: 8px !important; margin-bottom: 0 !important; line-height: 1.5 !important; color: var(--mc-text-main) !important; }

#mc-core-app .mc-references h1, #mc-core-app .mc-references h2, #mc-core-app .mc-references h3, #mc-core-app .mc-references h4, #mc-core-app .mc-references h5, #mc-core-app .mc-references h6 { font-size: 14px !important; font-family: -apple-system, sans-serif !important; font-weight: 700 !important; margin: 12px 0 4px 0 !important; color: var(--mc-dark) !important; }
#mc-core-app.mc-dark-mode .mc-references h1, #mc-core-app.mc-dark-mode .mc-references h2, #mc-core-app.mc-dark-mode .mc-references h3, #mc-core-app.mc-dark-mode .mc-references h4 { color: #fff !important; }

/* ==========================================================================
   UNIFIED GLOBAL FOOTER
   ========================================================================== */
.mc-global-footer { position: relative; background: var(--mc-bg-card); border: 1px solid var(--mc-border); border-radius: 16px; margin-bottom: 24px; box-shadow: var(--mc-shadow-sm); overflow: hidden; width: 100%; }

/* The Tri-Color Glow Accent Line */
.mc-footer-accent { 
    height: 5px; 
    width: 100%; 
    background: linear-gradient(to right, #FF9933 0%, #FFFFFF 50%, #138808 100%); 
    box-shadow: 0 2px 15px rgba(255, 153, 51, 0.4), 0 2px 15px rgba(19, 136, 8, 0.4); 
    border-bottom: none; 
}

.mc-footer-content { padding: 20px; }

.mc-footer-disclaimer { font-size: 13px; color: var(--mc-text-muted); line-height: 1.5; text-align: justify; }
.mc-footer-disclaimer strong { color: var(--mc-text-main); font-weight: 700; }

.mc-footer-divider { height: 1px; background: var(--mc-border-light); width: 100%; margin: 16px 0; border: none; }

.mc-footer-copyright { text-align: center; display: flex; flex-direction: column; gap: 4px; }
.mc-footer-org { font-size: 15px; font-weight: 800; color: var(--mc-dark); }
.mc-footer-author { font-size: 13px; color: var(--mc-text-muted); }
.mc-footer-author strong { color: var(--mc-text-main); font-weight: 600; }
/* The Stealth Link */
.mc-stealth-link { color: inherit !important; text-decoration: none !important; padding: 2px 6px; margin: 0 -2px; border-radius: 6px; transition: all 0.2s ease; }
.mc-stealth-link:hover { background-color: rgba(142, 142, 147, 0.15); color: var(--mc-dark) !important; }
#mc-core-app.mc-dark-mode .mc-stealth-link:hover { background-color: rgba(255, 255, 255, 0.1); color: #ffffff !important; }

/* Bottom Navigation Actions (Integrated Aesthetic) */
.mc-bottom-nav { background: var(--mc-bg-card); border: 1px solid var(--mc-border); border-radius: 12px; margin: 0 auto 24px auto; box-shadow: var(--mc-shadow-sm); display: flex; flex-direction: column; overflow: hidden; width: 100%; transition: border-color 0.2s; }
.mc-bottom-nav:hover { border-color: var(--mc-primary); }

.mc-nav-link { display: flex; align-items: center; justify-content: center; padding: 18px 16px; font-size: 16px; font-weight: 700; color: var(--mc-dark); text-decoration: none; transition: background-color 0.2s, color 0.2s; cursor: pointer; }
.mc-nav-link svg { transition: transform 0.2s ease; }
.mc-nav-link:hover { background-color: rgba(128, 0, 0, 0.03); color: var(--mc-primary); }
.mc-nav-link:hover svg { transform: translateX(-5px); }
.mc-nav-link:active { background-color: rgba(128, 0, 0, 0.06); }

.mc-nav-divider { height: 1px; background: var(--mc-border); width: 100%; margin: 0; border: none; }

.mc-nav-link.feedback { color: var(--mc-text-muted); font-size: 14px; font-weight: 500; }
.mc-nav-link.feedback:hover { background-color: rgba(0, 0, 0, 0.02); color: var(--mc-text-main); }

/* =========================================================
   DARK MODE OVERRIDES FOR FOOTER
   ========================================================= */
#mc-core-app.mc-dark-mode .mc-global-footer, #mc-core-app.mc-dark-mode .mc-bottom-nav { background-color: #1e1e1e !important; border-color: #38383a !important; }
#mc-core-app.mc-dark-mode .mc-footer-accent { border-bottom-color: #38383a !important; }
#mc-core-app.mc-dark-mode .mc-footer-divider, #mc-core-app.mc-dark-mode .mc-nav-divider { background-color: #2c2c2e !important; }
#mc-core-app.mc-dark-mode .mc-footer-org { color: #ffffff !important; }
#mc-core-app.mc-dark-mode .mc-footer-disclaimer, #mc-core-app.mc-dark-mode .mc-footer-author, #mc-core-app.mc-dark-mode .mc-nav-link.feedback { color: #a1a1aa !important; }
#mc-core-app.mc-dark-mode .mc-footer-disclaimer strong, #mc-core-app.mc-dark-mode .mc-footer-author strong { color: #ebebf5 !important; }
#mc-core-app.mc-dark-mode .mc-nav-link { color: #ffffff !important; }
#mc-core-app.mc-dark-mode .mc-nav-link:hover { background-color: rgba(255, 255, 255, 0.05) !important; color: #ff7675 !important; }
#mc-core-app.mc-dark-mode .mc-nav-link:active { background-color: rgba(255, 255, 255, 0.1) !important; }
#mc-core-app.mc-dark-mode .mc-nav-link.feedback { color: #a1a1aa !important; }
#mc-core-app.mc-dark-mode .mc-nav-link.feedback:hover { background-color: rgba(255, 255, 255, 0.03) !important; color: #ebebf5 !important; }

/* =========================================================
   STYLING THE SAHRE BUTTON
   ========================================================= */
.mc-btn-share { width: 100%; display: flex; align-items: center; justify-content: center; padding: 16px; margin-bottom: 24px; background: linear-gradient(135deg, var(--mc-primary), #4a0000); color: #fff; border: none; border-radius: 12px; font-size: 16px; font-weight: 700; cursor: pointer; box-shadow: 0 4px 15px rgba(128, 0, 0, 0.3); transition: transform 0.2s; font-family: -apple-system, sans-serif; }
.mc-btn-share:active { transform: scale(0.98); }

/* ==========================================================================
   SUPPLEMENTARY CSS: Rabies PEP Vaccination Pathway
   Required by: rabies-pep-module.html
   Inject into: mediscuss-cdss.css (after the existing .mc-result-card rules)
   ========================================================================== */

/* Full-width result card spanning entire grid row */
.mc-result-card-full {
    grid-column: 1 / -1;
}

/* Highlighted result description (bold, slightly larger, spaced) */
.mc-result-desc-highlight {
    font-weight: 700 !important;
    font-size: 15px !important;
    margin-bottom: 8px !important;
}

/* Bottom breathing room for the primary action button */
.mc-action-row {
    margin-bottom: 24px;
}

/* Muted text within table cells (for manufacturer attribution) */
.mc-text-muted {
    color: var(--mc-text-muted) !important;
    font-weight: 400 !important;
    font-size: 12px !important;
}

@media print {
    @page { margin: 1cm; } body * { visibility: hidden; }
    .mc-wrapper.mc-app-mode { position: relative !important; height: auto !important; width: 100% !important; overflow: visible !important; box-shadow: none !important; }
    #mc-core-app, #mc-core-app * { visibility: visible; }
    #mc-core-app { background: #fff !important; color: #000 !important; }
    .mc-tabs-container, .mc-btn, .mc-theme-toggle, .mc-bottom-nav, .mc-btn-clear, .mc-btn-copy, .mc-tooltip-trigger { display: none !important; }
    .mc-panel { display: block !important; padding-top: 0 !important; }
    .mc-result { display: block !important; border: 2px solid #000 !important; box-shadow: none !important; break-inside: avoid; }
    #res-anthro, .mc-result-white-box { display: block !important; opacity: 1 !important; visibility: visible !important; }
    .mc-result-grid { display: flex !important; flex-direction: row !important; gap: 20px !important; }
    .mc-result-card { border: 1px solid #000 !important; break-inside: avoid; }
}