.app[data-v-1bc4c429]{width:100%;height:100%;display:flex;flex-direction:column}:root{--color-primary: #3B82F6;--color-primary-light: #60A5FA;--color-secondary: #8B5CF6;--color-accent: #06B6D4;--color-success: #10B981;--color-warning: #F59E0B;--color-danger: #EF4444;--color-text: #1E293B;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-text-light: #FFFFFF;--color-bg-light: #F8FAFC;--color-bg-white: #FFFFFF;--color-bg-card: rgba(255, 255, 255, .95);--color-bg-secondary: rgba(203, 213, 225, .25);--color-bg-gradient-start: #FFFFFF;--color-bg-gradient-end: #EFF6FF;--color-border: rgba(59, 130, 246, .3);--color-border-light: rgba(96, 165, 250, .2);--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 2px 8px rgba(59, 130, 246, .15);--shadow-md: 0 4px 16px rgba(59, 130, 246, .22);--shadow-lg: 0 8px 24px rgba(59, 130, 246, .28);--shadow-glow: 0 0 30px rgba(59, 130, 246, .35)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}html,body{width:100%;height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;color:var(--color-text);background:var(--color-bg-light)}#app{width:100%;height:100vh;overflow:hidden;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--color-bg-gradient-start),var(--color-bg-gradient-end));background-size:200% 200%;animation:gentleGradient 20s ease infinite;position:relative}@keyframes gentleGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}#app:before{content:"";position:fixed;bottom:-10vh;left:0;width:3px;height:3px;border-radius:50%;pointer-events:none;z-index:0;box-shadow:20vw 0 #3b82f6e6,80vw 15vh #3b82f6cc,15vw 30vh #3b82f6e6,65vw 45vh #3b82f6d9,10vw 60vh #3b82f6cc,60vw 10vh #8b5cf6e6,90vw 25vh #8b5cf6d9,75vw 40vh #8b5cf6cc,35vw 55vh #8b5cf6e6,95vw 70vh #8b5cf6cc,70vw 5vh #8b5cf6d9,50vw 20vh #06b6d4e6,33vw 35vh #06b6d4cc,45vw 50vh #06b6d4d9,85vw 65vh #06b6d4e6,25vw 8vh #3b82f6b3,40vw 22vh #8b5cf6b3,55vw 38vh #06b6d4b3,72vw 52vh #3b82f699,88vw 68vh #8b5cf699,42vw 12vh #06b6d499;animation:floatingUp1 15s linear infinite}#app:after{content:"";position:fixed;bottom:-10vh;left:0;width:2px;height:2px;border-radius:50%;pointer-events:none;z-index:0;box-shadow:18vw 5vh #3b82f6d9,82vw 18vh #3b82f6cc,48vw 32vh #3b82f6bf,92vw 48vh #3b82f6cc,28vw 12vh #8b5cf6d9,68vw 28vh #8b5cf6cc,12vw 42vh #8b5cf6bf,78vw 58vh #8b5cf6cc,38vw 22vh #06b6d4d9,58vw 38vh #06b6d4cc,98vw 52vh #06b6d4bf,5vw 8vh #3b82f699,52vw 25vh #8b5cf699,76vw 45vh #06b6d499,32vw 62vh #3b82f680,62vw 15vh #8b5cf680;animation:floatingUp2 20s linear infinite}@keyframes floatingUp1{0%{transform:translateY(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-120vh);opacity:0}}@keyframes floatingUp2{0%{transform:translateY(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-120vh);opacity:0}}@keyframes twinkle1{0%,to{opacity:1}50%{opacity:.3}}@keyframes twinkle2{0%,to{opacity:.4}50%{opacity:1}}@keyframes floatingStars{0%,to{opacity:1;transform:scale(1)}25%{opacity:.6;transform:scale(1.1)}50%{opacity:.8;transform:scale(.9)}75%{opacity:.7;transform:scale(1.05)}}@keyframes floatingParticles{0%,to{opacity:.6;transform:translateY(0)}50%{opacity:.8;transform:translateY(-10px)}}.room-header{flex-shrink:0;height:60px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#fff;box-shadow:var(--shadow-sm)}.dynamic-area{flex:1;min-height:0;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);position:relative;z-index:1}.card-container{width:100%;max-width:500px;max-height:calc(100vh - 108px);background:#fffffffa;border-radius:var(--radius-xl);border:1px solid rgba(59,130,246,.35);box-shadow:0 10px 40px #3b82f62e,0 2px 8px #1e293b1a;display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:2;animation:cardSlideIn .6s cubic-bezier(.34,1.56,.64,1)}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.card-container:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(59,130,246,.7) 20%,rgba(59,130,246,.7) 80%,transparent);z-index:1}.card-header{flex-shrink:0;padding:var(--spacing-lg);background:linear-gradient(135deg,#3b82f6f2,#60a5faeb);border-bottom:1px solid rgba(59,130,246,.4);text-align:center;position:relative;overflow:hidden}.card-header:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.25) 0%,transparent 70%);animation:headerGlow 20s linear infinite}.card-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent)}@keyframes headerGlow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.card-header h1,.card-header h2{font-size:22px;font-weight:700;color:#fff;margin:0;position:relative;z-index:1;text-shadow:0 2px 8px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.12);letter-spacing:.5px;animation:titleFadeIn .8s ease .2s both}@keyframes titleFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.card-header p{font-size:13px;color:#ffffffe6;margin:6px 0 0;position:relative;z-index:1;opacity:.95}.card-content{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-lg);-webkit-overflow-scrolling:touch;animation:contentFadeIn .8s ease .3s both}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.card-content::-webkit-scrollbar{width:6px}.card-content::-webkit-scrollbar-track{background:var(--color-bg-secondary);border-radius:3px}.card-content::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--color-primary),var(--color-primary-light));border-radius:3px}.card-content::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.card-content h2{font-size:20px;font-weight:700;color:var(--color-text);text-align:center;margin:0 0 20px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card-content h3{font-size:16px;font-weight:600;color:var(--color-text);margin:16px 0 12px}.card-content p{font-size:14px;color:var(--color-text-secondary);line-height:1.6;margin:8px 0;text-align:center}.card-content button{padding:12px 24px;font-size:15px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 3px 12px #f5c35a59,0 1px 3px #5a4a2f1f;margin:12px auto;display:block;min-width:120px;position:relative;overflow:hidden;animation:buttonSlideIn .5s ease both}@keyframes buttonSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card-content button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s,height .6s}.card-content button:hover:before{width:300px;height:300px}.card-content button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f5c35a73,0 2px 6px #5a4a2f2e}.card-content button:active{transform:translateY(0);box-shadow:0 2px 8px #f5c35a47,0 1px 2px #5a4a2f1a}.card-content button:disabled{opacity:.5;cursor:not-allowed;transform:none}.button-group{display:flex;gap:12px;margin:16px 0;animation:buttonGroupSlideIn .6s ease .4s both}@keyframes buttonGroupSlideIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.button-group .btn{flex:1;position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light))}.btn-secondary{background:linear-gradient(135deg,var(--color-secondary),#FFCC80)}.btn-danger{background:linear-gradient(135deg,var(--color-danger),#FFB399)}.btn-success{background:linear-gradient(135deg,var(--color-success),#A8DCC8)}.countdown-number{font-size:48px;font-weight:800;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;margin:20px 0;position:relative;display:inline-block;filter:drop-shadow(0 2px 6px rgba(245,195,90,.35))}.countdown-display{text-align:center;margin:20px 0;padding:20px;background:linear-gradient(135deg,#f5c35a1a,#ffb84d1a);border-radius:var(--radius-md);border:1px solid rgba(245,195,90,.25)}.countdown-time{font-size:42px;font-weight:800;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 2px 6px rgba(245,195,90,.35))}.info-list,.users-list,.role-list{display:flex;flex-direction:column;gap:10px;margin:16px 0}.info-item,.user-item,.role-item{padding:12px 16px;background:#fffffff2;border-radius:var(--radius-md);border:1px solid rgba(245,195,90,.28);display:flex;justify-content:space-between;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--color-text);box-shadow:0 2px 6px #f5c35a1f;position:relative;overflow:hidden;animation:itemSlideIn .4s ease both}@keyframes itemSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.info-item:nth-child(1),.user-item:nth-child(1),.role-item:nth-child(1){animation-delay:.1s}.info-item:nth-child(2),.user-item:nth-child(2),.role-item:nth-child(2){animation-delay:.2s}.info-item:nth-child(3),.user-item:nth-child(3),.role-item:nth-child(3){animation-delay:.3s}.info-item:nth-child(4),.user-item:nth-child(4),.role-item:nth-child(4){animation-delay:.4s}.info-item:nth-child(5),.user-item:nth-child(5),.role-item:nth-child(5){animation-delay:.5s}.info-item:before,.user-item:before,.role-item:before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:linear-gradient(180deg,var(--color-primary),var(--color-primary-light));opacity:0;transition:opacity .3s ease}.info-item:hover,.user-item:hover,.role-item:hover{border-color:#f5c35a80;background:#fffffffa;transform:translate(6px);box-shadow:0 4px 16px #f5c35a33,0 2px 6px #5a4a2f1a}.info-item:hover:before,.user-item:hover:before,.role-item:hover:before{opacity:1}.user-item.is-me,.role-item.is-me{border-color:#ffb84d80;background:#ffb84d26;box-shadow:0 2px 8px #ffb84d33}.user-item.ready{border-color:#88c4a873;background:#88c4a826;box-shadow:0 2px 8px #88c4a82e}.progress-info,.countdown-info{text-align:center;margin:16px 0;padding:16px;background:#ffffff80;border-radius:var(--radius-md);border:1px solid var(--color-border)}.progress-text{font-size:13px;color:var(--color-text-secondary);text-align:center;margin-top:8px}.question-content,.paper-content{padding:16px;background:#ffffffeb;border-radius:var(--radius-md);border:1px solid rgba(245,195,90,.28);margin:12px 0;line-height:1.8;color:var(--color-text);box-shadow:0 2px 8px #f5c35a1f;position:relative}.question-content:before,.paper-content:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(245,195,90,.4),transparent)}.modal-overlay{position:fixed;inset:0;background:#e3f9f5e6;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.modal-container{width:100%;max-width:500px;background:var(--color-bg-card);backdrop-filter:blur(20px);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);overflow:hidden;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));text-align:center}.modal-header h2{font-size:20px;font-weight:700;color:#fff;margin:0 0 8px}.modal-header .subtitle{font-size:13px;color:#ffffffe6;margin:0}.modal-body{padding:var(--spacing-lg);max-height:60vh;overflow-y:auto}.loading-spinner{display:flex;justify-content:center;align-items:center;padding:20px}.spinner{width:40px;height:40px;border:3px solid rgba(103,198,184,.2);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}.slide-enter-active,.slide-leave-active{transition:all .3s ease}.slide-enter-from{transform:translateY(-20px);opacity:0}.slide-leave-to{transform:translateY(20px);opacity:0}@media (max-width: 768px){.room-header{height:50px;font-size:14px;padding:0 var(--spacing-md)}.room-info{gap:12px;flex-wrap:wrap;justify-content:center}.room-id{font-size:14px}.role-number{font-size:13px;padding:3px 10px}.dynamic-area{padding:var(--spacing-sm)}.card-container{max-width:100%;max-height:calc(100vh - 74px);border-radius:var(--radius-lg);margin:0 var(--spacing-sm)}.card-header{padding:var(--spacing-md) var(--spacing-md)}.card-content{padding:var(--spacing-md)}.card-header h1,.card-header h2{font-size:18px}.card-header p{font-size:12px}.countdown-number,.countdown-time{font-size:36px}.card-content button{padding:10px 20px;font-size:14px;min-width:100px}.info-item,.user-item,.role-item{padding:10px 12px;font-size:13px}.question-content,.paper-content{padding:12px;font-size:13px}.card-content h3{font-size:15px;margin:12px 0 10px}.card-content p{font-size:13px}}@media (max-width: 375px){.dynamic-area{padding:6px}.room-info{gap:8px;font-size:12px}.room-id{font-size:13px}.role-number{font-size:12px;padding:2px 8px}.card-container{max-height:calc(100vh - 62px);border-radius:var(--radius-md);margin:0 6px}.card-header,.card-content{padding:12px}.card-header h1,.card-header h2{font-size:16px}.countdown-number,.countdown-time{font-size:32px}.card-content button{padding:9px 16px;font-size:13px}.info-item,.user-item,.role-item{padding:8px 10px;font-size:12px}}@media (max-height: 600px) and (orientation: landscape){.room-header{height:40px;font-size:13px}.dynamic-area{padding:8px}.card-container{max-height:calc(100vh - 56px)}.card-header{padding:10px}.card-content{padding:12px}.card-header h1,.card-header h2{font-size:16px}.countdown-number,.countdown-time{font-size:28px;margin:10px 0}.card-content button{padding:8px 16px;font-size:13px;margin:8px auto}.info-item,.user-item,.role-item{padding:6px 10px}.card-content h3{font-size:14px;margin:10px 0 8px}}@media (hover: none) and (pointer: coarse){.card-content button{min-height:44px;padding:12px 24px}.info-item,.user-item,.role-item{min-height:44px}.info-item:hover,.user-item:hover,.role-item:hover{transform:none}.card-content button:active{transform:scale(.97)}.info-item:active,.user-item:active,.role-item:active{background:#fff}}
