/* ============================================
   INTERNAL PAGES STYLES
   NAUW Starter Theme
   ============================================ */

/* ============================================
   LEGAL PAGES
   ============================================ */
.legal-page {
    padding: 6rem 0 4rem;
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%);
    min-height: 60vh;
}

.legal-page .container {
    max-width: 800px;
}

.legal-page h1 {
    font-family: var(--font-body);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 100;
    margin-bottom: 2rem;
}

.legal-page h2 {
    font-size: 1.4rem;
    font-weight: 500;
    margin: 2rem 0 1rem;
}

.legal-page h3 {
    font-size: 1.1rem;
    font-weight: 500;
    margin: 1.5rem 0 0.75rem;
}

.legal-page p {
    opacity: 0.85;
    margin-bottom: 1rem;
    line-height: 1.7;
}

.legal-page ul,
.legal-page ol {
    margin: 1rem 0 1rem 1.5rem;
    list-style: disc;
    opacity: 0.85;
}

.legal-page ol {
    list-style: decimal;
}

.legal-page li {
    margin-bottom: 0.5rem;
    line-height: 1.6;
}

.legal-page a {
    color: var(--color-red);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.legal-page a:hover {
    opacity: 1;
}

/* ============================================
   THANK YOU PAGE
   ============================================ */
.thankyou-page {
    padding: 8rem 0 6rem;
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%);
    min-height: 70vh;
    display: flex;
    align-items: center;
}

.thankyou-content {
    text-align: center;
    max-width: 600px;
    margin: 0 auto;
}

.thankyou-icon {
    font-size: 4rem;
    margin-bottom: 1.5rem;
    color: #4ade80;
}

.thankyou-content h1 {
    font-family: var(--font-body);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 100;
    margin-bottom: 1rem;
}

.thankyou-content p {
    opacity: 0.8;
    margin-bottom: 2rem;
    line-height: 1.7;
}

.thankyou-content .btn {
    width: auto;
    display: inline-flex;
}

/* ============================================
   PAST EVENTS DIRECTORY
   ============================================ */
.archive-eventos-pasados {
    padding: 6.5rem 0 4rem;
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%);
    min-height: 80vh;
}

.archive-eventos-pasados h1 {
    font-family: var(--font-body);
    font-size: clamp(2rem, 4vw, 3.5rem);
    font-weight: 100;
    text-align: center;
    margin-bottom: 2rem;
}

.archive-eventos-pasados h1 em {
    font-family: var(--font-display);
    font-style: normal;
    font-weight: 400;
}

.eventos-pasados-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.5rem;
}

@media (max-width: 480px) {
    .eventos-pasados-grid {
        grid-template-columns: 1fr;
    }
}

/* Evento card — shared styles (same as home) */
.eventos-pasados-grid .evento-card {
    background: var(--color-dark);
    border-radius: 16px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.eventos-pasados-grid .evento-card-link {
    display: block;
    flex: 1;
}

.eventos-pasados-grid .evento-card-image {
    position: relative;
    aspect-ratio: 3 / 2;
    overflow: hidden;
    border-radius: 12px;
    margin: 0.75rem;
}

.eventos-pasados-grid .evento-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.eventos-pasados-grid .evento-card:hover .evento-card-image img {
    transform: scale(1.05);
}

.eventos-pasados-grid .evento-card-placeholder {
    background: var(--gradient-hero);
    width: 100%;
    height: 100%;
}

.eventos-pasados-grid .evento-card-date {
    position: absolute;
    top: 1rem;
    left: 1rem;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.eventos-pasados-grid .date-label {
    font-family: var(--font-body);
    font-size: 0.85rem;
    font-weight: 100;
    letter-spacing: 0.1em;
    opacity: 0.8;
}

.eventos-pasados-grid .date-value {
    font-family: var(--font-body);
    font-size: 1.3rem;
    font-weight: 700;
    letter-spacing: 0.03em;
}

.eventos-pasados-grid .evento-card-info {
    padding: 1rem 1.25rem 0.5rem;
}

.eventos-pasados-grid .evento-card-title {
    font-family: var(--font-body);
    font-size: 1.2rem;
    font-weight: 400;
    letter-spacing: 0.02em;
}

.eventos-pasados-grid .evento-card .btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin: 0.25rem 0.75rem 0.75rem;
    font-family: var(--font-body);
    font-size: 0.85rem;
    font-weight: 400;
    padding: 0.7rem 1.5rem;
    border-radius: 8px;
    width: auto;
    overflow: visible;
}

.eventos-pasados-empty {
    text-align: center;
    opacity: 0.6;
    padding: 3rem 0;
}

/* ============================================
   ARTISTS DIRECTORY
   ============================================ */
.archive-artistas {
    padding: 6.5rem 0 4rem;
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-red-dark) 50%, var(--color-dark-brown) 100%);
    min-height: 80vh;
}

.archive-artistas h1 {
    font-family: var(--font-body);
    font-size: clamp(2rem, 4vw, 3.5rem);
    font-weight: 100;
    text-align: center;
    margin-bottom: 2rem;
}

.archive-artistas h1 em {
    font-family: var(--font-display);
    font-style: normal;
    font-weight: 400;
}

/* Search bar */
.artistas-search {
    max-width: 500px;
    margin: 0 auto 3rem;
    position: relative;
}

.artistas-search input {
    width: 100%;
    padding: 0.9rem 1.5rem 0.9rem 3rem;
    border-radius: 50px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.05);
    color: var(--color-white);
    font-size: 1rem;
    outline: none;
    transition: border-color 0.3s ease;
}

.artistas-search input::placeholder {
    color: var(--color-gray);
}

.artistas-search input:focus {
    border-color: var(--color-red);
}

.artistas-search-icon {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0.5;
    color: var(--color-white);
}

/* Artists grid */
.artistas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1.5rem;
}

.artistas-no-results {
    text-align: center;
    opacity: 0.6;
    padding: 3rem 0;
    display: none;
}

/* ============================================
   SINGLE ARTIST PAGE
   ============================================ */
.single-artista {
    padding: 3rem 0 4rem;
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%);
    min-height: 70vh;
}

.artista-back {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--color-white);
    font-size: 0.85rem;
    font-weight: 400;
    margin-bottom: 1.5rem;
    opacity: 0.6;
    transition: opacity 0.3s ease;
}

.artista-back:hover {
    opacity: 1;
}

.artista-detail-grid {
    display: grid;
    grid-template-columns: 2fr 3fr;
    gap: 3rem;
    align-items: start;
}

.artista-detail-image img {
    width: 100%;
    max-height: 520px;
    object-fit: cover;
    border-radius: 12px;
}

.artista-detail-placeholder {
    width: 100%;
    aspect-ratio: 3/4;
    background: var(--color-dark-gray);
    border-radius: 12px;
}

.artista-detail-name {
    font-family: var(--font-body);
    font-size: clamp(2rem, 4vw, 3.5rem);
    font-weight: 100;
    margin-bottom: 1.5rem;
}

.artista-detail-bio {
    line-height: 1.8;
    opacity: 0.85;
    margin-bottom: 2rem;
}

.artista-detail-bio p {
    margin-bottom: 1rem;
}

.artista-detail-links {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.artista-link {
    width: auto;
    padding: 0.7rem 1.5rem;
    font-size: 0.9rem;
}

/* ============================================
   SINGLE EVENT — CUSTOM TWO-COLUMN LAYOUT
   ============================================ */
.evento-single {
    padding: 6rem 0 2rem;
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%);
    min-height: 80vh;
}

/* Back link — needs !important to override body.single-tribe_events a catch-all */
.evento-back {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--color-white) !important;
    font-size: 0.85rem;
    font-weight: 400;
    margin-bottom: 2rem;
    opacity: 0.6;
    transition: opacity 0.3s ease;
}

.evento-back:hover {
    opacity: 1;
    color: var(--color-white) !important;
}

/* Two-column grid — equal height columns */
.evento-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
    align-items: stretch;
    margin-bottom: 0;
}

/* Poster (left column) — fill height */
.evento-poster {
    display: flex;
}

