*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{color:#1e293b;background:#f8fafc;min-height:100vh;font-family:Noto Sans TC,system-ui,sans-serif}.dark body,.dark{color:#e2e8f0;background:#0f172a}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}select{font-family:inherit}.container{max-width:72rem;margin:0 auto;padding:0 1rem}.header{z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffc;border-bottom:1px solid #e2e8f0;position:sticky;top:0}.dark .header{background:#0f172acc;border-color:#334155}.header-inner{justify-content:space-between;align-items:center;max-width:72rem;margin:0 auto;padding:.75rem 1rem;display:flex}.header-title{font-size:1.125rem;font-weight:700}.tab-bar{gap:.25rem;max-width:72rem;margin:0 auto;padding:0 1rem .25rem;display:flex;overflow-x:auto}.tab-btn{white-space:nowrap;color:#64748b;background:0 0;border:none;border-radius:.5rem .5rem 0 0;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.tab-btn:hover{color:#1e293b}.dark .tab-btn{color:#94a3b8}.dark .tab-btn:hover{color:#e2e8f0}.tab-btn.active{color:#1d4ed8;background:#eff6ff}.dark .tab-btn.active{color:#93c5fd;background:#1e3a8a4d}main{max-width:72rem;margin:0 auto;padding:1.5rem 1rem}h2{margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}h3{margin-bottom:.75rem;font-size:1.125rem;font-weight:700}.theme-btn{color:inherit;background:0 0;border:1px solid #d1d5db;border-radius:.5rem;padding:.375rem .75rem;font-size:.875rem}.dark .theme-btn{border-color:#475569}.stats-grid{gap:1rem;margin-bottom:2rem;display:grid}@media (width>=640px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;padding:1.25rem;box-shadow:0 1px 3px #0000000a}.dark .stat-card{background:#1e293b;border-color:#334155}.stat-label{color:#64748b;font-size:.875rem}.dark .stat-label{color:#94a3b8}.stat-value{margin-top:.25rem;font-size:1.875rem;font-weight:900}.card{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px #0000000a}.dark .card{background:#1e293b;border-color:#334155}.filter-bar{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.filter-bar select,.filter-bar button{color:inherit;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;padding:.5rem .75rem;font-size:.875rem}.dark .filter-bar select,.dark .filter-bar button{background:#1e293b;border-color:#475569}.filter-bar button:hover{background:#f1f5f9}.dark .filter-bar button:hover{background:#334155}.q-item{margin-bottom:1rem}.q-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.q-tags{color:#64748b;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.dark .q-tags{color:#94a3b8}.q-tags .tag{background:#f1f5f9;border-radius:.25rem;padding:.125rem .5rem;font-size:.75rem}.dark .q-tags .tag{background:#1e293b}.q-tags .tag.easy{color:#166534;background:#dcfce7}.dark .q-tags .tag.easy{color:#86efac;background:#1665344d}.q-tags .tag.medium{color:#854d0e;background:#fef9c3}.dark .q-tags .tag.medium{color:#fde047;background:#854d0e4d}.q-tags .tag.hard{color:#991b1b;background:#fee2e2}.dark .q-tags .tag.hard{color:#fca5a5;background:#991b1b4d}.q-actions{gap:.5rem;display:flex}.q-actions button{background:0 0;border:none;font-size:1rem}.q-text{margin-bottom:.75rem}.q-options{color:#475569;margin-left:1rem;font-size:.875rem}.dark .q-options{color:#cbd5e1}details summary{cursor:pointer;color:#2563eb;font-size:.875rem;font-weight:500}.dark details summary{color:#60a5fa}details .ans-box{background:#f0fdf4;border-radius:.75rem;margin-top:.5rem;padding:1rem;font-size:.875rem}.dark details .ans-box{background:#22c55e1a}details .ans-box .ans-label{font-weight:500}details .ans-box .ans-desc{color:#475569;margin-top:.25rem}.dark details .ans-box .ans-desc{color:#94a3b8}.pagination{justify-content:center;align-items:center;gap:.5rem;margin-top:1.5rem;display:flex}.pagination button{color:inherit;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;padding:.375rem .75rem;font-size:.875rem}.dark .pagination button{background:#1e293b;border-color:#475569}.pagination button:disabled{opacity:.4;cursor:default}.pagination span{color:#64748b;font-size:.875rem}.exam-setup{max-width:36rem}.exam-setup .field{margin-bottom:1rem}.exam-setup label{margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.exam-setup select,.exam-setup input[type=range]{width:100%}.exam-setup select{color:inherit;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;padding:.5rem .75rem}.dark .exam-setup select{background:#1e293b;border-color:#475569}.exam-setup .time-display{align-items:center;gap:.5rem;display:flex}.exam-setup .time-display input{flex:1}.exam-setup .time-display span{width:5rem;font-size:.875rem;font-weight:500}.topic-picker{flex-wrap:wrap;gap:.5rem;display:flex}.topic-picker button{color:inherit;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;padding:.375rem .75rem;font-size:.875rem}.dark .topic-picker button{background:0 0;border-color:#475569}.topic-picker button.selected{color:#1d4ed8;background:#eff6ff;border-color:#3b82f6}.dark .topic-picker button.selected{color:#93c5fd;background:#1e3a8a4d}.btn-primary{color:#fff;background:#2563eb;border:none;border-radius:.75rem;width:100%;padding:.75rem;font-size:1rem;font-weight:500;transition:background .15s}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{opacity:.5;cursor:default}.btn-sm{color:inherit;background:0 0;border:1px solid #d1d5db;border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem}.dark .btn-sm{border-color:#475569}.btn-sm:hover{background:#f1f5f9}.dark .btn-sm:hover{background:#334155}.btn-sm:disabled{opacity:.4;cursor:default}.btn-danger-sm{color:#dc2626;background:0 0;border:1px solid #fca5a5;border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem}.dark .btn-danger-sm{color:#fca5a5;border-color:#991b1b}.btn-danger-sm:hover{background:#fef2f2}.dark .btn-danger-sm:hover{background:#dc26261a}.progress-bar{margin-bottom:1.5rem}.progress-header{justify-content:space-between;margin-bottom:.5rem;font-size:.875rem;display:flex}.progress-track{background:#e2e8f0;border-radius:999px;height:.5rem;overflow:hidden}.dark .progress-track{background:#334155}.progress-fill{background:#3b82f6;border-radius:999px;height:100%;transition:width .3s}.nav-dots{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.nav-dot{border:none;border-radius:.25rem;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.875rem;display:flex}.nav-dot.current{color:#fff;background:#2563eb}.nav-dot.answered{color:#1d4ed8;background:#dbeafe}.dark .nav-dot.answered{color:#93c5fd;background:#1e3a8a4d}.nav-dot.empty{color:#64748b;background:#f1f5f9}.dark .nav-dot.empty{color:#94a3b8;background:#1e293b}.exam-options{flex-direction:column;gap:.5rem;display:flex}.exam-option{text-align:left;width:100%;color:inherit;font-size:inherit;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:all .15s;display:flex}.dark .exam-option{background:#1e293b;border-color:#334155}.exam-option:hover{background:#f8fafc}.dark .exam-option:hover{background:#0f172a}.exam-option.selected{background:#eff6ff;border-color:#3b82f6}.dark .exam-option.selected{background:#1e3a8a33}.exam-option .circle{background:#f1f5f9;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:1.75rem;height:1.75rem;font-size:.875rem;font-weight:500;display:flex}.dark .exam-option .circle{background:#334155}.exam-option.selected .circle{color:#fff;background:#2563eb}.timer{font-family:monospace;font-size:1.125rem;font-weight:700}.timer.warning{color:#ef4444}.exam-nav{justify-content:space-between;align-items:center;margin-top:1.5rem;display:flex}.submit-btn{color:#fff;background:#2563eb;border:none;border-radius:.5rem;padding:.5rem 1.5rem;font-size:.875rem;font-weight:500}.submit-btn:hover{background:#1d4ed8}.empty-state{text-align:center;color:#94a3b8;padding:3rem 0}.empty-state .icon{margin-bottom:.5rem;font-size:2.25rem}.table-wrap{border:1px solid #e2e8f0;border-radius:1rem;overflow-x:auto}.dark .table-wrap{border-color:#334155}table{border-collapse:collapse;width:100%;font-size:.875rem}thead{background:#f8fafc}.dark thead{background:#1e293b80}th{text-align:left;padding:.75rem 1rem;font-weight:500}td{border-top:1px solid #e2e8f0;padding:.75rem 1rem}.dark td{border-color:#334155}tr:hover{background:#f8fafc}.dark tr:hover{background:#1e293b4d}td:last-child,th:last-child{text-align:right}.action-bar{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}
