﻿/* =========================================================
   07) TURISMO AVENTURA (cards + modals + reserva avanzada)
   ========================================================= */

/* --- helpers locales --- */
#turismo-aventura {
    --ta-card-bg: radial-gradient(circle at 0% -30%, rgba(255,213,165,0.25), transparent 55%), #fff;
    --ta-shadow: 0 18px 40px rgba(0,0,0,0.06), 0 0 0 1px rgba(255,255,255,0.85);
    --ta-shadow-hover: 0 26px 70px rgba(0,0,0,0.12), 0 0 0 1px rgba(255,255,255,1);
    --ta-radius: 1.6rem;
    --ta-radius-sm: 1.2rem;
    --ta-line: rgba(215,198,182,0.9);
    --ta-soft: rgba(249,225,193,0.55);
    --ta-soft-2: rgba(249,193,133,0.92);
    --ta-ink: var(--tal-text);
    --ta-muted: var(--tal-muted);
}

/* ====== Section background ====== */
#turismo-aventura {
    position: relative;
    padding: 4rem 0;
    background: radial-gradient(circle at 0% 0%, rgba(255,215,170,0.25), transparent 55%), radial-gradient(circle at 100% 100%, rgba(230,198,170,0.24), transparent 60%), var(--tal-bg-soft);
    overflow: hidden;
}

    #turismo-aventura::before {
        content: "";
        position: absolute;
        inset: -1px;
        background: radial-gradient(620px 240px at 18% 18%, rgba(201,115,44,0.08), transparent 65%), radial-gradient(620px 240px at 82% 82%, rgba(228,167,105,0.10), transparent 60%);
        pointer-events: none;
    }

    /* ====== Header ====== */
    #turismo-aventura .ta-header {
        position: relative;
        z-index: 1;
        text-align: center;
        margin-bottom: 1.6rem;
    }

        #turismo-aventura .ta-header h2 {
            font-weight: 900;
            letter-spacing: -0.02em;
            margin-bottom: .55rem;
            color: var(--ta-ink);
        }

        #turismo-aventura .ta-header .section-subtitle {
            max-width: 940px;
            margin: 0 auto 1.05rem;
            color: var(--ta-muted);
            line-height: 1.55;
            font-size: 1.02rem;
        }

    /* chips */
    #turismo-aventura .ta-chips {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: .55rem;
        margin-top: .25rem;
    }

    #turismo-aventura .tag-pill {
        display: inline-flex;
        align-items: center;
        gap: .45rem;
        padding: .42rem .9rem;
        border-radius: 999px;
        border: 1px solid rgba(215,198,182,0.9);
        background: rgba(255,255,255,0.75);
        box-shadow: 0 8px 18px rgba(0,0,0,0.06);
        color: var(--ta-muted);
        font-weight: 800;
        letter-spacing: .04em;
        font-size: .86rem;
        backdrop-filter: blur(8px);
    }

    /* ====== Card ====== */
    #turismo-aventura .cd-card {
        height: 100%;
        display: flex;
        flex-direction: column;
        border-radius: var(--ta-radius);
        padding: 1.35rem 1.35rem 1.15rem;
        border: 1px solid var(--ta-line);
        box-shadow: var(--ta-shadow);
        background: var(--ta-card-bg);
        transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
        position: relative;
        overflow: hidden;
    }

        #turismo-aventura .cd-card::after {
            content: "";
            position: absolute;
            inset: -40% -40% auto auto;
            width: 280px;
            height: 280px;
            background: radial-gradient(circle at 30% 30%, rgba(201,115,44,0.14), transparent 60%);
            transform: rotate(18deg);
            pointer-events: none;
        }

        #turismo-aventura .cd-card:hover {
            transform: translateY(-7px);
            box-shadow: var(--ta-shadow-hover);
            border-color: var(--tal-gold-soft);
        }

    #turismo-aventura .cd-card-img-wrapper {
        border-radius: var(--ta-radius-sm);
        aspect-ratio: 4 / 3;
        overflow: hidden;
        margin-bottom: .85rem;
        position: relative;
        box-shadow: 0 12px 30px rgba(0,0,0,0.10);
    }

    #turismo-aventura .cd-card-img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transform: scale(1.04);
        transition: transform .35s ease;
    }

    #turismo-aventura .cd-card:hover .cd-card-img {
        transform: scale(1.09);
    }

    #turismo-aventura .cd-card h3 {
        font-size: 1.05rem;
        line-height: 1.25;
        margin: .15rem 0 .45rem;
        font-weight: 950;
        letter-spacing: -0.01em;
        color: var(--ta-ink);
    }

