:root{
    --primario:#0f766e;
    --primario-2:#0b5f59;
    --secundario:#1d4ed8;
    --oscuro:#0f172a;
    --gris:#64748b;
    --gris-suave:#e2e8f0;
    --claro:#f8fafc;
    --blanco:#ffffff;
    --sombra:0 12px 35px rgba(15,23,42,.12);
    --radio:22px;
}

*{
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    margin:0;
    font-family:'Inter', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background:linear-gradient(180deg,#f8fbff 0%,#f4f7fb 100%);
    color:#1e293b;
}

.site-header{
    position:sticky;
    top:0;
    z-index:999;
    backdrop-filter:blur(10px);
}

.site-header .navbar{
    background:linear-gradient(90deg, rgba(15,118,110,.95), rgba(29,78,216,.95));
    box-shadow:0 8px 24px rgba(0,0,0,.08);
    padding-top:14px;
    padding-bottom:14px;
}

.navbar-brand{
    font-size:1.7rem;
    letter-spacing:-0.5px;
}

.navbar-dark .navbar-nav .nav-link{
    color:rgba(255,255,255,.88);
    font-weight:500;
    margin-left:10px;
    transition:.2s ease;
}

.navbar-dark .navbar-nav .nav-link:hover{
    color:#fff;
    transform:translateY(-1px);
}

.hero{
    position:relative;
    min-height:640px;
    display:flex;
    align-items:center;
    overflow:hidden;
    color:var(--blanco);
    background:
        linear-gradient(115deg, rgba(3,7,18,.72) 10%, rgba(15,118,110,.45) 45%, rgba(30,64,175,.35) 100%),
        url('../img/fondo.jpg?q=80&w=1800&auto=format&fit=crop') center center/cover no-repeat;
}

.hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(to bottom, rgba(15,23,42,.2), rgba(15,23,42,.35));
}

.hero .container{
    position:relative;
    z-index:2;
}

.hero-content{
    max-width:680px;
}

.hero-kicker{
    display:inline-flex;
    align-items:center;
    gap:10px;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.18);
    color:#fff;
    padding:10px 16px;
    border-radius:999px;
    font-size:.92rem;
    margin-bottom:22px;
    backdrop-filter:blur(10px);
}

.hero h1{
    font-size:clamp(2.5rem, 5vw, 4.4rem);
    line-height:1.02;
    letter-spacing:-1.8px;
    font-weight:900;
    margin-bottom:18px;
    text-wrap:balance;
}

.hero p{
    font-size:1.18rem;
    line-height:1.7;
    max-width:620px;
    color:rgba(255,255,255,.95);
    margin-bottom:0;
}

.buscador-box{
    background:rgba(255,255,255,.95);
    border:1px solid rgba(255,255,255,.65);
    border-radius:28px;
    padding:26px;
    box-shadow:0 24px 60px rgba(2,6,23,.22);
    backdrop-filter:blur(10px);
}

.buscador-box .form-label{
    font-size:.92rem;
    color:#334155;
    font-weight:700;
    margin-bottom:8px;
}

.buscador-box .form-control,
.buscador-box .form-select{
    height:56px;
    border-radius:16px;
    border:1px solid #dbe3ef;
    font-size:1rem;
    padding-left:16px;
    box-shadow:none !important;
}

.buscador-box .form-control:focus,
.buscador-box .form-select:focus{
    border-color:#93c5fd;
    box-shadow:0 0 0 4px rgba(59,130,246,.12) !important;
}