.evento-poster img {
    width: 100%;
    border-radius: 12px;
    object-fit: cover;
}

.evento-poster-placeholder {
    width: 100%;
    flex: 1;
    background: var(--color-dark-gray);
    border-radius: 12px;
}

/* Details (right column) */
.evento-info {
    display: flex;
    flex-direction: column;
}

.evento-title {
    font-family: var(--font-body);
    font-size: clamp(1.8rem, 3.5vw, 2.8rem);
    font-weight: 100;
    margin-bottom: 1rem;
    color: var(--color-white);
    line-height: 1.2;
}

/* Meta info rows */
.evento-meta {
    margin-bottom: 1rem;
}

.evento-meta-row {
    padding: 0.6rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.evento-meta-row:first-child {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

/* Double row (Fecha + Horario side by side) */
.evento-meta-row--double {
    display: flex;
    gap: 2rem;
}

.evento-meta-cell {
    flex: 1;
}

.evento-meta-label {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    opacity: 0.45;
    margin-bottom: 0.3rem;
    color: var(--color-white);
}

.evento-meta-value {
    font-size: 1.05rem;
    color: var(--color-white);
}

.evento-map-link {
    display: inline-block;
    margin-left: 0.75rem;
    font-size: 0.85rem;
    color: var(--color-red) !important;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.evento-map-link:hover {
    opacity: 0.8;
}

/* Ticket purchase widget area */
.evento-tickets-area {
    margin-top: -0.5rem;
    margin-bottom: -0.5rem;
}

/* Ticket form wrapper — no outer box, content only */
.evento-ticket-form {
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
    overflow: hidden;
    font-size: 0.9rem;
}

/* All text white */
.evento-ticket-form,
.evento-ticket-form h2,
.evento-ticket-form h3,
.evento-ticket-form h4,
.evento-ticket-form label,
.evento-ticket-form span,
.evento-ticket-form p,
.evento-ticket-form td,
.evento-ticket-form th,
.evento-ticket-form div,
.evento-ticket-form a,
.evento-ticket-form button,
.evento-ticket-form .tribe-tickets__tickets-item-content-title,
.evento-ticket-form .tribe-tickets__tickets-item-details-content,
.evento-ticket-form .tribe-tickets__tickets-item-extra-price,
.evento-ticket-form .tribe-tickets__tickets-sale-price,
.evento-ticket-form .tribe-amount,
.evento-ticket-form .tribe-tickets__tickets-footer-quantity,
.evento-ticket-form .tribe-tickets__tickets-footer-total,
.evento-ticket-form .tribe-tickets__tickets-footer-quantity-label,
.evento-ticket-form .tribe-tickets__tickets-footer-total-label {
    color: var(--color-white) !important;
}

/* Reset backgrounds */
.evento-ticket-form .tribe-events-tickets,
.evento-ticket-form .tribe-tickets,
.evento-ticket-form .tribe-tickets__form,
.evento-ticket-form .tribe-common,
.evento-ticket-form .tribe-tickets__tickets-wrapper,
.evento-ticket-form .tribe-tickets__tickets-item,
.evento-ticket-form .tribe-common--breakpoint-medium,
.evento-ticket-form .event-tickets,
.evento-ticket-form table,
.evento-ticket-form tr,
.evento-ticket-form td {
    background: transparent !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
}

/* Ticket title — smaller */
.evento-ticket-form .tribe-tickets__tickets-title {
    font-size: 1rem !important;
    font-weight: 500 !important;
    margin-bottom: 0.8rem !important;
}

/* Hide cart notice (yellow-bordered box) */
.evento-ticket-form .tribe-tickets__notice,
.evento-ticket-form .tribe-tickets__notice--barred {
    display: none !important;
}

/* Hide availability / stock count ("Ilimitado") */
.evento-ticket-form .tribe-tickets__tickets-item-extra-available {
    display: none !important;
}

/* Ticket item — compact */
.evento-ticket-form .tribe-tickets__tickets-item {
    padding: 0.6rem 0 !important;
}

.evento-ticket-form .tribe-tickets__tickets-item-content-title {
    font-size: 0.85rem !important;
}

.evento-ticket-form .tribe-tickets__tickets-item-details-content {
    font-size: 0.8rem !important;
    opacity: 0.7;
}

.evento-ticket-form .tribe-tickets__tickets-item-extra-price {
    font-size: 0.95rem !important;
    font-weight: 600 !important;
}

/* Quantity wrapper — flex alignment */
.evento-ticket-form .tribe-tickets__tickets-item-quantity,
.evento-ticket-form .tribe-tickets__tickets-item-quantity-number {
    display: flex !important;
    align-items: center !important;
    gap: 0.25rem;
}

/* Quantity input */
.evento-ticket-form input[type="number"],
.evento-ticket-form .tribe-tickets__tickets-item-quantity-number-input {
    background: rgba(255, 255, 255, 0.08) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
    border-radius: 6px;
    text-align: center;
    width: 3rem !important;
    height: 2rem !important;
    font-size: 0.9rem !important;
}

/* +/- buttons */
.evento-ticket-form .tribe-tickets__tickets-item-quantity-remove,
.evento-ticket-form .tribe-tickets__tickets-item-quantity-add {
    color: var(--color-white) !important;
    background: rgba(255, 255, 255, 0.08) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 6px;
    width: 2rem !important;
    height: 2rem !important;
    font-size: 0.9rem !important;
}

/* Footer (Cantidad + Total) — compact */
.evento-ticket-form .tribe-tickets__tickets-footer {
    padding-top: 0.8rem !important;
    margin-top: 0.5rem !important;
    font-size: 0.85rem !important;
    border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
}

/* Submit / Get Tickets button */
.evento-ticket-form .tribe-common-c-btn,
.evento-ticket-form .tribe-tickets__tickets-buy,
.evento-ticket-form input[type="submit"],
.evento-ticket-form button[type="submit"] {
    background: var(--color-red) !important;
    color: var(--color-white) !important;
    border: none !important;
    border-radius: 50px;
    padding: 0.7rem 1.5rem;
    font-weight: 500;
    font-size: 0.9rem;
    cursor: pointer;
    transition: var(--transition);
    margin-top: 0.3rem;
}

.evento-ticket-form .tribe-common-c-btn:hover,
.evento-ticket-form input[type="submit"]:hover,
.evento-ticket-form button[type="submit"]:hover {
    background: var(--color-red-dark) !important;
}

/* Override "Obtener Entradas" → "Comprar Entradas" */
.evento-ticket-form .tribe-tickets__tickets-buy {
    font-size: 0 !important;
    line-height: 0;
}

.evento-ticket-form .tribe-tickets__tickets-buy::after {
    content: 'Comprar entradas';
    font-size: 0.9rem;
    line-height: normal;
}

/* Hide unnecessary TEC chrome */
.evento-ticket-form .tribe-events-back,
.evento-ticket-form .tribe-events-single-event-title,
.evento-ticket-form .tribe-events-event-image,
.evento-ticket-form .tribe-events-schedule,
.evento-ticket-form .tribe-events-event-meta,
.evento-ticket-form .tribe-events-content,
.evento-ticket-form .tribe-events-cal-links,
.evento-ticket-form .tribe-events-nav-pagination,
.evento-ticket-form .tribe-events-sub-nav,
.evento-ticket-form .tribe-events-ajax-loading,
.evento-ticket-form .tribe-events-before-html,
.evento-ticket-form .tribe-events-after-html {
    display: none !important;
}

/* Description (inside right column, below tickets) */
.evento-description {
    margin-top: 1rem;
    padding-top: 0.8rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.evento-description h2 {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    opacity: 0.45;
    margin-bottom: 0.8rem;
    color: var(--color-white);
}

.evento-description p {
    opacity: 0.85;
    line-height: 1.7;
    margin-bottom: 1rem;
    color: var(--color-white);
}

.evento-description a {
    color: var(--color-red);
}

.evento-description ul,
.evento-description ol {
    margin: 1rem 0 1rem 1.5rem;
    opacity: 0.85;
    list-style: disc;
}

.evento-description ol {
    list-style: decimal;
}

.evento-description li {
    margin-bottom: 0.5rem;
    line-height: 1.7;
    color: var(--color-white);
}

/* ============================================
   EVENT ARTISTS — slider mobile / grid desktop
   ============================================ */
.evento-artistas {
    padding: 3.5rem 0 4rem;
    background: linear-gradient(180deg, var(--color-dark-brown) 0%, var(--color-dark) 100%);
}

.evento-artistas .artistas-title {
    text-align: center;
    margin-bottom: 3rem;
}

.evento-artistas .artistas-carousel {
    padding: 0 2rem 3rem;
    max-width: var(--container-max);
    margin: 0 auto;
}

#evento-artistas-swiper .swiper-slide {
    width: 260px;
}

#evento-artistas-swiper .swiper-button-prev,
#evento-artistas-swiper .swiper-button-next {
    color: var(--color-white);
    width: 40px;
    height: 40px;
    background: rgba(0, 0, 0, 0.5);
    border-radius: 50%;
}

#evento-artistas-swiper .swiper-button-prev::after,
#evento-artistas-swiper .swiper-button-next::after {
    font-size: 16px;
}

/* Desktop: disable slider, show as adaptive grid */
@media (min-width: 768px) {
    #evento-artistas-swiper .swiper-wrapper {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 1.25rem;
        transform: none !important;
        max-width: var(--container-max);
        margin: 0 auto;
        padding: 0 2rem;
    }

    #evento-artistas-swiper .swiper-slide {
        width: auto !important;
    }

    #evento-artistas-swiper .swiper-button-prev,
    #evento-artistas-swiper .swiper-button-next {
        display: none;
    }
}

