.vr-gallery{position:fixed;top:0;left:0;width:100%;height:100%;overflow:hidden}.vr-loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#1a1a2e;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;transition:opacity .5s}.vr-loading-overlay.hidden{opacity:0;pointer-events:none}.loading-spinner{width:50px;height:50px;border:4px solid rgba(253,121,168,.3);border-top-color:#fd79a8;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-family:Fredoka One,cursive;font-size:1.5rem;color:#c4a77d}.vr-back-btn{position:fixed;top:20px;left:20px;background:#ffffffe6;color:#333;padding:12px 24px;border-radius:25px;font-family:Fredoka One,cursive;font-size:1rem;z-index:100;box-shadow:0 4px 15px #0003;text-decoration:none;cursor:pointer;border:none;transition:all .3s}.vr-back-btn:hover{transform:scale(1.05);background:#fff}.vr-gallery-title{position:fixed;top:20px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#c4a77df2,#8b7765f2);color:#fff;padding:15px 40px;border-radius:30px;font-family:Fredoka One,cursive;font-size:1.5rem;z-index:100;box-shadow:0 4px 20px #0003;text-shadow:1px 1px 2px rgba(0,0,0,.2)}.vr-room-info{position:fixed;top:80px;right:20px;background:#ffffffe6;padding:15px 20px;border-radius:15px;box-shadow:0 4px 15px #0000001a;z-index:100;font-size:13px;color:#636e72}.vr-room-info strong{color:#c4a77d}.vr-hint{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:12px 24px;border-radius:30px;font-size:14px;z-index:100;display:flex;align-items:center;gap:10px;animation:fadeInOut 4s ease forwards}@keyframes fadeInOut{0%,to{opacity:0}10%,80%{opacity:1}}a-scene{width:100%!important;height:100%!important}.a-enter-vr-button{width:80px!important;height:50px!important;border-radius:12px!important;background:linear-gradient(135deg,#667eea,#764ba2)!important;border:3px solid rgba(255,255,255,.5)!important;box-shadow:0 4px 15px #0000004d!important;opacity:.9!important;transition:all .3s ease!important}.a-enter-vr-button:hover{transform:scale(1.1)!important;opacity:1!important;box-shadow:0 6px 25px #667eea80!important}.a-enter-vr-button:after{content:"🥽 VR"!important;font-size:14px!important;font-weight:700!important;color:#fff!important;display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important;height:100%!important}.clickable{cursor:pointer}.clickable:hover{opacity:.9}@media (max-width: 768px){.vr-gallery-title{font-size:1.1rem;padding:10px 25px}.vr-back-btn{padding:10px 18px;font-size:.9rem}.vr-room-info{display:none}}.modal{z-index:1000}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-gradient-start: #ffeaa7;--bg-gradient-mid1: #fab1a0;--bg-gradient-mid2: #fd79a8;--bg-gradient-mid3: #a29bfe;--bg-gradient-end: #74b9ff;--card-bg: white;--text-primary: #2d3436;--text-secondary: #636e72;--accent-color: #fdcb6e;--shadow-color: rgba(0,0,0,.1);--teacher-bubble: #e3f2fd;--teacher-bubble-border: #90caf9;--student-bubble: #f5f5f5;--student-bubble-border: #e0e0e0;--chat-bg: #fafafa}[data-theme=dark]{--bg-gradient-start: #1a1a2e;--bg-gradient-mid1: #16213e;--bg-gradient-mid2: #0f3460;--bg-gradient-mid3: #533483;--bg-gradient-end: #e94560;--card-bg: #2d3436;--text-primary: #dfe6e9;--text-secondary: #b2bec3;--accent-color: #e94560;--shadow-color: rgba(0,0,0,.3);--teacher-bubble: #1e3a5f;--teacher-bubble-border: #3d7ab8;--student-bubble: #3d3d3d;--student-bubble-border: #555;--chat-bg: #1a1a1a}body{font-family:Nunito,Segoe UI,sans-serif;background:linear-gradient(180deg,var(--bg-gradient-start) 0%,var(--bg-gradient-mid1) 25%,var(--bg-gradient-mid2) 50%,var(--bg-gradient-mid3) 75%,var(--bg-gradient-end) 100%);min-height:100vh;padding:20px;position:relative;overflow-x:hidden;transition:all .5s ease}.floating-animals{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.animal{position:absolute;font-size:40px;opacity:.08;animation:gentleFloat 8s infinite ease-in-out}@keyframes gentleFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(2deg)}}.container{max-width:1200px;margin:0 auto;position:relative;z-index:1}.header{text-align:center;margin-bottom:30px}.title-wrapper{display:inline-flex;align-items:center;position:relative;padding:20px 50px;background:var(--card-bg);border-radius:30px;box-shadow:0 8px 32px var(--shadow-color)}.title-content{text-align:center}.title-content p{font-size:clamp(.85rem,4vw,1rem);color:var(--text-secondary);font-weight:600;margin-top:5px;text-align:center;padding:0 20px;max-width:100%;box-sizing:border-box}.header h1{font-family:Fredoka One,cursive;font-size:2.8rem;background:linear-gradient(135deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:rainbow 4s ease infinite}@keyframes rainbow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@media (max-width: 480px){.title-wrapper{padding:15px 20px;max-width:92vw}.header h1{font-size:clamp(1.6rem,7vw,2rem);white-space:nowrap}.title-content{text-align:center;max-width:100%}.title-content p{text-align:center;font-size:clamp(.8rem,3.5vw,.9rem);padding:0 10px}}.login-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;z-index:2000;display:flex;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-box{background:var(--card-bg);border-radius:30px;padding:40px;max-width:400px;width:90%;box-shadow:0 30px 100px #00000080;border:4px solid var(--accent-color)}.login-box h2{font-family:Fredoka One,cursive;text-align:center;color:var(--text-primary);margin-bottom:30px;font-size:1.8rem}.login-box input{width:100%;padding:15px 20px;border:2px solid var(--accent-color);border-radius:15px;font-size:1rem;font-family:inherit;background:var(--card-bg);color:var(--text-primary);margin-bottom:15px}.login-box input:focus{outline:none;border-color:#ff6b6b}.login-box button{width:100%;padding:15px;border:none;border-radius:15px;font-size:1.1rem;font-weight:700;cursor:pointer;font-family:Fredoka One,cursive;background:linear-gradient(135deg,#ff6b6b,#feca57);color:#fff;transition:all .3s}.login-box button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ff6b6b66}.login-error{color:#ff6b6b;text-align:center;margin-top:15px;font-weight:600;display:none}.login-error{display:block}.theme-toggle{position:fixed;top:20px;right:20px;width:50px;height:50px;border-radius:50%;border:none;background:var(--card-bg);cursor:pointer;font-size:1.5rem;transition:all .3s ease;box-shadow:0 4px 15px var(--shadow-color);z-index:100}.theme-toggle:hover{transform:scale(1.1) rotate(15deg)}.vr-btn{position:fixed;top:20px;right:75px;width:50px;height:50px;border-radius:50%;border:none;background:var(--card-bg);cursor:pointer;font-size:1.5rem;transition:all .3s ease;box-shadow:0 4px 15px var(--shadow-color);z-index:100;text-decoration:none;display:flex;align-items:center;justify-content:center}.vr-btn:hover{transform:scale(1.1);background:linear-gradient(135deg,#a29bfe,#fd79a8)}.logout-btn{position:fixed;top:20px;right:130px;padding:10px 20px;border:none;border-radius:20px;background:var(--card-bg);color:var(--text-primary);cursor:pointer;font-size:.9rem;font-weight:600;box-shadow:0 4px 15px var(--shadow-color);z-index:100;transition:all .3s;display:none}.logout-btn:hover{transform:scale(1.05);background:#ff6b6b;color:#fff}.logout-btn.visible{display:block}.masonry{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:40px}@media (max-width: 1024px){.masonry{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.masonry{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.masonry{grid-template-columns:repeat(1,1fr)}.photo-info .rating-bar{flex-wrap:wrap;justify-content:center;gap:6px}.photo-info .rating-divider{display:none}.photo-info .card-action-inline{margin-top:0}}.photo-card{break-inside:avoid;background:var(--card-bg);border-radius:20px;margin-bottom:20px;overflow:hidden;box-shadow:0 4px 15px var(--shadow-color);transition:all .3s ease;cursor:pointer;position:relative;border:3px solid transparent;animation:fadeInUp .5s ease forwards;opacity:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.photo-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 12px 30px var(--shadow-color);border-color:var(--accent-color)}.photo-wrapper{position:relative;overflow:hidden;height:279px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f5f5,#e8e8e8)}.photo-wrapper img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}.photo-card:hover .photo-wrapper img{transform:scale(1.05)}.delete-btn{position:absolute;top:8px;left:8px;width:28px;height:28px;background:#ff7675;border:2px solid #ff7675;border-radius:50%;cursor:pointer;font-size:14px;font-weight:700;line-height:1;display:none;align-items:center;justify-content:center;color:#fff;text-shadow:0 0 2px rgba(0,0,0,.3);z-index:20;transition:all .2s;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.photo-card:hover .delete-btn{display:flex;background:#ff7675;color:#fff}.photo-card:hover .delete-btn:hover{transform:scale(1.1)}.photo-info{padding:10px 12px;background:var(--card-bg)}.photo-name{font-weight:700;color:var(--text-primary);font-size:.95rem;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Fredoka One,cursive}.photo-info .rating-bar{display:flex;justify-content:center;align-items:center;flex-direction:row;gap:8px;padding:8px 6px;background:#fdcb6e1a;border-top:1px solid rgba(0,0,0,.05);position:relative;z-index:5}.photo-info .rating-items{display:flex;gap:6px}.photo-info .rating-item{display:flex;align-items:center;gap:3px;cursor:pointer;padding:5px 8px;border-radius:8px;background:#fff;box-shadow:0 1px 4px #0000000f;transition:all .25s ease;flex-shrink:0;position:relative;z-index:10}.photo-info .rating-item:hover{transform:translateY(-2px);box-shadow:0 3px 10px #0000001a}.photo-info .rating-item.disabled{cursor:not-allowed;opacity:.7}.photo-info .rating-item.disabled:hover{transform:none;box-shadow:0 1px 4px #0000000f}.photo-info .rating-item .icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.photo-info .rating-item .count{font-size:.8rem;color:var(--text-secondary);font-weight:600;min-width:20px;text-align:center}.photo-info .rating-item.active .count{color:#ff6b6b;font-weight:700}.photo-info .rating-divider{color:var(--text-secondary);font-size:1.2rem;opacity:.5;flex-shrink:0}.photo-info .card-action-inline{display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;border-radius:50%;transition:all .3s ease;flex-shrink:0;position:relative;z-index:10}.photo-info .card-action-inline:hover{transform:scale(1.1)}.photo-info .card-action-inline.record{width:32px;height:32px;background:linear-gradient(135deg,#ff6b6b,#feca57);box-shadow:0 2px 8px #ff6b6b66;animation:pulse-action 2s infinite}.photo-info .card-action-inline.record:hover{animation:none;box-shadow:0 4px 12px #ff6b6b80}.photo-info .card-action-inline.play{width:32px;height:32px;background:linear-gradient(135deg,#00b894,#00cec9);box-shadow:0 2px 8px #00b89466}.photo-info .card-action-inline.play:hover{box-shadow:0 4px 12px #00b89480}@keyframes pulse-action{0%,to{box-shadow:0 2px 8px #ff6b6b66}50%{box-shadow:0 2px 12px #ff6b6b80,0 0 15px #ff6b6b26}}.upload-btn{position:fixed;bottom:30px;right:30px;width:60px;height:60px;border-radius:50%;border:none;background:linear-gradient(135deg,#ff6b6b,#feca57);color:#fff;cursor:pointer;box-shadow:0 6px 20px #ff6b6b66;transition:all .4s cubic-bezier(.4,0,.2,1);z-index:100;display:flex;align-items:center;overflow:hidden;padding:0}.upload-btn:hover{width:260px;border-radius:30px;box-shadow:0 10px 30px #ff6b6b80}.upload-btn:active{transform:scale(.95)}.upload-btn .icon-wrapper{width:60px;height:60px;min-width:60px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.upload-btn .text{white-space:nowrap;opacity:0;max-width:0;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);font-size:1rem;font-weight:600;font-family:Nunito,sans-serif;color:#fff;padding-left:5px}.upload-btn:hover .text{opacity:1;max-width:200px}.empty-state{text-align:center;padding:80px 20px;color:var(--text-primary);display:none}.empty-state.show{display:block}.empty-icon{font-size:80px;margin-bottom:20px;animation:bounce 2s infinite}.empty-text{font-size:1.3rem;font-weight:600}.stats-bar{text-align:center;margin-bottom:20px;color:var(--text-primary);font-weight:600;font-size:1rem}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;z-index:1000;justify-content:center;align-items:center;padding:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal.active{display:flex}.modal-content{background:var(--card-bg);border-radius:30px;max-width:1000px;width:95%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 30px 100px #00000080;border:4px solid var(--accent-color)}.modal-header{padding:20px 30px;border-bottom:2px solid var(--accent-color);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#fdcb6e1a,#fff5f51a)}.modal-title{font-size:1.4rem;font-weight:700;color:var(--text-primary);font-family:Fredoka One,cursive;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:15px}.modal-close{background:#ff7675;border:none;font-size:24px;color:#fff;cursor:pointer;flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;box-shadow:0 2px 8px #0003}.modal-close:hover{background:#d63031;transform:scale(1.1) rotate(90deg)}.modal-body{display:flex;flex:1;overflow:hidden}.photo-preview{flex:1;padding:30px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8f9fa1a,#fff5f51a);min-width:0}.preview-img{max-width:100%;max-height:400px;border-radius:20px;box-shadow:0 10px 40px #00000026;border:4px solid var(--card-bg)}.chat-modal .modal-content{max-width:1100px}.chat-panel{width:420px;display:flex;flex-direction:column;background:var(--chat-bg);border-left:2px solid var(--accent-color)}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.chat-message{display:grid;grid-template-columns:40px 10px 1fr 10px 40px;gap:0;width:100%;animation:messageSlideIn .3s ease}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.teacher{grid-template-areas:"avatar gap bubble bubble bubble"}.chat-message.teacher .chat-avatar{grid-area:avatar}.chat-message.teacher .chat-bubble{grid-area:bubble;background:var(--teacher-bubble);border:2px solid var(--teacher-bubble-border);border-radius:18px 18px 18px 4px;justify-self:start;max-width:calc(100% - 50px)}.chat-message.student{grid-template-areas:"bubble bubble bubble gap avatar"}.chat-message.student .chat-avatar{grid-area:avatar}.chat-message.student .chat-bubble{grid-area:bubble;background:var(--student-bubble);border:2px solid var(--student-bubble-border);border-radius:18px 18px 4px;justify-self:end;max-width:calc(100% - 50px)}.chat-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#ff6b6b,#feca57);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;position:relative;cursor:default}.chat-avatar.clickable{cursor:pointer}.chat-avatar .default-avatar,.chat-avatar img{display:block;width:32px;height:32px;border-radius:50%;object-fit:cover}.chat-avatar.clickable:hover{transform:scale(1.1);box-shadow:0 4px 12px #0003}.chat-avatar.speaking{background:linear-gradient(135deg,#00b894,#00cec9);animation:avatar-speaking 1s ease-in-out infinite;box-shadow:0 4px 15px #00b89466}.chat-avatar.speaking img{animation:avatar-speaking 1s ease-in-out infinite}@keyframes avatar-speaking{0%,to{transform:scale(1);box-shadow:0 4px 15px #00b89466}50%{transform:scale(1.1);box-shadow:0 6px 20px #00b89499}}@keyframes speaker-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.chat-bubble{padding:12px 16px;min-height:44px;display:flex;align-items:center;transition:all .2s ease;max-width:100%;box-sizing:border-box}.chat-bubble.has-audio{cursor:pointer;position:relative}.chat-bubble.has-audio:hover{transform:scale(1.02)}.chat-bubble.has-audio.playing{box-shadow:0 0 0 3px #00b8944d}.audio-indicator{margin-left:8px;font-size:.9rem;opacity:.7}.chat-bubble.has-audio:hover .audio-indicator{opacity:1}.chat-text{font-size:.95rem;line-height:1.5;color:var(--text-primary)}.chat-text.typing{min-height:1.5em}.typing-cursor{display:inline-block;color:var(--teacher-bubble-border);font-weight:300;animation:cursor-blink .8s infinite;margin-left:2px}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.typing-waves{display:flex;align-items:center;gap:4px;height:20px;padding:0 4px}.typing-waves span{width:6px;height:6px;background:var(--teacher-bubble-border);border-radius:50%;animation:typing-wave 1.4s ease-in-out infinite}.typing-waves span:nth-child(1){animation-delay:0s}.typing-waves span:nth-child(2){animation-delay:.2s}.typing-waves span:nth-child(3){animation-delay:.4s}@keyframes typing-wave{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-8px);opacity:1}}.chat-audio{display:flex;align-items:center;gap:8px;width:100%;min-width:100px;max-width:100%;box-sizing:border-box}.chat-bubble.skeleton-bubble{background:var(--teacher-bubble);border:2px solid var(--teacher-bubble-border);min-width:220px;animation:skeleton-pulse 2s ease-in-out infinite}.chat-audio-skeleton{display:flex;align-items:center;gap:10px;width:100%}.skeleton-play-btn{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#e0e0e0,#f0f0f0);display:flex;align-items:center;justify-content:center;flex-shrink:0}.skeleton-spinner{width:18px;height:18px;border:2px solid #ddd;border-top-color:#90caf9;border-radius:50%;animation:skeleton-spin 1s linear infinite}@keyframes skeleton-spin{to{transform:rotate(360deg)}}.skeleton-wave{flex:1;display:flex;align-items:center;gap:3px;height:30px}.skeleton-bar{flex:1;height:8px;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;border-radius:2px;animation:skeleton-shimmer 1.5s infinite}.skeleton-bar:nth-child(odd){height:12px;animation-delay:.1s}.skeleton-bar:nth-child(3n){height:16px;animation-delay:.2s}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.7}}.skeleton-time{font-size:.8rem;color:var(--text-secondary);font-weight:600;min-width:40px;text-align:right;opacity:.6}.chat-controls{padding:16px 20px;background:var(--card-bg);border-top:2px solid var(--accent-color);display:flex;flex-direction:column;gap:16px}.recording-section{display:flex;flex-direction:column;gap:10px}.record-actions-row{display:flex;gap:10px;align-items:center}.record-btn-chat{flex:1;padding:14px 20px;border:none;border-radius:25px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px;font-family:Fredoka One,cursive;box-shadow:0 4px 15px var(--shadow-color)}.record-btn-chat.start{background:linear-gradient(135deg,#ff6b6b,#feca57);color:#fff}.record-btn-chat.start:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ff6b6b66}.record-btn-chat.recording{background:linear-gradient(135deg,#ff6b6b,#ff7675);color:#fff;animation:pulse-shadow 1.5s infinite}.record-btn-chat:disabled{opacity:.5;cursor:not-allowed}.record-btn-chat svg{width:20px;height:20px}.recording-indicator-chat{display:none;align-items:center;justify-content:center;gap:10px;color:#ff6b6b;font-weight:700;font-size:.9rem}.recording-indicator-chat.active{display:flex}.recording-pulse{width:12px;height:12px;background:#ff6b6b;border-radius:50%;animation:pulse-dot 1s infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.delete-record-btn{width:46px;height:46px;border-radius:50%;border:none;background:linear-gradient(135deg,#ff7675,#d63031);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.delete-record-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #d630314d}.delete-record-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.delete-record-btn svg{width:20px;height:20px;fill:#fff}.rating-section{padding-top:12px;border-top:1px solid rgba(0,0,0,.1)}.rating-title{font-weight:700;color:var(--text-primary);margin-bottom:10px;font-family:Fredoka One,cursive;font-size:.95rem}.rating-bar-vr{display:flex;flex-direction:column;gap:8px}.rating-item-vr{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:12px;background:#fff;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px #00000014;border:2px solid transparent}.rating-item-vr:hover{transform:translate(5px);box-shadow:0 4px 12px #0000001f;border-color:var(--accent-color)}.rating-item-vr.disabled{opacity:.6;cursor:not-allowed}.rating-item-vr.disabled:hover{transform:none;border-color:transparent}.rating-item-vr .rating-label{display:flex;align-items:center;gap:10px;font-size:.85rem;font-weight:600;color:var(--text-primary)}.rating-item-vr .icon{font-size:18px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fdcb6e33,#fff5f533);border-radius:8px}.rating-item-vr .count{font-size:.9rem;font-weight:700;color:#ff6b6b;background:linear-gradient(135deg,#fff5f5,#fff);padding:4px 12px;border-radius:15px;min-width:35px;text-align:center}@media (max-width: 768px){body{-webkit-overflow-scrolling:touch}.chat-modal .modal-content{width:100%;max-height:95vh}.modal-body{flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}.photo-preview{padding:15px;max-height:35vh;flex-shrink:0}.preview-img{max-height:180px}.chat-panel{width:100%;border-left:none;border-top:2px solid var(--accent-color);max-height:none;flex:1;overflow-y:visible}.chat-messages{padding:15px;max-height:40vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.chat-message.teacher .chat-bubble,.chat-message.student .chat-bubble{max-width:calc(100% - 45px)}.chat-audio{gap:6px}.chat-audio-play{width:32px;height:32px}.audio-wave-bars{gap:1px}.audio-wave-bars span{min-width:2px;max-width:3px}.audio-wave-bars span:nth-child(n+16){display:none}.chat-controls{padding:12px 15px}}.toast{position:fixed;bottom:30px;left:50%;transform:translate(-50%) translateY(100px);background:linear-gradient(135deg,#ff6b6b,#feca57);color:#fff;padding:16px 35px;border-radius:50px;font-size:1.1rem;font-weight:700;opacity:0;transition:all .3s;z-index:2000;box-shadow:0 10px 40px #0003;font-family:Fredoka One,cursive}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:3000;display:flex;justify-content:center;align-items:center}.loading-overlay.hidden{display:none}.chat-audio-play{width:36px;height:36px;border-radius:50%;border:none;background:linear-gradient(135deg,#55efc4,#00b894);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.chat-audio-play:hover{transform:scale(1.1);box-shadow:0 4px 12px #00b8944d}.chat-audio-play.playing{background:linear-gradient(135deg,#feca57,#ff9f43)}.chat-audio-play svg{width:16px;height:16px;fill:#fff}.chat-audio-wave{flex:1;height:30px;display:flex;align-items:center;min-width:0}.audio-wave-bars{display:flex;align-items:center;gap:2px;height:100%;flex:1;min-width:0}.audio-wave-bars span{flex:1;min-width:2px;max-width:4px;height:8px;background:var(--text-secondary);border-radius:2px;opacity:.5;transition:all .2s}.audio-wave-bars span.active{animation:soundWave .5s ease-in-out infinite;background:#00b894;opacity:1}.audio-wave-bars span:nth-child(odd){height:12px;animation-delay:.1s}.audio-wave-bars span:nth-child(3n){height:16px;animation-delay:.2s}@keyframes soundWave{0%,to{height:8px}50%{height:24px}}.chat-audio-time{font-size:.75rem;color:var(--text-secondary);font-weight:600;min-width:32px;text-align:right;flex-shrink:0}.ai-evaluating{display:flex;align-items:center;gap:12px}.evaluating-text{font-size:.9rem;color:var(--text-secondary);font-weight:600}.typing-indicator{display:flex;gap:4px}.typing-indicator span{width:8px;height:8px;background:var(--teacher-bubble-border);border-radius:50%;animation:typingBounce 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typingBounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}
