body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-page{align-items:center;background:linear-gradient(135deg,#001988,#3496ff);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-container{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;max-width:400px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-header h1{color:#2c3e50;font-size:2rem;margin-bottom:10px}.login-header p{color:#7f8c8d;font-size:1rem}.login-form h2{color:#2c3e50;text-align:center}.form-group,.login-form h2{margin-bottom:20px}.form-group label{color:#2c3e50;display:block;font-weight:500;margin-bottom:5px}.form-group input{border:2px solid #e9ecef;border-radius:6px;font-size:16px;padding:12px;transition:border-color .3s ease;width:100%}.form-group input:focus{border-color:#3498db;outline:none}.error-message{background:#fee;border:1px solid #fed7d7;border-radius:6px;color:#c53030;margin-bottom:20px;padding:12px}.login-btn{background:#3498db;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:background .3s ease;width:100%}.login-btn:hover:not(:disabled){background:#2980b9}.login-btn:disabled{background:#bdc3c7;cursor:not-allowed}.login-footer{margin-top:20px;text-align:center}.switch-mode-btn{background:none;border:none;color:#3498db;cursor:pointer;font-size:14px;text-decoration:underline}.switch-mode-btn:hover{color:#2980b9}@media (max-width:480px){.login-container{padding:30px 20px}.login-header h1{font-size:1.5rem}}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;background:var(--glass-bg);border-bottom:1px solid #2196f34d;border-bottom:1px solid var(--glass-border);box-shadow:0 4px 12px #2196f31a;box-shadow:var(--shadow-light);box-sizing:border-box;height:64px;justify-content:space-between;left:0;padding:1rem 2rem;position:fixed;right:0;top:0;z-index:1000}.header,.header-brand,.logo{align-items:center;display:flex}.logo{color:#1d2525;color:var(--gray-text);font-size:1.5rem;font-weight:700;gap:.5rem;letter-spacing:-.02em;margin:0}.logo-icon{fill:#2196f3;fill:var(--primary-blue);height:24px;width:24px}.navigation{display:flex;flex:1 1;gap:.75rem;justify-content:center}.nav-item{align-items:center;background:none;border:none;border-radius:8px;color:#1d2525;color:var(--gray-text);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;min-width:100px;padding:.5rem 1rem;position:relative;transition:background-color .2s ease,transform .2s ease,color .2s ease}.nav-item:hover{background:#e3f2fd;background:var(--light-blue);transform:translateY(-1px)}.nav-item.active{color:#2196f3;color:var(--primary-blue);font-weight:600}.nav-item.active:after{background:linear-gradient(45deg,#2196f3,#42a5f5);background:var(--gradient-button);border-radius:2px;bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}.nav-item:focus{outline:2px solid #2196f3;outline:2px solid var(--primary-blue);outline-offset:2px}.nav-icon{fill:currentColor;height:20px;margin-right:.5rem;width:20px}.header-actions{align-items:center}.logout-btn{background:#ff3b30;background:var(--error-red);border:none;border-radius:8px;color:#fff;color:var(--white);cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:background-color .2s ease,transform .2s ease}.logout-btn:focus,.logout-btn:hover{background:#d32f2f;transform:scale(1.02)}.logout-btn:focus{outline:2px solid #ff3b30;outline:2px solid var(--error-red);outline-offset:2px}@media (max-width:768px){.header{flex-direction:column;gap:1rem;height:auto;padding:1rem}.navigation{flex-wrap:wrap;gap:.5rem;justify-content:center}.nav-item{font-size:.75rem;min-width:80px;padding:.5rem}.nav-icon{height:18px;width:18px}.logo{font-size:1.25rem}}@media (max-width:480px){.header{padding:.75rem}.nav-item{min-width:70px;padding:.4rem}.logout-btn{font-size:.75rem;padding:.4rem .8rem}}@media (prefers-reduced-motion:reduce){.logout-btn,.nav-item{transition:none}.logout-btn:hover,.nav-item:hover{transform:none}}@supports not ((-webkit-backdrop-filter:blur(10px)) or (backdrop-filter:blur(10px))){.header{background:#fff;background:var(--white)}}.home-screen{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:5% auto 0;max-width:1400px;min-height:100vh;padding:2rem}:root{--apple-blue:#007aff;--apple-blue-light:#409cff;--apple-blue-dark:#0056cc;--apple-gray-1:#f5f5f7;--apple-gray-2:#e8e8ed;--apple-gray-3:#d1d1d6;--apple-gray-4:#8e8e93;--apple-gray-5:#48484a;--apple-white:#fff;--shadow-light:0 4px 20px #007aff14;--shadow-medium:0 8px 32px #007aff1f;--shadow-heavy:0 16px 48px #007aff26}.modal-overlay{animation:appleFadeIn .4s cubic-bezier(.25,.46,.45,.94);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0006}.modal-content{animation:appleSlideUp .5s cubic-bezier(.25,.46,.45,.94);background:#fff;background:var(--apple-white);border:1px solid #e8e8ed;border:1px solid var(--apple-gray-2);border-radius:20px;box-shadow:0 16px 48px #007aff26;box-shadow:var(--shadow-heavy);max-width:380px;padding:2.5rem;text-align:center}.modal-content h3{color:#48484a;color:var(--apple-gray-5);font-size:1.4rem;letter-spacing:-.5px;margin-bottom:1rem}.modal-content p{color:#8e8e93;color:var(--apple-gray-4);font-size:.95rem;margin-bottom:2rem}.code-input{background:#f5f5f7;background:var(--apple-gray-1);border:2px solid #e8e8ed;border:2px solid var(--apple-gray-2);border-radius:14px;color:#48484a;color:var(--apple-gray-5);font-size:1.1rem;font-weight:500;letter-spacing:3px;margin-bottom:2rem;padding:1rem 1.5rem;text-align:center;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:100%}.code-input:focus{background:#fff;background:var(--apple-white);border-color:#007aff;border-color:var(--apple-blue);box-shadow:0 0 0 4px #007aff1a;outline:none;transform:translateY(-1px)}.modal-actions{gap:.8rem;justify-content:center}.btn-primary,.btn-secondary{border:none;border-radius:12px;flex:1 1;font-size:.85rem;letter-spacing:.3px;padding:.75rem 1.8rem;transition:all .3s cubic-bezier(.25,.46,.45,.94)}.btn-primary{background:#007aff;background:var(--apple-blue);box-shadow:0 4px 20px #007aff14;box-shadow:var(--shadow-light);color:var(--apple-white)}.btn-primary:hover:not(:disabled){background:#409cff;background:var(--apple-blue-light);box-shadow:0 8px 32px #007aff1f;box-shadow:var(--shadow-medium);transform:translateY(-1px) scale(1.02)}.btn-primary:active{background:#0056cc;background:var(--apple-blue-dark);transform:translateY(0) scale(1)}.btn-primary:disabled{opacity:.5;transform:none}.btn-secondary{background:var(--apple-gray-1);border:1px solid #e8e8ed;border:1px solid var(--apple-gray-2);color:#48484a;color:var(--apple-gray-5)}.btn-secondary:hover:not(:disabled){background:#e8e8ed;background:var(--apple-gray-2);transform:translateY(-1px)}.welcome-section{color:#48484a;color:var(--apple-gray-5);margin-bottom:3rem;text-align:center}.welcome-section h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#48484a,#000);background:linear-gradient(135deg,var(--apple-gray-5),#000);-webkit-background-clip:text;font-size:2.8rem;font-weight:700;letter-spacing:-1px;margin-bottom:1rem}.welcome-section p{font-size:1.1rem;margin-bottom:1rem}.current-date,.welcome-section p{color:#8e8e93;color:var(--apple-gray-4);font-weight:400}.current-date{font-size:.95rem;font-style:normal}.stats-section{margin-bottom:3rem}.stats-section h2{color:#48484a;color:var(--apple-gray-5);font-size:1.6rem;font-weight:600;letter-spacing:-.5px;margin-bottom:2rem;text-align:center}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem}.stat-card{background:#fff;background:var(--apple-white);border:1px solid #e8e8ed;border:1px solid var(--apple-gray-2);border-radius:20px;box-shadow:0 4px 20px #007aff14;box-shadow:var(--shadow-light);overflow:hidden;padding:2rem 1.5rem;position:relative;text-align:center;transition:all .4s cubic-bezier(.25,.46,.45,.94)}.stat-card:before{background:#007aff;background:var(--apple-blue);content:"";height:3px;left:0;opacity:.8;position:absolute;right:0;top:0}.stat-card:hover{border-color:#d1d1d6;border-color:var(--apple-gray-3);box-shadow:0 16px 48px #007aff26;box-shadow:var(--shadow-heavy);transform:translateY(-6px)}.stat-number{color:#48484a;color:var(--apple-gray-5);font-size:2.5rem;letter-spacing:-1px}.stat-label{color:#8e8e93;color:var(--apple-gray-4);font-size:.9rem;font-weight:500}.quick-actions{margin-bottom:3rem}.quick-actions h2{color:#48484a;color:var(--apple-gray-5);font-size:1.6rem;font-weight:600;letter-spacing:-.5px;margin-bottom:2rem;text-align:center}.actions-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.action-card{align-items:center;background:#fff;background:var(--apple-white);border:1px solid #e8e8ed;border:1px solid var(--apple-gray-2);border-radius:20px;box-shadow:0 4px 20px #007aff14;box-shadow:var(--shadow-light);cursor:pointer;display:flex;flex-direction:column;gap:1.2rem;overflow:hidden;padding:2rem 1rem;position:relative;transition:all .4s cubic-bezier(.25,.46,.45,.94)}.action-card:before{background:linear-gradient(90deg,#0000,#007aff0d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.action-card:hover:before{left:100%}.action-card:hover{border-color:#007aff;border-color:var(--apple-blue);box-shadow:0 16px 48px #007aff26;box-shadow:var(--shadow-heavy);transform:translateY(-6px) scale(1.02)}.action-icon{filter:grayscale(.3);font-size:2.5rem;transition:all .3s ease}.action-card:hover .action-icon{filter:grayscale(0);transform:scale(1.1)}.action-text{color:#48484a;color:var(--apple-gray-5);font-size:1rem;font-weight:600;text-align:center}.recent-section{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fff;background:var(--apple-white);border:1px solid #e8e8ed;border:1px solid var(--apple-gray-2);border-radius:20px;box-shadow:0 4px 20px #007aff14;box-shadow:var(--shadow-light);padding:2.5rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.section-header h2{color:#48484a;color:var(--apple-gray-5);font-size:1.5rem;font-weight:600;letter-spacing:-.5px;margin:0}.view-all-btn{background:#007aff;background:var(--apple-blue);border:none;border-radius:10px;box-shadow:0 4px 20px #007aff14;box-shadow:var(--shadow-light);color:#fff;color:var(--apple-white);cursor:pointer;font-size:.8rem;font-weight:600;letter-spacing:.3px;padding:.7rem 1.3rem;transition:all .3s cubic-bezier(.25,.46,.45,.94)}.view-all-btn:hover{background:#409cff;background:var(--apple-blue-light);box-shadow:0 8px 32px #007aff1f;box-shadow:var(--shadow-medium);transform:translateY(-1px)}.presentations-list{grid-gap:.8rem;display:grid;gap:.8rem}.presentation-item{align-items:center;background:#f5f5f7;background:var(--apple-gray-1);border:1px solid #0000;border-radius:14px;cursor:pointer;display:flex;gap:1rem;padding:1.2rem 1.5rem;transition:all .3s cubic-bezier(.25,.46,.45,.94)}.presentation-item:hover{background:#fff;background:var(--apple-white);border-color:#007aff;border-color:var(--apple-blue);box-shadow:0 4px 20px #007aff14;box-shadow:var(--shadow-light);transform:translateX(4px)}.presentation-icon{color:#8e8e93;color:var(--apple-gray-4);flex-shrink:0;font-size:1.8rem}.presentation-content{flex:1 1}.presentation-content h4{color:#48484a;color:var(--apple-gray-5);font-size:1rem;font-weight:600;margin:0 0 .3rem}.presentation-content p{font-size:.85rem;margin:0}.empty-state,.presentation-content p{color:#8e8e93;color:var(--apple-gray-4)}.empty-state{padding:3rem 2rem}.empty-icon{font-size:3.5rem;opacity:.6}.empty-state p{font-weight:500;margin-bottom:2rem}@keyframes appleFadeIn{0%{opacity:0}to{opacity:1}}@keyframes appleSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.home-screen:before{background:radial-gradient(circle at 15% 50%,#007aff08 0,#0000 50%),radial-gradient(circle at 85% 30%,#007aff05 0,#0000 50%),radial-gradient(circle at 50% 80%,#007aff0a 0,#0000 50%);content:"";height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:-1}.recent-section::-webkit-scrollbar{width:4px}.recent-section::-webkit-scrollbar-track{background:#f5f5f7;background:var(--apple-gray-1);border-radius:10px}.recent-section::-webkit-scrollbar-thumb{background:#007aff;background:var(--apple-blue);border-radius:10px}.recent-section::-webkit-scrollbar-thumb:hover{background:#409cff;background:var(--apple-blue-light)}@media (max-width:768px){.home-screen{padding:1.5rem}.welcome-section h1{font-size:2.2rem}.stats-grid{grid-template-columns:1fr}.actions-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.section-header{flex-direction:column;gap:1rem;text-align:center}.modal-content{margin:1rem;padding:2rem 1.5rem}.modal-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}.action-card,.stat-card{padding:1.5rem 1rem}}@media (max-width:480px){.actions-grid{grid-template-columns:1fr}.welcome-section h1{font-size:1.8rem}.stat-number{font-size:2rem}.presentation-item{flex-direction:column;gap:.8rem;padding:1.5rem;text-align:center}.recent-section{padding:1.5rem}}.action-card:hover .action-icon,.presentation-item:hover .presentation-icon{filter:drop-shadow(0 4px 8px rgba(0,122,255,.3))}.loading-spinner{border:2px solid #e8e8ed;border-top:2px solid #007aff;border:2px solid var(--apple-gray-2);border-top-color:var(--apple-blue);height:20px;width:20px}@media (prefers-reduced-motion:reduce){.action-card,.btn-primary,.btn-secondary,.presentation-item,.stat-card{transition:none}.action-card:hover,.stat-card:hover{transform:none}}.sync-devices{background-color:#fff;margin:0 auto;max-width:800px;min-height:100vh;padding:20px}.sync-devices.loading{align-items:center;display:flex;flex-direction:column;height:100vh;justify-content:center}.spinner{border-top-color:#007aff}.sync-header{background-color:#f8f9fa;border-bottom:1px solid #e9ecef;margin-bottom:20px;padding:20px}.sync-header h2{color:#000;font-size:28px;font-weight:700;margin:0 0 8px}.subtitle{color:#666;font-size:16px}.connected-section{padding:20px}.section-title{color:#000;font-size:18px;font-weight:600;margin-bottom:16px}.device-card{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;margin-bottom:16px;padding:16px}.device-header{align-items:center;display:flex;margin-bottom:12px}.device-icon{font-size:24px;margin-right:12px}.device-header h4{color:#000;flex:1 1;font-size:18px;font-weight:600}.status-badge{border-radius:16px;font-size:12px;font-weight:600;padding:6px 12px}.status-badge.connected{background-color:#d4edda;color:#155724}.status-badge.disconnected{background-color:#f8d7da;color:#721c24}.device-info p{color:#666;font-size:14px;margin-bottom:4px}.online-status{color:#888;font-size:12px;font-style:italic}.device-actions{display:flex;gap:12px}.btn-danger,.btn-primary,.btn-secondary{align-items:center;border:1px solid;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:8px 16px;transition:background-color .2s}.btn-primary{background-color:#007aff;border-color:#007aff}.btn-primary.disabled{background-color:#ccc;border-color:#ccc;cursor:not-allowed}.btn-secondary{background-color:#fff;border-color:#007aff;color:#007aff}.btn-danger{background-color:#fff5f5;border-color:#fed7d7;color:#c53030}.edit-btn{background-color:#fff;border-color:#007aff;color:#007aff}.manual-btn{border-width:2px;justify-content:center;padding:16px}.cancel-btn{border-color:#e9ecef}.empty-devices{margin-top:20px;padding:40px;text-align:center}.empty-icon{color:#ccc;font-size:64px}.empty-devices h3{color:#000;font-size:20px;font-weight:600;margin:16px 0 8px}.empty-devices p{color:#666;font-size:16px;line-height:22px}.actions-section{display:flex;gap:12px}.modal-container{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background-color:#fff;max-width:400px;padding:24px;width:100%}.modal-content h3{color:#000;font-size:20px;font-weight:700;margin-bottom:8px}.modal-subtitle{color:#666;font-size:16px;line-height:22px;margin-bottom:24px}.code-input,.name-input{background-color:#f8f9fa;border:2px solid #e9ecef;border-radius:12px;font-size:18px;font-weight:600;letter-spacing:2px;margin-bottom:24px;padding:16px;text-align:center;width:100%}.name-input{font-size:16px;font-weight:500;letter-spacing:normal;text-align:left}.modal-buttons{display:flex;gap:12px}:root{--primary-blue:#007aff;--light-blue:#e5f2ff;--dark-blue:#0051a8;--off-white:#f9f9fb;--glass-bg:#ffffffd9;--glass-border:#007aff33;--shadow-light:0 4px 12px #007aff14;--shadow-medium:0 8px 24px #007aff1f;--gradient-button:linear-gradient(135deg,#007aff,#5ac8fa);--text-primary:#1d1d1f;--text-secondary:#6e6e73;--success:#34c759;--error:#ff3b30}.presentations-screen{background:linear-gradient(180deg,#f2f7ff,#fff);box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:2rem}.presentations-header{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd9;background:var(--glass-bg);border:1px solid #007aff33;border:1px solid var(--glass-border);border-radius:16px;box-shadow:0 4px 12px #007aff14;box-shadow:var(--shadow-light);display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.header-info h2{color:#1d1d1f;color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0}.presentations-count{color:#6e6e73;color:var(--text-secondary);font-size:.95rem;margin:.5rem 0 0}.tv-indicator{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.6rem 1rem}.tv-indicator.connected{background:#34c75926;border:1px solid #34c7594d;color:#34c759;color:var(--success)}.tv-indicator.disconnected{background:#ff3b301a;border:1px solid #ff3b3040;color:#ff3b30;color:var(--error)}.tv-icon{fill:currentColor;height:18px;width:18px}.presentations-screen.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh}.spinner{border:4px solid #e5f2ff;border-top:4px solid #007aff;border:4px solid var(--light-blue);border-top-color:var(--primary-blue);height:44px;margin-bottom:1rem;width:44px}.error-messages{border:1px solid #ff3b3040;border-radius:12px;margin-bottom:1.5rem}.error-message{color:var(--error);margin:0}.empty-presentations{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd9;background:var(--glass-bg);border:1px solid #007aff33;border:1px solid var(--glass-border);border-radius:16px;box-shadow:0 4px 12px #007aff14;box-shadow:var(--shadow-light);padding:3rem 2rem;text-align:center}.empty-icon{fill:#007aff;fill:var(--primary-blue);height:56px;margin-bottom:1rem;width:56px}.empty-presentations h3{color:#1d1d1f;color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.empty-presentations p{color:#6e6e73;color:var(--text-secondary);font-size:.95rem;margin:0}.presentations-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.presentation-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd9;background:var(--glass-bg);border:1px solid #007aff33;border:1px solid var(--glass-border);border-radius:16px;box-shadow:0 4px 12px #007aff14;box-shadow:var(--shadow-light);display:flex;flex-direction:column;overflow:hidden;transition:all .3s cubic-bezier(.25,.8,.25,1)}.presentation-card:hover{border-color:#007aff66;box-shadow:0 8px 24px #007aff1f;box-shadow:var(--shadow-medium);transform:translateY(-6px)}.presentation-info{cursor:pointer;flex-grow:1;padding:1.5rem}.info-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.presentation-title{color:#1d1d1f;color:var(--text-primary);flex:1 1;font-size:1.25rem;font-weight:600;margin:0;overflow:hidden;padding-right:.5rem;text-overflow:ellipsis;white-space:nowrap}.live-badge{align-items:center;background:#ff3b30;background:var(--error);border-radius:8px;color:#fff;display:flex;font-size:.7rem;font-weight:700;gap:.3rem;letter-spacing:.5px;padding:.25rem .5rem;text-transform:uppercase}.live-icon{height:12px;width:12px}.info-content{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.info-item{color:#6e6e73;color:var(--text-secondary);font-size:.875rem;gap:.5rem}.info-icon{fill:#007aff;fill:var(--primary-blue);height:18px;width:18px}.info-item span{color:#1d1d1f;color:var(--text-primary);font-weight:500}.presentation-description{color:#6e6e73;color:var(--text-secondary);font-size:.875rem;margin:0}.presentation-actions{background:#f9f9fbcc;border-top:1px solid #007aff33;border-top:1px solid var(--glass-border);display:flex;gap:.5rem;padding:1rem}.btn-delete,.btn-send,.btn-view{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;flex:1 1;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem;transition:all .2s ease}.btn-view{background:linear-gradient(135deg,#007aff,#5ac8fa);background:var(--gradient-button);box-shadow:0 2px 4px #007aff33;color:#fff}.btn-view:hover{box-shadow:0 4px 8px #007aff4d;transform:translateY(-1px)}.btn-send{background:#34c75926;border:1px solid #34c7594d;color:#34c759;color:var(--success)}.btn-send:hover:not(.disabled){background:#34c759;background:var(--success);color:#fff;transform:translateY(-1px)}.btn-send.disabled{background:#f9f9fb;background:var(--off-white);color:#6e6e73;color:var(--text-secondary);cursor:not-allowed;opacity:.6}.btn-delete{background:#ff3b3026;border:1px solid #ff3b304d;color:#ff3b30;color:var(--error)}.btn-delete:hover{background:#ff3b30;background:var(--error);color:#fff;transform:translateY(-1px)}.action-icon{fill:currentColor;height:18px;width:18px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffd9;background:var(--glass-bg);border:1px solid #007aff33;border:1px solid var(--glass-border);border-radius:16px;box-shadow:0 8px 24px #007aff1f;box-shadow:var(--shadow-medium);max-width:420px;padding:2rem;width:90%}.modal-content h3{color:#1d1d1f;color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0 0 1rem}.modal-content p{color:#6e6e73;color:var(--text-secondary);font-size:.925rem;line-height:1.5;margin:0 0 1.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-cancel,.btn-confirm-delete{border-radius:12px;cursor:pointer;font-size:.875rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.btn-cancel{background:#f9f9fb;background:var(--off-white);border:1px solid #007aff33;border:1px solid var(--glass-border);color:#6e6e73;color:var(--text-secondary)}.btn-cancel:hover{background:#e5f2ff;background:var(--light-blue);color:#007aff;color:var(--primary-blue)}.btn-confirm-delete{background:#ff3b30;background:var(--error);color:#fff}.btn-confirm-delete:hover{background:#d32f2f}@media (max-width:768px){.presentations-grid{grid-template-columns:1fr}.presentations-header{align-items:flex-start;flex-direction:column;gap:1rem}.info-content{grid-template-columns:1fr}}@media (max-width:480px){.presentation-actions{flex-direction:column}.btn-delete,.btn-send,.btn-view{width:100%}}.presentation-preview{background:#000;display:flex;flex-direction:column;height:100%;position:relative}.presentation-preview.error,.presentation-preview.loading{align-items:center;background:#fff;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:40px;text-align:center}.spinner{border:4px solid #f3f3f3;border-top-color:#007bff}.loading-text{color:#6c757d;font-size:16px}.error-icon,.error-text{margin-bottom:20px}.error-text{color:#2c3e50;text-align:center}.retry-button{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;margin:8px;padding:12px 24px;transition:background .3s ease}.retry-button:hover{background:#0056b3}.back-button{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;margin:8px;padding:12px 24px;transition:background .3s ease}.back-button:hover{background:#545b62}.preview-header{align-items:center;background:#fff;border-bottom:1px solid #e9ecef;display:flex;padding:16px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.preview-title{color:#2c3e50;flex:1 1;font-size:18px;font-weight:700;margin:0 16px;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.action-button{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;font-size:16px;padding:8px 12px;transition:all .3s ease}.action-button:hover{background:#e9ecef}.preview-content{background:#000;flex:1 1;flex-direction:column}.media-container,.preview-content{align-items:center;display:flex;justify-content:center;position:relative}.media-container{height:70vh;width:100%}.no-media-container{color:#bdc3c7;padding:40px;text-align:center}.no-media-icon{font-size:64px;margin-bottom:16px}.no-media-text{font-size:16px}.error-container{background:#fdf2f2;border-radius:12px;color:#e74c3c;margin:20px;padding:40px;text-align:center}.error-icon{font-size:48px;margin-bottom:16px}.error-text{font-size:18px;font-weight:700;margin-bottom:8px}.error-subtext{color:#7f8c8d;font-size:14px;margin-bottom:20px}.video-container{align-items:center;background:#000;display:flex;height:100%;justify-content:center;position:relative;width:100%}.video-player{height:auto;max-height:100%;max-width:100%;width:auto}.image-container{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.preview-image{height:auto;max-height:100%;max-width:100%;object-fit:contain;width:auto}.play-button{align-items:center;background:#000000b3;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:24px;height:60px;justify-content:center;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:background .3s ease;width:60px;z-index:10}.play-button:hover{background:#000000e6}.video-loading-overlay{align-items:center;background:#000c;bottom:0;color:#fff;display:flex;flex-direction:column;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:5}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:40px;margin-bottom:16px;width:40px}.video-loading-text{font-size:16px}.error-overlay{align-items:center;background:#000000e6;bottom:0;color:#e74c3c;display:flex;flex-direction:column;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:5}.error-overlay-text{font-size:16px;font-weight:700;margin:16px 0}.navigation-controls{align-items:center;background:#000c;display:flex;gap:40px;justify-content:center;padding:20px}.control-button{background:#ffffffe6;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;min-width:100px;padding:12px 20px;transition:all .3s ease}.control-button:hover:not(.disabled){background:#fff;transform:translateY(-2px)}.control-button.disabled{cursor:not-allowed;opacity:.3}.slide-counter{color:#fff;font-size:16px;font-weight:700;min-width:80px;text-align:center}.thumbnails-container{background:#000000e6;border-top:1px solid #333;height:100px;padding:12px}.thumbnails-list{display:flex;gap:10px;overflow-x:auto;padding:4px}.thumbnail{border:2px solid #0000;border-radius:6px;cursor:pointer;flex-shrink:0;height:60px;overflow:hidden;position:relative;transition:all .3s ease;width:80px}.thumbnail:hover{transform:scale(1.05)}.active-thumbnail{border-color:#007bff}.thumbnail-image{height:100%;object-fit:cover;width:100%}.video-indicator{background:#000000b3;border-radius:4px;font-size:10px;padding:2px 4px;position:absolute;right:4px;top:4px}.active-indicator{background:#007bff;bottom:0;height:3px;left:0;position:absolute;right:0}.fullscreen-modal{background:#000;bottom:0;display:flex;flex-direction:column;left:0;position:fixed;right:0;top:0;z-index:1000}.fullscreen-header{background:#000c;padding:16px;position:-webkit-sticky;position:sticky;top:0;z-index:1001}.close-fullscreen,.fullscreen-header{align-items:center;color:#fff;display:flex}.close-fullscreen{background:#fff3;border:none;border-radius:50%;cursor:pointer;font-size:20px;height:40px;justify-content:center;transition:background .3s ease;width:40px}.close-fullscreen:hover{background:#ffffff4d}.fullscreen-title{flex:1 1;font-size:18px;font-weight:700;margin:0 20px;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.fullscreen-content{flex:1 1;position:relative}.fullscreen-content,.fullscreen-controls{align-items:center;display:flex;justify-content:center}.fullscreen-controls{bottom:40px;gap:40px;left:0;padding:20px;position:absolute;right:0}@media (max-width:768px){.preview-header{padding:12px}.preview-title{font-size:16px;margin:0 12px}.media-container{height:60vh}.control-button{font-size:12px;min-width:80px;padding:10px 16px}.thumbnails-container{height:80px}.thumbnail{height:45px;width:60px}}@media (max-width:480px){.navigation-controls{gap:20px;padding:15px}.control-button{font-size:11px;min-width:70px;padding:8px 12px}.slide-counter{font-size:14px;min-width:60px}.thumbnails-list{gap:6px}.thumbnail{height:38px;width:50px}}.file-upload{background:#fff;background:var(--white);box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:2rem}:root{--primary-blue:#2196f3;--light-blue:#e3f2fd;--dark-blue:#1976d2;--white:#fff;--off-white:#f5f5f7;--gray-text:#1d2525;--gray-secondary:#4b5e5e;--success-green:#34c759;--error-red:#ff3b30;--shadow-light:0 4px 12px #2196f31a;--shadow-medium:0 8px 24px #2196f326;--glass-bg:#fffffff2;--glass-border:#2196f34d;--gradient-button:linear-gradient(45deg,#2196f3,#42a5f5)}.upload-header{margin-bottom:2rem;text-align:center}.upload-header h2{color:#1d2525;color:var(--gray-text);font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.upload-header p{color:#4b5e5e;color:var(--gray-secondary);font-size:1rem}.error-messages{background:#ff3b301a;border:1px solid #ff3b304d;border-radius:8px;margin-bottom:1rem;padding:1rem}.error-message{color:#ff3b30;color:var(--error-red);font-size:.875rem;margin:.5rem 0}.upload-area{background:#f5f5f7;background:var(--off-white);border:2px dashed #2196f34d;border:2px dashed var(--glass-border);border-radius:12px;cursor:pointer;padding:2rem;text-align:center;transition:border-color .2s ease,background-color .2s ease}.upload-area.drag-active{background:#e3f2fd;background:var(--light-blue);border-color:#2196f3;border-color:var(--primary-blue)}.upload-content{align-items:center;display:flex;flex-direction:column;gap:.5rem}.upload-icon{fill:#2196f3;fill:var(--primary-blue);height:48px;width:48px}.upload-area h3{color:#1d2525;color:var(--gray-text);font-size:1.25rem;font-weight:600;margin:.5rem 0}.upload-area p{color:#4b5e5e;color:var(--gray-secondary);font-size:.875rem;margin:.25rem 0}.file-size-info{font-weight:500}.presentation-creator{background:#fffffff2;background:var(--glass-bg);border:1px solid #2196f34d;border:1px solid var(--glass-border);border-radius:12px;box-shadow:0 4px 12px #2196f31a;box-shadow:var(--shadow-light);padding:1.5rem}.creator-header{margin-bottom:1.5rem}.creator-header h3{color:#1d2525;color:var(--gray-text);font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.creator-header p{color:#4b5e5e;color:var(--gray-secondary);font-size:.95rem}.presentation-form{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:1.5rem}.form-group{gap:.5rem}.form-group label{color:#1d2525;color:var(--gray-text);font-size:.875rem}.form-input,.form-textarea{background:#fff;background:var(--white);border:1px solid #2196f34d;border:1px solid var(--glass-border);border-radius:8px;font-size:.875rem;padding:.75rem;transition:border-color .2s ease}.form-input:focus,.form-textarea:focus{border-color:#2196f3;border-color:var(--primary-blue);outline:none}.form-textarea{resize:vertical}.orientation-options{display:flex;gap:1rem}.orientation-option{flex:1 1}.option-content,.orientation-option{align-items:center;display:flex;gap:.5rem}.option-content{background:#f5f5f7;background:var(--off-white);border-radius:8px;cursor:pointer;padding:.5rem;transition:background-color .2s ease}.option-content:hover{background:#e3f2fd;background:var(--light-blue)}.option-icon{fill:#2196f3;fill:var(--primary-blue);height:20px;width:20px}.option-text{color:#1d2525;color:var(--gray-text);font-size:.875rem}.orientation-option input{margin-right:.5rem}.uploaded-files-section{margin-bottom:1.5rem}.section-header{margin-bottom:1rem}.section-header h4{color:#1d2525;color:var(--gray-text);font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.section-header p{color:#4b5e5e;color:var(--gray-secondary);font-size:.875rem}.files-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.file-item{background:#fff;background:var(--white);border:1px solid #2196f34d;border:1px solid var(--glass-border);border-radius:8px;box-shadow:0 4px 12px #2196f31a;box-shadow:var(--shadow-light);transition:transform .2s ease}.file-item:hover{transform:translateY(-2px)}.file-item[draggable=true]:hover{cursor:move}.file-thumbnail-container{height:120px;overflow:hidden;position:relative}.file-thumbnail{display:block;height:100%;object-fit:cover;width:100%}.file-thumbnail.video{align-items:center;background:#e3f2fd;background:var(--light-blue);display:flex;justify-content:center}.file-icon{fill:#4b5e5e;fill:var(--gray-secondary);height:48px;width:48px}.video-badge{background:#2196f3e6;border-radius:6px;color:#fff;color:var(--white);font-size:.75rem;font-weight:600;left:8px;padding:.3rem .6rem;position:absolute;top:8px}.file-overlay{align-items:flex-start;background:#0000004d;bottom:0;display:flex;justify-content:space-between;left:0;opacity:0;padding:8px;position:absolute;right:0;top:0;transition:opacity .2s ease}.file-item:hover .file-overlay{opacity:1}.remove-btn{align-items:center;background:#ff3b30;background:var(--error-red);border:none;border-radius:50%;color:#fff;color:var(--white);cursor:pointer;display:flex;height:24px;justify-content:center;transition:transform .2s ease;width:24px}.remove-btn:hover{transform:scale(1.1)}.remove-btn svg{fill:#fff;fill:var(--white);height:16px;width:16px}.file-position{align-items:center;background:#2196f3;background:var(--primary-blue);border-radius:50%;color:#fff;color:var(--white);display:flex;font-size:.75rem;font-weight:600;height:24px;justify-content:center;width:24px}.file-info{padding:.75rem}.file-name{color:#1d2525;color:var(--gray-text);font-size:.875rem;font-weight:500;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#4b5e5e;color:var(--gray-secondary);font-size:.75rem;margin:.25rem 0 0}.creation-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-primary,.btn-secondary{border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;padding:.75rem 1.5rem;transition:background-color .2s ease,transform .2s ease}.btn-primary{align-items:center;background:linear-gradient(45deg,#2196f3,#42a5f5);background:var(--gradient-button);border:none;color:#fff;color:var(--white);display:flex;gap:.5rem}.btn-primary:focus,.btn-primary:hover{background:#1976d2;background:var(--dark-blue);transform:scale(1.02)}.btn-primary:disabled{cursor:not-allowed}.btn-primary:disabled,.btn-secondary{background:#f5f5f7;background:var(--off-white);color:#4b5e5e;color:var(--gray-secondary)}.btn-secondary{border:1px solid #2196f34d;border:1px solid var(--glass-border)}.btn-secondary:focus,.btn-secondary:hover{background:#e3f2fd;background:var(--light-blue);color:#2196f3;color:var(--primary-blue);transform:scale(1.02)}.btn-icon{fill:#fff;fill:var(--white);height:20px;width:20px}.upload-progress{margin-top:1.5rem;text-align:center}.progress-bar{background:#f5f5f7;background:var(--off-white);border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(45deg,#2196f3,#42a5f5);background:var(--gradient-button);height:100%;transition:width .3s ease}.upload-progress p{color:#1d2525;color:var(--gray-text);font-size:.875rem;margin-top:.5rem}.upload-summary{background:#fffffff2;background:var(--glass-bg);border:1px solid #2196f34d;border:1px solid var(--glass-border);border-radius:12px;box-shadow:0 4px 12px #2196f31a;box-shadow:var(--shadow-light);margin-top:1.5rem;padding:1.5rem;text-align:center}.summary-content{align-items:center;display:flex;flex-direction:column;gap:.75rem}.summary-content h4{align-items:center;color:#1d2525;color:var(--gray-text);display:flex;font-size:1.25rem;font-weight:600;gap:.5rem;margin:0}.summary-icon{fill:#34c759;fill:var(--success-green);height:24px;width:24px}.summary-content p{color:#4b5e5e;color:var(--gray-secondary);font-size:.875rem;margin:0}@media (max-width:768px){.file-upload{padding:1rem}.files-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.file-thumbnail-container{height:100px}.upload-header h2{font-size:1.5rem}.creator-header h3{font-size:1.25rem}.orientation-options{flex-direction:column}}@media (max-width:480px){.files-grid{grid-template-columns:1fr}.creation-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}@media (prefers-reduced-motion:reduce){.btn-primary,.btn-secondary,.file-item,.upload-area{transition:none}.btn-primary:hover,.btn-secondary:hover,.file-item:hover{transform:none}}.visually-hidden{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}@supports not ((-webkit-backdrop-filter:blur(10px)) or (backdrop-filter:blur(10px))){.presentation-creator,.upload-summary{background:#fff;background:var(--white)}}.user-profile{background-color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;margin:0 auto;max-width:800px;min-height:100vh;padding:20px}.user-profile.error,.user-profile.loading{align-items:center;display:flex;flex-direction:column;height:100vh;justify-content:center}.spinner{border:4px solid #e9ecef;border-top-color:#2196f3;height:40px;width:40px}.spinner.small{height:20px;width:20px}.profile-header{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px}.profile-header h2{color:#000;font-size:28px;font-weight:700;margin:0}.header-actions{display:flex;gap:12px}.action-btn,.cancel-btn,.edit-btn,.logout-btn,.refresh-btn,.save-btn{align-items:center;border:1px solid;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:8px 16px;transition:background-color .2s,opacity .2s}.edit-btn{background-color:#2196f3;border-color:#2196f3;color:#fff}.refresh-btn{background-color:#f8f9fa;border-color:#e9ecef;color:#666}.refresh-btn:disabled{cursor:not-allowed;opacity:.6}.save-btn{background-color:#34c759;border-color:#34c759;color:#fff}.cancel-btn{background-color:#f8f9fa;border:1px solid #e9ecef;color:#666}.action-btn{background-color:#fff;border:2px solid #2196f3;color:#2196f3;display:block;margin-bottom:12px;padding:12px;text-align:center;width:100%}.premium-btn{background-color:#2196f3;border-color:#2196f3;color:#fff}.reconnect-btn{background-color:#ff9500;border-color:#ff9500;color:#fff}.logout-btn{background-color:#fff5f5;border-color:#fed7d7;color:#c53030;justify-content:center;margin-top:20px;width:100%}.profile-content{display:flex;gap:40px;padding:20px}.avatar-section{flex:1 1}.avatar-container{height:150px;position:relative;width:150px}.profile-avatar{object-fit:cover}.avatar-placeholder,.profile-avatar{border:2px solid #e9ecef;border-radius:50%;height:100%;width:100%}.avatar-placeholder{align-items:center;background-color:#2196f3;display:flex;justify-content:center}.avatar-text{color:#fff;font-size:48px;font-weight:700}.avatar-upload{background-color:#2196f3;border-radius:12px;bottom:0;color:#fff;cursor:pointer;font-size:12px;padding:8px;position:absolute;right:0;transition:background-color .2s}.avatar-upload:hover{background-color:#1976d2}.profile-info{flex:2 1}.edit-form{gap:16px}.edit-form,.form-group{display:flex;flex-direction:column}.form-group label{color:#000;font-size:14px;font-weight:600;margin-bottom:8px}.form-input{background-color:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;font-size:16px;padding:12px;transition:border-color .2s}.form-input:focus{border-color:#2196f3;outline:none}.form-actions{display:flex;gap:12px;margin-top:16px}.view-mode{display:flex;flex-direction:column;gap:16px}.info-item{align-items:center;display:flex;gap:12px}.info-item strong{color:#000;font-size:16px;font-weight:600;width:150px}.info-item span{color:#666;font-size:16px}.plan-text{color:#2196f3;font-weight:700}.stats{display:flex;gap:24px;justify-content:space-between;margin-top:24px}.stat-item{flex:1 1;text-align:center}.stat-number{color:#2196f3;display:block;font-size:24px;font-weight:700}.stat-label{color:#666;font-size:14px}.account-info{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;margin-top:20px;padding:20px}.account-info h3{color:#000;font-size:18px;font-weight:600;margin-bottom:16px}.actions-section{margin-top:20px;padding:20px}.actions-section h3{color:#000;font-size:18px;font-weight:600;margin-bottom:16px}button:hover:not(:disabled){opacity:.9}.connected-users{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin:0 auto;max-width:1000px;min-height:100vh;padding:2rem}.connected-users.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh}.spinner{height:60px;margin-bottom:1.5rem;width:60px}.connected-users.loading p{font-size:1.2rem;opacity:.9}.users-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:3rem;padding:0 1rem}.users-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#f8f9fa);-webkit-background-clip:text;font-size:2.5rem;font-weight:800;margin:0;text-shadow:0 4px 20px #0000001a}.users-count{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:50px;box-shadow:0 4px 15px #0000001a;font-size:1.1rem;font-weight:600;padding:.8rem 1.5rem}.users-list{grid-gap:1.5rem;display:grid;gap:1.5rem;margin-bottom:3rem}.user-card{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 8px 32px #0000001a;display:flex;gap:1.5rem;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.user-card:before{background:linear-gradient(135deg,#3498db,#2980b9);content:"";height:100%;left:0;position:absolute;top:0;transition:all .3s ease;width:4px}.user-card:hover{box-shadow:0 15px 40px #0003;transform:translateY(-5px) scale(1.02)}.user-card:hover:before{background:linear-gradient(135deg,#e74c3c,#c0392b);width:6px}.user-avatar{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);border-radius:50%;box-shadow:0 4px 15px #3498db4d;color:#fff;display:flex;flex-shrink:0;font-size:1.5rem;font-weight:700;height:70px;justify-content:center;transition:all .3s ease;width:70px}.user-card:hover .user-avatar{box-shadow:0 6px 20px #3498db66;transform:scale(1.1)}.user-info{flex:1 1}.user-info h4{color:#2c3e50;font-size:1.3rem;font-weight:700;margin:0 0 .5rem}.user-email{color:#7f8c8d;font-size:.95rem;font-weight:500;margin:0 0 .5rem}.user-role{background:linear-gradient(135deg,#27ae60,#229954);border-radius:20px;color:#fff;display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.5px;margin:0;padding:.3rem 1rem;text-transform:uppercase}.user-status{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:.5rem}.status-indicator{animation:pulse 2s infinite;border-radius:50%;height:16px;position:relative;width:16px}.status-indicator.online{background:#27ae60;box-shadow:0 0 0 #27ae6066}.status-indicator.away{background:#f39c12;box-shadow:0 0 0 #f39c1266}@keyframes pulse{0%{box-shadow:0 0 0 0 #27ae6066}70%{box-shadow:0 0 0 10px #27ae6000}to{box-shadow:0 0 0 0 #27ae6000}}.status-indicator.away{animation:pulseAway 2s infinite}@keyframes pulseAway{0%{box-shadow:0 0 0 0 #f39c1266}70%{box-shadow:0 0 0 10px #f39c1200}to{box-shadow:0 0 0 0 #f39c1200}}.last-active{color:#7f8c8d;font-size:.8rem;font-weight:500;white-space:nowrap}.users-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:2rem}.stat{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 8px 32px #0000001a;overflow:hidden;padding:2rem 1.5rem;position:relative;text-align:center;transition:all .3s ease}.stat:before{background:linear-gradient(90deg,var(--gradient-color));content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat:first-child:before{--gradient-color:#3498db,#2980b9}.stat:nth-child(2):before{--gradient-color:#e74c3c,#c0392b}.stat:nth-child(3):before{--gradient-color:#27ae60,#229954}.stat:hover{box-shadow:0 15px 40px #0003;transform:translateY(-8px)}.stat-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2c3e50,#34495e);-webkit-background-clip:text;font-size:3rem;font-weight:800;line-height:1;margin-bottom:.5rem}.stat-label{color:#7f8c8d;font-size:1rem;font-weight:600;letter-spacing:1px;text-transform:uppercase}.empty-state{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;margin:2rem 0;padding:4rem 2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.7}.empty-state h3{color:#2c3e50;font-size:1.5rem;margin-bottom:1rem}.empty-state p{color:#7f8c8d;font-size:1.1rem}.connected-users:before{animation:float 8s ease-in-out infinite;background:radial-gradient(circle at 10% 20%,#7877c64d 0,#0000 50%),radial-gradient(circle at 90% 80%,#ff77c64d 0,#0000 50%),radial-gradient(circle at 30% 70%,#78dbff33 0,#0000 50%);content:"";height:100%;left:0;position:fixed;top:0;width:100%;z-index:-1}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}.user-role.admin{background:linear-gradient(135deg,#e74c3c,#c0392b)}.user-role.moderator{background:linear-gradient(135deg,#f39c12,#e67e22)}.user-role.usuario{background:linear-gradient(135deg,#3498db,#2980b9)}.user-card.new-user{animation:newUserHighlight 2s ease}@keyframes newUserHighlight{0%{background:#3498db4d;transform:scale(1)}50%{background:#3498db99;transform:scale(1.02)}to{background:#fffffff2;transform:scale(1)}}@media (max-width:768px){.connected-users{padding:1rem}.users-header{flex-direction:column;gap:1rem;text-align:center}.users-header h2{font-size:2rem}.user-card{flex-direction:column;gap:1rem;padding:2rem 1.5rem;text-align:center}.user-status{flex-direction:row;gap:1rem}.users-stats{grid-template-columns:1fr}.stat{padding:1.5rem 1rem}.stat-number{font-size:2.5rem}}@media (max-width:480px){.users-header h2{font-size:1.5rem}.users-count{font-size:.9rem;padding:.6rem 1.2rem}.user-avatar{font-size:1.2rem;height:60px;width:60px}.user-info h4{font-size:1.1rem}}.users-list::-webkit-scrollbar{width:6px}.users-list::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}.users-list::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#3498db,#2980b9);border-radius:10px}.users-list::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#2980b9,#1f618d)}.users-list.updating{position:relative}.users-list.updating:after{animation:pulse 2s infinite;background:#ffffffe6;border-radius:10px;color:#2c3e50;content:"🔄 Actualizando...";font-weight:600;left:50%;padding:1rem 2rem;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:10}.main-app{background-color:#f5f5f5;display:flex;flex-direction:column;height:100vh;margin-top:5%}.main-content{flex:1 1;margin-left:250px;overflow-y:auto;padding:20px}@media (max-width:768px){.main-content{margin-left:0;padding:10px}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{min-height:100vh}.loading-screen{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;height:100vh;justify-content:center}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-screen p{font-size:18px;font-weight:500}@media (max-width:768px){.loading-screen{padding:20px;text-align:center}.spinner{height:40px;width:40px}.loading-screen p{font-size:16px}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}
/*# sourceMappingURL=main.8ad58e40.css.map*/