/* ============================================
   EVENT TICKETS — MODAL (Attendee Registration)
   ============================================ */

/* Modal overlay */
.tribe-dialog__overlay.tribe-modal__overlay {
    background: rgba(0, 0, 0, 0.85) !important;
}

/* Modal wrapper — dark card */
.tribe-dialog__wrapper.tribe-modal__wrapper--ar {
    background: var(--color-dark) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    color: var(--color-white) !important;
    max-width: 600px !important;
}

/* Modal title */
.tribe-dialog__title.tribe-modal__title,
.tribe-modal--ar__title {
    color: var(--color-white) !important;
    font-family: var(--font-body) !important;
    font-weight: 400 !important;
    font-size: 1.2rem !important;
    padding: 1.5rem 1.5rem 0.5rem !important;
}

/* Modal content area */
.tribe-dialog__content.tribe-modal__content {
    background: transparent !important;
    color: var(--color-white) !important;
    padding: 0.5rem 1.5rem 1.5rem !important;
}

/* Close button */
.tribe-dialog__close-button.tribe-modal__close-button {
    color: var(--color-white) !important;
    opacity: 0.7;
}

.tribe-dialog__close-button.tribe-modal__close-button:hover {
    opacity: 1;
}

/* All text inside modal white */
.tribe-modal__wrapper--ar *,
.tribe-modal__wrapper--ar h2,
.tribe-modal__wrapper--ar h3,
.tribe-modal__wrapper--ar span,
.tribe-modal__wrapper--ar p,
.tribe-modal__wrapper--ar div,
.tribe-modal__wrapper--ar label,
.tribe-modal__wrapper--ar a,
.tribe-modal__wrapper--ar button,
.tribe-modal-cart *,
.tribe-modal__cart * {
    color: var(--color-white) !important;
}

/* Modal backgrounds transparent */
.tribe-modal__wrapper--ar .tribe-modal__cart,
.tribe-modal__wrapper--ar .tribe-modal-cart,
.tribe-modal__wrapper--ar .tribe-common,
.tribe-modal__wrapper--ar .event-tickets,
.tribe-modal__wrapper--ar .tribe-tickets__form,
.tribe-modal__wrapper--ar .tribe-tickets__tickets-item,
.tribe-modal__wrapper--ar .tribe-tickets__attendee-tickets-form {
    background: transparent !important;
}

/* Ticket item in modal */
.tribe-modal__wrapper--ar .tribe-tickets__tickets-item {
    border-color: rgba(255, 255, 255, 0.1) !important;
    padding: 0.8rem 0 !important;
}

/* Hide "Ilimitado" in modal too */
.tribe-modal__wrapper--ar .tribe-tickets__tickets-item-extra-available {
    display: none !important;
}

/* Hide notices in modal */
.tribe-modal__wrapper--ar .tribe-tickets__notice {
    display: none !important;
}

/* More/Less toggle buttons */
.tribe-modal__wrapper--ar .tribe-tickets__tickets-item-details-summary-button--more,
.tribe-modal__wrapper--ar .tribe-tickets__tickets-item-details-summary-button--less {
    color: var(--color-red) !important;
    background: transparent !important;
    border: none;
    cursor: pointer;
    font-size: 0.8rem;
}

/* Ticket description in modal */
.tribe-modal__wrapper--ar .tribe-tickets__tickets-item-details-content {
    font-size: 0.85rem !important;
    opacity: 0.7;
}

/* Quantity input in modal */
.tribe-modal__wrapper--ar input[type="number"] {
    background: rgba(255, 255, 255, 0.08) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
    border-radius: 6px;
    text-align: center;
}

/* Footer divider */
.tribe-modal__wrapper--ar .tribe-tickets__tickets-footer {
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
    padding-top: 0.8rem !important;
}

/* Attendee section */
.tribe-modal__wrapper--ar .tribe-tickets__attendee-tickets-title {
    font-size: 1rem !important;
    font-weight: 500 !important;
    margin-bottom: 1rem !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
    padding-top: 1rem !important;
}

/* Attendee form fields */
.tribe-modal__wrapper--ar input[type="text"],
.tribe-modal__wrapper--ar input[type="email"],
.tribe-modal__wrapper--ar select,
.tribe-modal__wrapper--ar textarea {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
    border-radius: 8px;
    padding: 0.6rem 0.8rem;
}

.tribe-modal__wrapper--ar input::placeholder {
    color: rgba(255, 255, 255, 0.4) !important;
}

/* "Completar la compra" button */
.tribe-modal__wrapper--ar .tribe-tickets__attendee-tickets-submit,
.tribe-modal__wrapper--ar .tribe-tickets__attendee-tickets-footer-checkout-button {
    background: var(--color-red) !important;
    color: var(--color-white) !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 0.8rem 2rem !important;
    font-weight: 500 !important;
    font-size: 0.95rem !important;
    cursor: pointer;
    transition: var(--transition);
}

.tribe-modal__wrapper--ar .tribe-tickets__attendee-tickets-submit:hover {
    background: var(--color-red-dark) !important;
}

/* Hide "Guardar y ver carrito" button — only keep "Completar la compra" */
.tribe-modal__wrapper--ar .tribe-tickets__attendee-tickets-footer-cart-button,
.tribe-modal__wrapper--ar [class*="footer-cart"],
.tribe-modal__wrapper--ar [class*="cart-button"],
.tribe-tickets__attendee-tickets-footer-cart-button {
    display: none !important;
}

/* Hide the "o" separator between buttons */
.tribe-modal__wrapper--ar .tribe-tickets__attendee-tickets-footer-or,
.tribe-modal__wrapper--ar [class*="footer-or"] {
    display: none !important;
}

/* Make "Completar la compra" full width since it's the only button now */
.tribe-modal__wrapper--ar .tribe-tickets__attendee-tickets-footer-checkout-button {
    width: 100% !important;
    text-align: center !important;
}

/* ============================================
   CHECKOUT PAGE (Tickets Commerce)
   ============================================ */
body.page-template-default .tribe-tickets__commerce-checkout {
    background: transparent !important;
    color: var(--color-white) !important;
    max-width: 800px;
    margin: 0 auto;
    padding: 2rem 0;
}

/* Checkout page wrapper — dark background */
body.page-template-default:has(.tribe-tickets__commerce-checkout) {
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%) !important;
    color: var(--color-white) !important;
    min-height: 100vh;
}