.btn-success{
    background:linear-gradient(135deg, var(--primario), #169c59);
    border:none;
    border-radius:16px;
    font-weight:700;
    letter-spacing:.2px;
    box-shadow:0 10px 24px rgba(22,156,89,.22);
}

.btn-success:hover{
    background:linear-gradient(135deg, var(--primario-2), #11804a);
}

.btn-outline-primary,
.btn-outline-dark,
.btn-outline-secondary{
    border-radius:14px;
    font-weight:600;
}

.section-block{
    padding:80px 0;
}

.section-title{
    font-size:2.2rem;
    font-weight:900;
    line-height:1.1;
    color:var(--oscuro);
    letter-spacing:-1px;
    margin-bottom:10px;
}

.section-subtitle{
    color:var(--gris);
    font-size:1.05rem;
    max-width:680px;
}

.card-turismo{
    background:#fff;
    border:none;
    border-radius:26px;
    overflow:hidden;
    box-shadow:var(--sombra);
    transition:transform .22s ease, box-shadow .22s ease;
    height:100%;
}

.card-turismo img{
    width:100%;
    height:240px;
    object-fit:cover;
    background:#e2e8f0;
    display:block;
}

.card-turismo:hover{
    transform:translateY(-6px);
    box-shadow:0 18px 45px rgba(15,23,42,.15);
}

.card-turismo img{
    width:100%;
    height:240px;
    object-fit:cover;
}

.card-turismo .card-body{
    padding:24px;
}

.card-turismo h4{
    font-size:1.25rem;
    font-weight:800;
    margin-bottom:8px;
    letter-spacing:-.4px;
}

.card-meta{
    color:var(--gris);
    font-size:.95rem;
    margin-bottom:12px;
}

.card-text{
    color:#475569;
    line-height:1.65;
    font-size:.98rem;
}

.destino-card{
    position:relative;
    min-height:320px;
    border-radius:28px;
    overflow:hidden;
    box-shadow:var(--sombra);
    transition:transform .25s ease;
}

.destino-card:hover{
    transform:translateY(-6px);
}

.destino-card img{
    width:100%;
    height:320px;
    object-fit:cover;
}

.destino-overlay{
    position:absolute;
    inset:0;
    display:flex;
    align-items:flex-end;
    padding:28px;
    background:linear-gradient(to top, rgba(2,6,23,.88) 8%, rgba(2,6,23,.35) 45%, rgba(2,6,23,.10) 100%);
}

.destino-overlay h4{
    font-size:1.7rem;
    font-weight:900;
    margin-bottom:6px;
    letter-spacing:-.7px;
    color:#ffffff;
    text-shadow:0 3px 14px rgba(0,0,0,.45);
}

.destino-overlay span{
    color:rgba(255,255,255,.96);
    font-weight:500;
    text-shadow:0 2px 10px rgba(0,0,0,.35);
}

.destino-overlay > div{
    background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00));
    padding:8px 10px;
    border-radius:14px;
}
.badge-soft{
    display:inline-flex;
    align-items:center;
    gap:6px;
    background:#eef6ff;
    color:#1d4ed8;
    border-radius:999px;
    padding:7px 12px;
    font-size:.82rem;
    font-weight:700;
}

.badge-servicio{
    background:#ecfdf5;
    color:#166534;
    border:1px solid #d1fae5;
    padding:8px 12px;
    border-radius:999px;
    font-size:.86rem;
    margin:4px 6px 0 0;
    display:inline-block;
}

.box-detalle{
    background:#fff;
    border-radius:26px;
    box-shadow:var(--sombra);
    padding:28px;
}

.galeria-mini img{
    border-radius:16px;
    height:110px;
    object-fit:cover;
    width:100%;
}



.page-hero-sm{
    padding:70px 0 30px;
}

.filtros-box{
    background:#fff;
    border-radius:24px;
    box-shadow:var(--sombra);
    padding:22px;
}

@media (max-width: 991px){
    .hero{
        min-height:auto;
        padding:70px 0;
    }

    .hero h1{
        margin-top:10px;
    }

    .buscador-box{
        margin-top:10px;
    }
}

@media (max-width: 767px){
    .section-block{
        padding:60px 0;
    }

    .hero{
        padding:60px 0 50px;
    }

    .hero p{
        font-size:1.05rem;
    }

    .navbar-brand{
        font-size:1.45rem;
    }
}


.navbar-dark .navbar-nav .nav-link.active{
    color:#ffffff;
    font-weight:800;
    position:relative;
}

.navbar-dark .navbar-nav .nav-link.active::after{
    content:"";
    position:absolute;
    left:12px;
    right:12px;
    bottom:-6px;
    height:3px;
    border-radius:999px;
    background:rgba(255,255,255,.95);
}

.navbar-text{
    font-weight:600;
    letter-spacing:.2px;
}

.form-control-lg,
.form-select-lg,
.form-control{
    border-radius:16px;
    border:1px solid #dbe3ef;
    box-shadow:none !important;
}

