/* ═══════════════════════════════════════════════════════════
   Booking UI — shared design system across booking flow
   Brand primary: var(--primary-color) = #22b0af
   Used by: event-details, check-out, payment pages
═══════════════════════════════════════════════════════════ */

/* ── Card wrapper ───────────────────────────────────────── */
.td-card {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 28px rgba(0,0,0,.09), 0 1px 4px rgba(0,0,0,.04);
    overflow: hidden;
    margin-bottom: 20px;
    position: relative;
    z-index: 0;
}
.td-card .td-head {
    background: var(--primary-color);
    color: #fff;
    padding: 18px 22px;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: .2px;
}
.td-card .td-head i { opacity: .85; }
.td-card .td-body { padding: 22px; }

/* ── Sidebar sticky ─────────────────────────────────────── */
.sidebar-sticky { position: sticky; top: 80px; z-index: 10; }

/* ── event-details-information reset ────────────────────── */
.td-card .event-details-information {
    box-shadow: none !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.td-card .event-details-information .author { margin-top: 4px; margin-bottom: 20px; }
.td-card .event-details-information .author img { width: 44px !important; height: 44px !important; }

/* ── Section labels ─────────────────────────────────────── */
.event-details-information .form-group > label,
.event-details-information > b,
.co-section-label {
    display: block !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .7px !important;
    color: #94a3b8 !important;
    margin-bottom: 8px !important;
}
.event-details-information > b + hr,
.co-section-label + hr {
    margin: 0 0 12px !important;
    border-color: #f1f5f9 !important;
}

/* ── Date select ────────────────────────────────────────── */
.event-details-information .form-group .form-control {
    border-radius: 10px !important;
    border: 1.5px solid #e2e8f0 !important;
    height: 44px !important;
    font-size: 14px !important;
    color: #1e293b !important;
    background: #fff !important;
}
.event-details-information .form-group .form-control:focus {
    border-color: var(--primary-color) !important;
    box-shadow: 0 0 0 3px rgba(34,176,175,.12) !important;
}

/* ── Ticket Item Card ───────────────────────────────────── */
.ticket-item {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    grid-template-rows: auto 1fr auto !important;
    border: 1.5px solid #e2e8f0 !important;
    border-radius: 12px !important;
    padding: 14px 16px !important;
    margin-bottom: 10px !important;
    gap: 3px 14px !important;
    background: #fff !important;
}
.ticket-item > p.mb-0 {
    grid-column: 1 !important; grid-row: 1 !important;
    margin: 0 !important; font-size: 14px !important;
    font-weight: 700 !important; color: #030a15 !important;
}
.ticket-item > .click-show {
    grid-column: 1 !important; grid-row: 2 !important;
    font-size: 12.5px !important; color: #64748b !important;
    line-height: 1.5 !important; align-self: start !important; margin-top: 1px !important;
}
.ticket-item > p.text-warning {
    grid-column: 1 / -1 !important; grid-row: 3 !important;
    font-size: 12px !important; margin-top: 4px !important;
}

/* ── Price count (right column) ─────────────────────────── */
.ticket-item > .price-count,
.event-details-information .price-count {
    grid-column: 2 !important; grid-row: 1 / 3 !important;
    display: flex !important; flex-direction: column !important;
    align-items: flex-end !important; justify-content: space-between !important;
    gap: 10px !important;
    border: none !important; border-bottom: none !important;
    border-radius: 0 !important; padding: 0 !important; margin: 0 !important;
    background: transparent !important; flex-wrap: nowrap !important;
}
.ticket-item > .price-count h6,
.event-details-information .price-count h6 {
    margin: 0 !important; font-size: 15px !important;
    font-weight: 800 !important; color: var(--primary-color) !important;
    white-space: nowrap !important; min-width: 0 !important;
}

/* ── Quantity buttons ───────────────────────────────────── */
.ticket-item > .price-count .quantity-input,
.event-details-information .price-count .quantity-input,
.quantity-input {
    display: inline-flex !important; align-items: center !important;
    margin-bottom: 0 !important; gap: 0 !important;
    border: 1.5px solid var(--primary-color) !important;
    border-radius: 8px !important; overflow: hidden !important;
}
.event-details-information .price-count .quantity-input button,
.quantity-down, .quantity-up, .quantity-down_variation {
    width: 32px !important; height: 32px !important;
    background: var(--primary-color) !important; color: #fff !important;
    border: none !important; font-size: 17px !important; font-weight: 700 !important;
    line-height: 1 !important; cursor: pointer !important; flex-shrink: 0 !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    transition: opacity .15s !important; border-radius: 0 !important;
}
.event-details-information .price-count .quantity-input button:hover,
.quantity-down:hover, .quantity-up:hover, .quantity-down_variation:hover { opacity: .8 !important; }

.event-details-information .price-count .quantity-input input,
.quantity-input input.quantity {
    width: 36px !important; height: 32px !important;
    text-align: center !important; border: none !important;
    font-size: 14px !important; font-weight: 700 !important;
    color: #030a15 !important; background: #fff !important;
    padding: 0 !important; outline: none !important;
    -moz-appearance: textfield !important;
}
.event-details-information .price-count .quantity-input input::-webkit-outer-spin-button,
.event-details-information .price-count .quantity-input input::-webkit-inner-spin-button,
.quantity-input input.quantity::-webkit-outer-spin-button,
.quantity-input input.quantity::-webkit-inner-spin-button { -webkit-appearance: none !important; }

/* ── Order Summary (event-details dynamic) ──────────────── */
.order-summary {
    background: transparent !important; border: none !important;
    border-top: 1.5px solid #e2e8f0 !important; border-radius: 0 !important;
    padding: 14px 0 0 !important; margin-top: 14px !important;
}
.os-row {
    display: flex !important; justify-content: space-between !important;
    align-items: center !important; font-size: 13.5px !important;
    color: #475569 !important; padding: 4px 0 !important;
}
.os-row.os-vat { color: #94a3b8 !important; font-size: 13px !important; }
.os-row.os-total {
    border-top: 1px solid #e2e8f0 !important; margin-top: 8px !important;
    padding-top: 10px !important; font-size: 15px !important;
    font-weight: 800 !important; color: #030a15 !important;
}

/* ── Checkout Order Summary (static list) ───────────────── */
.co-summary-list { list-style: none; margin: 0; padding: 0; }
.co-summary-list li {
    display: flex; justify-content: space-between; align-items: center;
    padding: 6px 0; font-size: 13.5px; color: #475569;
    border-bottom: 1px solid #f1f5f9;
}
.co-summary-list li:last-child { border-bottom: none; }
.co-summary-list li .text { color: #64748b; }
.co-summary-list li .number { font-weight: 700; color: #1e293b; }
.co-summary-list li.co-total {
    font-size: 15px; font-weight: 800; color: #030a15;
    border-top: 1.5px solid #e2e8f0; border-bottom: none;
    margin-top: 6px; padding-top: 10px;
}
.co-summary-list li.co-total .number { color: var(--primary-color); }

/* Ticket slot box inside checkout */
.slot-box-wrap { margin-bottom: 10px; }
.slot-box2 {
    background: #f8fafc; border: 1px solid #e2e8f0;
    border-radius: 10px; padding: 10px 14px;
    margin-bottom: 6px; font-size: 13.5px;
}
.slot-box2-header {
    display: flex !important; justify-content: space-between;
    align-items: center; list-style: none;
    background: #f8fafc; border: 1px solid #e2e8f0;
    border-radius: 10px; padding: 10px 14px !important;
    margin-bottom: 6px; font-size: 13.5px;
}
.slot-box2-header .text { font-weight: 600; color: #1e293b; }
.slot-box2-header .number { font-weight: 700; color: var(--primary-color); font-size: 13px; }

/* Event thumbnail in checkout sidebar */
.co-event-card {
    display: flex; gap: 12px; align-items: flex-start;
    margin-bottom: 16px; padding-bottom: 16px;
    border-bottom: 1.5px solid #f1f5f9;
}
.co-event-card img {
    width: 68px; height: 68px; object-fit: cover;
    border-radius: 10px; flex-shrink: 0;
}
.co-event-card .co-event-info h6 {
    font-size: 14px; font-weight: 700; color: #1e293b;
    margin-bottom: 4px; line-height: 1.4;
}
.co-event-card .co-event-info span {
    display: block; font-size: 12px; color: #64748b; margin-bottom: 2px;
}

/* ── Coupon ─────────────────────────────────────────────── */
.co-coupon-wrap { margin-top: 16px; }
.co-coupon-wrap h6 {
    font-size: 11px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .7px; color: #94a3b8; margin-bottom: 8px;
}
.co-coupon-wrap .input-group .form-control {
    border-radius: 10px 0 0 10px !important; border: 1.5px solid #e2e8f0 !important;
    height: 42px !important; font-size: 13.5px !important;
}
.co-coupon-wrap .input-group .btn {
    border-radius: 0 10px 10px 0 !important;
    background: var(--primary-color) !important; color: #fff !important;
    border: none !important; font-size: 13px !important; font-weight: 700 !important;
    padding: 0 18px !important;
}

/* ── Payment method select ──────────────────────────────── */
.co-payment-wrap { margin-top: 16px; }
.co-payment-wrap h6 {
    font-size: 11px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .7px; color: #94a3b8; margin-bottom: 8px;
}
.co-payment-wrap .nice-select,
.co-payment-wrap .form-control,
.co-payment-wrap .co-gateway-select {
    border-radius: 10px !important; border: 1.5px solid #e2e8f0 !important;
    height: 44px !important; font-size: 14px !important; color: #1e293b !important;
    width: 100% !important; padding: 0 12px !important; appearance: auto !important;
    -webkit-appearance: auto !important; background-color: #fff !important;
    cursor: pointer !important;
}
.co-payment-wrap .nice-select:focus,
.co-payment-wrap .form-control:focus,
.co-payment-wrap .co-gateway-select:focus {
    border-color: var(--primary-color) !important;
    box-shadow: 0 0 0 3px rgba(34,176,175,.12) !important;
    outline: none !important;
}

/* ── Primary booking buttons ────────────────────────────── */
.theme-btn.booking-next-btn,
.theme-btn.payBtn,
.booking-submit-btn {
    background: var(--primary-color) !important; border: none !important;
    font-size: 15px !important; font-weight: 700 !important; letter-spacing: .3px !important;
    border-radius: 10px !important; height: 50px !important; width: 100% !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    gap: 8px !important; color: #fff !important; margin-top: 16px !important;
    box-shadow: 0 4px 14px rgba(34,176,175,.3) !important; cursor: pointer !important;
    transition: opacity .2s, transform .2s !important;
}
.theme-btn.booking-next-btn:hover,
.theme-btn.payBtn:hover,
.booking-submit-btn:hover { opacity: .9 !important; transform: translateY(-1px) !important; color: #fff !important; }

/* ── Auth Modal ─────────────────────────────────────────── */
.auth-modal-card { border-radius: 20px; overflow: hidden; padding: 32px 28px; border: none; box-shadow: 0 20px 60px rgba(0,0,0,.15); position: relative; }
.auth-modal-close { position: absolute; top: 14px; right: 18px; background: none; border: none; font-size: 22px; cursor: pointer; color: #aaa; line-height: 1; }
.auth-modal-brand { margin-bottom: 20px; text-align: center; }
.auth-modal-brand img { max-height: 56px; max-width: 160px; object-fit: contain; }
.auth-modal-form .form-control { border-radius: 10px; height: 46px; border: 1.5px solid #e2e8f0; font-size: 14px; }
.auth-modal-form .form-control:focus { border-color: var(--primary-color); box-shadow: 0 0 0 3px rgba(34,176,175,.12); }
.auth-modal-submit { border-radius: 10px; height: 46px; background: var(--primary-color); color: #fff; font-weight: 600; font-size: 15px; border: none; width: 100%; transition: .2s; }
.auth-modal-submit:hover { opacity: .9; transform: translateY(-1px); }