/* Fallback for browsers without :has() — use the page-id */
body.page-id-37 {
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%) !important;
    color: var(--color-white) !important;
}

/* All text white on checkout */
body.page-id-37 h1,
body.page-id-37 h2,
body.page-id-37 h3,
body.page-id-37 h4,
body.page-id-37 p,
body.page-id-37 span,
body.page-id-37 div,
body.page-id-37 label,
body.page-id-37 a,
body.page-id-37 td,
body.page-id-37 th,
body.page-id-37 li {
    color: var(--color-white) !important;
}

body.page-id-37 .site-main a {
    color: var(--color-red) !important;
}

/* Checkout header */
.tribe-tickets__commerce-checkout-header-title {
    font-family: var(--font-body) !important;
    font-weight: 100 !important;
    font-size: clamp(1.8rem, 3.5vw, 2.5rem) !important;
    margin-bottom: 2rem !important;
}

/* Checkout cart items */
.tribe-tickets__commerce-checkout .tribe-tickets__tickets-item {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px;
    padding: 1.2rem !important;
    margin-bottom: 1rem;
}

/* Empty cart message */
.tribe-tickets__commerce-checkout-cart-empty {
    text-align: center;
    padding: 4rem 0;
}

.tribe-tickets__commerce-checkout-cart-empty-title {
    font-family: var(--font-body) !important;
    font-weight: 100 !important;
    margin-bottom: 1rem !important;
}

.tribe-tickets__commerce-checkout-cart-empty-description a {
    color: var(--color-red) !important;
    text-decoration: underline;
}

/* Checkout notice */
.tribe-tickets__commerce-checkout-notice {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px;
    padding: 1rem !important;
    margin-bottom: 1rem;
}

/* Checkout form fields */
body.page-id-37 input[type="text"],
body.page-id-37 input[type="email"],
body.page-id-37 input[type="number"],
body.page-id-37 select,
body.page-id-37 textarea {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
    border-radius: 8px;
    padding: 0.7rem 1rem;
}

body.page-id-37 input::placeholder {
    color: rgba(255, 255, 255, 0.4) !important;
}

/* Checkout submit buttons */
body.page-id-37 .tribe-common-c-btn,
body.page-id-37 button[type="submit"],
body.page-id-37 input[type="submit"] {
    background: var(--color-red) !important;
    color: var(--color-white) !important;
    border: none !important;
    border-radius: 50px;
    padding: 0.8rem 2rem;
    font-weight: 500;
    font-size: 0.95rem;
    cursor: pointer;
    transition: var(--transition);
}

body.page-id-37 .tribe-common-c-btn:hover,
body.page-id-37 button[type="submit"]:hover {
    background: var(--color-red-dark) !important;
}

/* Checkout footer */
.tribe-tickets__commerce-checkout-footer {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

/* --- Back link (styled via JS .nauw-back-link) --- */
body.page-id-37 .nauw-back-link:hover {
    opacity: 1 !important;
}

/* --- Coupon section — minimalist style --- */
body.page-id-37 [class*="coupon"] input[type="text"] {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
    border-radius: 8px;
    padding: 0.5rem 0.8rem;
    font-size: 0.85rem;
    max-width: 200px;
    margin-right: 0.5rem;
}

body.page-id-37 [class*="coupon"] input::placeholder {
    color: rgba(255, 255, 255, 0.35) !important;
}

body.page-id-37 [class*="coupon"] button:not([type="submit"]) {
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--color-white) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 8px;
    padding: 0.5rem 1rem;
    font-size: 0.8rem;
    cursor: pointer;
    transition: var(--transition);
}

body.page-id-37 [class*="coupon"] button:not([type="submit"]):hover {
    background: rgba(255, 255, 255, 0.15) !important;
}

/* ============================================
   THE EVENTS CALENDAR - DARK THEME OVERRIDES
   Uses !important to override TEC V2 inline styles
   ============================================ */

/* === BODY-LEVEL BACKGROUNDS === */
body.single-tribe_events,
body.post-type-archive-tribe_events,
body.events-archive {
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%) !important;
    color: var(--color-white) !important;
}

/* === GLOBAL TEC CONTAINER RESETS === */
.single-tribe_events #tribe-events,
.single-tribe_events .tribe-events-single,
.single-tribe_events .tribe-events-l-container,
.single-tribe_events .tribe-common,
.single-tribe_events .tribe-common--breakpoint-medium,
.single-tribe_events .tribe-common--breakpoint-medium.tribe-events,
.single-tribe_events .tribe-events-l-container,
body.single-tribe_events .tribe-events-l-container {
    background: transparent !important;
    color: var(--color-white) !important;
}

.single-tribe_events #tribe-events,
.single-tribe_events .tribe-events-single {
    max-width: 1100px;
    margin: 0 auto;
    padding: 6rem var(--container-padding) 4rem;
}

/* === BACK LINK === */
.single-tribe_events .tribe-events-back {
    margin-bottom: 1.5rem;
}

.single-tribe_events .tribe-events-back a {
    color: var(--color-white) !important;
    font-size: 0.9rem;
}

/* === EVENT TITLE === */
.single-tribe_events .tribe-events-single-event-title,
body.single-tribe_events h1.tribe-events-single-event-title {
    font-family: var(--font-body) !important;
    font-size: clamp(2rem, 4vw, 3rem) !important;
    font-weight: 100 !important;
    margin-bottom: 1.5rem;
    color: var(--color-white) !important;
}

/* === FEATURED IMAGE === */
.single-tribe_events .tribe-events-event-image {
    margin-bottom: 2rem;
}

.single-tribe_events .tribe-events-event-image img {
    width: 100%;
    border-radius: 12px;
}

/* === META INFO (date, time, venue, cost) === */
.single-tribe_events .tribe-events-schedule,
.single-tribe_events .tribe-events-schedule * {
    color: var(--color-white) !important;
}

.single-tribe_events .tribe-events-schedule {
    font-size: 1.1rem;
    margin-bottom: 0.75rem;
}

.single-tribe_events .tribe-events-schedule h2 {
    display: inline;
    font-size: inherit;
    font-weight: 700;
}

.single-tribe_events .tribe-events-schedule .tribe-events-cost {
    color: var(--color-red) !important;
    font-weight: 500;
}

.single-tribe_events .tribe-venue,
.single-tribe_events .tribe-venue *,
.single-tribe_events .tribe-events-cost,
.single-tribe_events .tribe-organizer,
.single-tribe_events .tribe-organizer * {
    color: var(--color-white) !important;
    font-size: 1rem;
    opacity: 0.85;
    margin-bottom: 0.5rem;
}

.single-tribe_events .tribe-events-schedule a,
.single-tribe_events .tribe-venue a,
.single-tribe_events .tribe-organizer a {
    color: var(--color-red) !important;
}

/* === EVENT DETAILS META === */
.single-tribe_events .tribe-events-meta-group {
    margin-bottom: 1.5rem;
}

.single-tribe_events .tribe-events-meta-group h2,
.single-tribe_events .tribe-events-meta-group h3 {
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.5;
    margin-bottom: 0.4rem;
    color: var(--color-white) !important;
}

.single-tribe_events .tribe-events-meta-group dd,
.single-tribe_events .tribe-events-meta-group address,
.single-tribe_events .tribe-events-meta-group dl,
.single-tribe_events .tribe-events-meta-group dt {
    font-style: normal;
    line-height: 1.6;
    color: var(--color-white) !important;
}

/* === EVENT CONTENT === */
.single-tribe_events .tribe-events-content,
.single-tribe_events .tribe-events-single-section {
    margin-top: 2rem;
    line-height: 1.7;
    opacity: 0.9;
    color: var(--color-white) !important;
}

.single-tribe_events .tribe-events-content p,
.single-tribe_events .tribe-events-content li,
.single-tribe_events .tribe-events-content span {
    color: var(--color-white) !important;
    margin-bottom: 1rem;
}

.single-tribe_events .tribe-events-content h2 {
    font-size: 1.4rem;
    font-weight: 500;
    margin: 2rem 0 1rem;
    color: var(--color-white) !important;
}

