/**
 * 天域活动报名系统 - 用户中心样式
 *
 * @Author: Tianyu
 * @Date: 2026-01-31
 * @Description: 用户中心页面样式
 */

:root {
    --tianyu-border-color: var(--main-border-color);
    --tianyu-border-radius: 8px;
    --tianyu-card-padding: 15px;
    --tianyu-verified-color: rgba(103, 194, 58, 0.4);
    --tianyu-rejected-color: rgba(245, 108, 108, 0.4);
    --tianyu-not-exists-color: rgba(144, 147, 153, 0.4);
}

.tianyu-activity-border {
    border: 1px solid var(--tianyu-border-color);
    border-radius: var(--tianyu-border-radius);
}

.tianyu-activity-card {
    border: 1px solid var(--tianyu-border-color);
}

.activity-tab-nav ul.list-inline {
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
}

.activity-tab-nav ul.list-inline > li {
    display: inline-block;
    float: none;
}

.activity-tab-refresh-btn {
    padding: 6px 10px;
}

.activity-tab-refresh-btn.is-refreshing i.fa-refresh {
    animation: activity-icon-spin 1s linear infinite;
}

@keyframes activity-icon-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.tianyu-card-verified {
    opacity: 0.7;
    filter: grayscale(30%);
}

.tianyu-verified-watermark {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-30deg);
    font-size: 36px;
    font-weight: bold;
    color: var(--tianyu-verified-color);
    border: 4px solid var(--tianyu-verified-color);
    border-radius: 12px;
    padding: 12px 28px;
    pointer-events: none;
    z-index: 10;
    white-space: nowrap;
    letter-spacing: 4px;
    text-align: center;
}

.tianyu-card-rejected {
    opacity: 0.7;
    filter: grayscale(30%);
}

.tianyu-rejected-watermark {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-30deg);
    font-size: 36px;
    font-weight: bold;
    color: var(--tianyu-rejected-color);
    border: 4px solid var(--tianyu-rejected-color);
    border-radius: 12px;
    padding: 12px 28px;
    pointer-events: none;
    z-index: 10;
    white-space: nowrap;
    letter-spacing: 4px;
    text-align: center;
}

.tianyu-card-not-exists {
    opacity: 0.7;
    filter: grayscale(30%);
}

.tianyu-not-exists-watermark {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-30deg);
    font-size: 36px;
    font-weight: bold;
    color: var(--tianyu-not-exists-color);
    border: 4px solid var(--tianyu-not-exists-color);
    border-radius: 12px;
    padding: 12px 28px;
    pointer-events: none;
    z-index: 10;
    white-space: nowrap;
    letter-spacing: 4px;
    text-align: center;
}

.tianyu-watermark-info {
    font-size: 11px;
    font-weight: normal;
    letter-spacing: 0;
    margin-top: 4px;
    opacity: 0.9;
}

.tianyu-ticket-verified-watermark {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    font-weight: bold;
    color: #67c23a;
    border: 3px solid #67c23a;
    border-radius: 10px;
    pointer-events: none;
    z-index: 10;
    letter-spacing: 3px;
    text-align: center;
}

.tianyu-ticket-verified-watermark .tianyu-watermark-info {
    font-size: 14px;
    font-weight: normal;
    letter-spacing: 0;
    margin-top: 6px;
}

.tianyu-scan-container {
    position: relative;
    min-height: 250px;
    background: #000;
    border-radius: var(--tianyu-border-radius);
    overflow: hidden;
}

#tianyu-scan-video {
    width: 100%;
    height: 250px;
    object-fit: cover;
    display: block;
}

.tianyu-scan-overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 180px;
    height: 180px;
    border: 2px solid #67c23a;
    border-radius: var(--tianyu-border-radius);
    box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.5);
    opacity: 0;
    transition: opacity 0.3s;
}

.tianyu-scan-overlay.active {
    opacity: 1;
}

.tianyu-scan-line {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, #67c23a, transparent);
    animation: tianyu-scan-anim 2s linear infinite;
}

@keyframes tianyu-scan-anim {
    0% { top: 0; }
    100% { top: 100%; }
}

.tianyu-scan-loading {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    text-align: center;
}

.tianyu-scan-loading i {
    font-size: 32px;
    animation: activity-icon-spin 1s linear infinite;
}

.tianyu-quick-scan-result {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 100;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.75);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.tianyu-quick-scan-result-icon {
    font-size: 54px;
    margin-bottom: 10px;
    animation: tianyu-result-bounce 0.5s ease-out;
    filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.5));
}

.tianyu-quick-scan-result-msg {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 15px;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.8);
    padding: 8px 20px;
    border-radius: 8px;
    background: rgba(0, 0, 0, 0.3);
    text-align: center;
    line-height: 1.3;
}

.tianyu-quick-scan-result-detail {
    font-size: 14px;
    font-weight: normal;
    line-height: 1.3;
}

.tianyu-quick-scan-result.success .tianyu-quick-scan-result-icon {
    color: #67c23a;
}

.tianyu-quick-scan-result.success .tianyu-quick-scan-result-msg {
    color: #67c23a;
}

.tianyu-quick-scan-result.error .tianyu-quick-scan-result-icon {
    color: #f56c6c;
}

.tianyu-quick-scan-result.error .tianyu-quick-scan-result-msg {
    color: #f56c6c;
}

@keyframes tianyu-result-bounce {
    0% { transform: scale(0); opacity: 0; }
    50% { transform: scale(1.2); }
    100% { transform: scale(1); opacity: 1; }
}

.ticket-swiper {
    overflow: hidden;
}

.ticket-swiper .swiper-slide {
    width: 100%;
}

.ticket-card {
    min-height: 200px;
}

.ticket-prev:hover,
.ticket-next:hover {
    color: var(--focus-color);
}

.form-data-swiper {
    overflow: hidden;
}

.form-data-swiper .swiper-slide {
    width: 100%;
}

.form-person-card {
    min-height: 100px;
}

.form-swiper-prev:hover,
.form-swiper-next:hover {
    color: var(--focus-color);
}
