/* ========================================
   LEAFLET DARK MODE POPUPS & MARKERS
   ======================================== */

/* Clean up default Leaflet marker containers */
.leaflet-div-icon {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* Remove default marker shadows */
.leaflet-marker-shadow {
    display: none !important;
}

/* Ship markers - clean circles */
.ship-marker {
    display: flex;
    align-items: center;
    justify-content: center;
}

.ship-marker div {
    border-radius: 50%;
}

/* Override Leaflet popup for dark mode */
.leaflet-popup-content-wrapper {
    background: var(--color-bg-elevated) !important;
    color: var(--color-text) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-lg) !important;
    border: 1px solid var(--color-border);
}

.leaflet-popup-content {
    background: var(--color-bg-elevated) !important;
    color: var(--color-text) !important;
    margin: 0 !important;
    padding: var(--space-3) !important;
    font-family: var(--font-sans) !important;
}

.leaflet-popup-tip {
    background: var(--color-bg-elevated) !important;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg) !important;
}

/* Popup close button */
.leaflet-container a.leaflet-popup-close-button {
    color: var(--color-text-muted) !important;
    font-size: 18px !important;
    padding: var(--space-2) !important;
    width: 32px !important;
    height: 32px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: var(--radius-md);
    transition: all var(--duration-fast) ease;
}

.leaflet-container a.leaflet-popup-close-button:hover {
    color: var(--color-text) !important;
    background: var(--color-bg-hover);
}

/* Custom popup styles for ships */
.ship-popup {
    min-width: 180px;
    max-width: 280px;
}

.ship-popup__title {
    font-size: var(--text-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--space-2);
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--color-border);
}

.ship-popup__row {
    display: flex;
    justify-content: space-between;
    padding: var(--space-1) 0;
    font-size: var(--text-sm);
}

.ship-popup__label {
    color: var(--color-text-muted);
}

.ship-popup__value {
    color: var(--color-text);
    font-weight: 500;
}

.ship-popup__alert {
    margin-top: var(--space-2);
    padding: var(--space-2);
    background: rgba(220, 38, 38, 0.1);
    border-left: 3px solid var(--color-danger);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--color-danger);
}

/* Custom popup styles for ports */
.port-popup {
    min-width: 160px;
    text-align: center;
}

.port-popup__icon {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-1);
}

.port-popup__name {
    font-size: var(--text-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--space-1);
}

.port-popup__country {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    margin-bottom: var(--space-2);
}

.port-popup__role {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    padding: var(--space-1) var(--space-2);
    background: var(--color-bg);
    border-radius: var(--radius-md);
    display: inline-block;
}

.port-popup__alert {
    margin-top: var(--space-2);
    padding: var(--space-1) var(--space-2);
    background: rgba(220, 38, 38, 0.1);
    border-radius: var(--radius-md);
    font-size: var(--text-xs);
    color: var(--color-danger);
}

/* Factory Popup */
.factory-popup {
    min-width: 160px;
    text-align: center;
}

.factory-popup__icon {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-1);
}

.factory-popup__name {
    font-size: var(--text-base);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--space-1);
}

.factory-popup__country {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    margin-bottom: var(--space-2);
}

.factory-popup__products {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    justify-content: center;
}

.factory-popup__product {
    font-size: var(--text-xs);
    padding: var(--space-1) var(--space-2);
    background: var(--color-bg);
    border-radius: var(--radius-sm);
    color: var(--color-text-secondary);
}

/* Marker pulse animation for high-importance items */
@keyframes markerPulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.7);
    }
    50% {
        box-shadow: 0 0 0 12px rgba(220, 38, 38, 0);
    }
}

/* Marker cluster customization */
.leaflet-cluster-anim .leaflet-marker-icon {
    transition: transform 0.3s ease-out;
}

.custom-cluster {
    background: transparent !important;
}

.custom-cluster div {
    box-shadow: 0 0 0 4px rgba(220, 38, 38, 0.3),
                0 0 0 8px rgba(220, 38, 38, 0.1) !important;
}

/* Ship marker glow animation */
@keyframes marker-pulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.4);
    }
    50% {
        box-shadow: 0 0 0 8px rgba(220, 38, 38, 0);
    }
}

.ship-marker--weapons {
    animation: marker-pulse 2s ease-in-out infinite;
}

/* Factory marker styling */
.factory-marker-icon {
    font-size: 18px;
    text-shadow: 0 0 10px currentColor;
}

/* Tooltip styling */
.leaflet-tooltip {
    background: var(--color-bg-elevated) !important;
    color: var(--color-text) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-md) !important;
    font-family: var(--font-sans) !important;
    font-size: var(--text-xs) !important;
}

.leaflet-tooltip-top:before,
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
    border-top-color: var(--color-bg-elevated) !important;
    border-bottom-color: var(--color-bg-elevated) !important;
}

/* High contrast mode */
[data-contrast="high"] {
    --color-text: #ffffff;
    --color-text-secondary: #ffffff;
    --color-text-muted: #cccccc;
    --color-border: #ffffff;
    --color-bg-elevated: #000000;
}

[data-contrast="high"] * {
    font-weight: 500;
}

/* Large touch targets */
[data-touch="large"] .toggle-item,
[data-touch="large"] .btn,
[data-touch="large"] .a11y-btn {
    min-height: 56px;
}