: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}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-eebd9d2d]{max-width:420px;margin:0 auto;text-align:center;padding:40px;min-height:calc(100vh - 4rem);display:flex;flex-direction:column;justify-content:center}.logo[data-v-eebd9d2d]{font-size:60px;margin-bottom:10px}h2[data-v-eebd9d2d]{margin:0 0 20px;font-size:28px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.mode-switch[data-v-eebd9d2d]{display:flex;background:#f3f4f6;padding:5px;border-radius:12px;margin-bottom:25px}.mode-btn[data-v-eebd9d2d]{flex:1;padding:10px;border:none;background:transparent;border-radius:8px;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .3s ease}.mode-btn.active[data-v-eebd9d2d]{background:#fff;color:#667eea;box-shadow:0 2px 10px #0000000d}.progress-section[data-v-eebd9d2d]{padding:20px 0}.timeline[data-v-eebd9d2d]{display:flex;justify-content:space-between;margin-bottom:20px;position:relative}.timeline[data-v-eebd9d2d]:before{content:"";position:absolute;top:20px;left:10%;right:10%;height:2px;background:#e5e7eb;z-index:0}.timeline-step[data-v-eebd9d2d]{display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}.step-icon[data-v-eebd9d2d]{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#f3f4f6;font-size:16px;margin-bottom:8px;transition:all .3s ease}.timeline-step.done .step-icon[data-v-eebd9d2d]{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.timeline-step.active .step-icon[data-v-eebd9d2d]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;animation:pulse-eebd9d2d 1.5s infinite}.timeline-step.error .step-icon[data-v-eebd9d2d]{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}@keyframes pulse-eebd9d2d{0%,to{box-shadow:0 0 #667eea66}50%{box-shadow:0 0 0 10px #667eea00}}.step-label[data-v-eebd9d2d]{font-size:11px;color:#9ca3af}.timeline-step.done .step-label[data-v-eebd9d2d],.timeline-step.active .step-label[data-v-eebd9d2d]{color:#374151;font-weight:500}.spinner-small[data-v-eebd9d2d]{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-eebd9d2d 1s linear infinite}@keyframes spin-eebd9d2d{to{transform:rotate(360deg)}}.status-message[data-v-eebd9d2d]{font-size:14px;color:#667eea;font-weight:500;padding:15px;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:12px;margin-bottom:20px}.form-group[data-v-eebd9d2d]{text-align:left;margin-bottom:1.2rem}.form-group label[data-v-eebd9d2d]{display:block;margin-bottom:8px;font-weight:600;color:#374151}.form-group input[data-v-eebd9d2d]{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;transition:all .3s ease;box-sizing:border-box}.form-group input[data-v-eebd9d2d]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.btn[data-v-eebd9d2d]{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn[data-v-eebd9d2d]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}.btn[data-v-eebd9d2d]:disabled{opacity:.7;cursor:not-allowed}.btn.secondary[data-v-eebd9d2d]{background:#f3f4f6;color:#374151}.btn-group[data-v-eebd9d2d]{display:flex;gap:15px}.footer[data-v-eebd9d2d]{margin-top:25px;font-size:13px;color:#9ca3af}.remember-row[data-v-eebd9d2d]{display:flex;justify-content:flex-start;margin-bottom:20px}.checkbox-label[data-v-eebd9d2d]{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#6b7280}.checkbox-label input[type=checkbox][data-v-eebd9d2d]{width:18px;height:18px;accent-color:#667eea;cursor:pointer}.captcha-display[data-v-eebd9d2d]{display:flex;justify-content:center;align-items:center;gap:15px;margin-bottom:20px;padding:15px;background:#f9fafb;border-radius:12px}.captcha-img[data-v-eebd9d2d]{height:40px;border-radius:6px;cursor:pointer}.refresh-btn[data-v-eebd9d2d]{background:none;border:none;font-size:20px;cursor:pointer;color:#6b7280;transition:transform .3s ease}.refresh-btn[data-v-eebd9d2d]:hover{transform:rotate(180deg);color:#667eea}.captcha-input[data-v-eebd9d2d]{text-align:center;letter-spacing:5px;font-weight:700}.ai-hint[data-v-eebd9d2d]{font-size:12px;color:#10b981;margin-top:5px;text-align:right}.subtitle[data-v-eebd9d2d]{color:#667eea;font-size:14px;margin:0 0 20px;font-weight:500}@media(max-width:768px){.login-container[data-v-eebd9d2d]{max-width:100%;padding:60px 20px 30px;min-height:auto;justify-content:flex-start}.logo[data-v-eebd9d2d]{font-size:48px}h2[data-v-eebd9d2d]{font-size:22px}.timeline[data-v-eebd9d2d]{gap:8px}.timeline[data-v-eebd9d2d]:before{left:5%;right:5%}.step-icon[data-v-eebd9d2d]{width:32px;height:32px;font-size:14px}.step-label[data-v-eebd9d2d]{font-size:11px}}@media(max-width:480px){.login-container[data-v-eebd9d2d]{padding:20px 15px;border-radius:0}.captcha-display[data-v-eebd9d2d]{flex-direction:column;gap:10px}.captcha-img[data-v-eebd9d2d]{height:50px}}.dashboard[data-v-8781f81b]{max-width:1200px;margin:0 auto;padding:20px}.header[data-v-8781f81b]{display:flex;flex-direction:column;margin-bottom:30px;padding:20px 30px}.header h2[data-v-8781f81b]{margin:0 0 10px;font-size:24px}.header-row[data-v-8781f81b]{display:flex;justify-content:space-between;align-items:center}.stats[data-v-8781f81b]{display:flex;gap:20px;font-size:14px;color:#666}.stat strong[data-v-8781f81b]{color:#4338ca}.term-section[data-v-8781f81b]{margin-bottom:40px}.term-title[data-v-8781f81b]{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #e5e7eb}.term-icon[data-v-8781f81b]{font-size:24px}.term-count[data-v-8781f81b]{font-size:14px;font-weight:400;color:#9ca3af;margin-left:auto}.grades-grid[data-v-8781f81b]{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}.grade-card[data-v-8781f81b]{padding:20px;cursor:pointer;transition:all .3s ease;border-radius:16px}.grade-card[data-v-8781f81b]:hover{transform:translateY(-5px);box-shadow:0 15px 40px #00000026}.course-name[data-v-8781f81b]{margin:0 0 15px;font-size:15px;font-weight:600;color:#374151;line-height:1.3}.score[data-v-8781f81b]{font-size:42px;font-weight:700;margin:10px 0;text-align:center}.score.excellent[data-v-8781f81b]{color:#059669}.score.good[data-v-8781f81b]{color:#3b82f6}.score.pass[data-v-8781f81b]{color:#f59e0b}.score.fail[data-v-8781f81b]{color:#ef4444}.score.text[data-v-8781f81b]{color:#6b7280}.meta[data-v-8781f81b]{display:flex;justify-content:space-between;font-size:12px;color:#9ca3af;margin-top:10px}.modal-backdrop[data-v-8781f81b]{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal[data-v-8781f81b]{width:90%;max-width:600px;max-height:85vh;overflow-y:auto;background:#fff;border-radius:20px;padding:0}.modal-header[data-v-8781f81b]{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #e5e7eb}.modal-header h3[data-v-8781f81b]{margin:0;font-size:20px}.close-btn[data-v-8781f81b]{background:none;border:none;font-size:28px;color:#9ca3af;cursor:pointer;line-height:1}.close-btn[data-v-8781f81b]:hover{color:#374151}.modal-body[data-v-8781f81b]{padding:25px}.score-display[data-v-8781f81b]{font-size:56px;font-weight:700;text-align:center;margin-bottom:25px}.detail-grid[data-v-8781f81b]{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.detail-item[data-v-8781f81b]{padding:12px 15px;background:#f9fafb;border-radius:10px}.detail-item.full-width[data-v-8781f81b]{grid-column:span 2}.detail-item label[data-v-8781f81b]{display:block;font-size:12px;color:#9ca3af;margin-bottom:5px}.detail-item span[data-v-8781f81b]{font-size:14px;font-weight:500;color:#374151}.btn.small[data-v-8781f81b]{padding:10px 20px;font-size:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;cursor:pointer}.modal-enter-active[data-v-8781f81b],.modal-leave-active[data-v-8781f81b]{transition:all .3s ease}.modal-enter-from[data-v-8781f81b],.modal-leave-to[data-v-8781f81b]{opacity:0}.modal-enter-from .modal[data-v-8781f81b],.modal-leave-to .modal[data-v-8781f81b]{transform:scale(.9)}@media(max-width:768px){.dashboard[data-v-8781f81b]{padding:10px}.header.glass-card[data-v-8781f81b]{flex-direction:column;padding:10px 12px!important;margin-bottom:10px}.header h2[data-v-8781f81b]{font-size:14px;margin:0 0 6px;text-align:center}.header-row[data-v-8781f81b]{width:100%}.stats[data-v-8781f81b]{gap:8px;font-size:11px}.btn.small[data-v-8781f81b]{padding:6px 10px;font-size:11px;white-space:nowrap}.grades-grid[data-v-8781f81b]{grid-template-columns:repeat(2,1fr);gap:12px;align-items:start}.grade-card[data-v-8781f81b]{padding:15px;height:auto;min-height:unset}.course-name[data-v-8781f81b]{font-size:13px;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;min-height:36px}.score[data-v-8781f81b]{font-size:32px;margin:8px 0}.meta[data-v-8781f81b]{flex-direction:column;gap:2px;font-size:11px;margin-top:8px}.modal[data-v-8781f81b]{width:95%;max-height:90vh;margin:10px}.detail-grid[data-v-8781f81b]{grid-template-columns:1fr}.detail-item.full-width[data-v-8781f81b]{grid-column:span 1}.btn.small[data-v-8781f81b]{width:100%}}@media(max-width:480px){.grades-grid[data-v-8781f81b]{grid-template-columns:repeat(2,1fr);gap:8px}.grade-card[data-v-8781f81b]{padding:12px}.course-name[data-v-8781f81b]{font-size:12px;min-height:32px}.score[data-v-8781f81b]{font-size:26px;margin:6px 0}.term-title[data-v-8781f81b]{font-size:16px}.score-display[data-v-8781f81b]{font-size:48px}}.fade-enter-active[data-v-bca75e4c],.fade-leave-active[data-v-bca75e4c]{transition:opacity .3s ease}.fade-enter-from[data-v-bca75e4c],.fade-leave-to[data-v-bca75e4c]{opacity:0}