.single-tribe_events .tribe-events-content h3 {
    font-size: 1.1rem;
    font-weight: 500;
    margin: 1.5rem 0 0.75rem;
    color: var(--color-white) !important;
}

.single-tribe_events .tribe-events-content a {
    color: var(--color-red) !important;
}

.single-tribe_events .tribe-events-content ul {
    margin: 1rem 0 1rem 1.5rem;
    list-style: disc;
}

.single-tribe_events .tribe-events-content li {
    margin-bottom: 0.5rem;
    line-height: 1.6;
}

/* === ALL TEXT WHITE CATCH-ALL === */
body.single-tribe_events p,
body.single-tribe_events span,
body.single-tribe_events li,
body.single-tribe_events dd,
body.single-tribe_events dt,
body.single-tribe_events address,
body.single-tribe_events label,
body.single-tribe_events h1,
body.single-tribe_events h2,
body.single-tribe_events h3,
body.single-tribe_events h4,
body.single-tribe_events h5,
body.single-tribe_events h6 {
    color: var(--color-white) !important;
}

/* Event content links only — scoped to TEC containers, NOT footer/artist cards/nav */
.single-tribe_events #tribe-events a,
.single-tribe_events .tribe-events-single a {
    color: var(--color-red) !important;
}

/* === TICKET WIDGET / CTA BUTTONS === */
.single-tribe_events .tribe-events-event-url a,
.single-tribe_events .tribe-events-cal-links a {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.8rem 2rem;
    border-radius: 50px;
    border: 1px solid var(--color-white) !important;
    color: var(--color-white) !important;
    font-weight: 500;
    margin-top: 1rem;
    transition: var(--transition);
}

.single-tribe_events .tribe-events-event-url a:hover,
.single-tribe_events .tribe-events-cal-links a:hover {
    background: var(--color-white) !important;
    color: var(--color-dark) !important;
    opacity: 1;
}

/* === TICKET FORM === */
.single-tribe_events .tribe-events-tickets,
.single-tribe_events .cart,
.single-tribe_events .tribe-common-c-btn-border-small {
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 16px;
    padding: 2rem;
    margin: 2rem 0;
    color: var(--color-white) !important;
}

.single-tribe_events .tribe-events-tickets h2,
.single-tribe_events .tribe-events-tickets .tribe-events-tickets-title {
    font-family: var(--font-body) !important;
    font-size: 1.3rem;
    font-weight: 400;
    margin-bottom: 1rem;
    color: var(--color-white) !important;
}

.single-tribe_events .tribe-events-tickets .tribe-ticket {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    padding: 1rem 0;
}

.single-tribe_events .tribe-events-tickets .tribe-ticket .ticket-name,
.single-tribe_events .tribe-events-tickets .tribe-ticket td {
    color: var(--color-white) !important;
}

.single-tribe_events .tribe-events-tickets .tribe-ticket .ticket-price,
.single-tribe_events .tribe-events-tickets .tribe-ticket .tribe-ticket-price {
    color: var(--color-white) !important;
    font-weight: 500;
}

/* Ticket submit button */
.single-tribe_events .tribe-events-tickets input[type="submit"],
.single-tribe_events .tribe-events-tickets button[type="submit"],
.single-tribe_events .tribe-events-tickets .tribe-common-c-btn,
.single-tribe_events .tribe-common-c-btn {
    background: var(--color-red) !important;
    color: var(--color-white) !important;
    border: none !important;
    border-radius: 50px;
    padding: 0.8rem 2rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition);
}

.single-tribe_events .tribe-events-tickets input[type="submit"]:hover,
.single-tribe_events .tribe-events-tickets button[type="submit"]:hover,
.single-tribe_events .tribe-common-c-btn:hover {
    background: var(--color-red-dark) !important;
}

/* === EVENT NAVIGATION (prev/next) === */
.single-tribe_events .tribe-events-nav-pagination {
    display: flex;
    justify-content: space-between;
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.single-tribe_events .tribe-events-nav-pagination a {
    color: var(--color-red) !important;
}

/* === TEC V2 VIEW SYSTEM OVERRIDES === */
.single-tribe_events .tribe-common,
.single-tribe_events .tribe-common--breakpoint-medium,
.single-tribe_events .tribe-events-pro,
.single-tribe_events .tribe-events {
    color: var(--color-white) !important;
    background: transparent !important;
}

.single-tribe_events .tribe-common a {
    color: var(--color-red) !important;
}

.single-tribe_events .tribe-common--breakpoint-medium .tribe-events-c-events-bar {
    background: transparent !important;
}

/* TEC V2 specific widget/block overrides */
.single-tribe_events .tribe-events-event-meta,
.single-tribe_events .tribe-events-event-meta * {
    color: var(--color-white) !important;
    background: transparent !important;
}

/* === EVENTS ARCHIVE/LIST PAGE === */
body.post-type-archive-tribe_events #tribe-events,
body.post-type-archive-tribe_events .tribe-events-l-container,
body.post-type-archive-tribe_events .tribe-common,
body.events-archive .tribe-events-l-container {
    background: transparent !important;
    color: var(--color-white) !important;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 6rem var(--container-padding) 4rem;
}

body.post-type-archive-tribe_events .tribe-events-header__title,
body.post-type-archive-tribe_events h1 {
    font-family: var(--font-body) !important;
    font-weight: 100;
    color: var(--color-white) !important;
}

body.post-type-archive-tribe_events p,
body.post-type-archive-tribe_events span,
body.post-type-archive-tribe_events li,
body.post-type-archive-tribe_events h2,
body.post-type-archive-tribe_events h3 {
    color: var(--color-white) !important;
}

body.post-type-archive-tribe_events #tribe-events a {
    color: var(--color-red) !important;
}

/* Archive event cards */
body.post-type-archive-tribe_events .tribe-events-calendar-list__event-row,
body.post-type-archive-tribe_events .tribe-common-g-row {
    border-color: rgba(255, 255, 255, 0.1) !important;
}

body.post-type-archive-tribe_events .tribe-events-calendar-list__event-date-tag-datetime,
body.post-type-archive-tribe_events .tribe-events-calendar-list__event-date-tag-weekday {
    color: var(--color-white) !important;
}

body.post-type-archive-tribe_events .tribe-events-calendar-list__event-featured-image-link img {
    border-radius: 12px;
}

/* Archive search bar */
body.post-type-archive-tribe_events .tribe-events-c-events-bar,
body.post-type-archive-tribe_events .tribe-events-c-events-bar__search-container {
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 50px;
}

body.post-type-archive-tribe_events .tribe-events-c-events-bar input {
    color: var(--color-white) !important;
    background: transparent !important;
}

body.post-type-archive-tribe_events .tribe-events-c-search__input-control-icon-svg path {
    fill: var(--color-white);
}

/* ============================================
   WOOCOMMERCE — DARK THEME
   Cart (/carrito/) & Checkout (/finalizar-compra/)
   ============================================ */

/* --- Fix WooCommerce overriding theme image heights ---
   WooCommerce adds: .woocommerce-page img { height: auto; max-width: 100% }
   This overrides our header (100px) and footer (60px) logo sizes.
   We fight it with higher specificity (0,2,1 vs 0,1,1). */
body.woocommerce-page .header-logo-img {
    height: 100px;
    width: auto;
    margin: -22px 0;
}

body.woocommerce-page .footer-logo-img {
    height: 60px;
    width: auto;
}

/* --- WooCommerce page wrapper (from page.php) --- */
.woo-page {
    padding: 6rem 0 4rem;
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%);
    min-height: 60vh;
}

.woo-page .container {
    max-width: 1200px;
}

.woo-page-title {
    font-family: var(--font-body);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 100;
    margin-bottom: 2rem;
}

/* --- All text white --- */
.woo-page .woocommerce * {
    color: var(--color-white);
}

/* --- Constrain ALL images inside WooCommerce content --- */
.woo-page .woocommerce img {
    max-width: 100%;
    height: auto;
}

/* Override for legacy body-class selectors */
body.woocommerce-page .legal-page .container {
    max-width: 1200px;
}

