/* Ticketa — Personal Zone (My Orders)
 * Prefix: spz- (Site Personal Zone)
 */

.personal-zone-page {
    min-height: calc(100vh - var(--header-height, 80px));
    background:
        radial-gradient(ellipse at top, rgba(232,119,34,.05) 0%, transparent 60%),
        linear-gradient(180deg, #1a1815 0%, #100e0b 100%);
    padding: 2rem 1rem 4rem;
}

.spz {
    max-width: 880px;
    margin: 0 auto;
    color: #f5f1ea;
    font-family: var(--font-body, system-ui, sans-serif);
}

/* Topbar */
.spz__topbar {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.5rem 0 1rem;
    border-bottom: 1px solid rgba(255,255,255,.07);
    margin-bottom: 1.25rem;
}
.spz__topbar h1 {
    margin: 0;
    font-size: 1.7rem;
    font-weight: 800;
    color: #fff;
}
.spz__email {
    margin: .25rem 0 0;
    font-size: .85rem;
    color: rgba(255,255,255,.55);
    display: flex;
    align-items: center;
    gap: .35rem;
}
.spz__email i { color: #e87722; }

/* Filters */
.spz__filters {
    display: flex;
    gap: .85rem;
    align-items: end;
    flex-wrap: wrap;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 12px;
    padding: 1rem 1.15rem;
    margin-bottom: 1.25rem;
}
.spz__filter {
    display: flex;
    flex-direction: column;
    gap: .3rem;
    flex: 1;
    min-width: 130px;
}
.spz__filter > span {
    font-size: .78rem;
    color: rgba(255,255,255,.6);
    font-weight: 600;
}
.spz__filter input,
.spz__filter select {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.14);
    color: #fff;
    border-radius: 8px;
    padding: .55rem .7rem;
    font-size: .92rem;
    font-family: inherit;
    /* Native popup uses OS dark theme; option elements get readable colors. */
    color-scheme: dark;
}
.spz__filter select option {
    background: #1a1815;
    color: #f5f1ea;
}
/* Date input calendar icon — invert so it shows on dark */
.spz__filter input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(0.8);
    cursor: pointer;
}
.spz__filter input:focus,
.spz__filter select:focus {
    outline: none;
    border-color: #e87722;
    background: rgba(255,255,255,.08);
}

/* Body */
.spz__body { display: block; }
.spz__empty,
.spz__error {
    text-align: center;
    color: rgba(255,255,255,.6);
    padding: 3rem 1rem;
    font-size: 1rem;
}
.spz__empty i { font-size: 2.5rem; color: #e87722; opacity: .6; display: block; margin-bottom: .75rem; }
.spz__empty p { margin: .5rem 0 1.25rem; }
.spz__error {
    color: #ff8a7a;
    background: rgba(231,76,60,.1);
    border: 1px solid rgba(231,76,60,.3);
    border-radius: 10px;
    padding: 1rem 1.25rem;
}

/* Orders */
.spz__orders {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.spz__order {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 14px;
    overflow: hidden;
    transition: border-color .15s, background .15s;
}
.spz__order:hover { border-color: rgba(255,255,255,.14); background: rgba(255,255,255,.05); }
.spz__order-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 1.1rem 1.25rem .65rem;
    gap: 1rem;
}
.spz__order-title {
    font-size: 1.1rem;
    font-weight: 700;
    margin: 0;
    color: #fff;
}
.spz__order-meta {
    margin: .2rem 0 0;
    font-size: .82rem;
    color: rgba(255,255,255,.5);
    display: flex;
    gap: .35rem;
    flex-wrap: wrap;
}
.spz__sep { color: rgba(255,255,255,.2); }
.spz__order__body { padding: .35rem 1.25rem 1.1rem; }
.spz__order-body { padding: .65rem 1.25rem 1.1rem; }

/* Booking details grid */
.spz__details-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: .65rem .85rem;
    padding: .9rem 1rem;
    background: rgba(255,255,255,.025);
    border: 1px solid rgba(255,255,255,.06);
    border-radius: 10px;
    margin-bottom: 1rem;
}
.spz__detail {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.spz__detail-k {
    font-size: .72rem;
    font-weight: 600;
    color: rgba(255,255,255,.5);
    letter-spacing: .02em;
    text-transform: none;
}
.spz__detail-v {
    font-size: .92rem;
    color: #fff;
    font-weight: 500;
    word-break: break-word;
}
.spz__detail-sub {
    font-size: .8rem;
    color: rgba(255,255,255,.55);
    font-weight: 400;
    margin-inline-start: .35rem;
}

/* Section titles inside order body */
.spz__section-title {
    font-size: .82rem;
    font-weight: 700;
    color: rgba(255,255,255,.7);
    margin: 1rem 0 .55rem;
    display: flex;
    align-items: center;
    gap: .4rem;
}
.spz__section-title i { color: #e87722; font-size: .85rem; }

/* Room block inside order body */
.spz__rooms { margin-bottom: .25rem; }
.spz__room {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.06);
    border-radius: 10px;
    padding: .8rem 1rem;
    margin-bottom: .6rem;
}
.spz__room:last-child { margin-bottom: 0; }
.spz__room-head {
    display: flex;
    align-items: baseline;
    gap: .35rem;
    flex-wrap: wrap;
    margin-bottom: .55rem;
    color: #fff;
}
.spz__room-head strong { font-size: .95rem; }
.spz__room-hotel { color: rgba(255,255,255,.65); font-size: .88rem; }
.spz__room-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: .55rem .85rem;
}