/* meta top badges */
.package-meta-top {
    display: inline-flex;
    flex-wrap: wrap;
    gap: .45rem;
    margin-top: .1rem;
    margin-bottom: .35rem;
    position: relative;
    z-index: 1;
}

.pkg-tag, .pkg-diff {
    padding: .18rem .72rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: .12em;
    font-weight: 900;
    font-size: .68rem;
    border: 1px solid rgba(215,198,182,0.9);
    background: #FFF8F1;
    color: var(--ta-muted);
}

.pkg-diff {
    border: none;
    color: #fff;
}

.pkg-diff-baja {
    background: linear-gradient(135deg,#34A874,#1E7E57);
}

.pkg-diff-media {
    background: linear-gradient(135deg,#E8A93C,#C9732C);
}

.pkg-diff-alta {
    background: linear-gradient(135deg,#D9534F,#B02A37);
}

/* short description */
#turismo-aventura .cd-meta {
    color: var(--ta-muted);
    line-height: 1.45;
    margin-bottom: .75rem;
}

/* info rows */
#turismo-aventura .pkg-info {
    color: var(--ta-ink);
    margin-bottom: .8rem;
    font-size: .95rem;
}

    #turismo-aventura .pkg-info i {
        color: var(--tal-gold);
        margin-right: .35rem;
    }

/* price row */
#turismo-aventura .pkg-price {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .6rem;
    margin-top: .1rem;
    margin-bottom: .85rem;
    padding: .6rem .75rem;
    border-radius: 1rem;
    border: 1px solid rgba(215,198,182,0.85);
    background: rgba(255,255,255,0.85);
    box-shadow: 0 10px 22px rgba(0,0,0,0.06);
}

    #turismo-aventura .pkg-price .amount {
        font-weight: 950;
        letter-spacing: -0.02em;
        color: var(--ta-ink);
    }

        #turismo-aventura .pkg-price .amount span {
            color: var(--tal-gold);
        }

    #turismo-aventura .pkg-price .note {
        color: var(--ta-muted);
        font-size: .85rem;
        font-weight: 850;
    }

/* CTAs */
#turismo-aventura .pkg-actions {
    margin-top: auto;
    display: flex;
    gap: .55rem;
}

#turismo-aventura .ta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    width: 100%;
    padding: .55rem .9rem;
    border-radius: 999px;
    font-weight: 950;
    letter-spacing: .02em;
    border: 1px solid rgba(215,198,182,0.9);
    text-decoration: none;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
    cursor: pointer;
    user-select: none;
}

    #turismo-aventura .ta-btn:focus {
        outline: none;
        box-shadow: 0 0 0 4px rgba(201,115,44,0.22);
    }

#turismo-aventura .ta-btn-details {
    background: rgba(249,225,193,0.55);
    color: var(--tal-gold);
    border-color: rgba(249,193,133,0.85);
}

    #turismo-aventura .ta-btn-details:hover {
        background: rgba(249,193,133,0.96);
        color: #40210F;
        transform: translateY(-1px);
        box-shadow: 0 10px 22px rgba(0,0,0,0.12);
    }