/* --- WooCommerce Notices --- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-info {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-left: 4px solid var(--color-red) !important;
    border-radius: 8px;
    color: var(--color-white) !important;
    padding: 1rem 1.5rem 1rem 3.5rem !important;
    margin-bottom: 1.5rem;
    position: relative;
}

.woocommerce-error {
    border-left-color: #e74c3c !important;
}

.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error li::before {
    color: var(--color-white) !important;
    position: absolute;
    left: 1.2rem;
    top: 50%;
    transform: translateY(-50%);
}

.woocommerce-message a,
.woocommerce-info a {
    color: var(--color-red) !important;
    font-weight: 500;
}

/* --- Cart Table --- */
.woocommerce table.shop_table {
    background: transparent !important;
    border: none !important;
    border-collapse: separate;
    border-spacing: 0;
}

.woocommerce table.shop_table thead {
    display: none;
}

.woocommerce table.shop_table td,
.woocommerce table.shop_table th {
    border: none !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    padding: 1.2rem 0.8rem !important;
    color: var(--color-white) !important;
    background: transparent !important;
    vertical-align: middle;
}

.woocommerce table.shop_table tr:last-child td {
    border-bottom: none !important;
}

/* Product thumbnail — aggressively constrain */
.woocommerce td.product-thumbnail {
    width: 80px;
    max-width: 80px;
    min-width: 60px;
}

.woocommerce td.product-thumbnail img {
    border-radius: 8px;
    width: 70px !important;
    max-width: 70px !important;
    height: auto !important;
    object-fit: cover;
}

/* Catch any stray large images in WooCommerce cart/checkout */
.woo-page .woocommerce .shop_table img {
    max-width: 80px !important;
    height: auto !important;
}

/* Product name */
.woocommerce td.product-name a {
    color: var(--color-white) !important;
    text-decoration: none;
    font-weight: 400;
    font-size: 1rem;
}

.woocommerce td.product-name a:hover {
    color: var(--color-red) !important;
}

/* Product name — variation/meta */
.woocommerce td.product-name .variation,
.woocommerce td.product-name dl.variation {
    opacity: 0.6;
    font-size: 0.85rem;
}

.woocommerce td.product-name dl.variation dt,
.woocommerce td.product-name dl.variation dd {
    color: var(--color-white) !important;
}

/* Price */
.woocommerce td.product-price,
.woocommerce td.product-subtotal {
    font-weight: 500;
}

.woocommerce .amount {
    color: var(--color-white) !important;
}

/* Remove item link */
.woocommerce a.remove {
    color: rgba(255, 255, 255, 0.4) !important;
    font-size: 1.4rem;
    transition: color 0.3s ease;
}

.woocommerce a.remove:hover {
    color: #e74c3c !important;
    background: transparent !important;
}

/* Quantity input (cart) */
.woocommerce .quantity .qty,
.woocommerce td.product-quantity input[type="number"] {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
    border-radius: 8px;
    text-align: center;
    width: 4rem;
    padding: 0.4rem;
    font-size: 0.95rem;
    -moz-appearance: textfield;
}

.woocommerce .quantity .qty::-webkit-inner-spin-button {
    opacity: 0.5;
}

/* Coupon section */
.woocommerce .coupon {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.woocommerce .coupon label {
    display: none;
}

.woocommerce .coupon #coupon_code {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
    border-radius: 8px;
    padding: 0.6rem 1rem;
    font-size: 0.85rem;
    width: 200px;
}

.woocommerce .coupon #coupon_code::placeholder {
    color: rgba(255, 255, 255, 0.35);
}

.woocommerce .coupon .button {
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--color-white) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 8px;
    padding: 0.6rem 1.2rem;
    font-size: 0.85rem;
    cursor: pointer;
    transition: var(--transition);
}

.woocommerce .coupon .button:hover {
    background: rgba(255, 255, 255, 0.15) !important;
}

/* Update cart button */
.woocommerce button[name="update_cart"],
.woocommerce input[name="update_cart"] {
    background: transparent !important;
    color: rgba(255, 255, 255, 0.5) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 8px;
    padding: 0.6rem 1.2rem;
    font-size: 0.85rem;
    cursor: pointer;
    transition: var(--transition);
}

.woocommerce button[name="update_cart"]:hover {
    color: var(--color-white) !important;
    border-color: rgba(255, 255, 255, 0.4) !important;
}

.woocommerce button[name="update_cart"]:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Cart actions row */
.woocommerce .cart-collaterals,
.woocommerce-cart .cart-collaterals {
    margin-top: 2rem;
}

/* --- Cart Totals --- */
.woocommerce .cart_totals {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    padding: 1.5rem;
    max-width: 450px;
    margin-left: auto;
}

.woocommerce .cart_totals h2 {
    font-family: var(--font-body);
    font-weight: 400;
    font-size: 1.2rem;
    margin-bottom: 1rem;
    padding-bottom: 0.8rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--color-white) !important;
}

.woocommerce .cart_totals table {
    background: transparent !important;
    border: none !important;
}

.woocommerce .cart_totals table td,
.woocommerce .cart_totals table th {
    border: none !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
    padding: 0.8rem 0 !important;
    background: transparent !important;
    color: var(--color-white) !important;
}

.woocommerce .cart_totals table th {
    font-weight: 400;
    opacity: 0.6;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.woocommerce .cart_totals .order-total th,
.woocommerce .cart_totals .order-total td {
    font-weight: 600;
    font-size: 1.1rem;
    opacity: 1;
    border-bottom: none !important;
    padding-top: 1rem !important;
}

/* Tax line */
.woocommerce .cart_totals .tax-rate,
.woocommerce .cart_totals .tax-total {
    opacity: 0.6;
    font-size: 0.85rem;
}

/* Shipping */
.woocommerce .cart_totals .shipping td {
    font-size: 0.9rem;
}

.woocommerce .shipping-calculator-button {
    color: var(--color-red) !important;
    font-size: 0.85rem;
}

/* --- Proceed to Checkout button --- */
.woocommerce .wc-proceed-to-checkout a.checkout-button,
.woocommerce a.checkout-button {
    background: var(--color-red) !important;
    color: var(--color-white) !important;
    border: none !important;
    border-radius: 50px;
    padding: 0.9rem 2.5rem;
    font-weight: 500;
    font-size: 1rem;
    text-align: center;
    display: block;
    width: 100%;
    margin-top: 1.2rem;
    transition: var(--transition);
    text-decoration: none;
}

.woocommerce .wc-proceed-to-checkout a.checkout-button:hover {
    background: var(--color-red-dark) !important;
}

/* --- Empty Cart --- */
.woocommerce .cart-empty {
    text-align: center;
    padding: 3rem 0;
    opacity: 0.7;
    font-size: 1.1rem;
}

.woocommerce .return-to-shop a {
    background: var(--color-red) !important;
    color: var(--color-white) !important;
    border: none !important;
    border-radius: 50px;
    padding: 0.8rem 2rem;
    display: inline-block;
    margin-top: 1rem;
    text-decoration: none;
    font-weight: 500;
    transition: var(--transition);
}

.woocommerce .return-to-shop a:hover {
    background: var(--color-red-dark) !important;
}

/* ============================================
   WOOCOMMERCE — CHECKOUT PAGE
   ============================================ */

/* Two-column layout via absolute positioning (works regardless of nesting) */
.woocommerce-checkout form.checkout {
    position: relative;
    padding-right: calc(38% + 2.5rem);
}

/* Make billing fields take full width */
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
    float: none;
    width: 100%;
}

/* More spacing before "Información adicional" */
.woocommerce-checkout .woocommerce-additional-fields {
    margin-top: 1.5rem;
}

/* Order review heading — absolute right, top */
.woocommerce-checkout #order_review_heading {
    position: absolute;
    top: 0;
    right: 0;
    width: 38%;
}

/* Order review (table + payment) — absolute right, below heading */
.woocommerce-checkout #order_review {
    position: absolute;
    top: 0;
    right: 0;
    width: 38%;
}

