:root{--primary-50: #fffbeb;--primary-100: #fef3c7;--primary-200: #fde68a;--primary-300: #fcd34d;--primary-400: #fbbf24;--primary-500: #f59e0b;--primary-600: #d97706;--primary-700: #b45309;--primary-800: #92400e;--primary-900: #78350f;--success-500: #16a34a;--success-600: #15803d;--warning-500: #ea580c;--warning-600: #c2410c;--error-500: #dc2626;--error-600: #b91c1c;--gray-50: #fafaf9;--gray-100: #f5f5f4;--gray-200: #e7e5e4;--gray-300: #d6d3d1;--gray-400: #a8a29e;--gray-500: #78716c;--gray-600: #57534e;--gray-700: #44403c;--gray-800: #292524;--gray-900: #1c1917;--gradient-primary: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);--gradient-success: linear-gradient(135deg, #16a34a 0%, #15803d 100%);--gradient-dark: linear-gradient(135deg, #44403c 0%, #292524 100%);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--gray-50);color:var(--gray-800);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--primary-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-700)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-normal)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background:#fff;color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover{background:var(--gray-50);border-color:var(--gray-400)}.btn-success{background:var(--gradient-success);color:#fff}.btn-danger{background:var(--error-500);color:#fff}.btn-danger:hover{background:var(--error-600)}.card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{padding:1.5rem;border-bottom:1px solid var(--gray-100)}.card-body{padding:1.5rem}.input{width:100%;padding:.75rem 1rem;font-size:1rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);transition:all var(--transition-fast);background:#fff}.input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #0066ff1a}.textarea{width:100%;padding:1rem;font-size:1rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);resize:vertical;min-height:200px;font-family:inherit;line-height:1.8;transition:all var(--transition-fast)}.textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #0066ff1a}.tag{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:500;border-radius:9999px;background:var(--gray-100);color:var(--gray-700)}.tag-primary{background:var(--primary-50);color:var(--primary-700)}.tag-success{background:#10b9811a;color:var(--success-600)}.tag-warning{background:#f59e0b1a;color:var(--warning-600)}.tag-error{background:#ef44441a;color:var(--error-600)}.progress{width:100%;height:8px;background:var(--gray-200);border-radius:9999px;overflow:hidden}.progress-bar{height:100%;background:var(--gradient-primary);border-radius:9999px;transition:width var(--transition-slow)}.progress-bar.success{background:var(--gradient-success)}.highlight-hit{background:linear-gradient(120deg,#10b98133,#10b9814d);padding:.1rem .3rem;border-radius:var(--radius-sm);border-bottom:2px solid var(--success-500)}.highlight-miss{background:linear-gradient(120deg,#ef44441a,#ef444433);padding:.1rem .3rem;border-radius:var(--radius-sm);border-bottom:2px dashed var(--error-500)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .5s ease forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}@media(min-width:640px){.container{padding:0 1.5rem}}@media(min-width:1024px){.container{padding:0 2rem}}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.text-4xl{font-size:2.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-gray-700{color:var(--gray-700)}.text-primary{color:var(--primary-600)}.text-success{color:var(--success-600)}.text-error{color:var(--error-600)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.progress-fill-global{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-400));border-radius:4px;transition:width .3s ease;position:relative;overflow:hidden}.progress-fill-global:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#fff0,#ffffff4d,#fff0);animation:shimmer-global 1.5s infinite}@keyframes shimmer-global{0%{transform:translate(-100%)}to{transform:translate(100%)}}.header{position:fixed;top:0;left:0;right:0;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;background:#fff;border-bottom:1px solid var(--gray-200);z-index:100}.header-brand{display:flex;align-items:center;gap:.75rem}.logo{display:flex;align-items:center;justify-content:center}.brand-name{font-size:1.375rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-tagline{font-size:.8125rem;color:var(--gray-500);padding-left:.75rem;border-left:1px solid var(--gray-300)}.header-nav{display:flex;gap:2rem}.nav-link{font-size:.9375rem;font-weight:500;color:var(--gray-600);transition:color var(--transition-fast);position:relative}.nav-link:hover,.nav-link.active{color:var(--primary-600)}.nav-link.active:after{content:"";position:absolute;bottom:-22px;left:0;right:0;height:2px;background:var(--primary-600);border-radius:1px}.btn-sm{padding:.5rem 1rem;font-size:.875rem}@media(max-width:768px){.header-nav,.brand-tagline{display:none}.header{padding:0 1rem}}.sidebar{position:fixed;top:64px;left:0;width:260px;height:calc(100vh - 64px);background:#fff;border-right:1px solid var(--gray-200);display:flex;flex-direction:column;z-index:50}.sidebar-menu{flex:1;padding:1.5rem;overflow-y:auto}.menu-section{margin-bottom:2rem}.menu-title{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--gray-400);letter-spacing:.05em;margin-bottom:.75rem}.menu-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.menu-title-row .menu-title{margin-bottom:0}.history-arrow{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:6px;color:var(--gray-600);font-size:.875rem;cursor:pointer;transition:all .2s}.history-arrow:hover{background:var(--primary-100);color:var(--primary-600)}.menu-list{display:flex;flex-direction:column;gap:.25rem}.menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;border:none;background:transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left}.menu-item:hover{background:var(--gray-50)}.menu-item.active{background:var(--primary-50)}.menu-item.active .menu-label{color:var(--primary-700);font-weight:600}.menu-icon{font-size:1.25rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border-radius:var(--radius-md)}.menu-item.active .menu-icon{background:var(--primary-100)}.menu-text{display:flex;flex-direction:column}.menu-label{font-size:.9375rem;font-weight:500;color:var(--gray-800)}.menu-desc{font-size:.75rem;color:var(--gray-500)}.stats-card{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;padding:1rem;background:var(--gray-50);border-radius:var(--radius-lg)}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-value{font-size:1.25rem;font-weight:700;color:var(--primary-600)}.stat-label{font-size:.6875rem;color:var(--gray-500)}.quick-links{display:flex;flex-direction:column;gap:.5rem}.quick-link{display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;font-size:.875rem;color:var(--gray-600);border-radius:var(--radius-md);transition:all var(--transition-fast)}.quick-link:hover{background:var(--gray-50);color:var(--gray-800)}.history-list{display:flex;flex-direction:column;gap:.5rem}.history-item{background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-md);padding:.625rem .75rem;display:flex;align-items:center;gap:.5rem;transition:background var(--transition-fast)}.history-item:hover{background:var(--gray-50)}.history-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.history-title{font-size:.8125rem;font-weight:500;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-date{font-size:.6875rem;color:var(--gray-400)}.history-status{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem;min-width:60px}.status-score{font-size:.875rem;font-weight:700;color:var(--primary-600)}.status-error{font-size:.6875rem;font-weight:500;color:#dc2626}.status-progress{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.mini-progress-bar{width:50px;height:4px;background:var(--gray-100);border-radius:2px;overflow:hidden}.mini-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-400),var(--primary-600));border-radius:2px;transition:width .3s ease;animation:miniShimmer 1.5s infinite;background-size:200% 100%}@keyframes miniShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.status-pending{font-size:.625rem;color:var(--gray-500)}.btn-view{padding:.25rem .5rem;font-size:.6875rem;font-weight:600;color:var(--primary-600);background:var(--primary-50);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.history-empty,.history-loading{font-size:.75rem;color:var(--gray-400);text-align:center;padding:1rem 0}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid var(--gray-100)}.pro-banner{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--gradient-primary);border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--transition-fast)}.pro-banner:hover{transform:translateY(-2px)}.pro-icon{font-size:1.5rem}.pro-text{display:flex;flex-direction:column}.pro-title{font-size:.875rem;font-weight:600;color:#fff}.pro-desc{font-size:.6875rem;color:#fffc}@media(max-width:1024px){.sidebar{display:none}}.mobile-navbar{position:fixed;bottom:0;left:0;width:100%;height:60px;background:#fff;display:flex;justify-content:space-around;align-items:center;border-top:1px solid #e0e0e0;padding-bottom:env(safe-area-inset-bottom);z-index:1000;box-shadow:0 -2px 10px #0000000d}.mobile-nav-item{background:none;border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px 8px;color:#999;flex:1;cursor:pointer;-webkit-tap-highlight-color:transparent}.mobile-nav-item.active{color:#06f}.mobile-nav-icon{font-size:20px;margin-bottom:2px}.mobile-nav-label{font-size:10px;font-weight:500}.mobile-layout{display:flex;flex-direction:column;height:100vh;background-color:#f5f7fa;overflow:hidden}.mobile-header{height:48px;background:#fff;display:flex;align-items:center;justify-content:center;border-bottom:1px solid #eee;flex-shrink:0;padding:0 16px;font-weight:600;color:#333}.mobile-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 12px 80px}.mobile-content .exam-list-page{padding:0}.mobile-content .exam-card{margin-bottom:12px}.exam-list-mobile{padding-bottom:20px}.mobile-page-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem;color:#1a1a1a}.mobile-years-container{display:flex;flex-direction:column;gap:12px}.mobile-year-section{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.mobile-year-header{padding:12px 16px;background:#f8f9fa;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer}.mobile-year-badge{font-size:16px;font-weight:600;color:#333}.mobile-expand-icon{font-size:12px;color:#999}.mobile-exams-list{padding:0}.mobile-exam-card{padding:16px;border-bottom:1px solid #f0f0f0;opacity:.7;cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,.05)}.mobile-exam-card:last-child{border-bottom:none}.mobile-card-top{display:flex;gap:12px;margin-bottom:12px}.mobile-exam-icon{font-size:24px;width:40px;height:40px;background:#f0f7ff;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-exam-info{flex:1}.mobile-exam-name{font-size:15px;font-weight:600;color:#333;margin-bottom:6px;line-height:1.4}.mobile-exam-tags{display:flex;gap:6px;flex-wrap:wrap}.mobile-tag{font-size:10px;padding:2px 6px;border-radius:4px;color:#fff;font-weight:500}.badge-national{background:#d93025}.badge-provincial{background:#1a73e8}.badge-institution{background:#188038}.badge-other{background:#5f6368}.level-tag{background:#fbbc04;color:#333}.mobile-card-bottom{display:flex;align-items:center;font-size:12px;color:#666;margin-top:8px}.mobile-divider{margin:0 8px;color:#ddd}.mobile-start-btn{margin-left:auto;padding:4px 12px;background:#e8f0fe;color:#1a73e8;border:none;border-radius:12px;font-size:12px;font-weight:600}.mobile-loading-state,.mobile-error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 0;color:#666}.mobile-spinner{width:24px;height:24px;border:2px solid #f3f3f3;border-top:2px solid #1a73e8;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.mobile-retry-btn{margin-top:12px;padding:8px 16px;background:#1a73e8;color:#fff;border:none;border-radius:6px}.exam-detail-mobile{padding-bottom:24px}.m-detail-header{margin-bottom:20px;background:#fff;padding:16px;border-radius:12px;box-shadow:0 1px 3px #0000000d}.m-back-btn{border:none;background:none;padding:0;margin-bottom:12px;color:#666;font-size:14px;display:flex;align-items:center}.m-exam-title{font-size:18px;font-weight:700;color:#202124;line-height:1.4;margin-bottom:12px}.m-exam-meta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.m-meta-badge{font-size:11px;padding:2px 8px;border-radius:4px;font-weight:500}.m-meta-badge.year{background:#e8f0fe;color:#1967d2}.m-meta-badge.type{background:#fce8e6;color:#c5221f}.m-meta-text{font-size:12px;color:#5f6368;margin-left:auto}.m-questions-list{display:flex;flex-direction:column;gap:12px}.m-section-title{font-size:15px;font-weight:600;color:#5f6368;margin-bottom:4px;margin-left:4px}.m-question-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 2px #0000001a;border:1px solid #f1f3f4;opacity:.8;cursor:pointer;transition:transform .1s}.m-question-card:active{transform:scale(.98);background:#f8f9fa}.m-q-card-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.m-q-num{background:#3c4043;color:#fff;font-size:11px;padding:2px 6px;border-radius:4px;font-weight:700}.m-q-type{font-size:11px;padding:2px 6px;border-radius:4px;font-weight:500}.type-summary{background:#e8f0fe;color:#1967d2}.type-analysis{background:#fef7e0;color:#ea8600}.type-solution{background:#e6f4ea;color:#137333}.type-execution{background:#e8eaed;color:#3c4043}.type-essay{background:#fce8e6;color:#c5221f}.m-q-score{font-size:12px;color:#5f6368;margin-left:auto;font-weight:500}.m-q-title{font-size:16px;font-weight:600;color:#202124;line-height:1.5;margin-bottom:16px;word-break:break-word;white-space:normal;overflow-wrap:break-word}.m-q-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid #f1f3f4;padding-top:12px}.m-q-limit{font-size:12px;color:#80868b}.m-start-btn{background:#1a73e8;color:#fff;border:none;padding:6px 16px;border-radius:16px;font-size:13px;font-weight:500}.mobile-back-text-btn{margin-top:16px;background:none;border:none;color:#1a73e8;font-size:14px;text-decoration:underline}.report-mobile{min-height:100vh;background:#f8f9fa;padding-bottom:80px}.m-report-header{background:#fff;padding:16px;margin-bottom:12px}.m-nav-back{border:none;background:none;padding:0;font-size:14px;color:#5f6368;margin-bottom:16px}.m-score-card{display:flex;align-items:center;gap:24px}.m-score-circle{position:relative;width:80px;height:80px;flex-shrink:0}.m-circular-chart{display:block;margin:0 auto;max-width:100%;max-height:100%}.m-circle-bg{fill:none;stroke:#eee;stroke-width:2.5}.m-circle{fill:none;stroke-width:2.5;stroke-linecap:round;animation:progress 1s ease-out forwards;transition:all .5s}@keyframes progress{0%{stroke-dasharray:0 100}}.m-score-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;line-height:1}.m-score-val{display:block;font-size:20px;font-weight:700;color:#202124}.m-score-max{font-size:10px;color:#9aa0a6}.m-score-stats{flex:1;display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.m-stat-item{display:flex;flex-direction:column;align-items:center;gap:4px}.m-stat-label{font-size:11px;color:#9aa0a6}.m-stat-val{font-size:14px;font-weight:600;color:#202124}.m-report-tabs{display:flex;background:#fff;padding:0 16px;border-bottom:1px solid #f1f3f4;position:sticky;top:0;z-index:10}.m-tab-item{flex:1;text-align:center;padding:12px 0;font-size:14px;color:#5f6368;background:none;border:none;border-bottom:2px solid transparent;transition:all .2s}.m-tab-item.active{color:#1a73e8;border-bottom-color:#1a73e8;font-weight:600}.m-report-content{padding:16px}.m-tab-pane{display:flex;flex-direction:column;gap:16px}.m-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 2px #0000000d}.m-card-title{font-size:15px;font-weight:600;margin-bottom:12px;color:#202124}.m-ai-comment{font-size:14px;line-height:1.6;color:#3c4043;background:#f8f9fa;padding:12px;border-radius:8px}.m-suggestion-list{list-style:none;padding:0}.m-suggestion-item{display:flex;gap:8px;font-size:13px;line-height:1.5;color:#5f6368;margin-bottom:10px}.m-sug-idx{background:#e8f0fe;color:#1a73e8;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;margin-top:2px}.m-user-answer{font-size:14px;line-height:1.8;color:#3c4043;white-space:pre-wrap}.m-points-list{display:flex;flex-direction:column;gap:12px}.m-point-item{display:flex;gap:12px;background:#fff;padding:14px;border-radius:12px;box-shadow:0 1px 2px #0000000d}.m-point-icon{font-size:18px;margin-top:2px}.m-point-body{flex:1}.m-point-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}.m-point-txt{font-size:14px;color:#202124;line-height:1.4;flex:1;margin-right:8px}.m-point-score{font-size:13px;font-weight:600;white-space:nowrap}.m-point-score.full{color:#10b981}.m-point-score.partial{color:#f59e0b}.m-point-score.missed{color:#ef4444}.m-point-gap{font-size:12px;color:#ef4444;background:#fef2f2;padding:4px 8px;border-radius:4px;display:inline-block}.m-hint-text{font-size:12px;color:#9aa0a6;margin-bottom:12px}.m-polish-content{font-size:15px;line-height:2;color:#3c4043}.m-deleted{color:#ef4444;text-decoration:line-through;background:#fef2f2;padding:0 2px}.m-added{color:#10b981;background:#ecfdf5;padding:0 2px;font-weight:500}.m-fixed-footer{position:fixed;bottom:0;left:0;right:0;background:#fff;padding:12px 16px;box-shadow:0 -2px 10px #0000000d;display:flex;gap:12px;z-index:100}.m-footer-btn{flex:1;padding:10px;border-radius:20px;font-size:14px;font-weight:500;border:none}.m-footer-btn.secondary{background:#f1f3f4;color:#3c4043}.m-footer-btn.primary{background:#1a73e8;color:#fff}.materials-mobile{padding-bottom:20px}.mobile-search-container{position:relative;margin-bottom:12px}.mobile-search-input{width:100%;padding:10px 12px 10px 36px;border:1px solid #eee;background:#fff;border-radius:20px;font-size:14px;outline:none}.mobile-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;color:#999}.mobile-categories-scroll{display:flex;overflow-x:auto;gap:8px;padding-bottom:4px;margin-bottom:12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.mobile-categories-scroll::-webkit-scrollbar{display:none}.mobile-category-pill{flex-shrink:0;padding:6px 16px;border-radius:16px;background:#f0f0f0;color:#666;font-size:13px;border:none;transition:all .2s}.mobile-category-pill.active{background:#e8f0fe;color:#1a73e8;font-weight:500}.mobile-daily-quote{background:linear-gradient(135deg,#e8f0fe,#d2e3fc);padding:16px;border-radius:12px;margin-bottom:16px;color:#174ea6}.quote-text{font-size:15px;font-weight:500;font-style:italic;margin:0 0 8px;line-height:1.4}.quote-author{font-size:12px;opacity:.8;display:block;text-align:right}.mobile-material-card{background:#fff;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 1px 3px #0000000d}.mobile-material-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.mobile-material-cat{font-size:10px;color:#1a73e8;background:#e8f0fe;padding:2px 6px;border-radius:4px}.mobile-fav-btn{background:none;border:none;font-size:18px;color:#ccc;padding:4px}.mobile-fav-btn.active{color:#fbbc04}.mobile-material-title{font-size:16px;font-weight:600;color:#333;margin-bottom:8px}.mobile-material-content{font-size:14px;color:#555;line-height:1.6;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.mobile-material-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid #f5f5f5;padding-top:10px}.mobile-material-source{font-size:12px;color:#999}.mobile-copy-btn{font-size:12px;color:#666;background:#f5f5f5;padding:4px 10px;border-radius:12px;border:none}.mobile-loading,.mobile-error,.mobile-empty{text-align:center;padding:40px;color:#999;font-size:14px}.history-mobile{padding-bottom:20px}.mobile-stats-row{display:flex;justify-content:space-around;background:#fff;padding:16px 0;border-radius:12px;margin-bottom:16px;box-shadow:0 1px 3px #0000000d}.mobile-stat-item{display:flex;flex-direction:column;align-items:center}.m-stat-val{font-size:20px;font-weight:700;color:#1a73e8}.m-stat-lbl{font-size:11px;color:#999;margin-top:4px}.mobile-history-list{background:#fff;border-radius:12px;overflow:hidden}.mobile-history-item{padding:16px;border-bottom:1px solid #f0f0f0;cursor:pointer}.mobile-history-item:last-child{border-bottom:none}.m-history-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.m-history-title{font-size:15px;font-weight:600;color:#333;flex:1;margin-right:12px;line-height:1.4}.m-status-tag{font-size:12px;padding:2px 8px;border-radius:10px;font-weight:600;white-space:nowrap}.m-status-tag.completed{color:#188038;background:#e6f4ea}.m-status-tag.processing,.m-status-tag.pending{color:#1a73e8;background:#e8f0fe}.m-status-tag.error{color:#d93025;background:#fce8e6}.m-history-mid{display:flex;gap:12px;font-size:12px;color:#999;margin-bottom:8px}.m-progress-bar{height:4px;background:#f0f0f0;border-radius:2px;margin:8px 0;overflow:hidden}.m-progress-fill{height:100%;background:#1a73e8;border-radius:2px;transition:width .3s}.m-history-btm{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.m-view-link{font-size:12px;color:#1a73e8}.m-delete-btn{font-size:12px;color:#ccc;background:none;border:none;padding:4px;margin-left:auto}.exam-list-page{padding:2rem;max-width:1200px;margin:0 auto}.page-header{margin-bottom:2rem}.page-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.page-subtitle{color:var(--text-secondary);font-size:1rem}.years-container{display:flex;flex-direction:column;gap:1rem}.year-section{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.year-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;cursor:pointer;transition:background .2s;background:#f8fafc!important;color:#1e293b!important;border-bottom:1px solid #e2e8f0}.year-header:hover{background:#f1f5f9!important}.year-info{display:flex;align-items:center;gap:1rem}.year-badge{font-size:1.5rem;font-weight:700}.exam-count{font-size:.9rem;opacity:.9}.expand-icon{font-size:1rem;transition:transform .2s}.year-header.expanded .expand-icon{transform:rotate(0)}.exams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;padding:1.5rem;background:#f1f5f9;border-radius:0 0 12px 12px}.exam-card{background:#fff;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .2s;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a}.exam-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border-color:var(--primary-color)}.exam-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.exam-icon{font-size:1.5rem}.exam-type-badge{font-size:.75rem;padding:.25rem .75rem;border-radius:20px;font-weight:600}.badge-national{background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff}.badge-provincial{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.badge-institution{background:linear-gradient(135deg,#059669,#047857);color:#fff}.badge-other{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.exam-badges{display:flex;gap:.375rem;flex-wrap:wrap}.exam-level-badge{font-size:.6875rem;padding:.2rem .5rem;border-radius:12px;font-weight:600}.level-provincial{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.level-county{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.exam-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;line-height:1.4}.exam-meta{display:flex;gap:1.5rem;margin-bottom:1.25rem}.meta-item{display:flex;flex-direction:column;gap:.25rem}.meta-label{font-size:.75rem;color:var(--text-muted)}.meta-value{font-size:1rem;font-weight:600;color:var(--text-primary)}.start-btn{width:100%;padding:.75rem 1rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.start-btn:hover{filter:brightness(110%);transform:scale(1.02)}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.error-icon,.empty-icon{font-size:4rem;margin-bottom:1rem}.error-text,.empty-text{color:var(--text-secondary);font-size:1rem;margin-bottom:1rem}.empty-hint{color:var(--text-muted);font-size:.875rem}.exam-detail-page{min-height:100vh;background:var(--bg-primary)}.exam-header{background:#fff;margin:2rem auto 0;max-width:1000px;padding:2.5rem;border-radius:24px;box-shadow:var(--shadow-xl);border:1px solid var(--primary-100);position:relative;overflow:hidden}.exam-header:before{content:"";position:absolute;top:0;left:0;right:0;height:8px;background:var(--gradient-primary)}.back-btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--gray-100);border:none;color:var(--text-primary);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;margin-bottom:2rem;border:1px solid var(--gray-200);transition:all .2s}.back-btn:hover{background:#fff;box-shadow:var(--shadow-sm);transform:translate(-2px);color:var(--primary-600)}.exam-title{font-size:2rem;font-weight:800;color:var(--gray-900);margin-bottom:1.5rem;line-height:1.3;letter-spacing:-.02em}.exam-badges{display:flex;gap:.75rem;flex-wrap:wrap}.badge{padding:.5rem 1rem;border-radius:9999px;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:.375rem;border:1px solid transparent}.badge-year{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-200)}.badge-type{background:#fff1f2;color:#be123c;border-color:#fecdd3}.badge-level{background:var(--gray-50);color:var(--gray-700);border-color:var(--gray-200)}.badge-score{background:#059669}.exam-content{max-width:1000px;margin:0 auto;padding:2rem}.questions-section{background:transparent;padding:0}.questions-section.full-width{width:100%}.section-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:2rem;text-align:center}.questions-list{display:flex;flex-direction:column;gap:1.5rem}.question-item{display:flex;align-items:flex-start;gap:1.5rem;padding:1.75rem;background:#fff;border-radius:16px;cursor:pointer;transition:all .3s ease;border:1px solid var(--gray-200);box-shadow:var(--shadow-sm)}.question-item:hover{background:#fff;border-color:var(--primary-color);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.questions-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm)}.section-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem}.questions-list{display:flex;flex-direction:column;gap:1rem}.question-item{display:flex;align-items:flex-start;gap:1.25rem;padding:1.25rem;background:var(--bg-secondary);border-radius:10px;cursor:pointer;transition:all .2s;border:1px solid transparent}.question-item:hover{background:var(--bg-tertiary);border-color:var(--primary-color);transform:translate(4px)}.question-number{flex-shrink:0;width:80px;padding:.5rem;background:#f1f5f9;color:#475569;border-radius:8px;font-size:.85rem;font-weight:600;text-align:center}.question-content{flex:1;min-width:0}.question-header{display:flex;gap:.75rem;margin-bottom:.5rem}.question-type{padding:.25rem .75rem;border-radius:4px;font-size:.8rem;font-weight:600}.type-summary{background:#dbeafe;color:#1d4ed8}.type-analysis{background:#fef3c7;color:#b45309}.type-solution{background:#d1fae5;color:#047857}.type-execution{background:#e0e7ff;color:#4338ca}.type-essay{background:#fce7f3;color:#be185d}.question-score{color:var(--text-secondary);font-size:.85rem}.question-title{color:var(--text-primary);font-size:1rem;line-height:1.5;margin-bottom:.5rem;word-break:break-word;white-space:normal}.question-meta{display:flex;gap:1rem}.question-meta .meta-item{font-size:.8rem;color:var(--text-muted)}.answer-btn{flex-shrink:0;padding:.75rem 1.25rem;background-color:#f59e0b;background-image:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;align-self:center;box-shadow:0 2px 4px #f59e0b4d}.answer-btn:hover{transform:scale(1.05)}.no-questions{text-align:center;padding:3rem;color:var(--text-muted)}.no-questions span{font-size:3rem;display:block;margin-bottom:1rem}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center}.loading-spinner{font-size:3rem;animation:spin 1s linear infinite}.error-icon{font-size:4rem;margin-bottom:1rem}.error-text{color:var(--text-secondary);margin-bottom:1rem}.answer-page{max-width:1400px;margin:0 auto}.answer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9375rem;color:var(--gray-600);background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.back-btn:hover{color:var(--gray-800);border-color:var(--gray-300)}.timer-section{display:flex;align-items:center;gap:1rem}.timer{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--gray-100);border-radius:var(--radius-lg)}.timer.paused{opacity:.6}.timer-value{font-size:1.25rem;font-weight:700;font-family:SF Mono,Monaco,monospace;color:var(--gray-800)}.pause-btn{padding:.5rem 1rem;font-size:.875rem;color:var(--gray-700);background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);cursor:pointer}.answer-content{display:grid;grid-template-columns:1fr 1.5fr;gap:2rem}.question-panel{background:#fff;border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-md);height:fit-content;position:sticky;top:calc(64px + 2rem)}.question-header{display:flex;gap:.75rem;margin-bottom:1.5rem}.question-badge{padding:.375rem .75rem;font-size:.8125rem;font-weight:600;color:var(--primary-700);background:var(--primary-50);border-radius:var(--radius-md)}.question-type-badge{padding:.375rem .75rem;font-size:.8125rem;font-weight:600;color:var(--success-600);background:#10b9811a;border-radius:var(--radius-md)}.question-text{font-size:1.125rem;font-weight:500;color:var(--gray-800);line-height:1.8;margin-bottom:1.5rem}.question-requirements{display:flex;gap:2rem;padding-top:1.5rem;border-top:1px solid var(--gray-100)}.requirement{display:flex;flex-direction:column;gap:.25rem}.req-label{font-size:.75rem;color:var(--gray-500)}.req-value{font-size:1rem;font-weight:600;color:var(--gray-800)}.editor-panel{background:#fff;border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-md);display:flex;flex-direction:column}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.editor-title{font-size:1.125rem;font-weight:600;color:var(--gray-800)}.word-counter{font-size:.9375rem}.word-count{font-weight:700;color:var(--primary-600)}.word-count.over-limit{color:var(--error-500)}.word-limit{color:var(--gray-500)}.editor-textarea{width:100%;min-height:480px;padding:1.5rem;font-size:1rem;line-height:2;border:2px solid var(--gray-200);border-radius:var(--radius-lg);resize:vertical;font-family:inherit;transition:all var(--transition-fast)}.editor-textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 4px #0066ff1a}.editor-textarea.over-limit{border-color:var(--error-500)}.editor-textarea.over-limit:focus{box-shadow:0 0 0 4px #ef44441a}.editor-textarea::placeholder{color:var(--gray-400)}.editor-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--gray-100)}.editor-tips{display:flex;align-items:center;gap:.5rem}.tip-text{font-size:.875rem;color:var(--gray-500)}.editor-actions{display:flex;gap:1rem}.submit-btn{min-width:140px}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:1024px){.answer-content{grid-template-columns:1fr}.question-panel{position:static}}.answer-main{display:flex;flex-direction:column;gap:1.5rem}.materials-panel{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden}.materials-panel .materials-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);cursor:pointer}.materials-panel .materials-header h3{font-size:1.1rem;font-weight:600;color:var(--gray-800);margin:0}.materials-panel .toggle-btn{font-size:.85rem;color:var(--gray-600)}.materials-panel .materials-body{padding:1.5rem;max-height:400px;overflow-y:auto;line-height:1.8}.materials-panel .materials-body p{margin-bottom:1rem;text-indent:2em;color:var(--gray-700)}.mode-switcher{display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.25rem;background:var(--gray-100);border-radius:var(--radius-lg)}.mode-btn{flex:1;padding:.75rem 1rem;font-size:.9rem;font-weight:500;color:var(--gray-600);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.mode-btn.active{color:#fff;background:var(--primary-600);box-shadow:var(--shadow-sm)}.mode-btn:hover:not(.active){color:var(--gray-800);background:var(--gray-200)}.image-upload-panel{min-height:480px;display:flex;align-items:center;justify-content:center;position:relative}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem;border:2px dashed var(--gray-300);border-radius:var(--radius-xl);cursor:pointer;transition:all .2s;width:100%}.upload-placeholder:hover{border-color:var(--primary-500);background:var(--primary-50)}.upload-icon{font-size:4rem}.upload-text{font-size:1.1rem;font-weight:500;color:var(--gray-700);margin:0}.upload-hint{font-size:.85rem;color:var(--gray-500);margin:0}.image-preview{position:relative;width:100%}.image-preview img{width:100%;max-height:450px;object-fit:contain;border-radius:var(--radius-lg);border:1px solid var(--gray-200)}.remove-image-btn{position:absolute;top:.5rem;right:.5rem;padding:.5rem 1rem;font-size:.85rem;color:#fff;background:#dc2626e6;border:none;border-radius:var(--radius-md);cursor:pointer}.upload-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#000000b3;color:#fff;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.upload-progress-content{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 2rem;text-align:center}.progress-bar-container{width:200px;height:8px;background:#fff3;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#10b981,#34d399);border-radius:4px;transition:width .3s ease}.upload-overlay.compressing .progress-bar-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.upload-overlay.uploading .progress-bar-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.upload-overlay.processing .progress-bar-fill{background:linear-gradient(90deg,#8b5cf6,#a78bfa);animation:pulse 1s ease-in-out infinite}.upload-overlay.completed{background:#10b981d9}.upload-overlay.error{background:#ef4444d9}.progress-text{font-size:1rem;font-weight:500}.progress-percent{font-size:1.5rem;font-weight:700}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.submit-section{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--gray-100)}.submit-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.submit-modal{background:#fff;border-radius:var(--radius-xl);padding:2rem;max-width:450px;width:90%;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.submit-modal .modal-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.submit-modal .modal-icon{font-size:2rem}.submit-modal .modal-icon.processing{animation:pulse 1.5s infinite}.submit-modal .modal-header h3{font-size:1.25rem;font-weight:600;color:var(--gray-900);margin:0}.submit-modal .modal-body{margin-bottom:1.5rem}.progress-container{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.progress-bar{flex:1;height:8px;background:var(--gray-100);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .5s ease-out}.progress-fill.pending,.progress-fill.processing{background:linear-gradient(90deg,var(--primary-400),var(--primary-600));animation:shimmer 1.5s infinite;background-size:200% 100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.progress-fill.completed{background:linear-gradient(90deg,#10b981,#059669)}.progress-fill.error{background:linear-gradient(90deg,#ef4444,#dc2626)}.progress-text{font-size:.875rem;font-weight:600;color:var(--gray-600);min-width:40px}.status-message{font-size:1rem;color:var(--gray-700);margin-bottom:.75rem}.hint-message{font-size:.875rem;color:var(--gray-500);background:var(--gray-50);padding:.75rem 1rem;border-radius:var(--radius-md);border-left:3px solid var(--primary-400)}.error-details{margin-top:1rem}.error-details summary{font-size:.875rem;color:var(--gray-600);cursor:pointer}.error-details pre{margin-top:.5rem;padding:.75rem;background:var(--gray-50);border-radius:var(--radius-md);font-size:.75rem;overflow-x:auto;white-space:pre-wrap;word-break:break-all;color:#dc2626}.submit-modal .modal-footer{display:flex;justify-content:flex-end}.submit-modal .modal-footer .btn{min-width:140px}.ocr-review-modal{max-width:900px;width:95%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column}.ocr-review-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-200);background:linear-gradient(135deg,#f0f9ff,#e0f2fe)}.ocr-review-modal .modal-header h3{margin:0;font-size:1.25rem;color:var(--gray-800)}.ocr-review-modal .close-btn{background:none;border:none;font-size:1.5rem;color:var(--gray-500);cursor:pointer;padding:.25rem;line-height:1}.ocr-review-modal .close-btn:hover{color:var(--gray-700)}.ocr-review-modal .modal-body{padding:1.5rem;overflow-y:auto;flex:1}.ocr-review-hint{margin:0 0 1rem;padding:.75rem 1rem;background:#fef3c7;border-radius:var(--radius-md);color:#92400e;font-size:.9rem}.ocr-review-content{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.ocr-image-preview,.ocr-text-edit{display:flex;flex-direction:column}.ocr-image-preview h4,.ocr-text-edit h4{margin:0 0 .75rem;font-size:1rem;color:var(--gray-700)}.ocr-image-preview img{width:100%;max-height:350px;object-fit:contain;border:1px solid var(--gray-200);border-radius:var(--radius-md);background:var(--gray-50)}.ocr-text-edit textarea{flex:1;min-height:300px;padding:1rem;border:2px solid var(--gray-200);border-radius:var(--radius-md);font-size:1rem;line-height:1.6;resize:none;font-family:inherit}.ocr-text-edit textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f61a}.ocr-text-stats{margin-top:.5rem;font-size:.85rem;color:var(--gray-600);display:flex;align-items:center;gap:.5rem}.edited-badge{background:#dbeafe;color:#1e40af;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.ocr-review-modal .modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;gap:1rem;background:var(--gray-50)}.ocr-review-modal .modal-footer .btn{min-width:120px}@media(max-width:768px){.ocr-review-content{grid-template-columns:1fr}.ocr-image-preview img{max-height:200px}.ocr-text-edit textarea{min-height:200px}}.grading-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#ffffffe6;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:9999;animation:fadeIn .3s ease}.grading-card{background:#fff;width:420px;padding:32px;border-radius:20px;box-shadow:0 10px 40px #0000001a;text-align:center;border:1px solid #f0f0f0;transform:translateY(0);transition:transform .3s ease}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-5px)}to{transform:translateY(0)}}.icon-wrapper{width:64px;height:64px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-size:32px}.icon-wrapper.processing{background:#e0f2fe;animation:float 3s ease-in-out infinite}.icon-wrapper.success{background:#d1fae5;color:#059669}.icon-wrapper.error{background:#fee2e2;color:#ef4444}.spinner{display:inline-block;animation:spin 3s linear infinite}.card-header h3{margin:0 0 24px;color:#1e293b;font-size:1.25rem}.progress-track{height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden;margin-bottom:16px;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:4px;transition:width .4s ease-out;position:relative}.progress-fill.completed{background:#10b981}.progress-fill.error{background:#ef4444}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#fff0,#ffffff4d,#fff0);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.status-text{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;color:#475569;min-height:24px;margin-bottom:20px}.phase-msg{font-weight:500;color:#2563eb;animation:fadeInText .5s ease}@keyframes fadeInText{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.fun-fact{background:#fffbeb;color:#b45309;font-size:.85rem;padding:12px;border-radius:8px;margin-bottom:24px;text-align:left}.card-footer{display:flex;justify-content:center;gap:12px}.btn-primary{background:#2563eb;color:#fff;border:none;padding:10px 24px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn-primary:hover{background:#1d4ed8;transform:translateY(-1px)}.btn-text{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:.9rem}.btn-text:hover{color:#64748b}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.report-page{max-width:1200px;margin:0 auto}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.report-title{font-size:1.5rem;font-weight:700;color:var(--gray-900)}.score-summary{background:#fff;border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-md);margin-bottom:2rem;display:grid;grid-template-columns:auto 1fr auto;gap:3rem;align-items:center}.score-main{display:flex;flex-direction:column;align-items:center;gap:1rem}.score-circle{width:140px;height:140px;position:relative}.score-ring{width:100%;height:100%;transform:rotate(-90deg)}.score-ring-bg{fill:none;stroke:var(--gray-200);stroke-width:8}.score-ring-progress{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dasharray 1s ease}.score-ring-progress.success{stroke:var(--success-500)}.score-ring-progress.primary{stroke:var(--primary-500)}.score-ring-progress.warning{stroke:var(--warning-500)}.score-ring-progress.error{stroke:var(--error-500)}.score-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.score-number{font-size:2.5rem;font-weight:800;color:var(--gray-900);line-height:1}.score-max{font-size:.875rem;color:var(--gray-500)}.score-info{display:flex;flex-direction:column;align-items:center;gap:.5rem}.score-percentile{font-size:.8125rem;color:var(--gray-500)}.scoring-points-mini{display:flex;flex-direction:column;gap:.5rem;max-width:320px}.point-mini{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--gray-50);border-radius:var(--radius-md);font-size:.8125rem}.point-status-badge{padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;white-space:nowrap}.point-status-badge.full{background:#10b98126;color:var(--success-600)}.point-status-badge.partial{background:#f59e0b26;color:var(--warning-600)}.point-status-badge.missed{background:#ef444426;color:var(--error-500)}.point-mini .point-score{font-weight:600;color:var(--gray-700);min-width:40px}.point-mini .score-earned{color:var(--success-600)}.point-mini .score-zero{color:var(--error-500)}.point-mini .point-text{color:var(--gray-600);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.no-points{color:var(--gray-500);font-size:.875rem;padding:1rem;text-align:center}.score-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--gray-50);border-radius:var(--radius-lg)}.stat-icon{font-size:1.5rem}.stat-content{display:flex;flex-direction:column}.stat-card .stat-value{font-size:1.125rem;font-weight:700;color:var(--gray-900)}.stat-card .stat-label{font-size:.75rem;color:var(--gray-500)}.report-tabs{display:flex;gap:.5rem;padding:.5rem;background:var(--gray-100);border-radius:var(--radius-xl);margin-bottom:2rem}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:500;color:var(--gray-600);background:transparent;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.tab-btn:hover{color:var(--gray-800)}.tab-btn.active{background:#fff;color:var(--primary-600);font-weight:600;box-shadow:var(--shadow-sm)}.report-content{background:#fff;border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-md);margin-bottom:2rem}.tab-panel{animation:fadeIn .3s ease}.feedback-card{background:var(--gray-50);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.feedback-card.success-card{background:#10b98114;border-left:4px solid var(--success-500)}.feedback-card.warning-card{background:#f59e0b14;border-left:4px solid var(--warning-500)}.feedback-title{font-size:1rem;font-weight:600;color:var(--gray-800);margin-bottom:1rem}.feedback-comment{font-size:1rem;color:var(--gray-700);line-height:1.8}.feedback-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.feedback-list{list-style:none;margin:0;padding:0}.feedback-list li{position:relative;padding-left:1.5rem;margin-bottom:.75rem;font-size:.9375rem;color:var(--gray-700)}.feedback-list li:before{content:"•";position:absolute;left:0;color:var(--gray-400);font-weight:700}.suggestion-list{list-style:none;margin:0;padding:0}.suggestion-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--gray-200)}.suggestion-item:last-child{border-bottom:none}.suggestion-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:#fff;background:var(--primary-500);border-radius:50%;flex-shrink:0}.suggestion-text{font-size:.9375rem;color:var(--gray-700);line-height:1.6}.user-answer-section{margin-top:2rem}.section-title{font-size:1rem;font-weight:600;color:var(--gray-800);margin-bottom:1rem}.user-answer-content{padding:1.5rem;background:var(--gray-50);border-radius:var(--radius-lg);font-size:.9375rem;color:var(--gray-700);line-height:2;white-space:pre-wrap}.points-overview{margin-bottom:2rem}.points-chart{padding:1.5rem;background:var(--gray-50);border-radius:var(--radius-lg)}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.chart-header h3{font-size:.9375rem;font-weight:600;color:var(--gray-800)}.hit-ratio{font-size:.875rem;font-weight:600;color:var(--primary-600)}.points-bar{display:flex;gap:4px;height:32px}.point-segment{flex:1;border-radius:var(--radius-sm);transition:transform var(--transition-fast)}.point-segment:hover{transform:scaleY(1.1)}.point-segment.hit{background:var(--success-500)}.point-segment.miss{background:var(--gray-300)}.points-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.point-card{padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--gray-200);transition:all var(--transition-fast)}.point-card.hit{border-color:#10b9814d;background:#10b9810d}.point-card.miss{border-color:#ef44444d;background:#ef44440d}.point-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.point-number{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase}.point-content{font-size:.9375rem;color:var(--gray-800);line-height:1.6;margin-bottom:.75rem}.point-score{font-size:.8125rem;font-weight:600;color:var(--gray-600)}.comparison-view{display:grid;grid-template-columns:1fr auto 1fr;gap:1.5rem;align-items:start;margin-bottom:2rem}.comparison-card{background:var(--gray-50);border-radius:var(--radius-lg);padding:1.5rem}.comparison-card.polished{background:#10b98114;border:1px solid rgba(16,185,129,.2)}.comparison-title{font-size:.9375rem;font-weight:600;color:var(--gray-800);margin-bottom:1rem}.comparison-content{font-size:.9375rem;color:var(--gray-700);line-height:1.8}.comparison-arrow{font-size:2rem;color:var(--gray-300);padding-top:3rem}.polish-tips{background:var(--gray-50);border-radius:var(--radius-lg);padding:1.5rem}.tips-title{font-size:.9375rem;font-weight:600;color:var(--gray-800);margin-bottom:1rem}.tips-list{display:flex;flex-direction:column;gap:.75rem}.tip-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fff;border-radius:var(--radius-md)}.tip-before{color:var(--gray-500);text-decoration:line-through}.tip-arrow{color:var(--gray-400)}.tip-after{color:var(--success-600);font-weight:500}.upgrade-intro{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,var(--primary-50) 0%,rgba(0,198,255,.1) 100%);border-radius:var(--radius-lg);margin-bottom:2rem}.upgrade-icon{font-size:2rem}.upgrade-text{font-size:.9375rem;color:var(--gray-700)}.upgrade-content{background:var(--gray-50);border-radius:var(--radius-lg);padding:2rem;margin-bottom:2rem}.upgrade-title{font-size:1rem;font-weight:600;color:var(--gray-800);margin-bottom:1.5rem}.upgraded-answer{font-size:1rem;color:var(--gray-800);line-height:2;white-space:pre-wrap}.upgrade-tips{padding:1.5rem;background:#f59e0b14;border-radius:var(--radius-lg);border-left:4px solid var(--warning-500)}.tips-subtitle{font-size:.9375rem;font-weight:600;color:var(--gray-800);margin-bottom:1rem}.learning-points{margin:0;padding-left:1.25rem}.learning-points li{font-size:.9375rem;color:var(--gray-700);margin-bottom:.5rem}.report-actions{display:flex;justify-content:center;gap:1rem}@media(max-width:1024px){.score-summary{grid-template-columns:1fr;gap:2rem}.feedback-grid,.comparison-view{grid-template-columns:1fr}.comparison-arrow{transform:rotate(90deg);justify-self:center;padding:0}}.progress{width:100%;height:8px;background:var(--gray-200);border-radius:9999px;overflow:hidden;margin-top:.5rem}.progress-bar{height:100%;background-color:var(--primary-500);border-radius:9999px;transition:width .5s ease}.progress-bar.success{background-color:var(--success-500)}.progress-bar.warning{background-color:var(--warning-500)}.progress-bar.error{background-color:var(--error-500)}.polish-section{background:var(--gray-50);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.polish-section.polished-version{background:#10b98114;border:1px solid rgba(16,185,129,.2)}.polish-hint{font-size:.8125rem;color:var(--gray-600);margin-bottom:1rem}.deleted-hint{color:var(--error-500);text-decoration:line-through;background:#ef44441a;padding:.125rem .25rem;border-radius:2px}.added-hint{color:var(--success-600);background:#10b98126;padding:.125rem .25rem;border-radius:2px}.polish-diff-content{background:#fff;border-radius:var(--radius-md);padding:1.25rem;border:1px solid var(--gray-200)}.diff-text{font-size:.9375rem;line-height:2;color:var(--gray-700)}.diff-sentence{display:inline}.diff-text .deleted{color:var(--error-500);text-decoration:line-through;background:#ef44441a;padding:.125rem .25rem;border-radius:2px;margin-right:.25rem}.diff-text .added{color:var(--success-600);background:#10b98126;padding:.125rem .25rem;border-radius:2px;font-weight:500}.diff-text .unchanged{color:var(--gray-700)}.no-upgrades{text-align:center;padding:2rem;color:var(--gray-500)}.no-upgrades .hint{font-size:.8125rem;margin-top:.5rem}.polished-content{font-size:.9375rem;line-height:2;color:var(--gray-800);white-space:pre-wrap}.polish-change{display:inline}.polished-content .deleted,.polish-diff-content .deleted{color:var(--error-500);text-decoration:line-through;background:#ef44441a;padding:.125rem .25rem;border-radius:2px;margin-right:.25rem}.polished-content .added,.polish-diff-content .added{color:var(--success-600);background:#10b98126;padding:.125rem .25rem;border-radius:2px;font-weight:500}.upgrade-reasons{background:var(--gray-50)}.upgrade-list{display:flex;flex-direction:column;gap:1rem}.upgrade-item{background:#fff;border-radius:var(--radius-md);padding:1rem;border:1px solid var(--gray-200)}.upgrade-row{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.upgrade-before,.upgrade-after{flex:1;display:flex;flex-direction:column;gap:.25rem}.upgrade-before .label,.upgrade-after .label{font-size:.75rem;font-weight:600;text-transform:uppercase}.upgrade-before .label{color:var(--error-500)}.upgrade-after .label{color:var(--success-600)}.upgrade-before .text{color:var(--error-600);text-decoration:line-through;background:#ef444414;padding:.5rem;border-radius:var(--radius-sm);font-size:.875rem;line-height:1.6}.upgrade-after .text{color:var(--success-700);background:#10b9811a;padding:.5rem;border-radius:var(--radius-sm);font-size:.875rem;line-height:1.6;font-weight:500}.upgrade-row .arrow{color:var(--gray-400);font-size:1.25rem;padding-top:1.5rem}.upgrade-reason{background:#fbbf241a;border-left:3px solid var(--warning-500);padding:.5rem .75rem;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.reason-label{font-weight:600;color:var(--warning-700);font-size:.8125rem}.reason-text{color:var(--gray-700);font-size:.875rem;line-height:1.5}.scoring-point-table-container{margin:20px 0;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000d;padding:20px;border:1px solid #eee}.section-title{font-size:1.1rem;color:#2c3e50;margin-bottom:16px;font-weight:600}.scoring-point-table{width:100%;border-collapse:collapse;font-size:.95rem}.scoring-point-table th{text-align:left;padding:12px 16px;background-color:#f8f9fa;color:#666;font-weight:500;border-bottom:2px solid #eee}.scoring-point-table td{padding:16px;border-bottom:1px solid #f0f0f0;vertical-align:top}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-badge.full{background-color:#e6fffa;color:#047857;border:1px solid #a7f3d0}.status-badge.partial{background-color:#fffbeb;color:#b45309;border:1px solid #fcd34d}.status-badge.missed{background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.score-cell{font-family:Roboto Mono,monospace}.score-earned{color:#047857;font-weight:700;font-size:1.1em}.score-zero{color:#ccc;font-weight:700}.score-total{color:#999;font-size:.8em;margin-left:2px}.score-row.missed .point-content{color:#999}.evidence-box{margin-bottom:8px;font-size:13px;background:#f0fff4;padding:8px;border-radius:6px;color:#2f855a;border-left:3px solid #48bb78}.missing-keywords-box{margin-top:4px;font-size:13px}.missing-keywords-box .label{color:#e53e3e;margin-right:4px;font-weight:500}.keywords-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.keyword-tag{background-color:#fff5f5;color:#c53030;border:1px solid #feb2b2;padding:2px 6px;border-radius:4px;font-size:12px}.logic-comparison-container{margin:20px 0;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000d;padding:24px;border:1px solid #eee}.logic-columns{display:flex;justify-content:space-between;align-items:stretch;gap:20px;margin-bottom:24px}.logic-column{flex:1;background:#f8fafc;border-radius:8px;padding:16px;border:1px solid #e2e8f0}.logic-column.master-logic{background:#f0fff4;border-color:#c6f6d5}.column-header{text-align:center;font-weight:600;margin-bottom:16px;color:#475569;font-size:1.05rem;display:flex;align-items:center;justify-content:center;gap:8px}.master-logic .column-header{color:#2f855a}.steps-container{display:flex;flex-direction:column;gap:12px}.logic-step{background:#fff;padding:12px;border-radius:6px;border:1px solid #cbd5e1;position:relative;display:flex;gap:10px;box-shadow:0 1px 2px #0000000d}.master-logic .logic-step{border-color:#9ae6b4;box-shadow:0 1px 2px #2f855a1a}.step-number{width:24px;height:24px;background:#e2e8f0;color:#64748b;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.master-logic .step-number{background:#c6f6d5;color:#276749}.step-content{font-size:.95rem;line-height:1.5;color:#334155}.step-arrow{text-align:center;color:#cbd5e1;font-weight:700;margin-top:-8px;margin-bottom:-8px;z-index:1}.logic-divider{display:flex;flex-direction:column;align-items:center;justify-content:center;width:40px}.divider-line{width:1px;height:100%;background:#e2e8f0}.vs-badge{background:#e2e8f0;color:#64748b;font-size:12px;font-weight:700;padding:4px;border-radius:4px;margin:10px 0}.logic-analysis-footer{border-top:1px solid #eee;padding-top:20px;display:flex;flex-direction:column;gap:16px}.analysis-block h4{margin:0 0 8px;font-size:1rem;display:flex;align-items:center;gap:8px}.analysis-block.warning h4{color:#d97706}.analysis-block.suggestion h4{color:#2563eb}.analysis-block ul{margin:0;padding-left:20px;color:#475569}.analysis-block li{margin-bottom:4px}.materials-page{max-width:1400px;margin:0 auto}.materials-layout{display:grid;grid-template-columns:260px 1fr;gap:2rem}.categories-sidebar{background:#fff;border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-sm);height:fit-content;position:sticky;top:calc(64px + 2rem)}.sidebar-title{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--gray-400);letter-spacing:.05em;margin-bottom:1rem}.category-list{display:flex;flex-direction:column;gap:.25rem;margin-bottom:2rem}.category-btn{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.75rem 1rem;font-size:.9375rem;color:var(--gray-700);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.category-btn:hover{background:var(--gray-50)}.category-btn.active{background:var(--primary-50);color:var(--primary-700);font-weight:600}.category-count{font-size:.75rem;padding:.125rem .5rem;background:var(--gray-100);border-radius:9999px;color:var(--gray-500)}.category-btn.active .category-count{background:var(--primary-100);color:var(--primary-600)}.daily-quote{padding:1.25rem;background:linear-gradient(135deg,var(--primary-50) 0%,rgba(0,198,255,.1) 100%);border-radius:var(--radius-lg)}.quote-title{font-size:.875rem;font-weight:600;color:var(--gray-800);margin-bottom:.75rem}.quote-content{font-size:.9375rem;font-style:italic;color:var(--gray-700);line-height:1.6;margin:0 0 .5rem;padding-left:.75rem;border-left:3px solid var(--primary-400)}.quote-source{font-size:.75rem;color:var(--gray-500)}.materials-main{display:flex;flex-direction:column;gap:1.5rem}.search-section{display:flex;gap:1rem}.search-section .search-box{flex:1}.header-actions{display:flex;gap:.75rem}.filter-toggle{padding:.5rem 1rem;font-size:.875rem;color:var(--gray-600);background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.filter-toggle:hover,.filter-toggle.active{color:var(--warning-600);border-color:var(--warning-500);background:#f59e0b0d}.materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.material-card{background:#fff;border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);transition:all var(--transition-normal);display:flex;flex-direction:column}.material-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.material-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.material-category{font-size:.75rem;font-weight:600;color:var(--primary-600);background:var(--primary-50);padding:.25rem .75rem;border-radius:var(--radius-md)}.favorite-btn{font-size:1.25rem;background:none;border:none;cursor:pointer;transition:transform var(--transition-fast);color:var(--gray-400)}.favorite-btn:hover{transform:scale(1.2)}.favorite-btn.active{color:var(--warning-500)}.material-title{font-size:1rem;font-weight:600;color:var(--gray-800);margin-bottom:.75rem}.material-content{font-size:.9375rem;color:var(--gray-600);line-height:1.8;flex:1;margin-bottom:1rem}.material-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--gray-100);margin-bottom:.75rem}.material-source{font-size:.75rem;color:var(--gray-500)}.material-actions{display:flex;gap:.5rem}.action-btn{padding:.375rem .75rem;font-size:.75rem;color:var(--gray-600);background:var(--gray-100);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.action-btn:hover{background:var(--gray-200);color:var(--gray-800)}.material-tags{display:flex;gap:.5rem;flex-wrap:wrap}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);color:var(--gray-600);gap:1rem}.loader{width:40px;height:40px;border:3px solid var(--primary-100);border-top-color:var(--primary-600);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-icon{font-size:2.5rem;margin-bottom:.5rem}.error-state{color:var(--error-600);border:1px solid var(--error-100);background:var(--error-50)}@media(max-width:1024px){.materials-layout{grid-template-columns:1fr}.categories-sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:1rem}.category-list{margin-bottom:0}}@media(max-width:640px){.categories-sidebar,.materials-grid{grid-template-columns:1fr}}.ai-progress-container{margin:20px 0;padding:20px;background:linear-gradient(135deg,#6366f11a,#a855f71a);border-radius:12px;border:1px solid rgba(99,102,241,.2)}.ai-progress-container h4{margin:0 0 12px;color:#6366f1;font-size:14px;display:flex;align-items:center;gap:8px}.ai-progress-container h4 span{animation:pulse 1s ease-in-out infinite}.ai-progress-bar{height:10px;background:#6366f133;border-radius:10px;overflow:hidden;position:relative}.ai-progress-bar-inner{height:100%;background:linear-gradient(90deg,#6366f1,#a855f7);border-radius:10px;transition:width .3s ease-out}.ai-progress-percent{margin-top:8px;font-size:14px;font-weight:600;color:#6366f1;text-align:center}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.ai-progress-status{margin-top:10px;font-size:13px;color:#94a3b8;text-align:center}.admin-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f172a;position:relative;overflow:hidden;font-family:Inter,system-ui,-apple-system,sans-serif}.login-background{position:absolute;width:100%;height:100%;z-index:1}.blob{position:absolute;width:500px;height:500px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);filter:blur(80px);border-radius:50%;opacity:.15;animation:move 20s infinite alternate}.blob:nth-child(2){bottom:-100px;right:-100px;background:linear-gradient(135deg,#10b981,#059669);animation-delay:-10s}@keyframes move{0%{transform:translate(0) scale(1)}to{transform:translate(100px,100px) scale(1.1)}}.admin-login-card{position:relative;z-index:2;width:100%;max-width:420px;background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:40px;box-shadow:0 25px 50px -12px #00000080}.login-header{text-align:center;margin-bottom:32px}.login-logo{font-size:40px;margin-bottom:16px}.login-header h1{font-size:28px;font-weight:800;color:#fff;margin:0;letter-spacing:-.5px}.login-header p{color:#94a3b8;margin:8px 0 0;font-size:15px}.login-body{display:flex;flex-direction:column;gap:24px}.input-group{display:flex;flex-direction:column;gap:10px}.input-group label{color:#cbd5e1;font-size:14px;font-weight:500}.input-group input{background:#0f172a99;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px 16px;color:#fff;font-size:16px;transition:all .2s}.input-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a}.login-submit-btn{background:#3b82f6;color:#fff;border:none;border-radius:12px;padding:16px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.login-submit-btn:hover{background:#2563eb;transform:translateY(-1px)}.login-submit-btn .arrow{font-size:20px;transition:transform .2s}.login-submit-btn:hover .arrow{transform:translate(4px)}.login-footer{margin-top:24px;text-align:center}.btn-link{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:14px;text-decoration:underline}.btn-link:hover{color:#fff}.admin-container{display:flex;min-height:100vh;background-color:var(--bg-color-soft, #f8fafc);color:var(--text-color, #1e293b)}.admin-sidebar{width:260px;background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar-header{padding:24px;border-bottom:1px solid #f1f5f9;display:flex;flex-direction:column;gap:16px}.header-actions{display:flex;gap:10px}.btn-text,.btn-logout{flex:1;padding:8px;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}.btn-text{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0}.btn-text:hover{background:#e2e8f0;color:#1e293b}.btn-logout{background:#fee2e2;color:#ef4444;border:1px solid #fecaca}.btn-logout:hover{background:#fecaca}.sidebar-header h2{margin:0;font-size:1.25rem;color:var(--primary-color, #2563eb);font-weight:700}.sidebar-nav{padding:16px;display:flex;flex-direction:column;gap:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border:none;background:transparent;border-radius:8px;font-size:1rem;color:#64748b;cursor:pointer;transition:all .2s;text-align:left}.nav-item:hover{background:#f1f5f9;color:var(--primary-color, #2563eb)}.nav-item.active{background:#eff6ff;color:var(--primary-color, #2563eb);font-weight:600}.admin-content{flex:1;padding:40px;overflow-y:auto}.pane-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.pane-header h1{font-size:1.875rem;font-weight:800;margin:0;color:#0f172a}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}.stat-card{background:#fff;padding:24px;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #f1f5f9}.stat-card h3{margin:0 0 12px;font-size:.875rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:2.25rem;font-weight:800;margin:0;color:var(--primary-color, #2563eb)}.table-container{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden;border:1px solid #f1f5f9}.admin-table{width:100%;border-collapse:collapse;text-align:left}.admin-table th{padding:16px 24px;background:#f8fafc;font-size:.875rem;font-weight:600;color:#64748b;border-bottom:1px solid #f1f5f9}.admin-table td{padding:16px 24px;border-bottom:1px solid #f1f5f9;font-size:.9375rem}.admin-table tr:last-child td{border-bottom:none}.title-cell{font-weight:500;color:#0f172a;max-width:400px}.category-tag{background:#e0f2fe;color:#0369a1;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.action-cell{display:flex;gap:8px}.btn-primary{background:var(--primary-color, #2563eb);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-primary:hover{opacity:.9}.btn-icon{background:#f1f5f9;border:none;padding:8px;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:#e2e8f0}.btn-icon.delete:hover{background:#fee2e2;color:#ef4444}.loading{padding:40px;text-align:center;color:#64748b}@media(max-width:768px){.admin-container{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:relative}}.admin-form-card{background:#fff;padding:32px;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #f1f5f9;max-width:800px}.admin-form-card h2{margin:0 0 24px;font-size:1.5rem;color:#0f172a}.admin-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px;flex:1}.form-row{display:flex;gap:20px}.form-group label{font-size:.875rem;font-weight:600;color:#64748b}.form-group input,.form-group select,.form-group textarea{padding:12px;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color, #2563eb)}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:12px}.btn-secondary{background:#fff;color:#64748b;border:1px solid #e2e8f0;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer}.btn-secondary:hover{background:#f8fafc}.pdf-upload-banner{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px dashed #e2e8f0;border-radius:12px;padding:24px;display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.pdf-upload-banner.mini{padding:16px;margin-bottom:24px}.banner-content h3{margin:0 0 4px;font-size:1.125rem;color:#0f172a}.banner-content h4{margin:0 0 4px;font-size:1rem;color:#0f172a}.banner-content p{margin:0;font-size:.875rem;color:#64748b}.btn-upload{background:#fff;color:#3b82f6;border:1px solid #3b82f6;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-upload:hover{background:#3b82f6;color:#fff}.btn-upload-sm{background:#fff;color:#3b82f6;border:1px solid #3b82f6;padding:6px 14px;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer}.stat-card.highlight{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.stat-card.highlight h3{color:#ffffffd9}.stat-card.highlight .stat-value{color:#fff}.stats-details{margin-top:32px;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.detail-card{background:#fff;padding:24px;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #f1f5f9}.detail-card h3{margin:0 0 16px;font-size:1rem;color:#64748b;font-weight:600}.detail-list{display:flex;flex-direction:column;gap:12px}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f1f5f9}.detail-item:last-child{border-bottom:none}.detail-item .count{font-weight:600;color:#3b82f6}.empty-state{padding:60px 40px;text-align:center;color:#94a3b8}.empty-state p:first-child{font-size:2rem;margin-bottom:8px}.badge{background:#e0f2fe;color:#0369a1;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.badge.secondary{background:#fef3c7;color:#92400e}.ai-parse-banner{background:linear-gradient(135deg,#eef2ff,#e0e7ff);border:1px solid #c7d2fe;border-radius:12px;padding:24px;display:flex;gap:16px;align-items:center;margin-bottom:24px}.banner-icon{font-size:48px}.parse-section .form-group textarea{font-family:SF Mono,Monaco,Consolas,monospace;font-size:.875rem;line-height:1.6;background:#fafbfc}.preview-section{display:flex;flex-direction:column;gap:24px}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.preview-header h2{margin:0;font-size:1.25rem;color:#0f172a}.preview-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.preview-card h3{margin:0 0 16px;font-size:.9375rem;color:#0f172a;font-weight:600}.preview-card textarea{width:100%;font-family:inherit;font-size:.875rem;resize:vertical}.info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.info-grid .info-item.wide{grid-column:span 4}.info-item{display:flex;flex-direction:column;gap:6px}.info-item label{font-size:.75rem;color:#64748b;font-weight:600}.info-item input,.info-item select{padding:10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.9375rem;background:#fff}.questions-preview{display:flex;flex-direction:column;gap:12px}.question-preview-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.q-header{display:flex;gap:12px;align-items:center;margin-bottom:8px}.q-number{font-weight:700;color:#3b82f6}.q-type{background:#fef3c7;color:#92400e;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.q-score{color:#059669;font-weight:600;font-size:.875rem}.q-limit{color:#64748b;font-size:.75rem}.q-title{margin:0;color:#374151;font-size:.9375rem;line-height:1.5}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.parse-options{display:flex;flex-direction:column;gap:24px}.pdf-upload-box{border:2px dashed #cbd5e1;border-radius:12px;padding:32px;display:flex;flex-direction:column;align-items:center;gap:12px;background:#f8fafc;transition:all .2s}.pdf-upload-box:hover{border-color:#3b82f6;background:#eff6ff}.btn-upload-lg{background:#fff;color:#3b82f6;border:1px solid #3b82f6;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 1px 2px #0000000d;transition:all .2s}.btn-upload-lg:hover{background:#3b82f6;color:#fff;transform:translateY(-1px);box-shadow:0 4px 6px -1px #3b82f633}.btn-upload-lg.disabled{opacity:.6;cursor:not-allowed;background:#e2e8f0;border-color:#cbd5e1;color:#64748b}.hint{margin:0;font-size:.875rem;color:#94a3b8}.divider{display:flex;align-items:center;gap:16px;color:#94a3b8;font-size:.875rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.pane-header .subtitle{margin:4px 0 0;font-size:.875rem;color:#64748b}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px}.stat-card{background:#fff;padding:24px;border-radius:16px;box-shadow:0 1px 2px #0000000d;border:1px solid #f1f5f9;display:flex;align-items:center;gap:16px;transition:transform .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.stat-icon{width:56px;height:56px;border-radius:12px;font-size:24px;display:flex;align-items:center;justify-content:center}.stat-card.blue .stat-icon{background:#eff6ff;color:#3b82f6}.stat-card.green .stat-icon{background:#f0fdf4;color:#22c55e}.stat-card.purple .stat-icon{background:#faf5ff;color:#a855f7}.stat-card.orange .stat-icon{background:#fff7ed;color:#f97316}.stat-info{display:flex;flex-direction:column}.stat-info h3{margin:0;font-size:.875rem;color:#64748b;font-weight:500}.stat-info .stat-value{font-size:1.5rem;font-weight:800;color:#0f172a;line-height:1.2}.stat-trend{font-size:.75rem;color:#94a3b8;margin-top:2px}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;align-items:start}.dashboard-main,.dashboard-sidebar{display:flex;flex-direction:column;gap:24px}.dashboard-card{background:#fff;border-radius:16px;border:1px solid #f1f5f9;box-shadow:0 1px 2px #0000000d;overflow:hidden}.card-header{padding:20px;border-bottom:1px solid #f1f5f9}.card-header h3{margin:0;font-size:1rem;color:#0f172a;font-weight:600}.chart-container{padding:20px;display:flex;flex-direction:column;gap:16px}.chart-row{display:flex;align-items:center;gap:12px}.chart-label{width:60px;font-size:.875rem;color:#64748b;font-weight:500}.chart-bar-bg{flex:1;height:12px;background:#f1f5f9;border-radius:6px;overflow:hidden}.chart-bar{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:6px;transition:width 1s ease-out}.chart-value{font-size:.875rem;color:#0f172a;font-weight:600;min-width:30px;text-align:right}.tags-cloud{padding:20px;display:flex;flex-wrap:wrap;gap:12px}.tag-stat{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:20px}.tag-name{font-size:.875rem;color:#334155;font-weight:500}.tag-count{background:#e2e8f0;color:#64748b;padding:2px 8px;border-radius:10px;font-size:.75rem;font-weight:700}.quick-actions{padding:20px;display:flex;flex-direction:column;gap:12px}.action-btn{display:flex;align-items:center;gap:16px;padding:16px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s;text-align:left}.action-btn:hover{border-color:#3b82f6;background:#f0f9ff;box-shadow:0 4px 6px -1px #3b82f61a}.action-btn .icon{width:40px;height:40px;background:#f1f5f9;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px}.action-btn:hover .icon{background:#fff}.action-info{flex:1;display:flex;flex-direction:column;gap:2px}.action-info .title{font-weight:600;color:#0f172a;font-size:.9375rem}.action-info .desc{font-size:.75rem;color:#64748b}.action-btn .arrow{color:#cbd5e1;transition:transform .2s}.action-btn:hover .arrow{color:#3b82f6;transform:translate(4px)}.recent-activity-list{display:flex;flex-direction:column}.activity-item{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid #f1f5f9}.activity-item:last-child{border-bottom:none}.activity-icon{width:36px;height:36px;background:#f8fafc;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px}.activity-content{flex:1;min-width:0}.activity-title{margin:0 0 4px;font-size:.875rem;color:#334155;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-time{margin:0;font-size:.75rem;color:#94a3b8}.score-badge{padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:700}.score-badge.high{background:#dcfce7;color:#166534}.score-badge.mid{background:#e0f2fe;color:#075985}.score-badge.low{background:#fee2e2;color:#991b1b}.empty-activity{padding:30px;text-align:center;color:#94a3b8;font-size:.875rem}@media(max-width:1200px){.dashboard-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}.progress-container{margin-top:1rem;padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.progress-bar-bg{width:100%;height:12px;background:#e2e8f0;border-radius:6px;overflow:hidden;position:relative;box-shadow:inset 0 1px 2px #0000001a}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:6px;transition:width .3s ease-out;position:relative}.progress-bar-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(45deg,rgba(255,255,255,.2) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.2) 50%,rgba(255,255,255,.2) 75%,transparent 75%,transparent);background-size:20px 20px;animation:stripe-move 1s linear infinite}@keyframes stripe-move{0%{background-position:0 0}to{background-position:20px 20px}}.progress-text{margin-top:.5rem;font-size:.875rem;color:#475569;text-align:center;font-weight:500}.q-analysis-preview{margin-top:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.q-analysis-preview textarea.mini-textarea{width:100%;border:1px solid #cbd5e1;border-radius:6px;padding:8px;font-size:.875rem;resize:vertical;transition:border-color .2s;font-family:inherit}.q-analysis-preview textarea.mini-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tags-cloud{display:flex;flex-wrap:wrap;gap:8px}.tag-stat{background:#fff;border:1px solid #e2e8f0;color:#475569;padding:2px 8px;border-radius:4px;font-size:.75rem;display:inline-flex;align-items:center}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-content.modal-large{width:90%;max-width:900px}.modal-header{padding:20px 24px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#64748b;padding:4px 8px;border-radius:4px}.modal-close:hover{background:#f1f5f9;color:#0f172a}.modal-body{padding:24px;overflow-y:auto;max-height:calc(90vh - 140px)}.modal-footer{padding:16px 24px;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:12px}.edit-section{margin-bottom:24px}.edit-section h3{margin:0 0 16px;font-size:1rem;font-weight:600;color:#0f172a}.materials-textarea{width:100%;padding:12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.9375rem;font-family:inherit;resize:vertical;line-height:1.6}.materials-textarea:focus{outline:none;border-color:var(--primary-color, #2563eb)}.questions-edit-list{display:flex;flex-direction:column;gap:16px}.question-edit-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px}.q-edit-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.q-edit-header .q-number{font-weight:700;color:#3b82f6;min-width:70px}.q-edit-header select,.q-edit-header input{padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem}.q-edit-header span{color:#64748b;font-size:.875rem}.q-edit-body{display:flex;flex-direction:column;gap:8px}.q-edit-body label{font-size:.75rem;font-weight:600;color:#64748b;margin-top:8px}.q-edit-body textarea{width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;font-family:inherit;resize:vertical;line-height:1.5}.q-edit-body textarea:focus{outline:none;border-color:var(--primary-color, #2563eb)}.history-page{padding:2rem;max-width:1200px;margin:0 auto}.history-page .page-header{margin-bottom:2rem}.back-btn{display:inline-flex;align-items:center;gap:.25rem;background:none;border:none;color:var(--primary-600);font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem 0;margin-bottom:.5rem;transition:color .2s}.back-btn:hover{color:var(--primary-700)}.history-page .page-title{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.history-page .page-subtitle{color:var(--gray-500);font-size:.9375rem}.history-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:1.25rem;text-align:center;display:flex;flex-direction:column;gap:.25rem}.stat-number{font-size:2rem;font-weight:700;color:var(--primary-600)}.stat-label{font-size:.75rem;color:var(--gray-500)}.history-table-container{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-100);overflow:hidden}.history-table{width:100%;border-collapse:collapse}.history-table th{background:var(--gray-50);padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--gray-100)}.history-table td{padding:1rem;border-bottom:1px solid var(--gray-50);vertical-align:middle}.history-table tbody tr:last-child td{border-bottom:none}.history-table tbody tr:hover{background:var(--gray-25, #fafafa)}.question-cell{max-width:300px}.question-title{display:block;font-weight:500;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.question-type{font-size:.6875rem;color:var(--gray-500);background:var(--gray-100);padding:.125rem .375rem;border-radius:4px}.date-cell{font-size:.875rem;color:var(--gray-600);white-space:nowrap}.status-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:20px;font-size:.6875rem;font-weight:600}.status-badge.completed{background:#dcfce7;color:#166534}.status-badge.processing{background:#dbeafe;color:#1e40af}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.error{background:#fee2e2;color:#991b1b}.score-cell{font-weight:600}.score{color:var(--primary-600);font-size:1rem}.no-score{color:var(--gray-300)}.actions-cell{white-space:nowrap}.btn-action{padding:.375rem .75rem;font-size:.75rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;margin-right:.5rem}.btn-action:last-child{margin-right:0}.btn-view{background:var(--primary-50);color:var(--primary-600)}.btn-view:hover{background:var(--primary-100)}.btn-delete{background:#fee2e2;color:#dc2626}.btn-delete:hover{background:#fecaca}.btn-delete:disabled{opacity:.5;cursor:not-allowed}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-100)}.loading-spinner{font-size:2.5rem;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-text{color:var(--gray-600);font-size:1rem;margin-bottom:.5rem}.empty-hint{color:var(--gray-400);font-size:.875rem}@media(max-width:768px){.history-page{padding:1rem}.history-table-container{overflow-x:auto}.history-table{min-width:600px}}.history-groups{display:flex;flex-direction:column;gap:1.5rem}.exam-history-group{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200);overflow:hidden;box-shadow:0 1px 2px #0000000d}.exam-history-group .group-header{background:linear-gradient(to right,var(--gray-50),white);padding:1rem 1.5rem;border-bottom:1px solid var(--gray-100)}.exam-history-group .group-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--gray-800);display:flex;align-items:center;gap:.75rem}.exam-icon{font-size:1.25rem}.exam-count{color:var(--gray-500);font-size:.875rem;font-weight:400}.exam-history-group .history-table-container{border:none;border-radius:0;box-shadow:none}.exam-history-group .history-table th{background:#fff;border-bottom:2px solid var(--gray-100)}.group-title-wrapper{display:flex;justify-content:space-between;align-items:center}.group-total-score{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:var(--primary-50);border-radius:var(--radius-md);border:1px solid var(--primary-100)}.group-total-score .label{font-size:.75rem;font-weight:500;color:var(--primary-700)}.group-total-score .value{display:flex;align-items:center;font-weight:700}.group-total-score .earned{font-size:1.125rem;color:var(--primary-600)}.group-total-score .separator{margin:0 .125rem;color:var(--primary-300)}.group-total-score .total{font-size:.875rem;color:var(--primary-400)}.score-wrapper{display:flex;align-items:center;gap:.125rem}.score-earned{color:var(--primary-600);font-size:1.125rem;font-weight:700}.score-divider{color:var(--gray-300);font-size:.875rem}.score-max{color:var(--gray-400);font-size:.875rem;font-weight:500}.app{min-height:100vh;display:flex;flex-direction:column}.app-layout{display:flex;flex:1;padding-top:64px}.main-content{flex:1;margin-left:260px;padding:2rem;min-height:calc(100vh - 64px);background:var(--gray-50)}@media(max-width:1024px){.main-content{margin-left:0;padding:1rem}}
