:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;--primary-bg: #1a1a1a;--secondary-bg: rgba(255, 255, 255, .05);--accent-color: #4a90e2;--accent-gradient: linear-gradient(135deg, #4a90e2 0%, #2c5282 100%);--text-primary: rgba(255, 255, 255, .95);--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .5);--border-color: rgba(255, 255, 255, .15);--shadow-color: rgba(0, 0, 0, .4);--success-color: #4CAF50;--error-color: #f44336;--warning-color: #ff9800;color:var(--text-primary);background:var(--primary-bg);scroll-behavior:smooth;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#747bff}*{box-sizing:border-box}body{margin:0;padding:0;min-width:320px;min-height:100vh;background:var(--primary-bg);color:var(--text-primary);overflow-x:hidden;position:relative}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 25% 25%,rgba(74,144,226,.08) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(44,82,130,.08) 0%,transparent 50%);z-index:-1;animation:subtleFloat 20s ease-in-out infinite alternate}@keyframes subtleFloat{0%{transform:translate(0) rotate(0)}to{transform:translate(-10px,-10px) rotate(1deg)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}::-webkit-scrollbar-thumb{background:#4a90e2b3;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#4a90e2e6}h1{font-size:3.2em;line-height:1.1}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;background:var(--primary-bg)}.login-left{position:relative;background:linear-gradient(135deg,#4a90e214,#2c528214);overflow:hidden;display:flex;align-items:center;justify-content:center}.image-container{position:relative;width:90%;max-width:500px;height:70vh;border-radius:20px;overflow:hidden;box-shadow:0 25px 50px #0000004d}.hero-image{width:100%;height:100%;object-fit:cover;border-radius:20px;transition:transform .5s ease}.image-container:hover .hero-image{transform:scale(1.05)}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,#4a90e226,#2c528226);display:flex;align-items:center;justify-content:center}.floating-elements{position:relative;width:100%;height:100%}.code-snippet{position:absolute;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;padding:1rem;font-family:Monaco,Menlo,monospace;font-size:.875rem;color:#fff;box-shadow:0 8px 32px #0000004d;animation:floatUp 6s ease-in-out infinite alternate}.snippet-1{top:20%;left:10%;animation-delay:0s}.snippet-2{bottom:20%;right:10%;animation-delay:3s}.code-line{display:block;margin-bottom:.25rem}@keyframes floatUp{0%,to{transform:translateY(0) rotate(0);opacity:.8}50%{transform:translateY(-10px) rotate(1deg);opacity:1}}.login-right{display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--primary-bg)}.login-content{width:100%;max-width:480px;animation:slideInRight .8s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.login-header{text-align:center;margin-bottom:2rem}.app-title{font-size:3.5rem;font-weight:800;margin:0 0 1rem;line-height:1.1}.title-gradient{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.title-accent{color:var(--text-primary)}.app-subtitle{font-size:1.25rem;color:var(--text-secondary);margin:0;font-weight:400}.features-list{margin-bottom:3rem}.feature-item{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding:.5rem;background:#ffffff05;border-radius:12px;border:1px solid rgba(255,255,255,.08);transition:all .3s ease;animation:slideInUp .6s ease-out;animation-fill-mode:both}.feature-item:nth-child(1){animation-delay:.1s}.feature-item:nth-child(2){animation-delay:.2s}.feature-item:nth-child(3){animation-delay:.3s}.feature-item:nth-child(4){animation-delay:.4s}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.feature-item:hover{background:#ffffff0d;transform:translateY(-2px);border-color:#4a90e24d}.feature-icon{font-size:2rem;display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:#4a90e226;flex-shrink:0}.feature-text h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.feature-text p{margin:0;color:var(--text-secondary);font-size:.95rem;line-height:1.5}.login-action{text-align:center}.google-login-btn{width:100%;margin-bottom:1rem}.login-note{color:var(--text-muted);font-size:.875rem;margin:0}.loading-spinner{display:inline-flex;align-items:center;justify-content:center}.spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 968px){.login-container{grid-template-columns:1fr;grid-template-rows:40vh 1fr}.login-left{order:1}.login-right{order:2;padding:1rem}.image-container{height:35vh}.app-title{font-size:2.5rem}.login-content{max-width:100%}}@media (max-width: 640px){.app-title{font-size:2rem}.login-header,.features-list{margin-bottom:2rem}.feature-item{padding:.75rem}}.dashboard-container{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;background:var(--primary-bg)}.dashboard-left{position:relative;background:linear-gradient(135deg,#4a90e214,#2c528214);display:flex;align-items:center;justify-content:center;padding:2rem}.dashboard-left .image-container{position:relative;width:90%;max-width:500px;height:70vh;border-radius:20px;overflow:hidden;box-shadow:0 25px 50px #0000004d}.dashboard-left .image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,#4a90e226,#2c528226);display:flex;align-items:center;justify-content:center}.dashboard-stats{display:flex;flex-direction:column;gap:2rem}.stat-card{display:flex;align-items:center;gap:1rem;background:#000c;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);padding:1.5rem 2rem;border-radius:16px;border:1px solid rgba(255,255,255,.1);color:#fff;animation:slideInUp .6s ease-out;animation-fill-mode:both}.stat-card:first-child{animation-delay:.2s}.stat-card:last-child{animation-delay:.4s}.stat-icon{font-size:2.5rem;display:flex;align-items:center;justify-content:center;width:60px;height:60px;background:#4a90e233;border-radius:12px;flex-shrink:0}.stat-info h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:#fff}.stat-info p{margin:0;color:#fffc;font-size:1rem;line-height:1.4}.dashboard-right{display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--primary-bg)}.dashboard-content{width:100%;max-width:520px;animation:slideInRight .8s ease-out}.dashboard-header{text-align:center;margin-bottom:2rem}.welcome-title{font-size:2rem;font-weight:700;margin:0 0 1rem;color:var(--text-primary);line-height:1.2}.user-name{display:block;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-top:.5rem}.dashboard-subtitle{font-size:1rem;color:var(--text-secondary);margin:0;font-weight:400;line-height:1.6}.room-actions{display:flex;flex-direction:column;gap:.5rem}.action-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);animation:slideInUp .6s ease-out;animation-fill-mode:both}.create-card{animation-delay:.1s}.join-card{animation-delay:.2s}.action-card:hover{background:#ffffff0f;border-color:#4a90e24d;transform:translateY(-4px);box-shadow:0 20px 40px #00000026}.card-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:1rem}.card-icon{width:50px;height:50px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700;flex-shrink:0}.create-icon{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.join-icon{background:linear-gradient(135deg,#4a90e2,#2c5282);color:#fff}.card-title h3{margin:0;font-size:1.375rem;font-weight:600;color:var(--text-primary)}.card-title p{margin:0;color:var(--text-secondary);font-size:1rem;line-height:1.5}.card-content{display:flex;flex-direction:column;gap:1.25rem}.create-room-btn,.join-room-btn{width:100%}.divider{display:flex;align-items:center;justify-content:center;position:relative;margin:1rem 0}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(255,255,255,.2),transparent);transform:translateY(-50%)}.divider-text{background:var(--primary-bg);padding:0 1rem;color:var(--text-muted);font-weight:600;font-size:.875rem;position:relative;z-index:1}.custom-alert{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem 1.25rem;border-radius:12px;margin-bottom:2rem;border:1px solid;position:relative;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.custom-alert--warning{background:#ff98001a;border-color:#ff98004d;color:#ff9800}.custom-alert--error{background:#f443361a;border-color:#f443364d;color:#f44336}.custom-alert--success{background:#4caf501a;border-color:#4caf504d;color:#4caf50}.alert-content{flex:1}.alert-title{margin:0 0 .5rem;font-size:1rem;font-weight:600}.alert-message{margin:0;font-size:.925rem;opacity:.9;line-height:1.5}.alert-close{background:none;border:none;color:currentColor;font-size:1.25rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease;margin-left:1rem;flex-shrink:0}.alert-close:hover{background:#ffffff1a}@media (max-width: 968px){.dashboard-container{grid-template-columns:1fr;grid-template-rows:35vh 1fr}.dashboard-left{order:1;padding:1rem}.dashboard-right{order:2;padding:1rem}.dashboard-left .image-container{height:30vh}.dashboard-stats{flex-direction:row;gap:1rem}.stat-card{padding:1rem;flex:1}.stat-icon{width:40px;height:40px;font-size:1.5rem}.stat-info h3{font-size:1rem}.stat-info p{font-size:.875rem}.welcome-title{font-size:2rem}.dashboard-content{max-width:100%}}@media (max-width: 640px){.welcome-title{font-size:1.75rem}.dashboard-header{margin-bottom:2rem}.action-card{padding:1.5rem}.card-header{gap:1rem}.card-icon{width:50px;height:50px;font-size:1.5rem}.card-title h3{font-size:1.25rem}.dashboard-stats{flex-direction:column;gap:1rem}}.session-actions{display:flex;flex-direction:column;gap:20px;margin-top:40px}.session-actions button{padding:12px 24px;font-size:16px;cursor:pointer}.join-session{display:flex;flex-direction:column;gap:10px}.editor-container{padding:20px;height:100vh}.editor-header{display:flex;position:relative;justify-content:space-between;align-items:center;margin-bottom:20px}.language-selector{padding:8px 12px;font-size:16px;border-radius:4px}.MuiSpeedDial-root{display:-webkit-box!important}.chat-container{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 8px 32px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden;display:flex;flex-direction:column;height:100%}.chat-messages{flex:1;overflow-y:auto;padding:1rem;scrollbar-width:thin;scrollbar-color:rgba(74,144,226,.3) transparent}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#4a90e24d;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#4a90e280}.send-chat-input{position:sticky;bottom:0;padding:1rem;border-top:1px solid rgba(255,255,255,.1);background:#0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.chat-form{display:flex;gap:.75rem;align-items:center;width:100%}.chat-input{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:.75rem 1rem;color:var(--text-primary);font-size:.875rem;font-family:inherit;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;outline:none}.chat-input::placeholder{color:var(--text-muted)}.chat-input:focus{border-color:#4a90e266;background:#ffffff14;box-shadow:0 0 0 3px #4a90e21a}.chat-send-btn{background:linear-gradient(135deg,#4a90e2,#2c5282);border:none;border-radius:10px;padding:.75rem;color:#fff;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #4a90e24d;min-width:44px;height:44px}.chat-send-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90e266}.chat-send-btn:active{transform:translateY(0)}.MuiPaper-elevation{width:unset!important}.role-manager{position:absolute;right:0;width:max-content;top:50px;background:#fff;padding:15px;border-radius:8px;box-shadow:#00000059 0 5px 15px;z-index:10}.own-message{background:#4a90e226;color:var(--text-primary);border-left:3px solid #4a90e2}.loader-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh}.loader{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:20px}.editor-container{position:relative;height:100vh;padding:20px}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:15px}.connection-status{display:flex;align-items:center;gap:8px;background:#f5f5f5;padding:8px 15px;border-radius:20px}.status-indicator{width:12px;height:12px;border-radius:50%}.status-indicator.connected{background:#4caf50;animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 0 #4caf5066}70%{box-shadow:0 0 0 10px #4caf5000}to{box-shadow:0 0 #4caf5000}}.language-selector{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:#fff}.system-message{color:var(--text-muted);font-style:italic;text-align:center;margin:.75rem 0;padding:.5rem;background:#ffffff05;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.logout-button{position:absolute;top:20px;right:20px;padding:8px 16px;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer}.session-info{display:flex;gap:15px;align-items:center}.copy-btn{background:transparent;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer}.end-session-btn{background:#dc3545;color:#fff}.leave-session-btn{background:#ffc107;color:#000}.session-id{font-family:monospace;background:#f8f9fa;padding:4px 8px;border-radius:4px}.terminal-wrapper{margin-top:20px;border:1px solid #333;border-radius:4px;overflow:hidden}.xterm-viewport{background-color:#1e1e1e!important}.run-button{background:#2cbb5d;color:#fff;border-radius:4px;border:none;padding:4px 8px;font-size:16px;display:flex;font-weight:700;align-items:center;cursor:pointer}.run-button:hover{background:#24964c}.locked-line{background-color:#ffffff1a;pointer-events:none;color:#666!important}.app-header{position:sticky;top:0;z-index:100;background:#1a1a1af2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.15);box-shadow:0 8px 32px #0006}.header-container{max-width:1400px;margin:0 auto;padding:0 2rem;height:80px;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:transform .3s ease}.logo:hover{transform:scale(1.02)}.logo-text{font-size:1.75rem;font-weight:800;line-height:1}.logo-gradient{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-accent{color:var(--text-primary)}.logo-badge{background:linear-gradient(135deg,#ff6b6b,orange);color:#fff;font-size:.625rem;font-weight:700;padding:.25rem .5rem;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(.95)}}.header-right{display:flex;align-items:center;gap:1.5rem}.user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#ffffff0d;border-radius:6px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.user-info:hover{background:#ffffff14;border-color:#4a90e24d}.user-avatars{display:flex;justify-content:center;align-items:center;gap:8px}.manage-users-btn:hover{cursor:pointer;scale:1.05;transition:scale .2s ease-out}.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;display:flex;justify-content:center;align-items:center;background:#fff;color:#000;font-weight:700}.user-details{display:flex;flex-direction:column;gap:.125rem}.name-dashboard{font-size:32px!important;display:inline-block!important}.user-name{font-size:.875rem;font-weight:600;color:var(--text-primary);line-height:1.2}.user-email{font-size:.75rem;color:var(--text-muted);line-height:1.2}.logout-button{border-radius:25px}.header-spinner{display:inline-flex;align-items:center;justify-content:center}.header-spinner .spinner{width:14px;height:14px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.header-container{padding:0 1rem;height:70px}.logo-text{font-size:1.5rem}.user-info{padding:.5rem}.user-details{display:none}.header-right{gap:1rem}}@media (max-width: 480px){.logo-text{font-size:1.25rem}.logo-badge{display:none}}.join-session-container{display:flex;justify-content:center;flex-direction:column;gap:1rem}.password-options{display:flex;flex-direction:column;gap:1rem}.session-create{margin-bottom:1.5rem}.wrap{display:flex;height:100%}.gutter-horizontal{cursor:ew-resize}.gutter-vertical{cursor:ns-resize}.xterm-screen{height:unset!important;width:unset!important}.terminal.xterm{height:calc(100% - 20px)!important;padding:10px}.xterm-viewport{border-radius:10px!important}.gutter{background-repeat:no-repeat;background-position:50%;position:relative;z-index:10}.gutter.gutter-horizontal{cursor:col-resize}.gutter.gutter-horizontal:after{background-color:gray;border-radius:2px;content:"";height:30px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:4px}.gutter.gutter-vertical:after{background-color:gray;border-radius:2px;content:"";height:4px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:30px}.gutter.gutter-vertical{cursor:row-resize}.editor-header{height:40px;@apply bg-gray-800 flex items-center px-4 border-b border-gray-700;}.language-selector{@apply bg-gray-700 text-white px-3 py-1 rounded mr-4;}.end-session-btn{@apply bg-red-500 hover:bg-red-600 text-white px-4 py-1 rounded ml-auto;}.editor-head{width:100%;height:40px;background-color:#ffffff1a;border-top-left-radius:10px;border-top-right-radius:10px;color:#fff;font-weight:bolder;display:flex;justify-content:space-between;align-items:center;padding-inline:10px}.terminal-ui{border:1px solid rgba(255,255,255,.1);border-radius:12px}.editor-footer{width:100%;height:40px;background-color:#403d39;border-bottom-left-radius:10px;border-bottom-right-radius:10px}.editor-title{display:flex;align-items:center}.monaco-editor{padding-top:10px}.session-details{display:flex;justify-content:space-between;gap:8px;align-items:center}.editor-actions{display:flex;justify-content:space-around;gap:16px;align-items:center}.lang-select{background-color:transparent;border-radius:4px;border:unset;padding-block:2px;padding-inline:6px;color:#fff;cursor:pointer;font-weight:500;display:flex;justify-content:space-between;gap:2px;font-size:14px;align-items:center}button.lang-select:hover,button.lang-select:focus,button.lang-select:active,button.lang-select:visited{text-decoration:unset;outline:unset;border:unset}button.lang-select:hover,.lang-select-option:hover{background-color:#595959}.lang-select-wrapper{position:relative;width:max-content}.lang-select-dropdown{position:absolute;top:100%;right:0;z-index:10;background-color:#403d39;border-radius:5px;padding-block:5px}.lang-select-option{font-weight:400;font-size:12px;cursor:pointer;display:flex;justify-content:start;align-items:center;padding:2px 10px;margin:2px 5px;border-radius:5px}.lang-select-option svg{scale:.6}.user-message{display:flex;justify-content:flex-start;align-items:flex-end;gap:.75rem;margin-bottom:1rem;max-width:85%;animation:slideInUp .3s ease-out}.message-sender{flex-direction:row-reverse;margin-left:auto}.message-sender-name{color:var(--text-muted);font-size:.75rem;font-weight:500;font-style:italic;margin-bottom:.25rem;order:2}.message-content{padding:.25rem .5rem;max-width:75%;background:#282c34cc;border-radius:6px;border:1px solid rgba(255,255,255,.1);color:var(--text-primary);font-size:.875rem;line-height:1.4;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;word-wrap:break-word;position:relative;text-align:right}.message-text{display:flex;flex-direction:column-reverse;align-items:end;text-wrap:wrap}.message-content:hover{background:#32363ee6;border-color:#ffffff26}.message-sender-content{background:#1e272ee6!important;border-color:#4a90e24d!important}.message-sender-content:hover{background:#192229f2!important;border-color:#4a90e266!important}.manage-user-name-role{display:flex;justify-content:start;align-items:center;gap:5px}.manage-user-role-dropdown,.manage-user-role-update-btn{background-color:transparent;border:none;border-radius:50px;padding:5px 10px;gap:.5rem;width:fit-content;font-size:14px;font-weight:600;display:flex;justify-content:center;align-items:center}.manage-user-name{color:#7f7f7f;font-size:14px;font-weight:600}.manage-user-role-update-btn{cursor:pointer}.manage-user-role-update-btn:hover{background-color:#4a90e233}.role-manager-title{display:flex;align-items:center;justify-content:center;gap:5px;margin-bottom:10px;font-weight:600}.avatar-role-manager{position:relative}.custom-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:none;border-radius:6px;cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;-webkit-user-select:none;user-select:none;outline:none}.custom-btn--primary{background:linear-gradient(135deg,#4a90e2,#2c5282);color:#fff;box-shadow:0 4px 15px #4a90e266}.custom-btn--primary:hover:not(.custom-btn--disabled){transform:translateY(-2px);box-shadow:0 8px 25px #4a90e299}.custom-btn--secondary{background:transparent;color:#4a90e2;border:2px solid #4a90e2}.custom-btn--secondary:hover:not(.custom-btn--disabled){background:#4a90e2;color:#fff;transform:translateY(-2px)}.custom-btn--success{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;box-shadow:0 4px 15px #4caf5066}.custom-btn--success:hover:not(.custom-btn--disabled){transform:translateY(-2px);box-shadow:0 8px 25px #4caf5099}.custom-btn--error{background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff;box-shadow:0 4px 15px #f4433666}.custom-btn--error:hover:not(.custom-btn--disabled){transform:translateY(-2px);box-shadow:0 8px 25px #f4433699}.custom-btn--warning{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;box-shadow:0 4px 15px #ff980066}.custom-btn--warning:hover:not(.custom-btn--disabled){transform:translateY(-2px);box-shadow:0 8px 25px #ff980099}.custom-btn--small{padding:.5rem 1rem;font-size:.875rem;min-height:36px}.custom-btn--medium{padding:.75rem 1.5rem;font-size:1rem;min-height:44px}.custom-btn--large{padding:1rem 2rem;font-size:1.125rem;min-height:52px}.custom-btn--disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.custom-btn__icon,.custom-btn__text{display:inline-flex;align-items:center}.custom-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.custom-btn:active:not(.custom-btn--disabled):before{width:300px;height:300px}.custom-btn:focus-visible{outline:2px solid #4a90e2;outline-offset:2px}.custom-btn--loading{pointer-events:none}.custom-btn--loading .custom-btn__text{opacity:.7}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.custom-btn__icon--spinning{animation:spin 1s linear infinite}.custom-input-wrapper{width:100%;margin-bottom:.5rem}.custom-input{position:relative;width:100%;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.custom-input--focused{border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.custom-input--error{border-color:#f44336}.custom-input--error.custom-input--focused{box-shadow:0 0 0 3px #f443361a}.custom-input--disabled{opacity:.6;cursor:not-allowed}.custom-input__field{width:100%;border:none;outline:none;background:transparent;color:#ffffffe6;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:500;border-radius:12px;transition:all .3s ease}.custom-input__field::placeholder{color:#ffffff80}.custom-input__field:disabled{cursor:not-allowed}.custom-input--small .custom-input__field{padding:.75rem 1rem;font-size:.875rem;min-height:20px}.custom-input--medium .custom-input__field{padding:1rem 1.25rem;font-size:1rem;min-height:24px}.custom-input--large .custom-input__field{padding:1.25rem 1.5rem;font-size:1.125rem;min-height:28px}.custom-input__label{position:absolute;left:1.25rem;color:#ffffffb3;font-size:1rem;font-weight:500;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);background:#1a1a1acc;padding:0 .5rem;border-radius:4px}.custom-input--medium .custom-input__label{top:50%;transform:translateY(-50%)}.custom-input--small .custom-input__label{top:50%;transform:translateY(-50%);font-size:.875rem;left:1rem}.custom-input--large .custom-input__label{top:50%;transform:translateY(-50%);font-size:1.125rem;left:1.5rem}.custom-input__label--floating{top:0;transform:translateY(-50%);font-size:.875rem!important;color:#4a90e2}.custom-input--error .custom-input__label--floating{color:#f44336}.custom-input__helper{margin-top:.5rem;padding-left:1rem;font-size:.875rem;color:#fff9;font-weight:500}.custom-input__helper--error{color:#f44336}.custom-input__field:-webkit-autofill,.custom-input__field:-webkit-autofill:hover,.custom-input__field:-webkit-autofill:focus{-webkit-text-fill-color:rgba(255,255,255,.9);-webkit-box-shadow:0 0 0px 1000px rgba(255,255,255,.05) inset;transition:background-color 5000s ease-in-out 0s}.custom-checkbox-wrapper{display:inline-flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:500;color:#ffffffe6;transition:all .3s ease}.custom-checkbox-wrapper:hover:not(.custom-checkbox-wrapper--disabled){color:#fff}.custom-checkbox-wrapper--disabled{opacity:.6;cursor:not-allowed}.custom-checkbox__input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.custom-checkbox__checkmark{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:#ffffff0d;border:2px solid rgba(255,255,255,.3);border-radius:6px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.custom-checkbox__icon{width:12px;height:12px;color:#fff;opacity:0;transform:scale(.5);transition:all .3s cubic-bezier(.4,0,.2,1)}.custom-checkbox__input:checked+.custom-checkbox__checkmark{background:linear-gradient(135deg,#4a90e2,#2c5282);border-color:#4a90e2;box-shadow:0 4px 15px #4a90e266}.custom-checkbox__input:checked+.custom-checkbox__checkmark .custom-checkbox__icon{opacity:1;transform:scale(1)}.custom-checkbox-wrapper:hover:not(.custom-checkbox-wrapper--disabled) .custom-checkbox__checkmark{border-color:#4a90e2;background:#4a90e21a}.custom-checkbox__input:focus+.custom-checkbox__checkmark{outline:2px solid #4a90e2;outline-offset:2px}.custom-checkbox__label{font-size:1rem;line-height:1.5}.custom-checkbox__checkmark:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#4a90e24d;transform:translate(-50%,-50%);transition:width .3s,height .3s}.custom-checkbox__input:active+.custom-checkbox__checkmark:before{width:40px;height:40px}/**
 * Copyright (c) 2014 The xterm.js authors. All rights reserved.
 * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
 * https://github.com/chjj/term.js
 * @license MIT
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 *
 * Originally forked from (with the author's permission):
 *   Fabrice Bellard's javascript vt100 for jslinux:
 *   http://bellard.org/jslinux/
 *   Copyright (c) 2011 Fabrice Bellard
 *   The original design remains. The terminal itself
 *   has been extended to include xterm CSI codes, among
 *   other features.
 */.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{padding:0;border:0;margin:0;position:absolute;opacity:0;left:-9999em;top:0;width:0;height:0;z-index:-5;white-space:nowrap;overflow:hidden;resize:none}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;overflow-y:scroll;cursor:default;position:absolute;right:0;left:0;top:0;bottom:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;left:0;top:0}.xterm .xterm-scroll-area{visibility:hidden}.xterm-char-measure-element{display:inline-block;visibility:hidden;position:absolute;top:0;left:-9999em;line-height:normal}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility,.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .live-region{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{text-decoration:double underline}.xterm-underline-3{text-decoration:wavy underline}.xterm-underline-4{text-decoration:dotted underline}.xterm-underline-5{text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{text-decoration:overline double underline}.xterm-overline.xterm-underline-3{text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;position:absolute;top:0;right:0;pointer-events:none}.xterm-decoration-top{z-index:2;position:relative}