#turismo-aventura .ta-btn-book {
    background: linear-gradient(135deg, rgba(201,115,44,0.95), rgba(228,167,105,0.95));
    color: #fff;
    border-color: rgba(201,115,44,0.35);
}

    #turismo-aventura .ta-btn-book:hover {
        transform: translateY(-1px);
        box-shadow: 0 12px 26px rgba(0,0,0,0.16);
        filter: saturate(1.05);
    }

/* footnote */
#turismo-aventura .ta-footnote {
    text-align: center;
    margin-top: 1.35rem;
    color: var(--ta-muted);
    font-weight: 700;
    font-size: .92rem;
}

/* =========================================================
   MODALS (custom, simple + premium)
   ========================================================= */
.ta-modal {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

    .ta-modal.is-open {
        display: flex;
    }

.ta-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(20,12,8,0.55);
    backdrop-filter: blur(10px);
}

.ta-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(980px, 96vw);
    max-height: min(86vh, 860px);
    overflow: auto;
    border-radius: 1.35rem;
    border: 1px solid rgba(255,255,255,0.55);
    box-shadow: 0 30px 90px rgba(0,0,0,0.30);
    background: radial-gradient(circle at 0% 0%, rgba(255,213,165,0.18), transparent 55%), radial-gradient(circle at 100% 100%, rgba(228,167,105,0.18), transparent 55%), rgba(255,255,255,0.92);
    -webkit-backdrop-filter: blur(10px);
}

.ta-modal__header {
    padding: 1.05rem 1.15rem .85rem;
    border-bottom: 1px solid rgba(215,198,182,0.65);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: .75rem;
}

.ta-modal__title {
    margin: 0;
    font-weight: 950;
    letter-spacing: -0.02em;
    color: var(--ta-ink);
    font-size: 1.15rem;
}

.ta-modal__subtitle {
    margin: .25rem 0 0;
    color: var(--ta-muted);
    font-weight: 750;
    font-size: .95rem;
    line-height: 1.35;
}

.ta-modal__close {
    border: 1px solid rgba(215,198,182,0.95);
    background: rgba(255,255,255,0.8);
    width: 42px;
    height: 42px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform .15s ease, box-shadow .15s ease;
    flex: 0 0 auto;
}

    .ta-modal__close:hover {
        transform: translateY(-1px);
        box-shadow: 0 10px 22px rgba(0,0,0,0.12);
    }

.ta-modal__body {
    padding: 1rem 1.15rem 1.15rem;
}

.ta-modal__grid {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 1rem;
}

@media (max-width: 860px) {
    .ta-modal__grid {
        grid-template-columns: 1fr;
    }
}

/* panels */
.ta-panel {
    border: 1px solid rgba(215,198,182,0.75);
    background: rgba(255,255,255,0.86);
    border-radius: 1.1rem;
    padding: .95rem 1rem;
    box-shadow: 0 14px 30px rgba(0,0,0,0.06);
}

    .ta-panel h4 {
        margin: 0 0 .55rem;
        font-weight: 950;
        letter-spacing: -0.01em;
        color: var(--ta-ink);
        font-size: 1rem;
    }

/* kv */
.ta-kv {
    display: grid;
    grid-template-columns: 150px 1fr;
    gap: .45rem .75rem;
    align-items: start;
    font-size: .95rem;
}

    .ta-kv .k {
        color: var(--ta-muted);
        font-weight: 900;
        letter-spacing: .02em;
    }

    .ta-kv .v {
        color: var(--ta-ink);
        font-weight: 800;
    }

/* list */
.ta-list {
    margin: .3rem 0 0;
    padding-left: 1.1rem;
    color: var(--ta-ink);
}

    .ta-list li {
        margin: .35rem 0;
        line-height: 1.35;
    }

/* badges */
.ta-badges {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    margin-top: .35rem;
}

