a {
    text-decoration: none;
}
.btn-outline-primary {
    font-weight: bold;
}
.btn-outline-primary:hover {
    color: #fff;
}

header {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    border-bottom: 1px solid #e0e0e0;
}

#logo {
    height: 100px;
}

#ferry-search {
    background: url("../img/ferry-search-background-be8o4Q0.jpg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

#ferry-form {
    --bs-bg-opacity: 0.75;
    background-color: rgba(255, 255, 255, var(--bs-bg-opacity)) !important;
    border-radius: 10px;
}

#ferry-search #ferry-form .form-label {
    color: var(--bs-dark-text-emphasis);
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 0;
}

#ferry-search #ferry-form button.btn.btn-primary:hover {
    color: var(--bs-light);
}

#ferry-search #ferry-form #tripType button.btn.btn-primary:hover {
    background-color: var(--bs-warning);
    color: var(--bs-primary);
    border-color: var(--bs-primary);
}

#ferry-search #ferry-form button.btn.btn-outline-primary {
    color: var(--bs-light);
    background-color: var(--bs-secondary);
}

#ferry-search #ferry-form button.btn.btn-outline-primary:hover {
    color: var(--bs-light);
    background-color: var(--bs-warning);
}

.btn-primary {
    color: var(--bs-light);
}

#search-info {
    margin-top: 1rem;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    background-color: var(--bs-success);
}

#search-info p {
    color: var(--bs-light);
    font-size: 1.3rem;
    margin-bottom: 0;
    text-align: center;
}

#search-info p a {
    color: var(--bs-secondary);
    text-decoration: none;
}

header .nav-item svg {
    margin-right: 0.75rem;
}

header ul.nav.nav-tabs li.nav-item a.nav-link.active {
    color: var(--bs-primary);
    font-weight: bolder;
}

header ul.nav.nav-tabs li.nav-item a.nav-link {
    color: var(--bs-secondary);
    font-weight: initial;
    font-size: 1.2rem;
}

header ul.nav.nav-tabs li.nav-item a.nav-link:hover {
    color: var(--bs-warning);
}

header ul.nav.nav-tabs li.nav-item.dropdown .dropdown-menu a.dropdown-item {
    color: var(--bs-secondary);
}

header ul.nav.nav-tabs li.nav-item.dropdown .dropdown-menu a.dropdown-item:hover {
    color: var(--bs-warning);
}

/* Module Navigation - Pills Style */
.module-navigation {
    background-color: #ffffff;
}

.module-navigation .nav-link {
    color: var(--bs-secondary);
    font-weight: 600;
    font-size: 1.1rem;
    padding: 0.75rem 2rem;
    border-radius: 50px;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background-color: transparent;
    border: 2px solid transparent;
}

.module-navigation .nav-link:hover {
    background-color: rgba(112, 203, 210, 0.1);
    color: var(--bs-secondary);
}

.module-navigation .nav-link.active {
    background-color: var(--bs-primary);
    color: #ffffff;
    border-color: var(--bs-primary);
}

.module-navigation .nav-link svg {
    flex-shrink: 0;
}

#ferry-search #ferry-form .detail {
    position: relative;
    width: 100%;
    margin-top: -8px;
}

#ferry-search #ferry-form .detail .detail-content {
    position: absolute;
    width: 100%;
    max-height: 160px;
    padding: 0;
    z-index: 20;
    top: 0px;
    background-color: var(--bs-light);
    border-radius: 0 0 10px 10px;
    overflow-y: auto;
}

/* Popup passagers : pas de limite de hauteur */
#ferry-search #ferry-form .detail[data-ferry--travelers-target="div"] .detail-content {
    max-height: none;
    overflow-y: visible;
    padding: 10px;
}

/* Container des âges enfants dans le popup passagers */
#ferry-search #ferry-form [data-ferry--travelers-target="childrenAgesContainer"]:not(:empty) {
    border-top: 1px solid var(--bs-border-color);
    padding-top: 10px;
    margin-top: 5px;
}

#ferry-search #ferry-form [data-ferry--travelers-target="childrenAgesContainer"] .form-label {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--bs-dark);
    margin-bottom: 0.25rem;
}

#ferry-search #ferry-form [data-ferry--travelers-target="childrenAgesContainer"] .form-select {
    font-size: 0.9rem;
}

#ferry-search #ferry-form .detail-content .list-group {
    margin: 0;
    padding: 10px;
}

#ferry-search #ferry-form .list-group a {
    color: var(--bs-dark-text-emphasis);
    font-size: 1.2rem;
    margin-bottom: 0.5rem;
}

#ferry-search #ferry-form .list-group a:hover {
    color: var(--bs-primary);
}

#ferry-search #ferry-form #sqa_ferry_trip_type .form-check-label {
    color: var(--bs-primary);
    font-weight: 700;
    font-size: 1.2rem;
}

#ferry-search #ferry-form .detail-content label.col-form-label {
    color: var(--bs-dark);
    font-size: 1rem;
    font-weight: 900;
    margin-bottom: 0;
}

#ferry-search #ferry-form .detail-content input {
    text-align: center;
}

