body {
    background-color: #d8d8d8;
}

a {
    text-decoration: none;
    color: #252525;
}

a:hover {
    text-decoration: none;
}

.navbar {
    background-color: #ffffff7d;
    backdrop-filter: blur(8px);
}

.navbar-brand {
    margin-left: 20px;
}

.nav-pills .nav-link {
    color: #cf294b;
}

.nav-pills .nav-link.active {
    background-color: #cf294b;
}

/* Desktop only */
@media (min-width: 1200px) {
    .content-page {
        margin-left: 125px !important;
        margin-right: 125px !important;
    }
}

/* Mobile only */
@media (max-width: 768px) {
    .navbar-collapse {
        margin-top: 14px;
    }

    .navbar-current-city {
        max-width: 240px;
        font-size: 17px;
        margin-left: -20px;
    }

    .leaflet-bottom {
        bottom: 52px;
    }
}

.content-page {
    margin-top: 110px;
    margin-left: 30px;
    margin-right: 30px;
    margin-bottom: 30px;
}

.navbar-current-city {
    color: #545454;
    font-size: 20px;
    font-weight: bold;
    cursor: default;
}

.navbar-search {
    width: 300px;
    margin-left: 30px;
    margin-right: 30px;
}

.navbar-search-results {
    width: 300px;
    background-color: #ffffff;
    border: 1px solid #bdbdbd;
    border-radius: 5px;
    position: absolute;
    z-index: 1;
}

#map-div {
    width: 100%;
    height: 100vh;
}

/* .leaflet-tile {
    filter: grayscale(80%) contrast(140%) brightness(90%);
} */

/*
.map-neighborhood-green-label {
    font-size: 18px;
    color: #005900;
    /* text-shadow: #adadad 1px 1px 0px, #9C9C9C 1px 1px 0px; 
}
.map-neighborhood-red-label {
    font-size: 18px;
    color: #b82929;
    /* text-shadow: #adadad 1px 1px 0px, #9C9C9C 1px 1px 0px; 
} */

.map-neighborhood-label,
.map-attraction-label {
    transform-origin: center center;
    white-space: nowrap;
    transition: transform 0.2s ease;
    text-align: center;
    font-weight: 500;
    font-size: 18px;
    position: relative;
}

.map-neighborhood-label-green {
    color: #78a179;
}

.map-neighborhood-label-red {
    color: #b82929;
}

.map-neighborhood-label-neutral {
    color: #808080;
}

.map-neighborhood-neutral-label {
    font-size: 18px;
    color: #121212;
    text-shadow: #adadad 1px 1px 0px, #9C9C9C 1px 1px 0px;
}

.fixed-label-icon {
    position: absolute;
    transform-origin: top center;
    white-space: nowrap;
    transition: transform 0.2s ease;
    text-align: center;
    font-weight: 500;
    font-size: 14px;
    color: #2c3e50;
    background: white;
    padding: 2px 6px;
    border-radius: 4px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
    top: -50%;
    left: -50%;
}

#info-div {
    background-color: white;
    color: black;
    height: 100vh;
    padding: 90px 20px 40px 20px;
}

.info-icon {
    margin-right: 10px;
}
  
#mobile-tabs {
    background-color: #ffffff57;
    backdrop-filter: blur(8px);
}

.accordion-header button {
    font-size: 21px;
    background-color: #fafafa;
}

.beta-badge {
    font-size: 13px;
    margin-left: 6px;
}

.leaflet-control-attribution {
    font-size: 10px;
}

.alert {
    text-align: center;
}

.leaflet-control-custom {
    background-color: #fff !important;
}

#results-list,
.passport-list,
.passport-edits,
.highlighted-result {
  background-color: #fff;
  color: #000;
  cursor: pointer;
}

.popover {
  padding: 0.25rem !important;
  font-size: 0.8rem;
  max-width: 200px;
}

.popover-body {
  padding: 0.1rem 0.2rem !important;
}

/* Dark mode */

body.dark-mode {
    background-color: #434343;
    color: #e0e0e0;
}

body.dark-mode a {
    color: #fffffff6;
}

body.dark-mode .navbar {
    background-color: #3333337d;
}

body.dark-mode #info-div {
    background-color: #242424 !important;
    color: #e0e0e0;
}

body.dark-mode .text-muted {
    color: #9e9e9e !important;
}

body.dark-mode .navbar-current-city {
    color: #cccccc;
}

body.dark-mode #info-div {
    background-color: #1e1e1e;
    color: #e0e0e0;
}

body.dark-mode .accordion {
    border-color: #444;
}

body.dark-mode .accordion-item {
    background-color: #2a2a2a;
    border: 1px solid #444;
}

body.dark-mode .accordion-button {
    background-color: #2e2e2e;
    color: #e0e0e0;
}

body.dark-mode .accordion-button:not(.collapsed) {
    background-color: #3a3a3a;
    color: #fff;
}

