:root{--primary:#ff922b;--primary-dark:#e8590c;--secondary:#f76707;--accent-pink:#ffb6d9;--accent-blue:#b4e7ff;--accent-orange:#ffe4b5;--text-dark:#2d3748;--text-light:#718096;--white:#fff}#introScreen{background:linear-gradient(135deg,#ffecd2 0%,#fcb69f 50%,#fbc2eb 100%);min-height:100vh;font-family:Outfit,Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif;position:relative;overflow-x:hidden}.bg-shapes{pointer-events:none;z-index:0;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.shape{opacity:.15;border-radius:50%;animation:20s ease-in-out infinite float;position:absolute}.shape:first-child{background:var(--accent-pink);width:400px;height:400px;animation-delay:0s;top:-100px;left:-100px}.shape:nth-child(2){background:var(--accent-blue);width:300px;height:300px;animation-delay:-5s;top:50%;right:-80px}.shape:nth-child(3){background:var(--accent-orange);width:250px;height:250px;animation-delay:-10s;bottom:-50px;left:20%}.shape:nth-child(4){background:var(--white);width:200px;height:200px;animation-delay:-15s;top:30%;left:10%}@keyframes float{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(30px,-30px)rotate(5deg)}50%{transform:translate(-20px,20px)rotate(-5deg)}75%{transform:translate(20px,10px)rotate(3deg)}}.main-container{z-index:1;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;display:flex;position:relative}.card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);text-align:center;background:#fffffff2;border-radius:32px;width:100%;max-width:520px;padding:60px 50px;animation:.8s ease-out cardEntry;box-shadow:0 25px 80px #00000026,0 10px 30px #ff922b33}@keyframes cardEntry{0%{opacity:0;transform:translateY(40px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.logo-section{margin-bottom:30px}.logo-img{max-width:min(100%,560px);height:auto}.lang-section{margin-top:20px}.lang-label{color:var(--text-light);margin-bottom:20px;font-size:.95em;font-weight:500}.lang-buttons{justify-content:center;gap:16px;display:flex}.lang-btn{cursor:pointer;text-align:center;white-space:nowrap;color:#5c4a3a;background:linear-gradient(135deg,#fff3e0 0%,#ffe0b2 100%);border:2.5px solid #0000;border-radius:16px;flex:1;max-width:160px;padding:18px 24px;font-family:inherit;font-size:1.1em;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #ff922b26}.lang-btn:hover{background:linear-gradient(135deg,#ffe0b2 0%,#ffcc80 100%);transform:translateY(-4px);box-shadow:0 8px 25px #ff922b4d}.lang-btn.lang-recommended{color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);transform:scale(1.05);box-shadow:0 6px 20px #ff922b59}.lang-btn.lang-recommended:hover{transform:scale(1.05)translateY(-4px);box-shadow:0 10px 30px #ff922b73}.intro-desc{text-align:center;color:#8b7355;letter-spacing:.05em;margin:-10px 0 20px;font-size:1em;font-weight:500}.lang-btn:active{transform:translateY(-2px)}.flag{font-size:1.3em}.login-form{flex-direction:column;gap:14px;max-width:380px;margin-top:20px;margin-left:auto;margin-right:auto;display:flex}.login-input{color:var(--text-dark);background:#fff;border:2.5px solid #ffd6a8;border-radius:14px;outline:none;padding:16px 20px;font-family:inherit;font-size:1.05em;transition:all .2s}.login-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #ff922b26}.login-submit{cursor:pointer;color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);border:none;border-radius:14px;padding:18px 24px;font-family:inherit;font-size:1.15em;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px #ff922b59}.login-submit:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 30px #ff922b73}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#c00;text-align:center;background:#fee;border-radius:10px;padding:12px 16px;font-size:.9em}.login-help{color:var(--text-light);text-align:center;margin-top:18px;font-size:.9em}.login-help a{color:var(--primary);font-weight:600;text-decoration:none}.login-help a:hover{text-decoration:underline}.curriculum-link{text-align:center;margin-top:20px}.curriculum-link a{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;background:#fff3;border:1.5px solid #fff6;border-radius:20px;align-items:center;gap:6px;padding:10px 24px;font-size:.9em;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.curriculum-link a:hover{background:#ffffff59;transform:translateY(-2px);box-shadow:0 4px 15px #0000001a}.footer{color:#ffffffb3;margin-top:16px;font-size:.8em;font-weight:400}.footer a{color:#ffffffe6;font-weight:500;text-decoration:none;transition:color .2s}.footer a:hover{color:var(--white)}@media (width<=540px){.card{border-radius:24px;padding:40px 30px}.lang-buttons{flex-direction:column;gap:12px}.lang-btn{max-width:100%;padding:16px 24px}}*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#ffb6d9 0%,#fcd4ff 25%,#b4e7ff 50%,#ffe4b5 100%);min-height:100vh;font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}.screen{display:none}.screen.active{display:block}.connect-container{max-width:1400px;margin:0 auto;padding:16px 20px}.connect-header{text-align:center;margin-bottom:16px}.connect-header h1{color:#495057;margin-bottom:4px;font-size:1.8em;font-weight:700}.connect-header p{color:#6c757d;font-size:1.1em}.group-section{background:linear-gradient(135deg,#ffffffe6 0%,#e9ecefe6 100%);border-radius:14px;margin-bottom:16px;padding:14px 20px}.group-section h2{color:#495057;margin-bottom:10px;font-size:1.1em}.input-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.input-row label{min-width:90px;font-weight:600}.input-row input{text-align:center;border:2px solid #ff922b;border-radius:8px;width:120px;padding:10px 16px;font-size:16px;font-weight:700}.blocks-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.block-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-align:center;background:#ffffffe6;border-radius:18px;padding:16px 12px;transition:all .3s;box-shadow:0 4px 20px #00000014}.block-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px #0000001f}.block-icon{opacity:.6;justify-content:center;align-items:center;height:80px;margin-bottom:8px;font-size:2.5em;transition:all .3s;display:flex}.block-card.connecting .block-icon{animation:1s ease-in-out infinite connectingPulse}@keyframes connectingPulse{0%,to{opacity:.4}50%{opacity:.9}}.block-card.connected .block-icon{opacity:1;filter:drop-shadow(0 8px 16px #0000004d)}.block-name{color:#495057;margin-bottom:6px;font-size:.9em;font-weight:600}.connection-badge{border-radius:16px;margin-bottom:8px;padding:4px 12px;font-size:.78em;font-weight:600;display:inline-block}.connection-badge.connected{color:#155724;background:#d4edda}.connection-badge.disconnected{color:#721c24;background:#f8d7da}.block-btn-kid{cursor:pointer;color:#fff;background:linear-gradient(135deg,#28a745 0%,#20c997 100%);border:none;border-radius:14px;width:100%;margin-top:8px;padding:10px 16px;font-size:.95em;font-weight:700;transition:all .3s;box-shadow:0 4px 12px #28a7454d}.block-btn-kid:hover{transform:translateY(-2px);box-shadow:0 6px 16px #28a74566}.block-btn-kid.connected{cursor:pointer;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);box-shadow:0 4px 12px #ff922b4d}.block-btn-kid.connected:hover{transform:translateY(-2px);box-shadow:0 6px 16px #ff922b66}.block-btn{cursor:pointer;border:none;border-radius:10px;margin:2px;padding:7px 14px;font-size:.8em;font-weight:600;transition:all .2s}.block-btn.connect{color:#fff;background:#28a745}.block-btn.disconnect{color:#fff;background:#dc3545}.block-btn:hover:not(:disabled){transform:scale(1.05)}.block-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#495057;cursor:pointer;background:#ffffffe6;border:none;border-radius:20px;margin:20px auto;padding:20px 40px;font-size:1.2em;font-weight:600;transition:all .3s;display:block;box-shadow:0 8px 32px #0000001a}.action-btn:hover{transform:translateY(-3px);box-shadow:0 12px 48px #00000026}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff4d;justify-content:space-between;align-items:center;height:54px;padding:6px 16px;display:flex}.back-btn{cursor:pointer;background:#fffc;border:none;border-radius:15px;padding:10px 20px;font-size:1em;font-weight:600;transition:all .3s}.back-btn:hover{background:#fff;transform:scale(1.05)}.block-connect-btn{cursor:pointer;color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);border:2px solid #ff922b;border-radius:20px;align-items:center;gap:4px;padding:6px 14px;font-size:.85em;font-weight:600;transition:all .3s;display:inline-flex;box-shadow:0 2px 8px #ff922b4d}.block-connect-btn:hover{transform:translateY(-2px);box-shadow:0 4px 20px #ff922b80}.mode-btn-grid{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.mode-btn{color:#8b7355;cursor:pointer;white-space:nowrap;background:#fff;border:2px solid #ffd8a8;border-radius:16px;align-items:center;gap:4px;min-height:44px;padding:10px 16px;font-size:.85em;font-weight:600;transition:all .25s;display:flex}.mode-btn:hover{color:#e8590c;border-color:#ff922b;transform:translateY(-1px);box-shadow:0 3px 10px #ff922b2e}.mode-btn.active{color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);border-color:#0000;box-shadow:0 3px 12px #ff922b59}.mode-btn-icon{font-size:1.1em;line-height:1}.mode-btn-text{font-size:.95em}.block-link-badge.disabled{color:#999;background:#f8f9fa;border-color:#ddd}.header-tabs{flex:1;justify-content:center;align-items:center;gap:2px;margin:0 12px;display:flex}.header-tab{cursor:pointer;white-space:nowrap;background:#ffffff80;border:none;border-radius:20px;align-items:center;gap:5px;min-height:40px;padding:6px 14px;transition:all .25s;display:flex}.header-tab.active{color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);transform:scale(1.05);box-shadow:0 3px 12px #ff922b59}.header-tab-icon{filter:grayscale();font-size:1.7rem;line-height:1;transition:filter .3s}.header-tab.active .header-tab-icon{filter:grayscale(0%)}.header-logo{flex-shrink:0}.mode-selector-bar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff80;border-radius:16px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;max-width:none;margin:0 auto 38px;padding:10px 16px;animation:.3s ease-out slideDown;display:flex;box-shadow:0 4px 15px #0000001a}#faceModeSelector,#actionModeSelector,#handModeSelector,#voiceModeSelector,#colorModeSelector{width:fit-content}.mode-btn-group{flex-wrap:nowrap;justify-content:center;align-items:center;gap:8px;display:flex}.motor-swap-toggle{visibility:hidden;white-space:nowrap;background:#ffffffe6;border:2px solid #e2e8f0;border-radius:20px;flex-shrink:0;align-items:center;gap:5px;margin-left:8px;padding:5px 10px;font-size:13px;display:flex}.motor-swap-toggle.visible{visibility:visible}.toggle-switch{cursor:pointer;background:#ccc;border-radius:13px;width:50px;height:26px;transition:background .3s;position:relative}.toggle-switch.active{background:#4caf50}.toggle-slider{background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .3s;position:absolute;top:3px;left:3px;box-shadow:0 2px 4px #0003}.toggle-switch.active .toggle-slider{transform:translate(24px)}.motor-status{color:#666;font-size:.75em;font-weight:500}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.main-content{grid-template-columns:1fr 1fr;gap:16px;max-width:1400px;margin:0 auto;padding:0 16px 16px;display:grid}.output-panel{background:#fff;border-radius:16px;padding:16px;box-shadow:0 4px 16px #00000014}.panel-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.result-item{background:#f8f9fa;border-radius:15px;justify-content:space-between;align-items:center;margin-bottom:15px;padding:15px 20px;transition:all .3s;display:flex}.result-item:hover{background:#f0f0f0;transform:translate(5px)}.result-info{align-items:center;gap:15px;display:flex}.result-avatar{background:linear-gradient(135deg,#ffb6d9 0%,#fcd4ff 100%);border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.5rem;display:flex}.result-details{flex-direction:column;display:flex}.result-name{color:#333;margin-bottom:5px;font-weight:600}.result-value{color:#666;font-size:.9rem}.status-badge{border-radius:20px;padding:8px 20px;font-size:.9rem;font-weight:600}.status-present{color:#2e7d32;background:#c8e6c9}.status-absent{color:#c62828;background:#ffcdd2}.status-active{color:#2e7d32;background:#c8e6c9}.voice-control-btn{cursor:pointer;color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);border:none;border-radius:15px;width:100%;margin-top:15px;padding:15px;font-size:1.1rem;font-weight:600;transition:all .3s}.voice-control-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #ff922b66}.voice-control-btn.listening{background:linear-gradient(135deg,#ff6b6b 0%,#ff4757 100%);animation:2s infinite pulse}.video-panel{background:#fff;border-radius:16px;padding:12px;position:relative;box-shadow:0 4px 16px #00000014}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.video-container{background:#f5f1ec;border-radius:16px;position:relative;overflow:hidden}#video{object-fit:cover;border-radius:0;width:100%;display:block}#canvas{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.loading{text-align:center;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:12px;margin:8px 16px;padding:10px;font-size:1rem}@media (width<=1024px){.main-content{gap:12px;padding:0 12px 12px}.blocks-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){.main-content{grid-template-columns:1fr}.header-tabs{gap:1px;margin:0 6px}.header-tab{min-height:32px;padding:4px 6px}.header-tab-label{display:none}.header-tab-icon{font-size:1.3rem}}@media (width>=768px) and (height<=700px){.header{height:46px;padding:4px 12px}.header img{height:28px!important}.header-tabs{gap:1px}.header-tab{padding:4px 8px}.mode-selector-bar{margin-bottom:8px;padding:8px 14px}.main-content{gap:10px;padding:0 10px 10px}.output-panel{padding:12px}}.game-container{text-align:center;width:100%;max-width:900px;margin:8px auto;display:none;overflow:hidden}.game-container.active{display:block}.game-score-big{color:#f59e0b;text-align:center;text-shadow:0 2px 8px #f59e0b4d;padding:8px 0 4px;font-size:2.2em;font-weight:800}.game-canvas-container{background:#f8f9fa;border-radius:20px;padding:0;position:relative;overflow:hidden;box-shadow:0 8px 30px #00000026}#gameCanvas{background:linear-gradient(#87ceeb 0%,#e0f6ff 100%);max-width:100%;margin:0 auto;display:block}.game-btn-kid{cursor:pointer;color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);border:none;border-radius:20px;width:100%;max-width:400px;margin:16px auto 0;padding:18px 32px;font-size:1.3em;font-weight:700;transition:all .3s;display:block;box-shadow:0 6px 20px #ff922b4d}.game-btn-kid:hover{transform:translateY(-3px);box-shadow:0 10px 30px #ff922b66}.game-btn-kid.ready{background:linear-gradient(135deg,#4caf50 0%,#66bb6a 100%);animation:2s ease-in-out infinite pulseGlow;box-shadow:0 6px 20px #4caf5066}.game-btn-kid.ready:hover{transform:translateY(-3px);box-shadow:0 10px 30px #4caf5080}.game-btn-kid.stop{white-space:nowrap;background:linear-gradient(135deg,#ef4444 0%,#f87171 100%);max-width:250px;box-shadow:0 6px 20px #ef44444d}.game-btn{cursor:pointer;border:none;border-radius:20px;padding:12px 28px;font-size:1.1em;font-weight:700;transition:all .3s;box-shadow:0 4px 15px #0003}.game-btn-start{color:#fff;background:linear-gradient(135deg,#4caf50 0%,#66bb6a 100%)}.game-btn:hover{transform:translateY(-2px)}.game-over-screen{color:#fff;text-align:center;z-index:100;background:#000000e6;border-radius:20px;padding:40px;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.game-over-screen h2{margin-bottom:20px;font-size:3em}.game-final-score{color:#ffc107;margin:16px 0;font-size:2.5em;font-weight:800}.game-over-stats{opacity:.8;justify-content:center;gap:20px;margin-bottom:20px;font-size:1.1em;display:flex}#toast-container{visibility:hidden;color:#fff;text-align:center;z-index:10000;opacity:0;white-space:nowrap;background-color:#323232f2;border-radius:50px;min-width:250px;padding:16px 24px;font-size:16px;font-weight:500;transition:opacity .3s,bottom .3s;position:fixed;bottom:30px;left:50%;transform:translate(-50%);box-shadow:0 4px 15px #0000004d}#toast-container.show{visibility:visible;opacity:1;bottom:80px}.popup-overlay{z-index:15000;background:#00000080;display:none;position:fixed;inset:0}.popup-overlay.on{display:block}.popup{z-index:16000;text-align:center;background:#fff;border-radius:20px;max-width:560px;padding:32px 36px;display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 8px 32px #0000004d}.popup.on{display:block}.popup img{border-radius:12px;width:100%;max-width:480px;margin-bottom:16px}.popup-msg{color:#333;white-space:pre-line;margin-bottom:20px;font-size:18px;font-weight:600;line-height:1.5}.popup-close{color:#fff;cursor:pointer;background:#29a8e0;border:none;border-radius:12px;padding:10px 32px;font-size:15px;font-weight:700}.popup-close:hover{filter:brightness(1.1)}.help-group-bar{background:#f8f9fa;border-radius:12px;align-items:center;gap:10px;margin-bottom:14px;padding:12px 16px;display:flex}.help-group-bar label{color:#495057;white-space:nowrap;font-size:14px;font-weight:700}.help-group-bar input{border:2px solid #dee2e6;border-radius:8px;flex:1;min-width:0;padding:8px 12px;font-size:14px}.help-group-bar input:focus{border-color:#29a8e0;outline:none}.help-group-apply-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);border:none;border-radius:8px;padding:8px 18px;font-size:14px;font-weight:700;box-shadow:0 2px 8px #f7670740}.help-group-apply-btn:hover{filter:brightness(1.08)}.img-lightbox{z-index:20000;cursor:zoom-out;background:#00000080;justify-content:center;align-items:center;padding:40px;display:none;position:fixed;inset:0}.img-lightbox.on{display:flex}.img-lightbox img{object-fit:contain;border-radius:12px;width:70vw;height:70vh;box-shadow:0 8px 40px #00000080}.game-help-btn{color:#fff;cursor:pointer;z-index:20;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);border:none;border-radius:50%;width:44px;height:44px;font-size:22px;font-weight:800;line-height:1;transition:transform .2s,box-shadow .2s;position:absolute;bottom:16px;right:16px;box-shadow:0 4px 12px #f7670759}.game-help-btn:hover{transform:scale(1.08);box-shadow:0 6px 16px #f7670780}.game-guide-overlay{z-index:25000;background:#0000008c;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.game-guide-overlay.on{display:flex}.game-guide-popup{text-align:center;background:#fff;border-radius:24px;width:100%;max-width:560px;padding:32px 36px 28px;position:relative;box-shadow:0 12px 40px #00000059}.game-guide-close{color:#555;cursor:pointer;background:#f1f3f5;border:none;border-radius:50%;width:34px;height:34px;font-size:16px;font-weight:700;position:absolute;top:14px;right:14px}.game-guide-close:hover{background:#e9ecef}.game-guide-title{color:#222;margin-bottom:20px;font-size:22px;font-weight:800}.game-guide-slides{min-height:340px;position:relative}.game-guide-slide{flex-direction:column;align-items:center;animation:.3s gameGuideFadeIn;display:none}.game-guide-slide.active{display:flex}@keyframes gameGuideFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.game-guide-num{color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:14px;font-size:20px;font-weight:800;display:flex;box-shadow:0 4px 10px #f767074d}.game-guide-img{background:#f8f9fa;border-radius:14px;max-width:100%;max-height:280px;margin-bottom:16px}.game-guide-text{color:#333;padding:0 8px;font-size:17px;font-weight:600;line-height:1.5}.game-guide-dots{justify-content:center;gap:8px;margin:20px 0 18px;display:flex}.game-guide-dot{cursor:pointer;background:#dee2e6;border-radius:50%;width:10px;height:10px;transition:background .2s,transform .2s}.game-guide-dot.active{background:#29a8e0;transform:scale(1.2)}.game-guide-nav{justify-content:space-between;gap:12px;display:flex}.game-guide-btn{color:#555;cursor:pointer;background:#fff;border:2px solid #dee2e6;border-radius:12px;flex:1;padding:12px 20px;font-size:15px;font-weight:700;transition:all .2s}.game-guide-btn:hover:not(:disabled):not(.primary){background:#f8f9fa}.game-guide-btn:disabled{opacity:.4;cursor:not-allowed}.game-guide-btn.primary{color:#fff;background:linear-gradient(135deg,#29a8e0 0%,#1d8abf 100%);border-color:#0000}.game-guide-btn.primary:hover{filter:brightness(1.08)}@media (width<=600px){.mode-selector-bar{gap:8px;padding:10px 12px}.mode-btn{padding:6px 10px;font-size:.75em}.mode-btn-grid{gap:6px}}.mode-help-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#0006;justify-content:center;align-items:center;padding:20px;animation:.2s ease-out fadeIn;display:none;position:fixed;inset:0}.mode-help-overlay.active{display:flex}.mode-help-popup{background:#fff;border-radius:20px;width:100%;max-width:700px;max-height:80vh;animation:.25s ease-out popIn;overflow-y:auto;box-shadow:0 20px 60px #00000040}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.9)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.help-popup-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.help-popup-title{color:#2d3748;font-size:1.15em;font-weight:700}.help-popup-close{cursor:pointer;color:#718096;background:#f7fafc;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.1em;transition:all .2s;display:flex}.help-popup-close:hover{color:#2d3748;background:#edf2f7}.help-popup-body{grid-template-columns:1fr 1fr;gap:8px 20px;padding:16px 20px 20px;display:grid}.help-popup-left,.help-popup-right{flex-direction:column;gap:12px;min-width:0;display:flex}.help-section{margin-bottom:0}.help-section-label{color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.8em;font-weight:700}.help-block-tags{flex-wrap:wrap;gap:6px;display:flex}.help-block-tag{color:#e8590c;background:linear-gradient(135deg,#ff922b15,#f7670715);border:1.5px solid #ffd8a860;border-radius:14px;padding:4px 12px;font-size:.82em;font-weight:600;display:inline-block}.help-assembly{text-align:center;background:#f7fafc;border-radius:12px;justify-content:center;align-items:center;min-height:80px;padding:16px;display:flex}.help-assembly img{border-radius:8px;max-width:100%;max-height:250px}.help-no-img{color:#a0aec0;font-size:.85em;font-style:italic}.help-actions{background:#f7fafc;border-radius:12px;padding:12px 16px}.help-action-line{color:#4a5568;padding:4px 0;font-size:.88em;line-height:1.6}.mode-btn{position:relative}.mode-usage-tag{color:#e8590c;cursor:pointer;white-space:nowrap;z-index:1;background:#fff;border:2.5px solid #ff922b;border-radius:16px;min-height:40px;padding:8px 20px;font-size:1em;font-weight:700;line-height:1;transition:all .2s;display:none;position:absolute;bottom:-44px;left:50%;transform:translate(-50%);box-shadow:0 3px 12px #ff922b33}.mode-btn.active .mode-usage-tag{align-items:center;animation:.2s ease-out fadeIn;display:flex}.mode-usage-tag:hover{color:#fff;background:#ff922b;border-color:#e8590c}.help-block-card{background:#f7fafc;border-radius:14px;align-items:center;gap:12px;margin-bottom:8px;padding:12px;display:flex}.help-block-img{object-fit:contain;width:72px;height:72px}.help-block-info{flex:1}.help-block-name{color:#2d3748;font-size:1em;font-weight:700}.help-block-status{color:#a0aec0;margin-top:2px;font-size:.8em}.help-block-status.connected{color:#48bb78}.help-connect-btn{color:#e8590c;cursor:pointer;white-space:nowrap;background:#fff;border:2px solid #ff922b;border-radius:16px;padding:10px 18px;font-size:.88em;font-weight:700;transition:all .2s}.help-connect-btn:hover{color:#fff;background:#ff922b}.help-connect-btn.connected{color:#48bb78;cursor:default;border-color:#48bb78}@media (width<=600px){.mode-help-popup{border-radius:16px;max-width:95%;max-height:75vh}.help-popup-header{padding:14px 16px 12px}.help-popup-body{grid-template-columns:1fr;padding:12px 16px 16px}}.mode-bar-label{color:#e8590c;white-space:nowrap;flex-shrink:0;font-size:.8em;font-weight:700}.kid-result-guide{text-align:center;padding:24px 20px}.kid-guide-emoji{opacity:.7;margin-bottom:12px;font-size:3rem}.kid-guide-text{color:#a0aec0;font-size:1.2em;font-weight:700;line-height:1.4}@keyframes gentleBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.kid-result-hero{text-align:center;background:linear-gradient(135deg,#f0f4ff 0%,#fdf2f8 100%);border-radius:20px;margin-bottom:12px;padding:16px}.kid-hero-emoji{margin-bottom:8px;font-size:3.5rem;line-height:1}.kid-hero-text{color:#718096;margin-bottom:4px;font-size:.85em;font-weight:600}.kid-hero-value{color:#2d3748;font-size:1.4em;font-weight:800}.pop-in{animation:.4s ease-out popBounce}@keyframes popBounce{0%{opacity:.7;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.pulse{animation:1.5s ease-in-out infinite pulseGlow}@keyframes pulseGlow{0%,to{box-shadow:0 0 #ff922b33}50%{box-shadow:0 0 0 15px #ff922b00}}.kid-result-cards{justify-content:center;gap:10px;display:flex}.kid-card{background:#fff;border-radius:16px;flex-direction:column;align-items:center;gap:2px;min-width:100px;padding:12px 20px;display:flex;box-shadow:0 2px 8px #0000000f}.kid-card-emoji{font-size:1.8rem}.kid-card-label{color:#a0aec0;font-size:.7em;font-weight:600}.kid-card-value{color:#2d3748;font-size:.95em;font-weight:700}.kid-color-swatch{border-radius:14px;height:40px;box-shadow:inset 0 2px 4px #0000001a}.kid-voice-btn{cursor:pointer;color:#fff;background:linear-gradient(135deg,#ff922b,#f76707);border:none;border-radius:16px;width:100%;margin-top:12px;padding:14px;font-size:1.1em;font-weight:700;transition:all .3s;display:block}.kid-voice-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ff922b66}.kid-voice-btn.listening{background:linear-gradient(135deg,#fc5c65,#eb3b5a);animation:1.5s ease-in-out infinite pulseGlow}.voice-history{max-height:120px;margin-top:8px;padding:0 4px;overflow-y:auto}.voice-history-item{color:#4a5568;background:#fff;border-radius:12px;margin-bottom:4px;padding:6px 12px;font-size:.9em;font-weight:600;box-shadow:0 1px 3px #0000000d}.action-guide{background:linear-gradient(135deg,#f0f4ff 0%,#fef3f2 100%);border:2px dashed #c7d2fe;border-radius:16px;margin-top:12px;padding:14px 16px}.action-guide-title{color:#e8590c;text-align:center;margin-bottom:10px;font-size:.95em;font-weight:700}.action-guide-item{background:#fff;border-radius:12px;align-items:center;gap:6px;margin-bottom:4px;padding:6px 8px;font-size:.88em;font-weight:600;display:flex;box-shadow:0 1px 3px #0000000a}.action-guide-item:last-child{margin-bottom:0}.action-guide-do{color:#4a5568;flex:1}.action-guide-arrow{color:#e8590c;flex-shrink:0;font-weight:800}.action-guide-result{color:#e53e3e;text-align:right;flex:1;font-weight:700}.game-connect-shortcut{color:#e8590c;cursor:pointer;background:#fff;border:2px solid #ff922b;border-radius:16px;margin-left:12px;padding:6px 16px;font-size:.9em;font-weight:700;transition:all .2s;display:inline-block}.game-connect-shortcut:hover{color:#fff;background:#ff922b}.game-status.connected .game-connect-shortcut{display:none}.combo-status{text-align:center;border-radius:16px;margin:8px 0 12px;padding:10px 20px;font-size:1.1em;font-weight:700;animation:.3s pop-in}.combo-status.combo-waiting{color:#868e96;background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%)}.combo-status.combo-ready{color:#856404;background:linear-gradient(135deg,#fff3cd 0%,#ffeeba 100%);animation:1.5s infinite pulse}.combo-status.combo-go{color:#155724;background:linear-gradient(135deg,#d4edda 0%,#c3e6cb 100%)}.combo-status.combo-stop{color:#721c24;background:linear-gradient(135deg,#f8d7da 0%,#f5c6cb 100%)}.combo-voice-section{background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border-radius:16px;flex-direction:column;align-items:center;gap:8px;margin-top:12px;padding:12px;display:flex}.combo-voice-result{align-items:center;gap:8px;font-size:1em;display:flex}.combo-voice-icon{font-size:1.3em}.combo-voice-text{color:#495057;font-weight:600}.free-mode-header{text-align:center;color:#5c4a3a;letter-spacing:-.02em;padding:12px 12px 4px;font-size:1.1em;font-weight:800}.fm-current-badge{text-align:center;color:#9e8a78;background:linear-gradient(135deg,#fff8f0 0%,#ffecd2 100%);border:1.5px solid #ffd8a8;border-radius:22px;width:fit-content;margin:6px auto 12px;padding:8px 22px;font-size:1.05em;font-weight:700;transition:all .35s cubic-bezier(.4,0,.2,1);display:block}.fm-current-badge.fm-badge-active{color:#e8590c;background:linear-gradient(135deg,#fff4e6 0%,#ffe8cc 100%);border-color:#ffa94d;box-shadow:0 3px 14px #e8590c1f}.free-mode-table{border-collapse:separate;border-spacing:0 8px;width:100%;font-size:.88em}.free-mode-table th{color:#9e8a78;text-align:center;text-transform:uppercase;letter-spacing:.04em;padding:0 6px 8px;font-size:.78em;font-weight:700}.free-mode-table td{text-align:center;vertical-align:middle;padding:0 4px}.free-mode-table .fm-label{text-align:left;white-space:nowrap;color:#5c4a3a;border-radius:14px 0 0 14px;padding:10px 10px 10px 14px;font-size:1em;font-weight:700;transition:all .3s}.free-mode-table tr.fm-row{background:#fff;border-radius:14px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #b48c6412}.free-mode-table tr.fm-row td:first-child{border-radius:14px 0 0 14px}.free-mode-table tr.fm-row td:last-child{border-radius:0 14px 14px 0;padding-right:8px}.free-mode-table tr.fm-row:hover{transform:translateY(-1px);box-shadow:0 4px 16px #b48c641f}.free-mode-table select{color:#5c4a3a;cursor:pointer;-webkit-appearance:none;text-align:center;background:#fdf8f3;border:2px solid #0000;border-radius:12px;width:100%;min-height:44px;padding:8px 6px;font-size:1.1em;font-weight:500;transition:all .25s}.free-mode-table select:hover{background:#fff4e6;border-color:#ffd8a8}.free-mode-table select:focus{background:#fff;border-color:#ff922b;outline:none;box-shadow:0 0 0 3px #ff922b2e}.free-mode-table tr.fm-current{background:linear-gradient(90deg,#e7f5ff 0%,#fff 60%);box-shadow:0 0 0 2px #74c0fc,0 3px 12px #339af01a}.free-mode-table tr.fm-current .fm-label{color:#1971c2}.free-mode-table tr.fm-active{transform:scale(1.015);background:linear-gradient(90deg,#ebfbee 0%,#fff 60%)!important;box-shadow:0 0 0 2px #69db7c,0 3px 14px #40c05726!important}.free-mode-table tr.fm-active .fm-label{color:#2b8a3e!important}.free-mode-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;padding:16px 0 10px;display:flex}.free-mode-actions button{cursor:pointer;letter-spacing:-.01em;border:none;border-radius:16px;padding:10px 24px;font-size:.92em;font-weight:700;transition:all .25s cubic-bezier(.4,0,.2,1)}.fm-run-btn{color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);min-width:120px;min-height:48px;font-size:1em;box-shadow:0 4px 16px #ff922b59}.fm-run-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #ff922b73}.fm-run-btn:active{transform:translateY(0)}.fm-run-btn.fm-running{animation:2s ease-in-out infinite fm-pulse;background:linear-gradient(135deg,#51cf66 0%,#37b24d 100%)!important;box-shadow:0 4px 16px #51cf6666!important}@keyframes fm-pulse{0%,to{box-shadow:0 4px 16px #51cf6659}50%{box-shadow:0 4px 28px #51cf668c}}.fm-test-btn{color:#5c4a3a;background:#fff;min-height:44px;box-shadow:0 2px 6px #b48c640f;border:2px solid #ffd8a8!important}.fm-test-btn:hover{color:#e8590c;background:#fff8f0;border-color:#ff922b!important}.fm-preset-btn{color:#5c4a3a;cursor:pointer;background:#fff;border:2px solid #ffd8a8;border-radius:16px;min-height:44px;padding:10px 18px;font-size:1.1em;font-weight:600;transition:all .25s;box-shadow:0 2px 6px #b48c640f}.fm-preset-btn:hover{color:#e8590c;background:linear-gradient(135deg,#fff8f0 0%,#ffecd2 100%);border-color:#ff922b;transform:translateY(-2px);box-shadow:0 4px 14px #ff922b26}.mode-switch-group{background:linear-gradient(135deg,#fff4e6 0%,#ffecd2 100%);border-radius:16px;gap:3px;padding:4px;display:flex;box-shadow:inset 0 1px 4px #b48c641a}.mode-switch-btn{color:#c2a58a;cursor:pointer;background:0 0;border:none;border-radius:13px;padding:7px 18px;font-size:.88em;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1)}.mode-switch-btn.active{color:#5c4a3a;background:#fff;box-shadow:0 2px 10px #b48c641f}.mode-switch-btn:hover:not(.active){color:#8b7355}.free-mode-table input[type=text]{color:#5c4a3a;text-align:center;background:#fdf8f3;border:2px solid #0000;border-radius:12px;width:72px;min-height:44px;padding:8px 10px;font-size:.95em;font-weight:600;transition:all .25s}.free-mode-table input[type=text]:focus{background:#fff;border-color:#ff922b;outline:none;box-shadow:0 0 0 3px #ff922b2e}.free-mode-table input[type=text]::placeholder{color:#d4b99a;font-weight:500}.free-mode-table button[onclick*=remove]{color:#c2a58a;cursor:pointer;background:#fdf8f3;border:none;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1em;transition:all .2s;display:flex}.free-mode-table button[onclick*=remove]:hover{color:#e03131;background:#fff0f0}#comboModeSelector .mode-bar-label{color:#5c4a3a;font-size:1em;font-weight:800}@media (width<=768px){.free-mode-table{-webkit-overflow-scrolling:touch;font-size:.82em;display:block;overflow-x:auto}.free-mode-table select{min-width:48px;min-height:40px;padding:6px 3px;font-size:1em}.free-mode-table th{padding:2px 3px 6px;font-size:.68em}.free-mode-table .fm-label{padding:8px 6px 8px 10px;font-size:.92em}.fm-preset-btn{min-height:40px;padding:8px 14px;font-size:1em}.combo-rule-table select{min-width:44px}.mode-switch-group{gap:2px;padding:3px}.mode-switch-btn{padding:5px 12px;font-size:.82em}.free-mode-actions button{min-height:40px;padding:8px 18px;font-size:.88em}}@media (width<=480px){.free-mode-table select{min-width:40px;min-height:38px;font-size:.95em}.free-mode-actions{flex-wrap:wrap}.free-mode-table input[type=text]{width:58px;min-height:38px;font-size:.88em}}.fm-voice-input{color:#5c4a3a;text-align:center;background:#fdf8f3;border:2px solid #0000;border-radius:12px;min-height:44px;padding:8px 10px;font-weight:600;transition:all .25s;width:100px!important;font-size:1em!important}.fm-voice-input:focus{background:#fff;border-color:#ff922b;outline:none;box-shadow:0 0 0 3px #ff922b2e}.fm-voice-input::placeholder{color:#d4b99a;font-weight:500}.kidsai-app{background:linear-gradient(135deg,#ffe5d6 0%,#fff3e6 50%,#ffe9f0 100%);flex-direction:column;min-height:100vh;display:flex}.kidsai-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;background:#ffffffd9;align-items:center;gap:16px;padding:10px 20px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #0000000f}.header-logo{flex-shrink:0;align-items:center;display:flex}.header-tabs{flex-wrap:wrap;flex:1;justify-content:center;gap:6px;padding:0 8px;display:flex}.header-tab{cursor:pointer;white-space:nowrap;background:0 0;border:2px solid #0000;border-radius:12px;flex-direction:column;align-items:center;gap:2px;min-width:70px;padding:8px 14px;font-family:inherit;transition:all .2s;display:flex}.header-tab:hover{background:#ff922b14}.header-tab.active{color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);box-shadow:0 4px 12px #ff922b4d}.header-tab-icon{font-size:1.8rem}.header-tab-label{font-size:1rem;font-weight:700}.header-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.artibo-select{cursor:pointer;background:#fff;border:1.5px solid #ffd6a8;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:1rem}.artibo-name{color:#5c4a3a;white-space:nowrap;text-overflow:ellipsis;background:linear-gradient(135deg,#fff3e0 0%,#ffe0b2 100%);border:1.5px solid #ffd6a8;border-radius:999px;max-width:260px;padding:8px 16px;font-size:1.05rem;font-weight:700;overflow:hidden}.conn-badge{color:#495057;background:#fff;border:1px solid #e9ecef;border-radius:20px;align-items:center;gap:6px;padding:8px 14px;font-size:1rem;font-weight:600;display:flex}.conn-dot{border-radius:50%;width:8px;height:8px}.conn-dot.on{background:#10b981;box-shadow:0 0 6px #10b981}.conn-dot.off{background:#ef4444}.logout-btn{color:#495057;cursor:pointer;background:#fff;border:1.5px solid #e9ecef;border-radius:8px;padding:8px 18px;font-family:inherit;font-size:1rem;font-weight:700}.logout-btn:hover{background:#f8f9fa}.banner{text-align:center;padding:12px 20px;font-size:1.05rem;font-weight:600}.banner-info{color:#0369a1;background:#e0f2fe}.banner-error{color:#c00;background:#fee}.banner-warn{color:#92400e;background:#fef3c7}.banner a{color:inherit;font-weight:700}.kidsai-main{box-sizing:border-box;flex:1;width:100%;max-width:1400px;margin:0 auto;padding:14px 20px 20px}.mode-bar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb3;border-radius:16px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;padding:10px 14px;display:flex}.mode-bar-label{color:#495057;white-space:nowrap;font-size:1.15rem;font-weight:700}.mode-btn-grid{flex-wrap:wrap;gap:8px;display:flex}.mode-btn{color:#495057;cursor:pointer;background:#fff;border:2px solid #0000;border-radius:12px;align-items:center;gap:8px;padding:10px 18px;font-family:inherit;font-size:1.1rem;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 2px 6px #0000000f}.mode-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.mode-btn.active{color:#fff;background:linear-gradient(135deg,#ff922b 0%,#f76707 100%);border-color:#0000}.mode-btn-icon{font-size:1.35rem}.mode-hint{background:linear-gradient(135deg,#fff8e7 0%,#fff3d6 100%);border:2px solid #ffd6a8;border-radius:14px;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:14px;padding:12px 18px;display:flex;box-shadow:0 2px 8px #ff922b14}.mode-hint-label{color:#d2691e;white-space:nowrap;background:#fff;border:1.5px solid #ffd6a8;border-radius:999px;flex-shrink:0;padding:6px 14px;font-size:1.15rem;font-weight:800}.mode-hint-body{flex-wrap:wrap;flex:1;gap:8px 18px;min-width:0;display:flex}.mode-hint-line{color:#5c4a3a;white-space:nowrap;font-size:1.15rem;font-weight:600}.main-content{grid-template-columns:1fr 1.2fr;align-items:start;gap:16px;display:grid}@media (width<=900px){.main-content{grid-template-columns:1fr}}.output-panel,.video-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border-radius:18px;min-height:400px;padding:16px;position:relative;box-shadow:0 6px 24px #00000014}.panel-header{border-bottom:2px solid #ffd6a8;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:10px;display:flex}.panel-title{color:#495057;font-size:1.3rem;font-weight:700}.video-container{aspect-ratio:4/3;background:#000;border-radius:12px;width:100%;position:relative;overflow:hidden}.video-container video,.video-container canvas{width:100%;height:100%;position:absolute;inset:0}.video-container video{object-fit:cover;transform:scaleX(-1)}.live-badge{color:#fff;z-index:2;background:#0009;border-radius:12px;align-items:center;gap:5px;padding:6px 14px;font-size:.95rem;font-weight:700;display:inline-flex;position:absolute;top:10px;left:10px}.live-dot{background:#ef4444;border-radius:50%;width:7px;height:7px;animation:1.5s infinite pulse}.result-big{text-align:center;padding:30px 20px;font-size:4rem;font-weight:700}.result-label{color:#6c757d;margin-top:10px;font-size:1.6rem;font-weight:600}.empty-state{text-align:center;color:#94a3b8;padding:60px 20px;font-size:1.2rem;font-weight:600}.empty-state .icon{margin-bottom:16px;font-size:4rem}.placeholder-panel{text-align:center;color:#6c757d;padding:80px 20px}.placeholder-panel .big-icon{margin-bottom:16px;font-size:4rem}:root{--primary:#667eea;--primary-dark:#5568d3;--accent:#ff922b;--bg:#f7f8fc;--surface:#fff;--text:#1a1d29;--text-muted:#6b7280;--border:#e5e7eb;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;color:var(--text);background:var(--bg);font-family:Noto Sans KR,Outfit,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0}button{cursor:pointer;font-family:inherit}button:disabled{cursor:not-allowed;opacity:.5}
