:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--secondary-gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--accent-gradient: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border-light: #e2e8f0;--border-medium: #cbd5e1;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition-fast: .15s ease-out;--transition-normal: .3s ease-out;--transition-slow: .5s ease-out}*{box-sizing:border-box}body{margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden}.main-container{position:relative;width:100vw;height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);overflow:hidden}.infinite-canvas{width:100%!important;height:100%!important;position:absolute!important;top:0!important;left:0!important}.floating-ball-container{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:1000}.floating-ball{position:absolute;width:60px;height:60px;background:var(--primary-gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:all;box-shadow:0 8px 32px #667eea4d;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;z-index:1001;right:30px;top:30px}.floating-ball:hover{transform:translate(var(--x, 0),var(--y, 0)) scale(1.1);box-shadow:0 12px 40px #667eea66}.floating-ball.dragging{transform:translate(var(--x, 0),var(--y, 0)) scale(1.05);box-shadow:0 16px 48px #667eea80}.floating-ball.expanded{background:var(--secondary-gradient);transform:translate(var(--x, 0),var(--y, 0)) scale(1.1)}.floating-ball-icon{font-size:24px;color:#fff;font-weight:700;transition:transform .3s ease}.floating-ball.expanded .floating-ball-icon{transform:rotate(45deg)}.floating-menu{position:absolute;top:0;left:0;pointer-events:all;z-index:1002}.floating-menu-item{position:absolute;width:200px;height:40px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;display:flex;align-items:center;padding:0 16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px #0000001a;border:1px solid rgba(255,255,255,.2);animation:slideInRight .3s ease-out forwards;opacity:0;transform:translate(-20px)}.floating-menu-item:hover{background:#fff;transform:translate(var(--x, 0),var(--y, 0)) translate(10px);box-shadow:0 8px 32px #00000026}.menu-item-icon{font-size:18px;margin-right:12px;width:24px;text-align:center}.menu-item-label{font-size:14px;font-weight:500;color:#374151;white-space:nowrap}.floating-menu-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:transparent;pointer-events:all;z-index:999}.floating-ball-menu{position:absolute;top:0;right:80px;background:#fff;border-radius:12px;box-shadow:0 8px 30px #00000026;padding:16px;min-width:300px;max-width:350px;opacity:0;visibility:hidden;transform:translate(20px);transition:all .3s ease;z-index:1001}.floating-ball-menu.show{opacity:1;visibility:visible;transform:translate(0)}.about-section{width:80%;margin:0 auto;text-align:left}.floating-ball-menu-item{display:flex;align-items:flex-start;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-bottom:8px;font-size:14px;color:#333;white-space:nowrap;animation:slideInRight .3s ease forwards;opacity:0;transform:translate(20px)}.floating-ball-menu-item:nth-child(1){animation-delay:.1s}.floating-ball-menu-item:nth-child(2){animation-delay:.15s}.floating-ball-menu-item:nth-child(3){animation-delay:.2s}.floating-ball-menu-item:nth-child(4){animation-delay:.25s}.floating-ball-menu-item:nth-child(5){animation-delay:.3s}.floating-ball-menu-item:nth-child(6){animation-delay:.35s}.floating-ball-menu-item:hover{background:#f8f9fa;transform:translate(4px)}.about-item{cursor:default;padding:5px;border-bottom:1px solid #f0f0f0;margin-bottom:8px;white-space:normal}.about-item:last-child{border-bottom:none;margin-bottom:0}.about-item.clickable{cursor:pointer;border-radius:8px;padding:8px;margin-bottom:8px;transition:all .2s ease}.about-item.clickable:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.about-item:hover{background:#f8f9fa;transform:none}.about-content{flex:1;margin-left:12px}.about-label{font-weight:600;color:#2c3e50;margin-bottom:4px;font-size:13px}.about-detail{color:#666;font-size:12px;line-height:1.4;word-break:break-all}.ai-token-link{color:#667eea;text-decoration:none;font-weight:500;transition:color .2s ease}.ai-token-link:hover{color:#5a67d8;text-decoration:underline}.about-header{text-align:center}.about-header h3{margin:0 0 4px;color:#2c3e50;font-size:16px;font-weight:700}.about-header p{margin:0;color:#6c757d;font-size:12px}.afdian-section{text-align:center}.afdian-container{display:flex;justify-content:center;align-items:center;width:100%;overflow:hidden;border-radius:8px;box-shadow:0 2px 8px #0000001a}.afdian-iframe{width:100%;height:200px;border:none;border-radius:8px;transition:transform .2s ease}.afdian-iframe:hover{transform:scale(1.02)}.qr-code-section{text-align:center;margin-top:10px}.qr-code-container{display:flex;justify-content:center;align-items:center}.qr-code-image{border-radius:8px;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease}.qr-code-image:hover{transform:scale(1.05)}.floating-ball-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000001a;z-index:999;opacity:0;visibility:hidden;transition:all .3s ease}.floating-ball-overlay.show{opacity:1;visibility:visible}.sidebar{position:absolute;top:1rem;left:1rem;z-index:20;width:18rem;max-height:90vh;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:1rem;border:1px solid rgba(255,255,255,.2);box-shadow:var(--shadow-xl);padding:1rem;display:flex;flex-direction:column;gap:1rem;transition:all var(--transition-normal);transform:translate(0);overflow-y:auto;overflow-x:visible}.sidebar.collapsed{transform:translate(-100%)}.sidebar-header{text-align:center;border-bottom:2px solid var(--border-light)}.author-qr-section{margin-top:auto;padding-top:1rem;border-top:2px solid var(--border-light)}.qr-section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem;text-align:center}.qr-codes-container{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.qr-code-item{display:flex;flex-direction:column;align-items:center;padding:.5rem;background:#ffffff80;border-radius:.75rem;border:1px solid var(--border-light);transition:all var(--transition-fast)}.qr-code-item:hover{background:#fffc;transform:translateY(-2px);box-shadow:var(--shadow-md)}.qr-code-label{font-size:.75rem;color:var(--text-secondary);margin:.5rem 0 0;font-weight:500}.title-with-logo{display:flex;align-items:center;gap:.75rem}.site-logo{width:32px;height:32px;object-fit:contain;border-radius:6px;box-shadow:0 2px 8px #0000001a}.sidebar-title{font-size:1.5rem;font-weight:700;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.sidebar-subtitle{font-size:.875rem;color:var(--text-secondary);margin:.5rem 0 0}.button-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.button-grid-full{grid-column:1 / -1}.modern-button{position:relative;padding:.75rem 1rem;border:none;border-radius:.75rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);overflow:hidden;text-align:center;display:flex;align-items:center;justify-content:center;gap:.5rem;color:#374151;background:#ffffffe6;border:1px solid rgba(226,232,240,.8)}.modern-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left var(--transition-normal)}.modern-button:hover:before{left:100%}.modern-button:active{transform:translateY(1px)}.m0{margin:0 auto}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:var(--shadow-md)}.btn-success:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:var(--shadow-md)}.btn-warning:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:var(--shadow-md)}.btn-danger:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:var(--shadow-md)}.btn-purple:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-medium);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg-tertiary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed;opacity:.6}.btn-disabled:hover{transform:none;box-shadow:var(--shadow-sm)}.color-picker{width:100%;overflow:visible;min-height:auto;flex-shrink:0}.color-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(2.5rem,1fr));gap:.75rem;width:100%;max-width:100%;overflow:visible;justify-items:center;min-height:auto}.color-button{width:2.5rem;height:2.5rem;border-radius:50%;border:3px solid white;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);flex-shrink:0;min-width:2.5rem;min-height:2.5rem;overflow:visible}.color-button:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.control-panel{margin:0;padding:0;border:none}.control-panel-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem;padding:0;text-align:center;background:linear-gradient(135deg,var(--primary-color),var(--accent-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.control-section{margin-bottom:1rem;padding:0;background:none;border-radius:0;border:none;-webkit-backdrop-filter:none;backdrop-filter:none}.control-section:last-child{margin-bottom:0}.control-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.control-grid:last-child{margin-bottom:0}.control-grid-three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem;margin-bottom:.75rem}.control-grid-four{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.5rem;margin-bottom:.75rem}.control-grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem;margin-bottom:.75rem}.control-grid-compact{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.4rem;margin-bottom:.75rem}.collapse-button{position:absolute;top:1rem;z-index:25;width:3rem;height:3rem;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal);box-shadow:var(--shadow-lg)}.collapse-button:hover{transform:scale(1.05);box-shadow:var(--shadow-xl)}.collapse-button svg{width:1.25rem;height:1.25rem;color:var(--text-primary);transition:transform var(--transition-fast)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:50;animation:fadeIn var(--transition-normal)}.modal-content{background:var(--bg-secondary);border-radius:1rem;box-shadow:var(--shadow-xl);padding:2rem;max-width:90vw;max-height:90vh;overflow-y:scroll;animation:slideUp var(--transition-normal);border:1px solid var(--border-light)}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-light)}.modal-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:.5rem;transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.instructions-modal{background:var(--bg-secondary);border-radius:1rem;box-shadow:var(--shadow-xl);max-width:600px;max-height:80vh;width:90%;animation:slideUp .3s ease-out;overflow:hidden;display:flex;flex-direction:column}.tutorial-modal{max-width:1000px;max-height:90vh}.modal-content{padding:1.5rem;overflow-y:auto;overflow-x:hidden;flex:1;display:flex;flex-direction:column;gap:1rem;max-height:calc(80vh - 100px);scrollbar-width:thin;scrollbar-color:var(--accent-gradient) transparent;scroll-behavior:smooth}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track{background:transparent}.modal-content::-webkit-scrollbar-thumb{background:var(--accent-gradient);border-radius:3px}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}.instruction-section{background:var(--bg-tertiary);border-radius:.5rem;padding:.75rem;border-left:3px solid var(--accent-gradient)}.instruction-section h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem;display:flex;align-items:center;gap:.25rem}.instruction-section ul{margin:0;padding-left:1rem;list-style:none}.instruction-section li{font-size:.8rem;color:var(--text-secondary);margin-bottom:.25rem;position:relative;line-height:1.4}.instruction-section li:before{content:"•";color:#667eea;font-weight:700;position:absolute;left:-.75rem}.instruction-section strong{color:var(--text-primary);font-weight:600}.tutorial-video-section{margin-bottom:2rem}.tutorial-text-section{margin-top:1rem}.tutorial-section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-gradient)}.video-container{position:relative;background:#000;border-radius:.5rem;overflow:hidden;aspect-ratio:16/9;margin-bottom:1rem}.context-menu{position:fixed;background:var(--bg-secondary);border-radius:.75rem;box-shadow:var(--shadow-xl);border:1px solid var(--border-light);padding:.5rem;z-index:40;min-width:12rem;animation:slideIn var(--transition-fast)}.context-menu-item{width:100%;padding:.75rem 1rem;border:none;background:none;text-align:left;font-size:.875rem;color:var(--text-primary);cursor:pointer;border-radius:.5rem;transition:all var(--transition-fast);display:flex;align-items:center;gap:.5rem}.context-menu-item:hover{background:var(--bg-tertiary)}.context-menu-item:disabled{color:var(--text-muted);cursor:not-allowed}.context-menu-item:disabled:hover{background:none}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:60;color:#fff;animation:fadeIn var(--transition-normal)}.loading-spinner{width:3rem;height:3rem;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-text{font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.loading-subtext{font-size:.875rem;opacity:.8}.canvas-element{transition:all var(--transition-fast)}.canvas-element:hover{transform:scale(1.02)}.canvas-element.selected{outline:2px solid #3b82f6;outline-offset:2px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(2rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-.5rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:translate(var(--x, 0),var(--y, 0)) scale(1)}50%{transform:translate(var(--x, 0),var(--y, 0)) scale(1.05)}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.floating-ball:not(.expanded):not(.dragging){animation:pulse 3s ease-in-out infinite}.video-player-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.video-player-overlay.embedded{position:static;width:auto;height:auto;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;animation:none}.video-player-container{background:var(--bg-secondary);border-radius:1rem;box-shadow:var(--shadow-xl);max-width:90vw;max-height:90vh;width:800px;overflow:hidden;animation:slideUp .3s ease-out;border:1px solid var(--border-light)}.video-player-container.embedded{max-width:100%;max-height:none;width:100%;animation:none;box-shadow:none;border:1px solid var(--border-light)}.video-player-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--primary-gradient);color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}.video-player-title{margin:0;font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.video-player-close{background:#fff3;border:none;color:#fff;font-size:1.25rem;cursor:pointer;padding:.5rem;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.video-player-close:hover{background:#ffffff4d;transform:scale(1.1)}.video-wrapper{position:relative;background:#000;aspect-ratio:16/9;overflow:hidden}.video-player{width:100%;height:100%;object-fit:contain;cursor:pointer}.video-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:1rem;opacity:0;transition:opacity var(--transition-normal)}.video-controls.show{opacity:1}.video-progress{margin-bottom:.75rem}.progress-bar{width:100%;height:4px;background:#ffffff4d;border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.progress-bar::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:var(--primary-gradient);border-radius:50%;cursor:pointer;box-shadow:0 2px 8px #0000004d}.progress-bar::-moz-range-thumb{width:16px;height:16px;background:var(--primary-gradient);border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 8px #0000004d}.video-controls-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem}.video-controls-left,.video-controls-right{display:flex;align-items:center;gap:.75rem}.control-button{background:#fff3;border:none;color:#fff;font-size:1.25rem;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.control-button:hover{background:#ffffff4d;transform:scale(1.1)}.time-display{color:#fff;font-size:.875rem;font-weight:500;font-family:monospace;background:#00000080;padding:.25rem .5rem;border-radius:.25rem}.volume-control{display:flex;align-items:center;gap:.5rem}.volume-icon{color:#fff;font-size:1rem}.volume-bar{width:80px;height:4px;background:#ffffff4d;border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.volume-bar::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0000004d}.volume-bar::-moz-range-thumb{width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 4px #0000004d}@media (max-width: 768px){.sidebar{width:16rem;padding:1rem}.site-logo{width:28px;height:28px}.sidebar-title{font-size:1.25rem}.button-grid{grid-template-columns:1fr}.control-grid-three,.control-grid-four{grid-template-columns:1fr 1fr;gap:.5rem}.control-grid-auto{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.4rem}.control-grid-compact{grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:.3rem}.color-grid{grid-template-columns:repeat(auto-fit,minmax(2rem,1fr));gap:.5rem}.modal-content{margin:1rem;padding:1.5rem}.instructions-modal{max-width:95%;max-height:85vh}.modal-header{padding:1rem}.modal-title{font-size:1.125rem}.modal-content{padding:1rem;gap:.75rem;max-height:calc(85vh - 80px)}.instruction-section h4{font-size:.8rem}.instruction-section li{font-size:.75rem}.qr-codes-container{grid-template-columns:1fr;gap:.5rem}.qr-code-label{font-size:.7rem}.video-player-container{width:95vw;max-height:80vh}.video-player-header{padding:.75rem 1rem}.video-player-title{font-size:1rem}.video-controls{padding:.75rem}.video-controls-bottom{flex-direction:column;gap:.5rem;align-items:stretch}.video-controls-left,.video-controls-right{justify-content:space-between}.volume-control{order:2}.volume-bar{width:60px}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:#3b82f633;color:var(--text-primary)}.mobile-welcome-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.mobile-welcome-content{background:var(--bg-secondary);border-radius:1rem;padding:2rem;max-width:400px;width:100%;box-shadow:var(--shadow-xl);text-align:center;animation:welcomeSlideIn .5s ease-out}@keyframes welcomeSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.welcome-header{margin-bottom:2rem}.welcome-logo{width:60px;height:60px;margin-bottom:1rem;border-radius:50%;box-shadow:var(--shadow-md)}.welcome-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-body{margin-bottom:2rem}.welcome-icon{font-size:3rem;margin-bottom:1rem}.welcome-subtitle{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.welcome-description{color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}.welcome-features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.feature-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border-radius:.5rem;text-align:left}.feature-icon{font-size:1.25rem;flex-shrink:0}.feature-text{color:var(--text-primary);font-weight:500}.welcome-tips{text-align:left;background:var(--bg-tertiary);padding:1rem;border-radius:.5rem;margin-bottom:1.5rem}.welcome-tips h3{margin:0 0 .75rem;color:var(--text-primary);font-size:1rem}.welcome-tips ul{margin:0;padding-left:1.25rem;color:var(--text-secondary)}.welcome-tips li{margin-bottom:.25rem;font-size:.875rem}.welcome-footer{display:flex;flex-direction:column;gap:1rem}.welcome-button{padding:.875rem 1.5rem;border:none;border-radius:.5rem;font-weight:600;font-size:1rem;cursor:pointer;transition:var(--transition-fast);text-decoration:none;display:inline-block;text-align:center}.welcome-button-primary{background:var(--primary-gradient);color:#fff;box-shadow:var(--shadow-md)}.welcome-button-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.welcome-button-primary:active{transform:translateY(0)}.welcome-note{color:var(--text-muted);font-size:.875rem;margin:0;line-height:1.4}@media (max-width: 480px){.mobile-welcome-content{padding:1.5rem;margin:.5rem}.welcome-title{font-size:1.25rem}.welcome-subtitle{font-size:1.125rem}.welcome-icon{font-size:2.5rem}.welcome-logo{width:50px;height:50px}.video-player-container{width:100vw;height:100vh;border-radius:0;max-height:100vh}.video-player-header{padding:.5rem 1rem}.video-player-title{font-size:.875rem}.video-player-close{width:1.5rem;height:1.5rem;font-size:1rem}.video-controls{padding:.5rem}.control-button{font-size:1rem;padding:.375rem}.time-display{font-size:.75rem}}.modern-button:focus,.context-menu-item:focus,.modal-close:focus{outline:2px solid #3b82f6;outline-offset:2px}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--text-primary);color:#fff;padding:.5rem .75rem;border-radius:.5rem;font-size:.75rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast);z-index:100}.tooltip:hover:after{opacity:1}.user-section{padding:1rem;background:#ffffff1a;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.user-info{display:flex;flex-direction:column;gap:.5rem}.user-details{display:flex;flex-direction:column;gap:.25rem}.user-name{font-weight:600;color:#333;font-size:14px}.project-name{font-size:12px;color:#666;background:#fffc;padding:.25rem .5rem;border-radius:4px}.collaboration-status{font-size:12px;color:#4ade80;background:#4ade801a;padding:.25rem .5rem;border-radius:4px;border:1px solid rgba(74,222,128,.3)}.user-actions{display:flex;gap:.5rem;margin-top:.5rem}.user-actions .modern-button{flex:1;font-size:12px;padding:.5rem}.auth-section{text-align:center}.auth-tip{font-size:12px;color:#666;margin-top:.5rem;margin-bottom:0}.loading-text{text-align:center;color:#666;font-size:14px}.auth-modal{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;box-shadow:0 25px 50px #00000026,0 0 0 1px #ffffff1a;max-width:420px;width:90%;max-height:90vh;overflow-y:auto;position:relative;animation:modalSlideIn .4s cubic-bezier(.34,1.56,.64,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.auth-form{padding:1.5rem}.auth-modal .modal-header{padding:1.5rem 1.5rem 0;border-bottom:none;margin-bottom:0}.auth-modal .modal-title{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.auth-modal .modal-close{background:#ef44441a;border:none;width:32px;height:32px;border-radius:50%;font-size:16px;color:#ef4444;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.auth-modal .modal-close:hover{background:#ef444433;transform:scale(1.1)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151;font-size:14px;transition:color .2s ease}.form-group input{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:14px;transition:all .3s cubic-bezier(.4,0,.2,1);background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 1px 3px #0000001a}.form-group input:focus{outline:none;border-color:#667eea;background:#fffffff2;box-shadow:0 0 0 3px #667eea1a,0 4px 12px #667eea26;transform:translateY(-1px)}.form-group input:hover{border-color:#cbd5e0;background:#ffffffe6}.form-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:center}.form-actions .modern-button{flex:none;padding:.875rem 1.5rem;font-weight:600;font-size:14px;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.form-actions .modern-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.form-actions .modern-button:active{transform:translateY(0)}.auth-footer{padding:1rem 1.5rem 1.5rem;border-top:1px solid rgba(226,232,240,.5);text-align:center;background:#f8fafc80;border-radius:0 0 20px 20px}.auth-tip{margin:0;font-size:14px;color:#64748b}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;font-weight:600;text-decoration:none;margin-left:.5rem;padding:.25rem .5rem;border-radius:6px;transition:all .2s ease}.link-button:hover{color:#5a67d8;background:#667eea1a;text-decoration:none}.error-message{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;padding:.875rem 1rem;border-radius:12px;margin-bottom:1.5rem;font-size:14px;font-weight:500;border:1px solid rgba(239,68,68,.2);box-shadow:0 1px 3px #ef44441a;animation:slideIn .3s ease-out}.field-error{color:#dc2626;font-size:12px;font-weight:500;margin-top:.5rem;padding:.25rem .5rem;background:#ef44441a;border-radius:6px;border-left:3px solid #ef4444;animation:slideIn .2s ease-out}.form-group input.error{border-color:#ef4444;background:#fef2f2cc;box-shadow:0 0 0 3px #ef44441a,0 1px 3px #0000001a}.form-group input.error:focus{border-color:#ef4444;background:#fef2f2f2;box-shadow:0 0 0 3px #ef444433,0 4px 12px #ef444426}@media (max-width: 480px){.auth-modal{max-width:95%;margin:1rem;border-radius:16px}.auth-modal .modal-header{padding:1rem 1rem 0}.auth-modal .modal-title{font-size:1.5rem}.auth-form{padding:1rem}.form-group input{padding:.75rem .875rem;font-size:16px}.form-actions{flex-direction:column;gap:.75rem}.form-actions .modern-button{width:100%;padding:1rem;font-size:16px}.auth-footer{padding:1rem}}.project-manager-modal{background:#fff;border-radius:20px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff0d;max-width:900px;width:92%;max-height:88vh;overflow:hidden;border:1px solid rgba(255,255,255,.2);position:relative;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.project-manager-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem 2.5rem;border-bottom:none;position:relative;overflow:hidden}.project-manager-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="white" opacity="0.1"/><circle cx="75" cy="75" r="1" fill="white" opacity="0.1"/><circle cx="50" cy="10" r="0.5" fill="white" opacity="0.15"/><circle cx="10" cy="60" r="0.5" fill="white" opacity="0.15"/><circle cx="90" cy="40" r="0.5" fill="white" opacity="0.15"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.3}.project-manager-title{margin:0;font-size:1.75rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:1rem;position:relative;z-index:1;text-shadow:0 2px 4px rgba(0,0,0,.1)}.project-manager-title:before{content:"🚀";font-size:1.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.project-manager-content{padding:1rem;height:calc(100% - 100px);overflow-y:auto;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.project-manager-content::-webkit-scrollbar{width:8px}.project-manager-content::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.project-manager-content::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;transition:all .3s ease}.project-manager-content::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1)}.project-tabs{display:flex;background:#ffffffe6;border-radius:16px;padding:8px;margin-bottom:1rem;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #0000001a}.tab-button{flex:1;background:transparent;border:none;padding:1rem 1.5rem;cursor:pointer;font-size:15px;font-weight:600;color:#64748b;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.tab-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#667eea,#764ba2);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:12px}.tab-button.active{color:#fff!important;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.1);transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d;position:relative;z-index:2}.tab-button.active:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;z-index:-1}.tab-button:hover:not(.active){color:#334155;background:#ffffffb3;transform:translateY(-1px)}.create-project-form{background:#fffffff2;border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:2rem;margin-bottom:2.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 20px 40px #0000001a,0 0 0 1px #fff3;position:relative;overflow:hidden}.create-project-form:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2,#f093fb)}.create-project-form h3{margin:0 0 2rem;font-size:1.375rem;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:.75rem;position:relative;z-index:1}.create-project-form h3:before{content:"✨";font-size:1.25rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.75rem;font-weight:600;color:#374151;font-size:15px;position:relative}.form-group input[type=text],.form-group textarea{width:100%;padding:1rem 1.25rem;border:2px solid rgba(226,232,240,.8);border-radius:12px;font-size:15px;font-family:inherit;background:#ffffffe6;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000d}.form-group input[type=text]:focus,.form-group textarea:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a,0 8px 16px #667eea1a;transform:translateY(-1px)}.form-group textarea{resize:vertical;min-height:100px;line-height:1.6}.checkbox-label{display:flex;align-items:center;gap:1rem;cursor:pointer;font-size:15px;color:#374151;font-weight:600;padding:1rem;border-radius:12px;background:#f8fafccc;border:2px solid rgba(226,232,240,.6);transition:all .3s cubic-bezier(.4,0,.2,1)}.checkbox-label:hover{background:#ffffffe6;border-color:#667eea4d;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.checkbox-label input[type=checkbox]{width:20px;height:20px;accent-color:#667eea;cursor:pointer;transition:all .3s ease}.checkbox-label input[type=checkbox]:checked{transform:scale(1.1)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.form-actions .modern-button{padding:1rem 2rem;font-size:15px;font-weight:600;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;border:2px solid transparent;position:relative;overflow:hidden}.form-actions .modern-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#fff3,#ffffff1a);opacity:0;transition:opacity .3s ease}.form-actions .modern-button:hover:before{opacity:1}.form-actions .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;box-shadow:0 8px 20px #667eea4d}.form-actions .btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 28px #667eea66}.form-actions .btn-secondary{background:#ffffffe6;color:#64748b;border-color:#e2e8f0cc}.form-actions .btn-secondary:hover{background:#fff;color:#374151;border-color:#cbd5e1;transform:translateY(-1px)}.form-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.projects-list{max-height:450px;overflow-y:auto;padding-right:.5rem;padding-bottom:.5rem}.projects-list::-webkit-scrollbar{width:6px}.projects-list::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}.projects-list::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:3px}.projects-list::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1)}.project-item{background:#fffffff2;border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:2rem;margin-bottom:1.5rem;transition:all .4s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden;box-shadow:0 8px 32px #00000014,0 0 0 1px #fff3}.project-item:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#667eea0d,#764ba20d);opacity:0;transition:all .4s cubic-bezier(.4,0,.2,1)}.project-item:after{content:"";position:absolute;top:0;left:0;width:5px;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);opacity:0;transition:all .4s cubic-bezier(.4,0,.2,1)}.project-item:hover{transform:translateY(-4px);box-shadow:0 20px 40px #00000026,0 0 0 1px #667eea33;border-color:#667eea4d}.project-item:hover:before{opacity:1}.project-item:hover:after{opacity:1}.project-info{flex:1;position:relative;z-index:1}.project-title{margin:0 0 1rem;font-size:1.25rem;font-weight:700;color:#1e293b;background:linear-gradient(135deg,#1e293b,#334155);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:all .3s ease}.project-item:hover .project-title{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.project-description{margin:0 0 1.25rem;font-size:15px;color:#64748b;line-height:1.6;font-weight:400;transition:color .3s ease}.project-item:hover .project-description{color:#475569}.project-meta{display:flex;flex-wrap:wrap;gap:1.25rem;align-items:center;font-size:13px;color:#94a3b8;margin-bottom:1.25rem;transition:color .3s ease}.project-item:hover .project-meta{color:#64748b}.project-author,.project-date,.project-visibility{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#f8fafccc;border-radius:8px;font-weight:600;border:1px solid rgba(226,232,240,.6)}.project-visibility.public{background:linear-gradient(135deg,#22c55e1a,#16a34a1a);color:#16a34a;border-color:#22c55e33}.project-visibility.private{background:linear-gradient(135deg,#ef44441a,#dc26261a);color:#dc2626;border-color:#ef444433}.project-actions{display:flex;gap:.75rem;position:relative;z-index:1;padding-bottom:1rem}.project-actions .modern-button{padding:.75rem 1.5rem;font-size:14px;font-weight:600;border-radius:10px;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;border:2px solid transparent;position:relative;overflow:hidden}.project-actions .modern-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#fff3,#ffffff1a);opacity:0;transition:opacity .3s ease}.project-actions .modern-button:hover:before{opacity:1}.project-actions .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;box-shadow:0 4px 12px #667eea4d}.project-actions .btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 20px #667eea66}.project-actions .btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:#ef4444;box-shadow:0 4px 12px #ef44444d}.project-actions .btn-danger:hover{transform:translateY(-1px);box-shadow:0 8px 20px #ef444466}.empty-state{text-align:center;padding:4rem 2rem;color:#94a3b8}.empty-state-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.6;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.empty-state-title{font-size:1.375rem;font-weight:700;color:#64748b;margin-bottom:.75rem}.empty-state-description{font-size:15px;color:#94a3b8;line-height:1.5;max-width:350px;margin:0 auto}.loading-state{display:flex;justify-content:center;align-items:center;padding:4rem;color:#64748b;font-size:15px;font-weight:600}.loading-spinner{width:24px;height:24px;border:3px solid rgba(102,126,234,.2);border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-right:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.message{padding:1.25rem 1.5rem;border-radius:12px;margin-bottom:1.5rem;font-size:15px;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 12px #0000001a}.error-message{background:linear-gradient(135deg,#ef44441a,#dc26261a);color:#dc2626;border:1px solid rgba(239,68,68,.2)}.success-message{background:linear-gradient(135deg,#22c55e1a,#16a34a1a);color:#16a34a;border:1px solid rgba(34,197,94,.2)}@media (max-width: 768px){.project-manager-modal{width:96%;max-height:92vh}.project-manager-header{padding:1.5rem 2rem}.project-manager-content{padding:1rem}.project-tabs{flex-direction:column;gap:4px;padding:6px}.tab-button{text-align:center;padding:1rem}.project-item{padding:1.5rem}.project-title{font-size:1.125rem}.project-description{font-size:14px}.project-meta{flex-direction:column;align-items:flex-start;gap:.75rem}.project-actions{flex-direction:column;gap:.75rem}.project-actions .modern-button{width:100%;text-align:center}.form-actions{flex-direction:column}.form-actions .modern-button{width:100%}}@media (max-width: 480px){.project-manager-modal{width:100%;margin:0;border-radius:0;max-height:100vh}.project-manager-header{padding:1rem 1.5rem}.project-manager-content{padding:1rem}.create-project-form{padding:1.5rem}.project-item{padding:1.25rem}}
