/* --- Brand tokens (shared across all TBV tools) --- */
:root {
    --primary: #1a365d;
    --primary-light: #2b6cb0;
    --accent: #e53e3e;
    --accent-gold: #C4A55A;
    --text-primary: #1a202c;
    --text-secondary: #4a5568;
    --text-light: #ffffff;
    --bg-page: #edf2f7;
    --bg-surface: #f7fafc;
    --bg-card: #ffffff;
    --border-color: #cbd5e0;
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.06);
    --shadow-md: 0 4px 6px rgba(0,0,0,0.07), 0 2px 4px rgba(0,0,0,0.06);
    --shadow-lg: 0 10px 25px rgba(0,0,0,0.1), 0 4px 10px rgba(0,0,0,0.05);
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 14px;
    --green: #276749;
    --green-light: #38a169;
    --warning-bg: #fffaf0;
    --warning-border: #ed8936;
}

*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    background-color: var(--bg-page);
    color: var(--text-primary);
    margin: 0;
    padding: 24px;
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
}

/* --- Header --- */
.header-container { text-align: center; margin-bottom: 32px; }
.brand-header { margin-bottom: 8px; position: relative; }
.home-btn {
    position: absolute; left: 0; top: 50%;
    transform: translateY(-50%);
    display: inline-block;
    padding: 8px 20px;
    background-color: var(--primary);
    color: var(--text-light);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.85em;
    border-radius: var(--radius-sm);
    letter-spacing: 0.03em;
    transition: background-color 0.2s ease, box-shadow 0.2s ease;
}
.home-btn:hover { background-color: var(--primary-light); box-shadow: var(--shadow-sm); }
.brand-name { font-size: 1.6em; font-weight: 800; letter-spacing: -0.02em; }
.brand-the, .brand-better { color: var(--primary); }
.brand-veteran { color: var(--accent-gold); }

h1 { text-align: center; color: var(--primary); margin-bottom: 8px; font-size: 1.9em; letter-spacing: -0.02em; }
.tool-subtitle { font-size: 1em; color: var(--text-secondary); margin: 0; max-width: 720px; margin-left: auto; margin-right: auto; line-height: 1.5; }
h2 { color: var(--primary); border-bottom: 2px solid var(--primary-light); padding-bottom: 12px; margin-top: 0; font-size: 1.15em; letter-spacing: -0.01em; }
h3 { color: var(--primary); margin-top: 0; font-size: 1.05em; letter-spacing: -0.01em; }

/* --- Section containers --- */
.section-container {
    background-color: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: 24px 28px;
    margin-bottom: 24px;
    box-shadow: var(--shadow-md);
}

.intro-section p { font-size: 1em; color: var(--text-secondary); line-height: 1.65; margin: 0; }

/* --- Build notice (temporary v1.0 banner) --- */
.build-notice {
    background-color: var(--warning-bg);
    border-left: 4px solid var(--warning-border);
    border-radius: var(--radius-md);
    padding: 14px 18px;
    margin-bottom: 24px;
    font-size: 0.95em;
    color: #744210;
    line-height: 1.5;
}

/* --- Step header --- */
.step-header { margin-bottom: 24px; }
.step-number {
    display: inline-block;
    background-color: var(--accent-gold);
    color: var(--primary);
    padding: 4px 12px;
    border-radius: var(--radius-sm);
    font-weight: 700;
    font-size: 0.8em;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 8px;
}
.step-header h2 { border-bottom: 2px solid var(--primary-light); padding-bottom: 12px; margin-top: 8px; }
.step-subtitle { color: var(--text-secondary); font-size: 0.95em; line-height: 1.5; margin: 8px 0 0 0; }

/* --- Form rows --- */
.form-row { margin-bottom: 22px; }
.form-row label:not(.checkbox-label):not(.radio-card):not(.option-card) {
    display: block;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 8px;
    font-size: 0.95em;
}
.form-hint {
    color: var(--text-secondary);
    font-size: 0.85em;
    margin: 6px 0 0 0;
    line-height: 1.45;
}
.form-hint a { color: var(--primary-light); text-decoration: none; }
.form-hint a:hover { text-decoration: underline; }
.optional { color: var(--text-secondary); font-weight: 400; font-size: 0.88em; }
.pref-label { color: var(--primary); margin: 0 0 6px 0; font-size: 1em; }
.pref-hint { color: var(--text-secondary); font-size: 0.9em; margin: 0 0 12px 0; line-height: 1.45; }