/* If heading exists, push order review down */
.woocommerce-checkout #order_review_heading ~ #order_review {
    top: 2.5rem;
}

/* "Volver al Carrito" link */
.woocommerce-checkout a.wc-backward,
.woocommerce-checkout #order_review a[href*="carrito"],
.woocommerce-checkout #order_review a[href*="cart"] {
    display: block;
    text-align: right;
    color: var(--color-white) !important;
    font-size: 0.85rem;
    opacity: 0.7;
    text-decoration: none;
    margin-bottom: 1rem;
}

.woocommerce-checkout a.wc-backward:hover,
.woocommerce-checkout #order_review a[href*="carrito"]:hover,
.woocommerce-checkout #order_review a[href*="cart"]:hover {
    opacity: 1;
}

/* Coupon toggle */
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info {
    background: rgba(255, 255, 255, 0.03) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-left: none !important;
    border-radius: 8px;
    font-size: 0.9rem;
    padding: 0.8rem 1.2rem 0.8rem 3.5rem !important;
}

.woocommerce-checkout .woocommerce-form-coupon-toggle .showcoupon {
    color: var(--color-red) !important;
}

/* Coupon form */
.woocommerce form.checkout_coupon {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px;
    padding: 1.2rem !important;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.woocommerce form.checkout_coupon #coupon_code {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
    border-radius: 8px;
    padding: 0.6rem 1rem;
    font-size: 0.9rem;
    flex: 1;
}

.woocommerce form.checkout_coupon .button {
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--color-white) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 8px;
    padding: 0.6rem 1.5rem;
    font-size: 0.9rem;
    cursor: pointer;
    transition: var(--transition);
    white-space: nowrap;
}

.woocommerce form.checkout_coupon .button:hover {
    background: rgba(255, 255, 255, 0.15) !important;
}

/* --- Form Fields --- */
.woocommerce-checkout .form-row label {
    color: var(--color-white) !important;
    font-size: 0.85rem;
    font-weight: 400;
    opacity: 0.7;
    margin-bottom: 0.3rem;
    display: block;
}

.woocommerce-checkout .form-row label .required {
    color: var(--color-red) !important;
}

.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .select2-container--default .select2-selection--single {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
    border-radius: 8px;
    padding: 0.7rem 1rem;
    font-size: 0.95rem;
    font-family: var(--font-body);
    width: 100%;
    transition: border-color 0.3s ease;
}

.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row textarea:focus,
.woocommerce-checkout .form-row select:focus {
    border-color: var(--color-red) !important;
    outline: none;
}

.woocommerce-checkout .form-row input::placeholder {
    color: rgba(255, 255, 255, 0.3) !important;
}

/* Select2 dropdown (country/state selectors) */
.select2-container--default .select2-selection--single {
    height: auto !important;
    min-height: 2.8rem;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--color-white) !important;
    line-height: 1.6;
    padding-left: 0.5rem;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    top: 50% !important;
    transform: translateY(-50%);
}

.select2-dropdown {
    background: var(--color-dark) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 8px;
}

.select2-results__option {
    color: var(--color-white) !important;
    padding: 0.5rem 1rem;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background: var(--color-red) !important;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: var(--color-white) !important;
    border-radius: 6px;
}

/* Section headings */
.woocommerce-checkout h3,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3 {
    font-family: var(--font-body) !important;
    font-weight: 400;
    font-size: 1.2rem;
    margin-bottom: 1.2rem;
    padding-bottom: 0.6rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--color-white) !important;
}

/* --- Order Review (right column) --- */
#order_review_heading {
    font-family: var(--font-body) !important;
    font-weight: 400;
    font-size: 1.2rem;
    margin-bottom: 1.2rem;
    padding-bottom: 0.6rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--color-white) !important;
}

.woocommerce-checkout-review-order-table {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 1.5rem;
}

.woocommerce-checkout-review-order-table thead th {
    background: rgba(255, 255, 255, 0.04) !important;
    color: var(--color-white) !important;
    font-weight: 500;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    opacity: 0.6;
    padding: 0.8rem 1rem !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.woocommerce-checkout-review-order-table td,
.woocommerce-checkout-review-order-table th {
    border: none !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
    padding: 0.8rem 1rem !important;
    color: var(--color-white) !important;
    background: transparent !important;
}

.woocommerce-checkout-review-order-table .cart-subtotal th,
.woocommerce-checkout-review-order-table .tax-rate th,
.woocommerce-checkout-review-order-table .tax-total th {
    font-weight: 400;
    opacity: 0.6;
}

.woocommerce-checkout-review-order-table .order-total th,
.woocommerce-checkout-review-order-table .order-total td {
    font-weight: 600;
    font-size: 1.1rem;
    border-bottom: none !important;
}

/* --- Payment Methods --- */
#payment {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px;
    padding: 1.5rem !important;
}

#payment .payment_methods {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    margin-bottom: 1rem !important;
}

#payment .payment_methods li {
    padding: 0.8rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

#payment .payment_methods li:last-child {
    border-bottom: none;
}

#payment .payment_methods li label {
    color: var(--color-white) !important;
    font-weight: 400;
    font-size: 0.95rem;
    cursor: pointer;
    opacity: 1 !important;
}

#payment .payment_box {
    background: rgba(255, 255, 255, 0.03) !important;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    padding: 0.8rem 1rem;
    margin-top: 0.5rem;
    font-size: 0.85rem;
    opacity: 0.7;
    color: var(--color-white) !important;
}

/* Remove the grey triangle arrow */
#payment .payment_box::before {
    display: none !important;
}

/* Also hide WooCommerce's arrow/caret via other selectors */
#payment .payment_box::after {
    display: none !important;
}

.woocommerce-checkout #payment div.payment_box::before,
.woocommerce #payment div.payment_box::before {
    display: none !important;
    border: none !important;
    content: none !important;
}

/* Privacy policy / terms */
#payment .woocommerce-privacy-policy-text,
#payment .woocommerce-terms-and-conditions-wrapper {
    font-size: 0.8rem;
    opacity: 0.6;
    margin-bottom: 1rem;
}

#payment .woocommerce-terms-and-conditions-wrapper a {
    color: var(--color-red) !important;
}

/* --- Place Order Button --- */
#place_order {
    background: var(--color-red) !important;
    color: var(--color-white) !important;
    border: none !important;
    border-radius: 50px;
    padding: 1rem 2.5rem;
    font-weight: 500;
    font-size: 1rem;
    font-family: var(--font-body);
    cursor: pointer;
    transition: var(--transition);
    width: 100%;
    letter-spacing: 0.02em;
}

#place_order:hover {
    background: var(--color-red-dark) !important;
}

/* --- Cross-sells (cart page) --- */
.woocommerce .cross-sells {
    margin-top: 3rem;
}

.woocommerce .cross-sells h2 {
    font-family: var(--font-body);
    font-weight: 400;
    font-size: 1.2rem;
    margin-bottom: 1.5rem;
    color: var(--color-white) !important;
}

.woocommerce .cross-sells .products li {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    overflow: hidden;
}

.woocommerce .cross-sells .products li img {
    border-radius: 0;
}

.woocommerce .cross-sells .products li a {
    color: var(--color-white) !important;
    text-decoration: none;
}

.woocommerce .cross-sells .products li .price {
    color: var(--color-white) !important;
}

.woocommerce .cross-sells .products li .button {
    background: var(--color-red) !important;
    color: var(--color-white) !important;
    border-radius: 50px;
}

/* --- My Account (if needed) --- */
body.woocommerce-account .woo-page .container {
    max-width: 900px;
}

.woocommerce-MyAccount-navigation ul {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.woocommerce-MyAccount-navigation ul li a {
    color: var(--color-white) !important;
    opacity: 0.6;
    text-decoration: none;
    padding: 0.4rem 0.8rem;
    border-radius: 6px;
    font-size: 0.9rem;
    transition: var(--transition);
}

.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li a:hover {
    opacity: 1;
    background: rgba(255, 255, 255, 0.08);
}

/* --- WooCommerce General Buttons --- */
body.woocommerce-page .woocommerce .button:not(.checkout-button):not(#place_order):not(.coupon .button) {
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--color-white) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 8px;
    padding: 0.6rem 1.2rem;
    font-size: 0.9rem;
    font-family: var(--font-body);
    cursor: pointer;
    transition: var(--transition);
}

