/* ========== TOUCH DEVICE: disable sticky hover states ========== */
@media (hover: none) {
    .nav-btn:hover {
        background: transparent;
        color: var(--text-secondary);
    }
    .my-adoptions-btn:hover {
        transform: none;
        box-shadow: none;
    }
    .map-filter-btn:hover {
        background: rgba(255, 255, 255, 0.95);
        border-color: var(--border);
        transform: none;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    }
    .seat:hover circle {
        filter: none;
        transform: none;
        stroke: none;
        stroke-width: 0;
        animation-play-state: running;
    }
    .close-btn:hover {
        background: transparent;
        color: var(--text-secondary);
    }
    .politician-card:hover {
        border-color: var(--border);
        transform: none;
        box-shadow: none;
    }
    .adopt-btn:hover {
        background: var(--accent);
    }
}

/* ========== VERY SMALL PHONES (320px) ========== */
@media (max-width: 360px) {
    .politician-grid {
        grid-template-columns: 1fr;
    }
}

/* ========== SHARED .container HELPER (for footer) ========== */
.container {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 24px;
}

