.join-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#175093;padding:24px 16px;gap:24px}.join-logo{text-align:center}.join-logo-text{font-size:48px;font-weight:900;color:#fff;letter-spacing:4px;line-height:1}.join-logo-sub{font-size:14px;color:#fff9;letter-spacing:2px;text-transform:uppercase;margin-top:4px}.join-card{background:#fff;border-radius:20px;padding:40px 32px;width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 20px 60px #0000004d}.join-title{font-size:28px;font-weight:800;color:var(--navy);margin:0;text-align:center}.join-sub{font-size:15px;color:var(--muted);margin:0;text-align:center}.join-input{width:100%;box-sizing:border-box;padding:16px 20px;font-size:18px;border:2px solid #e5e7eb;border-radius:12px;outline:none;transition:border-color .2s;text-align:center}.join-input:focus{border-color:var(--navy)}.pin-input{font-size:36px;font-weight:700;letter-spacing:8px;color:var(--navy)}.join-error{font-size:14px;color:var(--red);text-align:center;padding:8px 12px;background:#fef2f2;border-radius:8px;width:100%;box-sizing:border-box}.join-btn{width:100%;padding:16px;background:var(--red);color:#fff;border:none;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;transition:background .2s,transform .1s}.join-btn:hover:not(:disabled){background:#c9281f;transform:translateY(-1px)}.join-btn:disabled{opacity:.5;cursor:default;transform:none}.join-back{background:none;border:none;color:var(--muted);font-size:14px;cursor:pointer;padding:4px}.join-back:hover{color:var(--navy)}.join-footer{font-size:13px}.join-footer a{color:#ffffff80;text-decoration:none}.join-footer a:hover{color:#fffc}.play-page{min-height:100dvh;background:#f9fafb;display:flex;flex-direction:column}.play-header{background:#175093;color:#fff;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;font-size:13px;font-weight:600;flex-shrink:0}.play-name{opacity:.85}.play-progress{opacity:.7;font-size:12px}.play-screen{flex:1;display:flex;flex-direction:column;align-items:center;padding:24px 16px 32px;gap:16px;max-width:480px;width:100%;margin:0 auto}.play-centered{justify-content:center;align-items:center;text-align:center;gap:12px}.play-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:var(--navy);border-radius:50%;animation:spin .8s linear infinite}.play-link{color:var(--navy);font-weight:600;text-decoration:none}.play-home-btn{margin-top:8px;padding:12px 24px;background:var(--navy);color:#fff;border-radius:10px;font-size:15px}.lobby-screen{justify-content:center;text-align:center;background:#175093;min-height:100dvh;color:#fff}.lobby-emoji{font-size:72px;animation:bounce 1.5s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.lobby-screen h2{font-size:26px;font-weight:800;margin:0;color:#fff}.lobby-sub{font-size:15px;color:#ffffffa6;margin:0}.lobby-count{margin-top:8px;display:flex;flex-direction:column;align-items:center;gap:2px}.lobby-count-num{font-size:56px;font-weight:900;color:#fff;line-height:1}.lobby-count-label{font-size:13px;color:#fff9;text-transform:uppercase;letter-spacing:1px}.lobby-pulse{width:12px;height:12px;border-radius:50%;background:#4ade80;box-shadow:0 0 #4ade8080;animation:pulse 1.5s ease-out infinite;margin-top:8px}@keyframes pulse{0%{box-shadow:0 0 #4ade8066}to{box-shadow:0 0 0 20px #4ade8000}}.waiting-screen{justify-content:center;text-align:center;background:#175093;min-height:100dvh;color:#fff}.waiting-icon{font-size:64px}.waiting-screen h2{font-size:24px;font-weight:800;color:#fff;margin:0}.waiting-screen p{color:#ffffffa6;margin:0}.waiting-dots{display:flex;gap:8px;justify-content:center;margin-top:8px}.waiting-dots span{width:10px;height:10px;border-radius:50%;background:#ffffff80;animation:dotPulse 1.2s ease-in-out infinite}.waiting-dots span:nth-child(2){animation-delay:.2s}.waiting-dots span:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{transform:scale(.8);opacity:.4}40%{transform:scale(1.2);opacity:1}}.question-screen{padding-top:16px}.timer-bar-wrap{width:100%;background:#e5e7eb;border-radius:99px;height:10px;position:relative;overflow:visible;display:flex;align-items:center}.timer-bar-fill{height:100%;border-radius:99px;transition:width .9s linear,background .3s}.timer-bar-num{position:absolute;right:0;top:-22px;font-size:13px;font-weight:700}.question-problem{font-size:17px;font-weight:600;color:var(--navy);text-align:center;background:#fff;border-radius:14px;padding:20px 18px;box-shadow:0 2px 8px #0000000f;line-height:1.5;width:100%;box-sizing:border-box}.question-hint{font-size:13px;color:var(--muted);text-align:center;margin:0}.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}.role-btn{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:14px 10px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;transition:border-color .15s,background .15s,transform .1s;position:relative}.role-btn:active{transform:scale(.96)}.role-btn.selected{border-color:var(--navy);background:#eff6ff}.role-icon{font-size:28px}.role-label{font-size:12px;font-weight:600;color:#374151;text-align:center;line-height:1.3}.role-btn.selected .role-label{color:var(--navy)}.role-check{position:absolute;top:6px;right:8px;font-size:14px;color:var(--navy);font-weight:700}.confirm-btn{width:100%;padding:16px;background:var(--navy);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s}.confirm-btn:disabled{opacity:.4;cursor:default}.confirm-btn:hover:not(:disabled){background:#003080}.mc-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%}.mc-grid-2{grid-template-columns:1fr 1fr}.mc-btn{padding:20px 12px;background:var(--mc-color, #002060);color:#fff;border:none;border-radius:14px;font-size:15px;font-weight:700;cursor:pointer;transition:filter .15s,transform .1s;min-height:80px;text-align:center;line-height:1.3}.mc-btn:hover:not(:disabled){filter:brightness(1.1)}.mc-btn:active:not(:disabled){transform:scale(.95)}.mc-btn:disabled{opacity:.5;cursor:default}.play-error-msg{font-size:13px;color:var(--red);text-align:center;background:#fef2f2;border-radius:8px;padding:8px;width:100%;box-sizing:border-box}.results-screen{gap:14px}.result-badge{width:100%;border-radius:14px;padding:18px 20px;display:flex;align-items:center;gap:16px;box-sizing:border-box}.result-correct{background:#f0fdf4;border:2px solid #16a34a}.result-partial{background:#fffbeb;border:2px solid #d97706}.result-wrong{background:#fef2f2;border:2px solid #dc2626}.result-neutral{background:#f9fafb;border:2px solid #e5e7eb}.result-icon{font-size:40px}.result-text{font-size:22px;font-weight:800;color:#111}.result-correct .result-text{color:#16a34a}.result-partial .result-text{color:#d97706}.result-wrong .result-text{color:#dc2626}.result-points{font-size:16px;font-weight:600;color:#374151;margin-top:2px}.answer-explanation{width:100%;background:#eff6ff;border-radius:12px;padding:14px 16px;box-sizing:border-box}.explanation-label{font-size:12px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.explanation-text{font-size:14px;color:#1e3a8a;line-height:1.5}.leaderboard-card{width:100%;background:#fff;border-radius:14px;padding:16px;box-shadow:0 2px 8px #0000000f;box-sizing:border-box}.lb-title{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.lb-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f3f4f6;font-size:15px}.lb-row:last-child{border-bottom:none}.lb-rank{font-size:18px;width:28px}.lb-name{flex:1;font-weight:600;color:#111}.lb-score{font-weight:700;color:var(--navy)}.next-hint{font-size:13px;color:var(--muted);text-align:center;margin:0}.finished-screen{padding-top:32px;text-align:center;gap:20px}.finished-title{font-size:32px;font-weight:900;color:var(--navy)}.podium{display:flex;align-items:flex-end;justify-content:center;gap:12px;width:100%}.podium-item{display:flex;flex-direction:column;align-items:center;gap:4px;background:#fff;border-radius:14px;padding:12px 10px;flex:1;box-shadow:0 2px 8px #00000014}.podium-1{order:2;padding-top:20px}.podium-2{order:1}.podium-3{order:3}.podium-medal{font-size:28px}.podium-name{font-size:13px;font-weight:700;color:var(--navy);word-break:break-word;text-align:center}.podium-score{font-size:12px;color:var(--muted)}.my-rank-card{background:#eff6ff;border-radius:12px;padding:12px 20px;font-size:15px;color:var(--navy)}.lb-rest{width:100%;background:#fff;border-radius:12px;padding:8px 16px;box-sizing:border-box}.lb-row-small{display:flex;gap:10px;padding:6px 0;font-size:14px;border-bottom:1px solid #f3f4f6;color:#374151}.lb-row-small:last-child{border-bottom:none}.lb-row-small span:first-child{width:24px;color:var(--muted)}.lb-row-small span:nth-child(2){flex:1;font-weight:600}.lb-row-small span:last-child{font-weight:600;color:var(--navy)}.host-page{min-height:100dvh;background:#f1f5f9;display:flex;flex-direction:column}.host-loading{justify-content:center;align-items:center;gap:12px;text-align:center;color:var(--muted)}.host-spinner{width:44px;height:44px;border:4px solid #e5e7eb;border-top-color:var(--navy);border-radius:50%;animation:spin .8s linear infinite}.host-topbar{background:#175093;color:#fff;display:flex;justify-content:space-between;align-items:center;padding:14px 24px;flex-shrink:0}.host-brand{font-weight:800;font-size:16px;letter-spacing:.5px}.host-dashboard-btn{background:#ffffff26;border:none;color:#fff;padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.host-dashboard-btn:hover{background:#ffffff40}.host-stop-btn{background:#e63229d9;border:none;color:#fff;padding:6px 14px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;transition:background .2s}.host-stop-btn:hover:not(:disabled){background:#c9281f}.host-stop-btn:disabled{opacity:.5;cursor:default}.host-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}.host-confirm-dialog{background:#fff;border-radius:16px;padding:28px 24px;max-width:380px;width:100%;box-shadow:0 20px 60px #0000004d}.host-confirm-title{font-size:20px;font-weight:800;color:var(--navy);margin-bottom:10px}.host-confirm-dialog p{font-size:14px;color:#374151;line-height:1.5;margin:0}.host-confirm-cancel{flex:1;padding:12px;background:#f3f4f6;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;color:#374151}.host-confirm-stop{flex:1;padding:12px;background:#dc2626;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;color:#fff}.host-content{flex:1;padding:24px;max-width:800px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:20px}.host-action-btn{width:100%;padding:18px;background:var(--red);color:#fff;border:none;border-radius:14px;font-size:17px;font-weight:700;cursor:pointer;transition:background .2s,transform .1s}.host-action-btn:hover:not(:disabled){background:#c9281f;transform:translateY(-1px)}.host-action-btn:disabled{opacity:.5;cursor:default;transform:none}.host-lobby{display:flex;flex-direction:column;gap:20px}.host-pin-section{background:#175093;border-radius:20px;padding:36px;text-align:center;color:#fff}.host-pin-label{font-size:13px;color:#fff9;text-transform:uppercase;letter-spacing:1px}.host-pin-url{font-size:20px;font-weight:700;color:#fff;margin-top:4px;margin-bottom:4px}.host-pin{font-size:80px;font-weight:900;letter-spacing:12px;color:#fff;line-height:1.1;margin-top:4px}.host-players-section{background:#fff;border-radius:16px;padding:20px}.host-players-header{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:15px;color:var(--navy);margin-bottom:14px}.host-player-count{background:var(--navy);color:#fff;border-radius:20px;padding:2px 12px;font-size:14px}.host-player-list{display:flex;flex-wrap:wrap;gap:8px;min-height:40px}.host-no-players{color:var(--muted);font-size:14px}.host-player-chip{background:#eff6ff;color:var(--navy);border-radius:20px;padding:6px 14px;font-size:14px;font-weight:600;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.host-question{display:flex;flex-direction:column;gap:16px}.host-q-header{display:flex;justify-content:space-between;align-items:center;background:var(--navy);color:#fff;border-radius:12px;padding:12px 18px}.host-q-num{font-weight:700;font-size:15px}.host-timer{font-size:22px;font-weight:900}.host-timer-bar{background:#e5e7eb;border-radius:99px;height:8px;overflow:hidden}.host-timer-fill{height:100%;border-radius:99px;transition:width .9s linear,background .3s}.host-question-card{background:#fff;border-radius:16px;padding:24px;display:flex;flex-direction:column;gap:12px;box-shadow:0 2px 8px #0000000f}.host-q-title{font-size:18px;font-weight:800;color:var(--navy)}.host-q-problem{font-size:16px;color:#374151;line-height:1.6}.host-role-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.host-role-chip{background:#eff6ff;color:var(--navy);border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}.host-mc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.host-mc-opt{padding:12px 14px;border-radius:10px;color:#fff;font-size:13px;font-weight:600;text-align:center}.host-answer-progress{background:#fff;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px}.host-answer-bar{background:#e5e7eb;border-radius:99px;height:10px;overflow:hidden}.host-answer-fill{height:100%;background:var(--navy);border-radius:99px;transition:width .5s ease}.host-answer-label{font-size:13px;font-weight:600;color:var(--navy);text-align:center}.host-results{display:flex;flex-direction:column;gap:16px}.host-results-header{background:var(--navy);border-radius:16px;padding:24px;color:#fff;display:flex;flex-direction:column;gap:8px}.host-results-title{font-size:18px;font-weight:800}.host-correct-roles{font-size:22px;font-weight:900;color:#4ade80}.host-explanation{font-size:14px;color:#ffffffbf;line-height:1.5;border-top:1px solid rgba(255,255,255,.15);padding-top:10px;margin-top:4px}.host-leaderboard{background:#fff;border-radius:16px;padding:20px;box-shadow:0 2px 8px #0000000f}.host-lb-title{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.host-lb-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f3f4f6;font-size:16px}.host-lb-row:last-child{border-bottom:none}.host-lb-rank{font-size:20px;width:30px}.host-lb-name{flex:1;font-weight:600;color:#111}.host-lb-score{font-weight:800;color:var(--navy);font-size:17px}.host-finished{display:flex;flex-direction:column;gap:20px;align-items:center;text-align:center}.host-finished-title{font-size:40px;font-weight:900;color:var(--navy)}.host-podium{display:flex;align-items:flex-end;justify-content:center;gap:16px;width:100%}.host-podium-item{display:flex;flex-direction:column;align-items:center;gap:6px;background:#fff;border-radius:16px;padding:16px 12px;flex:1;max-width:180px;box-shadow:0 2px 12px #0000001a}.host-podium-1{order:2;padding-top:28px}.host-podium-2{order:1}.host-podium-3{order:3}.host-podium-medal{font-size:36px}.host-podium-name{font-size:16px;font-weight:800;color:var(--navy);word-break:break-word}.host-podium-score{font-size:14px;color:var(--muted);font-weight:600}.host-lb-rest{width:100%;background:#fff;border-radius:14px;padding:12px 20px;box-sizing:border-box}.host-lb-row-small{display:flex;gap:12px;padding:8px 0;font-size:15px;border-bottom:1px solid #f3f4f6;color:#374151}.host-lb-row-small:last-child{border-bottom:none}.host-lb-row-small span:first-child{width:28px;color:var(--muted)}.host-lb-row-small span:nth-child(2){flex:1;font-weight:600}.host-lb-row-small span:last-child{font-weight:700;color:var(--navy)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--gray-bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px 36px;width:100%;max-width:400px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:8px}.login-logo{font-size:28px;font-weight:900;color:var(--klg-navy);letter-spacing:-.5px}.login-logo span{color:var(--klg-red)}.login-sub{font-size:13px;color:var(--muted);margin-bottom:8px}.login-form{width:100%;display:flex;flex-direction:column;gap:16px;margin-top:8px}.login-back{font-size:13px;color:var(--muted);margin-top:16px;transition:color .15s}.login-back:hover{color:var(--text)}.app-shell{display:flex;height:100vh;overflow:hidden}.nav-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:50}.sidebar{width:228px;flex-shrink:0;background:var(--klg-navy);color:#fff;display:flex;flex-direction:column;overflow-y:auto}.sidebar-logo{padding:20px 18px 14px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo .brand{font-size:17px;font-weight:800}.sidebar-logo .sub{font-size:11px;color:#ffffff8c;margin-top:2px}.nav{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:2px}.nav-item{padding:10px 12px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;color:#ffffffbf;transition:background .15s,color .15s}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:var(--klg-red);color:#fff}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1)}.user-info{margin-bottom:10px}.user-info strong{display:block;font-size:13px}.user-info span{font-size:11px;color:#ffffff8c;text-transform:uppercase;letter-spacing:.5px}.btn-logout{width:100%;background:#ffffff1a;color:#fffc;border:none;border-radius:6px;padding:9px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-logout:hover{background:#ffffff2e}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:52px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:14px;flex-shrink:0}.burger{display:none;background:none;border:none;font-size:20px;cursor:pointer;color:var(--text);padding:4px 6px}.topbar-title{font-size:15px;font-weight:700;flex:1}.topbar-quiz-btn{background:var(--red);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;transition:background .2s;white-space:nowrap}.topbar-quiz-btn:hover:not(:disabled){background:#c9281f}.topbar-quiz-btn:disabled{opacity:.6;cursor:default}.content{flex:1;overflow-y:auto;padding:24px 20px 40px;display:flex;flex-direction:column;gap:20px}@media (max-width: 768px){.sidebar{position:fixed;left:-228px;top:0;bottom:0;z-index:60;transition:left .25s ease}.sidebar.open{left:0}.nav-overlay,.burger{display:block}}.metrics{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm)}.metric-card .label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:8px}.metric-card .value{font-size:32px;font-weight:800;color:var(--klg-navy);line-height:1}.metric-card .sublabel{font-size:12px;color:var(--muted);margin-top:4px}.card-header{font-size:14px;font-weight:700;margin-bottom:16px;color:var(--text)}.section-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.section-title{font-size:16px;font-weight:700}.filters{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end;box-shadow:var(--shadow-sm)}.filters label{font-size:12px;font-weight:600;color:var(--muted);display:block;margin-bottom:5px}.filters input{background:var(--input-bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:14px;font-family:inherit;outline:none;transition:border-color .15s}.filters input:focus{border-color:var(--border-focus)}.chart-wrap{display:flex;align-items:flex-end;gap:6px;height:120px;padding:8px 0}.chart-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}.chart-bar{width:100%;background:var(--klg-navy);border-radius:3px 3px 0 0;min-height:3px;transition:height .3s}.chart-label{font-size:11px;color:var(--muted);font-weight:600}.chart-count{font-size:11px;color:var(--muted)}.scenario-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow-sm)}.scenario-stat-title{font-size:14px;font-weight:700;margin-bottom:12px}.stat-bars{display:flex;flex-direction:column;gap:6px}.stat-bar-row{display:flex;align-items:center;gap:10px;font-size:12px}.stat-bar-label{width:64px;flex-shrink:0;color:var(--muted);font-weight:600;text-align:right}.stat-bar-track{flex:1;height:12px;background:#f1f5f9;border-radius:6px;overflow:hidden}.stat-bar-fill{height:100%;border-radius:6px;transition:width .3s}.stat-bar-fill.correct{background:var(--green)}.stat-bar-fill.partial{background:var(--yellow)}.stat-bar-fill.wrong{background:var(--red)}.stat-bar-pct{width:36px;text-align:right;color:var(--text-soft);font-weight:600}.session-detail{display:flex;flex-direction:column;gap:16px}.session-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px}.meta-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px}.meta-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:2px}.meta-val{font-size:14px;font-weight:600}.result-list{display:flex;flex-direction:column;gap:8px}.result-item{padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:13px}.result-item.correct{background:var(--green-light);border-color:#86efac}.result-item.partial{background:var(--yellow-light);border-color:#fde68a}.result-item.wrong{background:var(--red-light);border-color:#fca5a5}.result-title{font-weight:700;display:flex;align-items:center;justify-content:space-between}.result-roles{color:var(--muted);margin-top:3px;font-size:12px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--klg-navy: #002060;--klg-navy-dark: #001540;--klg-red: #e63229;--klg-red-dark: #c41e16;--white: #ffffff;--gray-bg: #f0f2f5;--bg: var(--gray-bg);--surface: #ffffff;--surface-2: #f8fafc;--text: #0f1c2e;--text-soft: #374151;--muted: #6b7280;--accent: var(--klg-red);--accent-hover: var(--klg-red-dark);--accent-light: rgba(230, 50, 41, .08);--border: #e2e8f0;--border-focus: var(--klg-navy);--input-bg: #ffffff;--input-text: #0f1c2e;--input-ph: #9ca3af;--green: #16a34a;--green-light: #dcfce7;--green-text: #15803d;--red: #dc2626;--red-light: #fee2e2;--red-text: #b91c1c;--yellow: #d97706;--yellow-light: #fef3c7;--yellow-text: #b45309;--blue-light: #dbeafe;--blue-text: #1d4ed8;--radius: 10px;--radius-sm: 6px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.06);--shadow-sm: 0 1px 2px rgba(0,0,0,.06)}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--gray-bg);color:var(--text);-webkit-text-size-adjust:100%;line-height:1.5}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}*::-webkit-scrollbar{width:5px;height:5px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:3px}button{cursor:pointer;border:none;font-family:inherit}a{color:inherit;text-decoration:none}input,textarea,select{font-family:inherit}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn-primary{background:var(--klg-red);color:#fff;border:none;border-radius:var(--radius-sm);padding:12px 20px;min-height:44px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--text-soft);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px;min-height:40px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s;display:inline-flex;align-items:center;gap:6px}.btn-secondary:hover{background:var(--surface-2);border-color:#c9d3df}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:none;color:var(--muted);border:none;border-radius:var(--radius-sm);padding:8px 12px;font-size:13px;cursor:pointer;transition:background .15s,color .15s}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.btn-danger{background:var(--red-light);color:var(--red-text);border:1.5px solid #fca5a5;border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-danger:hover{background:#fee2e2}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:600;color:var(--text-soft)}.field label .opt{font-weight:400;color:var(--muted);font-size:12px}.field input,.field textarea,.field select{background:var(--input-bg);color:var(--input-text);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:15px;outline:none;transition:border-color .15s;width:100%}.field input::placeholder,.field textarea::placeholder{color:var(--input-ph)}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--border-focus)}.field textarea{resize:vertical;min-height:80px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow-sm)}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:500}.alert-error{background:var(--red-light);color:var(--red-text);border:1px solid #fca5a5}.alert-success{background:var(--green-light);color:var(--green-text);border:1px solid #86efac}.alert-info{background:var(--blue-light);color:var(--blue-text);border:1px solid #93c5fd}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:99px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.badge-green{background:var(--green-light);color:var(--green-text)}.badge-red{background:var(--red-light);color:var(--red-text)}.badge-yellow{background:var(--yellow-light);color:var(--yellow-text)}.badge-navy{background:var(--blue-light);color:var(--blue-text)}.badge-muted{background:#f1f5f9;color:var(--muted)}.spinner{display:inline-block;width:20px;height:20px;border:2.5px solid var(--border);border-top-color:var(--klg-red);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:200;overflow-y:auto;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:520px;box-shadow:0 20px 60px #00000040;animation:slideUp .2s ease}.modal-wide{max-width:720px}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:17px;font-weight:700}.modal-close{background:none;border:none;font-size:22px;line-height:1;cursor:pointer;color:var(--muted);padding:2px 6px;border-radius:4px}.modal-close:hover{background:var(--surface-2);color:var(--text)}.modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.table-scroll{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}th,td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--border)}th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);white-space:nowrap}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--surface-2)}.loading-row td,.loading{text-align:center;padding:40px;color:var(--muted);font-size:14px}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:999}.toast{background:#1e293b;color:#f8fafc;padding:12px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;box-shadow:0 4px 16px #0003;animation:toastIn .2s ease;max-width:320px}.toast-error{background:#7f1d1d}@keyframes toastIn{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}
