@import "https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;700;900&family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary:#c0392b;--primary-light:#e74c3c;--primary-dark:#96281b;--accent:#2471a3;--accent-light:#3498db;--accent-dark:#1a5276;--gold:#d4ac0d;--gold-dark:#b8960c;--success:#27ae60;--success-light:#1e8449;--warning:#e67e22;--locked:#9ca3af;--bg-base:#f5f7ff;--bg-surface:#fff;--bg-card:#fff;--bg-card-hover:#f0f4ff;--bg-elevated:#eef2ff;--bg-modal:#0f14328c;--text-primary:#1a1a2e;--text-secondary:#4a5568;--text-muted:#9ca3af;--text-korean:#1a1a2e;--border:#00000014;--border-accent:#c0392b4d;--border-focus:#3498db80;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--shadow-sm:0 1px 4px #00000014, 0 2px 8px #0000000a;--shadow-md:0 4px 16px #0000001a, 0 1px 4px #0000000f;--shadow-lg:0 8px 32px #0000001f, 0 2px 8px #0000000f;--shadow-glow-red:0 4px 20px #c0392b40;--shadow-glow-blue:0 4px 20px #2471a340;--shadow-glow-gold:0 4px 20px #d4ac0d4d;--nav-width:260px;--topbar-height:64px;--transition:all .25s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,Noto Sans KR,sans-serif;line-height:1.6;-webkit-user-select:none!important;user-select:none!important;-webkit-touch-callout:none!important}input,textarea,[contenteditable=true]{-webkit-user-select:text!important;user-select:text!important}@media print{body{display:none!important}}button{cursor:pointer;background:0 0;border:none;font-family:inherit}a{color:inherit;text-decoration:none}ul{list-style:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f0f4ff}::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--nav-width);background:var(--bg-surface);z-index:100;border-right:2px solid #0000000f;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden;box-shadow:2px 0 12px #0000000f}.sidebar-logo{border-bottom:1px solid var(--border);color:inherit;align-items:center;gap:12px;padding:24px 20px;text-decoration:none;transition:opacity .2s;display:flex}.sidebar-logo:hover{opacity:.85}.sidebar-logo .logo-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex;overflow:hidden}.sidebar-logo .logo-icon img{object-fit:contain;width:100%;height:100%}.sidebar-logo .logo-text{letter-spacing:-.5px;font-size:22px;font-weight:800}.sidebar-logo .logo-text span{color:var(--primary-light)}.sidebar-logo .logo-sub{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;white-space:nowrap;margin-top:1px;font-size:10px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex;overflow-y:auto}.nav-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-top:8px;padding:8px 8px 4px;font-size:10px;font-weight:700}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);transition:var(--transition);align-items:center;gap:12px;padding:12px 14px;font-size:14px;font-weight:500;display:flex;position:relative;overflow:hidden}.nav-item:hover{color:var(--primary);background:#fff0ee}.nav-item.active{color:var(--primary);background:linear-gradient(135deg,#c0392b1a,#2471a312);border:1.5px solid #c0392b33;font-weight:700}.nav-item.active:before{content:"";background:linear-gradient(to bottom, var(--primary), var(--accent));border-radius:0 2px 2px 0;width:3px;position:absolute;top:20%;bottom:20%;left:0}.nav-item .nav-icon{flex-shrink:0;font-size:18px}.nav-item .nav-badge{background:var(--primary);color:#fff;border-radius:var(--radius-full);margin-left:auto;padding:2px 7px;font-size:10px;font-weight:700}.sidebar-footer{border-top:2px solid #0000000f;padding:16px 12px}.sidebar-progress{background:var(--bg-elevated);border-radius:var(--radius-md);padding:14px}.sidebar-progress .sp-label{color:var(--text-muted);justify-content:space-between;margin-bottom:8px;font-size:11px;display:flex}.sidebar-progress .sp-label span{color:var(--primary);font-weight:700}.progress-bar-bg{background:#00000014;border-radius:3px;height:6px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--primary), var(--accent));border-radius:3px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.main-content{margin-left:var(--nav-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--topbar-height);z-index:90;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe6;border-bottom:1px solid #00000012;justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 1px 8px #0000000f}.topbar-title{color:var(--text-primary);font-size:18px;font-weight:700}.topbar-title span{color:var(--primary)}.topbar-actions{align-items:center;gap:12px;display:flex}.page-body{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:28px}.card{background:var(--bg-card);border-radius:var(--radius-lg);transition:var(--transition);box-shadow:var(--shadow-sm);border:1px solid #00000012;padding:24px}.card:hover{box-shadow:var(--shadow-md);border-color:#c0392b40;transform:translateY(-1px)}.card-glow{box-shadow:var(--shadow-glow-red)}.btn{border-radius:var(--radius-md);transition:var(--transition);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{background:linear-gradient(135deg, var(--primary-light), var(--primary));box-shadow:var(--shadow-glow-red);transform:translateY(-1px)}.btn-secondary{color:var(--text-primary);background:#fff;border:1.5px solid #0000001f;box-shadow:0 1px 4px #0000000f}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--accent)}.btn-accent{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#fff}.btn-accent:hover{box-shadow:var(--shadow-glow-blue);transform:translateY(-1px)}.btn-gold{background:linear-gradient(135deg, var(--gold), var(--gold-dark));color:#fff;font-weight:700}.btn-gold:hover{box-shadow:var(--shadow-glow-gold);transform:translateY(-1px)}.btn-sm{border-radius:var(--radius-sm);padding:8px 16px;font-size:12px}.btn-lg{border-radius:var(--radius-lg);padding:16px 32px;font-size:16px}.btn-full{width:100%}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.btn-icon{border-radius:var(--radius-md);background:var(--bg-elevated);width:42px;height:42px;color:var(--text-secondary);border:1px solid var(--border);padding:0}.btn-icon:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--accent)}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-success{color:var(--success-light);background:#27ae6033}.badge-warning{color:var(--warning);background:#e67e2233}.badge-locked{color:var(--locked);background:#4a55684d}.badge-gold{color:var(--gold);background:#f1c40f33}.badge-primary{color:var(--primary-light);background:#c0392b33}.ko-text{color:var(--text-korean);font-family:Noto Sans KR,sans-serif;line-height:1.7}.ko-text-lg{font-size:22px;font-weight:700}.ko-text-xl{font-size:26px;font-weight:700}.vi-text{color:var(--text-secondary);background:#fff3e0;border-radius:4px;padding:2px 6px;font-size:14px;font-style:italic;display:inline-block}.progress-container{margin-bottom:24px}.progress-info{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.progress-label{color:var(--text-secondary);font-size:13px;font-weight:500}.progress-value{color:var(--primary-light);font-size:13px;font-weight:700}.progress-track{background:var(--bg-elevated);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--primary), var(--accent));border-radius:4px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.progress-fill:after{content:"";background:linear-gradient(90deg,#0000,#ffffff26,#0000);animation:2s infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.dashboard-header{text-align:center;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);background:linear-gradient(135deg,#c0392b,#2471a3);margin-bottom:40px;padding:40px;position:relative;overflow:hidden}.dashboard-header:before{content:"";background:radial-gradient(#ffffff14 0%,#0000 60%);width:200%;height:200%;animation:4s ease-in-out infinite pulse-glow;position:absolute;top:-50%;left:-50%}@keyframes pulse-glow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.dashboard-header h1{color:#fff;text-shadow:0 2px 8px #0003;margin-bottom:8px;font-size:32px;font-weight:900}.dashboard-header p{color:#ffffffd9;font-size:15px}.dashboard-header .flag{margin-bottom:16px;font-size:40px;display:block}.roadmap{flex-direction:column;align-items:center;gap:0;padding:0 20px;display:flex;position:relative}.roadmap-node-wrapper{align-items:center;width:100%;max-width:600px;min-height:100px;display:flex;position:relative}.roadmap-node-wrapper.right{justify-content:flex-end}.roadmap-connector{z-index:0;width:4px;height:100%}.roadmap-connector.unlocked{background:linear-gradient(to bottom, var(--primary), var(--accent))}.roadmap-connector.locked{background:var(--bg-elevated)}.roadmap-node{cursor:pointer;width:60px;height:60px;transition:var(--transition);z-index:1;box-shadow:var(--shadow-md);background:#fff;border:3px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:22px;display:flex;position:relative}.roadmap-node.unlocked{border-color:var(--primary);box-shadow:0 4px 16px #c0392b33}.roadmap-node.unlocked:hover{transform:scale(1.15);box-shadow:0 6px 24px #c0392b59}.roadmap-node.completed{border-color:var(--gold);background:#fffde7;box-shadow:0 4px 16px #d4ac0d40}.roadmap-node.locked{border-color:var(--locked);cursor:not-allowed;opacity:.5;box-shadow:none}.roadmap-node.trophy{border-color:var(--gold);width:80px;height:80px;box-shadow:var(--shadow-glow-gold);font-size:36px}.roadmap-info{flex:1;max-width:220px;padding:0 20px}.roadmap-info.right{text-align:right;padding-right:20px}.roadmap-info h3{margin-bottom:4px;font-size:15px;font-weight:700}.roadmap-info.locked h3{color:var(--text-muted)}.roadmap-info .chapter-num{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.roadmap-node-btn{border-radius:var(--radius-full);transition:var(--transition);align-items:center;gap:4px;margin-top:6px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.roadmap-node-btn.start{color:var(--primary-light);background:#c0392b33}.roadmap-node-btn.done{color:var(--gold);background:#f1c40f33}.roadmap-node-btn.locked{color:var(--locked);background:#4a556833}.study-progress{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.study-counter{color:var(--text-secondary);font-size:13px}.study-counter strong{color:var(--primary-light);font-size:16px}.qa-card{background:var(--bg-card);border-radius:var(--radius-xl);transition:var(--transition);box-shadow:var(--shadow-sm);border:1px solid #00000012;margin-bottom:16px;padding:28px}.qa-card:hover{box-shadow:var(--shadow-md);border-color:#c0392b33}.qa-card-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.qa-card-header h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:12px;font-weight:700}.qa-card.answer-card{background:#f0fff4;border-color:#27ae6040}.qa-card.answer-card .card-label{color:var(--success)}.tts-btn{background:var(--bg-elevated);border:1px solid var(--border);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex}.tts-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.tts-btn.speaking{background:var(--primary);color:#fff;border-color:var(--primary);animation:1s infinite pulse}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.play-full-btn{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;border-radius:var(--radius-lg);cursor:pointer;width:100%;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:10px;margin-bottom:16px;padding:16px 24px;font-family:inherit;font-size:15px;font-weight:700;display:flex}.play-full-btn:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.next-btn{bottom:0;left:var(--nav-width);background:var(--bg-surface);border-top:1px solid var(--border);z-index:80;justify-content:center;gap:12px;padding:16px 28px;display:flex;position:fixed;right:0}.flashcard-scene{perspective:1200px;cursor:pointer;width:100%;max-width:560px;height:280px;margin:0 auto 24px}.flashcard-card{width:100%;height:100%;transform-style:preserve-3d;transition:transform .55s cubic-bezier(.4,0,.2,1);position:relative}.flashcard-card.flipped{transform:rotateY(180deg)}.fc-face{backface-visibility:hidden;border-radius:var(--radius-xl);text-align:center;box-shadow:var(--shadow-md);flex-direction:column;justify-content:center;align-items:center;padding:28px;display:flex;position:absolute;inset:0}.fc-face.front{background:linear-gradient(150deg,#fff 60%,#fff0ee);border:2px solid #c0392b33}.fc-face.back{background:linear-gradient(150deg,#f0fff4 60%,#e8f5e9);border:2px solid #27ae604d;transform:rotateY(180deg)}.fc-face .flip-hint{color:var(--text-muted);align-items:center;gap:4px;font-size:11px;display:flex;position:absolute;bottom:14px}.fc-controls{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:24px;display:flex}.chapter-select-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:28px;display:grid}.chapter-chip{background:var(--bg-card);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);text-align:center;box-shadow:var(--shadow-sm);border:1.5px solid #00000014;padding:14px}.chapter-chip:hover{box-shadow:var(--shadow-md);border-color:#2471a366;transform:translateY(-2px)}.chapter-chip.active{border-color:var(--primary);background:#fff0ee}.chapter-chip.locked{opacity:.55;cursor:not-allowed}.chapter-chip .chip-num{color:var(--primary);font-size:20px;font-weight:900}.chapter-chip .chip-title{color:var(--text-secondary);margin-top:4px;font-size:12px}.test-timer{color:var(--gold);align-items:center;gap:8px;font-size:24px;font-weight:800;display:flex}.test-timer.urgent{color:var(--primary-light);animation:.5s infinite pulse}.mcq-options{flex-direction:column;gap:12px;margin-top:24px;display:flex}.mcq-option{background:var(--bg-card);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition);text-align:left;color:var(--text-primary);box-shadow:var(--shadow-sm);border:1.5px solid #0000001a;align-items:center;gap:14px;padding:18px 22px;font-family:inherit;display:flex}.mcq-option:hover:not(:disabled){border-color:var(--accent);box-shadow:var(--shadow-md);background:#eff8ff;transform:translate(4px)}.mcq-option.correct{border-color:var(--success);background:#f0fff4}.mcq-option.wrong{border-color:var(--primary);background:#fff5f5}.option-letter{background:var(--bg-elevated);width:34px;height:34px;transition:var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:flex}.mcq-option.correct .option-letter{background:var(--success);color:#fff}.mcq-option.wrong .option-letter{background:var(--primary);color:#fff}.option-text{font-family:Noto Sans KR,sans-serif;font-size:14px;line-height:1.5}.result-screen{text-align:center;padding:40px 20px}.result-score{background:linear-gradient(135deg, var(--primary-light), var(--gold));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:16px 0;font-size:72px;font-weight:900;line-height:1}.result-grade{color:var(--text-secondary);font-size:18px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);text-align:center;transition:var(--transition);box-shadow:var(--shadow-sm);border:1px solid #00000012;padding:20px}.stat-card:hover{box-shadow:var(--shadow-md);border-color:#c0392b33;transform:translateY(-2px)}.stat-card .stat-icon{margin-bottom:8px;font-size:28px;display:block}.stat-card .stat-value{color:var(--primary);font-size:32px;font-weight:900;line-height:1}.stat-card .stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-size:12px;font-weight:600}.chapter-stats-list{flex-direction:column;gap:12px;display:flex}.chapter-stat-row{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid #00000012;padding:16px 20px}.csr-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.csr-title{font-size:14px;font-weight:600}.csr-count{color:var(--text-secondary);font-size:12px}.modal-overlay{background:var(--bg-modal);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{border-radius:var(--radius-xl);background:#fff;border:1px solid #0000001a;width:100%;max-width:480px;padding:32px;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;box-shadow:0 20px 60px #00000026}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.modal-title{font-size:20px;font-weight:800}.page-header{align-items:center;gap:16px;margin-bottom:28px;display:flex}.page-header h1{font-size:26px;font-weight:800}.page-header .page-icon{font-size:32px}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state .empty-icon{opacity:.5;margin-bottom:16px;font-size:56px;display:block}.empty-state p{font-size:15px}.toggle-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 0;display:flex}.toggle-label{font-size:14px;font-weight:500}.toggle-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.toggle-switch{background:var(--bg-elevated);cursor:pointer;border:none;border-radius:13px;flex-shrink:0;width:46px;height:26px;transition:background .25s;position:relative}.toggle-switch.on{background:linear-gradient(135deg, var(--primary), var(--accent))}.toggle-switch:after{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .25s cubic-bezier(.4,0,.2,1);position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0000004d}.toggle-switch.on:after{transform:translate(20px)}.mobile-nav{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border-top:1px solid #00000014;padding:8px 0 12px;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #00000014}.mobile-nav-grid{grid-template-columns:repeat(7,1fr);display:grid}.mobile-nav-item{color:var(--text-muted);transition:var(--transition);cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:3px;padding:8px 2px;font-family:inherit;font-size:9px;font-weight:600;display:flex}.mobile-nav-item.active{color:var(--primary)}.mobile-nav-item .mni-icon{font-size:19px}@media (width<=768px){.sidebar{display:none}.mobile-nav{display:block}.main-content{margin-left:0}.page-body{padding:16px 16px 80px}.topbar{padding:0 16px}.next-btn{padding:12px 16px 20px;left:0}.dashboard-header{padding:24px 16px}.dashboard-header h1{font-size:22px}.stats-grid{grid-template-columns:repeat(2,1fr)}.flashcard-scene{height:220px}}.interview-setup{max-width:760px;margin:0 auto}.interview-hero{border-radius:var(--radius-xl);text-align:center;margin-bottom:28px;padding:48px 32px;position:relative;overflow:hidden}.interview-hero-bg{background:linear-gradient(135deg,#c0392b26,#2471a326);position:absolute;inset:0}.interview-hero-bg:before{content:"";background:radial-gradient(at 30%,#c0392b1f 0%,#0000 60%),radial-gradient(at 70%,#2471a31a 0%,#0000 60%);animation:5s ease-in-out infinite pulse-glow;position:absolute;inset:0}.interview-hero-content{z-index:1;position:relative}.interview-hero-flag{margin-bottom:16px;font-size:52px;animation:3s ease-in-out infinite float;display:block}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.interview-hero h1{letter-spacing:-1px;background:linear-gradient(135deg, var(--primary-light), var(--accent-light), var(--gold));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:10px;font-size:34px;font-weight:900}.interview-hero p{color:var(--text-secondary);margin-bottom:20px;font-size:15px}.interview-hero-badges{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.iv-badge{border-radius:var(--radius-full);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff0f;border:1px solid #ffffff1f;padding:6px 14px;font-size:12px;font-weight:600}.interview-config-grid{flex-direction:column;gap:16px;margin-bottom:16px;display:flex}.iv-config-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.iv-config-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:12px;font-weight:700}.iv-chip-row{flex-wrap:wrap;gap:8px;display:flex}.iv-chip{border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:var(--transition);padding:8px 16px;font-size:13px;font-weight:600}.iv-chip:hover{border-color:var(--accent);color:var(--text-primary)}.iv-chip.active{border-color:var(--primary);color:var(--text-primary);background:linear-gradient(135deg,#c0392b2e,#2471a324);box-shadow:0 0 12px #c0392b33}.iv-available-info{text-align:center;color:var(--text-muted);padding:10px;font-size:13px}.iv-available-info span{color:var(--primary-light);font-size:22px;font-weight:900}.iv-tips{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-top:32px;padding:24px}.iv-tips-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;font-size:13px;font-weight:700}.iv-tips-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.iv-tip-item{align-items:flex-start;gap:12px;display:flex}.iv-tip-item>span{flex-shrink:0;font-size:24px}.iv-tip-item strong{margin-bottom:2px;font-size:13px;font-weight:700;display:block}.iv-tip-item p{color:var(--text-muted);margin:0;font-size:12px;line-height:1.5}.interview-room{flex-direction:column;display:flex}.interview-topbar{align-items:center;gap:16px;margin-bottom:20px;padding:12px 0;display:flex}.iv-tb-center{flex-direction:column;flex:1;gap:6px;display:flex}.iv-tb-progress{background:var(--bg-elevated);border-radius:3px;height:6px;overflow:hidden}.iv-tb-fill{background:linear-gradient(90deg, var(--primary), var(--accent));border-radius:3px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.iv-tb-counter{color:var(--text-muted);font-size:12px;font-weight:600}.iv-session-timer{color:var(--gold);text-align:right;min-width:60px;font-size:16px;font-weight:800}.interview-stage{grid-template-columns:280px 1fr;gap:24px;display:grid}.judge-panel{flex-direction:column;align-items:center;display:flex}.judge-avatar{flex-direction:column;align-items:center;gap:14px;display:flex}.judge-circle{border:3px solid var(--border);width:110px;height:110px;transition:var(--transition);background:linear-gradient(135deg,#c0392b1f,#2471a31f);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.judge-talking .judge-circle{border-color:var(--primary);animation:1s ease-in-out infinite alternate judgeGlow;box-shadow:0 0 28px #c0392b80}@keyframes judgeGlow{0%{box-shadow:0 0 14px #c0392b4d}to{box-shadow:0 0 36px #c0392bb3}}.judge-listening .judge-circle{border-color:var(--accent);animation:1.2s ease-in-out infinite alternate judgeListenGlow}@keyframes judgeListenGlow{0%{box-shadow:0 0 10px #2471a34d}to{box-shadow:0 0 30px #2471a3b3}}.judge-thinking .judge-circle{border-color:var(--gold);animation:3s linear infinite rotateGold}@keyframes rotateGold{0%{border-color:var(--gold)}33%{border-color:var(--primary-light)}66%{border-color:var(--accent-light)}to{border-color:var(--gold)}}.judge-emoji{font-size:52px;line-height:1}.judge-sound-waves{pointer-events:none;border-radius:50%;position:absolute;inset:-14px}.judge-sound-waves span{border:2px solid var(--primary);opacity:0;border-radius:50%;animation:1.4s ease-out infinite soundWave;position:absolute;inset:0}.judge-sound-waves span:nth-child(2){animation-delay:.42s}.judge-sound-waves span:nth-child(3){animation-delay:.84s}@keyframes soundWave{0%{opacity:.7;transform:scale(1)}to{opacity:0;transform:scale(1.55)}}.judge-mic-pulse{border:2px solid var(--accent);border-radius:50%;animation:1.5s ease-in-out infinite micPulse;position:absolute;inset:-10px}@keyframes micPulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.22)}}.judge-nameplate{text-align:center}.judge-name{color:var(--text-primary);font-size:16px;font-weight:800;display:block}.judge-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:3px;font-size:10px;display:block}.speech-bubble{background:var(--bg-card);border:1px solid var(--border-accent);border-radius:var(--radius-lg);opacity:0;border-bottom-left-radius:4px;width:100%;margin-top:18px;padding:16px;transition:opacity .3s,transform .3s;transform:translateY(8px)}.speech-bubble.visible{opacity:1;transform:translateY(0)}.answer-panel{flex-direction:column;gap:16px;display:flex}.iv-question-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);transition:var(--transition);padding:24px}.iv-question-card:hover{border-color:var(--border-accent)}.iv-question-meta{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.iv-cat-badge{border-radius:var(--radius-full);color:var(--accent-light);background:#2471a324;border:1px solid #2471a34d;padding:4px 12px;font-size:12px;font-weight:700}.iv-diff-badge{font-size:12px;font-weight:700}.iv-qtimer{margin-left:auto;font-size:13px;font-weight:700}.iv-hint-btn{color:var(--gold);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:#f1c40f1a;border:1px solid #f1c40f40;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:700}.iv-hint-btn:hover{background:#f1c40f33}.iv-hint-box{border-radius:var(--radius-md);color:var(--text-secondary);background:#f1c40f0f;border:1px solid #f1c40f38;margin-top:10px;padding:12px 16px;font-size:13px;line-height:1.6;animation:.2s slideUp}.iv-answer-area{flex-direction:column;gap:12px;display:flex}.iv-live-transcript{border-radius:var(--radius-md);background:#2471a314;border:1px solid #2471a338;align-items:center;gap:10px;padding:12px 16px;font-size:14px;display:flex}.iv-live-dot{background:var(--accent-light);border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:.8s infinite pulse}.iv-textarea{border-radius:var(--radius-lg);background:var(--bg-elevated);border:1.5px solid var(--border);width:100%;color:var(--text-primary);resize:none;transition:var(--transition);padding:16px;font-family:Noto Sans KR,Inter,sans-serif;font-size:14px;line-height:1.7}.iv-textarea:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #3498db1a}.iv-textarea::placeholder{color:var(--text-muted)}.iv-controls{gap:10px;display:flex}.iv-mic-btn{border-radius:var(--radius-md);cursor:pointer;height:46px;transition:var(--transition);background:var(--bg-elevated);border:1.5px solid var(--border);color:var(--text-primary);align-items:center;gap:8px;padding:0 20px;font-family:inherit;font-size:14px;font-weight:700;display:flex;position:relative;overflow:hidden}.iv-mic-btn:hover{border-color:var(--accent)}.iv-mic-btn.listening{border-color:var(--primary);color:var(--primary-light);background:#c0392b24;animation:1.5s ease-in-out infinite micBtnPulse}@keyframes micBtnPulse{0%,to{box-shadow:0 0 #c0392b66}50%{box-shadow:0 0 0 8px #c0392b00}}.iv-mic-ring{background:var(--primary-light);border-radius:50%;width:10px;height:10px;animation:.8s infinite pulse}.iv-feedback-area{flex-direction:column;display:flex}.iv-score-reveal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);align-items:center;gap:20px;padding:20px 24px;animation:.4s cubic-bezier(.4,0,.2,1) slideUp;display:flex}.iv-score-circle{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;display:flex}.iv-score-inner{background:var(--bg-card);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:62px;height:62px;display:flex}.iv-score-num{font-size:22px;font-weight:900;line-height:1}.iv-score-label{color:var(--text-muted);font-size:10px}.iv-keywords-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.iv-keyword-chip{border-radius:var(--radius-full);padding:4px 10px;font-family:Noto Sans KR,sans-serif;font-size:11px;font-weight:700}.iv-keyword-chip.matched{color:var(--success-light);background:#27ae6024;border:1px solid #27ae6059}.iv-keyword-chip.missed{color:var(--primary-light);background:#c0392b1c;border:1px solid #c0392b47}.iv-your-answer,.iv-model-answer{border-radius:var(--radius-md);padding:14px 16px}.iv-your-answer{background:#2471a312;border:1px solid #2471a333}.iv-model-answer{background:#27ae6012;border:1px solid #27ae6033}.iv-answer-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:700;display:block}.iv-your-answer p,.iv-model-answer p{margin:0;font-size:14px;line-height:1.7}.iv-judge-comment{background:var(--bg-elevated);border-radius:var(--radius-md);color:var(--text-secondary);text-align:center;margin-top:12px;padding:12px 16px;font-family:Noto Sans KR,sans-serif;font-size:13px;line-height:1.6}.interview-result{max-width:860px;margin:0 auto}.iv-result-hero{text-align:center;border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-card);padding:36px 28px;position:relative;overflow:hidden}.iv-result-hero.pass{border-color:#27ae6052}.iv-result-hero.fail{border-color:#c0392b52}.iv-result-emoji{margin-bottom:12px;font-size:56px;display:block}.iv-result-score{background:linear-gradient(135deg, var(--primary-light), var(--gold));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:72px;font-weight:900;line-height:1}.iv-result-label{margin-bottom:10px;font-size:22px;font-weight:800}.iv-result-meta{color:var(--text-secondary);flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin-bottom:12px;font-size:14px;display:flex}.iv-result-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);margin-bottom:14px;padding:20px}.iv-result-row:hover{border-color:var(--border-accent)}.iv-result-row-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.iv-q-num{background:var(--bg-elevated);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:800;display:flex}.iv-q-cat{color:var(--text-secondary);font-size:12px;font-weight:600}.iv-result-score-pill{border-radius:var(--radius-full);padding:4px 12px;font-size:13px;font-weight:800}.iv-answer-compare{grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;display:grid}@media (width<=768px){.interview-stage{grid-template-columns:1fr}.judge-panel{flex-direction:row;align-items:flex-start;gap:16px}.judge-circle{width:80px;height:80px}.judge-emoji{font-size:38px}.speech-bubble{flex:1;margin-top:0}.iv-tips-grid,.iv-answer-compare{grid-template-columns:1fr}.iv-controls{flex-direction:column}.iv-mic-btn{justify-content:center;width:100%}.mobile-nav-grid{grid-template-columns:repeat(6,1fr)}}.card-star-btn{cursor:pointer;width:42px;height:42px;color:var(--text-muted);z-index:20;background:#00000008;border:1px solid #0000000d;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:all .2s cubic-bezier(.175,.885,.32,1.275);display:flex;position:absolute;top:16px;right:16px}.card-star-btn:hover{border-color:var(--gold);background:#00000014;transform:scale(1.15)rotate(15deg)}.card-star-btn.active{color:var(--gold);border-color:var(--gold);background:#d4ac0d1a}.fc-face.back .card-star-btn{color:#fff9;background:#ffffff1a;border-color:#fff3}.fc-face.back .card-star-btn.active{color:var(--gold);background:#ffffff26}.flip-hint{color:var(--text-muted);opacity:.6;margin-top:auto;font-size:11px}html.dark-mode{--bg-base:#0f1117;--bg-surface:#1a1d27;--bg-card:#1e2130;--bg-card-hover:#262a3d;--bg-elevated:#252836;--bg-modal:#000005b3;--text-primary:#e8ecf4;--text-secondary:#9ba3b8;--text-muted:#5d667a;--text-korean:#e8ecf4;--border:#ffffff14;--shadow-sm:0 1px 4px #0000004d, 0 2px 8px #0003;--shadow-md:0 4px 16px #0006, 0 1px 4px #0000004d;--shadow-lg:0 8px 32px #00000080, 0 2px 8px #0000004d}html.dark-mode body{background:var(--bg-base);color:var(--text-primary)}html.dark-mode .sidebar{background:var(--bg-surface);border-right-color:#ffffff0f}html.dark-mode .topbar{background:#1a1d27f2;border-bottom-color:#ffffff0f}html.dark-mode .card,html.dark-mode .qa-card,html.dark-mode .stat-card,html.dark-mode .chapter-stat-row,html.dark-mode .modal-box{background:var(--bg-card);border-color:var(--border)}html.dark-mode .btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:#ffffff1f}html.dark-mode .btn-secondary:hover{background:var(--bg-card-hover)}html.dark-mode .mcq-option{background:var(--bg-card);color:var(--text-primary);border-color:#ffffff1a}html.dark-mode .mcq-option:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--accent)}html.dark-mode .mcq-option.correct{background:#27ae6026}html.dark-mode .mcq-option.wrong{background:#c0392b26}html.dark-mode .option-letter{background:var(--bg-elevated)}html.dark-mode .chapter-chip{background:var(--bg-card);border-color:#ffffff14}html.dark-mode .chapter-chip.active{background:#c0392b26}html.dark-mode .fc-face.front{background:linear-gradient(150deg,#1e2130 60%,#26162a);border-color:#c0392b4d}html.dark-mode .fc-face.back{background:linear-gradient(150deg,#162418 60%,#1a2b1c);border-color:#27ae604d}html.dark-mode .mobile-nav{background:#1a1d27f7;border-top-color:#ffffff0f}html.dark-mode .sidebar-progress{background:var(--bg-elevated)}html.dark-mode .progress-track,html.dark-mode .progress-bar-bg{background:#ffffff14}html.dark-mode .toggle-switch{background:#ffffff1f}html.dark-mode .toggle-switch.on{background:linear-gradient(135deg, var(--primary), var(--accent))}html.dark-mode .nav-item:hover{background:#c0392b1f}html.dark-mode .vi-text{color:#ffc970;background:#ffa0001a}html.dark-mode input,html.dark-mode select,html.dark-mode textarea{background:var(--bg-elevated)!important;color:var(--text-primary)!important;border-color:var(--border)!important}.dark-mode-btn{background:var(--bg-elevated);border:1.5px solid var(--border);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:18px;display:flex}.dark-mode-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-20px)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.confetti-piece{pointer-events:none;z-index:9999;border-radius:2px;width:10px;height:10px;animation:linear forwards confetti-fall;position:fixed}.quick-review-overlay{background:var(--bg-modal);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:300;justify-content:center;align-items:center;padding:20px;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.quick-review-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:560px;box-shadow:var(--shadow-lg);padding:36px;animation:.4s cubic-bezier(.4,0,.2,1) slideUp;position:relative}.quick-review-progress{background:var(--bg-elevated);border-radius:var(--radius-full) var(--radius-full) 0 0;height:4px;position:absolute;top:0;left:0;right:0;overflow:hidden}.quick-review-progress-fill{background:linear-gradient(90deg,var(--primary),var(--accent));height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.share-result-card{border-radius:var(--radius-xl);color:#fff;text-align:center;background:linear-gradient(135deg,#c0392b 0%,#2471a3 100%);padding:32px;position:relative;overflow:hidden}@keyframes achievement-pop{0%{opacity:0;transform:scale(.5)translateY(20px)}60%{opacity:1;transform:scale(1.1)translateY(-5px)}to{opacity:1;transform:scale(1)translateY(0)}}.achievement-toast{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:500;align-items:center;gap:12px;max-width:280px;padding:16px 20px;animation:.5s cubic-bezier(.4,0,.2,1) achievement-pop;display:flex;position:fixed;bottom:100px;right:24px}.countdown-widget{border-radius:var(--radius-lg);background:linear-gradient(135deg,#c0392b14,#2471a314);border:1.5px solid #c0392b33;padding:20px}.countdown-days{background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:48px;font-weight:900;line-height:1}.daily-question-widget{border-radius:var(--radius-lg);background:linear-gradient(135deg,#2471a314,#8e44ad14);border:1.5px solid #2471a333;padding:20px}