.ta-badge {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .32rem .75rem;
    border-radius: 999px;
    border: 1px solid rgba(215,198,182,0.85);
    background: rgba(255,248,241,0.92);
    color: var(--ta-muted);
    font-weight: 900;
    letter-spacing: .08em;
    font-size: .72rem;
    text-transform: uppercase;
}

/* form premium */
.ta-form {
    display: grid;
    gap: .75rem;
    margin-top: .35rem;
}

.ta-field {
    display: grid;
    gap: .35rem;
}

.ta-label {
    color: var(--ta-muted);
    font-weight: 900;
    font-size: .9rem;
    letter-spacing: .02em;
}

.ta-input, .ta-select {
    width: 100%;
    border-radius: 1rem;
    border: 1px solid rgba(215,198,182,0.9);
    background: rgba(255,255,255,0.92);
    padding: .62rem .75rem;
    font-weight: 850;
    color: var(--ta-ink);
    outline: none;
    transition: box-shadow .15s ease, border-color .15s ease, transform .12s ease;
}

    .ta-input:focus, .ta-select:focus {
        border-color: rgba(201,115,44,0.55);
        box-shadow: 0 0 0 4px rgba(201,115,44,0.18);
    }

.ta-row-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
}

@media (max-width: 520px) {
    .ta-row-2 {
        grid-template-columns: 1fr;
    }
}

/* totals */
.ta-total {
    margin-top: .4rem;
    border-radius: 1rem;
    padding: .75rem .85rem;
    border: 1px solid rgba(215,198,182,0.9);
    background: rgba(249,225,193,0.35);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
}

    .ta-total .tlabel {
        color: var(--ta-muted);
        font-weight: 950;
    }

    .ta-total .tval {
        color: var(--ta-ink);
        font-weight: 1000;
        letter-spacing: -0.02em;
        font-size: 1.05rem;
    }

        .ta-total .tval span {
            color: var(--tal-gold);
        }

/* bank */
.ta-bank {
    display: grid;
    gap: .6rem;
    margin-top: .65rem;
}

    .ta-bank .row {
        display: flex;
        justify-content: space-between;
        gap: .85rem;
        border: 1px dashed rgba(215,198,182,0.9);
        background: rgba(249,225,193,0.25);
        border-radius: 1rem;
        padding: .65rem .75rem;
        margin: 0;
    }

    .ta-bank .lbl {
        color: var(--ta-muted);
        font-weight: 900;
    }

    .ta-bank .val {
        color: var(--ta-ink);
        font-weight: 950;
        text-align: right;
        word-break: break-word;
    }

.ta-copy {
    margin-top: .65rem;
    display: flex;
    gap: .55rem;
    flex-wrap: wrap;
}

.ta-mini-btn {
    border: 1px solid rgba(215,198,182,0.95);
    background: rgba(255,255,255,0.88);
    padding: .48rem .9rem;
    border-radius: 999px;
    font-weight: 950;
    cursor: pointer;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
    text-decoration: none;
    color: var(--ta-ink);
    display: inline-flex;
    align-items: center;
    gap: .45rem;
}

    .ta-mini-btn:hover {
        transform: translateY(-1px);
        box-shadow: 0 10px 22px rgba(0,0,0,0.10);
        background: rgba(255,255,255,0.98);
    }

.ta-mini-btn--wa {
    border-color: rgba(30,126,87,0.35);
    background: linear-gradient(135deg, rgba(52,168,116,0.96), rgba(30,126,87,0.96));
    color: #fff;
}

    .ta-mini-btn--wa:hover {
        box-shadow: 0 12px 28px rgba(0,0,0,0.16);
    }

.ta-alert {
    margin-top: .75rem;
    border-radius: 1rem;
    padding: .75rem .85rem;
    border: 1px solid rgba(215,198,182,0.85);
    background: rgba(255,255,255,0.82);
    color: var(--ta-muted);
    font-weight: 780;
    line-height: 1.35;
}
