*{box-sizing:border-box}html,body{margin:0;padding:0;overflow-x:hidden;overflow-y:auto}.app{min-height:100vh;width:100%;overflow-x:hidden;overflow-y:auto}.app.loading{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem}.spinner{width:40px;height:40px;border:4px solid rgba(102,126,234,.1);border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.app.unauthenticated{display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,var(--yale-blue) 0%,var(--baltic-blue) 100%)}.login-container{text-align:center;max-width:500px;padding:3rem 2rem;background:#ffffff0d;border-radius:16px;border:1px solid rgba(68,252,235,.2);box-shadow:0 8px 32px #0000004d}.login-title{font-size:2.5rem;margin-bottom:.5rem;color:var(--neon-ice);display:flex;align-items:center;justify-content:center;gap:1rem;font-weight:600}.login-icon{display:flex;align-items:center;width:48px;height:48px}.login-icon svg{width:100%;height:100%;stroke:var(--sky-aqua);filter:drop-shadow(0 0 12px rgba(68,252,235,.6))}.login-tagline{font-size:1.1rem;color:var(--frozen-water);margin-bottom:2rem;margin-top:-.5rem}.login-btn{background:linear-gradient(135deg,var(--sky-aqua) 0%,var(--neon-ice) 100%);color:var(--yale-blue);border:none;padding:14px 32px;font-size:1rem;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;font-weight:600;margin-top:1rem;box-shadow:0 4px 16px #13c7fd4d}.login-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #13c7fd80}.app.authenticated{display:flex;flex-direction:column;width:100%;min-height:100vh;position:relative}.app.authenticated:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:100%;height:400px;background:radial-gradient(ellipse 1000px 400px at center top,rgba(19,199,253,.35) 20%,rgba(19,199,253,.15) 50%,transparent 90%);pointer-events:none;z-index:0}.app-body{display:flex;flex:1;width:100%;margin:2rem 0 0;position:relative;gap:2rem;padding:0 2rem 0 0;z-index:1;min-height:0}.main-content{flex:1;min-height:0}.content-container{width:100%;box-sizing:border-box}.empty-state{text-align:center;padding:4rem 2rem;color:var(--frozen-water)}.empty-state h3{color:var(--sky-aqua);margin-bottom:0rem}.empty-state p{margin-top:0rem}.empty-state-icon{font-size:4rem;color:var(--sky-aqua);margin-bottom:0rem;display:block}.instance-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.flavor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;margin-top:2rem;margin-bottom:1rem}.app-footer{margin-top:4rem;padding:2rem 0 3rem;text-align:center;border-top:1px solid rgba(var(--sky-aqua-rgb, 19, 199, 253),.2);color:rgba(var(--frozen-water-rgb, 203, 223, 219),.6)}.app-footer p{margin:0 0 .75rem;font-size:.9rem}.footer-links{display:flex;justify-content:center;gap:2rem}.footer-links a{color:var(--sky-aqua);text-decoration:none;font-size:.9rem;transition:color .2s ease}.footer-links a:hover{color:var(--neon-ice);text-decoration:underline}@media (max-width: 768px){.app-body{flex-direction:column}.content-container{padding:1rem}.instance-grid{grid-template-columns:1fr}.footer-links{flex-direction:column;gap:.5rem}}.app-header{background:transparent;border:none;padding:2rem 1rem 1rem;position:relative;width:100%;display:flex;justify-content:center;box-shadow:none;z-index:1;padding-left:calc((260px + 2rem)/2)}.header-center{display:flex;flex-direction:column;align-items:center;text-align:center}.logo{margin:0;font-size:2.5rem;color:#fff;display:flex;align-items:center;gap:1rem;font-weight:700;text-shadow:0 0 20px rgba(19,199,253,.4)}.logo-icon{display:flex;align-items:center;width:48px;height:48px}.logo-icon svg{width:100%;height:100%;stroke:var(--sky-aqua);filter:drop-shadow(0 0 15px rgba(68,252,235,.8))}.tagline{color:var(--frozen-water);font-size:1rem;margin:.5rem 0 1.5rem;opacity:.8}.user-welcome-row{display:flex;align-items:center;gap:1.5rem;background:#ffffff0d;padding:.5rem 1.5rem;border-radius:50px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.welcome-text{color:#e5e7eb;font-size:.95rem}.header-actions{display:flex;align-items:center;gap:.75rem;padding-left:1.5rem;border-left:1px solid rgba(255,255,255,.1)}.mini-btn{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--frozen-water);padding:.25rem .75rem;border-radius:4px;font-size:.8rem;text-decoration:none;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.4rem}.mini-btn:hover{border-color:var(--sky-aqua);color:var(--sky-aqua);background:#13c7fd1a}.login-btn-header{background:linear-gradient(135deg,#10b98126,#05966933);border:1px solid rgba(16,185,129,.4);color:#6ee7b7;font-weight:500}.login-btn-header:hover{border-color:#10b981;color:#fff;background:linear-gradient(135deg,#10b9814d,#05966959);box-shadow:0 0 15px #10b9814d}.login-row .welcome-text{opacity:.9}.sidebar{width:260px;min-width:260px;background:#224e7180;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-left:none;border-radius:0 16px 16px 0;padding:1.5rem 0;max-height:calc(100vh - 4rem);position:sticky;top:2rem;overflow-y:auto;box-shadow:0 4px 20px #0003;align-self:flex-start}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem;padding-right:16px;padding-left:8px}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1.25rem;background:transparent;border:1px solid transparent;color:var(--frozen-water);text-align:left;cursor:pointer;transition:all .2s;font-size:1.1rem;width:100%;position:relative;font-weight:500}.nav-item:hover{background:#13c7fd1a;color:var(--neon-ice);border-color:#13c7fd33}.nav-item.active{background:linear-gradient(90deg,#13c7fd26,#13c7fd0d);color:var(--sky-aqua);border:1px solid rgba(19,199,253,.3);box-shadow:0 0 15px #13c7fd1a}.nav-item.nav-group-header{font-weight:600;opacity:.9}.nav-group{margin-bottom:.5rem}.nav-submenu{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem;padding-left:0;margin-left:0;border-left:none}.nav-subitem{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem .6rem 2.5rem;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--frozen-water);text-align:left;cursor:pointer;transition:all .2s;font-size:.9rem;width:100%;opacity:.8}.nav-subitem:hover{background:#ffffff0d;color:var(--neon-ice);opacity:1}.nav-subitem.active{background:#ffffff0d;color:var(--sky-aqua);opacity:1;font-weight:600}.logout-btn{margin-top:auto;border:1px solid rgba(255,107,107,.2);padding:.75rem 1.25rem;color:#ff6b6b;margin-top:2rem}.logout-btn:hover{background:#ff6b6b1a;color:#ff8787;border-color:#ff6b6b66}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover{background:#fff3}.sidebar-nav-title{font-size:1.6rem;font-weight:600;color:var(--neon-ice);margin-bottom:1rem;padding-left:1rem}.instance-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;transition:all .2s ease;display:flex;flex-direction:column;height:100%}.instance-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003;border-color:#13c7fd4d}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.success{background:#22c55e33;color:#22c55e}.status-badge.secondary{background:#6b728033;color:#9ca3af}.status-badge.info{background:#3b82f633;color:#3b82f6}.status-badge.danger{background:#ef444433;color:#ef4444}.created-date{font-size:.875rem;color:#9ca3af}.card-logo-section{text-align:center;margin-bottom:1.5rem}.instance-logo{width:64px;height:64px;object-fit:contain;margin-bottom:.75rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.instance-title{margin:0 0 .25rem;font-size:1.125rem;font-weight:600;color:#fff}.instance-name{margin:0;font-size:.875rem;color:#9ca3af}.card-section{margin-bottom:1.5rem}.section-label{font-size:.75rem;font-weight:700;color:#6b7280;letter-spacing:.8px;margin:0 0 .75rem}.resource-list{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.resource-item{display:flex;align-items:center;font-size:.875rem;color:#e5e7eb}.resource-item.gpu{color:#3b82f6;font-weight:600;grid-column:1 / -1}.resource-item.gpu-placeholder{grid-column:1 / -1;height:1.6rem;visibility:hidden}.access-item{margin-bottom:.75rem}.access-label{display:block;font-size:.75rem;color:#9ca3af;margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.5px}.console-link{display:inline-block;padding:.5rem 1rem;background:#13c7fd1a;border:1px solid rgba(19,199,253,.3);border-radius:6px;color:#13c7fd;text-decoration:none;font-size:.875rem;font-weight:600;transition:all .2s ease}.console-link:hover{background:#13c7fd33;transform:translate(2px)}.cost-section{padding-top:1rem;border-top:1px solid rgba(255,255,255,.1);text-align:center}.cost-display{font-size:1.25rem;color:#9ca3af}.cost-display.running{color:#3b82f6;font-size:1.5rem}.cost-display.running strong{font-weight:700}.cost-display.stopped{color:#9ca3af;font-size:1.125rem}.cost-label{font-size:.75rem;color:#6b7280;display:block;margin-top:.25rem}.instance-actions{display:flex;gap:.5rem;margin-top:auto;padding-top:1rem}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.action-btn:disabled{opacity:.6;cursor:not-allowed}.btn-icon{width:16px;height:16px}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stop-btn{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.stop-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #fbbf2466}.restart-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.restart-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.destroy-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.destroy-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.copyable-bit{position:relative;margin:.5rem 0}.copyable-label{display:block;font-size:.85rem;color:rgba(var(--frozen-water-rgb),.7);margin-bottom:.25rem;font-weight:500}.copyable-container{display:flex;align-items:center;background:#0000004d;border:1px solid rgba(var(--sky-aqua-rgb),.3);border-radius:6px;padding:.5rem .75rem;gap:.5rem;transition:all .2s ease;cursor:pointer}.copyable-container:hover{border-color:var(--sky-aqua);background:#0006}.copyable-text{flex:1;font-family:Courier New,Courier,monospace;font-size:.9rem;color:var(--frozen-water);-webkit-user-select:none;user-select:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.copy-button{background:transparent;border:none;color:var(--sky-aqua);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;flex-shrink:0}.copy-button:hover{background:rgba(var(--sky-aqua-rgb),.2);color:var(--neon-ice);transform:scale(1.1)}.copy-button:active{transform:scale(.95)}.copyable-container.hue-green{background:#22c55e05;border:2px solid rgba(34,197,94,.4)}.copyable-container.hue-green:hover{background:#22c55e26;border-color:#22c55e99}.copyable-container.hue-red{background:#ef44441a;border:2px solid rgba(239,68,68,.4)}.copyable-container.hue-red:hover{background:#ef444426;border-color:#ef444499}.copyable-container.hue-blue{background:#3b82f61a;border:2px solid rgba(59,130,246,.4)}.copyable-container.hue-blue:hover{background:#3b82f626;border-color:#3b82f699}.flavor-card{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:2.5rem 2rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;min-height:520px;position:relative;overflow:hidden}.flavor-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#13c7fd0d,#44fceb0d);opacity:0;transition:opacity .3s ease;pointer-events:none}.flavor-card:hover{transform:translateY(-8px);border-color:#13c7fd66;box-shadow:0 20px 40px #0000004d,0 0 0 1px #13c7fd1a inset}.flavor-card:hover:before{opacity:1}.flavor-card:active{transform:translateY(-6px)}.gpu-badge{position:absolute;top:1rem;right:1rem;display:flex;align-items:center;gap:.5rem;background:#3b82f633;border:1px solid rgba(59,130,246,.4);border-radius:20px;padding:.4rem .75rem;z-index:10}.gpu-icon{width:16px;height:16px;color:#3b82f6}.gpu-tooltip{font-size:.55rem;color:#60a5fa;font-weight:600;letter-spacing:.4px;text-transform:uppercase}.flavor-icon-container{display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;height:90px}.flavor-icon-emoji{font-size:4.5rem;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4));transition:transform .3s ease}.flavor-icon-image{width:85px;height:85px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4));transition:transform .3s cubic-bezier(.4,0,.2,1)}.flavor-card:hover .flavor-icon-image,.flavor-card:hover .flavor-icon-emoji{transform:scale(1.15) translateY(-4px)}.flavor-title{color:#fff;font-size:1.5rem;font-weight:700;margin:0 0 .75rem;letter-spacing:.3px;line-height:1.3;text-align:center}.flavor-description{color:#d1d5db;font-size:.95rem;line-height:1.6;margin:0 0 1.5rem;text-align:center}.flavor-features{list-style:none;padding:0;margin:0 0 2rem;width:100%;flex-grow:1}.flavor-features li{color:#e5e7eb;font-size:.9rem;line-height:1.6;padding:.5rem 0 .5rem 1.75rem;position:relative;text-align:left}.flavor-features li:before{content:"✓";position:absolute;left:0;color:#13c7fd;font-weight:700;font-size:1rem}.flavor-button{background:#13c7fd26;color:#13c7fd;border:1px solid rgba(19,199,253,.3);padding:.875rem 2rem;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:auto;width:100%}.flavor-button:hover{background:#13c7fd40;border-color:#13c7fd80;transform:translateY(-1px)}.flavor-button:active{transform:translateY(0)}@media (max-width: 768px){.flavor-card{min-height:480px;padding:2rem 1.5rem}.flavor-icon-container{height:70px;margin-bottom:1.25rem}.flavor-icon-image{width:70px;height:70px}.flavor-icon-emoji{font-size:3.5rem}.flavor-title{font-size:1.35rem}.flavor-description{font-size:.9rem;margin-bottom:1.25rem}.flavor-features{margin-bottom:1.5rem}.flavor-features li{font-size:.85rem;padding:.4rem 0}.flavor-button{padding:.75rem 1.5rem;font-size:.9rem}.gpu-badge{top:.75rem;right:.75rem;padding:.35rem .65rem}.gpu-tooltip{font-size:.7rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;overflow-y:auto;z-index:9999;animation:fadeIn .2s ease-out;min-height:100%;box-sizing:border-box}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:linear-gradient(135deg,#0f2332f2,#051928fa);border:1px solid rgba(19,199,253,.3);border-radius:12px;max-width:1200px;width:90%;max-height:calc(100vh - 4rem);margin:auto;overflow-y:auto;box-shadow:0 20px 60px #000000b3;animation:slideUp .3s ease-out;flex-shrink:0}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid rgba(var(--sky-aqua-rgb, 19, 199, 253),.3)}.modal-header h2{margin:0;color:var(--sky-aqua);font-size:1.5rem}.modal-close{background:none;border:none;color:var(--frozen-water);font-size:2rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.modal-close:hover{background-color:#ffffff1a;color:var(--neon-ice)}.modal-body{padding:2rem;color:var(--frozen-water)}.form-section{margin-bottom:1.5rem;padding:1rem;background:#0006;border-radius:8px}.form-section h3{color:var(--sky-aqua);margin-top:0;margin-bottom:1rem}.modal-footer{display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:1.5rem 2rem;border-top:1px solid rgba(var(--sky-aqua-rgb, 19, 199, 253),.3);background:linear-gradient(135deg,#0003,#0000001a)}.cost-summary{flex:1;display:flex;flex-direction:column;gap:.5rem}.total-cost{display:flex;align-items:baseline;gap:.75rem}.cost-label{color:var(--frozen-water);font-size:1rem;font-weight:500}.cost-value{font-size:1.8rem;font-weight:700;background:#00c562;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cost-breakdown{display:flex;gap:1.5rem;flex-wrap:wrap}.breakdown-item{font-size:.9rem;color:rgba(var(--frozen-water-rgb, 203, 223, 219),.8);padding:.25rem .75rem;background:#ffffff0d;border-radius:4px;border-left:2px solid var(--sky-aqua)}.breakdown-item.gpu-cost{border-left-color:var(--neon-ice);color:var(--neon-ice);font-weight:600}.cost-disclaimer{margin-top:.75rem;margin-bottom:0;font-size:.85rem;color:rgba(var(--frozen-water-rgb, 203, 223, 219),.7);font-style:italic;line-height:1.5}.public-ipv4-row{display:flex;align-items:center;gap:1.5rem}.inline-question{margin:0;font-size:1.2rem;color:var(--sky-aqua);margin-bottom:0!important}.toggle-container{display:inline-flex;background:#0000004d;border-radius:8px;padding:4px;gap:4px}.toggle-option{padding:.75rem 2rem;background:transparent;border:none;color:var(--frozen-water);font-size:1rem;font-weight:600;cursor:pointer;border-radius:6px;transition:all .3s ease;min-width:80px}.toggle-option:hover{background:#ffffff1a}.toggle-option.active{background:linear-gradient(135deg,var(--sky-aqua) 0%,var(--neon-ice) 100%);color:var(--yale-blue);box-shadow:none}.modal-actions{display:flex;gap:1rem}.modal-footer button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-cancel{background-color:#ffffff1a;color:var(--frozen-water)}.btn-cancel:hover{background-color:#fff3}.btn-create{background:linear-gradient(135deg,var(--sky-aqua) 0%,var(--neon-ice) 100%);color:var(--yale-blue);box-shadow:0 4px 12px rgba(var(--sky-aqua-rgb, 19, 199, 253),.3);display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-create .spinner{width:16px;height:16px;border:2px solid rgba(34,78,113,.3);border-top:2px solid var(--yale-blue);margin-bottom:0}.btn-create:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(var(--neon-ice-rgb, 68, 252, 235),.4)}.modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--frozen-water)}.modal-loading .spinner{margin-bottom:1rem}.tier-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.tier-card{padding:1.5rem;background:#ffffff0d;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all 2s ease;text-align:center}.tier-card h4{margin:0 0 .5rem;color:var(--frozen-water);font-size:1.1rem}.tier-card p{margin:0;color:rgba(var(--frozen-water-rgb, 203, 223, 219),.7);font-size:.9rem}.tier-card:hover{background:#ffffff1a;border-color:var(--sky-aqua)}.tier-card.selected{background:linear-gradient(135deg,rgba(var(--sky-aqua-rgb, 19, 199, 253),.15),rgba(var(--neon-ice-rgb, 68, 252, 235),.08));border-color:var(--sky-aqua);box-shadow:none}.tier-card.selected h4{color:var(--neon-ice)}.gpu-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.gpu-card{padding:1rem;background:#ffffff0d;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all 2s ease;text-align:center}.gpu-card h4{margin:0;color:var(--frozen-water);font-size:.95rem}.gpu-card:hover{background:#ffffff1a;border-color:var(--sky-aqua)}.gpu-card.selected{background:linear-gradient(135deg,rgba(var(--sky-aqua-rgb, 19, 199, 253),.15),rgba(var(--neon-ice-rgb, 68, 252, 235),.08));border-color:var(--sky-aqua);box-shadow:none}.gpu-card.selected h4{color:var(--neon-ice)}.form-range{width:100%;height:10px;background:var(--sky-aqua);border-radius:5px;outline:none;transition:background .2s ease}.form-range::-webkit-slider-thumb{width:20px;height:20px;background:var(--neon-ice)}.ssh-key-section{margin-bottom:1.5rem;padding:1rem;background:#0003;border-radius:8px}.ssh-key-section textarea{width:100%;height:40px;padding:.5rem;background:#13c7fd14;border:1px solid rgba(19,199,253,.35);color:var(--frozen-water);border-radius:6px}.ssh-key-valid{color:green;font-size:.9rem;font-weight:600}.ssh-key-invalid{color:red;font-size:.9rem;font-weight:600}.billing-summary-container{max-width:1200px;margin:0 auto;padding:2rem}.billing-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden}.billing-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid rgba(255,255,255,.1)}.billing-header h3{margin:0;color:var(--frozen-water);font-size:1.25rem;display:flex;align-items:center;gap:.75rem}.billing-header .icon{width:24px;height:24px;color:#7c3aed;stroke-width:2}.refresh-btn{display:flex;align-items:center;gap:.5rem;background:transparent;border:1px solid rgba(var(--sky-aqua-rgb, 19, 199, 253),.5);color:var(--sky-aqua);padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s;font-size:.9rem}.refresh-btn:hover:not(:disabled){background:rgba(var(--sky-aqua-rgb, 19, 199, 253),.1);border-color:var(--sky-aqua)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.refresh-icon{width:16px;height:16px;stroke-width:2}.refresh-icon.spinning{animation:spin 1s linear infinite}.billing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:2rem}.metric{text-align:center;padding:0 1rem}.metric:not(:last-child){border-right:1px solid rgba(255,255,255,.1)}.metric-label{margin:0 0 .75rem;color:rgba(var(--frozen-water-rgb, 203, 223, 219),.7);font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.metric-value{margin:0;color:var(--frozen-water);font-size:1.75rem;font-weight:600}.metric-note{display:block;margin-top:.25rem;color:rgba(var(--frozen-water-rgb, 203, 223, 219),.6);font-size:.75rem}.billing-footer{display:flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:#0003;border-top:1px solid rgba(255,255,255,.1);color:rgba(var(--frozen-water-rgb, 203, 223, 219),.8);font-size:.875rem}.info-icon{width:16px;height:16px;flex-shrink:0;stroke-width:2;color:var(--sky-aqua)}.loading,.error{text-align:center;padding:3rem 2rem;color:var(--frozen-water)}.loading{display:flex;flex-direction:column;align-items:center;gap:1rem}.error{background:#ff44441a;border:1px solid rgba(255,68,68,.3);border-radius:8px;color:#f44}@media (max-width: 1024px){.billing-grid{grid-template-columns:repeat(2,1fr);gap:2rem 0}.metric{border-right:none!important;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1.5rem}.metric:nth-child(odd){border-right:1px solid rgba(255,255,255,.1)!important}.metric:nth-last-child(-n+2){border-bottom:none;padding-bottom:0}}@media (max-width: 640px){.billing-summary-container{padding:1rem}.billing-header{flex-direction:column;gap:1rem;align-items:stretch}.billing-header h3{font-size:1.1rem}.refresh-btn{width:100%;justify-content:center}.refresh-text{display:inline}.billing-grid{grid-template-columns:1fr;gap:1.5rem;padding:1.5rem}.metric{border-right:none!important;border-bottom:1px solid rgba(255,255,255,.1);padding:0 0 1.5rem}.metric:last-child{border-bottom:none;padding-bottom:0}.metric-value{font-size:1.5rem}.billing-footer{flex-direction:column;text-align:center;padding:1rem}}.credits-card{margin-top:2rem;border-width:2px;transition:all .3s ease}.credits-card.has-credits{border-color:#22c55e66;background:linear-gradient(135deg,#22c55e0d,#10b9810d)}.credits-card.no-credits{border-color:#ef444466;background:linear-gradient(135deg,#ef44440d,#dc26260d)}.credits-card.has-credits .billing-header .icon{color:#22c55e}.credits-card.no-credits .billing-header .icon{color:#ef4444}.credits-content{padding:2rem;text-align:center}.credits-amount{display:flex;flex-direction:column;align-items:center;margin-bottom:1.5rem}.credits-value{font-size:3rem;font-weight:700;line-height:1;margin-bottom:.5rem}.credits-card.has-credits .credits-value{background:linear-gradient(135deg,#22c55e,#10b981);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.credits-card.no-credits .credits-value{background:linear-gradient(135deg,#ef4444,#dc2626);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.credits-label{font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(var(--frozen-water-rgb, 203, 223, 219),.6)}.credits-message{font-size:1rem;line-height:1.6;max-width:600px;margin:0 auto}.credits-card.has-credits .credits-message{color:#22c55ee6}.credits-card.no-credits .credits-message{color:#ef4444e6}.credits-hours{color:#22c55ee6;font-weight:600}.payment-cards-container{max-width:1200px;margin:0 auto;padding:2rem}.payment-cards-container h2{margin-bottom:1.5rem;color:var(--frozen-water)}.loading{text-align:center;padding:2rem;color:var(--frozen-water);display:flex;flex-direction:column;align-items:center;gap:1rem}.loading .spinner{width:40px;height:40px;border:4px solid rgba(102,126,234,.1);border-top:4px solid var(--sky-aqua);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading p{margin:0;color:var(--frozen-water)}.no-payment-method{margin:2rem 0}.alert{padding:1.5rem;border-radius:8px;margin-bottom:1rem}.alert-info{background:rgba(var(--sky-aqua-rgb, 19, 199, 253),.1);border:1px solid rgba(var(--sky-aqua-rgb, 19, 199, 253),.3);color:var(--frozen-water)}.alert h5{margin:0 0 .5rem;color:var(--sky-aqua)}.alert p{margin:0}.btn-add-card{background:linear-gradient(135deg,var(--sky-aqua) 0%,var(--neon-ice) 100%);color:var(--yale-blue);border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s}.btn-add-card:hover:not(:disabled){transform:translateY(-2px)}.btn-add-card:disabled{opacity:.6;cursor:not-allowed}.payment-method-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-left:4px solid #28a745;border-radius:8px;padding:1.5rem;margin:2rem 0}.payment-method-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.check-icon{width:40px;height:40px;border-radius:50%;background:#28a745;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}.payment-method-info h4{margin:0 0 .5rem;color:var(--frozen-water)}.card-details{margin:.25rem 0;color:var(--frozen-water)}.card-expiry{margin:.25rem 0;color:rgba(var(--frozen-water-rgb, 203, 223, 219),.7);font-size:.9rem}.payment-method-actions{display:flex;gap:1rem}.btn-update-card,.btn-delete-card{padding:.5rem 1rem;border-radius:6px;border:none;font-weight:600;cursor:pointer;transition:all .2s}.btn-update-card{background:linear-gradient(135deg,var(--sky-aqua) 0%,var(--neon-ice) 100%);color:var(--yale-blue)}.btn-update-card:hover{transform:translateY(-1px)}.btn-delete-card{background:linear-gradient(135deg,#f44,#c00);color:#fff}.btn-delete-card:hover:not(:disabled){transform:translateY(-1px)}.btn-delete-card:disabled{opacity:.6;cursor:not-allowed}.add-card-form{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1.5rem;margin:2rem 0}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.form-header h4{margin:0;color:var(--frozen-water)}.btn-cancel{background:#ffffff1a;color:var(--frozen-water);border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:background .2s}.btn-cancel:hover:not(:disabled){background:#fff3}#payment-element{margin-bottom:1.5rem;padding:1rem;background:#0003;border-radius:8px}.btn-submit{width:100%;background:linear-gradient(135deg,var(--sky-aqua) 0%,var(--neon-ice) 100%);color:var(--yale-blue);border:none;padding:.75rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s}.btn-submit:hover:not(:disabled){transform:translateY(-2px)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.trial-info{background:rgba(var(--sky-aqua-rgb, 19, 199, 253),.1);border:1px solid rgba(var(--sky-aqua-rgb, 19, 199, 253),.3);border-radius:8px;padding:1.5rem;margin:2rem 0}.trial-info h5{margin:0 0 1rem;color:var(--sky-aqua)}.trial-info ul{margin:0;padding-left:1.5rem;color:var(--frozen-water)}.trial-info li{margin-bottom:.5rem}@media (max-width: 768px){.payment-cards-container{padding:1rem}.payment-method-actions{flex-direction:column}.btn-update-card,.btn-delete-card{width:100%}}.api-key-container{max-width:800px;margin:0 auto}.api-key-container h2{color:var(--sky-aqua);margin-bottom:1.5rem;font-size:1.8rem}.api-key-content{margin-bottom:2rem;padding:1.5rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(var(--sky-aqua-rgb, 19, 199, 253),.2)}.api-key-content p{color:var(--frozen-water);margin-bottom:1rem;line-height:1.6}.api-key-content h5{color:var(--frozen-water);font-size:1rem;font-weight:600;margin-bottom:1.5rem}.api-key-value{display:inline-block;padding:.5rem 1rem;background:linear-gradient(135deg,#22c55e14,#10b98114);border:1px solid rgba(34,197,94,.3);border-radius:6px;color:#22c55e;font-family:Courier New,monospace;font-size:.95rem;font-weight:600;letter-spacing:.5px}.api-key-actions{display:flex;gap:1rem;flex-wrap:wrap}.api-key-actions button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.btn-icon{width:18px;height:18px}.btn-generate{background:linear-gradient(135deg,var(--sky-aqua) 0%,var(--neon-ice) 100%);color:var(--yale-blue);box-shadow:0 4px 12px rgba(var(--sky-aqua-rgb, 19, 199, 253),.3)}.btn-generate:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(var(--neon-ice-rgb, 68, 252, 235),.4)}.btn-delete{background-color:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.4)}.btn-delete:hover{background-color:#ef44444d;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.shell-toggle{display:flex;gap:1rem;margin-bottom:1rem}.shell-toggle button{padding:.5rem 1rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .2s ease}.shell-toggle button.active{background-color:var(--sky-aqua);color:var(--yale-blue)}.buy-credits-container{max-width:800px;margin:0 auto;padding:2rem}.buy-credits-container h2{color:var(--sky-aqua);margin-bottom:2rem;text-align:center}.credit-input-section{text-align:center;margin-bottom:2rem}.credit-input-section label{display:block;font-size:.9rem;color:var(--frozen-water);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:1px}.credit-input{width:100%;max-width:300px;font-size:3rem;font-weight:700;text-align:center;padding:1rem;background:#ffffff0d;border:2px solid rgba(255,255,255,.2);border-radius:12px;color:var(--frozen-water);transition:all .3s ease}.credit-input:focus{outline:none;background:#ffffff14}.credits-explainer{text-align:center;color:rgba(var(--frozen-water-rgb),.8);margin-bottom:2rem;font-size:1rem}.credit-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.summary-item{padding:1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;text-align:center}.summary-item.discount-item{border-width:2px;transition:all .3s ease}.summary-item.aws-comparison{border-width:2px;background:linear-gradient(135deg,#22c55e1f,#10b9811f);border-color:#22c55e80}.summary-label{display:block;font-size:.8rem;color:rgba(var(--frozen-water-rgb),.7);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.summary-value{display:block;font-size:1.5rem;font-weight:700;color:var(--frozen-water)}.summary-value.cost{color:var(--sky-aqua)}.discount-info{text-align:center;font-size:.9rem;color:rgba(var(--frozen-water-rgb),.7);margin-bottom:2rem;line-height:1.6}.btn-coming-soon{display:block;width:100%;padding:1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:rgba(var(--frozen-water-rgb),.5);font-size:1rem;font-weight:600;cursor:not-allowed}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:8px;box-shadow:0 4px 12px #0000004d,0 2px 6px #0003;font-size:.95rem;font-weight:600;min-width:250px;max-width:400px;pointer-events:all;cursor:pointer;animation:slideInRight .3s ease,fadeOut .3s ease 2.7s;transition:transform .2s ease}.toast:hover{transform:translate(-4px)}.toast-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:1rem;flex-shrink:0}.toast-message{flex:1}.toast-success{background:linear-gradient(135deg,var(--sky-aqua) 0%,var(--neon-ice) 100%);color:var(--yale-blue)}.toast-success .toast-icon{background:rgba(var(--yale-blue-rgb),.2);color:var(--yale-blue)}.toast-error{background:linear-gradient(135deg,#ff444459,#cc000059);color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toast-error .toast-icon{background:#fff3;color:#fff}.toast-info{background:linear-gradient(135deg,var(--baltic-blue) 0%,var(--yale-blue) 100%);color:var(--frozen-water);border:1px solid rgba(var(--sky-aqua-rgb),.4)}.toast-info .toast-icon{background:rgba(var(--sky-aqua-rgb),.2);color:var(--sky-aqua)}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes fadeOut{to{opacity:0}}.banner{background:linear-gradient(135deg,#13c7fd26,#44fceb1a);border:1px solid rgba(19,199,253,.3);border-left:4px solid var(--sky-aqua);border-radius:8px;padding:1rem 1.5rem;margin-bottom:2rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);box-shadow:0 4px 12px #0000001a}.banner-trial{border-left-color:#10b981;background:linear-gradient(135deg,#10b98126,#0596691a);border-color:#10b9814d}.banner-payment-required{border-left-color:#f59e0b;background:linear-gradient(135deg,#f59e0b26,#d977061a);border-color:#f59e0b4d}.banner-content{display:flex;align-items:center;gap:1rem;width:100%}.banner-icon{font-size:1.5rem;color:var(--sky-aqua);flex-shrink:0}.banner-trial .banner-icon{color:#10b981}.banner-payment-required .banner-icon{color:#f59e0b}.banner-text{flex:1;display:flex;flex-direction:column;gap:.25rem}.banner-text strong{color:var(--neon-ice);font-size:1rem;font-weight:600}.banner-trial .banner-text strong{color:#6ee7b7}.banner-payment-required .banner-text strong{color:#fbbf24}.banner-text span{color:var(--frozen-water);font-size:.875rem;opacity:.9}.banner-button{padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;flex-shrink:0;border:none}.banner-button-primary{background:linear-gradient(135deg,#10b98133,#05966940);border:1px solid rgba(16,185,129,.4);color:#6ee7b7}.banner-button-primary:hover{border-color:#10b981;color:#fff;background:linear-gradient(135deg,#10b9814d,#05966959);box-shadow:0 0 15px #10b9814d;transform:translateY(-1px)}.banner-payment-required .banner-button-primary{background:linear-gradient(135deg,#f59e0b33,#d9770640);border-color:#f59e0b66;color:#fbbf24}.banner-payment-required .banner-button-primary:hover{border-color:#f59e0b;background:linear-gradient(135deg,#f59e0b4d,#d9770659);box-shadow:0 0 15px #f59e0b4d}.banner-button i{font-size:1rem}@media (max-width: 768px){.banner-content{flex-direction:column;align-items:flex-start}.banner-button{width:100%;justify-content:center}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--yale-blue: #224E71;--neon-ice: #44FCEB;--baltic-blue: #005387;--sky-aqua: #13C7FD;--frozen-water: #CBDFDB;color-scheme:dark;color:#ffffffde;background-color:#0a0f1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-width:320px;min-height:100vh;overflow-x:hidden;overflow-y:auto}#root{width:100%;min-height:100vh;margin:0;padding:0}
