:root {
    --urbi-primary: #0a5a7a;
    --urbi-secondary: #1f9d8b;
    --urbi-cream: #f4f1ea;
    --urbi-ink: #18242e;
}

body {
    font-family: 'Manrope', sans-serif;
    color: var(--urbi-ink);
    background: linear-gradient(180deg, #f7fbff 0%, #ffffff 100%);
}

.bg-primary {
    background: linear-gradient(120deg, var(--urbi-primary), #0e799f) !important;
}

.site-logo {
    height: 100px;
    width: auto;
    display: block;
}

.hero-urbi {
    background: radial-gradient(circle at top right, rgba(31, 157, 139, .20), transparent 50%), var(--urbi-cream);
}

.search-box {
    background: #fff;
    border-radius: 1rem;
    box-shadow: 0 15px 40px rgba(0, 0, 0, .08);
}

.home-banner-carousel {
    border-radius: 1rem;
}

.home-banner-link {
    display: block;
}

.home-banner-image {
    width: 100%;
    height: 420px;
    object-fit: cover;
}

.home-banner-carousel .carousel-control-prev,
.home-banner-carousel .carousel-control-next {
    width: 10%;
}

.home-banner-carousel .carousel-indicators [data-bs-target] {
    width: 26px;
    height: 3px;
    border: 0;
    border-radius: 999px;
}

.card-promo {
    transition: transform .25s ease, box-shadow .25s ease;
}

.card-promo:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, .12) !important;
}

.card-resultado {
    border: 1px solid #d8e2e8;
    border-radius: 12px;
    padding: 1rem;
    background: #fff;
}

.price-tag {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--urbi-primary);
}

.passenger-card {
    border-radius: 18px;
    border: 1px solid #dbe5ee;
}

.passenger-card .form-label {
    font-size: .92rem;
    font-weight: 700;
    color: #365066;
    margin-bottom: .45rem;
}

.passenger-card .form-control,
.passenger-card .form-select {
    min-height: 48px;
    border-radius: 12px;
    border-color: #d2dde8;
}

.passenger-card .form-control:focus,
.passenger-card .form-select:focus {
    border-color: #0e799f;
    box-shadow: 0 0 0 .2rem rgba(14, 121, 159, .14);
}

.passenger-badge {
    display: inline-flex;
    align-items: center;
    padding: .28rem .65rem;
    border-radius: 999px;
    background: rgba(31, 157, 139, .12);
    color: #157364;
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .02em;
}

.travel-summary-block {
    padding: .9rem 1rem;
    border: 1px solid #dde6ee;
    border-radius: 14px;
    background: #f8fbfd;
}

.travel-summary-label {
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #6a7a8b;
    margin-bottom: .25rem;
}

.travel-summary-value {
    font-size: 1rem;
    font-weight: 700;
    color: #203040;
}

.travel-summary-card {
    border: 1px solid #d8e5ef;
    border-radius: 16px;
    padding: 1rem;
    background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
}

.travel-summary-tag {
    display: inline-flex;
    margin-bottom: .6rem;
    padding: .3rem .65rem;
    border-radius: 999px;
    background: rgba(10, 90, 122, .1);
    color: var(--urbi-primary);
    font-size: .76rem;
    font-weight: 800;
}

.travel-summary-tag.return {
    background: rgba(31, 157, 139, .12);
    color: #157364;
}

.travel-summary-route {
    font-size: 1rem;
    font-weight: 800;
    color: #1e3245;
    margin-bottom: .2rem;
}

.travel-summary-service {
    color: #557085;
    font-weight: 600;
    margin-bottom: .65rem;
}

.travel-summary-meta {
    font-size: .92rem;
    color: #33495d;
    margin-bottom: .22rem;
}

.sticky-summary {
    position: sticky;
    top: 90px;
}

.admin-wrap {
    min-height: 100vh;
}

.admin-body {
    background: #f0f2f5;
}

.admin-shell {
    display: flex;
    min-height: 100vh;
}

.admin-sidebar {
    width: 290px;
    background: #f7f7f8;
    border-right: 1px solid #d8dde3;
    color: #1c2430;
    padding: 0;
    flex-direction: column;
    position: sticky;
    top: 0;
    height: 100vh;
}

.admin-brand {
    padding: 1.15rem 1rem;
    border-bottom: 1px solid #d8dde3;
}

.admin-brand-link {
    display: flex;
    align-items: center;
    gap: .7rem;
    color: #0f3f67;
    text-decoration: none;
}

.admin-logo {
    height: 46px;
    width: auto;
    max-width: 90%;
    display: block;
}

.admin-brand-link strong {
    display: block;
    line-height: 1.1;
    font-size: 1.1rem;
}

.admin-brand-link small {
    color: #637182;
}

.admin-brand-badge {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: linear-gradient(125deg, #0e799f, #1f9d8b);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.admin-sidebar-nav {
    display: block;
    padding-top: .5rem;
}

.admin-sidebar-link {
    color: #253444;
    text-decoration: none;
    padding: .82rem 1rem;
    border-bottom: 1px solid #e1e5ea;
    display: flex;
    align-items: center;
    gap: .6rem;
    transition: background-color .2s ease, color .2s ease;
}

.admin-sidebar-link:hover {
    background: #e9edf3;
    color: #0e4b73;
}

.admin-sidebar-link.active {
    background: #e9eef6;
    color: #2f58ff;
    font-weight: 700;
}

.admin-sidebar-foot {
    margin-top: auto;
    border-top: 1px solid #d8dde3;
    padding: .85rem 1rem;
    background: #f3f5f7;
}

.admin-user-line {
    display: flex;
    align-items: center;
    gap: .5rem;
    color: #2a3442;
    margin-bottom: .7rem;
}

.admin-user-line i {
    font-size: 1.25rem;
    color: #637182;
}

.admin-user-line strong {
    display: block;
    line-height: 1.1;
}

.admin-user-line small {
    display: block;
    color: #6c7a89;
}

.admin-main {
    flex: 1;
    min-width: 0;
}

.admin-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .75rem 1rem;
    background: #ffffff;
    border-bottom: 1px solid #d8dde3;
}

.admin-topbar-brand {
    color: #1b2d41;
    text-decoration: none;
    font-weight: 700;
}

.admin-topbar-logo {
    height: 34px;
    width: auto;
    display: block;
}

.admin-wrap .card {
    border-radius: 12px;
    border: 1px solid #e2e7ee;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .04);
}

@media (max-width: 991px) {
    .sticky-summary {
        position: static;
    }

    .home-banner-image {
        height: 280px;
    }
}
