:root {
    --bg-body: #FFFFFF;
    --bg-card: #F8F9FA;
    --bg-glass: rgba(255, 255, 255, 0.9);
    --text-primary: #212529;
    --text-secondary: #495057;
    /* Darker secondary for visibility */
    --accent-color: #008B94;
    --accent-hover: #00ADB5;
    --visited-country: #81C784;
    /* Light Green */
    --visited-country-hover: #4CAF50;
    /* Green Hover */
    --default-country: #E9ECEF;
    --default-country-stroke: #FFFFFF;
    --font-heading: 'Montserrat', sans-serif;
    --font-body: 'Lato', sans-serif;
}

body {
    background-color: var(--bg-body);
    color: var(--text-primary);
    font-family: var(--font-body);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: var(--text-primary);
    font-family: var(--font-heading);
    font-weight: 700;
}

a,
a:hover,
a:focus {
    color: var(--accent-color);
    text-decoration: none;
    transition: color 0.3s ease;
}

a:hover {
    color: var(--accent-hover);
}

/* Navbar Modernization - BLACK HEADER */
.rd-navbar-wrap,
.page-head {
    background-color: #121212 !important;
    color: #FFFFFF !important;
}

.rd-navbar-brand img {
    /* Filter to turn white logo to Yellow (#FFD700) */
    filter: brightness(0) saturate(100%) invert(78%) sepia(35%) saturate(1478%) hue-rotate(1deg) brightness(103%) contrast(104%);
}

.rd-navbar-nav>li>a {
    color: #AAAAAA !important;
    /* Navbar links text */
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.rd-navbar-nav>li.active>a,
.rd-navbar-nav>li>a:hover {
    color: #FFD700 !important;
    /* Yellow highlight in navbar */
    background: transparent;
}

/* Force Light background on Body content only */
.page,
.section:not(.page-head):not(.footer-default):not(.page-footer),
.novi-background,
.bg-default,
.shell {
    background-color: var(--bg-body) !important;
    color: var(--text-primary) !important;
}

/* Text Visibility Fix */
.blockquote-footer,
.text-secondary {
    color: #495057 !important;
    /* Ensure visibility on white */
}

/* Footer - BLACK FOOTER */
body .footer-default,
body footer,
body .page-footer,
.footer-default {
    background-color: #121212 !important;
    color: #AAAAAA !important;
    border-top: 1px solid #333;
}

.footer-default h3,
.footer-default a {
    color: #FFFFFF !important;
}

/* Map Component Styles */
.map-tooltip,
.map-legend {
    color: var(--text-primary);
}

#travel-map-container {
    position: relative;
    width: 100%;
    max-width: 1200px;
    margin: 4rem auto;
    background: var(--bg-card);
    border-radius: 16px;
    padding: 2rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

#travel-map {
    width: 100%;
    height: auto;
    aspect-ratio: 960/500;
    display: block;
}

/* Tooltip */
.map-tooltip {
    position: absolute;
    padding: 10px 15px;
    background: var(--bg-glass);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    color: var(--text-primary);
    font-size: 0.9rem;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    z-index: 100;
}

/* Legend */
.map-legend {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.5rem;
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.legend-color-box {
    width: 12px;
    height: 12px;
    border-radius: 2px;
}

.legend-visited {
    background-color: var(--visited-country);
}

.legend-default {
    background-color: var(--default-country);
}

/* SVG Map Styles */
.country,
.state {
    fill: var(--default-country);
    stroke: var(--default-country-stroke);
    stroke-width: 0.5px;
    transition: fill 0.3s ease;
    cursor: default;
}

.country.visited,
.state.visited {
    fill: var(--visited-country);
    cursor: pointer;
}

.country.visited:hover,
.state.visited:hover {
    fill: var(--visited-country-hover);
    filter: drop-shadow(0 0 5px var(--visited-country));
}

.country.country-home {
    fill: #ADB5BD;
    stroke: #ADB5BD;
    cursor: pointer;
}

.country.country-home:hover {
    fill: #6C757D;
    filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.2));
}

.country:hover:not(.visited):not(.country-home),
.state:hover:not(.visited) {
    fill: #CED4DA;
}

/* Helper utilities */
.text-accent {
    color: var(--accent-color) !important;
}

.bg-dark-modern {
    background-color: var(--bg-body) !important;
}

.home-icon {
    pointer-events: none;
}

@media (max-width: 768px) {
    #travel-map-container {
        padding: 1rem;
        margin: 2rem auto;
    }
}