body.woocommerce-page .woocommerce .button:not(.checkout-button):not(#place_order):not(.coupon .button):hover {
    background: rgba(255, 255, 255, 0.15) !important;
}

/* Alt buttons (primary actions) */
body.woocommerce-page .woocommerce .button.alt {
    background: var(--color-red) !important;
    border: none !important;
    border-radius: 50px;
}

body.woocommerce-page .woocommerce .button.alt:hover {
    background: var(--color-red-dark) !important;
}

/* Links inside WooCommerce content */
.woo-page .woocommerce a:not(.button):not(.checkout-button):not(.remove) {
    color: var(--color-red) !important;
}

/* Override for product names (white) */
.woo-page .woocommerce td.product-name a {
    color: var(--color-white) !important;
}

.woo-page .woocommerce td.product-name a:hover {
    color: var(--color-red) !important;
}

/* ============================================
   RESPONSIVE (internal pages)
   ============================================ */
@media (max-width: 1024px) {
    .evento-grid {
        grid-template-columns: 1fr;
        align-items: start;
        gap: 2rem;
    }

    .evento-poster {
        max-width: 450px;
    }

    .artista-detail-grid {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .artista-detail-image img {
        max-width: 500px;
        margin: 0 auto;
    }

    /* WooCommerce checkout → single column on tablet */
    .woocommerce-checkout form.checkout {
        padding-right: 0;
    }

    .woocommerce-checkout #order_review_heading,
    .woocommerce-checkout #order_review {
        position: static;
        width: 100%;
        margin-top: 2rem;
    }
}

@media (max-width: 768px) {
    .evento-single {
        padding: 5rem 0 3rem;
    }

    .evento-poster {
        max-width: 100%;
    }

    .evento-poster img {
        aspect-ratio: auto;
        max-height: 75vh;
        object-fit: contain;
    }

    .artistas-grid {
        grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
        gap: 1rem;
    }

    .legal-page {
        padding: 5rem 0 3rem;
    }

    .thankyou-page {
        padding: 6rem 0 4rem;
    }

    .archive-artistas {
        padding: 5rem 0 3rem;
    }

    .single-artista {
        padding: 3rem 0 3rem;
    }

    .artista-detail-links {
        flex-direction: column;
    }

    .artista-link {
        width: 100%;
        justify-content: center;
    }

    /* WooCommerce mobile */
    .woocommerce .cart_totals {
        max-width: 100%;
    }

    .woocommerce .coupon {
        width: 100%;
    }

    .woocommerce .coupon #coupon_code {
        width: 100%;
        margin-bottom: 0.5rem;
    }

    .woocommerce td.product-thumbnail {
        width: 60px;
    }

    .woocommerce td.product-thumbnail img {
        width: 55px;
    }
}


/* ============================================
   ENTRADAS GRATIS — LANDING PAGE
   ============================================ */

/* ---- Hero ---- */
.entradas-hero {
    background: var(--gradient-hero);
    padding: 9rem 0 5rem;
    min-height: 100svh;
    display: flex;
    align-items: center;
}

.entradas-hero__inner {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 4rem;
    align-items: stretch;
    width: 100%;
}

.entradas-hero__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1.5rem;
}

/* Headline — overrides section-title size */
.entradas-headline {
    font-size: clamp(3rem, 7vw, 6rem) !important;
    line-height: 1 !important;
    margin-bottom: 0 !important;
}

/* Event metadata bar — below headline */
.entradas-meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    border-left: 2px solid var(--color-red);
    padding-left: 1rem;
    font-family: var(--font-body);
    font-size: 0.85rem;
    font-weight: 100;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.entradas-meta__date {
    font-weight: 500;
}

.entradas-meta__sep {
    opacity: 0.25;
}

.entradas-meta__venue {
    opacity: 0.6;
}

.entradas-subtitle {
    font-size: 1rem;
    font-weight: 100;
    line-height: 1.9;
    letter-spacing: 0.06em;
    opacity: 0.75;
    max-width: 480px;
}

.entradas-cta {
    max-width: 260px;
}

/* Poster */
.entradas-hero__poster {
    align-self: stretch;
    min-height: 400px;
    border-radius: 12px;
    overflow: hidden;
}

.entradas-poster-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
}

.entradas-poster-placeholder {
    width: 100%;
    height: 100%;
    background: var(--color-dark-brown);
    border-radius: 12px;
}

/* ---- Perks ---- */
.entradas-perks {
    padding: 5rem 0;
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%);
}

.entradas-perks__list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 3rem;
    margin-top: 3rem;
}

.entradas-perk {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    border-top: 2px solid var(--color-red);
    padding-top: 1.5rem;
}

.entradas-perk__label {
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.04em;
}

.entradas-perk p {
    font-size: 0.9rem;
    line-height: 1.9;
    letter-spacing: 0.06em;
    font-weight: 100;
    opacity: 0.65;
}

/* ---- Artistas — slider mobile / grid desktop ---- */
.entradas-artistas {
    padding: 3.5rem 0 4rem;
    background: linear-gradient(180deg, var(--color-dark-brown) 0%, var(--color-dark) 100%);
}

.entradas-artistas .artistas-title {
    text-align: center;
    margin-bottom: 3rem;
}

.entradas-artistas .artistas-carousel {
    padding: 0 2rem 3rem;
    max-width: var(--container-max);
    margin: 0 auto;
}

#entradas-artistas-swiper .swiper-slide {
    width: 260px;
}

#entradas-artistas-swiper .swiper-button-prev,
#entradas-artistas-swiper .swiper-button-next {
    color: var(--color-white);
    width: 40px;
    height: 40px;
    background: rgba(0, 0, 0, 0.5);
    border-radius: 50%;
}

#entradas-artistas-swiper .swiper-button-prev::after,
#entradas-artistas-swiper .swiper-button-next::after {
    font-size: 16px;
}

/* Desktop: disable slider, show as adaptive grid */
@media (min-width: 768px) {
    #entradas-artistas-swiper .swiper-wrapper {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 1.25rem;
        transform: none !important;
        max-width: var(--container-max);
        margin: 0 auto;
        padding: 0 2rem;
    }

    #entradas-artistas-swiper .swiper-slide {
        width: auto !important;
    }

    #entradas-artistas-swiper .swiper-button-prev,
    #entradas-artistas-swiper .swiper-button-next {
        display: none;
    }
}

/* ---- Form section ---- */
.section-entradas-form {
    padding: 7.5rem 0 3rem;
    background: linear-gradient(180deg, var(--color-dark) 0%, var(--color-dark-brown) 100%);
}

.section-entradas-form .section-desc {
    margin-bottom: 2.5rem;
}

/* ---- Trust strip ---- */
.entradas-trust {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.5rem 1.25rem;
    padding: 2.5rem 0 0;
    margin-top: 2.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    font-size: 0.8rem;
    font-weight: 100;
    letter-spacing: 0.04em;
    opacity: 0.4;
}

.entradas-trust .trust-sep {
    opacity: 0.4;
}

/* ---- Responsive ---- */
@media (max-width: 960px) {
    .entradas-hero__inner {
        grid-template-columns: 1fr;
        gap: 3rem;
        align-items: start;
    }

    .entradas-hero__poster {
        min-height: 0;
        width: 260px;
        height: 325px;
        margin: 0 auto;
    }

    .entradas-perks__list {
        grid-template-columns: 1fr;
        gap: 2rem;
        max-width: 520px;
    }
}

@media (max-width: 640px) {
    .entradas-hero {
        padding: 7rem 0 4rem;
    }

    .entradas-cta {
        max-width: 100%;
    }

    .entradas-hero__poster {
        width: 200px;
        height: 250px;
    }

    .entradas-trust {
        flex-direction: column;
        gap: 0.4rem;
        text-align: center;
    }

    .entradas-trust .trust-sep {
        display: none;
    }
}
