*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-card: rgba(255, 255, 255, .95);--bg-card-hover: rgba(241, 245, 249, 1);--bg-glass: rgba(0, 0, 0, .03);--bg-glass-strong: rgba(0, 0, 0, .06);--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--accent-blue: #0d9488;--accent-purple: #0891b2;--accent-cyan: #0891b2;--accent-green: #10b981;--accent-amber: #d97706;--accent-rose: #e11d48;--gradient-hero: linear-gradient(135deg, #0d9488 0%, #0891b2 55%, #10b981 100%);--gradient-card: linear-gradient(135deg, rgba(13, 148, 136, .06), rgba(8, 145, 178, .06));--gradient-success: linear-gradient(135deg, #059669, #10b981);--gradient-danger: linear-gradient(135deg, #e11d48, #f43f5e);--border-color: rgba(0, 0, 0, .08);--border-hover: rgba(0, 0, 0, .15);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-glow-blue: 0 0 20px rgba(13, 148, 136, .18);--shadow-glow-purple: 0 0 20px rgba(8, 145, 178, .18);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--fs-xs: .75rem;--fs-sm: .85rem;--fs-base: .95rem;--fs-md: 1.05rem;--fs-lg: 1.25rem;--fs-xl: 1.5rem;--fs-2xl: 2rem;--fs-3xl: 2.5rem;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 30%,rgba(13,148,136,.04) 0%,transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(13,148,136,.03) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(8,145,178,.02) 0%,transparent 50%);pointer-events:none;z-index:0}#app{position:relative;z-index:1}a{color:var(--accent-blue);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:1200px;margin:0 auto;padding:0 var(--sp-6)}.glass-card{background:var(--bg-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-normal)}.glass-card:hover{background:var(--bg-card-hover);border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--sp-4) var(--sp-6);position:sticky;top:0;z-index:100;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.app-header .header-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);padding:0 var(--sp-4)}.app-header .logo{display:flex;align-items:center;gap:var(--sp-3);cursor:pointer;text-decoration:none}.app-header .logo-icon{display:inline-flex;align-items:center;filter:drop-shadow(0 2px 6px rgba(13,148,136,.35))}.logo-mark{display:block}.app-header .logo-text{font-family:"Outfit",var(--font-family);font-size:var(--fs-lg);font-weight:600;letter-spacing:.01em;background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-header .nav-back{display:flex;align-items:center;gap:var(--sp-2);color:var(--text-secondary);cursor:pointer;padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:var(--fs-sm);border:none;background:none;font-family:inherit}.app-header .nav-back:hover{color:var(--text-primary);background:var(--bg-glass-strong)}.header-exam-info{display:flex;align-items:center;gap:var(--sp-3)}.header-exam-badge{display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:700;color:var(--accent-blue);background:#0d94881f;border:1px solid rgba(13,148,136,.25)}.hero-section{padding:var(--sp-12) 0 var(--sp-8);text-align:center}.hero-title{font-size:var(--fs-3xl);font-weight:800;line-height:1.2;margin-bottom:var(--sp-4);background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:var(--fs-md);color:var(--text-secondary);max-width:600px;margin:0 auto var(--sp-8);line-height:1.7}.hero-stats{display:flex;justify-content:center;gap:var(--sp-8);flex-wrap:wrap}.hero-stat{display:flex;flex-direction:column;align-items:center;gap:var(--sp-1)}.hero-stat-value{font-size:var(--fs-2xl);font-weight:800;background:linear-gradient(135deg,var(--accent-blue),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-stat-label{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.exam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--sp-6);padding-bottom:var(--sp-12)}.exam-card{position:relative;overflow:hidden;cursor:pointer;padding:0}.exam-card-header{padding:var(--sp-6);display:flex;align-items:flex-start;gap:var(--sp-4)}.exam-card-icon{font-size:2.5rem;flex-shrink:0;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.exam-icon-img{width:56px;height:56px;border-radius:var(--radius-md);object-fit:contain}.exam-card-info{flex:1;min-width:0}.exam-card-vendor{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--sp-1)}.exam-card-vendor svg{flex-shrink:0}.exam-card-title{font-size:var(--fs-xl);font-weight:800;margin-bottom:var(--sp-1)}.exam-card-fullname{font-size:var(--fs-sm);color:var(--text-secondary);margin-bottom:var(--sp-3)}.exam-card-desc{font-size:var(--fs-xs);color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.exam-card-meta{padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3)}.exam-card-badges{display:flex;gap:var(--sp-2);flex-wrap:wrap}.badge{padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-sm);font-size:var(--fs-xs);font-weight:600;background:var(--bg-glass-strong);color:var(--text-secondary);white-space:nowrap}.badge-blue{background:#3b82f626;color:var(--accent-blue)}.badge-purple{background:#0d948826;color:var(--accent-purple)}.badge-green{background:#10b98126;color:var(--accent-green)}.exam-card-btn{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-full);font-size:var(--fs-sm);font-weight:600;color:#fff;border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:var(--gradient-hero)}.exam-card-btn:hover{filter:brightness(1.15);transform:scale(1.03)}.exam-card-progress{padding:0 var(--sp-6) var(--sp-4)}.progress-bar-bg{width:100%;height:4px;background:var(--bg-glass-strong);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow);background:var(--gradient-hero)}.progress-text{display:flex;justify-content:space-between;margin-top:var(--sp-1);font-size:var(--fs-xs);color:var(--text-muted)}.study-layout{display:flex;min-height:calc(100vh - 60px)}.study-sidebar{width:300px;background:var(--bg-secondary);border-right:1px solid var(--border-color);overflow-y:auto;flex-shrink:0;position:sticky;top:60px;height:calc(100vh - 60px);padding:var(--sp-4)}.study-main{flex:1;padding:var(--sp-6);max-width:900px}.sidebar-section{margin-bottom:var(--sp-5)}.sidebar-section-title{font-size:var(--fs-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:var(--sp-2);padding:0 var(--sp-2)}.search-box{position:relative;margin-bottom:var(--sp-4)}.search-input{width:100%;padding:var(--sp-2) var(--sp-3) var(--sp-2) var(--sp-8);background:var(--bg-glass-strong);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--fs-sm);font-family:inherit;outline:none;transition:border-color var(--transition-fast)}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--accent-blue)}.search-icon{position:absolute;left:var(--sp-3);top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:var(--fs-sm);pointer-events:none}.mode-tabs{display:flex;gap:var(--sp-1);background:var(--bg-glass);padding:var(--sp-1);border-radius:var(--radius-md);margin-bottom:var(--sp-4)}.mode-tab{flex:1;padding:var(--sp-2);text-align:center;font-size:var(--fs-sm);font-weight:600;border:none;background:transparent;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-family:inherit}.mode-tab.active{background:var(--accent-blue);color:#fff}.mode-tab:not(.active):hover{color:var(--text-primary);background:var(--bg-glass-strong)}.filter-list{display:flex;flex-direction:column;gap:var(--sp-1)}.filter-item{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);font-size:var(--fs-sm);cursor:pointer;transition:all var(--transition-fast);border:none;background:transparent;color:var(--text-secondary);font-family:inherit;width:100%;text-align:left}.filter-item:hover{background:var(--bg-glass-strong);color:var(--text-primary)}.filter-item.active{background:#3b82f626;color:var(--accent-blue);font-weight:600}.filter-count{font-size:var(--fs-xs);opacity:.7;min-width:24px;text-align:right}.sidebar-progress{padding:var(--sp-3);background:var(--bg-glass);border-radius:var(--radius-md);border:1px solid var(--border-color)}.sidebar-progress-title{font-size:var(--fs-sm);font-weight:600;margin-bottom:var(--sp-2)}.sidebar-progress-bar{height:6px;background:var(--bg-glass-strong);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--sp-1)}.sidebar-progress-fill{height:100%;border-radius:var(--radius-full);background:var(--gradient-success);transition:width var(--transition-slow)}.sidebar-progress-text{font-size:var(--fs-xs);color:var(--text-muted)}.resume-btn{width:100%;margin-top:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--accent-blue);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--fs-xs);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.resume-btn:hover{opacity:.9;box-shadow:var(--shadow-glow-blue)}.reset-btn{width:100%;padding:var(--sp-2) var(--sp-3);background:transparent;color:var(--accent-rose);border:1px solid var(--accent-rose);border-radius:var(--radius-sm);font-size:var(--fs-xs);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.reset-btn:hover{background:#e11d4814;box-shadow:0 0 10px #e11d481a}.question-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--sp-5);overflow:hidden;transition:border-color var(--transition-fast)}.question-card:hover{border-color:var(--border-hover)}.question-header{padding:var(--sp-4) var(--sp-5);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color)}.question-number{font-size:var(--fs-sm);font-weight:700;color:var(--accent-blue)}.question-type-badge{font-size:var(--fs-xs);padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-sm);background:var(--bg-glass-strong);color:var(--text-muted)}.question-actions{display:flex;gap:var(--sp-2);align-items:center}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:var(--fs-base)}.btn-icon:hover{background:var(--bg-glass-strong);color:var(--text-primary)}.btn-icon.bookmarked{color:var(--accent-amber)}.btn-icon.bookmarked .ui-icon{fill:var(--accent-amber)}.question-body{padding:var(--sp-5)}.question-text{font-size:var(--fs-base);line-height:1.8;color:var(--text-primary);margin-bottom:var(--sp-4)}.question-text-ko{font-size:var(--fs-base);line-height:1.8;color:var(--text-primary);margin-bottom:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--bg-glass);border-radius:var(--radius-md);border-left:3px solid var(--accent-cyan)}.question-images{margin:var(--sp-3) 0}.question-images img{max-width:100%;border-radius:var(--radius-md);margin:var(--sp-2) 0}.inline-choice-images{margin:var(--sp-3) 0}.inline-choice-item{display:flex;align-items:flex-start;gap:var(--sp-2);margin-bottom:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--bg-glass);border-radius:var(--radius-md)}.inline-choice-item img{max-width:calc(100% - 40px);border-radius:var(--radius-sm)}.inline-choice-content{flex:1;min-width:0}.inline-choice-content img{max-width:100%}.choice-image{margin:var(--sp-1) 0}.choice-image img{max-width:100%;border-radius:var(--radius-sm)}.question-text-en{font-size:var(--fs-sm);line-height:1.7;color:var(--text-muted);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);background:var(--bg-glass);display:none}.question-text-en.visible{display:block}.choices-list-en{margin-top:var(--sp-3);border-top:1px solid rgba(255,255,255,.1);padding-top:var(--sp-3)}.choice-item-en{display:flex;align-items:flex-start;gap:var(--sp-2);padding:var(--sp-2) 0}.choice-item-en img{max-width:100%}.toggle-lang-btn{font-size:var(--fs-xs);color:var(--accent-blue);cursor:pointer;border:none;background:none;font-family:inherit;padding:var(--sp-1) 0;margin-bottom:var(--sp-3);display:inline-flex;align-items:center;gap:var(--sp-1)}.toggle-lang-btn:hover{text-decoration:underline}.question-text img,.question-body img{max-width:100%;border-radius:var(--radius-md);margin:var(--sp-3) 0}.choices-list{display:flex;flex-direction:column;gap:var(--sp-2);margin-bottom:var(--sp-4)}.choice-item{display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%;font-family:inherit;color:var(--text-primary);font-size:var(--fs-base);line-height:1.6}.choice-item:hover{border-color:var(--accent-blue);background:#3b82f614}.choice-item.selected{border-color:var(--accent-blue);background:#3b82f61f}.choice-item.correct{border-color:var(--accent-green);background:#10b9811f}.choice-item.wrong{border-color:var(--accent-rose);background:#f43f5e1f}.choice-letter{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-size:var(--fs-sm);font-weight:700;flex-shrink:0;background:var(--bg-glass-strong);color:var(--text-secondary);transition:all var(--transition-fast)}.choice-item.selected .choice-letter{background:var(--accent-blue);color:#fff}.choice-item.correct .choice-letter{background:var(--accent-green);color:#fff}.choice-item.wrong .choice-letter{background:var(--accent-rose);color:#fff}.choice-content{flex:1;min-width:0}.choice-text-ko{color:var(--text-primary)}.choice-text-en{font-size:var(--fs-sm);color:var(--text-muted);margin-top:var(--sp-1);display:none}.choice-text-en.visible{display:block}.answer-section{padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border-color);background:var(--bg-glass)}.answer-row{display:flex;gap:var(--sp-4);flex-wrap:wrap;margin-bottom:var(--sp-3)}.answer-badge{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);font-size:var(--fs-sm);font-weight:600}.answer-badge.suggested{background:#10b98126;color:var(--accent-green)}.answer-badge.voted{background:#3b82f626;color:var(--accent-blue)}.answer-badge.voted-count{background:#0d948826;color:var(--accent-purple)}.answer-description{font-size:var(--fs-sm);color:var(--text-secondary);line-height:1.6;padding:var(--sp-3);background:var(--bg-glass);border-radius:var(--radius-md);margin-top:var(--sp-2)}.show-answer-btn{display:block;width:100%;padding:var(--sp-3);border:1px dashed var(--border-color);background:transparent;color:var(--text-secondary);font-size:var(--fs-sm);font-weight:600;text-align:center;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);font-family:inherit}.show-answer-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:#3b82f60d}.explanation-section{padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border-color)}.explanation-content{display:none;padding:var(--sp-4);background:linear-gradient(135deg,#10b98114,#3b82f60d);border-radius:var(--radius-lg);border-left:3px solid var(--accent-green);line-height:1.7;font-size:var(--fs-sm)}.explanation-content.visible{display:block}.explanation-content .exp-h3{font-size:var(--fs-md);font-weight:700;color:var(--accent-green);margin:var(--sp-4) 0 var(--sp-2) 0;padding-bottom:var(--sp-1);border-bottom:1px solid rgba(16,185,129,.2)}.explanation-content .exp-h3:first-child{margin-top:0}.explanation-content .exp-h4{font-size:var(--fs-sm);font-weight:600;color:var(--text-primary);margin:var(--sp-3) 0 var(--sp-1) 0}.explanation-content ul{margin:var(--sp-2) 0;padding-left:var(--sp-4)}.explanation-content li{margin-bottom:var(--sp-1)}.explanation-content code{background:#0d948826;color:var(--accent-purple);padding:1px 6px;border-radius:4px;font-family:SF Mono,Fira Code,monospace;font-size:.9em}.explanation-content strong{color:var(--text-primary);font-weight:600}.explanation-content p{margin:var(--sp-2) 0}.comments-section{padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border-color)}.comments-toggle{display:flex;align-items:center;gap:var(--sp-2);cursor:pointer;border:none;background:none;font-family:inherit;font-size:var(--fs-sm);font-weight:600;color:var(--text-secondary);padding:var(--sp-2) 0;width:100%;text-align:left;transition:color var(--transition-fast)}.comments-toggle:hover{color:var(--text-primary)}.comments-list{margin-top:var(--sp-3);display:flex;flex-direction:column;gap:var(--sp-3);display:none}.comments-list.visible{display:flex}.comment-item{padding:var(--sp-3);background:var(--bg-glass);border-radius:var(--radius-md);border:1px solid var(--border-color)}.comment-header{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2)}.comment-username{font-size:var(--fs-sm);font-weight:600;color:var(--accent-cyan)}.comment-upvotes{font-size:var(--fs-xs);color:var(--accent-amber);font-weight:600}.comment-badges{display:flex;gap:var(--sp-1)}.comment-badge{font-size:10px;padding:1px 6px;border-radius:var(--radius-sm);background:#0d948826;color:var(--accent-purple);font-weight:600}.comment-badge.highly-voted{background:#f59e0b26;color:var(--accent-amber)}.comment-content{font-size:var(--fs-sm);color:var(--text-secondary);line-height:1.6;white-space:pre-wrap;word-break:break-word}.comment-date{font-size:var(--fs-xs);color:var(--text-muted);margin-top:var(--sp-2)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-6) 0;flex-wrap:wrap}.pagination-top{position:sticky;top:60px;z-index:10;background:var(--bg-glass-strong);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-color);margin:calc(-1 * var(--sp-6)) calc(-1 * var(--sp-6)) var(--sp-6) calc(-1 * var(--sp-6));padding:var(--sp-3) var(--sp-6);box-shadow:0 4px 20px #00000026;transition:all var(--transition-normal)}@media(max-width:768px){.pagination-top{margin:calc(-1 * var(--sp-3)) calc(-1 * var(--sp-3)) var(--sp-4) calc(-1 * var(--sp-3));padding:var(--sp-2) var(--sp-3)}}.page-btn{min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:var(--fs-sm);font-weight:600;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-family:inherit;padding:0 var(--sp-2)}.page-btn:hover:not(:disabled){border-color:var(--accent-blue);color:var(--accent-blue)}.page-btn.active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.page-btn:disabled{opacity:.4;cursor:not-allowed}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:var(--sp-4)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:var(--fs-sm);color:var(--text-muted)}.empty-state{text-align:center;padding:var(--sp-12) var(--sp-6);color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:var(--sp-4)}.empty-state-title{font-size:var(--fs-lg);font-weight:600;margin-bottom:var(--sp-2);color:var(--text-secondary)}.empty-state-text{font-size:var(--fs-sm)}.mobile-menu-btn{display:none;border:none;background:var(--bg-glass-strong);color:var(--text-primary);padding:var(--sp-2);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--fs-md)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:199;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sidebar-overlay.open{display:block}.app-footer{text-align:center;padding:var(--sp-8) var(--sp-6);color:var(--text-muted);font-size:var(--fs-xs);border-top:1px solid var(--border-color)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-glass-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}@media(max-width:1024px){.exam-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.study-main{max-width:100%}}@media(max-width:768px){.mobile-menu-btn{display:flex}.app-header{padding:var(--sp-3) var(--sp-4)}.app-header .logo-text{font-size:var(--fs-md)}.app-header .logo-icon{font-size:1.2rem}.header-exam-badge,.app-header .nav-back{font-size:var(--fs-xs);padding:var(--sp-1) var(--sp-2)}.study-sidebar{display:none;position:fixed;left:0;top:0;bottom:0;z-index:200;width:280px;box-shadow:var(--shadow-lg);padding-top:var(--sp-6)}.study-sidebar.open{display:block}.study-main{padding:var(--sp-3);max-width:100%}.question-card{border-radius:var(--radius-md)}.question-header{padding:var(--sp-3);flex-wrap:wrap;gap:var(--sp-2)}.question-number{font-size:var(--fs-md)}.question-body{padding:var(--sp-3)}.question-text-ko,.question-text{font-size:var(--fs-base);line-height:1.7}.choice-item{padding:var(--sp-3);min-height:44px}.choice-letter{width:28px;height:28px;font-size:var(--fs-xs);flex-shrink:0}.choice-text-ko{font-size:var(--fs-sm)}.answer-section{padding:var(--sp-3)}.answer-row{flex-direction:column;gap:var(--sp-2)}.answer-badge{font-size:var(--fs-sm)}.explanation-section{padding:var(--sp-3)}.explanation-content{padding:var(--sp-3);font-size:var(--fs-sm)}.comments-section{padding:var(--sp-3)}.comment-content{font-size:var(--fs-sm)}.show-answer-btn{font-size:var(--fs-sm);padding:var(--sp-3)}.toggle-lang-btn{font-size:var(--fs-xs)}.question-body img,.answer-section img,.explanation-content img,.question-images img,.inline-choice-images img{max-width:100%;height:auto}.pagination{gap:var(--sp-1);padding:var(--sp-4) 0}.page-btn{min-width:32px;height:32px;font-size:var(--fs-xs)}.hero-title{font-size:var(--fs-2xl)}.hero-subtitle{font-size:var(--fs-sm)}.exam-grid{grid-template-columns:1fr;gap:var(--sp-4)}.exam-card-body{padding:var(--sp-4)}}@media(max-width:480px){.app-header{padding:var(--sp-2) var(--sp-3)}.app-header .logo-text{font-size:var(--fs-base)}.header-exam-info{gap:var(--sp-2)}.header-exam-badge{font-size:.7rem}.study-sidebar{width:100%}.study-main{padding:var(--sp-2)}.question-header,.question-body{padding:var(--sp-2) var(--sp-3)}.question-text-ko,.question-text{font-size:var(--fs-sm)}.choice-item{padding:var(--sp-2) var(--sp-3);gap:var(--sp-2)}.choice-letter{width:24px;height:24px;font-size:.7rem}.answer-section,.explanation-section,.comments-section,.explanation-content{padding:var(--sp-2) var(--sp-3)}.exp-h3,.exp-h4{font-size:var(--fs-sm)}.page-btn{min-width:28px;height:28px;font-size:.7rem}.hero-stats{gap:var(--sp-4)}.container{padding:0 var(--sp-3)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-normal) ease forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp var(--transition-slow) ease forwards}.non-choice-actions{display:flex;justify-content:center;margin-top:var(--sp-6)}.mark-solved-btn{padding:var(--sp-3) var(--sp-6);background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--fs-base);font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--sp-2);box-shadow:var(--shadow-sm)}.mark-solved-btn:hover{background:var(--bg-hover);border-color:var(--accent-blue);box-shadow:var(--shadow-md)}.mark-solved-btn.solved{background:var(--accent-green);color:#fff;border-color:var(--accent-green)}.mark-solved-btn.solved:hover{background:#047857;border-color:#047857}.explanation-content table{width:100%;border-collapse:collapse;margin:var(--sp-4) 0;font-size:var(--fs-sm);background:var(--bg-card)}.explanation-content th,.explanation-content td{padding:var(--sp-3);border:1px solid var(--border-color);text-align:left}.explanation-content th{background:var(--bg-glass-strong);font-weight:600;color:var(--text-primary)}.explanation-content tr:nth-child(2n){background:var(--bg-glass)}.custom-dialog-overlay{position:fixed;inset:0;background:#0f172a66;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;transition:opacity var(--transition-normal)}.custom-dialog-overlay.fade-in{opacity:1}.custom-dialog-overlay.fade-out{opacity:0}.custom-dialog-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:90%;max-width:420px;box-shadow:var(--shadow-lg);overflow:hidden;transform:scale(.9) translateY(20px);transition:transform var(--transition-normal)}.custom-dialog-overlay.fade-in .custom-dialog-card{transform:scale(1) translateY(0)}.custom-dialog-overlay.fade-out .custom-dialog-card{transform:scale(.9) translateY(20px)}.custom-dialog-header{padding:var(--sp-4) var(--sp-5) var(--sp-2) var(--sp-5)}.custom-dialog-title{font-size:var(--fs-md);font-weight:700;color:var(--text-primary)}.custom-dialog-body{padding:var(--sp-3) var(--sp-5) var(--sp-5) var(--sp-5);font-size:var(--fs-sm);color:var(--text-secondary);line-height:1.6}.custom-dialog-footer{display:flex;justify-content:flex-end;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);background:var(--bg-secondary);border-top:1px solid var(--border-color)}.custom-dialog-btn{padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-sm);font-size:var(--fs-xs);font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:none;font-family:inherit}.custom-dialog-btn.confirm-btn{background:var(--accent-blue);color:#fff}.custom-dialog-btn.confirm-btn:hover{opacity:.9}.custom-dialog-btn.confirm-btn.danger{background:var(--accent-rose)}.custom-dialog-btn.cancel-btn{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.custom-dialog-btn.cancel-btn:hover{background:var(--bg-glass-strong);color:var(--text-primary)}body.dark-theme{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: rgba(30, 41, 59, .95);--bg-card-hover: rgba(51, 65, 85, 1);--bg-glass: rgba(255, 255, 255, .03);--bg-glass-strong: rgba(255, 255, 255, .08);--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #64748b;--border-color: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .15)}body.dark-theme:before{background:radial-gradient(ellipse at 20% 30%,rgba(13,148,136,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(13,148,136,.1) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(8,145,178,.05) 0%,transparent 50%)}.setting-select,.setting-checkbox{transition:all var(--transition-fast)}.setting-select:focus{border-color:var(--accent-blue)!important}.notepad-textarea{transition:all var(--transition-fast)}.notepad-textarea:focus{border-color:var(--accent-purple)!important;box-shadow:0 0 10px #0d948826}.stat-badge{font-size:var(--fs-xs);padding:2px 8px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;gap:4px;font-weight:600;transition:all var(--transition-fast)}.stat-badge.correct{background:#0596691a;color:var(--accent-green)}.stat-badge.wrong{background:#e11d481a;color:var(--accent-rose)}.btn-icon.has-note{color:var(--accent-purple)!important;animation:pulse-note 2s infinite ease-in-out}@keyframes pulse-note{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.notepad-section{animation:slide-down .25s ease-out}@keyframes slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notepad-clear-btn{transition:all var(--transition-fast)}.notepad-clear-btn:hover{opacity:.8;text-decoration:underline}.sidebar-section-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:var(--sp-2) var(--sp-1);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.sidebar-section-header:hover{background:var(--bg-glass)}.sidebar-section-title{margin-bottom:0!important}.sidebar-section-arrow{width:6px;height:6px;border-right:1.5px solid var(--text-muted);border-bottom:1.5px solid var(--text-muted);transform:rotate(-45deg);transition:transform var(--transition-normal);display:inline-block;vertical-align:middle;margin-right:8px;margin-top:-2px}.sidebar-section-arrow.expanded{transform:rotate(45deg)}.sidebar-section-content{margin-top:var(--sp-2);transition:max-height var(--transition-normal),opacity var(--transition-normal)}.sidebar-section-content.collapsed{display:none}.setting-select{appearance:none;background-repeat:no-repeat;background-position:right 8px center;background-size:14px;padding-right:28px!important;cursor:pointer;transition:all var(--transition-fast)}body:not(.dark-theme) .setting-select{background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}body.dark-theme .setting-select{background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23cbd5e1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}.setting-checkbox{appearance:none;width:18px;height:18px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-glass-strong);cursor:pointer;position:relative;transition:all var(--transition-fast)}.setting-checkbox:checked{background:var(--accent-blue);border-color:var(--accent-blue)}body.dark-theme .setting-checkbox:checked{background:var(--accent-purple);border-color:var(--accent-purple)}.setting-checkbox:checked:after{content:"";position:absolute;top:3px;left:6px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.theme-toggle-switch{display:flex;background:var(--bg-glass-strong);padding:3px;border-radius:var(--radius-full);border:1px solid var(--border-color);gap:2px}.theme-toggle-btn{flex:1;border:none;background:transparent;padding:var(--sp-1) var(--sp-3);font-size:var(--fs-sm);border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all var(--transition-fast);color:var(--text-muted)}.theme-toggle-btn.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}body.dark-theme .theme-toggle-btn.active{background:var(--bg-secondary)}.toggle-notes-btn{transition:all var(--transition-fast)}.toggle-notes-btn.has-note{border-color:var(--accent-purple)!important;background:#0d948814!important;color:var(--accent-purple)!important;animation:pulse-note-btn 2.5s infinite ease-in-out}@keyframes pulse-note-btn{0%{box-shadow:0 0 #0d948833}70%{box-shadow:0 0 0 6px #0d948800}to{box-shadow:0 0 #0d948800}}.quiz-setup-card{padding:var(--sp-6);text-align:center;max-width:500px;margin:var(--sp-12) auto;border-radius:var(--radius-lg)}.quiz-setup-title{font-size:var(--fs-xl);font-weight:800;margin-bottom:var(--sp-2)}.quiz-setup-desc{font-size:var(--fs-sm);color:var(--text-secondary);margin-bottom:var(--sp-6);line-height:1.6}.quiz-config-group{display:flex;flex-direction:column;gap:var(--sp-2);max-width:300px;margin:0 auto var(--sp-6) auto;text-align:left}.quiz-config-label{font-size:var(--fs-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.quiz-start-btn{background:var(--accent-blue);color:#fff;border:none;font-weight:700;font-size:var(--fs-base);padding:var(--sp-3) var(--sp-8);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.quiz-start-btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:var(--shadow-glow-blue)}body.dark-theme .quiz-start-btn{background:var(--accent-purple)}body.dark-theme .quiz-start-btn:hover{box-shadow:var(--shadow-glow-purple)}.quiz-header-panel{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-3) var(--sp-4);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--sp-4)}.quiz-timer-badge{font-weight:700;font-size:var(--fs-sm);padding:4px 12px;border-radius:var(--radius-full);background:#d9770626;color:var(--accent-amber);display:flex;align-items:center;gap:4px}.quiz-timer-badge.warning{background:#e11d4826;color:var(--accent-rose);animation:pulse-timer 1s infinite alternate}@keyframes pulse-timer{0%{opacity:1}to{opacity:.6}}.quiz-submit-btn{background:var(--accent-rose);color:#fff;border:none;font-weight:700;font-size:var(--fs-xs);padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.quiz-submit-btn:hover{opacity:.9}.quiz-nav-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--sp-2);padding:var(--sp-2)}.quiz-nav-btn{width:36px;height:36px;border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--bg-glass);color:var(--text-secondary);font-size:var(--fs-xs);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--transition-fast)}.quiz-nav-btn:hover{background:var(--bg-glass-strong);color:var(--text-primary)}.quiz-nav-btn.active{border-color:var(--accent-blue);color:var(--accent-blue);font-weight:700;box-shadow:0 0 0 2px #0d948833}body.dark-theme .quiz-nav-btn.active{border-color:var(--accent-purple);color:var(--accent-purple);box-shadow:0 0 0 2px #0d948833}.quiz-nav-btn.answered{background:#0d94881a;border-color:var(--accent-blue);color:var(--accent-blue)}body.dark-theme .quiz-nav-btn.answered{background:#0d94881a;border-color:var(--accent-purple);color:var(--accent-purple)}.quiz-nav-btn.flagged:after{content:"🚩";position:absolute;top:-4px;right:-4px;font-size:10px}.quiz-results-card{padding:var(--sp-8);text-align:center;max-width:600px;margin:var(--sp-8) auto;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-card)}.quiz-results-score-circle{width:140px;height:140px;border-radius:var(--radius-full);margin:var(--sp-6) auto;display:flex;flex-direction:column;align-items:center;justify-content:center;border:8px solid var(--border-color);position:relative;transition:all var(--transition-slow)}.quiz-results-score-circle.pass{border-color:var(--accent-green);box-shadow:0 0 25px #05966933}.quiz-results-score-circle.fail{border-color:var(--accent-rose);box-shadow:0 0 25px #e11d4833}.quiz-score-val{font-size:var(--fs-3xl);font-weight:800}.quiz-score-label{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase}.quiz-results-badge{font-size:var(--fs-base);font-weight:800;padding:6px 20px;border-radius:var(--radius-full);color:#fff;display:inline-block;margin-bottom:var(--sp-4)}.quiz-results-badge.pass{background:var(--gradient-success)}.quiz-results-badge.fail{background:var(--gradient-danger)}.quiz-review-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);margin:var(--sp-6) 0;font-size:var(--fs-sm);background:var(--bg-glass)}body.dark-theme .mode-tab.active{background:var(--accent-purple);color:#fff}body.dark-theme .filter-item.active{background:#0d948826;color:var(--accent-purple)}body.dark-theme .choice-item.selected{border-color:var(--accent-purple);background:#0d94881f}body.dark-theme .choice-item.selected .choice-letter{background:var(--accent-purple);color:#fff}body.dark-theme .choice-item:hover:not(.correct):not(.wrong):not(.selected){border-color:var(--accent-purple);background:#0d948814}.setting-select option{background-color:var(--bg-secondary);color:var(--text-primary)}.memo-popover{position:absolute;background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--sp-3);box-shadow:var(--shadow-lg);z-index:2000;display:flex;flex-direction:column;box-sizing:border-box;opacity:0;transform:translateY(8px);transition:opacity .2s ease,transform .2s ease}.memo-popover.fade-in{opacity:1;transform:translateY(0)}.memo-popover.fade-out{opacity:0;transform:translateY(8px);pointer-events:none}.memo-popover-arrow{position:absolute;top:-6px;width:10px;height:10px;background:var(--bg-card);border-left:1px solid var(--border-color);border-top:1px solid var(--border-color);transform:rotate(45deg);box-sizing:border-box}body.dark-theme .memo-popover-arrow{background:var(--bg-card)}.ui-icon{display:inline-block;vertical-align:-.15em;flex-shrink:0}.ui-icon.flip-x{transform:scaleX(-1)}.app-header .header-inner{display:flex;align-items:center;gap:var(--sp-3)}.header-center{display:flex;align-items:center;gap:var(--sp-2);flex:1;min-width:0;overflow:hidden}.header-actions{display:flex;align-items:center;gap:var(--sp-2);margin-left:auto}.header-icon-btn{display:inline-flex;align-items:center;justify-content:center;gap:2px;width:38px;height:38px;padding:0;border:1px solid transparent;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.header-icon-btn:hover{background:var(--bg-glass-strong);color:var(--text-primary)}#headerMenuBtn{width:auto;padding:0 var(--sp-2)}.menu-caret{opacity:.6}.theme-icon-dark,body.dark-theme .theme-icon-light{display:none}body.dark-theme .theme-icon-dark{display:inline-block}.header-menu{position:relative}.header-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;padding:var(--sp-1);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50}.header-dropdown[hidden]{display:none}.header-dropdown-item{display:flex;align-items:center;gap:var(--sp-2);width:100%;padding:var(--sp-2) var(--sp-3);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font-size:var(--fs-sm);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.header-dropdown-item:hover{background:var(--bg-glass-strong)}.header-dropdown-item.danger{color:var(--accent-rose)}.header-dropdown-item[hidden]{display:none}.header-context-link{display:inline-flex;align-items:center;gap:4px;padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--fs-sm);text-decoration:none;white-space:nowrap;transition:background var(--transition-fast),color var(--transition-fast)}.header-context-link:hover{background:var(--bg-glass-strong);color:var(--text-primary)}.header-exam-icon{width:18px;height:18px;vertical-align:middle;margin-right:4px;border-radius:3px}.toast-container{position:fixed;bottom:var(--sp-5);right:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-2);z-index:1000;pointer-events:none}.toast{display:flex;align-items:center;gap:var(--sp-2);min-width:240px;max-width:360px;padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);color:var(--text-primary);font-size:var(--fs-sm);cursor:pointer;pointer-events:auto;opacity:0;transform:translateY(12px);transition:opacity var(--transition-normal),transform var(--transition-normal)}.toast.show{opacity:1;transform:translateY(0)}.toast.hide{opacity:0;transform:translateY(12px)}.toast-icon{display:inline-flex;flex-shrink:0}.toast-success .toast-icon{color:var(--accent-green)}.toast-error .toast-icon{color:var(--accent-rose)}.toast-info .toast-icon{color:var(--accent-blue)}.toast-message{line-height:1.4}.more-filters-toggle{display:flex;align-items:center;justify-content:space-between;margin:var(--sp-1) var(--sp-2) 0;padding:var(--sp-2);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);font-size:var(--fs-xs);transition:background var(--transition-fast)}.more-filters-toggle:hover{background:var(--bg-glass);color:var(--text-secondary)}.more-filters-label{font-weight:600}.sidebar-tools{margin-top:var(--sp-3);padding-top:var(--sp-3);border-top:1px solid var(--border-color)}.sidebar-toolbar{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-1);padding:0 var(--sp-2)}.tool-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--sp-2) 0;border:1px solid transparent;border-radius:var(--radius-md);background:transparent;color:var(--text-muted);font-size:11px;cursor:pointer;transition:all var(--transition-fast)}.tool-btn:hover{background:var(--bg-glass);color:var(--text-secondary)}.tool-btn.active{background:var(--bg-glass-strong);color:var(--accent-blue);border-color:var(--border-color)}.tool-btn-label{line-height:1}.tool-panel{padding:var(--sp-3) var(--sp-2) 0}.tool-panel-title{font-size:var(--fs-xs);font-weight:700;color:var(--text-muted);margin-bottom:var(--sp-2);padding-left:var(--sp-1)}.settings-box{display:flex;flex-direction:column;gap:var(--sp-2)}.setting-item{display:flex;justify-content:space-between;align-items:center;font-size:var(--fs-sm);color:var(--text-secondary)}.setting-select{padding:4px 28px 4px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background-color:var(--bg-glass-strong);color:var(--text-primary);outline:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);border:1px solid transparent;border-radius:var(--radius-md);font-size:var(--fs-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover{opacity:.9}.btn-secondary{background:var(--bg-glass-strong);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover{background:var(--bg-card-hover)}.empty-state-action{margin-top:var(--sp-4)}.empty-state .ui-icon{color:var(--text-muted)}@media(max-width:768px){.app-header .header-inner{gap:var(--sp-2)}.header-center{gap:var(--sp-1);flex:1;justify-content:flex-end}.header-center .header-exam-badge{display:none}.header-context-link{padding:var(--sp-1)}.mobile-menu-btn{display:inline-flex;align-items:center;justify-content:center}}@media(max-width:640px){.header-exam-badge{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.admin-menu-item{margin-bottom:var(--sp-2)}.admin-menu-item.disabled{opacity:.5;cursor:not-allowed}.admin-main{padding-top:var(--sp-10);max-width:800px}.admin-page-header{margin-bottom:var(--sp-8);padding:var(--sp-3) 0}.admin-page-title{font-size:var(--fs-xl);text-align:left;font-weight:800;color:var(--text-primary);margin-bottom:var(--sp-2)}.admin-page-desc{text-align:left;font-size:var(--fs-sm);margin-bottom:0;color:var(--text-secondary)}.admin-card{padding:var(--sp-6)}.admin-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-5)}.admin-card-title{margin:0;font-size:var(--fs-md)}.admin-create-form{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-6)}.admin-email-input{flex:1;padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-glass-strong);color:var(--text-primary)}.admin-create-btn{margin:0;padding:var(--sp-2) var(--sp-5)}.admin-error{text-align:left;margin-bottom:var(--sp-2)}.admin-table-container{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;text-align:left;font-size:var(--fs-sm)}.admin-table thead tr,.admin-table tbody tr{border-bottom:1px solid var(--border-color)}.admin-table th{padding:var(--sp-3);font-weight:600;color:var(--text-muted)}.admin-table th.col-date{width:100px}.admin-table th.col-actions{text-align:right;width:80px}.admin-table td{padding:var(--sp-3)}.admin-table td.cell-muted{color:var(--text-muted)}.admin-table td.cell-actions{text-align:right;white-space:nowrap}.admin-table-msg{text-align:center;padding:var(--sp-8);color:var(--text-muted)}.admin-table-msg.error{color:var(--accent-rose)}.badge.badge-admin{background:#0d948821;color:var(--accent-purple);margin-left:var(--sp-1)}.badge.badge-status-confirmed{background:#05966921;color:var(--accent-green)}.badge.badge-status-pending{background:#d9770621;color:var(--accent-amber)}.admin-action-btn{padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--fs-xs);margin-right:var(--sp-1);border:1px solid transparent;background:transparent}.admin-action-btn.grant{color:var(--accent-blue);border-color:var(--accent-blue)}.admin-action-btn.revoke{color:var(--accent-purple);border-color:var(--accent-purple)}.admin-action-btn.delete{background:var(--accent-rose);color:#fff;padding:var(--sp-1) var(--sp-3)}.quiz-config-select{width:100%;padding:var(--sp-2) var(--sp-6) var(--sp-2) var(--sp-3);border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-glass-strong);color:var(--text-primary);outline:none}.quiz-nav-progress{font-size:var(--fs-xs);color:var(--text-secondary);text-align:center;margin-top:var(--sp-2)}.quiz-exit-btn{width:100%}.quiz-config-hint{margin-top:var(--sp-2);font-size:var(--fs-xs);color:var(--text-muted)}.floating-pager{position:fixed;bottom:var(--sp-6);left:50%;transform:translate(-50%) translateY(12px);display:flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:90;opacity:0;pointer-events:none;transition:opacity var(--transition-normal),transform var(--transition-normal)}.floating-pager.visible{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.floating-pager-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.floating-pager-btn:hover:not(:disabled){background:var(--bg-glass-strong);color:var(--text-primary)}.floating-pager-btn:disabled{opacity:.3;cursor:default}.floating-pager-label{font-size:var(--fs-sm);font-weight:600;color:var(--text-primary);padding:0 var(--sp-2);min-width:48px;text-align:center;font-variant-numeric:tabular-nums}.floating-pager-btn .rot-90{transform:rotate(90deg)}.floating-pager-btn .rot-270{transform:rotate(-90deg)}.hero-section{padding:var(--sp-10) 0 var(--sp-6)}.home-layout{max-width:1200px;margin:0 auto;padding:0 var(--sp-6);display:grid;grid-template-columns:240px 1fr;gap:var(--sp-6);align-items:start}.home-sidebar{position:sticky;top:88px;display:flex;flex-direction:column;gap:var(--sp-5)}.home-search.search-box{display:flex;align-items:center;gap:var(--sp-2);padding:0 var(--sp-3);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md)}.home-search .search-icon{position:static;transform:none;color:var(--text-muted);display:flex;flex-shrink:0}.home-search .search-input{flex:1;min-width:0;border:none;background:transparent;outline:none;padding:var(--sp-3) 0;font-size:var(--fs-sm);color:var(--text-primary);font-family:inherit}.filter-block-title{font-size:var(--fs-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--sp-2)}.filter-checkbox{display:flex;align-items:center;gap:var(--sp-2);padding:5px 0;cursor:pointer;font-size:var(--fs-sm);color:var(--text-secondary)}.filter-checkbox input{position:absolute;opacity:0;pointer-events:none}.filter-checkbox-box{width:18px;height:18px;flex-shrink:0;border:1px solid var(--border-color);border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;color:transparent;background:var(--bg-card);transition:all var(--transition-fast)}.filter-checkbox:hover .filter-checkbox-box{border-color:var(--accent-blue)}.filter-checkbox input:checked+.filter-checkbox-box{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.filter-checkbox-label{flex:1}.filter-checkbox input:checked~.filter-checkbox-label{color:var(--text-primary);font-weight:600}.filter-checkbox-count{font-size:var(--fs-xs);color:var(--text-muted)}.filter-reset{width:100%;justify-content:center}.home-main{min-width:0}.section-label{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);font-weight:700;color:var(--text-secondary);margin-bottom:var(--sp-3)}.section-label .ui-icon{color:var(--accent-blue)}.continue-section{margin-bottom:var(--sp-6)}.continue-row{display:flex;gap:var(--sp-3);overflow-x:auto;padding-bottom:var(--sp-2)}.continue-card{display:flex;align-items:center;gap:var(--sp-3);min-width:260px;flex:0 0 auto;padding:var(--sp-3) var(--sp-4);border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-card);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.continue-card:hover{border-color:var(--accent-blue);transform:translateY(-2px);box-shadow:var(--shadow-md)}.continue-icon{flex-shrink:0;font-size:1.8rem;line-height:1}.continue-icon-img{width:40px;height:40px;object-fit:contain}.continue-info{flex:1;min-width:0}.continue-title{font-weight:700;font-size:var(--fs-base);margin-bottom:5px;color:var(--text-primary)}.continue-bar-bg{height:5px;background:var(--bg-glass-strong);border-radius:99px;overflow:hidden}.continue-bar-fill{height:100%;background:var(--gradient-hero);border-radius:99px}.continue-pct{font-size:var(--fs-xs);color:var(--text-muted);margin-top:4px}.continue-arrow{color:var(--text-muted);flex-shrink:0;display:flex}.continue-card:hover .continue-arrow{color:var(--accent-blue)}.results-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4);gap:var(--sp-3)}.result-count{font-size:var(--fs-sm);color:var(--text-muted);font-weight:600}.sort-control{position:relative;display:inline-flex;align-items:center;gap:var(--sp-2);padding:0 calc(var(--sp-6) + 2px) 0 var(--sp-3);height:38px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);cursor:pointer;transition:border-color var(--transition-fast)}.sort-control:hover{border-color:var(--accent-blue)}.sort-control:focus-within{border-color:var(--accent-blue);box-shadow:0 0 0 3px #0d94881f}.sort-icon{color:var(--text-muted);display:flex;flex-shrink:0}.sort-control:hover .sort-icon,.sort-control:focus-within .sort-icon{color:var(--accent-blue)}.sort-select{appearance:none;-webkit-appearance:none;border:none;background:transparent;outline:none;color:var(--text-primary);font-size:var(--fs-sm);font-family:inherit;font-weight:600;cursor:pointer;padding:0}.sort-caret{position:absolute;right:var(--sp-2);pointer-events:none;color:var(--text-muted);display:flex}.sort-control:hover .sort-caret,.sort-control:focus-within .sort-caret{color:var(--accent-blue)}.home-main .exam-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}@media(max-width:860px){.home-layout{grid-template-columns:1fr}.home-sidebar{position:static}}.home-hero{max-width:1200px;margin:0 auto;padding:var(--sp-8) var(--sp-6) var(--sp-5)}.home-hero-title{font-size:var(--fs-2xl);font-weight:800;line-height:1.2;margin-bottom:var(--sp-2);background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-hero-subtitle{font-size:var(--fs-base);color:var(--text-secondary)}.question-exhibit{margin:var(--sp-3) 0;padding:var(--sp-2);background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow-x:auto}.question-exhibit img{max-width:100%;height:auto;display:block}