/* --- Input fields --- */
input[type="number"], input[type="email"], select {
    width: 100%;
    padding: 12px 14px;
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    font-size: 1em;
    font-family: inherit;
    background-color: var(--bg-surface);
    color: var(--text-primary);
}
input[type="number"]:focus, input[type="email"]:focus, select:focus {
    outline: none;
    border-color: var(--primary-light);
    background-color: #fff;
}

.input-with-prefix {
    display: flex;
    align-items: stretch;
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    background-color: var(--bg-surface);
    overflow: hidden;
}
.input-with-prefix:focus-within { border-color: var(--primary-light); background-color: #fff; }
.input-with-prefix .input-prefix,
.input-with-prefix .input-suffix {
    display: flex;
    align-items: center;
    padding: 0 14px;
    font-weight: 600;
    color: var(--text-secondary);
    background-color: transparent;
}
.input-with-prefix .input-suffix { color: var(--text-secondary); font-size: 0.9em; }
.input-with-prefix input {
    flex: 1;
    border: none;
    background: transparent;
    padding: 12px 4px;
    font-size: 1em;
    font-family: inherit;
    color: var(--text-primary);
    min-width: 0;
}
.input-with-prefix input:focus { outline: none; }

/* --- Grouped form rows (checkbox + dependent inputs) --- */
.form-row-grouped {
    background-color: var(--bg-surface);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 16px 18px;
}
.form-row-sub { margin-top: 14px; padding-top: 14px; border-top: 1px dashed var(--border-color); }

/* --- Checkbox & radio labels --- */
.checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    cursor: pointer;
    font-size: 0.95em;
    line-height: 1.5;
    color: var(--text-primary);
}
.checkbox-label input[type="checkbox"] {
    margin-top: 3px;
    width: 18px;
    height: 18px;
    accent-color: var(--primary);
    flex-shrink: 0;
}

.radio-group { display: flex; flex-direction: column; gap: 10px; margin-top: 8px; }
.radio-card {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 14px;
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    cursor: pointer;
    background-color: #fff;
    transition: border-color 0.15s, background-color 0.15s;
}
.radio-card input[type="radio"] {
    margin-top: 3px;
    width: 18px;
    height: 18px;
    accent-color: var(--primary);
    flex-shrink: 0;
}
.radio-card:has(input[type="radio"]:checked) { border-color: var(--primary); background-color: #f0f6ff; }
.radio-card strong { display: block; color: var(--text-primary); font-size: 0.95em; }
.radio-card p { margin: 4px 0 0 0; font-size: 0.85em; color: var(--text-secondary); line-height: 1.4; }

/* --- Grid layouts --- */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .grid-2 { grid-template-columns: 1fr; } }

/* --- Option grids (preferences) --- */
.option-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-top: 8px;
}
.option-grid.two-col { grid-template-columns: repeat(2, 1fr); }
.option-grid.three-col { grid-template-columns: repeat(3, 1fr); }
.option-grid.four-col { grid-template-columns: repeat(4, 1fr); }
.option-grid.checkbox-grid { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 700px) {
    .option-grid,
    .option-grid.three-col,
    .option-grid.four-col,
    .option-grid.checkbox-grid { grid-template-columns: 1fr 1fr; }
    .option-grid.two-col { grid-template-columns: 1fr; }
}