body.dark-mode .accordion-body {
    background-color: #1e1e1e;
    color: #ddd;
}

body.dark-mode .navbar-search-results {
    background-color: #2a2a2a;
    border-color: #555;
    color: #e0e0e0;
}

body.dark-mode .leaflet-control-container .leaflet-bar a {
    background-color: #2a2a2a !important;
    color: #fff !important;
    border: 1px solid #444 !important;
}

body.dark-mode .leaflet-control-container .leaflet-bar a:hover {
    background-color: #3a3a3a !important;
}

body.dark-mode .leaflet-control-attribution {
    background-color: #2a2a2a !important;
    color: #ccc !important;
    border: none !important;
}

body.dark-mode .leaflet-control-attribution a {
    color: #bbb !important;
}

body.dark-mode .leaflet-control-custom {
    background-color: #2a2a2a !important;
}

body.dark-mode .leaflet-popup-content-wrapper {
    background-color: #2a2a2a !important;
    color: #fff !important;
    border: 1px solid #444 !important;
}

body.dark-mode .leaflet-popup-tip {
    background: #2a2a2a !important;
    border: none !important;
}

body.dark-mode .leaflet-popup-close-button {
    color: #fff !important;
}

body.dark-mode .list-group,
body.dark-mode .list-group-item,
body.dark-mode .dropdown-menu,
body.dark-mode .passport-list,
body.dark-mode .submit-btn,
body.dark-mode .passport-edits {
    background-color: #2a2a2a !important;
    color: #fff !important;
    border-color: #444 !important;
}

body.dark-mode .edit-button {
    color: #fff;
    border-color: #fff;
}

body.dark-mode .edit-button:hover {
    color: #121212;
    background-color: #fff;
}

body.dark-mode .list-group-item a {
    color: #fff !important;
}

body.dark-mode .save-btn:hover,
body.dark-mode .list-group-item:hover,
body.dark-mode .dropdown-menu .dropdown-item:hover {
    background-color: #3a3a3a !important;
    color: #fff;
}

body.dark-mode .navbar-search .input-group {
    border: 1px solid #444;
    border-radius: 4px;
}

body.dark-mode .navbar-search .input-group-text {
    background-color: #3a3a3a;
    border: 1px solid #444;
    color: #fff;
}

body.dark-mode .navbar-search .form-control,
body.dark-mode .form-control.selected_passports,
body.dark-mode #results-list {
    background-color: #2a2a2a;
    border: 1px solid #444;
    color: #fff;
}

body.dark-mode .btn-remove-passport {
    filter: invert(1);
}

body.dark-mode .highlighted-result,
body.dark-mode .highlighted-result:hover {
  background-color: #3a3a3a;
  color: #fff;
}

body.dark-mode .navbar-search .form-control::placeholder,
body.dark-mode .form-control.selected_passports::placeholder {
    color: #ccc;
}

body.dark-mode .leaflet-tooltip {
    background-color: #2a2a2a !important;
    color: #fff !important;
    border: 1px solid #444 !important;
    box-shadow: none !important;
}

body.dark-mode .leaflet-tooltip:before {
    border-top-color: #2a2a2a !important;
    border-bottom-color: #2a2a2a !important;
}

body.dark-mode .leaflet-tile {
    filter: brightness(0.5);
}

body.dark-mode .alert-secondary {
    background-color: #2a2a2a !important;
    color: #fff !important;
    border-color: #444 !important;
}

body.dark-mode .map-airport-label {
    position: absolute;
    transform-origin: top center;
    white-space: nowrap;
    transition: transform 0.2s ease;
    text-align: center;
    font-weight: 500;
    font-size: 14px;
    color: #fff;
    background: #444;
    padding: 2px 6px;
    border-radius: 4px;
    top: -50%;
    left: -50%;
}

body.dark-mode .img-thumbnail {
    background-color: #d0d0d0;
}

body.dark-mode .modal-content.delete {
    --bs-modal-bg: #2a2a2a;
    --bs-modal-footer-border-color: #3a3a3a !important;
    --bs-modal-header-border-color: #3a3a3a !important;
    background-color: var(--bs-modal-bg) !important;
}

/* Language RTL adaptation */

:dir(rtl) .list-inline-item:last-child {
    margin-right: 10px;
}

:dir(rtl) .info-icon {
    margin-left: 10px;
}

:dir(rtl) .content-page {
    margin-right: 30px;
}

.accordion-button::after {
    display: block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    transform: rotate(0deg);
    transition: transform 0.3s;
}

:dir(rtl) .accordion-button::after {
margin-inline-start: auto;
margin-inline-end: 0;
}

:dir(ltr) .accordion-button::after {
margin-inline-start: auto;
margin-inline-end: 0; 
}

.accordion-button:not(.collapsed)::after {
transform: rotate(-180deg);
}
