@import url(https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#e8edf5;font-family:Nunito,sans-serif;min-height:100vh}.hidden{display:none!important}.app-shell{background:#e8edf5;display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{background:#fff;box-shadow:0 1px 4px #0000000f;justify-content:space-between;padding:10px 40px}.app-header,.header-brand{align-items:center;display:flex}.header-brand{gap:10px}.brand-icon{align-items:center;background:#4361ee;border-radius:12px;display:flex;font-size:20px;height:40px;justify-content:center;width:40px}.brand-title{color:#3a86ff;font-size:22px;font-weight:800}.header-actions{display:flex;gap:12px}.back-home-btn{background:none;border:1.5px solid #cbd5e0;border-radius:10px;color:#4a5568;cursor:pointer;font-size:14px;font-weight:600;padding:7px 16px;transition:background .15s,color .15s}.back-home-btn:hover{background:#ebf4ff;border-color:#93c5fd;color:#2563eb}.btn-outline{background:#0000;border:1.5px solid #cbd5e0;border-radius:10px;color:#4a5568;cursor:pointer;font-family:Nunito,sans-serif;font-size:14px;font-weight:700;padding:8px 20px;transition:all .2s}.btn-outline:hover{background:#f7fafc;border-color:#a0aec0}.btn-primary{align-items:center;background:#4361ee;border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;font-family:Nunito,sans-serif;font-size:14px;font-weight:700;gap:6px;padding:8px 20px;transition:all .2s}.btn-primary:hover{background:#3451d1}.progress-track{background:#d6e0f7;height:6px;margin:0 40px}.progress-fill{background:linear-gradient(90deg,#4361ee,#7b8cde);border-radius:0 4px 4px 0;height:100%;width:55%}.app-main{grid-gap:18px;align-items:stretch;display:grid;flex:1 1;gap:18px;grid-template-columns:1.4fr 1.7fr;margin:0 auto;max-width:1500px;min-height:0;overflow:hidden;padding:16px 40px;width:100%}.left-col{display:flex;flex-direction:column;gap:10px;height:100%;min-height:0}.image-card{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;flex:1 1;min-height:0}.emotion-image{display:block;height:100%;object-fit:cover;width:100%}.image-placeholder{align-items:center;background:#f7f8fa;color:#a0aec0;display:flex;flex-direction:column;gap:10px;height:100%;justify-content:center;width:100%}.placeholder-icon{font-size:52px}.placeholder-text{font-size:15px;font-weight:600}.upload-card{align-items:center;background:#fff;border:2px dashed #90b4ff;border-radius:18px;box-shadow:0 2px 10px #0000000a;cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:12px;transition:all .2s}.upload-card:hover{background:#f0f4ff;border-color:#4361ee}.upload-icon{font-size:26px}.upload-text{color:#4361ee;font-size:15px;font-weight:700}.hint-card{animation:fadeSlideIn .3s ease;background:#fff;border-left:4px solid #4361ee;border-radius:14px;box-shadow:0 2px 12px #00000012;padding:10px 14px}.hint-header{align-items:center;display:flex;gap:8px;margin-bottom:4px}.hint-label{color:#4361ee;font-size:20px;font-weight:1000;letter-spacing:1.5px;text-transform:uppercase}.hint-audio-btn{background:none;border:none;border-radius:8px;cursor:pointer;font-size:16px;line-height:1;margin-left:auto;opacity:.7;padding:2px 4px;transition:opacity .2s,transform .2s}.hint-audio-btn:hover:not(:disabled){opacity:1;transform:scale(1.2)}.hint-audio-btn:disabled{cursor:default;opacity:.4}.hint-audio-btn.speaking{animation:pulse-speaker .8s ease-in-out infinite alternate;opacity:1}@keyframes pulse-speaker{0%{filter:brightness(1);transform:scale(1)}to{filter:brightness(1.4);transform:scale(1.25)}}.hint-text{color:#2d3748;font-size:32px;font-weight:700;line-height:1.4;text-align:center;text-transform:capitalize}.right-col{display:flex;flex-direction:column;gap:5px;height:100%;min-height:0}.question-block{text-align:center}.question-title{color:#4361ee;font-size:22px;font-weight:900}.question-sub{color:#718096;font-size:14px;font-weight:600}.emotion-grid{grid-gap:10px;display:grid;flex:1 1;gap:10px;grid-template-columns:1fr 1fr 1fr;grid-template-rows:repeat(2,1fr);min-height:0}.emotion-btn{align-items:center;border:2.5px solid #0000;border-radius:18px;cursor:pointer;display:flex;flex-direction:column;font-family:Roboto,sans-serif;font-weight:700;gap:4px;justify-content:center;padding:10px;transition:transform .18s ease,box-shadow .18s ease}.emotion-btn:hover{box-shadow:0 8px 20px #0000001f!important;transform:translateY(-3px)}.emotion-btn:active{transform:scale(.96)}.em-emoji{font-size:95px;line-height:1}.em-name{font-size:24px;font-weight:700}.feedback-bar{animation:fadeSlideIn .3s ease;border-radius:16px;font-size:14px;font-weight:800;padding:10px 16px;text-align:center}.feedback-bar.success{background:#f0fff4;border:1.5px solid #9ae6b4;color:#276749}.feedback-bar.error{background:#fff5f5;border:1.5px solid #feb2b2;color:#c53030}.feedback-bar.info{background:#ebf8ff;border:1.5px solid #90cdf4;color:#2b6cb0}.help-btn{align-items:center;background:#7b8cde;border:none;border-radius:18px;box-shadow:0 4px 14px #7b8cde66;color:#fff;cursor:pointer;display:flex;font-family:Nunito,sans-serif;font-size:22px;font-weight:800;gap:10px;justify-content:center;padding:14px;transition:all .2s;width:100%}.help-btn:hover{background:#4361ee;box-shadow:0 6px 20px #4361ee73;transform:translateY(-2px)}.help-btn:active{transform:scale(.97)}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.app-header{padding:14px 20px}.progress-track{margin:0 20px}.app-main{gap:20px;grid-template-columns:1fr;padding:20px}}.image-card{overflow:hidden;position:relative}.analyse-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#ffffffd1;border-radius:20px;color:#4361ee;display:flex;flex-direction:column;font-size:15px;font-weight:700;gap:12px;inset:0;justify-content:center;position:absolute}.spinner{animation:spin .8s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#4361ee;height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.detected-badge{animation:fadeSlideIn .4s ease;background:#ffffffeb;border:2px solid #68d391;border-radius:20px;bottom:12px;box-shadow:0 2px 8px #0000001a;color:#276749;font-size:14px;font-weight:800;left:50%;padding:6px 18px;position:absolute;transform:translateX(-50%);white-space:nowrap}.analyse-error{background:#fff5f5;border:1.5px solid #fc8181;border-radius:12px;bottom:12px;color:#c53030;font-size:13px;font-weight:700;left:12px;padding:8px 14px;position:absolute;right:12px;text-align:center}.em-loading{animation:spin 1s linear infinite;display:inline-block;font-size:14px}.explanation-card{background:#f0f4ff;border-left:4px solid #4361ee}.upload-sub{color:#94a3b8;font-size:13px;font-weight:600;margin-top:2px}.help-btn:disabled{cursor:not-allowed;opacity:.65;transform:none}@keyframes blinkGreen{0%,to{background:#22c55e!important;box-shadow:0 0 0 3px #16a34a,0 0 20px #22c55ecc!important;transform:scale(1)}50%{background:#10b981!important;box-shadow:0 0 0 8px #22c55e,0 0 35px #22c55e!important;transform:scale(1.02)}}@keyframes blinkRed{0%,to{background:#ef4444!important;box-shadow:0 0 0 3px #dc2626,0 0 20px #ef4444cc!important;transform:scale(1)}50%{background:#f87171!important;box-shadow:0 0 0 8px #ef4444,0 0 35px #ef4444!important;transform:scale(1.02)}}.emotion-btn.detected-correct{animation:blinkGreen .5s ease-in-out infinite!important}.celebration-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.celebration-content{animation:popInCelebration .5s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(135deg,#667eea,#764ba2);border-radius:32px;box-shadow:0 20px 60px #0000004d;max-width:500px;padding:48px 36px;text-align:center;width:90%}@keyframes popInCelebration{0%{opacity:0;transform:scale(.5) rotate(-10deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}.celebration-emoji{animation:bounce .6s ease-in-out infinite;font-size:80px;margin-bottom:16px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.celebration-title{color:#fff;font-size:48px;font-weight:900;letter-spacing:-1px;margin:0 0 12px;text-shadow:0 2px 10px #0003}.celebration-message{color:#fffffff2;font-size:18px;font-weight:600;line-height:1.6;margin:0 0 24px}.celebration-confetti{display:flex;gap:12px;justify-content:space-around;margin-top:20px}.celebration-confetti span{animation:float 2s ease-in-out infinite;font-size:40px}.celebration-confetti span:first-child{animation-delay:0s}.celebration-confetti span:nth-child(2){animation-delay:.1s}.celebration-confetti span:nth-child(3){animation-delay:.2s}.celebration-confetti span:nth-child(4){animation-delay:.3s}.celebration-confetti span:nth-child(5){animation-delay:.4s}.home-shell{background:#e8f4fd;flex-direction:column;font-family:Segoe UI,Inter,sans-serif;min-height:100vh;padding:48px 24px 64px}.home-header,.home-shell{align-items:center;display:flex}.home-header{background:#fff;box-shadow:0 2px 8px #0000000f;box-sizing:border-box;height:70px;justify-content:space-between;left:0;padding:0 40px;position:fixed;right:0;top:0;z-index:100}.home-brand{align-items:center;color:#1a2340;display:flex;font-size:22px;font-weight:800;gap:10px}.home-logo-icon{font-size:28px}.home-brand-name{letter-spacing:-.5px}.home-user-section{align-items:center;display:flex;gap:16px}.home-user-greeting{color:#4a5568;font-size:15px;font-weight:700}.home-logout-btn{background:#ebf4ff;border:1.5px solid #93c5fd;border-radius:12px;color:#2563eb;cursor:pointer;font-family:Segoe UI,Inter,sans-serif;font-size:14px;font-weight:700;padding:8px 16px;transition:all .2s ease}.home-logout-btn:hover{background:#dbeafe;border-color:#60a5fa;transform:translateY(-2px)}.home-logout-btn:active{transform:translateY(0)}.home-hero{flex-direction:column;gap:12px;margin-bottom:48px;margin-top:60px;text-align:center}.home-hero,.home-logo{align-items:center;display:flex}.home-logo{background:#fff;border-radius:20px;box-shadow:0 4px 18px #0000001a;font-size:38px;height:72px;justify-content:center;margin-bottom:8px;width:72px}.home-title{color:#1a2340;font-size:36px;font-weight:800;letter-spacing:-.5px;margin:0}.home-subtitle{color:#5a6580;font-size:15px;line-height:1.6;margin:0;max-width:440px}.home-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(4,1fr);max-width:1080px;width:100%}.home-grid>:last-child:nth-child(4n+1){grid-column:2/4}.home-card{background:#fff;border-radius:20px;box-shadow:0 4px 24px #00000012;display:flex;flex-direction:column;gap:12px;padding:28px 24px 24px;transition:transform .2s,box-shadow .2s}.home-card:hover{box-shadow:0 10px 32px #0000001c;transform:translateY(-4px)}.home-card--dim{opacity:.65}.home-card--dim:hover{box-shadow:0 4px 24px #00000012;transform:none}.home-card-icon{align-items:center;border-radius:14px;display:flex;font-size:26px;height:52px;justify-content:center;width:52px}.home-card-title{color:#1a2340;font-size:18px;font-weight:700;margin:0}.home-card-desc{color:#6b7280;flex:1 1;font-size:13.5px;line-height:1.55;margin:0}.home-start-btn{background:#2563eb;border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:15px;font-weight:700;letter-spacing:.2px;margin-top:4px;padding:13px 0;transition:background .18s,transform .15s;width:100%}.home-start-btn:hover:not(:disabled){background:#1d4ed8;transform:scale(1.02)}.home-start-btn:disabled{background:#93c5fd;cursor:not-allowed}@media (max-width:960px){.home-grid{grid-template-columns:repeat(2,1fr)}.home-grid>:last-child:nth-child(4n+1){grid-column:auto}.home-header{padding:0 20px}}@media (max-width:560px){.home-grid{grid-template-columns:1fr}.home-title{font-size:28px}.home-header{padding:0 16px}.home-user-section{flex-direction:column;gap:8px}.home-user-greeting{font-size:13px}.home-logout-btn{font-size:12px;padding:6px 12px}}.ig-shell{background:#f7f9fc;flex-direction:column;font-family:Segoe UI,Inter,sans-serif;min-height:100vh;padding-bottom:48px}.ig-header,.ig-shell{align-items:center;display:flex}.ig-header{background:#fff;box-shadow:0 1px 6px #00000012;box-sizing:border-box;justify-content:space-between;padding:18px 36px;width:100%}.ig-back-btn{background:none;border:1.5px solid #cbd5e0;border-radius:10px;color:#4a5568;cursor:pointer;font-size:14px;font-weight:600;padding:8px 18px;transition:background .15s,color .15s}.ig-back-btn:hover{background:#ebf4ff;border-color:#93c5fd;color:#2563eb}.ig-title{color:#1a2340;font-size:22px;font-weight:800;margin:0}.ig-score{font-size:17px;font-weight:700;min-width:80px;text-align:right}.ig-card{background:#fff;box-shadow:0 6px 32px #00000017;flex-direction:column;gap:20px;margin-top:40px;max-width:1000px;padding:36px 40px 32px;width:1000px}.ig-card,.ig-img-wrap{align-items:center;border-radius:24px;box-sizing:border-box;display:flex}.ig-img-wrap{animation:fadeIn .35s ease;box-shadow:0 4px 18px #00000014;height:360px;justify-content:center;padding:10px;width:360px}.ig-item-img{-webkit-user-drag:none;animation:popIn .3s ease;font-size:800px;height:360px;object-fit:contain;-webkit-user-select:none;user-select:none;width:560px}@keyframes fadeIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.ig-question{color:#1a2340;font-size:20px;font-weight:800;margin:0;text-align:center}.ig-subtitle{color:#718096;font-size:14px;margin:-10px 0 0;text-align:center}.ig-choices{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);width:100%}.ig-choice{background:#eef2ff;border:2px solid #e2e8f0;border-radius:14px;color:#2d3748;cursor:pointer;font-size:20px;font-weight:700;padding:14px 8px;transition:background .15s,border-color .15s,transform .12s}.ig-choice:hover:not(:disabled){background:#e0e7ff;transform:translateY(-2px)}.ig-choice:disabled{cursor:default}.ig-choice.correct{animation:blinkGreenIG .5s ease-in-out infinite!important;background:#22c55e;border-color:#16a34a;box-shadow:0 0 0 3px #16a34a,0 0 20px #22c55ecc;color:#fff}.ig-choice.wrong{background:#ef4444;border-color:#dc2626;box-shadow:0 0 0 3px #dc2626,0 0 20px #ef4444cc;color:#fff}.ig-choice.picked.wrong,.ig-choice.wrong{animation:blinkRedIG .5s ease-in-out infinite!important}@keyframes blinkGreenIG{0%,to{background:#22c55e!important;box-shadow:0 0 0 3px #16a34a,0 0 20px #22c55ecc!important;transform:scale(1)}50%{background:#10b981!important;box-shadow:0 0 0 8px #22c55e,0 0 35px #22c55e!important;transform:scale(1.02)}}@keyframes blinkRedIG{0%,to{background:#ef4444!important;box-shadow:0 0 0 3px #dc2626,0 0 20px #ef4444cc!important;transform:scale(1)}50%{background:#f87171!important;box-shadow:0 0 0 8px #ef4444,0 0 35px #ef4444!important;transform:scale(1.02)}}.ig-feedback{align-items:center;animation:fadeIn .3s ease;border-radius:16px;box-sizing:border-box;display:flex;gap:12px;justify-content:space-between;padding:16px 20px;width:100%}.ig-fb-correct{background:#f0fff4;border:1.5px solid #9ae6b4}.ig-fb-wrong{background:#fff5f5;border:1.5px solid #feb2b2}.ig-fb-msg{color:#2d3748;font-size:15px;font-weight:700}.ig-next-btn{border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:10px 24px;transition:opacity .15s,transform .12s;white-space:nowrap}.ig-next-btn:hover{opacity:.88;transform:scale(1.03)}@media (max-width:600px){.ig-card{margin-top:24px;padding:24px 18px}.ig-choices{grid-template-columns:repeat(2,1fr)}.ig-img-wrap{height:180px;width:180px}.ig-header{padding:14px 18px}.ig-title{font-size:17px}}.login-shell{align-items:center;background:linear-gradient(135deg,#1e40af,#1e3a8a);display:flex;font-family:Nunito,sans-serif;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-bg-decoration{inset:0;opacity:.1;pointer-events:none;position:absolute}.login-bg-decoration:before{animation:float 6s ease-in-out infinite;content:"😊 😢 😠 😮 😨 😐";font-size:120px;left:10%;position:absolute;top:-50px;white-space:nowrap}.login-bg-decoration:after{animation:float 8s ease-in-out infinite reverse;bottom:-50px;content:"🧠 💡 🎯 ⭐ 🎨 🌟";font-size:100px;position:absolute;right:5%;white-space:nowrap}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(20px) rotate(5deg)}}.login-container{gap:32px;max-width:420px;position:relative;width:100%;z-index:10}.login-container,.login-header{align-items:center;display:flex;flex-direction:column}.login-header{gap:12px;margin-bottom:20px;text-align:center}.login-logo{align-items:center;animation:popIn .6s cubic-bezier(.34,1.56,.64,1);background:#1e40af;border-radius:24px;box-shadow:0 10px 40px #0003;display:flex;font-size:48px;height:80px;justify-content:center;width:80px}@keyframes popIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.login-title{color:#fff;font-size:42px;font-weight:900;letter-spacing:-1px;margin:0;text-shadow:0 2px 10px #0003}.login-subtitle{color:#ffffffe6;font-size:16px;font-weight:500;line-height:1.5;margin:0}.login-subtitle-small{display:block;font-size:13px;font-style:italic;margin-top:4px;opacity:.9}.login-card{animation:slideUp .6s cubic-bezier(.34,1.56,.64,1);background:#fff;border-radius:28px;border-top:5px solid #1e40af;box-shadow:0 20px 60px #00000026;padding:40px 32px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.login-form-title{color:#1e40af;font-size:28px;font-weight:800;margin:0 0 24px;text-align:center}.login-error{align-items:center;animation:shake .4s ease-in-out;background:#fff5f5;border:2px solid #feb2b2;border-radius:14px;color:#c53030;display:flex;font-size:14px;font-weight:600;gap:10px;margin-bottom:20px;padding:12px 16px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}.error-icon{flex-shrink:0;font-size:20px}.login-form{gap:18px;margin-bottom:20px}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-label{align-items:center;display:flex;font-weight:700;gap:6px}.form-input,.form-label{color:#2d3748;font-size:15px}.form-input{background:#f7fafc;border:2px solid #e2e8f0;border-radius:14px;font-family:Nunito,sans-serif;font-weight:500;outline:none;padding:14px 16px;transition:all .3s ease}.form-input:focus{background:#fff;border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a}.form-input:disabled{cursor:not-allowed;opacity:.6}.form-input::placeholder{color:#a0aec0}.password-wrapper{align-items:center;display:flex;position:relative}.password-toggle{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:18px;justify-content:center;padding:0 8px;position:absolute;right:14px;transition:transform .2s ease}.password-toggle:hover{transform:scale(1.1)}.password-toggle:active{transform:scale(.95)}.login-btn{background:linear-gradient(135deg,#1e40af,#1e3a8a);border:none;border-radius:14px;box-shadow:0 6px 20px #1e40af66;color:#fff;cursor:pointer;font-family:Nunito,sans-serif;font-size:16px;font-weight:800;letter-spacing:.5px;padding:14px 24px;text-transform:uppercase;transition:all .3s ease}.login-btn:hover:not(:disabled){box-shadow:0 8px 28px #1e40af80;transform:translateY(-2px)}.login-btn:active:not(:disabled){box-shadow:0 4px 16px #1e40af66;transform:translateY(0)}.login-btn:disabled{cursor:not-allowed;opacity:.7}.login-info-box{background:#eff6ff;border:1px solid #bfdbfe;border-left:4px solid #1e40af;border-radius:12px;margin-top:20px;padding:14px 16px;text-align:center}.info-text{color:#1e40af;font-size:13px;font-weight:600;line-height:1.6;margin:0}.login-footer{padding:0 20px;text-align:center}.login-footer p{color:#ffffffd9;font-size:13px;font-weight:500;line-height:1.6;margin:0 0 8px}.login-footer-secondary{font-size:12px!important;opacity:.8}@media (max-width:480px){.login-shell{padding:16px}.login-container{gap:24px;max-width:100%}.login-card{padding:28px 20px}.login-logo{font-size:42px;height:70px;width:70px}.login-title{font-size:36px}.login-subtitle{font-size:15px}.login-form-title{font-size:24px;margin-bottom:18px}.form-input{font-size:14px;padding:12px 14px}.demo-btn,.login-btn{font-size:15px;padding:12px 20px}.helper-text{font-size:12px}}@media print{.login-shell{display:none}}
/*# sourceMappingURL=main.a7802a77.css.map*/