/* Add-ons */
.spz__addons { margin-bottom: .25rem; }
.spz__addon {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.06);
    border-radius: 8px;
    padding: .55rem .85rem;
    color: rgba(255,255,255,.85);
    font-size: .9rem;
    margin-bottom: .35rem;
}

/* Total row stays prominent */
.spz__row {
    display: flex;
    align-items: center;
    gap: .55rem;
    font-size: .92rem;
    color: rgba(255,255,255,.85);
    padding: .35rem 0;
}
.spz__row i { color: #e87722; width: 18px; flex-shrink: 0; text-align: center; }
.spz__row--total {
    margin-top: .85rem;
    padding-top: .85rem;
    border-top: 1px solid rgba(255,255,255,.08);
    align-items: baseline;
}
.spz__row--total .spz__detail-k { flex: 1; font-size: .82rem; }
.spz__row--total strong { color: #fff; font-size: 1.25rem; }
.spz__cancel-info {
    margin-top: .8rem;
    padding: .75rem 1rem;
    border-radius: 10px;
    font-size: .9rem;
    line-height: 1.5;
}
.spz__cancel-info.is-requested { background: rgba(241,196,15,.1); color: #f5d76e; }
.spz__cancel-info.is-approved,
.spz__cancel-info.is-refunded  { background: rgba(46,204,113,.1);  color: #7dd99c; }
.spz__cancel-info.is-denied    { background: rgba(231,76,60,.1);   color: #ff8a7a; }
.spz__cancel-msg {
    margin: .4rem 0 0;
    font-size: .85rem;
    opacity: .9;
}
.spz__order-foot {
    padding: .65rem 1.25rem 1.1rem;
    border-top: 1px solid rgba(255,255,255,.05);
    display: flex;
    justify-content: flex-end;
}

/* Status badge */
.spz__badge {
    flex-shrink: 0;
    padding: .3rem .75rem;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 700;
    line-height: 1.5;
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.85);
    white-space: nowrap;
}
.spz__badge.is-paid       { background: rgba(46,204,113,.18);  color: #7dd99c; }
.spz__badge.is-pending    { background: rgba(241,196,15,.18);  color: #f5d76e; }
.spz__badge.is-failed     { background: rgba(231,76,60,.2);    color: #ff8a7a; }
.spz__badge.is-abandoned  { background: rgba(255,255,255,.08); color: rgba(255,255,255,.55); }
.spz__badge.is-requested  { background: rgba(241,196,15,.18);  color: #f5d76e; }
.spz__badge.is-cancelled  { background: rgba(189,195,199,.15); color: rgba(255,255,255,.7); }
.spz__badge.is-refunded   { background: rgba(46,204,113,.18);  color: #7dd99c; }

/* Buttons */
.spz__btn {
    appearance: none;
    border: 1px solid transparent;
    border-radius: 999px;
    padding: .65rem 1.1rem;
    font-size: .92rem;
    font-weight: 700;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    transition: background .15s, transform .12s, border-color .15s;
    font-family: inherit;
    text-decoration: none;
}
.spz__btn:disabled { opacity: .55; cursor: not-allowed; }
.spz__btn--primary {
    background: #e87722;
    color: #fff;
    border-color: #e87722;
    box-shadow: 0 4px 14px rgba(232,119,34,.3);
}
.spz__btn--primary:hover:not(:disabled) { background: #ff8c33; border-color: #ff8c33; }
.spz__btn--ghost {
    background: rgba(255,255,255,.06);
    color: #fff;
    border-color: rgba(255,255,255,.18);
}
.spz__btn--ghost:hover:not(:disabled) { background: rgba(255,255,255,.12); }
.spz__btn--clear {
    background: transparent;
    color: rgba(255,255,255,.6);
    border-color: rgba(255,255,255,.14);
    padding: .45rem .85rem;
    font-size: .82rem;
    align-self: end;
}
.spz__btn--clear:hover { color: #fff; border-color: rgba(255,255,255,.3); }
.spz__btn--danger-ghost {
    background: rgba(231,76,60,.08);
    color: #ff8a7a;
    border-color: rgba(231,76,60,.35);
}
.spz__btn--danger-ghost:hover { background: rgba(231,76,60,.18); }
.spz__btn--danger {
    background: #c0392b;
    color: #fff;
    border-color: #c0392b;
}
.spz__btn--danger:hover:not(:disabled) { background: #d04432; }

/* Cancellation modal ─────────────────────────────────────── */
.spz__overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0,0,0,.7);
    backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    overflow-y: auto;
}
.spz__modal {
    background: linear-gradient(180deg, #1a1815 0%, #15130f 100%);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 18px;
    width: 100%;
    max-width: 520px;
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
    position: relative;
    box-shadow: 0 30px 80px rgba(0,0,0,.6);
}
.spz__modal-close {
    position: absolute;
    top: 14px;
    inset-inline-end: 14px;
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.15);
    background: rgba(255,255,255,.06);
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.spz__modal-close:hover { background: rgba(255,255,255,.12); }
.spz__modal-head {
    text-align: center;
    padding: 2.25rem 1.5rem 1rem;
}
.spz__modal-icon { font-size: 38px; color: #e87722; margin-bottom: .5rem; display: block; }
.spz__modal-head h2 { font-size: 1.4rem; font-weight: 800; margin: 0 0 .35rem; color: #fff; }
.spz__modal-head p { color: rgba(255,255,255,.6); font-size: .9rem; margin: 0; }
.spz__modal-body {
    padding: 1rem 1.75rem 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.spz__terms {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 10px;
    padding: .9rem 1rem;
    max-height: 220px;
    overflow-y: auto;
}
.spz__terms h4 { margin: 0 0 .4rem; font-size: .9rem; color: rgba(255,255,255,.85); }
.spz__terms pre {
    margin: 0;
    font-family: inherit;
    color: rgba(255,255,255,.72);
    font-size: .85rem;
    line-height: 1.6;
    white-space: pre-wrap;
    word-break: break-word;
}

.spz__field { display: flex; flex-direction: column; gap: .35rem; }
.spz__field-label { font-size: .82rem; font-weight: 600; color: rgba(255,255,255,.82); }
.spz__field textarea {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.14);
    color: #fff;
    border-radius: 10px;
    padding: .7rem .9rem;
    font-size: .95rem;
    font-family: inherit;
    resize: vertical;
}
.spz__field textarea:focus { outline: none; border-color: #e87722; background: rgba(255,255,255,.07); }

.spz__checkbox {
    display: flex;
    align-items: flex-start;
    gap: .55rem;
    color: rgba(255,255,255,.85);
    font-size: .92rem;
    cursor: pointer;
    user-select: none;
}
.spz__checkbox input { margin-top: 2px; accent-color: #e87722; cursor: pointer; }

.spz__modal-actions {
    display: flex;
    gap: .65rem;
    margin-top: .35rem;
    justify-content: flex-end;
}
.spz__modal-actions .spz__btn { flex: 1; }

/* Success */
.spz__success { text-align: center; padding: 3rem 1.75rem 2rem; }
.spz__success-icon {
    color: #2ecc71;
    width: 96px;
    height: 96px;
    margin: 0 auto 1rem;
}
.spz__success-icon svg { width: 100%; height: 100%; }
.spz__ring {
    stroke-dasharray: 151;
    stroke-dashoffset: 151;
    animation: spz-ring .55s ease-out forwards;
}
.spz__check {
    stroke-dasharray: 50;
    stroke-dashoffset: 50;
    animation: spz-check .45s .35s ease-out forwards;
}
@keyframes spz-ring  { to { stroke-dashoffset: 0; } }
@keyframes spz-check { to { stroke-dashoffset: 0; } }
.spz__success h2 { margin: .5rem 0 .35rem; color: #fff; }
.spz__success p { color: rgba(255,255,255,.7); margin: .25rem 0; }
.spz__success .spz__btn { margin-top: 1.25rem; min-width: 200px; }
.spz__fineprint { color: rgba(255,255,255,.45) !important; font-size: .82rem !important; }

/* Transitions */
.spz-fade-enter-active, .spz-fade-leave-active { transition: opacity .18s ease; }
.spz-fade-enter-active .spz__modal, .spz-fade-leave-active .spz__modal {
    transition: transform .22s cubic-bezier(.2, .9, .25, 1.2), opacity .18s ease;
}
.spz-fade-enter-from, .spz-fade-leave-to { opacity: 0; }
.spz-fade-enter-from .spz__modal { transform: translateY(20px) scale(.96); opacity: 0; }
.spz-fade-leave-to   .spz__modal { transform: translateY(10px) scale(.98); opacity: 0; }

/* Mobile */
@media (max-width: 600px) {
    .personal-zone-page { padding: 1rem .75rem 3rem; }
    .spz__topbar { flex-direction: column; align-items: stretch; gap: .5rem; }
    .spz__topbar h1 { font-size: 1.4rem; }
    .spz__filter { min-width: 100%; }
    .spz__modal-actions { flex-direction: column-reverse; }
}

/* Past-event notice when payment can't be completed */
.spz__order-foot--note {
    background: rgba(255,255,255,.02);
    border-top: 1px solid var(--ticketa-border);
}
.spz__past-note {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(255,255,255,.6);
    font-size: .88rem;
    line-height: 1.4;
}
.spz__past-note i { color: rgba(255,255,255,.4); }

/* Anchor styled as a primary button (for the complete-payment link) */
a.spz__btn--primary {
    text-decoration: none;
}