.option-card {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 12px 10px;
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    cursor: pointer;
    background-color: var(--bg-surface);
    font-weight: 500;
    font-size: 0.9em;
    color: var(--text-primary);
    transition: all 0.15s ease;
    min-height: 52px;
    line-height: 1.3;
}
.option-card:hover { border-color: var(--primary-light); background-color: #fff; }
.option-card input[type="radio"],
.option-card input[type="checkbox"] { display: none; }
.option-card.selected {
    border-color: var(--primary);
    background-color: var(--primary);
    color: var(--text-light);
    box-shadow: var(--shadow-sm);
}
.option-card span { display: block; }
.option-card small {
    display: block;
    font-size: 0.78em;
    font-weight: 400;
    margin-top: 4px;
    opacity: 0.75;
    line-height: 1.3;
}
.option-card.selected small { color: rgba(255, 255, 255, 0.85); }

/* --- Submit row --- */
.submit-row { text-align: center; margin-top: 16px; }
.action-btn {
    display: inline-block;
    padding: 14px 32px;
    background-color: var(--primary);
    color: var(--text-light);
    border: none;
    border-radius: var(--radius-md);
    font-size: 1em;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s, box-shadow 0.2s;
    box-shadow: var(--shadow-sm);
    text-decoration: none;
    letter-spacing: 0.02em;
}
.action-btn:hover { background-color: var(--primary-light); box-shadow: var(--shadow-md); }
.action-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.action-btn-secondary { background-color: var(--accent-gold); color: var(--primary); }
.action-btn-secondary:hover { background-color: #b8983e; color: var(--text-light); }

.form-error { color: var(--accent); margin-top: 12px; font-size: 0.95em; min-height: 1.2em; }

/* --- VA comp auto-calc result --- */
.va-comp-result {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-top: 14px;
    padding: 12px 16px;
    background-color: #fff;
    border: 2px solid var(--accent-gold);
    border-radius: var(--radius-md);
    font-size: 1em;
}
.va-comp-label { color: var(--text-secondary); font-weight: 500; }
.va-comp-amount {
    color: var(--primary);
    font-weight: 800;
    font-size: 1.2em;
    letter-spacing: -0.01em;
}

/* --- Income total card --- */
.income-total {
    background: linear-gradient(135deg, var(--primary) 0%, #234572 100%);
    color: var(--text-light);
    border-radius: var(--radius-lg);
    padding: 24px 28px;
    margin: 28px 0 32px;
    text-align: center;
    box-shadow: var(--shadow-md);
}
.income-total-label {
    font-size: 0.9em;
    color: rgba(255,255,255,0.85);
    margin-bottom: 6px;
    letter-spacing: 0.02em;
}
.income-total-amount {
    font-size: 2.6em;
    font-weight: 800;
    color: var(--accent-gold);
    letter-spacing: -0.02em;
    line-height: 1.1;
    margin-bottom: 12px;
}
.income-breakdown {
    text-align: left;
    background-color: rgba(255,255,255,0.08);
    border-radius: var(--radius-md);
    padding: 8px 14px;
    margin-top: 10px;
}
.income-breakdown summary {
    color: var(--accent-gold);
    cursor: pointer;
    font-weight: 600;
    font-size: 0.9em;
    padding: 6px 0;
    list-style: none;
}
.income-breakdown summary::-webkit-details-marker { display: none; }
.income-breakdown summary::before { content: "▸ "; font-size: 0.8em; }
.income-breakdown[open] summary::before { content: "▾ "; }
.income-breakdown-body {
    padding: 8px 0 12px;
    border-top: 1px solid rgba(255,255,255,0.15);
    margin-top: 6px;
}
.income-line {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.9em;
    color: rgba(255,255,255,0.9);
}
.income-line strong { color: var(--text-light); }

/* --- Results --- */
.results-header { margin-bottom: 24px; }
.results-title-row { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.results-summary { color: var(--text-secondary); margin-top: 8px; line-height: 1.5; font-size: 0.95em; }
.retake-btn {
    background-color: var(--bg-surface);
    color: var(--primary);
    border: 2px solid var(--border-color);
    padding: 8px 16px;
    border-radius: var(--radius-md);
    font-weight: 600;
    cursor: pointer;
    font-size: 0.9em;
}
.retake-btn:hover { background-color: #fff; border-color: var(--primary); }

/* --- Country rank cards --- */
.country-card {
    background-color: var(--bg-card);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 20px 22px;
    margin-bottom: 16px;
    box-shadow: var(--shadow-sm);
}
.country-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 8px;
}
.country-card-title {
    display: flex;
    align-items: baseline;
    gap: 10px;
    flex-wrap: wrap;
}
.country-rank {
    background-color: var(--primary);
    color: var(--accent-gold);
    border-radius: var(--radius-sm);
    padding: 4px 10px;
    font-weight: 800;
    font-size: 0.85em;
    letter-spacing: 0.02em;
}
.country-name { font-size: 1.4em; font-weight: 800; color: var(--primary); letter-spacing: -0.01em; }
.country-tagline { color: var(--text-secondary); font-size: 0.9em; margin: 4px 0 14px 0; line-height: 1.5; }

/* Tier toggle */
.tier-toggle {
    display: inline-flex;
    background-color: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    overflow: hidden;
}
.tier-toggle button {
    background: transparent;
    border: none;
    padding: 6px 12px;
    font-size: 0.85em;
    font-weight: 600;
    cursor: pointer;
    color: var(--text-secondary);
}
.tier-toggle button.active { background-color: var(--primary); color: var(--text-light); }
.tier-toggle button:hover:not(.active) { background-color: #fff; color: var(--primary); }

/* Country data grid */
.country-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
    margin-top: 16px;
}
@media (max-width: 700px) { .country-detail-grid { grid-template-columns: 1fr; } }
.country-detail-block {
    background-color: var(--bg-surface);
    border-radius: var(--radius-md);
    padding: 12px 14px;
    border: 1px solid var(--border-color);
}
.country-detail-block h4 {
    margin: 0 0 8px 0;
    color: var(--primary);
    font-size: 0.85em;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}
.country-detail-block ul { margin: 0; padding-left: 18px; font-size: 0.9em; line-height: 1.5; color: var(--text-secondary); }
.country-detail-block ul li { margin-bottom: 4px; }
.country-detail-block .stat-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.9em;
    color: var(--text-secondary);
}
.country-detail-block .stat-row strong { color: var(--text-primary); }

/* ─── Tax treatment block — sentiment-based left border ─────────────────── */
.country-detail-block.tax-block { border-left-width: 4px; }
.country-detail-block.tax-territorial,
.country-detail-block.tax-no-income-tax { border-left-color: #2f8a4f; }                /* green — favorable */
.country-detail-block.tax-worldwide-with-program { border-left-color: #C4A55A; }       /* gold — mixed (program available) */
.country-detail-block.tax-worldwide-standard { border-left-color: #C26B36; }           /* amber — cautious */
.country-detail-block.tax-us-domestic { border-left-color: #1a365d; }                  /* navy — U.S. soil */

/* Education-benefit offset notice (shown when GI Bill / VR&E aren't usable in a country) */
.education-offset-notice {
    background-color: #fff5f5;
    border-left: 4px solid var(--accent);
    border-radius: var(--radius-md);
    padding: 12px 16px;
    margin: 12px 0;
    font-size: 0.9em;
    color: #742a2a;
    line-height: 1.5;
}
.education-offset-notice strong { color: var(--accent); }

/* Budget snapshot */
.budget-snapshot {
    background: linear-gradient(135deg, #f7fafc 0%, #fff 100%);
    border: 2px solid var(--accent-gold);
    border-radius: var(--radius-md);
    padding: 14px 18px;
    margin-top: 12px;
}
.budget-snapshot-headline {
    font-size: 1.1em;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: 8px;
}
.budget-snapshot-headline .surplus-positive { color: var(--green); }
.budget-snapshot-headline .surplus-negative { color: var(--accent); }
.budget-snapshot-detail { font-size: 0.85em; color: var(--text-secondary); line-height: 1.5; }

/* --- Schools section (per country card, static WEAMS data) --- */
.schools-section {
    margin-top: 14px;
    padding: 14px 16px;
    background-color: #fffaf0;
    border: 1px solid var(--accent-gold);
    border-radius: var(--radius-md);
}
.schools-section h4 {
    margin: 0 0 8px 0;
    color: var(--primary);
    font-size: 0.85em;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}
.schools-content { font-size: 0.9em; color: var(--text-secondary); }
.schools-content a { color: var(--primary-light); }
.schools-headline { margin: 4px 0 10px 0; font-size: 0.92em; }
.schools-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
}
.schools-list li {
    padding: 8px 12px;
    background-color: #fff;
    border: 1px solid #f0d59c;
    border-radius: var(--radius-sm);
    font-size: 0.9em;
    line-height: 1.4;
    color: var(--text-primary);
}
.schools-list .school-city { color: var(--text-secondary); font-weight: 500; }
.school-tag {
    display: inline-block;
    margin-left: 8px;
    padding: 1px 8px;
    border-radius: 4px;
    font-size: 0.72em;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    vertical-align: middle;
}
.school-tag-accredited {
    background-color: #c6f6d5;
    color: #22543d;
    position: relative;
    cursor: help;
    outline: none;
}
.school-tag-accredited:focus { box-shadow: 0 0 0 2px rgba(34, 84, 61, 0.4); }
.school-tag-yellow-ribbon {
    background-color: #fef5e7;
    color: #744210;
    border: 1px solid #d69e2e;
    position: relative;
    cursor: help;
    outline: none;
}
.school-tag-yellow-ribbon:focus { box-shadow: 0 0 0 2px rgba(214, 158, 46, 0.4); }
/* Uncapped YR is rare and HUGE — make it pop with a stronger styling */
.school-tag-yellow-ribbon-uncapped {
    background-color: #d69e2e;
    color: #fff;
    border-color: #b7791f;
    font-weight: 800;
}
.schools-yr-callout {
    background-color: #fef5e7;
    border-left: 4px solid #d69e2e;
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    margin: 6px 0 10px;
    font-size: 0.88em;
    color: #744210;
    line-height: 1.5;
}
.schools-yr-callout strong { color: #5c3414; }
.school-tag-caution {
    background-color: #fed7d7;
    color: #742a2a;
    position: relative;
    cursor: help;
    outline: none;
}
.school-tag-caution:focus { box-shadow: 0 0 0 2px rgba(116, 42, 42, 0.4); }
.school-tooltip {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: calc(100% + 8px);
    width: 320px;
    max-width: 92vw;
    padding: 12px 14px;
    background-color: #2d3748;
    color: #fff;
    border-radius: var(--radius-md);
    font-size: 0.78em;
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0;
    line-height: 1.5;
    box-shadow: var(--shadow-lg);
    z-index: 100;
    text-align: left;
    pointer-events: none;
    transition: opacity 0.15s, visibility 0.15s;
}
.school-tooltip::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: #2d3748;
}
.school-tooltip strong {
    display: block;
    color: #fed7d7;
    font-size: 0.92em;
    margin-bottom: 6px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.school-tooltip .tooltip-body {
    display: block;
    color: rgba(255, 255, 255, 0.92);
    margin-bottom: 8px;
}
.school-tooltip .tooltip-cta {
    display: block;
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.88em;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    padding-top: 6px;
    pointer-events: auto;
}
.school-tooltip .tooltip-cta a {
    color: var(--accent-gold);
    text-decoration: none;
    font-weight: 600;
    pointer-events: auto;
}
.school-tooltip .tooltip-cta a:hover { text-decoration: underline; }
.school-tag-caution:hover .school-tooltip,
.school-tag-caution:focus .school-tooltip,
.school-tag-caution:focus-within .school-tooltip {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}
@media (max-width: 600px) {
    .school-tooltip { width: 280px; }
}
.schools-footer-note { margin: 10px 0 0 0; font-size: 0.78em; color: var(--text-secondary); font-style: italic; }

/* --- Remaining countries section (loaded after matched) --- */
.remaining-header {
    margin: 28px 0 14px;
    padding: 14px 18px;
    background: linear-gradient(135deg, #f7fafc 0%, #fff 100%);
    border-left: 4px solid var(--primary-light);
    border-radius: var(--radius-md);
}
.remaining-header h3 { margin: 0 0 6px 0; color: var(--primary); font-size: 1.05em; }
.remaining-header p { margin: 0; color: var(--text-secondary); font-size: 0.9em; line-height: 1.5; }
.country-card-remaining { border-style: dashed; opacity: 0.96; }
.country-card-remaining .country-rank { background-color: var(--text-secondary); }

/* Supplemental: didn't strictly match user filters but included to hit minimum option floor */
.country-card-supplemental { border-color: var(--primary-light); border-style: dashed; }
.country-card-supplemental .country-rank { background-color: var(--primary-light); }
.supplemental-banner {
    background-color: #ebf8ff;
    border-left: 3px solid var(--primary-light);
    border-radius: var(--radius-sm);
    padding: 8px 12px;
    margin: 8px 0 12px;
    font-size: 0.85em;
    color: var(--primary);
    line-height: 1.45;
}

/* --- Pre-filled share-link banner --- */
.share-link-banner {
    background-color: #ebf8ff;
    border-left: 4px solid var(--primary-light);
    border-radius: var(--radius-md);
    padding: 12px 16px;
    margin-bottom: 20px;
    font-size: 0.95em;
    color: var(--primary);
    line-height: 1.5;
}

/* --- Compare button (on each country card) --- */
.compare-control {
    text-align: right;
    margin-top: -4px;
    margin-bottom: 8px;
}
.compare-toggle-btn {
    background: transparent;
    border: 1.5px solid var(--accent-gold);
    color: var(--primary);
    padding: 4px 12px;
    border-radius: var(--radius-sm);
    font-size: 0.82em;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.15s, color 0.15s;
}
.compare-toggle-btn:hover { background-color: var(--accent-gold); }
.compare-toggle-btn.in-cart {
    background-color: var(--primary);
    border-color: var(--primary);
    color: #fff;
}

/* --- Floating compare CTA --- */
.compare-cta {
    position: fixed;
    bottom: 16px;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--primary);
    color: #fff;
    padding: 12px 18px;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    display: flex;
    align-items: center;
    gap: 12px;
    z-index: 90;
    flex-wrap: wrap;
    max-width: 92vw;
}
.compare-cta-count { font-weight: 600; font-size: 0.95em; }
.compare-cta-clear {
    background: transparent;
    border: 1px solid rgba(255,255,255,0.4);
    color: #fff;
    padding: 4px 10px;
    border-radius: var(--radius-sm);
    font-size: 0.85em;
    cursor: pointer;
}
.compare-cta-clear:hover { background-color: rgba(255,255,255,0.15); }
.compare-cta-open {
    background-color: var(--accent-gold);
    color: var(--primary);
    border: none;
    padding: 8px 16px;
    border-radius: var(--radius-md);
    font-weight: 700;
    font-size: 0.95em;
    cursor: pointer;
}
.compare-cta-open:hover { background-color: #b8983e; color: #fff; }
.compare-cta-hint { color: rgba(255,255,255,0.7); font-size: 0.85em; }

/* --- Comparison modal --- */
.compare-modal-overlay {
    position: fixed;
    inset: 0;
    background-color: rgba(0,0,0,0.7);
    z-index: 1000;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 24px;
    overflow-y: auto;
}
.compare-modal-content {
    background-color: #fff;
    border-radius: var(--radius-lg);
    max-width: 1200px;
    width: 100%;
    margin-top: 12px;
    box-shadow: var(--shadow-lg);
    display: flex;
    flex-direction: column;
}
.compare-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 28px;
    border-bottom: 2px solid var(--bg-page);
}
.compare-modal-header h2 { margin: 0; color: var(--primary); border-bottom: none; padding-bottom: 0; }
.compare-modal-close {
    background: transparent;
    border: none;
    font-size: 1.5em;
    cursor: pointer;
    color: var(--text-secondary);
    width: 36px;
    height: 36px;
    border-radius: 50%;
}
.compare-modal-close:hover { background-color: var(--bg-page); }
.compare-modal-body { padding: 20px 28px; overflow-x: auto; }
.compare-modal-footer {
    padding: 16px 28px;
    border-top: 2px solid var(--bg-page);
    text-align: center;
}
.compare-modal-footer p { margin: 0 0 12px 0; font-size: 0.92em; color: var(--text-secondary); }
.compare-modal-footer a { color: var(--primary-light); }

/* --- Comparison table --- */
.compare-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.92em;
    table-layout: fixed;
}
.compare-table th, .compare-table td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--border-color);
    vertical-align: middle;
    text-align: center;
}
.compare-table thead th {
    background-color: var(--bg-surface);
    text-align: center;
    border-bottom: 2px solid var(--primary-light);
    min-width: 160px;
    padding: 16px 12px;
}
.compare-flag { font-size: 2em; line-height: 1; }
.compare-country-name { font-weight: 700; color: var(--primary); margin-top: 4px; font-size: 1.05em; }
.compare-tier-city { font-size: 0.85em; color: var(--text-secondary); margin-top: 2px; }
.compare-baseline-tag {
    display: inline-block;
    margin-top: 4px;
    padding: 2px 8px;
    background-color: var(--accent-gold);
    color: var(--primary);
    border-radius: var(--radius-sm);
    font-size: 0.75em;
    font-weight: 700;
}
.compare-section-header {
    background-color: var(--primary);
    color: #fff;
    text-align: center;
    font-weight: 700;
    padding: 10px 12px !important;
    letter-spacing: 0.02em;
    border-bottom: none;
    font-size: 1.05em;
}
.compare-cell {
    text-align: center;
    vertical-align: top;
}
.compare-cell .metric-label {
    font-size: 0.72em;
    color: var(--text-secondary);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 6px;
    line-height: 1.3;
}
.compare-cell .metric-value {
    font-size: 1em;
    color: var(--text-primary);
    line-height: 1.4;
}
.compare-cell .metric-value strong { font-size: 1.05em; }
.compare-cell .metric-sub {
    display: block;
    font-size: 0.78em;
    color: var(--text-secondary);
    margin-top: 4px;
    line-height: 1.35;
}
.compare-cell-baseline {
    background-color: #fff8e8;
}
.compare-cell-baseline .metric-value em {
    color: var(--primary);
    font-style: italic;
}
.best-badge {
    display: inline-block;
    margin-left: 4px;
    padding: 1px 6px;
    background-color: #d6f5e0;
    color: var(--green);
    border-radius: var(--radius-sm);
    font-size: 0.7em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    vertical-align: middle;
}

/* --- Baseline comparison line in country cards --- */
.baseline-comparison {
    display: inline-block;
    margin-top: 8px;
    padding: 6px 10px;
    background-color: #fff8e8;
    border-left: 3px solid var(--accent-gold);
    border-radius: var(--radius-sm);
    color: var(--primary);
    font-size: 0.9em;
}

@media (max-width: 700px) {
    .compare-table { font-size: 0.82em; }
    .compare-table thead th { min-width: 120px; }
    .compare-cta { font-size: 0.85em; padding: 10px 14px; gap: 8px; }
    .compare-modal-overlay { padding: 12px; }
}

@media print {
    .compare-cta, .compare-modal-overlay, .compare-toggle-btn { display: none !important; }
}

/* --- Load More pagination block --- */
.load-more-block {
    text-align: center;
    padding: 20px 16px 8px;
    margin-top: 8px;
    margin-bottom: 8px;
}
.load-more-progress {
    color: var(--text-secondary);
    font-size: 0.9em;
    margin: 0 0 12px 0;
}
.load-more-progress.all-shown {
    color: var(--green);
    font-weight: 500;
}
.load-more-btn { font-size: 0.95em; padding: 12px 24px; }
.load-more-hint {
    color: var(--text-secondary);
    font-size: 0.82em;
    margin: 12px 0 0 0;
    font-style: italic;
}

/* --- Empty results message --- */
.empty-results {
    padding: 24px;
    background-color: var(--warning-bg);
    border: 2px dashed var(--warning-border);
    border-radius: var(--radius-md);
    text-align: center;
    color: #744210;
    font-size: 0.95em;
    line-height: 1.55;
}

/* --- Long-term projection block (10/20-year cumulative) --- */
.projection-block {
    margin-top: 12px;
    padding: 14px 18px;
    background: linear-gradient(135deg, #1a365d 0%, #234572 100%);
    color: #fff;
    border-radius: var(--radius-md);
    border-left: 4px solid var(--accent-gold);
}
.projection-headline {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    flex-wrap: wrap;
    gap: 8px;
}
.projection-label-main {
    color: rgba(255,255,255,0.9);
    font-size: 0.92em;
    font-weight: 500;
}
.projection-value-main {
    font-size: 1.6em;
    font-weight: 800;
    color: var(--accent-gold);
    letter-spacing: -0.01em;
}
.projection-value-main.surplus-negative { color: #fc8181; }
.projection-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.92em;
    color: rgba(255,255,255,0.85);
    border-top: 1px solid rgba(255,255,255,0.12);
    padding-top: 8px;
}
.projection-row strong { color: var(--accent-gold); }
.projection-details {
    margin-top: 10px;
    padding-top: 8px;
    border-top: 1px solid rgba(255,255,255,0.15);
}
.projection-details summary {
    color: var(--accent-gold);
    cursor: pointer;
    font-size: 0.85em;
    font-weight: 600;
    list-style: none;
}
.projection-details summary::-webkit-details-marker { display: none; }
.projection-details summary::before { content: "▸ "; font-size: 0.8em; }
.projection-details[open] summary::before { content: "▾ "; }
.projection-breakdown {
    padding: 10px 0 0 0;
    font-size: 0.88em;
    line-height: 1.55;
    color: rgba(255,255,255,0.9);
}
.projection-breakdown p { margin: 0 0 8px 0; }
.projection-breakdown p:last-child { margin-bottom: 0; }
.projection-breakdown strong { color: #fff; }
.projection-caveat {
    margin-top: 10px !important;
    padding: 8px 10px;
    background-color: rgba(255,255,255,0.08);
    border-radius: var(--radius-sm);
    font-size: 0.82em;
    font-style: italic;
    color: rgba(255,255,255,0.78);
}

/* --- Currency volatility warning --- */
.currency-warning {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
    padding: 8px 14px;
    border-radius: var(--radius-md);
    font-size: 0.88em;
    cursor: help;
    outline: none;
}
.currency-warning:focus { box-shadow: 0 0 0 2px rgba(237, 137, 54, 0.4); }
.currency-warning-high {
    background-color: #fffaf0;
    border: 1.5px solid var(--warning-border);
    color: #7c4d11;
}
.currency-warning-moderate {
    background-color: #fffcf2;
    border: 1px dashed var(--warning-border);
    color: #8c5e1d;
}
.currency-warning-icon { font-size: 1.1em; }
.currency-tooltip {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    left: 0;
    bottom: calc(100% + 8px);
    width: 380px;
    max-width: 92vw;
    padding: 12px 14px;
    background-color: #2d3748;
    color: #fff;
    border-radius: var(--radius-md);
    font-size: 0.85em;
    font-weight: 500;
    line-height: 1.5;
    box-shadow: var(--shadow-lg);
    z-index: 100;
    text-align: left;
    pointer-events: none;
    transition: opacity 0.15s, visibility 0.15s;
    cursor: default;
}
.currency-tooltip::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 24px;
    border: 6px solid transparent;
    border-top-color: #2d3748;
}
.currency-tooltip strong:first-child {
    display: block;
    color: #fbd38d;
    font-size: 0.92em;
    margin-bottom: 6px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.currency-tooltip .tooltip-body {
    display: block;
    color: rgba(255, 255, 255, 0.92);
    font-weight: 400;
}
.currency-warning:hover .currency-tooltip,
.currency-warning:focus .currency-tooltip {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}

/* --- GI Bill callout --- */
.gi-bill-callout {
    background: linear-gradient(135deg, #fffaf0 0%, #fffaf5 100%);
    border-left: 4px solid var(--accent-gold);
    border-radius: var(--radius-md);
    padding: 18px 22px;
    margin: 20px 0;
}
.gi-bill-callout h3 { color: var(--primary); margin-bottom: 8px; }
.gi-bill-callout p { color: var(--text-secondary); line-height: 1.55; font-size: 0.95em; margin: 0; }

/* --- Caveats --- */
.caveats-section { margin-top: 28px; }
.caveats-section h3 { margin-bottom: 10px; color: var(--primary); }
.caveats-section ul { padding-left: 20px; }
.caveats-section li { color: var(--text-secondary); font-size: 0.9em; line-height: 1.55; margin-bottom: 6px; }

/* --- Email capture --- */
.section-subtitle { color: var(--text-secondary); font-size: 0.95em; margin: 0 0 14px 0; line-height: 1.5; }
.email-results-form { margin-top: 12px; }
.email-form-row { display: flex; gap: 10px; flex-wrap: wrap; }
.email-form-row input { flex: 1; min-width: 240px; }
.email-status { font-size: 0.9em; margin: 10px 0 0 0; min-height: 1.2em; }
.email-status.success { color: var(--green); }
.email-status.error { color: var(--accent); }
.input-hint { font-size: 0.82em; color: var(--text-secondary); margin: 8px 0 0 0; line-height: 1.4; }

/* --- Action bar --- */
.action-bar { display: flex; gap: 12px; justify-content: center; margin-bottom: 24px; flex-wrap: wrap; }
.action-bar .action-btn { flex: 0 1 auto; }

/* --- How This Works --- */
.how-it-works p { color: var(--text-secondary); line-height: 1.6; font-size: 0.95em; margin: 0 0 12px 0; }
.how-it-works p:last-child { margin-bottom: 0; }

/* --- FAQ --- */
.faq-section h2 { margin-bottom: 16px; }
.faq-item {
    background-color: var(--bg-surface);
    border-radius: var(--radius-md);
    padding: 12px 18px;
    margin-bottom: 10px;
    border: 1px solid var(--border-color);
}
.faq-item summary {
    font-weight: 600;
    color: var(--primary);
    cursor: pointer;
    padding: 6px 0;
    font-size: 1em;
    list-style: none;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before { content: "▸ "; color: var(--accent-gold); font-weight: 700; }
.faq-item[open] summary::before { content: "▾ "; }
.faq-item p {
    margin: 10px 0 6px 0;
    color: var(--text-secondary);
    line-height: 1.6;
    font-size: 0.95em;
}
.faq-item a { color: var(--primary-light); text-decoration: none; }
.faq-item a:hover { text-decoration: underline; }

/* --- More tools (matches the established TBV pattern across all other tools) --- */
.more-tools {
    background-color: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: 20px 24px;
    margin-bottom: 24px;
    text-align: center;
    box-shadow: var(--shadow-sm);
}
.more-tools h3 {
    font-size: 1rem;
    color: #999;
    margin-top: 0;
    margin-bottom: 0.75rem;
    font-weight: 500;
}
.more-tools .tools-links {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    flex-wrap: wrap;
}
.more-tools .tools-links a {
    color: #C5A55A;
    text-decoration: none;
    font-size: 0.9rem;
    transition: color 0.2s;
}
.more-tools .tools-links a:hover { color: #e0c675; text-decoration: underline; }

/* --- Footer --- */
footer {
    text-align: center;
    color: var(--text-secondary);
    font-size: 0.85em;
    line-height: 1.55;
    padding: 16px 8px 8px;
}
.footer-sources { font-size: 0.78em; color: #718096; margin-top: 8px; }

/* --- Print styles --- */
@media print {
    body { padding: 0; max-width: 100%; background: #fff; }
    .no-print, .home-btn, .build-notice, #vfi-form, .action-bar, #email-results-container, .faq-section, .more-tools { display: none !important; }
    .section-container { box-shadow: none; border: 1px solid #ddd; page-break-inside: avoid; }
    .country-card { page-break-inside: avoid; box-shadow: none; }
}
