:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#f5f7fa}body{margin:0;min-width:320px;min-height:100vh}h1,h2,h3{margin:0 0 16px}p{margin:0 0 8px}button,input,select{font-family:inherit}a{color:#1976d2;text-decoration:none}a:hover{text-decoration:underline}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease-out;padding:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:420px;width:100%;animation:slideIn .25s ease-out;overflow:hidden}.modal-header{display:flex;align-items:center;gap:12px;padding:20px 24px 16px;border-bottom:1px solid #e0e0e0}.modal-icon{font-size:1.8rem}.modal-title{margin:0;font-size:1.2rem;font-weight:600;color:#333}.modal-body{padding:20px 24px}.modal-body p{margin:0;font-size:1rem;line-height:1.6;color:#555}.modal-actions{display:flex;gap:12px;padding:16px 24px 20px;justify-content:flex-end}.modal-btn{padding:10px 24px;font-size:1rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.modal-btn-cancel{background:#e0e0e0;color:#555}.modal-btn-cancel:hover{background:#d0d0d0}.modal-btn-confirm{background:#1976d2;color:#fff}.modal-btn-confirm:hover{background:#1565c0;transform:translateY(-1px)}.modal-btn-warning{background:#ff9800}.modal-btn-warning:hover{background:#f57c00}.modal-btn-error{background:#f44336}.modal-btn-error:hover{background:#d32f2f}.modal-btn-success{background:#4caf50}.modal-btn-success:hover{background:#388e3c}.modal-btn-confirm.modal-btn-confirm{background:#ff9800}.modal-btn-confirm.modal-btn-confirm:hover{background:#f57c00}@media(max-width:480px){.modal-content{max-width:100%;margin:0 10px}.modal-header{padding:16px 20px 12px}.modal-body{padding:16px 20px}.modal-actions{padding:12px 20px 16px;flex-direction:column-reverse}.modal-btn{width:100%;padding:12px}}.home{max-width:960px;margin:0 auto;padding:24px}.home.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh}.spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#1976d2;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.hero{text-align:center;margin-bottom:32px;padding:32px;background:linear-gradient(135deg,#42a5f5,#7e57c2);color:#fff;border-radius:18px;box-shadow:0 10px 26px #0f172a33}.hero h1{font-size:2.1rem;margin-bottom:8px}.hero p{opacity:.9}.pending-session{background:#fff3e0;border:2px solid #ff9800;border-radius:14px;padding:20px;margin-bottom:24px;text-align:center}.pending-session h3{color:#e65100;margin-bottom:8px}.pending-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:12px}.continue-btn{padding:12px 32px;background:#ff9800;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer}.continue-btn:hover{background:#f57c00}.discard-btn{padding:12px 24px;background:#f5f5f5;color:#333;border:1px solid #ddd;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer}.discard-btn:hover{background:#eee}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px}.action-card{background:#fff;border-radius:16px;padding:24px;text-align:center;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:all .2s}.action-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.card-icon{font-size:2.5rem;display:block;margin-bottom:12px}.action-card h3{margin-bottom:8px;color:#333}.action-card p{color:#666;font-size:.9rem}.recent-activity{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000001a}.recent-activity h3{margin-bottom:16px;color:#333}.session-list{display:flex;flex-direction:column;gap:8px}.session-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f5f5f5;border-radius:8px}.session-item.clickable{cursor:pointer;transition:all .2s}.session-item.clickable:hover{background:#e0e0e0;transform:translate(4px)}.session-date{color:#666}.session-score{font-weight:600;color:#4caf50}.session-count{color:#999;font-size:.9rem}.quiz-config{max-width:720px;margin:0 auto;padding:24px 28px;background:#fff;border-radius:18px;box-shadow:0 10px 26px #0f172a29}.quiz-config h2{text-align:center;margin-bottom:24px;color:#333}.config-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #eee}.config-section:last-of-type{border-bottom:none}.config-section h3{margin-bottom:12px;color:#555;font-size:1rem}.toggle-group{display:flex;gap:12px}.toggle-btn{flex:1;padding:12px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-weight:500;transition:all .2s}.toggle-btn:hover{border-color:#1976d2}.toggle-btn.active{background:#1976d2;color:#fff;border-color:#1976d2}.exam-select{width:100%;padding:12px;font-size:1rem;border:2px solid #ddd;border-radius:8px}.category-list{display:flex;flex-direction:column;gap:8px}.category-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f5f5f5;border-radius:8px;cursor:pointer}.category-item:hover{background:#e3f2fd}.category-item input{width:18px;height:18px}.question-count-input{width:100px;padding:8px 12px;font-size:1rem;border:2px solid #ddd;border-radius:8px;margin-right:16px}.shuffle-option{display:inline-flex;align-items:center;gap:8px;cursor:pointer}.time-options{display:flex;gap:12px;flex-wrap:wrap}.time-btn{flex:1;min-width:120px;padding:12px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:.9rem;transition:all .2s}.time-btn:hover{border-color:#1976d2}.time-btn.active{background:#e3f2fd;border-color:#1976d2;color:#1976d2}.config-actions{display:flex;justify-content:space-between;margin-top:24px}.back-btn,.start-btn{padding:14px 28px;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.back-btn{background:#f5f5f5;color:#333}.back-btn:hover{background:#e0e0e0}.start-btn{background:#4caf50;color:#fff}.start-btn:hover{background:#43a047}.question-display{background:#fff;border-radius:14px;padding:18px 20px;box-shadow:0 8px 20px #0f172a24;display:flex;flex-direction:column;box-sizing:border-box;animation:questionFadeIn .25s ease-out}@keyframes questionFadeIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.question-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid #e3f2fd;flex-wrap:wrap}.question-header-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap;flex:1;min-width:0}.question-header-nav{display:flex;gap:8px}.question-number{font-weight:700;color:#1976d2;font-size:1.1rem}.question-points{background:#fff3e0;color:#e65100;padding:4px 12px;border-radius:16px;font-size:.85rem;font-weight:600}.question-category{background:#e3f2fd;color:#1976d2;padding:4px 12px;border-radius:16px;font-size:.85rem;margin-left:auto}.question-content{flex:0 0 auto;overflow-y:visible}.question-text{font-size:1.15rem;line-height:1.7;color:#333;margin-bottom:16px;white-space:pre-wrap}.question-text .wingdings,.question-text .wingdings2,.question-text .wingdings3{font-size:1.4em;vertical-align:middle}.question-images{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin:20px 0}.question-images.clickable{gap:20px}.image-option{position:relative;display:flex;flex-direction:column;align-items:center}.image-option.selectable{cursor:pointer;padding:8px;border:3px solid transparent;border-radius:12px;transition:all .2s}.image-option.selectable:hover{border-color:#90caf9;background:#e3f2fd}.image-option.selectable.selected{border-color:#1976d2;background:#bbdefb}.image-label{position:absolute;top:-8px;left:-8px;width:28px;height:28px;background:#1976d2;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}.question-image{display:block;width:auto;height:auto;max-width:380px;max-height:320px;border-radius:8px;object-fit:contain;background:#fff}.answer-section{margin-top:24px;padding-top:16px;border-top:1px solid #eee;min-height:180px;display:flex;flex-direction:column;justify-content:center}.answer-input{width:100%;max-width:360px;padding:14px 18px;font-size:1.1rem;border:2px solid #ddd;border-radius:999px;transition:all .2s}.answer-input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.blank-input{display:inline-block;min-width:80px;max-width:180px;margin:0 6px;padding:6px 10px;border:2px solid #1976d2;border-radius:8px;font-size:1rem;vertical-align:baseline;background:#e3f2fd}.blank-input:not(:placeholder-shown){background:#e8f5e9;border-color:#2e7d32}.blank-input:focus{outline:none;border-color:#0d47a1;box-shadow:0 0 0 3px #0d47a11a}.blank-input:focus:not(:placeholder-shown){box-shadow:0 0 0 3px #2e7d3226}.blank-input.context-blank{background:#f5f5f5;border-color:#ccc;cursor:not-allowed;opacity:.6}.blank-input.context-blank:focus{border-color:#ccc;box-shadow:none}.blank-hint{font-size:.95rem;color:#666;padding:10px 12px;background:#f5f5f5;border-radius:10px}.choice-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px}.choice-option{position:relative;display:flex;align-items:center;justify-content:center;padding:40px 10px 12px;border:3px solid #e0e0e0;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:center;min-height:80px}.choice-option:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.choice-option:active{transform:scale(.98);transition:transform .1s}.choice-option.choice-a{background:#fff3e0;border-color:#ff9800}.choice-option.choice-a:hover{background:#ffe0b2;border-color:#f57c00}.choice-option.choice-a.selected{background:linear-gradient(135deg,#ff9800,#f57c00);border-color:#e65100;box-shadow:0 0 0 4px #ff98004d,0 8px 20px #ff980040;transform:scale(1.02);color:#fff}.choice-option.choice-b{background:#e3f2fd;border-color:#2196f3}.choice-option.choice-b:hover{background:#bbdefb;border-color:#1976d2}.choice-option.choice-b.selected{background:linear-gradient(135deg,#2196f3,#1976d2);border-color:#0d47a1;box-shadow:0 0 0 4px #2196f34d,0 8px 20px #2196f340;transform:scale(1.02);color:#fff}.choice-option.choice-c{background:#e8f5e9;border-color:#4caf50}.choice-option.choice-c:hover{background:#c8e6c9;border-color:#388e3c}.choice-option.choice-c.selected{background:linear-gradient(135deg,#4caf50,#388e3c);border-color:#1b5e20;box-shadow:0 0 0 4px #4caf504d,0 8px 20px #4caf5040;transform:scale(1.02);color:#fff}.choice-option.choice-d{background:#fce4ec;border-color:#e91e63}.choice-option.choice-d:hover{background:#f8bbd0;border-color:#c2185b}.choice-option.choice-d.selected{background:linear-gradient(135deg,#e91e63,#c2185b);border-color:#880e4f;box-shadow:0 0 0 4px #e91e634d,0 8px 20px #e91e6340;transform:scale(1.02);color:#fff}.choice-label{position:absolute;top:12px;left:12px;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0;box-shadow:0 2px 6px #00000026}.choice-label-a{background:#ff9800;color:#fff}.choice-label-b{background:#2196f3;color:#fff}.choice-label-c{background:#4caf50;color:#fff}.choice-label-d{background:#e91e63;color:#fff}.choice-option.selected .choice-label{transform:scale(1.15);box-shadow:0 3px 10px #0000004d;background:#fffffff2;color:#333}.choice-option.selected .choice-display{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.choice-display{font-size:clamp(1.4rem,4vw,2rem);color:#333;font-weight:600;line-height:1.4;text-align:center;width:100%;word-break:break-word;overflow-wrap:break-word;padding:0 4px;transition:color .2s,text-shadow .2s}.question-nav-btn{padding:8px 16px;font-size:.9rem;font-weight:500;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s;background:#fff;color:#333}.question-nav-btn:hover:not(:disabled){border-color:#1976d2;background:#e3f2fd;transform:translateY(-1px)}.question-nav-btn:disabled{opacity:.5;cursor:not-allowed}.question-nav-btn.prev-btn{margin-right:8px}@media(max-width:768px){.choice-options-grid{grid-template-columns:1fr;gap:10px}.choice-option{min-height:60px;padding:36px 10px 10px}}@media(max-width:1024px){.question-display{padding:14px 16px;border-radius:12px}.question-header{flex-direction:row;align-items:center;flex-wrap:nowrap;margin-bottom:10px;padding-bottom:8px}.question-header-left{gap:8px}.question-header-nav{flex-shrink:0}.question-nav-btn{padding:4px 12px;font-size:1rem}.question-text{font-size:1.1rem;line-height:1.6;margin-bottom:12px}}.image-select-hint{text-align:center;color:#666;font-size:1rem;padding:12px;background:#f5f5f5;border-radius:8px}.icon-options{display:flex;flex-wrap:wrap;gap:12px}.icon-option{display:flex;align-items:center;gap:10px;padding:12px 16px;border:2px solid #e0e0e0;border-radius:10px;background:#fff;cursor:pointer;transition:all .2s}.icon-option:hover{border-color:#90caf9;background:#f5f5f5}.icon-option.selected{border-color:#1976d2;background:#e3f2fd}.icon-label{width:28px;height:28px;background:#f0f0f0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.icon-option.selected .icon-label{background:#1976d2;color:#fff}.icon-display{font-size:1.8rem}.answer-review{display:flex;flex-direction:column;gap:12px}.user-answer,.correct-answer{padding:14px 18px;border-radius:10px}.user-answer{background:#f5f5f5;border-left:4px solid #9e9e9e}.user-answer.correct{background:#e8f5e9;border-left-color:#4caf50}.user-answer.incorrect{background:#ffebee;border-left-color:#f44336}.correct-answer{background:#e8f5e9;color:#2e7d32;border-left:4px solid #4caf50}.report-btn{margin-top:12px;padding:8px 16px;background:#fff3e0;color:#e65100;border:1px solid #ffcc80;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s}.report-btn:hover{background:#ffe0b2}.report-form{margin-top:16px;padding:16px;background:#fafafa;border-radius:8px;border:1px solid #e0e0e0}.report-input{width:100%;padding:10px 14px;border:1px solid #ccc;border-radius:6px;font-size:1rem;margin-bottom:10px}.report-reason{width:100%;padding:10px 14px;border:1px solid #ccc;border-radius:6px;font-size:.9rem;min-height:60px;resize:vertical;margin-bottom:12px}.report-actions{display:flex;gap:10px}.report-submit{padding:8px 20px;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.report-submit:hover{background:#43a047}.report-cancel{padding:8px 20px;background:#9e9e9e;color:#fff;border:none;border-radius:6px;cursor:pointer}.report-cancel:hover{background:#757575}.report-submitted{margin-top:12px;padding:10px 16px;background:#e8f5e9;color:#2e7d32;border-radius:6px;font-weight:500}.report-section{margin-top:20px;padding-top:16px;border-top:1px dashed #e0e0e0}.report-btn-inline{padding:6px 14px;background:transparent;color:#757575;border:1px dashed #bdbdbd;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.report-btn-inline:hover{background:#fff3e0;color:#e65100;border-color:#ffcc80}.report-form-header{font-weight:600;color:#e65100;margin-bottom:12px}.report-icon-selector{margin-bottom:12px}.report-icon-label{font-size:.9rem;color:#666;margin-bottom:8px}.report-icons{display:flex;flex-wrap:wrap;gap:8px}.report-icon-btn{width:40px;height:40px;font-size:1.4rem;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.report-icon-btn:hover{border-color:#2196f3;background:#e3f2fd}.report-icon-btn.selected{border-color:#4caf50;background:#e8f5e9;box-shadow:0 0 0 2px #4caf504d}.timer{display:flex;flex-direction:column;gap:8px;padding:10px 16px;background:#e3f2fd;border-radius:8px;font-weight:600;font-size:1.1rem;min-width:140px}.timer-content{display:flex;align-items:center;gap:8px}.timer-icon{font-size:1.2rem}.timer-display{font-family:Courier New,monospace;color:#1976d2}.timer-progress-bar{width:100%;height:6px;background:#1976d233;border-radius:3px;overflow:hidden}.timer-progress-fill{height:100%;background:linear-gradient(90deg,#1976d2,#42a5f5);border-radius:3px;transition:width .5s ease}.timer.low{background:#fff3e0}.timer.low .timer-display{color:#f57c00}.timer.low .timer-progress-bar{background:#f57c0033}.timer.low .timer-progress-fill{background:linear-gradient(90deg,#f57c00,#ff9800)}.timer.critical{background:#ffebee;animation:pulse 1s ease-in-out infinite}.timer.critical .timer-display{color:#d32f2f}.timer.critical .timer-progress-bar{background:#d32f2f33}.timer.critical .timer-progress-fill{background:linear-gradient(90deg,#d32f2f,#f44336)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.timer.unlimited{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.timer.unlimited .timer-icon{font-size:1.4rem;font-weight:700;color:#2e7d32}.timer.unlimited .timer-display{color:#2e7d32}.timer.unlimited .timer-progress-bar{background:#2e7d3226}.timer.unlimited .timer-progress-fill{background:linear-gradient(90deg,#43a047,#66bb6a,#81c784);background-size:200% 100%;animation:shimmer 2s ease-in-out infinite}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.quiz-view{padding:10px 0 16px;max-width:1400px;margin:0 auto}.quiz-top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:10px 14px;background:#fff;border-radius:12px;box-shadow:0 4px 14px #0f172a1f}.quiz-top-left{flex:1}.quiz-top-right{margin-left:20px}.quiz-main-layout{display:grid;grid-template-columns:1fr 120px;gap:12px;align-items:stretch;min-height:calc(100vh - 240px);max-height:calc(100vh - 240px)}.quiz-content-area{min-width:0;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.quiz-content-area>.question-display{flex:1;height:100%}.quiz-sidebar{display:flex;flex-direction:column;min-height:0;height:100%;overflow:hidden}.question-nav-container{background:#fff;border-radius:12px;box-shadow:0 3px 10px #0f172a1a;padding:10px;display:flex;flex-direction:column;gap:8px;flex:1;min-height:0;height:100%;overflow:hidden}.quiz-stats{padding:0 4px;flex-shrink:0}.quiz-stats-label{display:block;font-size:.9rem;color:#666;font-weight:500}.question-nav-dots{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 6px;flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;align-content:start;justify-items:center;width:100%;box-sizing:border-box}.nav-dot{width:36px;height:36px;border:2px solid #ddd;border-radius:50%;background:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.nav-dot:hover{border-color:#1976d2;transform:scale(1.1)}.nav-dot.active{background:#1976d2;color:#fff;border-color:#1976d2}.nav-dot.answered{background:#e8f5e9;border-color:#4caf50}.nav-dot.active.answered{background:#1976d2}.question-nav-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid #e0e0e0;flex-shrink:0;margin-top:auto}.nav-pag-btn{width:24px;height:24px;min-width:24px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.nav-pag-btn:hover:not(:disabled){border-color:#1976d2;background:#e3f2fd;color:#1976d2}.nav-pag-btn:disabled{opacity:.4;cursor:not-allowed}.nav-pag-info{font-size:.7rem;color:#666;font-weight:500;white-space:nowrap}.nav-btn{padding:10px 20px;font-size:.95rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.nav-btn:disabled{opacity:.5;cursor:not-allowed}.submit-btn{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;padding:12px 24px;font-size:1rem;font-weight:600;box-shadow:0 4px 12px #ff980040}.submit-btn:hover{background:linear-gradient(135deg,#f57c00,#ef6c00);transform:translateY(-1px);box-shadow:0 6px 16px #ff980059}.submit-btn:active{transform:translateY(0);box-shadow:0 2px 8px #ff980040}.quit-button-header{position:relative;padding:12px 24px;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:not-allowed;transition:all .2s ease;background:#bdbdbd;color:#757575;overflow:hidden;user-select:none;-webkit-user-select:none;touch-action:manipulation;margin-left:12px;opacity:.7}.quit-button-header:not(.holding):not(.ready):hover{opacity:.8}.quit-button-header.holding{background:#ffcdd2;color:#c62828;cursor:progress;opacity:1;box-shadow:0 0 0 3px #f4433633}.quit-progress-bar{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#f44336,#e53935);transition:width .05s linear;z-index:0}.quit-text{position:relative;z-index:1;display:flex;align-items:center;gap:6px}.quit-button-header.ready{cursor:pointer;background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff;opacity:1;box-shadow:0 4px 12px #f443364d}.quit-button-header.ready:hover{background:linear-gradient(135deg,#e53935,#c62828);transform:translateY(-1px);box-shadow:0 6px 16px #f4433666}.quit-button-header.ready:active{transform:translateY(0);box-shadow:0 2px 8px #f443364d}.quit-button-header.ready .quit-progress-bar{display:none}@media(max-width:1024px){.quiz-view{padding:8px 0 12px}.quiz-top-bar{margin-bottom:8px;padding:8px 12px}.quiz-main-layout{grid-template-columns:1fr;min-height:auto;max-height:none;gap:8px}.quiz-sidebar{order:-1;height:auto}.question-nav-container{flex-direction:column;gap:6px;padding:8px 12px}.quiz-stats{flex-shrink:0;text-align:center;padding-bottom:4px;border-bottom:1px solid #e0e0e0}.question-nav-dots{display:flex;flex-wrap:wrap;gap:5px;max-height:70px;overflow:hidden;justify-content:center}.nav-dot{width:30px;height:30px;font-size:.75rem}.question-nav-pagination{border-top:none;padding-top:2px;justify-content:center;gap:10px}.question-nav-btn{padding:6px 12px;font-size:.8rem}.question-header-nav{position:absolute;right:0;top:50%;transform:translateY(-50%)}.question-header{position:relative}}@media(max-width:768px){.quiz-view{padding:12px 8px}.quiz-top-bar{flex-direction:column;gap:12px;align-items:stretch}.quiz-top-right{margin-left:0;display:flex;gap:10px}.quiz-top-right .submit-btn{flex:1}.quiz-top-right .quit-button-header{margin-left:0;flex-shrink:0}.nav-dot{width:30px;height:30px;font-size:.75rem}.question-nav-dots{max-height:68px}.choice-display{font-size:clamp(1.2rem,3.5vw,1.6rem)}}@media(max-width:480px){.nav-dot{width:28px;height:28px;font-size:.7rem}.question-nav-dots{max-height:64px}}.results,.review-mode{max-width:820px;margin:0 auto;padding:24px}.results-header{text-align:center;margin-bottom:24px}.result-emoji{font-size:4rem;display:block;margin-bottom:8px}.score-card{background:#fff;border-radius:20px;padding:32px;box-shadow:0 14px 32px #0f172a47;border-left:6px solid;margin-bottom:24px}.score-main{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:24px}.score-percentage{font-size:4rem;font-weight:700}.score-grade{font-size:2rem;font-weight:700;color:#fff;padding:8px 20px;border-radius:12px}.score-details{display:flex;justify-content:space-around;border-top:1px solid #eee;padding-top:20px}.detail{text-align:center}.detail-num{display:block;font-size:1.8rem;font-weight:600}.detail-label{font-size:.9rem;color:#666}.detail.correct .detail-num{color:#4caf50}.detail.wrong .detail-num{color:#f44336}.detail.time .detail-num{color:#1976d2}.category-breakdown{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.category-breakdown h3{margin-bottom:16px}.category-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.cat-name{flex:0 0 140px;font-size:.9rem;color:#555;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-bar{flex:1;height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden}.cat-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:6px}.cat-score{flex:0 0 50px;text-align:right;font-weight:600;color:#333}.question-review{background:#fff;border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:0 8px 20px #0f172a29}.question-review h3{margin-bottom:16px}.review-grid{display:flex;flex-wrap:wrap;gap:8px}.review-btn{width:40px;height:40px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s}.review-btn:hover{transform:scale(1.1)}.review-btn.correct{background:#e8f5e9;color:#4caf50}.review-btn.wrong{background:#ffebee;color:#f44336}.results-actions{display:flex;justify-content:center;gap:16px}.home-btn,.history-btn,.retry-btn{padding:14px 32px;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer}.home-btn{background:#f5f5f5;color:#333}.history-btn{background:#ff9800;color:#fff}.retry-btn{background:#1976d2;color:#fff}.review-header{display:flex;justify-content:space-between;margin-bottom:20px}.review-header button{padding:8px 16px;border:none;background:#f5f5f5;border-radius:8px;cursor:pointer}.review-nav{display:flex;justify-content:space-between;margin-top:20px}.review-nav button{padding:12px 24px;border:none;background:#f5f5f5;border-radius:8px;cursor:pointer}.review-nav button:disabled{opacity:.5}.history{max-width:900px;margin:0 auto;padding:24px}.history.empty{text-align:center;padding:48px}.history.empty button{margin-top:16px;padding:12px 24px;border:none;background:#1976d2;color:#fff;border-radius:8px;cursor:pointer}.history-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.history-header button{padding:8px 16px;border:none;background:#f5f5f5;border-radius:8px;cursor:pointer}.history-header h2{margin:0}.history-list{display:flex;flex-direction:column;gap:16px}.history-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 8px 18px #0f172a1f}.history-card.clickable{cursor:pointer;transition:all .2s}.history-card.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.history-card-header{display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #eee}.history-card-actions{display:flex;align-items:center;gap:10px}.delete-session-btn{border:none;background:#ffebee;color:#c62828;border-radius:8px;padding:6px 10px;cursor:pointer}.delete-session-btn:hover{background:#ffcdd2}.session-number{font-weight:600;color:#333}.session-date{color:#888;font-size:.9rem}.history-card-body{display:flex;align-items:center;gap:24px}.score-circle{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.score-value{color:#fff;font-size:1.5rem;font-weight:700}.history-stats{display:flex;flex-wrap:wrap;gap:20px;flex:1}.hist-stat{display:flex;flex-direction:column}.hist-stat-label{font-size:.8rem;color:#888;margin-bottom:4px}.hist-stat-value{font-size:1.2rem;font-weight:600;color:#333}.hist-stat-value.correct{color:#4caf50}.hist-stat-value.wrong{color:#f44336}.history-categories{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid #eee}.cat-tag{background:#e3f2fd;color:#1976d2;padding:4px 12px;border-radius:16px;font-size:.8rem}.analytics{max-width:960px;margin:0 auto;padding:24px}.analytics.empty{text-align:center;padding:48px}.analytics.empty button{margin-top:16px;padding:12px 24px;border:none;background:#1976d2;color:#fff;border-radius:8px;cursor:pointer}.analytics-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.analytics-header button{padding:8px 16px;border:none;background:#f5f5f5;border-radius:8px;cursor:pointer}.analytics-header h2{margin:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:20px;text-align:center;box-shadow:0 2px 8px #0000001a}.stat-card.best{background:linear-gradient(135deg,#4caf50,#8bc34a);color:#fff}.stat-value{display:block;font-size:2rem;font-weight:700}.stat-label{font-size:.85rem;opacity:.8}.accuracy-section,.category-section,.recent-section{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.accuracy-section h3,.category-section h3,.recent-section h3{margin-bottom:20px;color:#333}.accuracy-display{display:flex;align-items:center;gap:40px}.accuracy-ring{position:relative;width:120px;height:120px}.accuracy-ring svg{transform:rotate(-90deg)}.ring-bg,.ring-fill{fill:none;stroke-width:3}.ring-bg{stroke:#e0e0e0}.ring-fill{stroke:#4caf50;stroke-linecap:round}.ring-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;font-weight:700;color:#4caf50}.accuracy-details{display:flex;flex-direction:column;gap:12px}.acc-row{display:flex;justify-content:space-between;gap:32px;font-size:1.1rem}.acc-row.correct{color:#4caf50}.acc-row.wrong{color:#f44336}.category-perf-row{margin-bottom:16px}.cat-info{display:flex;justify-content:space-between;margin-bottom:6px}.cat-name{font-size:.9rem;color:#555}.cat-percent{font-weight:600}.cat-bar{height:10px;background:#e0e0e0;border-radius:5px;overflow:hidden;margin-bottom:4px}.cat-fill{height:100%;border-radius:5px;transition:width .5s ease}.cat-stats{font-size:.85rem;color:#888}.sessions-table{display:flex;flex-direction:column;gap:8px}.session-row{display:flex;align-items:center;padding:12px;background:#f5f5f5;border-radius:8px;gap:16px}.session-row.clickable{cursor:pointer;transition:all .2s}.session-row.clickable:hover{background:#e0e0e0;transform:translate(4px)}.session-num{color:#999;font-size:.85rem}.session-date{flex:1}.session-score{font-weight:600;padding:4px 12px;border-radius:16px}.session-score.good{background:#e8f5e9;color:#4caf50}.session-score.bad{background:#ffebee;color:#f44336}.session-correct{color:#666}@media(max-width:600px){.stats-grid{grid-template-columns:repeat(2,1fr)}.accuracy-display{flex-direction:column}}.app{min-height:100vh;background:radial-gradient(circle at top left,#e3f2fd 0,#f5f7fa 40%,#fafafa);padding:24px 16px}.app-shell{max-width:1200px;margin:0 auto;background:#fff;border-radius:18px;box-shadow:0 18px 40px #0f172a1f;overflow:hidden;display:flex;flex-direction:column;min-height:calc(100vh - 48px)}.app-header{padding:16px 24px;border-bottom:1px solid rgba(15,23,42,.06);background:linear-gradient(120deg,#1976d2,#42a5f5,#64b5f6);color:#fff;display:flex;justify-content:space-between;align-items:center}.app-header-compact{padding:8px 24px}.app-header-compact .app-brand{gap:8px}.app-logo-small{width:28px;height:28px;font-size:1rem;border-radius:8px}.app-title-small{font-size:1rem}.app-brand{display:flex;align-items:center;gap:12px}.app-logo{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#ffffff29;font-size:1.4rem}.app-title{font-size:1.25rem;font-weight:700;letter-spacing:.02em}.app-subtitle{font-size:.9rem;opacity:.9}.app-header-right{display:flex;align-items:center;gap:12px}.language-switcher{padding:8px 16px;font-size:.9rem;font-weight:600;border:2px solid rgba(0,0,0,.1);border-radius:8px;background:#0000000d;color:#333;cursor:pointer;transition:all .2s}.language-switcher:hover{background:#0000001a;border-color:#0003;transform:scale(1.05)}@media(max-width:768px){.app-header{flex-direction:column;gap:12px;align-items:flex-start}.app-header-right{width:100%;justify-content:space-between}}.app-main{flex:1;padding:24px;background:#f5f7fa;position:relative;overflow:hidden}@keyframes fadeSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes fadeSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-20px)}}.page-transition{animation:fadeSlideIn .3s ease-out forwards}button,.btn,[role=button]{transition:all .2s ease}.home,.quiz-config,.quiz-view,.results,.history,.analytics{animation:fadeSlideIn .3s ease-out}.app-footer{padding:16px 24px;border-top:1px solid rgba(15,23,42,.08);background:#fff}.footer-content{display:flex;justify-content:space-between;align-items:center}.footer-text{font-size:.85rem;color:#666}@media(max-width:480px){.footer-content{flex-direction:column;gap:12px}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@font-face{font-family:Wingdings;src:local("Wingdings")}@font-face{font-family:"Wingdings 2";src:local("Wingdings 2")}@font-face{font-family:"Wingdings 3";src:local("Wingdings 3")}.wingdings{font-family:Wingdings,sans-serif}.wingdings2{font-family:"Wingdings 2",sans-serif}.wingdings3{font-family:"Wingdings 3",sans-serif}
