*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f0f4f8;--surface: #ffffff;--surface-hover: #f8fafc;--border: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--accent: #3b82f6;--accent-dark: #2563eb;--success: #22c55e;--danger: #ef4444;--warning: #f59e0b;--radius: 10px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh}a{color:inherit;text-decoration:none}.app{display:flex;flex-direction:column;min-height:100vh}.site-header{position:sticky;top:0;z-index:100}.navbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 1.5rem;display:flex;align-items:center;gap:2rem;height:56px;box-shadow:var(--shadow)}.nav-links{display:flex;gap:2rem}.nav-user{margin-left:auto;display:flex;align-items:center;gap:.75rem}.nav-hamburger{display:none;margin-left:auto;background:none;border:none;cursor:pointer;font-size:1.35rem;color:var(--text-muted);padding:.25rem .125rem;line-height:1}.nav-mobile-menu{background:var(--surface);border-bottom:1px solid var(--border);padding:.5rem 1.5rem 1rem;display:flex;flex-direction:column;box-shadow:var(--shadow)}.nav-mobile-menu .navbar-link{padding:.75rem 0;border-bottom:1px solid var(--border);font-size:.95rem}.nav-mobile-user{padding-top:.75rem;display:flex;justify-content:space-between;align-items:center}@media (max-width: 768px){.navbar{gap:1rem}.nav-links,.nav-user{display:none}.nav-hamburger{display:flex;align-items:center}}.navbar-brand{font-size:1.125rem;font-weight:700;color:var(--accent);letter-spacing:-.02em}.navbar-link{font-size:.9rem;color:var(--text-muted);padding:.25rem 0;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.navbar-link:hover,.navbar-link.active{color:var(--accent);border-bottom-color:var(--accent)}.page{max-width:900px;margin:0 auto;padding:2rem 1.5rem;width:100%;flex:1}@media (max-width: 480px){.page{padding:1.25rem 1rem}.modal-box{margin:1rem;width:calc(100% - 2rem);min-width:unset}}.page-title{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1.125rem;border-radius:7px;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:background .15s,opacity .15s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-dark)}.btn-secondary{background:var(--border);color:var(--text)}.btn-secondary:hover:not(:disabled){background:#cbd5e1}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover:not(:disabled){background:#d97706}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.form-group{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}.form-label{font-size:.875rem;font-weight:500;color:var(--text-muted)}.form-input,.form-textarea,.form-select{padding:.5rem .75rem;border:1px solid var(--border);border-radius:7px;font-size:.9rem;background:var(--surface);color:var(--text);outline:none;transition:border-color .15s;font-family:inherit}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61a}.form-textarea{resize:vertical;min-height:120px}.source-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.source-item{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:var(--shadow)}.source-item .source-name{font-weight:600;font-size:.95rem}.source-item .source-meta{font-size:.8rem;color:var(--text-muted);margin-top:2px}.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-ready{background:#dcfce7;color:#15803d}.badge-generating{background:#fef9c3;color:#a16207}.badge-error{background:#fee2e2;color:#b91c1c}.question-card{max-width:700px;margin:0 auto}.question-text{font-size:1.15rem;font-weight:600;line-height:1.6;margin-bottom:1.5rem}.question-progress{font-size:.85rem;color:var(--text-muted);margin-bottom:1rem}.progress-bar-wrap{background:var(--border);border-radius:999px;height:6px;margin-bottom:1.5rem;overflow:hidden}.progress-bar-fill{background:var(--accent);height:100%;border-radius:999px;transition:width .3s}.options-grid{display:flex;flex-direction:column;gap:.625rem}.option-btn{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.125rem;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;font-size:.925rem;text-align:left;transition:border-color .15s,background .15s;font-family:inherit;color:var(--text)}.option-btn:hover:not(:disabled){border-color:var(--accent);background:var(--surface-hover)}.option-btn:disabled{cursor:default}.option-btn.correct{border-color:var(--success);background:#f0fdf4;color:#15803d}.option-btn.wrong{border-color:var(--danger);background:#fef2f2;color:#b91c1c}.option-btn.reveal-correct{border-color:var(--success);background:#f0fdf4;color:#15803d}.option-btn.selected{border-color:var(--accent);background:var(--surface-hover)}.option-key{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--bg);font-weight:700;font-size:.8rem;flex-shrink:0}.feedback-banner{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;font-weight:600;font-size:.9rem;margin-top:1rem}.feedback-banner.correct{background:#dcfce7;color:#15803d}.feedback-banner.wrong{background:#fee2e2;color:#b91c1c}.score-circle{width:120px;height:120px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:2rem;font-weight:800;border:6px solid var(--accent);color:var(--accent)}.score-circle .score-label{font-size:.75rem;font-weight:500;color:var(--text-muted)}.answers-list{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.answer-row{display:flex;gap:.75rem;padding:.75rem;border-radius:8px;font-size:.875rem;border:1px solid var(--border)}.answer-row.correct{background:#f0fdf4;border-color:#bbf7d0}.answer-row.wrong{background:#fef2f2;border-color:#fecaca}.history-table{width:100%;border-collapse:collapse;font-size:.9rem}.history-table th{text-align:left;padding:.75rem 1rem;border-bottom:2px solid var(--border);font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.history-table td{padding:.875rem 1rem;border-bottom:1px solid var(--border)}.history-table tr:last-child td{border-bottom:none}.history-table tr:hover td{background:var(--surface-hover);cursor:pointer}.upload-tabs{display:flex;gap:0;margin-bottom:1.25rem;border-bottom:2px solid var(--border)}.upload-tab{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border:none;background:none;cursor:pointer;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;font-family:inherit}.upload-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.source-checkbox-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.source-checkbox-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s;-webkit-user-select:none;user-select:none}.source-checkbox-item.selected{border-color:var(--accent);background:#eff6ff}.source-checkbox-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.error-text{color:var(--danger);font-size:.875rem}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.flex-row{display:flex;align-items:center;gap:.75rem}.flex-between{display:flex;align-items:center;justify-content:space-between}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.text-center{text-align:center}.text-muted{color:var(--text-muted);font-size:.875rem}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 768px){.dashboard-grid{grid-template-columns:1fr}}.stat-chip{display:flex;flex-direction:column;align-items:center;padding:.75rem 1.25rem}.stat-chip .value{font-size:2rem;font-weight:800;line-height:1}.stat-chip .label{font-size:.75rem;color:var(--text-muted);margin-top:2px}.heatmap-grid{display:grid;grid-template-columns:repeat(13,1fr);gap:3px}.heatmap-cell{width:12px;height:12px;border-radius:2px;background:var(--border)}.heatmap-cell.i1{background:#3b82f640}.heatmap-cell.i2{background:#3b82f680}.heatmap-cell.i3{background:#3b82f6bf}.heatmap-cell.i4{background:var(--accent)}.section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:1rem}.hero-stats{display:flex;gap:.5rem;flex-wrap:wrap}.hero-counts{font-size:1.5rem;font-weight:800;line-height:1.2;margin-bottom:.25rem}.hero-sub{font-size:.875rem;color:var(--text-muted);margin-bottom:1rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-box{background:var(--surface);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-md);min-width:320px;max-width:480px;width:100%}@media (max-width: 640px){.col-mobile-hide{display:none}}
