.app{min-height:100vh;display:flex;flex-direction:column;background:#f5f7fa}.top-nav{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100}.nav-content{max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.nav-brand{display:flex;align-items:center;gap:.75rem;color:#fff}.brand-icon{width:2rem;height:2rem}.brand-text{font-size:1.5rem;font-weight:700;letter-spacing:-.5px}.nav-actions{display:flex;align-items:center;gap:.75rem}.upload-button,.logout-button{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease}.upload-button:hover,.logout-button:hover{background:#ffffff4d;transform:translateY(-1px)}.upload-button{background:#fffffff2;color:#667eea;border-color:#fffffff2}.upload-button:hover{background:#fff;box-shadow:0 4px 12px #00000026}.upload-icon,.logout-icon{font-size:1.2rem}.main-content{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:0}.gallery-section{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 2px 8px #0000000d;margin:2rem}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.gallery-title-row{display:flex;align-items:center;gap:1rem}.gallery-title{font-size:1.75rem;color:#333;font-weight:700;margin:0}.refresh-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#f5f5f5;color:#666;border:1px solid #ddd;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:all .2s ease}.refresh-button:hover:not(:disabled){background:#e8e8e8;border-color:#ccc}.refresh-button:active:not(:disabled){transform:scale(.95)}.refresh-button:disabled{opacity:.4;cursor:not-allowed}.search-box{display:flex;align-items:center;gap:.5rem;background:#f5f7fa;border:2px solid #e0e0e0;border-radius:10px;padding:.5rem 1rem;transition:all .3s ease;min-width:250px}.search-box:focus-within{border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.search-icon{font-size:1.2rem;color:#666}.search-input{border:none;background:transparent;outline:none;font-size:.95rem;color:#333;flex:1;min-width:0}.search-input::placeholder{color:#999}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:12px;margin-bottom:1.5rem;text-align:center;border:2px solid #fcc}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#667eea}.spinner{width:50px;height:50px;border:4px solid rgba(102,126,234,.2);border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading p{color:#666;font-size:1rem}@media (max-width: 768px){.nav-content{padding:1rem}.brand-text{font-size:1.2rem}.brand-icon{width:1.5rem;height:1.5rem}.main-content{padding:1rem}.gallery-section{padding:1.5rem}.gallery-header{flex-direction:column;align-items:stretch}.gallery-title{font-size:1.5rem}.search-box{width:100%;min-width:0}.upload-button span:last-child,.logout-button span:last-child{display:none}.nav-actions{gap:.5rem}}@media (max-width: 480px){.gallery-section{padding:1rem;border-radius:12px}.gallery-title{font-size:1.25rem}}.video-gallery{width:100%}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.video-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014;transition:all .3s ease;cursor:pointer;display:flex;flex-direction:column;height:100%;border:1px solid #e0e0e0;position:relative}.video-card-blur-bg{position:absolute;top:-20px;left:-20px;right:-20px;bottom:-20px;background-size:cover;background-position:center;filter:blur(25px);opacity:.6;z-index:0}.video-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #667eea26}.video-card.disabled{opacity:.85;cursor:default}.video-card.disabled:hover{transform:translateY(-4px);box-shadow:0 8px 24px #667eea26}.video-thumbnail{width:100%;height:200px;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden;z-index:1}.english-level-badge{position:absolute;top:.75rem;right:.75rem;background:#667eeaf2;color:#fff;padding:.5rem .75rem;border-radius:8px;font-size:1rem;font-weight:700;z-index:10;letter-spacing:.5px}.english-level-badge.clickable{cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #667eea4d}.english-level-badge.clickable:hover{background:#764ba2fa;transform:scale(1.15);box-shadow:0 4px 12px #667eea80}.thumbnail-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.video-card:hover .thumbnail-image{transform:scale(1.05)}.thumbnail-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:1rem}.placeholder-icon{font-size:3rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.placeholder-text{font-size:1.1rem;font-weight:500}.video-info{padding:1.5rem;display:flex;flex-direction:column;flex:1;z-index:1;background:#fff}.video-name{color:#333;font-size:1.2rem;margin:0 0 1rem;line-height:1.4;flex:1;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative}.video-name-marquee{color:#333;font-size:1.2rem;margin:0 0 1rem;line-height:1.4;flex:1;display:block;white-space:nowrap;overflow:hidden;position:relative}.video-name-marquee .marquee-inner{display:inline-block;white-space:nowrap}.video-name-marquee:hover .marquee-inner{animation:marquee 8s linear infinite}@keyframes marquee{0%{transform:translate(0)}50%{transform:translate(calc(-100% + 200px))}to{transform:translate(0)}}.video-status{margin-top:auto;padding-top:.5rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.delete-button{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#fff5f5;border:1px solid #ffdddd;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease;padding:0}.delete-button:hover{background:#ffe8e8;border-color:#fcc}.delete-button:active{transform:scale(.95)}.prepare-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d}.prepare-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea80}.prepare-button:active{transform:scale(.95)}.delete-confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.delete-confirm-dialog{background:#fff;border-radius:20px;padding:2.5rem;max-width:480px;width:90%;box-shadow:0 25px 80px #0006;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}.delete-confirm-dialog h3{margin:0 0 1.5rem;font-size:1.75rem;color:#333;text-align:center;font-weight:700}.delete-confirm-dialog p{margin:0 0 .75rem;color:#666;line-height:1.6;text-align:center}.video-name-display{font-weight:600;color:#333!important;background:#f8f9fa;padding:.75rem 1rem;border-radius:8px;word-break:break-word;margin-bottom:1rem!important;font-size:.95rem}.warning-text{color:#dc3545!important;font-weight:600;margin-bottom:1.5rem!important;font-size:1.05rem}.math-verification{margin:1.5rem 0;padding:1.5rem;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;border:2px solid #dee2e6;text-align:center}.math-question{margin:0 0 .5rem;color:#666;font-size:.95rem;font-weight:500}.math-equation{margin:0 0 1rem;color:#007bff;font-size:2rem;font-weight:700;letter-spacing:2px}.math-input{width:100%;padding:1rem;border:2px solid #ced4da;border-radius:10px;font-size:1.25rem;text-align:center;font-weight:600;transition:all .3s ease;background:#fff}.math-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 4px #007bff26;transform:scale(1.02)}.math-input.error{border-color:#dc3545;background:#fff5f5;animation:shake .5s ease}.math-input.error:focus{box-shadow:0 0 0 4px #dc354526}.error-message{margin:.75rem 0 0;color:#dc3545;font-size:.95rem;font-weight:600}.dialog-buttons{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.cancel-button,.confirm-delete-button{flex:1;padding:1rem 2rem;border:none;border-radius:12px;font-size:1.05rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.cancel-button{background:#f8f9fa;color:#666;border:2px solid #dee2e6}.cancel-button:hover:not(:disabled){background:#e9ecef;border-color:#ced4da;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.confirm-delete-button{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;box-shadow:0 4px 15px #dc35454d}.confirm-delete-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #dc354566}.cancel-button:disabled,.confirm-delete-button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.status-badge{display:inline-block;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600}.status-badge.success{background:transparent;color:#155724;padding:0;font-size:.85rem}.status-badge.processing{background:#fff3cd;color:#856404}.processing-hint{font-size:.8rem;color:#856404;font-style:italic;white-space:nowrap}.retry-dialog-button{flex:1;padding:1rem 2rem;border:none;border-radius:12px;font-size:1.05rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.retry-dialog-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.delete-dialog-button{flex:1;padding:1rem 2rem;border:none;border-radius:12px;font-size:1.05rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;box-shadow:0 4px 15px #dc35454d}.delete-dialog-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #dc354566}.error-dialog-buttons{gap:1rem}.status-badge.error{background:#f8d7da;color:#721c24;display:flex;align-items:center;gap:.5rem}.error-status-group{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#fff5f5,#ffe8e8);border:1px solid #f5c6cb;border-radius:20px;padding:.25rem .5rem}.error-icon-btn{cursor:pointer;font-size:1.2rem;transition:transform .2s ease;display:flex;align-items:center;justify-content:center}.error-icon-btn:hover{transform:scale(1.2)}.retry-button{display:flex;align-items:center;gap:.25rem;padding:.35rem .75rem;background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;border:none;border-radius:15px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-button:hover{transform:scale(1.05);box-shadow:0 2px 8px #dc354566}.video-card.has-error{border-color:#f5c6cb}.video-card.has-error:hover{border-color:#dc3545;box-shadow:0 8px 24px #dc354526}.error-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.error-dialog{background:#fff;border-radius:20px;padding:2.5rem;max-width:500px;width:90%;box-shadow:0 25px 80px #0006;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}.error-dialog h3{margin:0 0 1rem;font-size:1.5rem;color:#dc3545;text-align:center}.error-video-name{font-weight:600;color:#333;background:#f8f9fa;padding:.75rem 1rem;border-radius:8px;word-break:break-word;margin-bottom:1rem;font-size:.95rem;text-align:center}.error-details{background:#fff5f5;border:1px solid #f5c6cb;border-radius:10px;padding:1rem;margin-bottom:1rem}.error-label{font-weight:600;color:#721c24;margin:0 0 .5rem;font-size:.9rem}.error-message-text{color:#856404;margin:0;font-size:.9rem;line-height:1.5;word-break:break-word;font-family:monospace;background:#fff;padding:.75rem;border-radius:6px;border:1px solid #e9ecef}.error-hint{color:#666;font-size:.9rem;text-align:center;margin:0 0 1.5rem}.view-button{width:100%;padding:.75rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;cursor:pointer;transition:all .3s ease}.view-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.view-button:disabled{opacity:.5;cursor:not-allowed;background:#ccc}.empty-gallery{text-align:center;padding:4rem 2rem;color:#666}.empty-icon{font-size:5rem;margin-bottom:1rem;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.empty-gallery h2{font-size:2rem;margin-bottom:.5rem;color:#333}.empty-gallery p{font-size:1.2rem;color:#666}@media (max-width: 768px){.gallery-grid{grid-template-columns:1fr;gap:1rem}}@media (max-width: 480px){.gallery-grid{grid-template-columns:1fr}.video-card{border-radius:10px}}.video-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;z-index:1000;overflow:hidden}.video-detail-container{width:100vw;height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden}.close-button-top{position:absolute;top:1rem;right:1rem;background:#667eeae6;color:#fff;border:none;border-radius:50%;width:48px;height:48px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:10;box-shadow:0 4px 12px #00000026}.close-button-top:hover{background:#764ba2e6;transform:scale(1.1);box-shadow:0 6px 16px #0003}.page-content{flex:1;overflow:hidden;padding:0;display:flex;flex-direction:column}.navigation-controls{display:flex;align-items:center;justify-content:space-between;padding:.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-top:1px solid rgba(255,255,255,.1)}.nav-button-wrapper{position:relative;display:flex;align-items:center}.nav-preview{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:.75rem;background:#fff;border:2px solid #667eea;border-radius:12px;overflow:hidden;box-shadow:0 8px 24px #0000004d;z-index:100;animation:fadeInUp .2s ease;min-width:200px}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.nav-preview-image{width:100%;height:auto;display:block;max-width:300px}.nav-preview-title{padding:.75rem;text-align:center;font-weight:600;color:#667eea;font-size:.95rem;background:linear-gradient(135deg,#f5f7ff,#f0f2ff)}.nav-preview-text{padding:1rem 1.5rem;text-align:center;font-weight:600;color:#667eea;font-size:1.05rem;white-space:nowrap}.nav-button{padding:.5rem 1.5rem;font-size:.9rem;font-weight:600;color:#fff;background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-button:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.nav-button:disabled{opacity:.3;cursor:not-allowed}.page-indicator{color:#fff;font-size:.95rem;font-weight:600}.loading-content,.error-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1.5rem}.loading-content .spinner{width:60px;height:60px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.loading-content p,.error-content p{font-size:1.2rem;color:#666}.error-content .close-button{padding:.75rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;cursor:pointer;transition:all .3s ease}.error-content .close-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media (max-width: 768px){.close-button-top{width:40px;height:40px;font-size:1.2rem;top:.75rem;right:.75rem}.page-content{padding:1.5rem 1rem}.navigation-controls{padding:.5rem 1rem}.nav-button{padding:.4rem .8rem;font-size:.85rem}.page-indicator{font-size:.85rem}}.overview-page-disney{width:100%;height:100%;overflow-y:auto;overflow-x:hidden;background:#f5f5f5;padding:20px 60px}.overview-container{width:100%;margin:0 auto;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a}.hero-section{position:relative;width:100%;height:500px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.hero-image-blur{position:absolute;width:100%;height:100%;object-fit:cover;filter:blur(20px);transform:scale(1.1);z-index:1}.hero-image{position:relative;width:100%;height:100%;object-fit:contain;z-index:2}.hero-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.hero-icon{font-size:6rem;color:#fff}.play-button-overlay{position:absolute;width:80px;height:80px;background:#fffffff2;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .3s ease;box-shadow:0 8px 30px #0000004d}.play-button-overlay:hover{transform:scale(1.1)}.play-icon{color:#667eea;font-size:2rem;margin-left:5px}.content-section{padding:30px 40px;background:#fff}.video-title-disney{font-size:2.5rem;font-weight:700;color:#333;margin:0 0 15px}.synopsis-section-disney{display:flex;align-items:flex-start;gap:15px;margin-bottom:40px}.audio-button-disney{flex-shrink:0;width:50px;height:50px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #667eea66;transition:transform .2s ease}.audio-button-disney:hover{transform:scale(1.1)}.audio-loading{font-size:1.5rem;animation:spin 1s linear infinite}.synopsis-text-disney{flex:1;font-size:1.1rem;line-height:1.6;color:#555;background:#f8f9fa;padding:15px 20px;border-radius:12px;border-left:4px solid #667eea;margin:0}.section-header-disney{display:flex;align-items:center;gap:10px;margin-bottom:20px;font-size:1.8rem;font-weight:700;color:#333}.section-header-icon{width:40px;height:40px;border-radius:50%;object-fit:cover}.section-header-emoji{font-size:1.8rem}.section-count{font-size:1rem;font-weight:400;color:#999}.characters-section-disney{margin-bottom:50px}.characters-scroll{display:flex;gap:20px;overflow-x:auto;padding:10px 0;scrollbar-width:thin;scrollbar-color:#667eea #f0f0f0}.characters-scroll::-webkit-scrollbar{height:8px}.characters-scroll::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.characters-scroll::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.character-card-disney{flex-shrink:0;width:120px;text-align:center;cursor:pointer;transition:transform .3s ease}.character-card-disney:hover{transform:translateY(-5px)}.character-avatar-disney{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:2.5rem;color:#fff;box-shadow:0 4px 15px #667eea4d;overflow:hidden}.character-avatar-image{width:100%;height:100%;object-fit:cover}.character-initial{font-size:2.5rem;font-weight:700;color:#fff}.character-name-disney{font-size:.9rem;font-weight:600;color:#333;line-height:1.2}.chapters-section-disney{margin-bottom:30px}.chapters-scroll{display:flex;gap:20px;overflow-x:auto;padding:10px 0;scrollbar-width:thin;scrollbar-color:#667eea #f0f0f0}.chapters-scroll::-webkit-scrollbar{height:8px}.chapters-scroll::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.chapters-scroll::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.chapter-card-disney{flex-shrink:0;width:280px;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 15px #0000001a;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}.chapter-card-disney:hover{transform:translateY(-5px);box-shadow:0 8px 25px #667eea4d}.chapter-thumbnail{width:100%;height:160px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;position:relative}.chapter-thumbnail-image{width:100%;height:100%;object-fit:cover}.chapter-thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.chapter-number-large{font-size:4rem;font-weight:700;color:#fff}.chapter-number-badge{position:absolute;top:10px;left:10px;background:#fffffff2;color:#667eea;font-weight:700;font-size:1.2rem;padding:5px 12px;border-radius:20px}.chapter-duration-badge{position:absolute;bottom:10px;right:10px;background:#000000b3;color:#fff;font-size:.85rem;padding:4px 10px;border-radius:12px}.chapter-info{padding:15px}.chapter-title-disney{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:8px;line-height:1.3}.chapter-description-disney{font-size:.9rem;color:#666;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.character-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.character-video-dialog{background:#fff;border-radius:20px;padding:0;max-width:800px;width:90%;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease;position:relative}.character-video-container{display:flex;flex-direction:column}.character-video{width:100%;max-height:60vh;background:#000;border-radius:20px 20px 0 0}.character-video-info{padding:20px 30px}.character-video-title{font-size:1.8rem;font-weight:700;color:#333;margin:0 0 10px}.character-video-description{font-size:1rem;line-height:1.6;color:#555;margin:0}.character-video-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 30px;gap:20px}.character-video-loading .spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.character-video-loading p{font-size:1.1rem;color:#666}.dialog-close-button{position:absolute;top:15px;right:15px;background:#f0f0f0;border:none;width:35px;height:35px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.dialog-close-button:hover{background:#e0e0e0}.dialog-title{font-size:2rem;font-weight:700;color:#333;margin:0 0 10px}.dialog-role{font-size:1.1rem;color:#667eea;font-weight:600;margin:0 0 20px}.dialog-description{font-size:1rem;line-height:1.6;color:#555}.dialog-description h3{font-size:1.3rem;color:#333;margin:0 0 10px}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.hero-section{height:300px}.video-title-disney{font-size:1.8rem}.section-header-disney{font-size:1.4rem}.content-section{padding:20px}.synopsis-section-disney{flex-direction:column}.audio-button-disney{align-self:flex-start}}.timeline-page{display:flex;flex-direction:column;height:100%;gap:.25rem}.page-title{font-size:2rem;color:#667eea;text-align:center;margin:0;flex-shrink:0;font-weight:700}.timeline-layout{flex:1;display:flex;min-height:0;gap:.5rem}.sidebar{display:flex;flex-direction:column;gap:1rem;width:60px;flex-shrink:0}.segment-badge{background:linear-gradient(135deg,#667eea,#764ba2);padding:.75rem 1rem;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:.25rem;box-shadow:0 4px 12px #667eea4d}.badge-label{font-size:.75rem;color:#ffffffe6;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.badge-number{font-size:1.3rem;color:#fff;font-weight:700}.sidebar-tabs{display:flex;flex-direction:column;gap:.5rem}.sidebar-tab{display:flex;align-items:center;justify-content:center;padding:.75rem;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .3s ease;width:100%;aspect-ratio:1}.sidebar-tab:hover{border-color:#667eea;transform:translate(5px)}.sidebar-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;transform:translate(5px)}.sidebar-tab.active .tab-icon,.sidebar-tab.active .tab-label{color:#fff}.tab-icon{font-size:1.8rem}.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:0;padding:0}@media (max-width: 768px){.timeline-layout{flex-direction:column}.sidebar{flex-direction:row;width:100%;gap:.75rem}.segment-badge{flex-direction:row;padding:.5rem 1rem;gap:.5rem;width:auto}.badge-label{font-size:.7rem}.badge-number{font-size:1.1rem}.sidebar-tabs{flex-direction:row;justify-content:space-around;flex:1}.sidebar-tab{flex:1;padding:.75rem .5rem}.sidebar-tab:hover,.sidebar-tab.active{transform:translateY(-3px)}.tab-icon{font-size:1.5rem}.tab-label{font-size:.75rem}}.video-segment-page{display:flex;flex-direction:column;height:100%}.segment-title{font-size:1.8rem;font-weight:700;color:#667eea;margin:0;text-align:center;flex-shrink:0}.event-description{flex-shrink:0;background:linear-gradient(135deg,#667eea,#764ba2);padding:.4rem .75rem;border-radius:8px 8px 0 0}.event-description p{margin:0;font-size:1rem;line-height:1.4;color:#fff}.video-with-controls{flex:1;display:flex;flex-direction:column;min-height:0;max-height:100%;overflow:hidden}.video-player-container{flex:1;display:flex;align-items:center;justify-content:center;background:#000;border-radius:0 0 12px 12px;overflow:hidden;min-height:0}.video-player{width:100%;height:100%;object-fit:contain}.video-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#fff;font-size:1.2rem}.segment-controls{display:flex;gap:0;flex-shrink:0;height:32px}.segment-bar{flex:1;padding:.35rem .5rem;background:linear-gradient(135deg,#f5f7ff,#f0f2ff);border:1px solid #d0d5f5;border-top:none;cursor:pointer;transition:all .3s ease;text-align:center;position:relative}.segment-bar:first-child{border-radius:0 0 0 12px}.segment-bar:last-child{border-radius:0 0 12px}.segment-bar:not(:last-child){border-right:none}.segment-bar:hover{background:linear-gradient(135deg,#e8ebff,#dde1ff);border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.segment-bar.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent}.segment-bar.active .segment-label,.segment-bar.active .segment-time{color:#fff}.segment-bar.highlight{border-color:#f99}.segment-bar.highlight:not(.active){background:linear-gradient(135deg,#fff5f7,#ffe8eb)}.segment-bar.highlight.active{background:linear-gradient(135deg,#ff6b6b,#ee5a6f)}.segment-label{font-size:.85rem;font-weight:600;color:#5a5a7a}.segment-time{font-size:.85rem;color:#666;font-family:monospace}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem}.loading-state .spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.loading-state p{font-size:1.1rem;color:#666}@media (max-width: 768px){.event-description p{font-size:.95rem}.segment-controls{flex-direction:column}.segment-bar{padding:.75rem}.segment-label{font-size:.9rem}.segment-time{font-size:.75rem}}.quiz-page{display:flex;flex-direction:column;height:100%;gap:1rem;overflow:hidden;padding:1rem}.quiz-header{flex-shrink:0}.quiz-title{font-size:2.2rem;font-weight:700;color:#667eea;margin:0 0 .75rem;text-align:center}.quiz-progress{display:flex;align-items:center;gap:1rem}.progress-bar{flex:1;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.progress-text{font-size:.9rem;font-weight:600;color:#667eea;min-width:50px;text-align:right}.questions-container{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem;padding-right:.5rem}.question-block{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.25rem;flex-shrink:0}.question-header{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:1rem}.question-number{font-size:1.5rem;font-weight:700;color:#667eea;flex-shrink:0}.question-text{flex:1;font-size:1.4rem;font-weight:600;color:#333;line-height:1.5}.difficulty-badge{flex-shrink:0;font-size:.85rem;color:#666;background:#f5f5f5;padding:.25rem .75rem;border-radius:12px;white-space:nowrap}.options-container{display:flex;flex-direction:column;gap:.75rem;margin-bottom:.75rem}.option{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:linear-gradient(135deg,#f5f7ff,#f0f2ff);border:2px solid #d0d5f5;border-radius:8px;cursor:pointer;transition:all .2s ease}.option:hover{background:linear-gradient(135deg,#e8ebff,#dde1ff);border-color:#667eea;transform:translate(4px)}.option-radio{font-size:1.4rem;color:#667eea;flex-shrink:0;width:28px;text-align:center}.option-label{font-size:1.3rem;font-weight:700;color:#667eea;flex-shrink:0}.option-text{flex:1;color:#333;font-size:1.3rem}.option-correct{background:linear-gradient(135deg,#d4edda,#c3e6cb);border-color:#28a745;cursor:default}.option-correct:hover{background:linear-gradient(135deg,#d4edda,#c3e6cb);transform:none}.option-correct .option-radio{color:#28a745;font-weight:700}.option-wrong{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border-color:#dc3545;cursor:default}.option-wrong:hover{background:linear-gradient(135deg,#f8d7da,#f5c6cb);transform:none}.option-wrong .option-radio{color:#dc3545;font-weight:700}.option-show-correct{background:linear-gradient(135deg,#d4edda,#c3e6cb);border-color:#28a745;cursor:default}.option-show-correct:hover{background:linear-gradient(135deg,#d4edda,#c3e6cb);transform:none}.feedback{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;font-size:1.25rem;font-weight:600;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.feedback-correct{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.feedback-wrong{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.feedback-icon{font-size:1.2rem;font-weight:700}.questions-container::-webkit-scrollbar{width:8px}.questions-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.questions-container::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.questions-container::-webkit-scrollbar-thumb:hover{background:#5568d3}.audio-button-small{width:28px;height:28px;min-width:28px;min-height:28px;max-width:28px;max-height:28px;margin-left:auto}.discussion-page{display:flex;flex-direction:column;height:100%;gap:1.5rem;overflow-y:auto;padding:1rem 1.5rem 1rem 1rem}.questions-list{display:flex;flex-direction:column;gap:1rem}.question-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;overflow:hidden;transition:all .3s ease}.question-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26}.question-card.expanded{border-color:#667eea}.question-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;cursor:pointer;gap:1rem}.question-content{display:flex;align-items:flex-start;gap:1rem;flex:1}.difficulty-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase;flex-shrink:0}.question-text{margin:0;font-size:1.4rem;color:#333;line-height:1.5}.expand-icon{font-size:1.2rem;color:#667eea;flex-shrink:0;transition:transform .3s ease}.question-card.expanded .expand-icon{transform:rotate(0)}.answer-section{padding:0 1.25rem 1.25rem;border-top:1px solid #e0e0e0;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.answer-section h4{margin:1rem 0 .5rem;font-size:1.3rem;color:#667eea}.answer-section p{margin:0;font-size:1.3rem;line-height:1.6;color:#555;background:#f8f9fa;padding:1rem;border-radius:8px;border-left:3px solid #667eea}.learning-focus{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem;border-radius:12px;color:#fff;margin-top:auto;flex-shrink:0}.learning-focus h3{margin:0 0 1rem;font-size:1.5rem}.focus-content{display:flex;flex-direction:column;gap:.75rem}.focus-item{font-size:1.3rem;line-height:1.5}.focus-item strong{display:inline-block;min-width:80px;opacity:.9}@media (max-width: 768px){.section-title{font-size:1.5rem}.question-header{padding:1rem}.question-content{flex-direction:column;gap:.5rem}.question-text{font-size:1rem}.answer-section{padding:0 1rem 1rem}.answer-section p{font-size:.95rem}.learning-focus{padding:1rem}.learning-focus h3{font-size:1.1rem}.focus-item{font-size:.9rem}}.audio-button{flex-shrink:0;width:36px;height:36px;min-width:36px;min-height:36px;max-width:36px;max-height:36px;border:none;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s ease;margin-left:.5rem;padding:0;box-sizing:border-box}.audio-spinner{width:18px;height:18px;display:block;animation:spin 1s linear infinite}.vocabulary-page{display:flex;flex-direction:column;height:100%;gap:1rem;overflow:hidden;padding:1rem}.section-title{font-size:2.2rem;color:#333;margin:0;flex-shrink:0}.no-data{text-align:center;color:#999;font-size:1.1rem;margin-top:2rem}.loading-hint{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:#f0f2ff;border-radius:8px;color:#667eea;font-size:.9rem;flex-shrink:0}.small-spinner{width:16px;height:16px;border:2px solid #e0e0e0;border-top:2px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.vocab-split-container{display:flex;gap:1rem;flex:1;min-height:0;overflow:hidden}.vocab-center-section,.vocab-video-with-card{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.word-info-bar{flex-shrink:0;background:linear-gradient(135deg,#667eea,#764ba2);padding:.6rem 1rem;border-radius:8px 8px 0 0}.vocab-word-title{font-size:2.2rem;font-weight:700;color:#fff;margin:0 0 .25rem}.vocab-word-definition{font-size:1.4rem;line-height:1.4;color:#fffffff2;margin:0}.video-player-wrapper{background:#000;overflow:hidden;flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.vocab-video-player{width:100%;height:100%;display:block;object-fit:contain}.video-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);border:2px dashed #ccc}.video-placeholder p{color:#999;font-size:1rem;margin:0;text-align:center;padding:0 2rem}.word-example-bar{flex-shrink:0;background:linear-gradient(135deg,#f5f7ff,#f0f2ff);padding:.75rem 1rem;border-radius:0 0 8px 8px;border-top:2px solid #d0d5f5}.word-example-bar .example-text{font-style:italic;color:#5a5a7a;margin:0;font-size:1.4rem;line-height:1.5}.vocab-list-section{flex:0 0 200px;display:flex;flex-direction:column;min-height:0}.vocab-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding-right:.25rem}.vocab-list-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease;flex-shrink:0}.vocab-list-item:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea33}.vocab-list-item.active{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:0 2px 8px #667eea4d}.vocab-list-item .word-number{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;font-weight:700;font-size:.8rem;flex-shrink:0}.vocab-list-item.active .word-number{box-shadow:0 0 0 2px #667eea4d}.word-title{margin:0;font-size:1.2rem;font-weight:700;color:#333;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vocab-list-item.active .word-title{color:#667eea}@media (max-width: 1024px){.vocab-split-container{flex-direction:column}.vocab-video-section,.vocab-list-section{flex:1}.vocab-video-section,.vocab-list-section{max-height:50%}}@media (max-width: 768px){.section-title,.current-word{font-size:1.5rem}.info-section p{font-size:1rem}.vocab-list-item{padding:.75rem}.word-title{font-size:1rem}.word-preview{font-size:.85rem}}.word-title-row{display:flex;align-items:center;gap:.75rem}.audio-button{flex-shrink:0;width:36px;height:36px;min-width:36px;min-height:36px;max-width:36px;max-height:36px;border:none;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s ease;padding:0;box-sizing:border-box}.audio-button:hover:not(:disabled){opacity:.85}.audio-button:disabled{opacity:.6;cursor:not-allowed}.audio-button.playing{background:linear-gradient(135deg,#28a745,#20c997)}.audio-button.loading{background:linear-gradient(135deg,#ccc,#999)}.audio-button-light{background:#fff3;border:2px solid rgba(255,255,255,.4)}.audio-button-light:hover:not(:disabled){background:#ffffff4d}.audio-button-light.playing{background:#28a74599;border-color:#28a745cc}.audio-button-small{width:28px;height:28px;min-width:28px;min-height:28px;max-width:28px;max-height:28px}.audio-button-small .audio-icon,.audio-button-small .audio-spinner{width:14px;height:14px}.audio-icon{width:18px;height:18px;display:block}.audio-spinner{width:18px;height:18px;display:block;animation:spin-vocab 1s linear infinite}@keyframes spin-vocab{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.overall-discussion-page{display:flex;flex-direction:column;height:100%;padding:2rem;overflow-y:auto;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.discussion-header{text-align:center;margin-bottom:2rem}.discussion-title{font-size:3rem;color:#333;margin:0 0 .5rem;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.discussion-subtitle{font-size:1.3rem;color:#666;margin:0;font-style:italic}.discussion-content{flex:1;display:flex;flex-direction:column;gap:2rem;max-width:900px;margin:0 auto;width:100%}.topic-card{background:#fff;padding:2.5rem;border-radius:20px;box-shadow:0 10px 40px #0000001a;text-align:center;border:3px solid #667eea}.topic-icon{font-size:4rem;margin-bottom:1rem}.topic-heading{font-size:2rem;color:#667eea;margin:0 0 1.5rem}.topic-text{font-size:1.4rem;line-height:1.8;color:#444;margin:0;font-weight:500}.reflection-prompt{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 6px 20px #00000014}.reflection-prompt h3{font-size:1.5rem;color:#667eea;margin:0 0 1rem}.reflection-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.reflection-list li{font-size:1.1rem;color:#555;padding-left:2rem;position:relative;line-height:1.6}.reflection-list li:before{content:"✓";position:absolute;left:0;color:#667eea;font-weight:700;font-size:1.3rem}.completion-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem 2rem;border-radius:16px;display:flex;align-items:center;justify-content:center;gap:1rem;box-shadow:0 8px 24px #667eea66;margin-top:2rem}.badge-icon{font-size:2rem;animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.2) rotate(180deg)}}.badge-text{font-size:1.3rem;font-weight:600}@media (max-width: 768px){.overall-discussion-page{padding:1.5rem 1rem}.discussion-title{font-size:2rem}.discussion-subtitle{font-size:1.1rem}.topic-card{padding:1.5rem}.topic-icon{font-size:3rem}.topic-heading{font-size:1.5rem}.topic-text{font-size:1.1rem}.reflection-prompt{padding:1.5rem}.reflection-prompt h3{font-size:1.2rem}.reflection-list li{font-size:1rem}.completion-badge{padding:1rem 1.5rem;flex-direction:column;gap:.5rem}.badge-text{font-size:1.1rem}}.upload-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.upload-modal{background:#fff;border-radius:20px;width:98vw;max-width:1600px;height:92vh;max-height:950px;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px 20px 0 0;padding:1rem 2rem;position:relative;flex-shrink:0}.hero{text-align:center;color:#fff}.hero h1{font-size:1.25rem;font-weight:600;letter-spacing:-.015em;line-height:1.1;margin-bottom:0}.hero p{font-size:.875rem;font-weight:400;opacity:.9;line-height:1.4}.close-button{position:absolute;top:.75rem;right:1rem;width:32px;height:32px;border-radius:50%;border:none;background:#fff3;color:#fff;font-size:1.25rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.close-button:hover:not(:disabled){background:#ffffff4d;transform:rotate(90deg)}.close-button:disabled{opacity:.5;cursor:not-allowed}.upload-section{padding:1.5rem 2rem;flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.step-indicator{display:flex;justify-content:center;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;flex-shrink:0}.step-dot{width:8px;height:8px;border-radius:50%;background:#d2d2d7;transition:all .3s cubic-bezier(.4,0,.2,1)}.step-dot.active{width:24px;border-radius:4px;background:#667eea}.step-content{animation:fadeIn .5s ease;flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.section-title{font-size:1.75rem;font-weight:600;letter-spacing:-.01em;text-align:center;margin-bottom:.5rem;color:#1d1d1f}.section-subtitle{font-size:1rem;font-weight:400;color:#86868b;text-align:center;margin-bottom:2.5rem;line-height:1.5}.mode-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem;background:#f8f9ff;padding:.4rem;border-radius:10px;flex-shrink:0}.mode-button{flex:1;padding:.6rem 1rem;font-size:.9rem;font-weight:600;color:#667eea;background:#fff;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .3s ease}.mode-button:hover:not(:disabled){background:#f0f2ff;border-color:#667eea}.mode-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.mode-button:disabled{opacity:.5;cursor:not-allowed}.file-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.file-input-group{display:flex;flex-direction:column;gap:.5rem}.file-label{font-weight:600;color:#555;font-size:1rem}.file-input{padding:.75rem;border:2px dashed #667eea;border-radius:10px;background:#f8f9ff;cursor:pointer;transition:all .3s ease;font-size:.95rem}.file-input:hover:not(:disabled){border-color:#764ba2;background:#f0f2ff}.file-input:disabled{opacity:.5;cursor:not-allowed}.file-info{color:#10b981;font-size:.9rem;padding:.5rem;background:#d1fae5;border-radius:8px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.s3-inputs{display:none;margin-bottom:1.5rem}.s3-inputs.active{display:block}.s3-input-group{display:flex;flex-direction:column;gap:.5rem}.s3-path-input{padding:.875rem 1rem;border:2px solid #667eea;border-radius:10px;background:#f8f9ff;font-size:1rem;transition:all .3s ease}.s3-path-input:focus{outline:none;border-color:#764ba2;background:#fff;box-shadow:0 0 0 3px #667eea1a}.s3-hint{color:#86868b;font-size:.875rem;font-style:italic}.baidu-explorer{display:none;flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.baidu-explorer.active{display:flex}.baidu-folder-list{border:2px solid #e0e0e0;border-radius:12px;flex:1;overflow-y:auto;background:#fff;min-height:0;display:flex;flex-direction:column;gap:.25rem;padding:.5rem;align-content:start}.baidu-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease;background:#fff;min-width:0;overflow:hidden}.baidu-item:hover{border-color:#667eea;background:#f8f9ff}.baidu-item.selected{background:#e3f2fd;border-color:#667eea;border-width:2px}.baidu-item.folder{font-weight:500}.baidu-icon{font-size:1.4rem;flex-shrink:0;width:1.75rem;text-align:center}.baidu-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#1d1d1f;font-size:1.05rem;min-width:0}.baidu-item.file:not(.important) .baidu-name{color:#86868b;font-weight:400}.baidu-item.file:not(.important) .baidu-icon{opacity:.5}.baidu-item.file.important .baidu-name{color:#667eea;font-weight:600}.baidu-item.file.important .baidu-icon{font-size:1.35rem}.baidu-size{color:#86868b;font-size:.95rem;flex-shrink:0}.baidu-badge{background:#d1fae5;color:#10b981;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;flex-shrink:0}.baidu-loading{text-align:center;padding:2rem;color:#86868b}.baidu-selected{display:none}.level-selector{margin-bottom:2rem}.level-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;background:#f5f5f7;padding:.4rem;border-radius:12px;margin-bottom:1.5rem}.level-option{background:transparent;border:none;border-radius:9px;padding:1rem .5rem;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.level-option:hover:not(:disabled){background:#667eea14}.level-option.selected{background:#fff;box-shadow:0 2px 8px #0000001a}.level-option:disabled{opacity:.5;cursor:not-allowed}.level-code{font-size:1.5rem;font-weight:700;color:#667eea;margin-bottom:.25rem}.level-name{font-size:.7rem;color:#86868b;font-weight:500}.level-info{padding:1rem;background:#f8f9ff;border-radius:10px;border:2px solid #e0e7ff;opacity:0;transform:translateY(-10px);transition:all .4s ease;margin-bottom:1.5rem}.level-info.show{opacity:1;transform:translateY(0)}.level-detail{color:#667eea;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.level-detail strong{color:#555}.level-description{color:#666;font-size:.9rem;line-height:1.5;font-style:italic}.summary{background:#f9fafb;border-radius:10px;padding:1.25rem;margin-bottom:1.5rem}.folder-name-editor{margin-bottom:1.5rem;padding:1rem;background:#f8f9ff;border-radius:10px;border:2px solid #e0e7ff}.folder-name-editor .file-label{display:block;margin-bottom:.5rem}.folder-name-editor .s3-path-input{width:100%;box-sizing:border-box}.folder-name-editor .s3-hint{margin-top:.5rem}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:.875rem 0;border-bottom:1px solid #e5e7eb}.summary-item:last-child{border-bottom:none}.summary-label{font-size:.95rem;color:#86868b;font-weight:500}.summary-value{font-size:.95rem;color:#1d1d1f;font-weight:600;text-align:right;max-width:60%;word-break:break-word}.upload-info{background:#e3f2fd;color:#1976d2;padding:1rem;border-radius:10px;margin:1rem 0;font-size:.9rem;line-height:1.5}.progress-container{margin:1.5rem 0}.progress-status{text-align:center;color:#667eea;font-weight:600;margin-bottom:.75rem;font-size:.95rem}.progress-bar{width:100%;height:24px;background:#e5e7eb;border-radius:12px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;border-radius:12px}.progress-text{text-align:center;margin-top:.5rem;font-weight:600;color:#667eea}.processing{text-align:center;padding:2rem 0;display:none}.processing.show{display:block;animation:fadeIn .5s ease}.processing-icon{font-size:4rem;margin-bottom:1rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.processing-title{font-size:1.5rem;font-weight:600;color:#10b981;margin-bottom:.5rem}.processing-text{font-size:1rem;color:#86868b;line-height:1.5}.message{padding:1rem;border-radius:10px;margin:1rem 0;font-weight:500;text-align:center}.message.success{background:#d1fae5;color:#10b981;border:2px solid #10b981}.message.error{background:#fee2e2;color:#ef4444;border:2px solid #ef4444}.button-group{display:flex;justify-content:center;gap:1rem;margin-top:1rem;flex-shrink:0}.btn{padding:.75rem 2rem;border:none;border-radius:980px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:140px}.btn-secondary{background:#f5f5f7;color:#1d1d1f}.btn-secondary:hover:not(:disabled){background:#e8e8ed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}@media (max-width: 900px){.baidu-folder-list{grid-template-columns:1fr}}@media (max-width: 600px){.upload-modal{width:98vw;height:95vh}.hero h1{font-size:1.125rem}.upload-section{padding:1rem}.file-inputs{grid-template-columns:1fr}.level-grid{grid-template-columns:repeat(3,1fr)}.mode-selector,.baidu-folder-list{grid-template-columns:1fr}.button-group{flex-direction:column}.btn{width:100%}.summary-value{max-width:50%;font-size:.85rem}}@media (max-width: 480px){.level-grid{grid-template-columns:repeat(2,1fr)}.level-code{font-size:1.25rem}.level-name{font-size:.65rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fffffff2;border-radius:20px;box-shadow:0 8px 32px #0000001a;padding:40px;width:100%;max-width:400px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:30px}.login-icon{width:60px;height:60px;margin-bottom:15px;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-header h1{color:#333;font-size:28px;margin:0 0 10px;font-weight:600}.login-header p{color:#666;font-size:14px;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.input-group{position:relative}.password-input{width:100%;padding:15px 20px;border:2px solid #e0e0e0;border-radius:12px;font-size:16px;transition:all .3s ease;box-sizing:border-box}.password-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.password-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-button{width:100%;padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;font-size:14px;text-align:center;animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@media (max-width: 480px){.login-card{padding:30px 20px}.login-header h1{font-size:24px}.login-icon{width:50px;height:50px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:#333}#root{min-height:100vh}