.form-control:focus,
.form-select:focus{
    border-color:#93c5fd;
    box-shadow:0 0 0 4px rgba(59,130,246,.12) !important;
}

.breadcrumb a{
    text-decoration:none;
}

.btn{
    font-weight:600;
}

.alert{
    border:none;
}

.text-muted{
    color:#64748b !important;
}


.encabezado-categoria{
    margin-bottom: 2rem;
}

.titulo-categoria{
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: #0f2747;
    margin-bottom: .75rem;
}

.subtitulo-categoria{
    max-width: 760px;
    font-size: 1.1rem;
    line-height: 1.7;
    color: #5f6f85;
    margin: 0;
    padding-left: 1rem;
    border-left: 4px solid #dbe7ff;
}

.subtitulo-categoria a{
    color: #1f6bff;
    text-decoration: none;
    font-weight: 600;
    border-bottom: 1px solid rgba(31, 107, 255, .25);
    transition: all .2s ease;
}

.subtitulo-categoria a:hover{
    color: #0d57e6;
    border-bottom-color: rgba(13, 87, 230, .45);
}

.subtitulo-categoria strong{
    color: #24364d;
    font-weight: 700;
}

.subtitulo-chip{
    display: inline-block;
    padding: .18rem .65rem;
    margin: 0 .15rem;
    border-radius: 999px;
    background: #eef4ff;
    color: #1f4fbf;
    font-weight: 700;
    font-size: .95rem;
    white-space: nowrap;
}



.footer-premium {
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, #0f172a 0%, #111827 100%);
    color: #d6ddeb;
    border-top: 1px solid rgba(255,255,255,0.06);
}

.footer-top-shape {
    position: absolute;
    top: -120px;
    right: -80px;
    width: 320px;
    height: 320px;
    background: radial-gradient(circle, rgba(34,197,94,0.16) 0%, rgba(34,197,94,0) 70%);
    pointer-events: none;
}

.footer-brand-card {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 22px;
    padding: 28px;
    backdrop-filter: blur(8px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.18);
}

.footer-kicker {
    display: inline-block;
    margin-bottom: 12px;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(34,197,94,0.14);
    color: #a7f3d0;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.footer-title-main {
    color: #ffffff;
    font-size: 1.5rem;
    font-weight: 800;
}

.footer-text {
    color: #c6d0e0;
    line-height: 1.75;
}

.footer-heading {
    color: #ffffff;
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 1rem;
}

.footer-links li + li {
    margin-top: .7rem;
}

.footer-links a {
    color: #d6ddeb;
    text-decoration: none;
    transition: all .2s ease;
}

.footer-links a:hover {
    color: #7ee7a8;
    padding-left: 4px;
}

.footer-links-two-cols {
    columns: 2;
    column-gap: 18px;
}

.footer-links-two-cols li {
    break-inside: avoid;
    margin-bottom: .7rem;
}

.footer-contact-box {
    display: grid;
    gap: 14px;
}

.footer-contact-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.footer-contact-label {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #8fa2bf;
}

.footer-contact-item a,
.footer-contact-item span {
    color: #eef2f7;
    text-decoration: none;
}

.footer-popular-searches {
    padding: 28px;
    border-radius: 22px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
}

.footer-mini-text {
    color: #aebbd0;
    font-size: .95rem;
}

.footer-chip-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.footer-chip {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 9px 16px;
    border-radius: 999px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    color: #f8fafc;
    text-decoration: none;
    font-size: .92rem;
    transition: all .2s ease;
}

.footer-chip:hover {
    color: #08111f;
    background: #7ee7a8;
    border-color: #7ee7a8;
    transform: translateY(-1px);
}

.footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.08);
}

.footer-copy {
    color: #9fb0c8;
    font-size: .92rem;
}

@media (max-width: 991.98px) {
    .footer-links-two-cols {
        columns: 1;
    }
}

@media (max-width: 575.98px) {
    .footer-brand-card,
    .footer-popular-searches {
        padding: 22px;
        border-radius: 18px;
    }

    .footer-title-main {
        font-size: 1.35rem;
    }

    .footer-chip {
        width: 100%;
        justify-content: center;
        text-align: center;
    }
}


.d-grid .btn i {
    font-size: 1rem;
    line-height: 1;
}