:root{--primary-color: #6366f1;--secondary-color: #a855f7;--bg-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--glass-bg: rgba(255, 255, 255, .9);--glass-border: rgba(255, 255, 255, .3);--text-color: #1f2937}*,*:before,*:after{box-sizing:border-box}html,body{overflow-x:hidden;width:100%;overscroll-behavior-y:none}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background:var(--bg-gradient);min-height:100vh;color:var(--text-color)}#app{width:100%;max-width:1200px;margin:0 auto;padding:2rem}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid var(--glass-border);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:2rem}.btn{background:linear-gradient(to right,var(--primary-color),var(--secondary-color));color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f166}input{width:100%;padding:.75rem;margin-bottom:1rem;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb;transition:border-color .2s}input:focus{outline:none;border-color:var(--primary-color);background:#fff}h1,h2,h3{margin-top:0}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}@media(max-width:768px){body{align-items:flex-start;padding-top:2rem}#app{padding:1rem;max-width:100%}.glass-card{padding:1.5rem;border-radius:12px;margin:0 .5rem}.btn{width:100%;padding:1rem;font-size:16px}input{font-size:16px;padding:1rem}}@media(max-width:480px){#app{padding:.5rem}.glass-card{padding:1rem;margin:0;border-radius:8px}h2{font-size:1.25rem}}.login-container[data-v-5fb8b7ad]{max-width:450px;margin:2rem auto;padding:2.5rem;text-align:center}.logo[data-v-5fb8b7ad]{font-size:4rem;margin-bottom:1rem;animation:bounce-5fb8b7ad 2s infinite}@keyframes bounce-5fb8b7ad{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}h2[data-v-5fb8b7ad]{color:var(--primary-color);margin-bottom:.5rem}.subtitle[data-v-5fb8b7ad]{color:#666;font-size:.9rem;margin-bottom:2rem}.form-container[data-v-5fb8b7ad]{margin-top:1.5rem}.input-group[data-v-5fb8b7ad]{text-align:left;margin-bottom:1.2rem}.input-group label[data-v-5fb8b7ad]{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-color)}.input-group input[data-v-5fb8b7ad]{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .3s}.input-group input[data-v-5fb8b7ad]:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.checkbox-group[data-v-5fb8b7ad]{text-align:left;margin-bottom:1.5rem}.checkbox-group label[data-v-5fb8b7ad]{display:flex;align-items:center;cursor:pointer;font-size:.9rem}.checkbox-group input[data-v-5fb8b7ad]{margin-right:.5rem;cursor:pointer}.login-btn[data-v-5fb8b7ad]{width:100%;padding:1rem;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #6366f166}.login-btn[data-v-5fb8b7ad]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6366f199}.login-btn[data-v-5fb8b7ad]:disabled{opacity:.6;cursor:not-allowed}.progress-container[data-v-5fb8b7ad]{padding:2rem;text-align:center}.loading-spinner[data-v-5fb8b7ad]{display:flex;justify-content:center;margin-bottom:1.5rem}.spinner[data-v-5fb8b7ad]{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid var(--primary-color);border-radius:50%;animation:spin-5fb8b7ad 1s linear infinite}@keyframes spin-5fb8b7ad{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-msg[data-v-5fb8b7ad]{margin-top:1rem;font-size:.95rem;color:var(--text-color);animation:fadeIn-5fb8b7ad .5s}.status-msg.error[data-v-5fb8b7ad]{color:#dc2626;font-weight:600}@keyframes fadeIn-5fb8b7ad{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.help-section[data-v-5fb8b7ad]{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.help-text[data-v-5fb8b7ad]{font-size:.85rem;color:#666;margin:.5rem 0}.help-text a[data-v-5fb8b7ad]{color:var(--primary-color);text-decoration:none;font-weight:600}.help-text a[data-v-5fb8b7ad]:hover{text-decoration:underline}@media(max-width:480px){.login-container[data-v-5fb8b7ad]{padding:1.5rem}.logo[data-v-5fb8b7ad]{font-size:3rem}h2[data-v-5fb8b7ad]{font-size:1.5rem}}.login-container[data-v-b0b75c2e]{max-width:450px;margin:2rem auto;padding:2.5rem;text-align:center}.logo[data-v-b0b75c2e]{font-size:4rem;margin-bottom:1rem;animation:bounce-b0b75c2e 2s infinite}@keyframes bounce-b0b75c2e{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}h2[data-v-b0b75c2e]{color:var(--primary-color);margin-bottom:.5rem}.subtitle[data-v-b0b75c2e]{color:#666;font-size:.9rem;margin-bottom:2rem}.form-container[data-v-b0b75c2e]{margin-top:1.5rem}.input-group[data-v-b0b75c2e]{text-align:left;margin-bottom:1.2rem}.input-group label[data-v-b0b75c2e]{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-color)}.input-group input[data-v-b0b75c2e]{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .3s;box-sizing:border-box}.input-group input[data-v-b0b75c2e]:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a;outline:none}.captcha-group[data-v-b0b75c2e]{text-align:left;margin-bottom:1.2rem}.captcha-group label[data-v-b0b75c2e]{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-color)}.captcha-row[data-v-b0b75c2e]{display:flex;gap:8px;align-items:center}.captcha-input[data-v-b0b75c2e]{flex:1;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1.2rem;text-transform:uppercase;letter-spacing:4px;text-align:center}.captcha-input[data-v-b0b75c2e]:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a;outline:none}.captcha-img-container[data-v-b0b75c2e]{width:120px;height:48px;border:2px solid #e5e7eb;border-radius:8px;overflow:hidden;cursor:pointer;display:flex;align-items:center;justify-content:center;background:#f9fafb}.captcha-img[data-v-b0b75c2e]{width:100%;height:100%;object-fit:contain}.captcha-loading[data-v-b0b75c2e],.captcha-placeholder[data-v-b0b75c2e]{font-size:.8rem;color:#666}.refresh-btn[data-v-b0b75c2e]{padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;font-size:1.2rem;transition:all .2s}.refresh-btn[data-v-b0b75c2e]:hover{background:#f3f4f6}.refresh-btn[data-v-b0b75c2e]:disabled{opacity:.5;cursor:not-allowed}.checkbox-group[data-v-b0b75c2e]{text-align:left;margin-bottom:1.5rem}.checkbox-group label[data-v-b0b75c2e]{display:flex;align-items:center;cursor:pointer;font-size:.9rem}.checkbox-group input[data-v-b0b75c2e]{margin-right:.5rem;cursor:pointer;font-size:.9rem}.login-btn[data-v-b0b75c2e]{width:100%;padding:1rem;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #6366f166}.login-btn[data-v-b0b75c2e]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6366f199}.login-btn[data-v-b0b75c2e]:disabled{opacity:.6;cursor:not-allowed}.progress-container[data-v-b0b75c2e]{padding:2rem;text-align:center}.loading-spinner[data-v-b0b75c2e]{display:flex;justify-content:center;margin-bottom:1.5rem}.spinner[data-v-b0b75c2e]{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid var(--primary-color);border-radius:50%;animation:spin-b0b75c2e 1s linear infinite}@keyframes spin-b0b75c2e{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-msg[data-v-b0b75c2e]{margin-top:1rem;font-size:.95rem;color:var(--text-color);animation:fadeIn-b0b75c2e .5s}.status-msg.error[data-v-b0b75c2e]{color:#dc2626;font-weight:600}@keyframes fadeIn-b0b75c2e{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mode-switch[data-v-b0b75c2e]{margin-top:1rem}.switch-btn[data-v-b0b75c2e]{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:.9rem;padding:.5rem}.switch-btn[data-v-b0b75c2e]:hover{text-decoration:underline}.help-section[data-v-b0b75c2e]{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.help-text[data-v-b0b75c2e]{font-size:.85rem;color:#666;margin:.5rem 0}.help-text a[data-v-b0b75c2e]{color:var(--primary-color);text-decoration:none;font-weight:600}.help-text a[data-v-b0b75c2e]:hover{text-decoration:underline}@media(max-width:480px){.login-container[data-v-b0b75c2e]{padding:1.5rem}.logo[data-v-b0b75c2e]{font-size:3rem}h2[data-v-b0b75c2e]{font-size:1.5rem}.captcha-row[data-v-b0b75c2e]{flex-wrap:wrap}.captcha-input[data-v-b0b75c2e]{width:100%;margin-bottom:8px}}.dashboard[data-v-27413819]{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.dashboard-header[data-v-27413819]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#fffffff2;border-radius:16px;box-shadow:0 4px 20px #0000001a;margin-bottom:24px}.brand[data-v-27413819]{display:flex;align-items:center;gap:12px}.brand .logo[data-v-27413819]{font-size:32px}.brand .title[data-v-27413819]{font-size:22px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.user-info[data-v-27413819]{display:flex;align-items:center;gap:12px}.student-id[data-v-27413819]{color:#374151;font-weight:500}.share-btn[data-v-27413819],.logout-btn[data-v-27413819]{padding:8px 16px;border-radius:8px;border:none;cursor:pointer;font-size:14px;transition:all .2s}.share-btn[data-v-27413819]{background:#f0f4ff;color:#667eea}.share-btn[data-v-27413819]:hover{background:#667eea;color:#fff}.logout-btn[data-v-27413819]{background:#fee2e2;color:#dc2626}.logout-btn[data-v-27413819]:hover{background:#dc2626;color:#fff}.module-grid[data-v-27413819]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;max-width:900px;margin:0 auto}.module-card[data-v-27413819]{background:#fff;border-radius:20px;padding:28px 20px;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #0000001a;position:relative;overflow:hidden}.module-card[data-v-27413819]:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--accent-color)}.module-card[data-v-27413819]:hover:not(.disabled){transform:translateY(-8px);box-shadow:0 12px 30px #00000026}.module-card.disabled[data-v-27413819]{opacity:.7;cursor:not-allowed}.module-icon[data-v-27413819]{font-size:48px;margin-bottom:12px}.module-name[data-v-27413819]{font-size:18px;font-weight:600;color:#1f2937;margin-bottom:8px}.module-desc[data-v-27413819]{font-size:13px;color:#6b7280}.coming-soon[data-v-27413819]{position:absolute;top:12px;right:-30px;background:#fbbf24;color:#92400e;font-size:10px;padding:4px 32px;transform:rotate(45deg);font-weight:600}.dashboard-footer[data-v-27413819]{text-align:center;margin-top:32px;color:#fffc}@media(max-width:640px){.dashboard-header[data-v-27413819]{flex-direction:column;gap:12px}.module-grid[data-v-27413819]{grid-template-columns:repeat(2,1fr)}.module-card[data-v-27413819]{padding:20px 16px}.module-icon[data-v-27413819]{font-size:36px}}.grade-view[data-v-307469b3]{min-height:100vh;background:#f5f7fa;padding-bottom:40px}.grade-header[data-v-307469b3]{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:sticky;top:0;z-index:100}.grade-header .title[data-v-307469b3]{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:600}.grade-header .icon[data-v-307469b3]{font-size:24px}.back-btn[data-v-307469b3],.logout-btn[data-v-307469b3]{padding:8px 16px;border-radius:8px;border:none;cursor:pointer;font-size:14px;transition:all .2s}.back-btn[data-v-307469b3]{background:#fff3;color:#fff}.back-btn[data-v-307469b3]:hover{background:#ffffff4d}.logout-btn[data-v-307469b3]{background:#ffffffe6;color:#764ba2}.user-info[data-v-307469b3]{display:flex;align-items:center;gap:12px}.filter-bar[data-v-307469b3]{background:#fff;padding:16px 20px;margin:16px 20px;border-radius:16px;box-shadow:0 2px 10px #0000000d}.filter-row[data-v-307469b3]{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.filter-row+.filter-row[data-v-307469b3]{margin-top:12px;padding-top:12px;border-top:1px solid #f3f4f6}.search-box[data-v-307469b3]{flex:1;min-width:200px;display:flex;align-items:center;background:#f5f7fa;border-radius:10px;padding:0 12px}.search-icon[data-v-307469b3]{margin-right:8px}.search-input[data-v-307469b3]{flex:1;border:none;background:transparent;padding:12px 0;font-size:14px;outline:none}.filter-select[data-v-307469b3]{padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;min-width:140px;background:#fff;cursor:pointer}.filter-group[data-v-307469b3]{display:flex;align-items:center;gap:8px}.filter-group label[data-v-307469b3]:first-child{font-size:13px;color:#6b7280;white-space:nowrap}.radio-group[data-v-307469b3]{display:flex;gap:4px}.radio-label[data-v-307469b3]{padding:6px 12px;border-radius:8px;font-size:13px;cursor:pointer;background:#f3f4f6;transition:all .2s}.radio-label input[data-v-307469b3]{display:none}.radio-label.active[data-v-307469b3]{background:#667eea;color:#fff}.reset-btn[data-v-307469b3]{padding:8px 16px;background:#fee2e2;color:#dc2626;border:none;border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s}.reset-btn[data-v-307469b3]:hover{background:#dc2626;color:#fff}.stats-row[data-v-307469b3]{display:flex;gap:12px;padding:0 20px;margin-bottom:16px}.stat-card[data-v-307469b3]{flex:1;background:#fff;border-radius:12px;padding:16px;text-align:center;box-shadow:0 2px 8px #0000000d}.stat-value[data-v-307469b3]{font-size:24px;font-weight:700;color:#667eea}.stat-label[data-v-307469b3]{font-size:12px;color:#6b7280;margin-top:4px}.grade-list[data-v-307469b3]{padding:0 20px}.term-group[data-v-307469b3]{margin-bottom:24px}.term-header[data-v-307469b3]{font-size:16px;font-weight:600;color:#374151;margin-bottom:12px}.grade-grid[data-v-307469b3]{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.grade-card[data-v-307469b3]{background:#fff;border-radius:14px;padding:16px;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px #0000000d;position:relative;overflow:hidden}.grade-card[data-v-307469b3]:before{content:"";position:absolute;top:0;left:0;right:0;height:4px}.grade-card.excellent[data-v-307469b3]:before{background:#10b981}.grade-card.good[data-v-307469b3]:before{background:#3b82f6}.grade-card.pass[data-v-307469b3]:before{background:#f59e0b}.grade-card.fail[data-v-307469b3]:before{background:#ef4444}.grade-card[data-v-307469b3]:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.card-score[data-v-307469b3]{font-size:28px;font-weight:700;margin-bottom:8px}.grade-card.excellent .card-score[data-v-307469b3]{color:#10b981}.grade-card.good .card-score[data-v-307469b3]{color:#3b82f6}.grade-card.pass .card-score[data-v-307469b3]{color:#f59e0b}.grade-card.fail .card-score[data-v-307469b3]{color:#ef4444}.card-name[data-v-307469b3]{font-size:14px;font-weight:500;color:#1f2937;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta[data-v-307469b3]{font-size:11px;color:#9ca3af;display:flex;gap:8px;margin-bottom:6px}.card-teacher[data-v-307469b3]{font-size:11px;color:#6b7280;background:#f3f4f6;padding:4px 8px;border-radius:6px;margin-top:8px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.no-results[data-v-307469b3]{text-align:center;padding:60px 20px;color:#6b7280}.empty-icon[data-v-307469b3]{font-size:64px;margin-bottom:16px}.no-results button[data-v-307469b3]{margin-top:16px;padding:12px 24px;background:#667eea;color:#fff;border:none;border-radius:10px;cursor:pointer}.modal-overlay[data-v-307469b3]{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content[data-v-307469b3]{background:#fff;border-radius:20px;padding:32px;max-width:480px;width:100%;position:relative;animation:slideUp-307469b3 .3s ease}@keyframes slideUp-307469b3{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close[data-v-307469b3]{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:#f3f4f6;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.detail-header[data-v-307469b3]{text-align:center;margin-bottom:24px}.detail-score[data-v-307469b3]{font-size:48px;font-weight:700;margin-bottom:8px}.detail-score.excellent[data-v-307469b3]{color:#10b981}.detail-score.good[data-v-307469b3]{color:#3b82f6}.detail-score.pass[data-v-307469b3]{color:#f59e0b}.detail-score.fail[data-v-307469b3]{color:#ef4444}.detail-header h2[data-v-307469b3]{font-size:20px;color:#1f2937;margin:0}.detail-grid[data-v-307469b3]{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.detail-item[data-v-307469b3]{background:#f9fafb;padding:12px;border-radius:10px}.detail-item.full-width[data-v-307469b3]{grid-column:span 2}.detail-label[data-v-307469b3]{display:block;font-size:12px;color:#6b7280;margin-bottom:4px}.detail-value[data-v-307469b3]{font-size:15px;font-weight:500;color:#1f2937}@media(max-width:640px){.filter-row[data-v-307469b3]{flex-direction:column;align-items:stretch}.filter-group[data-v-307469b3]{width:100%;justify-content:space-between}.grade-grid[data-v-307469b3]{grid-template-columns:repeat(2,1fr)}.stats-row[data-v-307469b3]{flex-wrap:wrap}.stat-card[data-v-307469b3]{min-width:calc(33% - 8px)}}.elec-view[data-v-607c56af]{min-height:100vh;background:#f5f7fa}.elec-header[data-v-607c56af]{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#e53e3e,#c53030);color:#fff}.elec-header .title[data-v-607c56af]{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:600}.back-btn[data-v-607c56af],.logout-btn[data-v-607c56af]{padding:8px 16px;border-radius:8px;border:none;cursor:pointer;background:#fff3;color:#fff;transition:background .2s}.back-btn[data-v-607c56af]:hover,.logout-btn[data-v-607c56af]:hover{background:#ffffff4d}.content[data-v-607c56af]{padding:20px;max-width:600px;margin:0 auto}.selector-card[data-v-607c56af]{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 12px #0000000d;margin-bottom:20px}.selector-card h3[data-v-607c56af]{margin:0 0 16px;font-size:16px;color:#2d3748}.select-group[data-v-607c56af]{display:grid;gap:12px}.modern-select[data-v-607c56af]{width:100%;padding:12px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;color:#4a5568;background-color:#fff;cursor:pointer;outline:none;transition:border-color .2s}.modern-select[data-v-607c56af]:focus{border-color:#e53e3e}.modern-select[data-v-607c56af]:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.7}.result-card[data-v-607c56af]{background:#fff;border-radius:16px;padding:24px;box-shadow:0 8px 24px #e53e3e1a;text-align:center;position:relative;overflow:hidden}.status-badge[data-v-607c56af]{position:absolute;top:16px;right:16px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.status-badge.normal[data-v-607c56af]{background:#def7ec;color:#03543f}.status-badge.warning[data-v-607c56af]{background:#fde8e8;color:#9b1c1c}.balance-display[data-v-607c56af]{margin:20px 0}.balance-display .label[data-v-607c56af]{font-size:14px;color:#718096;margin-bottom:8px}.balance-display .value[data-v-607c56af]{font-size:42px;font-weight:700;color:#2d3748}.balance-display .value.low[data-v-607c56af]{color:#e53e3e}.balance-display .value small[data-v-607c56af]{font-size:16px;font-weight:500;color:#718096}.detail-row[data-v-607c56af]{display:flex;justify-content:center;gap:32px;margin-bottom:24px;padding-top:20px;border-top:1px solid #f0f0f0}.detail-item[data-v-607c56af]{display:flex;flex-direction:column;gap:4px}.d-label[data-v-607c56af]{font-size:12px;color:#a0aec0}.d-value[data-v-607c56af]{font-size:16px;font-weight:600;color:#4a5568}.refresh-btn[data-v-607c56af]{width:100%;padding:12px;background:#f7fafc;color:#4a5568;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s}.refresh-btn[data-v-607c56af]:hover{background:#edf2f7;transform:translateY(-2px)}.loading-state[data-v-607c56af],.empty-state[data-v-607c56af],.error-msg[data-v-607c56af]{text-align:center;padding:40px;color:#718096}.error-msg[data-v-607c56af]{color:#e53e3e;background:#fff5f5;border-radius:12px}.spinner[data-v-607c56af]{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #e53e3e;border-radius:50%;margin:0 auto 16px;animation:spin-607c56af 1s linear infinite}@keyframes spin-607c56af{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.classroom-view[data-v-bcb2c526]{min-height:100vh;background:#f0f2f5;padding-bottom:20px}.app-header[data-v-bcb2c526]{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 4px 12px #10b98133}.title[data-v-bcb2c526]{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:600}.back-btn[data-v-bcb2c526],.logout-btn[data-v-bcb2c526]{padding:8px 16px;border-radius:8px;border:none;cursor:pointer;font-size:14px;transition:all .2s}.back-btn[data-v-bcb2c526]{background:#fff3;color:#fff}.back-btn[data-v-bcb2c526]:hover{background:#ffffff4d}.logout-btn[data-v-bcb2c526]{background:#ffffffe6;color:#059669;font-weight:600}.content-container[data-v-bcb2c526]{padding:16px;max-width:800px;margin:0 auto}.filter-card[data-v-bcb2c526]{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000000d;margin-bottom:16px}.filter-row[data-v-bcb2c526]{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}.filter-item[data-v-bcb2c526]{flex:1;min-width:100px}.filter-item label[data-v-bcb2c526]{display:block;font-size:12px;color:#6b7280;margin-bottom:4px}select[data-v-bcb2c526],input[data-v-bcb2c526]{width:100%;padding:8px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;background:#fff}.periods-row[data-v-bcb2c526]{margin-top:12px;flex-direction:column;gap:8px;align-items:stretch}.periods-label[data-v-bcb2c526]{display:flex;justify-content:space-between;align-items:center}.periods-label label[data-v-bcb2c526]{font-size:12px;color:#6b7280}.quick-actions span[data-v-bcb2c526]{font-size:12px;color:#10b981;margin-left:12px;cursor:pointer}.periods-grid[data-v-bcb2c526]{display:flex;flex-wrap:wrap;gap:8px}.period-tag[data-v-bcb2c526]{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;color:#374151;cursor:pointer;transition:all .2s}.period-tag.active[data-v-bcb2c526]{background:#10b981;color:#fff;border-color:#10b981}.seats-input[data-v-bcb2c526]{flex:2}.input-group[data-v-bcb2c526]{display:flex;align-items:center;gap:8px}.input-group input[data-v-bcb2c526]{text-align:center}.query-btn[data-v-bcb2c526]{flex:1;min-width:120px;padding:10px;background:#10b981;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;height:40px}.query-btn[data-v-bcb2c526]:disabled{opacity:.7;cursor:not-allowed}.empty-state[data-v-bcb2c526]{grid-column:1 / -1;text-align:center;padding:40px;color:#9ca3af}.empty-state .emoji[data-v-bcb2c526]{font-size:48px;margin-bottom:12px}.error-msg[data-v-bcb2c526]{background:#fee2e2;color:#dc2626;padding:12px;border-radius:8px;margin-bottom:16px;text-align:center;font-size:14px}.results-info[data-v-bcb2c526]{margin:16px 0;display:flex;justify-content:space-between;align-items:center;background:#fff;padding:12px 16px;border-radius:12px;box-shadow:0 2px 8px #00000008}.date-container[data-v-bcb2c526]{display:flex;flex-direction:column}.week-row[data-v-bcb2c526]{display:flex;gap:8px;align-items:center;margin-bottom:2px}.week-info[data-v-bcb2c526]{font-weight:600;color:#374151}.weekday[data-v-bcb2c526]{font-weight:600;color:#10b981}.date-row[data-v-bcb2c526]{font-size:13px;color:#6b7280}.semester-info[data-v-bcb2c526]{font-size:12px;color:#9ca3af;background:#f3f4f6;padding:4px 8px;border-radius:6px}.classroom-list[data-v-bcb2c526]{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.room-card[data-v-bcb2c526]{background:#fff;border-radius:16px;padding:16px;box-shadow:0 4px 12px #0000000d;display:flex;flex-direction:column;justify-content:height;position:relative;overflow:hidden;border:1px solid #f0fdf4;transition:transform .2s}.room-card[data-v-bcb2c526]:active{transform:scale(.98)}.room-card[data-v-bcb2c526]:before{content:"";position:absolute;top:0;left:0;width:6px;height:100%;background:#10b981}.card-top[data-v-bcb2c526]{display:flex;justify-content:space-between;margin-bottom:8px}.room-seats[data-v-bcb2c526]{font-size:14px;font-weight:700;color:#059669;background:#ecfdf5;padding:2px 6px;border-radius:6px}.room-type[data-v-bcb2c526]{font-size:10px;color:#9ca3af;border:1px solid #e5e7eb;padding:1px 4px;border-radius:4px}.room-main[data-v-bcb2c526]{margin:8px 0}.room-name[data-v-bcb2c526]{font-size:18px;font-weight:800;color:#1f2937;line-height:1.2}.room-building[data-v-bcb2c526]{font-size:12px;color:#6b7280;margin-top:4px}.card-bottom[data-v-bcb2c526]{display:flex;justify-content:space-between;align-items:flex-end;margin-top:auto}.floor-tag[data-v-bcb2c526]{font-size:12px;color:#9ca3af;background:#f9fafb;padding:2px 6px;border-radius:4px}.status-tag[data-v-bcb2c526]{font-size:12px;font-weight:600}.status-tag.available[data-v-bcb2c526]{color:#10b981}.schedule-view[data-v-603b3716]{height:100vh;display:flex;flex-direction:column;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overflow:hidden}.schedule-header[data-v-603b3716]{height:50px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-shrink:0}.back-btn[data-v-603b3716]{background:#fff3;border:none;color:#fff;padding:6px 12px;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s}.back-btn[data-v-603b3716]:hover{background:#ffffff4d}.schedule-header .title[data-v-603b3716]{display:flex;align-items:center;gap:6px;font-size:16px;font-weight:600}.schedule-header .icon[data-v-603b3716]{font-size:18px}.week-selector[data-v-603b3716]{position:relative;background:#fff3;padding:6px 12px;border-radius:12px}.week-selector select[data-v-603b3716]{appearance:none;border:none;background:transparent;font-size:14px;font-weight:600;color:#fff;padding-right:16px;outline:none;cursor:pointer}.week-selector select option[data-v-603b3716]{color:#333}.week-selector .arrow[data-v-603b3716]{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:10px;color:#fffc;pointer-events:none}.date-header[data-v-603b3716]{height:50px;display:flex;border-bottom:1px solid #f3f4f6;background:#fff;flex-shrink:0}.month-col[data-v-603b3716]{width:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;color:#1f2937;font-size:14px}.month-label[data-v-603b3716]{font-size:10px;font-weight:400;color:#6b7280}.days-row[data-v-603b3716]{flex:1;display:flex}.day-col[data-v-603b3716]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.day-col.is-today[data-v-603b3716]{background:#eff6ff;border-radius:0 0 12px 12px}.day-col.is-today .day-num[data-v-603b3716]{color:#2563eb;font-weight:700}.day-num[data-v-603b3716]{font-size:14px;color:#1f2937;font-weight:600}.day-label[data-v-603b3716]{font-size:10px;color:#6b7280;display:flex;flex-direction:column;align-items:center;line-height:1.1}.timetable-container[data-v-603b3716]{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.grid-body[data-v-603b3716]{flex:1;display:flex;overflow-y:auto;position:relative;scrollbar-width:none}.grid-body[data-v-603b3716]::-webkit-scrollbar{display:none}.time-axis[data-v-603b3716]{width:40px;background:#fff;display:flex;flex-direction:column}.time-slot[data-v-603b3716]{height:65px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10px;color:#9ca3af}.period-num[data-v-603b3716]{font-size:14px;font-weight:700;color:#374151;margin:2px 0}.courses-grid[data-v-603b3716]{flex:1;display:flex;position:relative}.grid-lines[data-v-603b3716]{position:absolute;inset:0;display:flex;flex-direction:column;pointer-events:none}.line-row[data-v-603b3716]{height:65px;border-bottom:1px dashed #f3f4f6;box-sizing:border-box}.day-column[data-v-603b3716]{flex:1;display:grid;grid-template-rows:repeat(11,65px);grid-template-columns:1fr;padding:0 2px;position:relative}.course-card[data-v-603b3716]{margin:2px;border-radius:6px;padding:6px 4px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;font-size:12px;overflow:hidden;cursor:pointer;transition:transform .1s,box-shadow .1s;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;border:1px solid rgba(255,255,255,.5)}.course-card[data-v-603b3716]:active{transform:scale(.98);box-shadow:0 0 1px #0000001a}.course-name[data-v-603b3716]{font-weight:600;font-size:12px;margin-bottom:4px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.course-room[data-v-603b3716]{font-size:11px;opacity:.85;font-weight:500}.modal-overlay[data-v-603b3716]{position:fixed;inset:0;background:#0006;z-index:100;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content[data-v-603b3716]{background:#fff;width:80%;max-width:320px;border-radius:20px;padding:24px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header[data-v-603b3716]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.modal-header h3[data-v-603b3716]{font-size:18px;color:#111827;margin:0;line-height:1.4}.close-btn[data-v-603b3716]{background:#f3f4f6;border:none;width:28px;height:28px;border-radius:50%;color:#6b7280;font-size:16px;cursor:pointer}.info-row[data-v-603b3716]{display:flex;justify-content:space-between;margin-bottom:12px;border-bottom:1px solid #f9fafb;padding-bottom:8px}.info-row[data-v-603b3716]:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.info-row .label[data-v-603b3716]{color:#9ca3af;font-size:13px}.info-row .value[data-v-603b3716]{color:#374151;font-size:13px;font-weight:500;text-align:right;max-width:70%}.fade-enter-active[data-v-603b3716],.fade-leave-active[data-v-603b3716]{transition:opacity .2s}.fade-enter-from[data-v-603b3716],.fade-leave-to[data-v-603b3716]{opacity:0}.student-info-view[data-v-ce867233]{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.view-header[data-v-ce867233]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#fffffff2;border-radius:16px;box-shadow:0 4px 20px #0000001a;margin-bottom:24px}.view-header h1[data-v-ce867233]{font-size:20px;margin:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.back-btn[data-v-ce867233],.logout-btn[data-v-ce867233]{padding:8px 16px;border-radius:8px;border:none;cursor:pointer;font-size:14px;transition:all .2s}.back-btn[data-v-ce867233]{background:#f0f4ff;color:#667eea}.back-btn[data-v-ce867233]:hover{background:#667eea;color:#fff}.logout-btn[data-v-ce867233]{background:#fee2e2;color:#dc2626}.logout-btn[data-v-ce867233]:hover{background:#dc2626;color:#fff}.view-content[data-v-ce867233]{max-width:600px;margin:0 auto}.loading-state[data-v-ce867233],.error-state[data-v-ce867233]{text-align:center;padding:60px 20px;background:#fff;border-radius:20px;color:#374151}.spinner[data-v-ce867233]{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin-ce867233 1s linear infinite;margin:0 auto 16px}@keyframes spin-ce867233{to{transform:rotate(360deg)}}.error-icon[data-v-ce867233]{font-size:48px;margin-bottom:16px}.error-state button[data-v-ce867233]{margin-top:16px;padding:10px 24px;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer}.info-card[data-v-ce867233]{background:#fff;border-radius:20px;padding:32px;box-shadow:0 4px 20px #0000001a}.avatar-section[data-v-ce867233]{text-align:center;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.avatar[data-v-ce867233]{width:80px;height:80px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:36px;font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:50%;margin:0 auto 16px}.avatar-section h2[data-v-ce867233]{margin:0 0 8px;font-size:24px;color:#1f2937}.student-id-badge[data-v-ce867233]{display:inline-block;padding:6px 16px;background:#f0f4ff;color:#667eea;border-radius:20px;font-size:14px;font-weight:500}.info-grid[data-v-ce867233]{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.info-item[data-v-ce867233]{display:flex;flex-direction:column;padding:12px;background:#f9fafb;border-radius:12px}.info-item .label[data-v-ce867233]{font-size:12px;color:#6b7280;margin-bottom:4px}.info-item .value[data-v-ce867233]{font-size:15px;color:#1f2937;font-weight:500}@media(max-width:640px){.info-grid[data-v-ce867233]{grid-template-columns:1fr}.view-header h1[data-v-ce867233]{font-size:16px}}.exam-view[data-v-34d14af3]{min-height:100vh;background:linear-gradient(135deg,#48bb78,#38a169);padding:20px}.view-header[data-v-34d14af3]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#fffffff2;border-radius:16px;box-shadow:0 4px 20px #0000001a;margin-bottom:16px}.view-header h1[data-v-34d14af3]{font-size:20px;margin:0;color:#22543d}.back-btn[data-v-34d14af3],.logout-btn[data-v-34d14af3]{padding:8px 16px;border-radius:8px;border:none;cursor:pointer;font-size:14px;transition:all .2s}.back-btn[data-v-34d14af3]{background:#c6f6d5;color:#22543d}.back-btn[data-v-34d14af3]:hover{background:#48bb78;color:#fff}.logout-btn[data-v-34d14af3]{background:#fee2e2;color:#dc2626}.logout-btn[data-v-34d14af3]:hover{background:#dc2626;color:#fff}.semester-selector[data-v-34d14af3]{background:#fffffff2;padding:16px 24px;border-radius:12px;margin-bottom:16px;display:flex;align-items:center;gap:12px}.semester-selector label[data-v-34d14af3]{font-weight:500;color:#22543d}.semester-selector select[data-v-34d14af3]{padding:10px 16px;border-radius:8px;border:2px solid #c6f6d5;font-size:14px;min-width:180px;cursor:pointer}.semester-selector select[data-v-34d14af3]:focus{outline:none;border-color:#48bb78}.view-content[data-v-34d14af3]{max-width:800px;margin:0 auto}.loading-state[data-v-34d14af3],.error-state[data-v-34d14af3],.empty-state[data-v-34d14af3]{text-align:center;padding:60px 20px;background:#fff;border-radius:20px;color:#374151}.spinner[data-v-34d14af3]{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#48bb78;border-radius:50%;animation:spin-34d14af3 1s linear infinite;margin:0 auto 16px}@keyframes spin-34d14af3{to{transform:rotate(360deg)}}.error-icon[data-v-34d14af3],.empty-icon[data-v-34d14af3]{font-size:48px;margin-bottom:16px}.error-state button[data-v-34d14af3]{margin-top:16px;padding:10px 24px;background:#48bb78;color:#fff;border:none;border-radius:8px;cursor:pointer}.exam-list[data-v-34d14af3]{display:flex;flex-direction:column;gap:16px}.exam-card[data-v-34d14af3]{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 15px #0000001a}.exam-header[data-v-34d14af3]{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.exam-type[data-v-34d14af3]{display:inline-block;padding:4px 10px;background:#c6f6d5;color:#22543d;border-radius:6px;font-size:12px;font-weight:500;margin-right:12px}.course-name[data-v-34d14af3]{font-size:18px;font-weight:600;color:#1f2937}.exam-details[data-v-34d14af3]{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.detail-item[data-v-34d14af3]{display:flex;align-items:center;gap:8px;color:#4b5563;font-size:14px}.detail-item .icon[data-v-34d14af3]{font-size:16px}@media(max-width:640px){.exam-details[data-v-34d14af3]{grid-template-columns:1fr}.semester-selector[data-v-34d14af3]{flex-direction:column;align-items:flex-start}.semester-selector select[data-v-34d14af3]{width:100%}}.ranking-view[data-v-c51277cf]{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.view-header[data-v-c51277cf]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#fffffff2;border-radius:16px;box-shadow:0 4px 20px #0000001a;margin-bottom:16px}.view-header h1[data-v-c51277cf]{font-size:20px;margin:0;color:#1f2937}.back-btn[data-v-c51277cf],.logout-btn[data-v-c51277cf]{padding:8px 16px;border-radius:8px;border:none;cursor:pointer;font-size:14px;transition:all .2s}.back-btn[data-v-c51277cf]{background:#f0f4ff;color:#667eea}.back-btn[data-v-c51277cf]:hover{background:#667eea;color:#fff}.logout-btn[data-v-c51277cf]{background:#fee2e2;color:#dc2626}.logout-btn[data-v-c51277cf]:hover{background:#dc2626;color:#fff}.semester-selector[data-v-c51277cf]{background:#fffffff2;padding:16px 24px;border-radius:12px;margin-bottom:16px;display:flex;align-items:center;gap:12px}.semester-selector .label[data-v-c51277cf]{font-weight:500;color:#374151}.semester-selector select[data-v-c51277cf]{padding:10px 16px;border-radius:8px;border:2px solid #e5e7eb;font-size:14px;min-width:160px;cursor:pointer}.semester-selector select[data-v-c51277cf]:focus{outline:none;border-color:#667eea}.search-btn[data-v-c51277cf]{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:transform .2s}.search-btn[data-v-c51277cf]:hover{transform:scale(1.02)}.view-content[data-v-c51277cf]{max-width:900px;margin:0 auto}.loading-state[data-v-c51277cf],.error-state[data-v-c51277cf],.empty-state[data-v-c51277cf]{text-align:center;padding:60px 20px;background:#fff;border-radius:20px;color:#374151}.spinner[data-v-c51277cf]{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin-c51277cf 1s linear infinite;margin:0 auto 16px}@keyframes spin-c51277cf{to{transform:rotate(360deg)}}.error-icon[data-v-c51277cf],.empty-icon[data-v-c51277cf]{font-size:48px;margin-bottom:16px}.error-state button[data-v-c51277cf]{margin-top:16px;padding:10px 24px;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer}.hint[data-v-c51277cf]{font-size:14px;color:#9ca3af;margin-top:8px}.ranking-card[data-v-c51277cf]{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 20px #0000001a}.student-info[data-v-c51277cf]{padding:24px;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-bottom:1px solid #c7d2fe}.info-row[data-v-c51277cf]{display:flex;flex-wrap:wrap;gap:24px;margin-bottom:12px}.info-row[data-v-c51277cf]:last-child{margin-bottom:0}.info-row.highlight[data-v-c51277cf]{margin-top:16px;padding-top:16px;border-top:1px dashed #a5b4fc}.info-item[data-v-c51277cf]{font-size:15px;color:#374151}.info-item strong[data-v-c51277cf]{color:#1e40af}.info-item .score[data-v-c51277cf]{font-size:18px;font-weight:700;color:#7c3aed}.info-item .gpa-badge[data-v-c51277cf]{display:inline-block;padding:6px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-size:20px;font-weight:800;box-shadow:0 4px 12px #667eea66;margin-left:4px}.ranking-table-wrapper[data-v-c51277cf]{padding:24px;overflow-x:auto}.ranking-table[data-v-c51277cf]{width:100%;border-collapse:collapse;text-align:center}.ranking-table th[data-v-c51277cf]{background:#3b82f6;color:#fff;padding:14px 16px;font-weight:600;font-size:14px}.ranking-table th[data-v-c51277cf]:first-child{border-radius:8px 0 0}.ranking-table th[data-v-c51277cf]:last-child{border-radius:0 8px 0 0}.ranking-table td[data-v-c51277cf]{padding:16px;border-bottom:1px solid #e5e7eb}.method-name[data-v-c51277cf]{text-align:left;font-weight:500;color:#374151;background:#f9fafb}.method-name.bold[data-v-c51277cf]{font-weight:700;color:#1f2937}.rank-cell[data-v-c51277cf]{font-size:16px}.rank-value[data-v-c51277cf]{display:inline-block;padding:6px 12px;background:#f0f9ff;color:#0369a1;border-radius:6px;font-weight:500}.rank-value.highlight-rank[data-v-c51277cf]{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;font-weight:700;border:2px solid #fcd34d}.class-highlight[data-v-c51277cf]{padding:20px 24px;background:linear-gradient(135deg,#fef3c7,#fde68a);display:flex;justify-content:center}.highlight-badge[data-v-c51277cf]{font-size:18px;font-weight:600;color:#92400e}.big-rank[data-v-c51277cf]{font-size:32px;font-weight:800;color:#d97706;margin:0 4px}@media(max-width:640px){.info-row[data-v-c51277cf]{flex-direction:column;gap:8px}.semester-selector[data-v-c51277cf]{flex-direction:column;align-items:flex-start;gap:12px}.semester-selector select[data-v-c51277cf],.search-btn[data-v-c51277cf]{width:100%}.ranking-table th[data-v-c51277cf],.ranking-table td[data-v-c51277cf]{padding:10px 8px;font-size:13px}.rank-value[data-v-c51277cf]{padding:4px 8px;font-size:13px}.big-rank[data-v-c51277cf]{font-size:24px}}.fade-enter-active[data-v-19707e92],.fade-leave-active[data-v-19707e92]{transition:opacity .3s ease}.fade-enter-from[data-v-19707e92],.fade-leave-to[data-v-19707e92]{opacity:0}.coming-soon-page[data-v-19707e92]{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}.coming-soon-content[data-v-19707e92]{text-align:center;color:#fff}.coming-soon-content .emoji[data-v-19707e92]{font-size:80px;margin-bottom:20px}.coming-soon-content h2[data-v-19707e92]{font-size:28px;margin-bottom:12px}.coming-soon-content p[data-v-19707e92]{opacity:.8;margin-bottom:24px}.coming-soon-content button[data-v-19707e92]{padding:12px 32px;background:#fff;color:#667eea;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s}.coming-soon-content button[data-v-19707e92]:hover{transform:scale(1.05)}
