@import url(https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700;800;900&family=Geist+Mono:wght@400;500;600&display=swap);@import url(https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800&family=DM+Sans:wght@400;500;600&display=swap);@import url(https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap);:root{--brand-primary:#0085c9;--brand-secondary:#36bee5;--brand-dark-1:#0d3f72;--brand-dark-2:#13599f;--brand-mid-1:#1872cd;--brand-mid-2:#318ce7;--brand-light-1:#5fa5ec;--brand-light-2:#8cbff2;--brand-light-3:#bad9f7;--cloud-bg:#06101e;--cloud-surface:#0a1929;--cloud-surface-2:#0d2040;--cloud-surface-3:#102650;--cloud-border:#0085c91f;--cloud-border-2:#0085c938;--accent:#0085c9;--accent-bright:#36bee5;--accent-dim:#0085c926;--accent-glow:#0085c966;--text-primary:#f0f7ff;--text-secondary:#8cbff2;--text-muted:#4a7499;--text-accent:#36bee5;--shadow-sm:0 1px 3px #00000080;--shadow-md:0 4px 16px #0009;--shadow-lg:0 8px 40px #000000b3;--shadow-accent:0 0 0 3px #0085c94d;--shadow-brand:0 4px 24px #0085c959;--success:#10b981;--success-dim:#10b98126;--warning:#f59e0b;--warning-dim:#f59e0b26;--danger:#ef4444;--danger-dim:#ef444426;--info:#318ce7;--info-dim:#318ce726;--primary-blue:#0085c9;--primary-light-blue:#36bee5;--secondary-dark-blue:#0a1929;--secondary-blue-1:#0085c9;--secondary-blue-2:#13599f;--secondary-blue-3:#318ce7;--secondary-blue-4:#5fa5ec;--secondary-blue-5:#bad9f7;--secondary-blue-6:#8cbff2;--neutral-white:#fff;--neutral-black:#000;--gradient-primary:linear-gradient(135deg,#0085c9,#0d3f72);--gradient-secondary:linear-gradient(135deg,#0a1929,#0085c9);--gradient-brand:linear-gradient(135deg,#0085c9,#36bee5);--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--transition:0.18s cubic-bezier(0.4,0,0.2,1)}[data-theme=light]{--cloud-bg:#f0f7ff;--cloud-surface:#fff;--cloud-surface-2:#eaf4fc;--cloud-surface-3:#d6ecfa;--cloud-border:#0085c926;--cloud-border-2:#0085c947;--accent:#0085c9;--accent-bright:#1872cd;--accent-dim:#0085c91a;--accent-glow:#0085c940;--text-primary:#000;--text-secondary:#13599f;--text-muted:#5fa5ec;--text-accent:#0085c9;--shadow-sm:0 1px 3px #0055a01a;--shadow-md:0 4px 16px #0055a021;--shadow-lg:0 8px 40px #0055a02e;--shadow-accent:0 0 0 3px #0085c933;--shadow-brand:0 4px 24px #0085c933;--gradient-primary:linear-gradient(135deg,#0085c9,#36bee5);--gradient-secondary:linear-gradient(135deg,#eaf4fc,#bad9f7);--gradient-brand:linear-gradient(135deg,#0085c9,#36bee5);--secondary-dark-blue:#fff;--secondary-blue-5:#eaf4fc;--secondary-blue-6:#d6ecfa}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#06101e;background:var(--cloud-bg);color:#f0f7ff;color:var(--text-primary);font-family:Geist,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;min-height:100vh;transition:background .3s ease,color .3s ease}.mono,code,pre{font-family:Geist Mono,JetBrains Mono,Fira Code,monospace}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}::selection{background:#0085c926;background:var(--accent-dim);color:#f0f7ff;color:var(--text-primary)}.cloud-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a1929;background:var(--cloud-surface);border:1px solid #0085c91f;border:1px solid var(--cloud-border);border-radius:12px;border-radius:var(--radius-lg)}.cloud-badge{align-items:center;border-radius:20px;display:inline-flex;font-family:Geist Mono,monospace;font-size:11px;font-weight:600;gap:5px;letter-spacing:.4px;padding:3px 10px}.badge-active{background:#10b98126;background:var(--success-dim);border:1px solid #10b9814d;color:#10b981;color:var(--success)}.badge-stopped{background:#ffffff0d;border:1px solid #0085c91f;border:1px solid var(--cloud-border);color:#4a7499;color:var(--text-muted)}.badge-error{background:#ef444426;background:var(--danger-dim);border:1px solid #ef44444d;color:#ef4444;color:var(--danger)}.badge-pending{background:#f59e0b26;background:var(--warning-dim);border:1px solid #f59e0b4d;color:#f59e0b;color:var(--warning)}.cloud-grid-bg{background-image:linear-gradient(hsla(0,0%,100%,.025) 1px,#0000 0),linear-gradient(90deg,hsla(0,0%,100%,.025) 1px,#0000 0);background-size:40px 40px}.recharge-modal{max-width:550px;width:90%}.modal-header-content{align-items:center;display:flex;gap:12px}.modal-logo{height:40px;object-fit:contain;width:auto}.recharge-message{border-radius:var(--radius-md);font-family:Geist,sans-serif;font-size:13px;line-height:1.5;margin-bottom:16px;padding:10px 12px}.recharge-message-success{background:#10b9811a;border:1px solid #10b9814d;color:#6ee7b7}.recharge-message-error{background:var(--danger-dim);border:1px solid #ef44444d;color:#fca5a5}.recharge-message-info{background:var(--accent-dim);border:1px solid #2563eb4d;color:var(--text-accent)}.recharge-loader{padding:32px 20px;text-align:center}.spinner{animation:rechargeSpin .7s linear infinite;border:2px solid var(--cloud-border);border-top-color:var(--accent);height:36px;margin:0 auto 16px;width:36px}@keyframes rechargeSpin{to{transform:rotate(1turn)}}.recharge-loader p{color:var(--text-muted);font-family:Geist,sans-serif;font-size:13px;margin:0}.form-group input{box-sizing:border-box;padding:9px 12px}.form-group input:disabled{background:var(--cloud-surface-2);color:var(--text-muted)}.form-group input.input-error{border-color:#ef444499}.form-group input.input-error:focus{border-color:#ef444499;box-shadow:0 0 0 3px var(--danger-dim)}.form-error,.form-hint{display:block;font-size:11px;margin-top:4px}.form-error{color:#fca5a5;font-family:Geist Mono,monospace;font-weight:500}.payment-type-selector{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.payment-type-btn{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:7px;justify-content:center;padding:12px;transition:all var(--transition)}.payment-type-btn.active,.payment-type-btn:hover:not(:disabled){background:var(--accent-dim);border-color:var(--accent);color:var(--text-accent)}.payment-type-btn:disabled{cursor:not-allowed;opacity:.4}.recharge-info{background:var(--accent-dim);border:1px solid #2563eb40;border-radius:var(--radius-md);margin-bottom:16px;padding:10px 14px}.recharge-info p{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;line-height:1.6;margin:0}.modal-footer{margin:0 -24px -24px}.projects-page{background:var(--cloud-bg);background-image:linear-gradient(hsla(0,0%,100%,.018) 1px,#0000 0),linear-gradient(90deg,hsla(0,0%,100%,.018) 1px,#0000 0);background-size:48px 48px;margin:0 auto;max-width:1440px;min-height:calc(100vh - 56px);padding:28px 32px;position:relative;width:100%}.projects-page:before{content:""}.projects-background,.projects-page:before{bottom:0;left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.projects-gradient-1,.projects-gradient-2,.projects-gradient-3{animation:projectsFloat 30s ease-in-out infinite;border-radius:50%;filter:blur(130px);opacity:.12;pointer-events:none;position:absolute}.projects-gradient-1{animation-delay:0s;background:radial-gradient(circle,#2563eb 0,#0000 70%);height:600px;right:-100px;top:-300px;width:600px}.projects-gradient-2{animation-delay:10s;background:radial-gradient(circle,#6366f1 0,#0000 70%);bottom:-200px;height:500px;left:-100px;width:500px}.projects-gradient-3{animation-delay:20s;background:radial-gradient(circle,#1d4ed8 0,#0000 70%);height:450px;right:8%;top:35%;width:450px}@keyframes projectsFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.92)}}.projects-header{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);margin-bottom:28px;padding:18px 24px;position:relative;z-index:1}.header-top{align-items:center;display:flex;flex-direction:row;gap:20px;justify-content:space-between;width:100%}.header-left{gap:20px}.header-left h1{color:var(--text-primary);font-family:Geist,sans-serif;font-size:20px;font-weight:700;letter-spacing:-.02em}.header-right{gap:12px}.mapata-logo{height:48px;object-fit:contain;width:auto}.client-info{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-md);display:flex;flex-wrap:nowrap;gap:10px;padding:6px 14px}.client-email{color:var(--text-secondary);font-size:12px;font-weight:500}.client-email,.credit-balance{font-family:Geist Mono,monospace}.credit-balance{background:var(--success-dim);border:1px solid #10b9814d;border-radius:20px;color:var(--success);font-size:13px;font-weight:700;padding:4px 12px;transition:all var(--transition)}.credit-balance.clickable{cursor:pointer}.credit-balance.clickable:hover{background:#10b98138;border-color:#10b98180;box-shadow:0 2px 8px #10b98133;transform:translateY(-1px)}.node-limit{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:20px;color:var(--text-secondary);font-family:Geist Mono,monospace;font-size:12px;font-weight:500;padding:4px 12px}.header-actions{flex-direction:row}.btn-view-limits{align-items:center;background:#0000;border:1px solid var(--cloud-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:500;gap:6px;padding:7px 14px;transition:all var(--transition);white-space:nowrap}.btn-view-limits:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border-2);color:var(--text-primary)}.btn-create-project{align-items:center;background:var(--accent);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:7px 16px;transition:all var(--transition);white-space:nowrap}.btn-create-project:hover{background:#1d4ed8;box-shadow:0 4px 14px #2563eb66;transform:translateY(-1px)}.loading-state{font-family:Geist Mono,monospace;font-size:14px;padding:100px 20px}.empty-state{background:var(--cloud-surface);border-radius:var(--radius-xl);margin:32px 0;padding:72px 40px}.empty-icon{font-size:56px;margin-bottom:16px;opacity:.4}.empty-state h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.02em;margin:0 0 10px}.empty-state p{color:var(--text-muted);margin:0 0 28px}.btn-create-first{background:var(--accent);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:14px;font-weight:600;padding:10px 28px;transition:all var(--transition)}.btn-create-first:hover{background:#1d4ed8;box-shadow:0 4px 16px #2563eb66;transform:translateY(-1px)}.projects-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:24px;position:relative;z-index:1}@media (max-width:768px){.projects-grid{grid-template-columns:1fr}}.project-card{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);cursor:pointer;overflow:hidden;padding:18px;position:relative;transition:all var(--transition)}.project-card:before{background:var(--accent);content:"";height:2px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition)}.project-card:hover{background:var(--cloud-surface-2);border-color:var(--cloud-border-2);box-shadow:0 4px 20px #0006;transform:translateY(-2px)}.project-card:hover:before{opacity:1}.project-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:10px}.project-card-header h3{color:var(--text-primary);flex:1 1;font-family:Geist,sans-serif;font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}.btn-delete-project{background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-size:13px;opacity:0;padding:5px 8px;transition:all var(--transition)}.project-card:hover .btn-delete-project{opacity:1}.btn-delete-project:hover{background:var(--danger-dim);border-color:#ef44444d;color:var(--danger)}.project-description{color:var(--text-muted);font-size:12px;line-height:1.5;margin:0 0 14px}.project-stats{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-md);display:flex;gap:20px;margin:14px 0;padding:12px 14px}.stat-label{color:var(--text-muted);font-size:10px;letter-spacing:.07em}.stat-label,.stat-value{font-family:Geist Mono,monospace}.stat-value{color:var(--text-primary);font-size:20px;letter-spacing:-.02em}.project-card-footer{align-items:center;display:flex;justify-content:space-between}.project-date{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px}.btn-open-project{background:var(--accent-dim);border:1px solid #2563eb59;border-radius:var(--radius-md);color:var(--accent-bright);cursor:pointer;font-family:Geist,sans-serif;font-size:12px;font-weight:600;padding:6px 14px;transition:all var(--transition)}.btn-open-project:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-1px)}.modal-overlay{animation:modalFadeIn .15s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:modalSlideUp .2s cubic-bezier(.16,1,.3,1) both;background:var(--cloud-surface);border:1px solid var(--cloud-border-2);border-radius:var(--radius-xl);box-shadow:0 24px 64px #000c;max-width:520px;overflow:hidden;width:90%}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:18px 20px}.modal-header h2{font-size:16px;letter-spacing:-.01em}.modal-close{background:#0000;border:1px solid var(--cloud-border);color:var(--text-secondary);font-size:18px;height:30px;line-height:1;width:30px}.modal-close:hover{border-color:var(--cloud-border-2)}.modal-body{padding:20px}.form-group label{letter-spacing:.06em}.form-group input,.form-group textarea{background:var(--cloud-bg);border:1px solid var(--cloud-border-2);border-radius:var(--radius-md);color:var(--text-primary);font-family:Geist,sans-serif;padding:10px 14px;transition:all var(--transition)}.form-group input:focus,.form-group textarea:focus{background:#080c14f2;border-color:var(--accent);box-shadow:0 0 0 3px #2563eb33}.form-group textarea{min-height:100px}.modal-footer{padding:16px 20px}.btn-cancel{background:#0000;border-radius:var(--radius-md);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:500;padding:8px 18px;transition:all var(--transition)}.btn-cancel:hover{background:var(--cloud-surface-3)}.btn-create{background:var(--accent);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:8px 20px;transition:all var(--transition)}.btn-create:hover{background:#1d4ed8;box-shadow:0 4px 14px #2563eb66;transform:translateY(-1px)}.limits-section{border-top:1px solid #06b6d426;margin-top:12px;padding-top:12px}.limits-title{color:#d4d4d4;font-size:13px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.limits-grid{grid-gap:8px;gap:8px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));margin-bottom:12px}.limit-item{align-items:center;background:#0d0d0d66;border:1px solid #06b6d41a;border-radius:8px;justify-content:space-between;padding:6px 10px}.limit-type{color:#999;font-size:11px;font-weight:500;text-transform:capitalize}.limit-value{color:#10b981;font-size:12px;font-weight:700}.limit-value.limit-reached{color:#ef4444}.total-limit{align-items:center;background:#06b6d41a;border:1px solid #06b6d433;border-radius:8px;display:flex;justify-content:space-between;margin-top:8px;padding:10px 12px}.limit-label{color:#06b6d4;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.total-limit .limit-value{color:#06b6d4;font-size:16px;font-weight:700}.global-limits{background:#06b6d414;border:1px solid #06b6d433;border-radius:12px;padding:20px;width:100%}.limits-header-title{color:#f5f5f5;font-size:16px;font-weight:600;letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase}.limits-header-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.limit-header-item{align-items:center;background:#0d0d0d99;border:1px solid #06b6d426;border-radius:10px;display:flex;justify-content:space-between;padding:10px 14px;transition:all .3s}.limit-header-item:hover{background:#0d0d0dcc;border-color:#06b6d44d;transform:translateY(-2px)}.limit-header-type{color:#d4d4d4;font-size:13px;font-weight:600;text-transform:capitalize}.limit-header-value{color:#10b981;font-size:14px;font-weight:700;text-shadow:0 2px 8px #10b9814d}.limit-header-value.limit-reached{color:#ef4444;text-shadow:0 2px 8px #ef44444d}.limits-modal-content{max-height:85vh;max-width:900px;overflow-y:auto}.limits-modal-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.limit-modal-item{background:#0d0d0d99;border:1px solid #06b6d433;border-radius:12px;padding:16px;transition:all .3s}.limit-modal-item:hover{border-color:#06b6d466;box-shadow:0 4px 12px #06b6d433;transform:translateY(-2px)}.limit-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.limit-modal-type{color:#f5f5f5;font-size:16px;font-weight:600;text-transform:capitalize}.limit-modal-badge{border-radius:20px;font-size:13px;font-weight:700;padding:4px 12px}.badge-success{background:#10b98133;border:1px solid #10b98166;color:#10b981}.badge-danger{background:#ef444433;border:1px solid #ef444466;color:#ef4444}.limit-modal-progress{background:#ffffff1a;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden;width:100%}.limit-modal-progress-bar{border-radius:4px;height:100%;transition:width .5s ease,background-color .3s}.limit-modal-info{align-items:center;display:flex;justify-content:space-between}.limit-modal-remaining{color:#999;font-size:12px;font-weight:500}.custom-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:180px;padding:0;transition:box-shadow .15s,border-color .15s}.custom-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.custom-node-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);color:var(--text-primary);display:flex;font-family:Geist,sans-serif;font-size:12px;font-weight:600;gap:8px;padding:10px 12px}.custom-node-id{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:3px;color:var(--text-muted);font-family:Geist Mono,monospace;font-size:9px;letter-spacing:.02em;padding:1px 6px;width:-webkit-fit-content;width:fit-content}.node-icon{font-size:1rem}.node-title{color:var(--text-primary);flex:1 1}.custom-node-body{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;line-height:1.5;padding:10px 12px}.custom-node-body p{margin:0}.custom-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.custom-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.node-status-badge{align-items:center;animation:fadeIn .25s ease;border-radius:var(--radius-sm);display:flex;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;gap:8px;margin:6px 10px;padding:7px 10px}.status-content{flex:1 1;gap:3px}.status-step{font-size:9px;font-weight:500;line-height:1.2;opacity:.8}.status-progress-bar{background:#ffffff26;border-radius:1px;height:2px;margin-top:3px;overflow:hidden;position:relative;width:100%}.status-progress-fill{background:currentColor;border-radius:1px;height:100%;opacity:.9;transition:width .4s ease}.status-progress-text{font-size:8px;font-weight:700;opacity:.8;position:absolute;right:2px;top:-13px}.status-provisioning{background:#2563eb2e;border:1px solid #2563eb59;color:#93c5fd}.status-deleting{background:#ef444426;border:1px solid #ef44444d;color:#fca5a5}.status-creating{background:#f59e0b26;border:1px solid #f59e0b4d;color:#fcd34d}.status-failed{background:#7f1d1d4d;border:1px solid #ef444466;color:#fca5a5}.status-stopped{background:#ffffff0d;border:1px solid var(--cloud-border);color:#475569}.status-icon{font-size:.9rem}.status-label{flex:1 1;letter-spacing:.03em}.status-spinner{animation:nodeSpinCustom .7s linear infinite;border:1.5px solid #fff3;border-radius:50%;border-top-color:initial;height:12px;width:12px}@keyframes nodeSpinCustom{to{transform:rotate(1turn)}}.node-transitioning{opacity:.8}.node-ip-info{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-muted);display:flex;font-family:Geist Mono,monospace;font-size:10px;gap:6px;margin:0 10px 8px;padding:5px 10px}.ip-icon{font-size:.8rem}.ip-address{color:var(--text-secondary);letter-spacing:.03em}.input-node{background:var(--cloud-surface);border:1px solid #10b98159;border-radius:var(--radius-md);min-width:130px;padding:10px 14px;transition:box-shadow .15s,border-color .15s}.input-node:hover{border-color:#10b98199;box-shadow:0 4px 16px #10b98126}.input-node-content{align-items:center;display:flex;font-weight:600;gap:6px}.input-node-label{color:#6ee7b7;font-family:Geist,sans-serif;font-size:12px;font-weight:600}.input-node-id{border:1px solid var(--cloud-border);border-radius:3px;color:var(--text-muted);font-family:Geist Mono,monospace;font-size:9px;letter-spacing:.02em;padding:1px 5px;width:-webkit-fit-content;width:fit-content}.input-handle,.input-node-id{background:var(--cloud-surface-3)}.input-handle{border:1px solid #10b98180;border-radius:2px;height:8px;width:8px}.input-handle:hover{background:#10b98166;border-color:#10b981;transform:scale(1.3)}.output-node{background:var(--cloud-surface);border:1px solid #ef44444d;border-radius:var(--radius-md);min-width:130px;padding:10px 14px;transition:box-shadow .15s,border-color .15s}.output-node:hover{border-color:#ef44448c;box-shadow:0 4px 16px #ef44441f}.output-node-content{align-items:center;display:flex;font-weight:600;gap:6px}.output-node-label{color:#fca5a5;font-family:Geist,sans-serif;font-size:12px;font-weight:600}.output-node-id{border:1px solid var(--cloud-border);border-radius:3px;color:var(--text-muted);font-family:Geist Mono,monospace;font-size:9px;letter-spacing:.02em;padding:1px 5px;width:-webkit-fit-content;width:fit-content}.output-handle,.output-node-id{background:var(--cloud-surface-3)}.output-handle{border:1px solid #ef444473;border-radius:2px;height:8px;width:8px}.output-handle:hover{background:#ef44444d;border-color:#ef4444;transform:scale(1.3)}.process-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;padding:8px 12px;transition:box-shadow .15s,border-color .15s}.process-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.process-node-content{align-items:center;display:flex;gap:8px}.process-info{display:flex;flex-direction:column;gap:3px}.node-label{font-size:12px}.process-node-id{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:3px;color:var(--text-muted);letter-spacing:.02em;padding:1px 5px}.node-status,.process-node-id{font-family:Geist Mono,monospace;font-size:9px;width:-webkit-fit-content;width:fit-content}.node-status{border-radius:3px;font-weight:600;letter-spacing:.04em;padding:1px 6px;text-transform:uppercase}.status-active{background:#10b98126}.status-pending{background:#f59e0b26;border:1px solid #f59e0b4d;color:#fcd34d}.process-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.process-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.docker-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;overflow:visible;padding:0;position:relative;transition:box-shadow .15s,border-color .15s}.docker-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.docker-status-badge{align-items:center;border:1px solid #0000;border-radius:20px;display:flex;font-family:Geist Mono,monospace;font-size:9px;font-weight:700;gap:4px;justify-content:center;left:50%;letter-spacing:.06em;padding:2px 10px;position:absolute;text-transform:uppercase;top:-11px;transform:translateX(-50%);white-space:nowrap;z-index:10}.docker-status-badge.status-active,.docker-status-badge.status-running{background:#10b9812e;border-color:#10b98159;color:#6ee7b7}.docker-status-badge.status-stopped{background:#ffffff0f;border-color:#ffffff1a;color:#64748b}.docker-status-badge.status-starting{background:#2563eb2e;border-color:#2563eb59;color:#93c5fd}.docker-status-badge.status-stopping{background:#f59e0b26;border-color:#f59e0b4d;color:#fcd34d}.docker-status-badge.status-restarting{background:#6366f126;border-color:#6366f14d;color:#a5b4fc}.status-dot{border-radius:50%;flex-shrink:0;height:5px;width:5px}.status-active .status-dot,.status-running .status-dot{animation:nodePulse 2s ease-in-out infinite;background:#10b981;box-shadow:0 0 5px #10b981cc}.status-stopped .status-dot{background:#475569}.status-restarting .status-dot,.status-starting .status-dot{animation:nodeSpin 1s linear infinite;background:#3b82f6;border-radius:0;-webkit-clip-path:polygon(50% 0,100% 100%,0 100%);clip-path:polygon(50% 0,100% 100%,0 100%);height:6px;width:6px}.status-stopping .status-dot{animation:nodePulse 1s ease-in-out infinite;background:#f59e0b}@keyframes nodePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}@keyframes nodeSpin{to{transform:rotate(1turn)}}@keyframes badge-pulse{0%,to{transform:translateX(-50%) scale(1)}50%{transform:translateX(-50%) scale(1.02)}}.status-restarting,.status-starting,.status-stopping{animation:badge-pulse 2s ease-in-out infinite}.docker-node-content{align-items:center;display:flex;gap:8px;padding:10px 10px 8px;position:relative;z-index:1}.docker-icon-wrapper{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;justify-content:center;padding:6px}.docker-icon{color:var(--text-secondary)}.docker-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.docker-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.docker-node-id{letter-spacing:.02em}.docker-ip,.docker-node-id{color:var(--text-muted);font-size:10px}.docker-ip,.docker-node-id,.docker-status{font-family:Geist Mono,monospace;width:-webkit-fit-content;width:fit-content}.docker-status{border-radius:3px;font-size:9px;font-weight:600;letter-spacing:.05em;padding:1px 6px;text-transform:uppercase}.docker-status.status-running{background:#10b98126;border:1px solid #10b9814d;color:#6ee7b7}.docker-status.status-stopped{background:#ffffff0d;border:1px solid var(--cloud-border);color:#475569}.docker-status.status-building{background:#f59e0b26;border:1px solid #f59e0b4d;color:#fcd34d}.docker-status.status-paused{background:#ffffff0d;border:1px solid var(--cloud-border);color:#475569}.docker-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.docker-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.status-content{align-items:center;display:flex;flex-direction:column;gap:1px}.status-text{font-size:8px!important;font-weight:700;letter-spacing:.05em}.provisioning-step,.status-text{font-family:Geist Mono,monospace}.provisioning-step{font-size:7px!important;font-weight:400;max-width:160px;opacity:.75;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.provisioning-progress{align-items:center;display:flex;gap:4px;margin-top:3px;width:100%}.progress-bar{background:#ffffff26;border-radius:1px;flex:1 1;height:2px}.progress-fill{background:currentColor;border-radius:1px;opacity:.9;transition:width .4s ease}.progress-text{font-size:7px!important;font-weight:600;min-width:20px;opacity:.8;text-align:right}.provisioning-spinner{animation:provSpin .7s linear infinite;border:1.5px solid #fff3;border-radius:50%;border-top-color:initial;flex-shrink:0;height:9px;margin-left:4px;width:9px}@keyframes provSpin{to{transform:rotate(1turn)}}.status-provisioning{background:#2563eb2e!important;border-color:#2563eb59!important;color:#93c5fd!important}.status-creating,.status-provisioning{animation:provBadgePulse 2s ease-in-out infinite}.status-creating{background:#6366f12e!important;border-color:#6366f159!important;color:#a5b4fc!important}.status-deleting{animation:provBadgePulse 2s ease-in-out infinite;background:#ef444426!important;border-color:#ef44444d!important;color:#fca5a5!important}.status-failed{background:#7f1d1d4d!important;border-color:#ef444466!important;color:#fca5a5!important}@keyframes provBadgePulse{0%,to{transform:translateX(-50%) scale(1)}50%{transform:translateX(-50%) scale(1.02)}}.podman-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;overflow:visible;padding:0;position:relative;transition:box-shadow .15s,border-color .15s}.podman-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.podman-status-badge{align-items:center;border:1px solid #0000;border-radius:20px;display:flex;font-family:Geist Mono,monospace;font-size:9px;font-weight:700;gap:4px;justify-content:center;left:50%;letter-spacing:.06em;padding:2px 10px;position:absolute;text-transform:uppercase;top:-11px;transform:translateX(-50%);white-space:nowrap;z-index:10}.podman-status-badge.status-running{background:#10b9812e;border-color:#10b98159;color:#6ee7b7}.podman-status-badge.status-stopped{background:#ffffff0f;border-color:#ffffff1a;color:#64748b}.podman-status-badge.status-starting{animation:provBadgePulse 2s ease-in-out infinite;background:#2563eb2e;border-color:#2563eb59;color:#93c5fd}.podman-status-badge.status-stopping{animation:provBadgePulse 2s ease-in-out infinite;background:#f59e0b26;border-color:#f59e0b4d;color:#fcd34d}.podman-status-badge.status-restarting{animation:provBadgePulse 2s ease-in-out infinite;background:#6366f126;border-color:#6366f14d;color:#a5b4fc}.podman-node-content{align-items:center;display:flex;gap:8px;padding:10px 10px 8px;position:relative;z-index:1}.podman-icon-wrapper{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;justify-content:center;padding:6px}.podman-icon{color:var(--text-secondary)}.podman-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.podman-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.podman-image,.podman-ip,.podman-node-id{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;width:-webkit-fit-content;width:fit-content}.podman-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.podman-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.dockerswarm-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;overflow:visible;padding:0;position:relative;transition:box-shadow .15s,border-color .15s}.dockerswarm-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.swarm-status-badge{align-items:center;border:1px solid #0000;border-radius:20px;display:flex;font-family:Geist Mono,monospace;font-size:9px;font-weight:700;gap:4px;justify-content:center;left:50%;letter-spacing:.06em;padding:2px 10px;position:absolute;text-transform:uppercase;top:-11px;transform:translateX(-50%);white-space:nowrap;z-index:10}.swarm-status-badge.status-running{background:#10b9812e;border-color:#10b98159;color:#6ee7b7}.swarm-status-badge.status-stopped{background:#ffffff0f;border-color:#ffffff1a;color:#64748b}.swarm-node-content{align-items:center;display:flex;gap:8px;padding:10px 10px 8px;position:relative;z-index:1}.swarm-icon-wrapper{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;justify-content:center;padding:6px}.swarm-icon{color:var(--text-secondary)}.swarm-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.swarm-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.swarm-node-id,.swarm-nodes{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;width:-webkit-fit-content;width:fit-content}.swarm-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.swarm-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.vm-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;overflow:visible;padding:0;position:relative;transition:box-shadow .15s,border-color .15s}.vm-status-badge{align-items:center;border:1px solid #0000;border-radius:20px;display:flex;font-family:Geist Mono,monospace;font-size:9px;font-weight:700;gap:4px;justify-content:center;left:50%;letter-spacing:.06em;padding:2px 10px;position:absolute;text-transform:uppercase;top:-11px;transform:translateX(-50%);white-space:nowrap;z-index:10}.vm-status-badge.status-running{background:#10b9812e;border-color:#10b98159;color:#6ee7b7}.vm-status-badge.status-stopped{background:#ffffff0f;border-color:#ffffff1a;color:#64748b}.vm-status-badge.status-starting{animation:provBadgePulse 2s ease-in-out infinite;background:#2563eb2e;border-color:#2563eb59;color:#93c5fd}.vm-status-badge.status-stopping{animation:provBadgePulse 2s ease-in-out infinite;background:#f59e0b26;border-color:#f59e0b4d;color:#fcd34d}.vm-status-badge.status-restarting{animation:provBadgePulse 2s ease-in-out infinite;background:#6366f126;border-color:#6366f14d;color:#a5b4fc}.vm-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.vm-node-content{align-items:center;display:flex;gap:8px;padding:10px 10px 8px;position:relative;z-index:1}.vm-icon-wrapper{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;justify-content:center;padding:6px}.vm-icon{color:var(--text-secondary)}.vm-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.vm-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vm-node-id,.vm-size{color:var(--text-muted)}.vm-node-id,.vm-os,.vm-size{font-family:Geist Mono,monospace;font-size:10px;width:-webkit-fit-content;width:fit-content}.vm-os{background:var(--accent-dim);border:1px solid #2563eb4d;border-radius:3px;color:var(--text-accent);font-weight:600;padding:1px 6px}.vm-ip{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;width:-webkit-fit-content;width:fit-content}.vm-specs{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.vm-spec-item{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:3px;color:var(--text-muted);font-weight:500;padding:1px 5px;white-space:nowrap}.vm-spec-item,.vm-status{font-family:Geist Mono,monospace;font-size:9px}.vm-status{border-radius:3px;font-weight:600;letter-spacing:.04em;padding:1px 6px;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.vm-status.status-running{background:#10b98126;border:1px solid #10b9814d;color:#6ee7b7}.vm-status.status-stopped{background:#ffffff0d;border:1px solid var(--cloud-border);color:#475569}.vm-status.status-active{background:var(--accent-dim);border:1px solid #2563eb4d;color:#93c5fd}.vm-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.vm-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.lb-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;overflow:visible;padding:0;position:relative;transition:box-shadow .15s,border-color .15s}.lb-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.lb-node-content{align-items:center;display:flex;gap:8px;padding:10px 10px 8px;position:relative;z-index:1}.lb-icon-wrapper{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;justify-content:center;padding:6px}.lb-icon{color:var(--text-secondary)}.lb-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.lb-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-node-id{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;width:-webkit-fit-content;width:fit-content}.lb-frontend-info{align-items:center;display:flex;flex-wrap:wrap;gap:4px}.lb-frontend-name{background:#6366f126;border:1px solid #6366f140;border-radius:3px;color:#a5b4fc;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;padding:1px 6px}.lb-mode{background:#10b9811f;border:1px solid #10b98140;border-radius:3px;color:#6ee7b7;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.lb-balancing-mode,.lb-mode{font-family:Geist Mono,monospace;font-size:9px;padding:1px 5px}.lb-balancing-mode{background:#6366f11f;border:1px solid #6366f140;border-radius:3px;color:#a5b4fc;font-weight:600}.lb-public-port{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:3px;color:var(--text-secondary);font-weight:700}.lb-connection-count,.lb-public-port{font-family:Geist Mono,monospace;font-size:10px;padding:1px 6px}.lb-connection-count{background:var(--accent-dim);border:1px solid #2563eb40;border-radius:3px;color:#93c5fd;font-weight:600;margin-top:2px}.lb-connection-count.lb-at-capacity{animation:lbCapPulse 2s ease-in-out infinite;background:var(--danger-dim);border-color:#ef44444d;color:#fca5a5}@keyframes lbCapPulse{0%,to{opacity:1}50%{opacity:.6}}.lb-algorithm{color:var(--text-muted);font-size:10px}.lb-algorithm,.lb-status{font-family:Geist Mono,monospace;width:-webkit-fit-content;width:fit-content}.lb-status{border-radius:3px;font-size:9px;font-weight:600;letter-spacing:.04em;padding:1px 6px;text-transform:uppercase}.lb-status.status-running{background:#10b98126;border:1px solid #10b9814d;color:#6ee7b7}.lb-status.status-stopped{background:#ffffff0d;border:1px solid var(--cloud-border);color:#475569}.lb-status.status-active{background:var(--accent-dim);border:1px solid #2563eb4d;color:#93c5fd}.lb-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.lb-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.ip-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;overflow:visible;padding:0;position:relative;transition:box-shadow .15s,border-color .15s}.ip-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.ip-node-content{align-items:center;display:flex;gap:8px;padding:10px 10px 8px;position:relative;z-index:1}.ip-icon-wrapper{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;justify-content:center;padding:6px}.ip-icon{color:var(--text-secondary)}.ip-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.ip-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ip-node-id{color:var(--text-muted);font-size:10px}.ip-address-display,.ip-node-id{font-family:Geist Mono,monospace;width:-webkit-fit-content;width:fit-content}.ip-address-display{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:var(--radius-sm);color:var(--text-primary);font-size:11px;font-weight:700;letter-spacing:.03em;padding:2px 7px}.ip-ports{display:flex;flex-direction:column;gap:2px}.ip-port{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:3px;color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:600;padding:1px 5px;width:-webkit-fit-content;width:fit-content}.ip-port.local{background:#10b9811f;border-color:#10b98140;color:#6ee7b7}.ip-port.public{background:var(--accent-dim);border-color:#2563eb40;color:#93c5fd}.ip-protocol{border:1px solid var(--cloud-border);border-radius:3px;color:var(--text-muted);font-family:Geist Mono,monospace;font-size:9px;font-weight:700;letter-spacing:.05em;padding:1px 5px;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.ip-handle,.ip-protocol{background:var(--cloud-surface-3)}.ip-handle{border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.ip-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.rp-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;overflow:visible;padding:0;position:relative;transition:box-shadow .15s,border-color .15s}.rp-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.rp-node-content{align-items:center;display:flex;gap:8px;padding:10px 10px 8px;position:relative;z-index:1}.rp-icon-wrapper{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;justify-content:center;padding:6px}.rp-icon{color:var(--text-secondary)}.rp-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.rp-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rp-node-id,.rp-server{color:var(--text-muted);font-size:10px}.rp-node-id,.rp-server,.rp-status{font-family:Geist Mono,monospace;width:-webkit-fit-content;width:fit-content}.rp-status{border-radius:3px;font-size:9px;font-weight:600;letter-spacing:.04em;padding:1px 6px;text-transform:uppercase}.rp-status.status-running{background:#10b98126;border:1px solid #10b9814d;color:#6ee7b7}.rp-status.status-stopped{background:#ffffff0d;border:1px solid var(--cloud-border);color:#475569}.rp-status.status-active{background:var(--accent-dim);border:1px solid #2563eb4d;color:#93c5fd}.rp-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.rp-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.lxc-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;overflow:visible;padding:0;position:relative;transition:box-shadow .15s,border-color .15s}.lxc-status-badge{align-items:center;border:1px solid #0000;border-radius:20px;display:flex;font-family:Geist Mono,monospace;font-size:9px;font-weight:700;gap:4px;justify-content:center;left:50%;letter-spacing:.06em;padding:2px 10px;position:absolute;text-transform:uppercase;top:-11px;transform:translateX(-50%);white-space:nowrap;z-index:10}.lxc-status-badge.status-running{background:#10b9812e;border-color:#10b98159;color:#6ee7b7}.lxc-status-badge.status-stopped{background:#ffffff0f;border-color:#ffffff1a;color:#64748b}.lxc-status-badge.status-starting{animation:provBadgePulse 2s ease-in-out infinite;background:#2563eb2e;border-color:#2563eb59;color:#93c5fd}.lxc-status-badge.status-stopping{animation:provBadgePulse 2s ease-in-out infinite;background:#f59e0b26;border-color:#f59e0b4d;color:#fcd34d}.lxc-status-badge.status-restarting{animation:provBadgePulse 2s ease-in-out infinite;background:#6366f126;border-color:#6366f14d;color:#a5b4fc}.lxc-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.lxc-node-content{align-items:center;display:flex;gap:8px;padding:10px 10px 8px;position:relative;z-index:1}.lxc-icon-wrapper{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;justify-content:center;padding:6px}.lxc-icon{color:var(--text-secondary)}.lxc-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.lxc-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lxc-node-id,.lxc-template{color:var(--text-muted);font-family:Geist Mono,monospace}.lxc-ip,.lxc-node-id,.lxc-template{font-size:10px;width:-webkit-fit-content;width:fit-content}.lxc-status{border-radius:3px;font-family:Geist Mono,monospace;font-size:9px;font-weight:600;letter-spacing:.04em;padding:1px 6px;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.lxc-status.status-running{background:#10b98126;border:1px solid #10b9814d;color:#6ee7b7}.lxc-status.status-stopped{background:#ffffff0d;border:1px solid var(--cloud-border);color:#475569}.lxc-status.status-frozen{background:var(--accent-dim);border:1px solid #2563eb4d;color:#93c5fd}.lxc-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.lxc-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.database-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;overflow:visible;padding:0;position:relative;transition:box-shadow .15s,border-color .15s}.database-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.database-status-badge{align-items:center;border:1px solid #0000;border-radius:20px;display:flex;font-family:Geist Mono,monospace;font-size:9px;font-weight:700;gap:4px;justify-content:center;left:50%;letter-spacing:.06em;padding:2px 10px;position:absolute;text-transform:uppercase;top:-11px;transform:translateX(-50%);white-space:nowrap;z-index:10}.database-status-badge.status-running{background:#10b9812e;border-color:#10b98159;color:#6ee7b7}.database-status-badge.status-stopped{background:#ffffff0f;border-color:#ffffff1a;color:#64748b}.database-status-badge.status-starting{animation:provBadgePulse 2s ease-in-out infinite;background:#2563eb2e;border-color:#2563eb59;color:#93c5fd}.database-status-badge.status-stopping{animation:provBadgePulse 2s ease-in-out infinite;background:#f59e0b26;border-color:#f59e0b4d;color:#fcd34d}.database-status-badge.status-restarting{animation:provBadgePulse 2s ease-in-out infinite;background:#6366f126;border-color:#6366f14d;color:#a5b4fc}.database-node-content{align-items:center;display:flex;gap:8px;padding:10px 10px 8px;position:relative;z-index:1}.database-icon-wrapper{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;justify-content:center;padding:6px}.database-icon-wrapper svg{color:var(--text-secondary)}.database-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.database-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.database-ip,.database-node-id{font-size:10px;width:-webkit-fit-content;width:fit-content}.database-ip,.database-node-id,.database-size{color:var(--text-muted);font-family:Geist Mono,monospace}.database-size{font-size:9px;font-weight:500;margin-top:2px}.database-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.database-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.vpc-node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);min-width:130px;overflow:visible;padding:0;position:relative;transition:box-shadow .15s,border-color .15s}.vpc-node:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 20px #00000080}.vpc-node-content{align-items:center;display:flex;gap:8px;padding:10px 10px 8px;position:relative;z-index:1}.vpc-icon-wrapper{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;justify-content:center;padding:6px}.vpc-icon{color:var(--text-secondary)}.vpc-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.vpc-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vpc-node-id{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;width:-webkit-fit-content;width:fit-content}.vpc-network{display:flex;flex-direction:column;gap:2px}.vpc-network-cidr{background:#10b9811f;border:1px solid #10b98140;border-radius:3px;color:#6ee7b7;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;padding:1px 6px;width:-webkit-fit-content;width:fit-content}.vpc-dhcp{display:flex;flex-direction:column;gap:2px}.vpc-dhcp-label{background:var(--accent-dim);border:1px solid #2563eb40;border-radius:3px;color:#93c5fd;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;padding:1px 6px;width:-webkit-fit-content;width:fit-content}.vpc-handle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:2px;height:8px;width:8px}.vpc-handle:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.node-palette{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:calc(100vh - 8rem);overflow:hidden;width:260px}.palette-error,.palette-loading{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;font-family:Geist Mono,monospace;font-size:13px;gap:.75rem;justify-content:center;padding:2rem}.palette-loading .spin{animation:spin 1s linear infinite}.palette-error button{background:var(--accent);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:12px;padding:6px 14px}.palette-error button:hover{background:#1d4ed8}.palette-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;gap:8px;padding:12px 14px}.palette-header h3{color:var(--text-secondary);font-family:Geist Mono,monospace;font-size:12px;font-weight:600;letter-spacing:.07em;margin:0;text-transform:uppercase}.palette-content{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:12px;scroll-behavior:smooth}.palette-content::-webkit-scrollbar{width:4px}.palette-content::-webkit-scrollbar-track{background:#0000}.palette-content::-webkit-scrollbar-thumb{background:var(--cloud-border-2);border-radius:2px}.palette-content::-webkit-scrollbar-thumb:hover{background:#fff3}.node-category{margin-bottom:1.25rem}.node-category:last-child{margin-bottom:0}.category-header{align-items:center;display:flex;gap:6px;margin-bottom:8px;padding:4px 2px}.category-toggle{background:none;border:none;border-radius:3px;color:var(--text-muted);cursor:pointer;justify-content:center;padding:2px;transition:all var(--transition)}.category-toggle:hover{color:var(--text-secondary)}.category-title{color:var(--text-muted);flex:1 1;font-size:10px;letter-spacing:.07em;margin:0}.category-status,.category-title{font-family:Geist Mono,monospace;font-weight:600;text-transform:uppercase}.category-status{border-radius:20px;font-size:9px;letter-spacing:.05em;padding:2px 7px}.category-status.active{background:var(--success-dim);border:1px solid #10b98140;color:var(--success)}.category-status.inactive{background:#ffffff0a;border:1px solid var(--cloud-border);color:var(--text-muted)}.node-list{display:flex;flex-direction:column;gap:4px}.palette-node{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);cursor:grab;display:flex;gap:10px;padding:9px 10px;transition:all var(--transition)}.palette-node:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border-2);transform:translateX(2px)}.palette-node:active{cursor:grabbing;transform:scale(.98)}.palette-node-icon{flex-shrink:0;font-size:1.2rem;text-align:center;width:28px}.palette-node-info{display:flex;flex:1 1;flex-direction:column;gap:.125rem;min-width:0}.palette-node-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;font-weight:600}.palette-node-description,.palette-node-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.palette-node-description{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px}.palette-node-price{background:var(--success-dim);border:1px solid #10b98140;border-radius:20px;color:var(--success);flex-shrink:0;font-family:Geist Mono,monospace;font-size:10px;font-weight:700;padding:2px 8px;white-space:nowrap}.palette-node-input{border-left:3px solid var(--success)}.palette-node-output{border-left:3px solid var(--danger)}.palette-node-process{border-left:3px solid var(--accent-bright)}.palette-node-custom{border-left:3px solid var(--accent)}.palette-node-docker{border-left:3px solid #0ea5e9}.palette-node-podman{border-left:3px solid #892ca0}.palette-node-dockerswarm{border-left:3px solid var(--warning)}.palette-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);padding:10px 14px}.palette-hint{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;letter-spacing:.03em;margin:0;text-align:center}@media (max-width:768px){.node-palette{max-height:300px;width:100%}}.delete-node-button{align-items:center;background:var(--danger-dim);border:1px solid #ef444459;border-radius:var(--radius-md);color:#fca5a5;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:12px;font-weight:600;gap:6px;padding:6px 14px;position:absolute;right:12px;top:12px;transition:all var(--transition);z-index:10}.delete-node-button:hover{background:#ef444440;border-color:#ef44448c;box-shadow:0 4px 12px #ef444433;color:#fecaca}.delete-node-button:active{transform:scale(.97)}.delete-node-button:disabled{cursor:not-allowed;opacity:.35}.delete-node-button:disabled:hover{box-shadow:none;transform:none}.context-menu-overlay{background:#0000;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.node-context-menu{animation:contextMenuAppear .12s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);box-shadow:0 8px 32px #0009,0 0 0 1px var(--cloud-border);min-width:200px;overflow:hidden;position:fixed;z-index:1000}@keyframes contextMenuAppear{0%{opacity:0;transform:scale(.95) translateY(-5px)}to{opacity:1;transform:scale(1) translateY(0)}}.context-menu-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;gap:8px;justify-content:space-between;padding:10px 14px}.context-menu-title{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.context-menu-id{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;letter-spacing:.02em}.context-menu-items{padding:.5rem 0}.context-menu-item{align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:13px;gap:10px;padding:9px 14px;text-align:left;transition:background var(--transition),color var(--transition);width:100%}.context-menu-item:hover{background:var(--cloud-surface-3);color:var(--text-primary)}.context-menu-item svg{color:var(--text-muted);flex-shrink:0}.context-menu-item:hover svg{color:var(--text-secondary)}.context-menu-item.start svg{color:#10b981}.context-menu-item.stop svg{color:#f59e0b}.context-menu-item.restart svg{color:#a5b4fc}.context-menu-item.restart:hover{background:#6366f11a}.context-menu-item.browser,.context-menu-item.browser svg{color:#93c5fd}.context-menu-item.browser:hover{background:var(--accent-dim);color:#bfdbfe}.context-menu-item.delete,.context-menu-item.delete svg{color:#fca5a5}.context-menu-item.delete:hover{background:var(--danger-dim);color:#fecaca}.context-menu-item.configure{color:var(--text-accent)}.context-menu-item.configure:hover{background:var(--accent-dim);color:#bfdbfe}.context-menu-divider{background:var(--cloud-border);height:1px;margin:4px 0}.edge-context-menu-overlay{background:#0000;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.edge-context-menu{animation:edgeContextMenuAppear .12s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);box-shadow:0 8px 32px #0009,0 0 0 1px var(--cloud-border);min-width:200px;overflow:hidden;position:fixed;z-index:1000}@keyframes edgeContextMenuAppear{0%{opacity:0;transform:scale(.95) translateY(-5px)}to{opacity:1;transform:scale(1) translateY(0)}}.edge-context-menu-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;gap:8px;justify-content:space-between;padding:10px 14px}.edge-context-menu-title{color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;font-weight:600}.edge-context-menu-id{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;letter-spacing:.02em}.edge-context-menu-items{padding:.5rem 0}.edge-context-menu-item{align-items:center;background:none;border:none;color:#fca5a5;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:13px;gap:10px;padding:9px 14px;text-align:left;transition:background var(--transition);width:100%}.edge-context-menu-item:hover{background:var(--danger-dim);color:#fecaca}.edge-context-menu-item svg{color:#fca5a5;flex-shrink:0}.edge-context-menu-item.delete{color:#fca5a5}.loading-overlay{align-items:center;animation:fadeIn .15s ease-in;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.loading-spinner-container{align-items:center;animation:slideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;gap:16px;padding:32px 48px}.loading-spinner{animation:lsSpin .7s linear infinite;border-top:2px solid var(--cloud-border);border:2px solid var(--cloud-border);border-radius:50%;border-top-color:var(--accent);height:40px;width:40px}@keyframes lsSpin{to{transform:rotate(1turn)}}.loading-message{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin:0;text-align:center}.connection-modal-overlay{align-items:center;animation:fadeIn .15s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.connection-modal{animation:slideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:500px;overflow:hidden;width:90%}.connection-modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 20px}.connection-modal-header h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}.connection-modal-close{align-items:center;background:none;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;height:30px;justify-content:center;line-height:1;transition:all var(--transition);width:30px}.connection-modal-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.connection-modal-body{max-height:calc(90vh - 80px);overflow-y:auto;padding:18px 20px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.connection-info{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);display:flex;gap:12px;justify-content:space-between;margin-bottom:18px;padding:12px 14px}.connection-node-info{flex:1 1}.connection-label{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.connection-node-name{color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;font-weight:600}.connection-arrow{color:var(--text-accent);font-size:18px;font-weight:700}.form-group input,.form-group select{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;padding:9px 12px;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.domain-select{background:var(--cloud-surface);cursor:pointer}.form-group input:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-group input.error:focus{box-shadow:0 0 0 3px var(--danger-dim)}.domain-preview{background:#10b98114;border:1px solid #10b98140;border-radius:var(--radius-sm);margin-top:8px;padding:10px 12px}.preview-label{display:block;font-size:10px;font-weight:600;letter-spacing:.05em;margin-bottom:4px;text-transform:uppercase}.domain-preview code{color:#6ee7b7;display:block;font-family:Geist Mono,monospace;font-size:12px;font-weight:600;word-break:break-all}.connection-modal-footer{border-top:1px solid var(--cloud-border);display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:16px}.connection-modal-footer button{border-radius:var(--radius-md);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:8px 18px;transition:all var(--transition)}.btn-confirm:hover{background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.btn-confirm:active{transform:scale(.98)}.btn-cancel:disabled,.btn-confirm:disabled{cursor:not-allowed;opacity:.4;transform:none!important}.btn-spinner{animation:connSpin .6s linear infinite;border:1.5px solid #ffffff40;border-radius:50%;border-top-color:#fff;display:inline-block;height:12px;margin-right:6px;vertical-align:middle;width:12px}@keyframes connSpin{to{transform:rotate(1turn)}}.rp-config-modal-overlay{align-items:center;animation:fadeIn .15s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.rp-config-modal{animation:slideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:80vh;max-width:95vw;overflow:hidden;width:600px}.rp-config-modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:12px 16px}.rp-config-header-title{align-items:center;display:flex;gap:10px}.rp-config-icon{font-size:18px;line-height:1}.rp-config-modal-header h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;letter-spacing:-.01em;margin:0}.rp-config-subtitle{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px;margin:2px 0 0}.rp-config-header-actions{align-items:center;display:flex;gap:6px}.rp-icon-btn{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;height:28px;justify-content:center;transition:all var(--transition);width:28px}.rp-icon-btn:hover{border-color:var(--cloud-border-2);color:var(--text-primary)}.rp-icon-btn:disabled{cursor:default;opacity:.5}.rp-icon-btn-close:hover{background:#ef444426;border-color:#ef444466;color:#fca5a5}.spinning{animation:spin .6s linear infinite}.rp-config-modal-body{flex:1 1;overflow-y:auto;padding:12px 14px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.rp-config-empty{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;font-family:Geist,sans-serif;gap:8px;padding:40px 20px;text-align:center}.rp-empty-icon{margin-bottom:4px;opacity:.4}.rp-config-empty p{color:var(--text-secondary);font-size:13px;font-weight:600;margin:0}.rp-config-empty span{font-size:12px}.rp-connections-list{display:flex;flex-direction:column;gap:8px}.rp-conn-section{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);overflow:hidden}.rp-conn-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;justify-content:space-between;padding:8px 10px}.rp-conn-toggle{align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;font-family:Geist Mono,monospace;font-size:11px;font-weight:600;gap:6px;padding:0;text-align:left}.rp-conn-toggle:hover{color:var(--text-primary)}.rp-conn-source-id{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:11px;padding:2px 7px}.rp-conn-badge{background:var(--accent-dim);border:1px solid #2563eb40;border-radius:10px;color:var(--text-muted);font-size:10px;padding:1px 6px}.rp-conn-header-actions{display:flex;gap:5px}.rp-btn-add-service{align-items:center;background:#10b9811f;border:1px solid #10b9814d;border-radius:var(--radius-sm);color:#6ee7b7;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:11px;font-weight:600;gap:4px;padding:4px 9px;transition:all var(--transition)}.rp-btn-add-service:hover{background:#10b98138;border-color:#10b98180}.rp-btn-add-service:disabled{cursor:default;opacity:.5}.rp-btn-delete-edge{align-items:center;background:var(--danger-dim);border:1px solid #ef444459;border-radius:var(--radius-sm);color:#fca5a5;cursor:pointer;display:flex;height:26px;justify-content:center;transition:all var(--transition);width:26px}.rp-btn-delete-edge:hover{background:#ef444440;border-color:#ef44448c;color:#fecaca}.rp-btn-delete-edge:disabled{cursor:default;opacity:.5}.rp-add-service-form{align-items:center;background:#10b9810a;border-bottom:1px solid var(--cloud-border);display:flex;gap:6px;padding:8px 10px}.rp-input-port{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);flex-shrink:0;font-family:Geist Mono,monospace;font-size:11px;padding:5px 8px;width:130px}.rp-input-port:focus{border-color:var(--accent);outline:none}.rp-input-label{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);flex:1 1;font-family:Geist,sans-serif;font-size:11px;padding:5px 8px}.rp-input-label:focus{border-color:var(--accent);outline:none}.rp-btn-confirm-add{align-items:center;background:#10b98126;border:1px solid #10b98159;border-radius:var(--radius-sm);color:#6ee7b7;cursor:pointer;display:flex;font-size:11px;font-weight:600;gap:4px;padding:5px 10px;transition:all var(--transition)}.rp-btn-confirm-add:hover{background:#10b98140}.rp-btn-confirm-add:disabled{cursor:default;opacity:.5}.rp-btn-cancel-add{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;height:26px;justify-content:center;transition:all var(--transition);width:26px}.rp-btn-cancel-add:hover{color:var(--text-primary)}.rp-services-list{padding:0}.rp-no-services{color:var(--text-muted);font-size:12px;font-style:italic;margin:0;padding:12px}.rp-service-row{align-items:center;border-bottom:1px solid var(--cloud-border);display:flex;gap:8px;padding:8px 10px;transition:background var(--transition)}.rp-service-row:last-child{border-bottom:none}.rp-service-row:hover{background:var(--cloud-surface-2)}.rp-service-info{align-items:center;display:flex;flex-shrink:0;gap:6px}.rp-service-label{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rp-service-port{background:var(--accent-dim);border:1px solid #2563eb40;border-radius:var(--radius-sm);color:var(--text-accent);font-size:11px}.rp-service-port,.rp-vhost-badge{font-family:Geist Mono,monospace;font-weight:600;padding:1px 6px}.rp-vhost-badge{border-radius:10px;font-size:10px;white-space:nowrap}.rp-vhost-badge.ok{background:#10b9811f;border:1px solid #10b9814d;color:#6ee7b7}.rp-vhost-badge.err{background:var(--danger-dim);border:1px solid #ef44444d;color:#fca5a5}.rp-service-domain{color:#c4b5fd;flex:1 1;font-family:Geist Mono,monospace;font-size:11px;overflow:hidden;text-decoration:none;text-overflow:ellipsis;transition:color var(--transition);white-space:nowrap}a.rp-service-domain:hover{color:#a78bfa;text-decoration:underline}.rp-service-domain-err{color:var(--text-muted);font-style:italic}.rp-btn-delete-service{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;height:22px;justify-content:center;transition:all var(--transition);width:22px}.rp-btn-delete-service:hover{background:var(--danger-dim);border-color:#ef44444d;color:#fca5a5}.rp-btn-delete-service:disabled{cursor:default;opacity:.5}.rp-config-modal-footer{align-items:center;background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:10px 14px}.rp-footer-info{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px}.rp-btn-close-footer{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:Geist,sans-serif;font-size:12px;font-weight:600;padding:6px 16px;transition:all var(--transition)}.rp-btn-close-footer:hover{background:var(--cloud-surface);border-color:var(--cloud-border-2);color:var(--text-primary)}.rp-spinner{border:2px solid var(--cloud-border);border-radius:50%;border-top-color:var(--accent);height:24px;width:24px}.rp-spinner,.rp-spinner-sm{animation:spin .6s linear infinite}.rp-spinner-sm{border:2px solid;border-radius:50%;border-top:2px solid #0000;display:inline-block;height:12px;width:12px}.ip-config-modal-overlay{align-items:center;animation:fadeIn .15s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.ip-config-modal{animation:slideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:80vh;max-width:900px;overflow:hidden;width:85%}.ip-config-modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:12px 18px}.ip-config-modal-header h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;letter-spacing:-.01em;margin:0}.ip-config-subtitle{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px;font-weight:400;margin:3px 0 0}.ip-config-modal-close{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;height:28px;justify-content:center;line-height:1;transition:all var(--transition);width:28px}.ip-config-modal-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.ip-config-modal-body{flex:1 1;overflow-y:auto;padding:14px 18px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.ip-config-empty{color:var(--text-muted);font-family:Geist,sans-serif;padding:32px 20px;text-align:center}.ip-config-empty p{color:var(--text-secondary);font-size:13px;font-weight:600;margin:0 0 4px}.ip-config-empty span{font-size:12px}.ip-config-table-container{border:1px solid var(--cloud-border);border-radius:var(--radius-md);overflow-x:auto}.ip-config-table{background:var(--cloud-surface);border-collapse:collapse;width:100%}.ip-config-table thead{background:var(--cloud-surface-2)}.ip-config-table th{border-bottom:1px solid var(--cloud-border);color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.05em;padding:8px 10px;text-align:left;text-transform:uppercase}.ip-config-table tbody tr{border-bottom:1px solid var(--cloud-border);transition:background var(--transition)}.ip-config-table tbody tr:hover{background:var(--cloud-surface-2)}.ip-config-table td{padding:8px 10px;vertical-align:middle}.ip-config-node-cell{display:flex;flex-direction:column;gap:3px}.ip-config-node-id{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:2px 6px;width:-webkit-fit-content;width:fit-content}.ip-config-node-id,.ip-config-port{display:inline-block;font-family:Geist Mono,monospace;font-size:11px;font-weight:600}.ip-config-port{background:var(--accent-dim);border:1px solid #2563eb40;border-radius:var(--radius-sm);color:var(--text-accent);padding:2px 7px}.ip-config-protocol{background:#6366f11f;border:1px solid #6366f140;border-radius:var(--radius-sm);color:#c4b5fd;display:inline-block;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;padding:2px 7px;text-transform:uppercase}.ip-config-input{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist Mono,monospace;font-size:11px;padding:5px 8px;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.ip-config-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim);outline:none}.ip-config-select{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:Geist Mono,monospace;font-size:11px;padding:5px 8px;transition:border-color var(--transition);width:100%}.ip-config-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim);outline:none}.ip-config-actions{gap:.5rem}.ip-config-actions,.ip-config-btn{display:flex;justify-content:center}.ip-config-btn{align-items:center;border:none;border-radius:4px;cursor:pointer;padding:.4rem;transition:all .2s}.ip-config-btn svg{height:14px;width:14px}.ip-config-btn-edit{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);color:var(--text-secondary)}.ip-config-btn-edit:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border-2);color:var(--text-primary)}.ip-config-btn-save{background:#10b98126;border:1px solid #10b9814d;color:#6ee7b7}.ip-config-btn-save:hover{background:#10b98140;border-color:#10b98180}.ip-config-btn-cancel{background:var(--danger-dim);border:1px solid #ef444459;color:#fca5a5}.ip-config-btn-cancel:hover{background:#ef444440;border-color:#ef44448c;color:#fecaca}.ip-config-btn-delete{background:var(--danger-dim);border:1px solid #ef444459;color:#fca5a5}.ip-config-btn-delete:hover{background:#ef444440;border-color:#ef44448c;color:#fecaca}.ip-config-modal-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:flex-end;padding:12px 18px}.ip-config-btn-close{background:var(--accent);border:1px solid #0000;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:7px 18px;transition:all var(--transition)}.ip-config-btn-close:hover{background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.ip-config-btn-close:active{transform:scale(.98)}.ip-config-ports-list{display:flex;flex-direction:column;gap:.5rem}.ip-config-port-item{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;gap:6px;padding:4px 6px}.ip-config-arrow{color:var(--text-muted);font-weight:600}.ip-config-ports-edit{display:flex;flex-direction:column;gap:6px}.ip-config-port-edit-row{align-items:center;display:flex;gap:6px}.ip-config-input-small{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist Mono,monospace;font-size:11px;padding:4px 6px;transition:border-color var(--transition);width:72px}.ip-config-input-small:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim);outline:none}.ip-config-select-small{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:Geist Mono,monospace;font-size:11px;padding:4px 6px;transition:border-color var(--transition);width:72px}.ip-config-select-small:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim);outline:none}.ip-config-btn-remove-port-inline{align-items:center;background:var(--danger-dim);border:1px solid #ef444459;border-radius:var(--radius-sm);color:#fca5a5;cursor:pointer;display:flex;justify-content:center;margin-left:3px;padding:3px;transition:all var(--transition)}.ip-config-btn-remove-port-inline:hover{background:#ef444440;border-color:#ef44448c;color:#fecaca}.ip-config-btn-add-port-inline{align-items:center;background:var(--accent);border:1px solid #0000;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:11px;font-weight:600;gap:4px;margin-top:6px;padding:5px 10px;transition:all var(--transition)}.ip-config-btn-add-port-inline:hover{background:var(--accent-hover);box-shadow:0 2px 8px #2563eb4d}.ip-conn-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.ip-conn-modal{animation:slideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;max-width:550px;overflow:hidden;width:90%}.ip-conn-modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;justify-content:space-between;padding:12px 16px}.ip-conn-modal-header h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;margin:0}.ip-conn-modal-close{align-items:center;background:none;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;height:28px;justify-content:center;transition:all var(--transition);width:28px}.ip-conn-modal-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.ip-conn-modal-body{padding:16px}.ip-conn-info{background:var(--accent-dim);border:1px solid #2563eb40;border-radius:var(--radius-md);margin-bottom:14px;padding:10px 12px}.ip-conn-info p{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;margin:3px 0}.ip-conn-info strong{color:var(--text-accent)}.ip-conn-form-group{margin-bottom:14px}.ip-conn-form-group label{color:var(--text-secondary);display:block;font-family:Geist,sans-serif;font-size:10px;font-weight:600;letter-spacing:.05em;margin-bottom:5px;text-transform:uppercase}.ip-conn-form-group input{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;padding:8px 10px;transition:border-color var(--transition);width:100%}.ip-conn-form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.ip-conn-form-group input.error{border-color:#ef444499}.ip-conn-error{color:#fca5a5}.ip-conn-error,.ip-conn-hint{display:block;font-family:Geist Mono,monospace;font-size:11px;margin-top:3px}.ip-conn-hint{color:var(--text-muted)}.ip-conn-ports-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.ip-conn-ports-header label{color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase}.ip-conn-add-port-btn,.ip-conn-ports-header label{font-family:Geist,sans-serif;font-size:11px;font-weight:600}.ip-conn-add-port-btn{align-items:center;background:var(--accent);border:1px solid #0000;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:flex;gap:5px;padding:5px 10px;transition:all var(--transition)}.ip-conn-add-port-btn:hover{background:var(--accent-hover);box-shadow:0 3px 8px #2563eb4d}.ip-conn-port-mapping{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);margin-bottom:10px;padding:10px 12px}.ip-conn-port-mapping-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.ip-conn-port-mapping-title{color:var(--text-accent);font-family:Geist Mono,monospace;font-size:11px;font-weight:600}.ip-conn-remove-port-btn{align-items:center;background:var(--danger-dim);border:1px solid #ef444459;border-radius:var(--radius-sm);color:#fca5a5;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all var(--transition)}.ip-conn-remove-port-btn:hover{background:#ef444440;border-color:#ef44448c}.ip-conn-port-row{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr 1fr}.ip-conn-protocol-select{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:Geist,sans-serif;font-size:12px;font-weight:600;padding:7px 8px;transition:border-color var(--transition);width:100%}.ip-conn-protocol-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.ip-conn-info-box{background:var(--accent-dim);border:1px solid #2563eb40;border-radius:var(--radius-md);margin-bottom:14px;padding:10px 12px}.ip-conn-info-box p{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;margin:0}.ip-conn-info-box strong{color:var(--text-accent)}.ip-conn-preview{color:var(--text-accent)!important;font-family:Geist Mono,monospace!important;font-size:12px!important;font-weight:600;margin-top:5px!important}.ip-conn-modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:14px}.ip-conn-btn-primary,.ip-conn-btn-secondary{align-items:center;border-radius:var(--radius-md);cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:5px;padding:7px 16px;transition:all var(--transition)}.ip-conn-btn-secondary{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);color:var(--text-secondary)}.ip-conn-btn-secondary:hover:not(:disabled){background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.ip-conn-btn-primary{background:var(--accent);border:1px solid #0000;color:#fff}.ip-conn-btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.ip-conn-btn-primary:disabled,.ip-conn-btn-secondary:disabled{cursor:not-allowed;opacity:.4}.ip-conn-spinner{animation:ipConnSpin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:13px;width:13px}@keyframes ipConnSpin{to{transform:rotate(1turn)}}.ip-details-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.ip-details-modal{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:85vh;max-width:900px;width:90%}.ip-details-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 20px}.ip-details-header h2{align-items:center;color:var(--text-primary);display:flex;font-family:Geist,sans-serif;font-size:15px;font-weight:600;gap:7px;margin:0}.ip-details-close{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;height:28px;justify-content:center;transition:all var(--transition);width:28px}.ip-details-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.ip-details-body{flex:1 1;overflow-y:auto;padding:16px 20px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.ip-info-section{grid-gap:12px;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:16px;padding:14px}.info-value{font-size:14px}.loading-state{font-size:13px;padding:40px}.loading-state,.no-connections{color:var(--text-muted);font-family:Geist,sans-serif;text-align:center}.no-connections{padding:48px 20px}.no-connections p{font-size:13px;margin:0}.connections-list h3{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;margin:0 0 12px}.connection-card{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);margin-bottom:12px;padding:14px;transition:all var(--transition)}.connection-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #2563eb1a}.connection-header{align-items:center;border-bottom:1px solid var(--cloud-border);display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.connection-node-info{display:flex;flex-direction:column;gap:3px}.node-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600}.node-ip{color:var(--text-accent);font-family:Geist Mono,monospace;font-size:12px}.btn-delete-connection{align-items:center;background:var(--danger-dim);border:1px solid #ef444459;border-radius:var(--radius-sm);color:#fca5a5;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:12px;font-weight:600;gap:5px;padding:5px 12px;transition:all var(--transition)}.btn-delete-connection:hover:not(:disabled){background:#ef444440;border-color:#ef44448c}.btn-delete-connection:disabled{cursor:not-allowed;opacity:.4}.mappings-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.mappings-section h4{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:11px;font-weight:600;letter-spacing:.04em;margin:0;text-transform:uppercase}.btn-add-mapping{align-items:center;background:#10b98126;border:1px solid #10b9814d;color:#6ee7b7;display:flex;font-size:11px;gap:4px;padding:4px 10px}.btn-add-mapping:hover:not(:disabled){background:#10b98140;border-color:#10b98180}.add-mapping-form{background:var(--cloud-surface);border:1px solid #10b98159;border-radius:var(--radius-md);margin-bottom:10px;padding:12px}.form-row{grid-gap:10px;margin-bottom:10px}.form-field{display:flex;flex-direction:column;gap:5px}.form-field label{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.form-field input{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist Mono,monospace;font-size:12px;padding:7px 10px;transition:border-color var(--transition)}.form-field input:focus{border-color:#10b98180;box-shadow:0 0 0 2px #10b98114;outline:none}.form-field input::placeholder{color:var(--text-muted)}.form-actions{gap:8px}.no-mappings-text{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:12px;font-style:italic;margin:0}.mappings-grid{display:flex;flex-direction:column;gap:6px}.mapping-item{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:10px 12px;transition:all var(--transition)}.mapping-item:hover{border-color:var(--cloud-border-2)}.mapping-info{flex:1 1}.mapping-label{color:var(--text-secondary);font-family:Geist Mono,monospace;font-size:12px}.mapping-actions{display:flex;gap:6px}.btn-delete,.btn-edit{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:Geist,sans-serif;font-size:12px;padding:4px 10px;transition:all var(--transition)}.btn-edit:hover:not(:disabled){background:var(--accent-dim);border-color:var(--accent);color:var(--text-accent)}.btn-delete:hover:not(:disabled){background:var(--danger-dim);border-color:#ef444466;color:#fca5a5}.btn-delete:disabled,.btn-edit:disabled{cursor:not-allowed;opacity:.4}.mapping-edit-form{gap:10px;width:100%}.edit-field,.mapping-edit-form{display:flex;flex-direction:column}.edit-field{gap:4px}.edit-field label{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.edit-field input{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist Mono,monospace;font-size:12px;padding:7px 10px;transition:border-color var(--transition)}.edit-field input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim);outline:none}.edit-actions{display:flex;gap:8px;justify-content:flex-end}.btn-cancel,.btn-save{font-size:12px;padding:6px 14px}.btn-save{background:#10b98133;border:1px solid #10b98166;color:#6ee7b7}.btn-save:hover:not(:disabled){background:#10b9814d;border-color:#10b98199}.btn-cancel:hover:not(:disabled){background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.btn-cancel:disabled,.btn-save:disabled{cursor:not-allowed;opacity:.4}.ip-details-footer{border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:flex-end;padding:12px 20px}.pf-section{border-top:1px dashed var(--cloud-border);margin-top:14px;padding-top:12px}.pf-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.pf-section-title{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.pf-mode-toggle{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-md);display:flex;gap:4px;margin-bottom:12px;padding:3px}.pf-mode-btn{background:#0000;border:none;border-radius:calc(var(--radius-md) - 2px);color:var(--text-muted);cursor:pointer;flex:1 1;font-family:Geist,sans-serif;font-size:11px;font-weight:600;padding:5px 12px;transition:all var(--transition)}.pf-mode-btn.active{background:var(--accent);color:#fff}.pf-mode-btn:not(.active):hover{background:var(--cloud-surface-2);color:var(--text-secondary)}.pf-form{background:var(--cloud-surface);border:1px solid #2563eb40;border-radius:var(--radius-md);margin-bottom:10px;padding:12px}.pf-form-fields{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));margin-bottom:10px}.pf-select{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:Geist Mono,monospace;font-size:12px;padding:7px 10px;width:100%}.pf-select:focus{border-color:var(--accent);outline:none}.pf-form-preview{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-accent);font-family:Geist Mono,monospace;font-size:11px;margin-bottom:10px;padding:7px 10px}.pf-rules-list{display:flex;flex-direction:column;gap:5px}.pf-rule-item{align-items:center;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:7px 10px;transition:all var(--transition)}.pf-rule-item:hover{border-color:var(--cloud-border-2)}.pf-rule-info{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.pf-arrow{color:var(--text-muted);font-size:11px}.pf-badge-subnet{background:#2563eb26;border:1px solid #2563eb4d;border-radius:99px;color:#93c5fd;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;padding:2px 7px}.pf-badge-full{background:#f59e0b26;border:1px solid #f59e0b59;border-radius:99px;color:#fcd34d;font-weight:700;letter-spacing:.04em}.pf-badge-full,.pf-badge-specific{font-family:Geist Mono,monospace;font-size:10px;padding:2px 8px}.pf-badge-specific{background:#10b9811f;border:1px solid #10b9814d;border-radius:99px;color:#6ee7b7;font-weight:600}.pf-badge-proto{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;text-transform:uppercase}.lb-config-modal-overlay{align-items:center;animation:fadeIn .15s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.lb-config-modal{animation:slideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:80vh;max-width:1000px;overflow:hidden;width:85%}.lb-config-modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:12px 18px}.lb-config-modal-header h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;letter-spacing:-.01em;margin:0}.lb-config-subtitle{align-items:center;color:var(--text-muted);display:flex;font-family:Geist Mono,monospace;font-size:11px;font-weight:500;gap:6px;margin:3px 0 0}.lb-config-connection-badge{background:var(--accent-dim);border:1px solid #2563eb4d;border-radius:20px;color:var(--text-accent);font-family:Geist Mono,monospace;font-size:10px;font-weight:700;padding:1px 7px}.lb-config-connection-badge.lb-config-at-limit{animation:lb-config-pulse 2s ease-in-out infinite;background:var(--danger-dim);border:1px solid #ef444459;color:#fca5a5}@keyframes lb-config-pulse{0%,to{opacity:1}50%{opacity:.7}}.lb-config-modal-close{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;height:28px;justify-content:center;line-height:1;transition:all var(--transition);width:28px}.lb-config-modal-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.lb-config-global-settings{background:#f59e0b12;border-bottom:1px solid #f59e0b33;flex-shrink:0;padding:10px 18px}.lb-config-port-section{display:flex;flex-direction:column;gap:6px}.lb-config-port-section label{color:#fcd34d;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.lb-config-port-controls{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.lb-config-frontend-input{background:var(--cloud-surface);border:1px solid #f59e0b59;border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist Mono,monospace;font-size:12px;font-weight:600;padding:6px 9px;width:180px}.lb-config-frontend-input:focus{border-color:#f59e0b99;box-shadow:0 0 0 2px #f59e0b1a;outline:none}.lb-config-balancing-select,.lb-config-mode-select{background:var(--cloud-surface);border:1px solid #f59e0b59;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:Geist Mono,monospace;font-size:12px;font-weight:600;padding:6px 9px}.lb-config-mode-select{text-transform:uppercase;width:90px}.lb-config-balancing-select{width:140px}.lb-config-balancing-select:focus,.lb-config-mode-select:focus{border-color:#f59e0b99;box-shadow:0 0 0 2px #f59e0b1a;outline:none}.lb-config-port-input{background:var(--cloud-surface);border:1px solid #f59e0b59;border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist Mono,monospace;font-size:12px;font-weight:600;padding:6px 9px;width:110px}.lb-config-port-input:focus{border-color:#f59e0b99;box-shadow:0 0 0 2px #f59e0b1a;outline:none}.lb-config-frontend-display{background:#8b5cf61a;border:1px solid #8b5cf640;border-radius:var(--radius-sm);color:#c4b5fd}.lb-config-frontend-display,.lb-config-mode-display{font-family:Geist Mono,monospace;font-size:12px;font-weight:700;padding:4px 10px}.lb-config-mode-display{background:#10b9811a;border:1px solid #10b98140;border-radius:var(--radius-sm);color:#6ee7b7;text-transform:uppercase}.lb-config-balancing-display{background:#8b5cf61a;border:1px solid #8b5cf640;border-radius:var(--radius-sm);color:#c4b5fd}.lb-config-balancing-display,.lb-config-port-display{font-family:Geist Mono,monospace;font-size:12px;font-weight:700;padding:4px 10px}.lb-config-port-display{background:#f59e0b1a;border:1px solid #f59e0b40;border-radius:var(--radius-sm);color:#fcd34d}.lb-config-hint{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-style:italic;margin:0}.lb-config-modal-body{flex:1 1;overflow-y:auto;padding:14px 18px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.lb-config-empty{color:var(--text-muted);font-family:Geist,sans-serif;padding:32px 20px;text-align:center}.lb-config-empty p{color:var(--text-secondary);font-size:13px;font-weight:600;margin:0 0 4px}.lb-config-empty span{font-size:12px}.lb-config-table-container{border:1px solid var(--cloud-border);border-radius:var(--radius-md);overflow-x:auto}.lb-config-table{background:var(--cloud-surface);border-collapse:collapse;width:100%}.lb-config-table thead{background:var(--cloud-surface-2)}.lb-config-table th{border-bottom:1px solid var(--cloud-border);color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.05em;padding:8px 10px;text-align:left;text-transform:uppercase}.lb-config-table tbody tr{border-bottom:1px solid var(--cloud-border);transition:background var(--transition)}.lb-config-table tbody tr:hover{background:var(--cloud-surface-2)}.lb-config-table td{padding:8px 10px;vertical-align:middle}.lb-config-node-cell{display:flex;flex-direction:column;gap:3px}.lb-config-node-id{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:2px 6px;width:-webkit-fit-content;width:fit-content}.lb-config-node-id,.lb-config-port{display:inline-block;font-family:Geist Mono,monospace;font-size:11px;font-weight:600}.lb-config-port{background:#f59e0b1a;border:1px solid #f59e0b40;border-radius:var(--radius-sm);color:#fcd34d;padding:2px 7px}.lb-config-mode{background:#8b5cf61a;border:1px solid #8b5cf640;border-radius:var(--radius-sm);color:#c4b5fd;padding:2px 7px;text-transform:lowercase}.lb-config-health,.lb-config-mode{display:inline-block;font-family:Geist Mono,monospace;font-size:10px;font-weight:600}.lb-config-health{border-radius:20px;padding:2px 8px}.lb-config-health.enabled{background:#10b9811f;border:1px solid #10b98140;color:#6ee7b7}.lb-config-health.disabled{background:var(--danger-dim);border:1px solid #ef444440;color:#fca5a5}.lb-config-input{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist Mono,monospace;font-size:11px;padding:5px 8px;transition:border-color var(--transition);width:100%}.lb-config-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim);outline:none}.lb-config-select{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:Geist Mono,monospace;font-size:11px;padding:5px 8px;transition:border-color var(--transition);width:100%}.lb-config-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim);outline:none}.lb-config-checkbox{accent-color:var(--accent);cursor:pointer;height:14px;width:14px}.lb-config-actions{gap:5px}.lb-config-actions,.lb-config-btn{display:flex;justify-content:center}.lb-config-btn{align-items:center;border-radius:var(--radius-sm);cursor:pointer;padding:4px;transition:all var(--transition)}.lb-config-btn svg{height:13px;width:13px}.lb-config-btn-edit{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);color:var(--text-secondary)}.lb-config-btn-edit:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border-2);color:var(--text-primary)}.lb-config-btn-save{background:#10b98126;border:1px solid #10b9814d;color:#6ee7b7}.lb-config-btn-save:hover{background:#10b98140;border-color:#10b98180}.lb-config-btn-cancel{background:var(--danger-dim);border:1px solid #ef444459;color:#fca5a5}.lb-config-btn-cancel:hover{background:#ef444440;border-color:#ef44448c}.lb-config-btn-delete{background:var(--danger-dim);border:1px solid #ef444459;color:#fca5a5}.lb-config-btn-delete:hover{background:#ef444440;border-color:#ef44448c;color:#fecaca}.lb-config-modal-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:flex-end;padding:12px 18px}.lb-config-btn-close{background:var(--accent);border:1px solid #0000;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:7px 18px;transition:all var(--transition)}.lb-config-btn-close:hover{background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.lb-config-btn-close:active{transform:scale(.98)}.lb-conn-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.lb-conn-modal{animation:slideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;max-width:500px;overflow:hidden;width:90%}.lb-conn-modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;justify-content:space-between;padding:12px 16px}.lb-conn-modal-header h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;margin:0}.lb-conn-subtitle{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px;font-weight:500;margin:2px 0 0}.lb-conn-modal-close{align-items:center;background:none;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;height:28px;justify-content:center;transition:all var(--transition);width:28px}.lb-conn-modal-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.lb-conn-modal-body{padding:16px}.lb-conn-info{background:#f59e0b12;border:1px solid #f59e0b40;border-radius:var(--radius-md);margin-bottom:14px;padding:10px 12px}.lb-conn-info p{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;margin:3px 0}.lb-conn-info strong{color:#fcd34d}.lb-conn-form-group{margin-bottom:14px}.lb-conn-form-group label{color:var(--text-secondary);display:block;font-family:Geist,sans-serif;font-size:10px;font-weight:600;letter-spacing:.05em;margin-bottom:5px;text-transform:uppercase}.lb-conn-form-group input[type=number],.lb-conn-form-group input[type=text]{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;padding:8px 10px;transition:border-color var(--transition);width:100%}.lb-conn-form-group input:focus{border-color:#f59e0b80;box-shadow:0 0 0 3px #f59e0b14;outline:none}.lb-conn-form-group input.error{border-color:#ef444499}.lb-conn-error{color:#fca5a5}.lb-conn-error,.lb-conn-hint{display:block;font-family:Geist Mono,monospace;font-size:11px;margin-top:3px}.lb-conn-hint{color:var(--text-muted)}.lb-conn-select{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:500;padding:8px 10px;transition:border-color var(--transition);width:100%}.lb-conn-select:focus{border-color:#f59e0b80;box-shadow:0 0 0 3px #f59e0b14;outline:none}.lb-conn-checkbox-label{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:8px}.lb-conn-checkbox{accent-color:#f59e0b;cursor:pointer;height:16px;width:16px}.lb-conn-info-box{background:#f59e0b12;border:1px solid #f59e0b40;border-radius:var(--radius-md);margin-bottom:14px;padding:10px 12px}.lb-conn-info-box p{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;margin:0}.lb-conn-info-box strong{color:#fcd34d}.lb-conn-preview{color:#fcd34d!important;font-family:Geist Mono,monospace!important;font-size:12px!important;font-weight:600;margin-top:5px!important}.lb-conn-modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:14px}.lb-conn-btn-primary,.lb-conn-btn-secondary{align-items:center;border-radius:var(--radius-md);cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:5px;padding:7px 16px;transition:all var(--transition)}.lb-conn-btn-secondary{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);color:var(--text-secondary)}.lb-conn-btn-secondary:hover:not(:disabled){background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.lb-conn-btn-primary{background:#f59e0b33;border:1px solid #f59e0b66;color:#fcd34d}.lb-conn-btn-primary:hover:not(:disabled){background:#f59e0b4d;border-color:#f59e0b99;box-shadow:0 4px 12px #f59e0b33}.lb-conn-btn-primary:disabled,.lb-conn-btn-secondary:disabled{cursor:not-allowed;opacity:.4}.lb-conn-spinner{animation:lbConnSpin .6s linear infinite;border:2px solid #f59e0b4d;border-radius:50%;border-top-color:#fcd34d;height:13px;width:13px}@keyframes lbConnSpin{to{transform:rotate(1turn)}}.duration-selector-overlay{align-items:center;animation:dsFadeIn .2s ease-in;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}@keyframes dsFadeIn{0%{opacity:0}to{opacity:1}}.duration-selector-modal{animation:dsSlideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;max-height:90vh;max-width:550px;overflow-y:auto;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin;width:90%}@keyframes dsSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.duration-selector-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;justify-content:space-between;padding:12px 14px}.duration-selector-header h3{color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin:0}.close-btn{font-size:18px;height:26px;width:26px}.duration-selector-body{padding:12px 14px}.configuration-summary{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);margin-bottom:10px;padding:8px 10px}.configuration-summary h4{color:var(--text-muted);font-family:Geist,sans-serif;font-size:9px;font-weight:600;letter-spacing:.05em;margin:0 0 5px;text-transform:uppercase}.config-details{grid-gap:3px;display:grid;gap:3px;grid-template-columns:repeat(2,1fr)}.config-details span{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:10px}.config-details strong{color:var(--text-primary)}.pricing-info{background:var(--accent-dim);border-left:2px solid var(--accent);border-radius:var(--radius-sm);margin-bottom:10px;padding:7px 10px}.price-row{align-items:center;color:var(--text-secondary);display:flex;font-family:Geist,sans-serif;font-size:11px;justify-content:space-between}.price-row strong{color:var(--text-accent);font-family:Geist Mono,monospace;font-size:12px}.duration-options h4{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:11px;font-weight:600;margin:0 0 7px}.duration-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(4,1fr);margin-bottom:10px}.duration-option{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);cursor:pointer;padding:8px 6px;position:relative;text-align:center;transition:all var(--transition)}.duration-option.selected,.duration-option:hover:not(.disabled){background:var(--accent-dim);border-color:var(--accent)}.duration-option.selected{box-shadow:0 0 0 2px #2563eb26}.duration-option.disabled{cursor:not-allowed;opacity:.4}.duration-name{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:10px;font-weight:600;margin-bottom:3px}.duration-price{color:var(--text-accent);font-family:Geist Mono,monospace;font-size:11px;font-weight:700}.insufficient-badge{background:var(--danger-dim);border-radius:3px;color:#fca5a5;font-family:Geist Mono,monospace;font-size:8px;font-weight:600;padding:1px 4px;position:absolute;right:3px;top:3px}.total-pricing{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);padding:8px 10px}.total-row{align-items:center;color:var(--text-secondary);display:flex;font-family:Geist,sans-serif;font-size:10px;justify-content:space-between;padding:3px 0}.total-row.highlight{border-top:1px solid var(--cloud-border-2);font-size:11px;margin-top:4px;padding-top:6px}.total-row.highlight strong{color:var(--text-accent);font-family:Geist Mono,monospace;font-size:13px}.text-success{color:#6ee7b7!important}.text-danger{color:#fca5a5!important}.insufficient-warning{background:var(--danger-dim);border-left:2px solid #ef444480;border-radius:var(--radius-sm);color:#fca5a5;font-family:Geist,sans-serif;font-size:10px;font-weight:500;margin-top:7px;padding:7px 10px}.network-node-info{align-items:center;background:#10b98112;border:1px solid #10b98140;border-radius:var(--radius-sm);display:flex;gap:8px;padding:8px 10px}.info-icon{font-size:16px}.network-node-info p{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:10px;line-height:1.4;margin:0}.duration-selector-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;gap:6px;justify-content:flex-end;padding:10px 14px}.btn-cancel,.btn-confirm{border-radius:var(--radius-md);cursor:pointer;font-family:Geist,sans-serif;font-size:12px;font-weight:600;padding:6px 14px;transition:all var(--transition)}.btn-confirm{background:var(--accent);border:1px solid #0000;color:#fff}.btn-confirm:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2563eb4d}.btn-confirm:disabled{cursor:not-allowed;opacity:.4}.modal-overlay{background:#000000bf}.database-config-modal{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden;position:relative;width:600px}.modal-header{flex-shrink:0}.modal-title{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;gap:8px}.modal-close,.modal-title{align-items:center;display:flex}.modal-close{background:none;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;justify-content:center;padding:4px;transition:all var(--transition)}.modal-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.modal-body{flex:1 1;overflow-y:auto;padding:14px 16px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.form-group{margin-bottom:12px}.form-group:last-child{margin-bottom:0}.form-row{gap:10px;margin-bottom:12px}.form-group-half{flex:1 1;margin-bottom:0}.form-label{color:var(--text-secondary);display:block;font-family:Geist,sans-serif;font-size:10px;font-weight:600;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.db-type-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(2,1fr)}.db-type-card{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:8px 6px;transition:all var(--transition)}.db-type-card.selected,.db-type-card:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--text-accent)}.db-type-card.selected{box-shadow:0 0 0 1px var(--accent)}.db-type-card svg{height:18px;width:18px}.db-type-name{font-size:10px;font-weight:600;line-height:1.2;text-align:center}.db-type-name,.form-select{font-family:Geist,sans-serif}.form-select{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:12px;padding:7px 10px;transition:border-color var(--transition);width:100%}.form-select:hover{border-color:var(--cloud-border-2)}.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.form-input{font-size:12px;padding:7px 10px;transition:border-color var(--transition)}.form-input:hover{border-color:var(--cloud-border-2)}.form-hint,.form-input::placeholder{color:var(--text-muted)}.form-hint{font-family:Geist Mono,monospace;font-size:10px;margin-top:5px}.config-summary-compact{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);margin-bottom:10px;padding:8px 10px}.config-summary-compact h4{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:10px;font-weight:600;letter-spacing:.05em;margin:0 0 6px;text-transform:uppercase}.config-summary-compact .summary-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:1fr}.config-summary-compact .summary-item{align-items:center;display:flex;justify-content:space-between}.config-summary-compact .summary-label{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:500}.config-summary-compact .summary-value{color:var(--text-primary);font-family:Geist Mono,monospace;font-size:11px;font-weight:600}.modal-footer{flex-shrink:0;gap:8px;padding:10px 16px}.btn-primary{font-size:12px}.btn-primary:active{transform:scale(.98)}.size-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(3,1fr)}.size-card{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:8px;text-align:left;transition:all var(--transition)}.size-card.selected,.size-card:hover{background:var(--accent-dim);border-color:var(--accent)}.size-card.selected{box-shadow:0 0 0 1px var(--accent)}.size-name{border-bottom:1px solid var(--cloud-border);color:var(--text-primary);font-family:Geist,sans-serif;font-size:10px;font-weight:700;padding-bottom:3px;text-align:center}.size-specs{display:flex;flex-direction:column;gap:2px}.spec-item{font-size:9px;justify-content:space-between}.spec-value{background:var(--accent-dim);border:1px solid #2563eb33;border-radius:3px;color:var(--text-accent);font-size:9px;padding:1px 4px}.database-details-modal{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden;position:relative;width:550px}.database-details-modal .modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;justify-content:space-between;padding:12px 16px}.database-details-modal .modal-title{align-items:center;color:var(--text-primary);display:flex;font-family:Geist,sans-serif;font-size:14px;font-weight:600;gap:8px}.database-details-modal .modal-title svg{color:var(--accent)}.database-details-modal .modal-close{align-items:center;background:none;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all var(--transition)}.database-details-modal .modal-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.database-details-modal .modal-body{flex:1 1;overflow-y:auto;padding:14px 16px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.db-info-section{margin-bottom:14px}.db-info-section:last-child{margin-bottom:0}.section-title{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:10px;font-weight:600;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.info-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(2,1fr)}.info-item{padding:7px 10px}.info-label{margin-bottom:3px}.info-label,.info-value{display:block}.info-value.monospace{font-family:Geist Mono,monospace}.info-value.status-running{color:#6ee7b7}.info-value.status-stopped{color:#fca5a5}.info-value.status-restarting,.info-value.status-starting,.info-value.status-stopping{color:#fcd34d}.info-field{margin-bottom:10px}.info-field:last-child{margin-bottom:0}.field-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:5px}.field-label{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.field-actions{display:flex;gap:5px}.copy-button,.toggle-button{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:3px 7px;transition:all var(--transition)}.copy-button:hover,.toggle-button:hover{background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.copy-button:active,.toggle-button:active{transform:scale(.95)}.field-value{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:Geist Mono,monospace;font-size:11px;padding:7px 10px;word-break:break-all}.field-value.monospace{font-family:Geist Mono,monospace;font-weight:600}.field-value.connection-string{font-size:10px;line-height:1.5}.database-details-modal .modal-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;gap:8px;justify-content:flex-end;padding:10px 16px}.btn-secondary{font-size:12px}.btn-secondary:active{transform:scale(.98)}.cluster-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.cluster-modal{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:95vw;overflow:hidden;width:900px}.cluster-modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 20px}.cluster-modal-title{align-items:center;color:#6ee7b7;display:flex;gap:10px}.cluster-modal-title h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}.cluster-modal-close{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:5px;transition:all var(--transition)}.cluster-modal-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.cluster-modal-body{flex:1 1;overflow-y:auto;padding:20px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.cluster-info{background:#10b98112;border:1px solid #10b98140;border-radius:var(--radius-md);margin-bottom:18px;padding:12px 14px}.cluster-info p{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:13px;margin:0 0 6px}.cluster-info p:last-child{margin-bottom:0}.cluster-hint{color:#6ee7b7!important;font-family:Geist Mono,monospace!important;font-size:12px!important}.cluster-name-section{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.cluster-name-section label{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.cluster-name-input{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:500;padding:9px 12px;transition:border-color var(--transition),box-shadow var(--transition)}.cluster-name-input:focus{border-color:#10b98180;box-shadow:0 0 0 3px #10b9811a;outline:none}.cluster-name-input::placeholder{color:var(--text-muted)}.cluster-duration-section{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.cluster-duration-section label{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.cluster-duration-select{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:500;padding:9px 12px;transition:border-color var(--transition)}.cluster-duration-select:focus{border-color:#10b98180;box-shadow:0 0 0 3px #10b9811a;outline:none}.cluster-duration-hint{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px;margin:3px 0 0}.cluster-nodes-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.cluster-node-card{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);padding:14px;transition:all var(--transition)}.cluster-node-card:hover{border-color:#10b98166;box-shadow:0 0 0 1px #10b9811a}.cluster-node-header{align-items:center;border-bottom:1px solid var(--cloud-border);display:flex;gap:10px;margin-bottom:12px;padding-bottom:10px}.cluster-node-number{align-items:center;color:var(--text-secondary);display:flex;flex:1 1;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:7px}.cluster-node-role{border-radius:20px;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;padding:2px 10px;text-transform:uppercase}.cluster-node-role.master{background:#10b9811f;border:1px solid #10b9814d;color:#6ee7b7}.cluster-node-role.worker{background:var(--accent-dim);border:1px solid #2563eb4d;color:var(--text-accent)}.cluster-node-remove{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;padding:4px;transition:all var(--transition)}.cluster-node-remove:hover{background:var(--danger-dim);border-color:#ef444459;color:#fca5a5}.cluster-node-config{display:flex;flex-direction:column;gap:10px}.cluster-config-field{display:flex;flex-direction:column;gap:5px}.cluster-config-field label{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.cluster-config-field input,.cluster-config-field select{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;padding:8px 10px;transition:border-color var(--transition)}.cluster-config-field input:focus,.cluster-config-field select:focus{border-color:#10b98180;box-shadow:0 0 0 3px #10b98114;outline:none}.cluster-node-specs{border-top:1px solid var(--cloud-border);display:flex;flex-wrap:wrap;gap:8px;margin-top:6px;padding-top:10px}.cluster-node-specs span{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px;padding:3px 9px}.cluster-node-price{background:#10b9811a!important;border-color:#10b98140!important;color:#6ee7b7!important;font-weight:600!important;margin-left:auto}.cluster-add-node-btn{align-items:center;background:#0000;border:1px dashed var(--cloud-border-2);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:7px;justify-content:center;padding:12px;transition:all var(--transition);width:100%}.cluster-add-node-btn:hover{background:#10b9810d;border-color:#10b98180;color:#6ee7b7}.cluster-summary{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);margin-top:18px;padding:12px 14px}.cluster-summary-row{align-items:center;color:var(--text-secondary);display:flex;font-family:Geist,sans-serif;font-size:13px;justify-content:space-between;padding:6px 0}.cluster-summary-row:not(:last-child){border-bottom:1px solid var(--cloud-border)}.cluster-summary-row strong{color:#6ee7b7;font-family:Geist Mono,monospace;font-size:14px}.cluster-summary-row strong.insufficient{color:#fca5a5}.cluster-insufficient-warning{background:var(--danger-dim);border:1px solid #ef44444d;border-radius:var(--radius-sm);color:#fca5a5;font-family:Geist,sans-serif;font-size:12px;margin-top:10px;padding:10px 12px;text-align:center}.cluster-modal-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;gap:10px;justify-content:flex-end;padding:14px 20px}.cluster-btn-cancel,.cluster-btn-confirm{border-radius:var(--radius-md);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:8px 20px;transition:all var(--transition)}.cluster-btn-cancel{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);color:var(--text-secondary)}.cluster-btn-cancel:hover{background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.cluster-btn-confirm{background:#10b98133;border:1px solid #10b98166;color:#6ee7b7}.cluster-btn-confirm:hover:not(:disabled){background:#10b9814d;border-color:#10b98199;box-shadow:0 4px 12px #10b98133}.cluster-btn-confirm:disabled{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-muted);cursor:not-allowed}.cluster-details-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.cluster-details-modal{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:95vw;overflow:hidden;width:800px}.cluster-details-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 20px}.cluster-details-title{align-items:center;color:#6ee7b7;display:flex;gap:10px}.cluster-details-title h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}.cluster-id{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px}.cluster-details-close{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:5px;transition:all var(--transition)}.cluster-details-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.cluster-details-body{flex:1 1;overflow-y:auto;padding:18px 20px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.cluster-info-section{margin-bottom:18px}.cluster-ssh-section{background:#10b9810f;border:1px solid #10b98133;border-radius:var(--radius-md);margin-bottom:18px;padding:14px}.cluster-ssh-section h3{color:#6ee7b7;font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin:0 0 12px}.ssh-access-box{display:flex;flex-direction:column;gap:12px}.ssh-info-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr)}.ssh-info-item{gap:3px}.ssh-command-box,.ssh-info-item{display:flex;flex-direction:column}.ssh-command-box{gap:6px}.ssh-command{align-items:center;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;gap:8px;padding:10px 12px}.ssh-command code{color:#6ee7b7;flex:1 1;font-family:Geist Mono,monospace;font-size:12px;word-break:break-all}.copy-ssh-btn{background:#10b9811a;border:1px solid #10b9814d;border-radius:var(--radius-sm);color:#6ee7b7;cursor:pointer;font-family:Geist,sans-serif;font-size:13px;padding:4px 10px;transition:all var(--transition)}.copy-ssh-btn:hover{background:#10b98133;border-color:#10b98180}.ssh-hint{background:#10b98112;border-left:2px solid #10b98180;border-radius:var(--radius-sm);color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;padding:8px 10px}.cluster-remote-section{background:var(--accent-dim);border:1px solid #2563eb33;border-radius:var(--radius-md);margin-bottom:18px;padding:14px}.cluster-remote-section h3{color:var(--text-accent);font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin:0 0 12px}.cluster-remote-section h4{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;font-weight:600;margin:12px 0 6px}.remote-access-box,.remote-instructions{display:flex;flex-direction:column;gap:10px}.download-certs-btn{background:var(--accent);border:1px solid #0000;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin-bottom:6px;padding:8px 16px;transition:all var(--transition)}.download-certs-btn:hover{background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.code-block{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:#6ee7b7;font-family:Geist Mono,monospace;font-size:11px;line-height:1.6;padding:10px 12px;position:relative}.code-block code{display:block}.copy-code-btn{background:#10b98126;border:1px solid #10b9814d;border-radius:var(--radius-sm);color:#6ee7b7;cursor:pointer;font-family:Geist,sans-serif;font-size:11px;padding:3px 8px;position:absolute;right:6px;top:6px;transition:all var(--transition)}.copy-code-btn:hover{background:#10b98140;border-color:#10b98180}.remote-info{background:#2563eb14;border-left:2px solid #2563eb66;border-radius:var(--radius-sm);margin-top:6px;padding:10px 12px}.remote-info p{color:var(--text-secondary);margin:0 0 6px}.remote-info p,.remote-info ul{font-family:Geist,sans-serif;font-size:12px}.remote-info ul{color:var(--text-muted);margin:0;padding-left:16px}.remote-info li{margin:3px 0}.remote-warning{background:#f59e0b14;border-left:2px solid #f59e0b80;border-radius:var(--radius-sm);color:#fcd34d;font-family:Geist,sans-serif;font-size:12px;margin-top:6px;padding:10px 12px}.cluster-info-section h3{color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin:0 0 12px}.cluster-info-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.cluster-info-item{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:5px;padding:12px}.info-value{font-size:15px}.status-badge{gap:5px}.cluster-nodes-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.cluster-nodes-section h3{color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin:0}.cluster-add-node-btn-small{align-items:center;background:#10b98126;border:1px solid #10b9814d;border-radius:var(--radius-md);color:#6ee7b7;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:12px;font-weight:600;gap:5px;padding:5px 12px;transition:all var(--transition)}.cluster-add-node-btn-small:hover{background:#10b98140;border-color:#10b98180;box-shadow:0 4px 12px #10b98126}.cluster-add-node-form{animation:slideDown .2s ease-out;background:var(--cloud-surface-2);border:1px solid #10b98166;border-radius:var(--radius-md);margin-bottom:12px;padding:12px 14px}.cluster-add-node-form h4{color:#6ee7b7;font-family:Geist,sans-serif;font-size:12px;font-weight:600;margin:0 0 10px}.add-node-form-content{display:flex;flex-direction:column;gap:10px}.add-node-field{display:flex;flex-direction:column;gap:5px}.add-node-field label{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.add-node-field select{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist,sans-serif;font-size:12px;padding:8px 10px;transition:border-color var(--transition)}.add-node-field select:focus{border-color:#10b98180;box-shadow:0 0 0 3px #10b98114;outline:none}.add-node-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:3px}.add-node-cancel,.add-node-confirm{border-radius:var(--radius-md);cursor:pointer;font-family:Geist,sans-serif;font-size:12px;font-weight:600;padding:6px 14px;transition:all var(--transition)}.add-node-cancel{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);color:var(--text-secondary)}.add-node-cancel:hover{background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.add-node-confirm{background:#10b98133;border:1px solid #10b98166;color:#6ee7b7}.add-node-confirm:hover{background:#10b9814d;border-color:#10b98199}.cluster-nodes-list-details{display:flex;flex-direction:column;gap:10px}.no-nodes-message{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;font-family:Geist,sans-serif;justify-content:center;padding:40px 24px;text-align:center}.no-nodes-message svg{margin-bottom:12px;opacity:.4}.cluster-node-item{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition)}.cluster-node-item:hover{border-color:#10b98166}.cluster-node-item-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:12px 14px;-webkit-user-select:none;user-select:none}.cluster-node-item-info{align-items:center;display:flex;flex:1 1;gap:10px}.cluster-node-item-text{display:flex;flex-direction:column;gap:3px}.cluster-node-item-label{color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;font-weight:600}.cluster-node-item-role{border-radius:20px;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;padding:1px 8px;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.cluster-node-item-role.master{background:#10b9811f;border:1px solid #10b9814d;color:#6ee7b7}.cluster-node-item-role.worker{background:var(--accent-dim);border:1px solid #2563eb4d;color:var(--text-accent)}.cluster-node-item-actions{align-items:center;display:flex;gap:10px}.cluster-node-item-status{align-items:center;display:flex;font-family:Geist Mono,monospace;font-size:12px;font-weight:500;gap:5px}.cluster-node-item-details{animation:slideDown .2s ease-out;border-top:1px solid var(--cloud-border);padding:0 14px 14px}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.node-specs-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));margin-bottom:12px;margin-top:12px}.node-spec-item{align-items:center;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-secondary);display:flex;font-family:Geist Mono,monospace;font-size:12px;gap:7px;padding:7px 10px}.node-spec-item svg{color:#6ee7b7}.node-additional-info{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:6px;padding:10px 12px}.node-info-row{align-items:center;display:flex;font-size:12px;justify-content:space-between}.node-info-label{color:var(--text-muted);font-family:Geist Mono,monospace;font-weight:500}.node-info-value{color:var(--text-secondary);font-family:Geist Mono,monospace}.cluster-details-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:flex-end;padding:12px 20px}.cluster-btn-close{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:7px 18px;transition:all var(--transition)}.cluster-btn-close:hover{background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.microk8s-details-modal-overlay{align-items:center;animation:k8sFadeIn .2s ease-in-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}@keyframes k8sFadeIn{0%{opacity:0}to{opacity:1}}.microk8s-details-modal{animation:k8sSlideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;max-height:90vh;max-width:620px;min-width:580px;overflow-y:auto;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin;width:-webkit-fit-content;width:fit-content}@keyframes k8sSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:12px 16px}.header-content{gap:3px}.modal-header h2{align-items:center;color:var(--text-primary);display:flex;font-family:Geist,sans-serif;font-size:14px;gap:6px}.cluster-name{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:400;margin:0}.close-button{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;height:28px;justify-content:center;transition:all var(--transition);width:28px}.close-button:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.modal-content{padding:14px 16px}.master-card{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);margin-bottom:10px;overflow:hidden}.card-header{background:var(--cloud-surface-3);border-bottom:1px solid var(--cloud-border);justify-content:space-between;padding:8px 12px}.card-header,.card-header h3{align-items:center;display:flex}.card-header h3{color:var(--text-accent);font-family:Geist,sans-serif;font-size:12px;font-weight:600;gap:5px;margin:0}.card-body{padding:10px 12px}.info-grid{grid-gap:6px!important;display:grid!important;gap:6px!important}.info-item{background:var(--cloud-surface);padding:8px 10px;text-align:center}.info-label{font-size:9px;letter-spacing:.06em}.info-value{color:var(--text-primary)}.workers-section{margin-bottom:10px}.section-header{margin-bottom:8px}.header-left{gap:10px}.header-left h3{align-items:center;display:flex;font-family:Geist,sans-serif;font-size:13px;gap:5px;margin:0}.header-left h3,.worker-count{color:var(--text-accent);font-weight:600}.worker-count{background:var(--accent-dim);border:1px solid #2563eb4d;border-radius:10px;font-family:Geist Mono,monospace;font-size:10px;padding:2px 8px}.add-worker-card{background:var(--accent-dim);border:1px dashed #2563eb66;border-radius:var(--radius-md);margin-bottom:8px;padding:10px 12px}.add-worker-header{margin-bottom:6px}.add-worker-title{color:var(--text-accent);font-family:Geist,sans-serif;font-size:12px;font-weight:600}.add-worker-body{display:flex;flex-direction:column;gap:8px}.form-group label{color:var(--text-muted)}.size-select{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-family:Geist,sans-serif;font-size:12px;padding:7px 10px;transition:border-color var(--transition)}.size-select:hover:not(:disabled){border-color:var(--accent)}.size-select:disabled{cursor:not-allowed;opacity:.4}.add-worker-button{align-items:center;background:var(--accent);border:1px solid #0000;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:12px;font-weight:600;gap:5px;justify-content:center;padding:7px 14px;transition:all var(--transition)}.add-worker-button:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2563eb4d}.add-worker-button:disabled{cursor:not-allowed;opacity:.4}.spinner{animation:k8sSpin .7s linear infinite;height:12px;width:12px}@keyframes k8sSpin{to{transform:rotate(1turn)}}.empty-state{background:var(--cloud-surface-2);border:1px dashed var(--cloud-border-2);border-radius:var(--radius-md);padding:20px 16px}.empty-icon{font-size:28px;margin-bottom:6px}.empty-title{color:var(--text-secondary);font-size:13px;font-weight:600;margin:0 0 3px}.empty-hint,.empty-title{font-family:Geist,sans-serif}.empty-hint{font-size:11px;line-height:1.4;margin:0}.workers-list{display:flex;flex-direction:column;gap:8px}.worker-card{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition)}.worker-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #2563eb1a}.worker-card-header{align-items:center;background:var(--cloud-surface-3);border-bottom:1px solid var(--cloud-border);display:flex;justify-content:space-between;padding:7px 10px}.worker-info{align-items:center;display:flex;gap:7px}.worker-label{color:var(--text-muted);font-size:9px;letter-spacing:.05em;text-transform:uppercase}.worker-id-short,.worker-label{font-family:Geist Mono,monospace}.worker-id-short{color:var(--text-accent);font-size:11px;font-weight:600}.worker-card-body{padding:10px 12px}.worker-specs{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));margin-bottom:8px}.spec-item{background:var(--cloud-surface);flex-direction:column;gap:2px;padding:5px 7px}.spec-icon{font-size:12px}.spec-label{font-size:9px;letter-spacing:.05em;text-transform:uppercase}.spec-value{color:var(--text-primary);font-family:Geist Mono,monospace;font-size:11px;font-weight:600}.worker-actions{border-top:1px solid var(--cloud-border);display:flex;justify-content:flex-end;padding-top:7px}.delete-worker-button{align-items:center;background:var(--danger-dim);border:1px solid #ef44444d;border-radius:var(--radius-sm);color:#fca5a5;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:11px;font-weight:500;gap:4px;padding:4px 10px;transition:all var(--transition)}.delete-worker-button:hover:not(:disabled){background:#ef444433;border-color:#ef444480}.delete-worker-button:disabled{cursor:not-allowed;opacity:.4}.delete-icon{font-size:11px}.status-badge{font-size:9px}.status-active{background:#10b9811f;border:1px solid #10b9814d;color:#6ee7b7}.status-provisioning{animation:k8sPulse 2s infinite;background:#f59e0b1f;border:1px solid #f59e0b4d;color:#fcd34d}.status-error{background:var(--danger-dim);border:1px solid #ef44444d;color:#fca5a5}.status-deleting{animation:k8sPulse 2s infinite;background:#8b5cf61f;border:1px solid #8b5cf64d;color:#c4b5fd}.status-unknown{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);color:var(--text-muted)}.info-banner{align-items:flex-start;background:var(--accent-dim);border:1px solid #2563eb40;border-radius:var(--radius-md);display:flex;gap:7px;padding:8px 10px}.info-icon{flex-shrink:0;font-size:13px}.info-content{flex:1 1}.info-title{color:var(--text-accent);font-weight:600;margin:0 0 2px}.info-text,.info-title{font-family:Geist,sans-serif;font-size:11px}.info-text{color:var(--text-secondary);line-height:1.4;margin:0}.error-message{gap:7px;margin:8px 14px;padding:8px 10px}@keyframes k8sPulse{0%,to{opacity:1}50%{opacity:.5}}.microk8s-details-modal::-webkit-scrollbar{width:6px}.microk8s-details-modal::-webkit-scrollbar-track{background:#0000}.microk8s-details-modal::-webkit-scrollbar-thumb{background:var(--cloud-border-2);border-radius:3px}.microk8s-details-modal::-webkit-scrollbar-thumb:hover{background:var(--cloud-border)}.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{border:0;height:0;left:-9999em;margin:0;opacity:0;overflow:hidden;padding:0;position:absolute;resize:none;top:0;white-space:nowrap;width:0;z-index:-5}.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;bottom:0;cursor:default;left:0;overflow-y:scroll;position:absolute;right:0;top:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{left:0;position:absolute;top:0}.xterm .xterm-scroll-area{visibility:hidden}.xterm-char-measure-element{display:inline-block;left:-9999em;line-height:normal;position:absolute;top:0;visibility:hidden}.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{bottom:0;color:#0000;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.xterm .live-region{height:1px;left:-9999px;overflow:hidden;position:absolute;width:1px}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{-webkit-text-decoration:double underline;text-decoration:double underline}.xterm-underline-3{-webkit-text-decoration:wavy underline;text-decoration:wavy underline}.xterm-underline-4{-webkit-text-decoration:dotted underline;text-decoration:dotted underline}.xterm-underline-5{-webkit-text-decoration:dashed underline;text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{-webkit-text-decoration:overline double underline;text-decoration:overline double underline}.xterm-overline.xterm-underline-3{-webkit-text-decoration:overline wavy underline;text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{-webkit-text-decoration:overline dotted underline;text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{-webkit-text-decoration:overline dashed underline;text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{position:absolute;z-index:6}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{pointer-events:none;position:absolute;right:0;top:0;z-index:8}.xterm-decoration-top{position:relative;z-index:2}.console-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.console-modal-overlay.fullscreen{padding:0}.console-modal{background:#0d1117;border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000c;display:flex;flex-direction:column;height:600px;max-height:90vh;max-width:95vw;overflow:hidden;transition:all .2s ease;width:900px}.console-modal.fullscreen{border:none;border-radius:0;height:100vh;max-height:100vh;max-width:100vw;width:100vw}.console-header{background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);flex-shrink:0;justify-content:space-between;padding:10px 16px}.console-header,.console-title{align-items:center;display:flex}.console-title{color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:8px}.console-title svg{color:#6ee7b7}.console-node-id{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px;font-weight:400}.console-actions{display:flex;gap:4px}.console-action-btn,.console-close-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:5px;transition:all var(--transition)}.console-action-btn:hover,.console-close-btn:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.console-body{background:#0d1117;flex:1 1;overflow:hidden;position:relative}.console-terminal{box-sizing:border-box;height:100%;padding:10px;width:100%}.console-status,.console-terminal{display:flex;flex-direction:column}.console-status{align-items:center;color:var(--text-muted);font-family:Geist Mono,monospace;font-size:13px;gap:16px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.console-spinner{animation:consoleSpin .8s linear infinite;border:2px solid var(--cloud-border);border-radius:50%;border-top:2px solid #6ee7b7;height:36px;width:36px}@keyframes consoleSpin{to{transform:rotate(1turn)}}.console-error{background:var(--danger-dim);border:1px solid #ef44444d;border-radius:var(--radius-md);color:#fca5a5;font-family:Geist Mono,monospace;font-size:13px;left:50%;padding:14px 22px;position:absolute;top:50%;transform:translate(-50%,-50%)}.console-terminal .xterm{height:100%;padding:0}.console-terminal .xterm-viewport{overflow-y:auto!important}.console-terminal .xterm-screen{height:100%}.browser-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.browser-modal-container{background:#0d1117;border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000e6;display:flex;flex-direction:column;height:95vh;max-height:1000px;max-width:1800px;overflow:hidden;width:95vw}.browser-modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:10px 16px}.browser-modal-title{align-items:center;color:var(--text-primary);display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:8px}.browser-icon{font-size:18px}.browser-modal-actions{align-items:center;display:flex;gap:6px}.browser-new-tab,.browser-url-copy{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:12px;font-weight:500;gap:5px;padding:5px 10px;transition:all var(--transition)}.browser-new-tab:hover,.browser-url-copy:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--text-accent)}.browser-modal-close{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;height:28px;justify-content:center;transition:all var(--transition);width:28px}.browser-modal-close:hover{background:var(--danger-dim);border-color:#ef444459;color:#fca5a5}.browser-modal-info{background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-direction:column;flex-shrink:0;gap:5px;padding:10px 16px}.info-item{font-size:12px;gap:10px}.info-label{font-weight:500;min-width:80px}.info-value{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);font-size:11px;padding:2px 7px}.info-link{color:var(--text-accent);font-family:Geist Mono,monospace;font-size:11px;text-decoration:none;transition:color var(--transition)}.info-link:hover{color:#93c5fd;text-decoration:underline}.info-security{background:#10b98114;border-left:2px solid #10b98180;border-radius:var(--radius-sm);color:#6ee7b7;font-family:Geist,sans-serif;font-size:11px;margin-top:2px;padding:5px 10px}.browser-modal-content{background:#000;flex:1 1;overflow:hidden;padding:0}.browser-iframe{background:#fff;border:none;height:100%;width:100%}.browser-loading-container{align-items:center;background:#0d1117;display:flex;height:100%;justify-content:center;width:100%}.browser-loading-content{align-items:center;display:flex;flex-direction:column;gap:16px;max-width:500px;padding:40px;text-align:center}.loading-spinner{animation:browserSpin .7s linear infinite;color:var(--accent)}@keyframes browserSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.progress-bar-container{gap:6px}.loading-steps{display:flex;flex-direction:column;gap:8px;margin-top:16px;width:100%}.loading-step{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-left:2px solid #0000;border-radius:var(--radius-md);display:flex;gap:10px;padding:8px 12px;transition:all var(--transition)}.loading-step.active{background:var(--accent-dim);border-left-color:var(--accent)}.loading-step span{color:var(--text-muted);flex:1 1;font-family:Geist,sans-serif;font-size:12px}.loading-step.active span{color:var(--text-primary);font-weight:500}.step-icon{align-items:center;background:#10b98133;border:1px solid #10b9814d;border-radius:50%;color:#6ee7b7;display:flex;font-size:11px;font-weight:700;height:20px;justify-content:center;width:20px}.step-icon.pending{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-muted)}.step-spinner{flex-shrink:0}.browser-loading-spinner,.step-spinner{animation:browserSpin .7s linear infinite;color:var(--accent)}.browser-ready-icon{animation:scaleIn .3s ease-out;color:#10b981}.browser-error-icon{animation:shake .5s ease-in-out;color:#ef4444}@media (max-width:768px){.browser-modal-container{border-radius:0;height:100vh;max-height:none;max-width:none;width:100vw}.browser-modal-header{align-items:flex-start;flex-direction:column;gap:8px}.browser-modal-actions{justify-content:space-between;width:100%}}.vpc-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.vpc-modal{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden;width:600px}.vpc-modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 20px}.vpc-modal-title{align-items:center;color:#c4b5fd;display:flex;gap:10px}.vpc-modal-title h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}.vpc-modal-close{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:5px;transition:all var(--transition)}.vpc-modal-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.vpc-modal-body{flex:1 1;overflow-y:auto;padding:20px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.vpc-form-group{margin-bottom:18px}.vpc-form-group label{color:var(--text-secondary);display:block;font-family:Geist,sans-serif;font-size:11px;font-weight:600;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.vpc-form-group input{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);font-family:Geist Mono,monospace;font-size:13px;padding:9px 12px;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.vpc-form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.vpc-form-group input.error{border-color:#ef444499}.vpc-form-group input.error:focus{box-shadow:0 0 0 3px var(--danger-dim)}.error-message,.help-text{display:block;margin-top:4px}.help-text{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px}.vpc-info-box{background:#8b5cf614;border:1px solid #8b5cf640;border-radius:var(--radius-md);padding:10px 14px}.vpc-info-box p{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;line-height:1.6;margin:0}.vpc-info-box p+p{margin-top:6px}.vpc-dhcp-range{align-items:flex-start;display:flex;gap:10px}.vpc-dhcp-input{flex:1 1}.vpc-dhcp-input label{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;margin-bottom:4px;text-transform:uppercase}.vpc-dhcp-separator{color:var(--text-muted);font-size:16px;font-weight:700;padding-top:28px}.vpc-modal-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;gap:10px;justify-content:flex-end;padding:14px 20px}.vpc-btn{padding:8px 18px}.vpc-btn-secondary{border:1px solid var(--cloud-border)}.vpc-btn-primary{background:var(--accent);border:1px solid #0000;color:#fff}.vpc-btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.vpc-details-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.vpc-details-modal{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:800px;width:90%}.vpc-details-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 20px}.vpc-details-title{align-items:center;color:#c4b5fd;display:flex;font-family:Geist,sans-serif;font-size:15px;font-weight:600;gap:10px}.vpc-details-close{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;height:28px;justify-content:center;transition:all var(--transition);width:28px}.vpc-details-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.vpc-details-body{flex:1 1;overflow-y:auto;padding:18px 20px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.vpc-details-error,.vpc-details-loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;font-family:Geist,sans-serif;gap:12px;justify-content:center;padding:40px}.spinner{animation:vpcSpin .7s linear infinite;border:2px solid var(--cloud-border-2);border-top:2px solid #8b5cf6;height:32px;width:32px}@keyframes vpcSpin{to{transform:rotate(1turn)}}.vpc-details-error{color:#fca5a5}.vpc-details-section{margin-bottom:20px}.vpc-details-section:last-child{margin-bottom:0}.vpc-details-section h3{align-items:center;color:var(--text-primary);display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:7px;margin-bottom:12px}.vpc-info-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.vpc-info-item{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);padding:10px 12px}.vpc-info-item label{color:var(--text-muted);display:block;font-family:Geist Mono,monospace;font-size:10px;letter-spacing:.05em;margin-bottom:5px;text-transform:uppercase}.vpc-info-value{color:var(--text-primary);font-family:Geist Mono,monospace;font-size:14px;font-weight:600}.vpc-leases-table{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);overflow-x:auto;overflow-y:visible}.vpc-leases-table table{border-collapse:collapse;min-width:600px;table-layout:auto;width:100%}.vpc-leases-table thead{background:var(--cloud-surface-3)}.vpc-leases-table th{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.05em;padding:8px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.vpc-leases-table th:first-child{width:35%}.vpc-leases-table th:nth-child(2){width:30%}.vpc-leases-table th:nth-child(3){width:25%}.vpc-leases-table th:nth-child(4){width:10%}.vpc-leases-table td{border-top:1px solid var(--cloud-border);color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;max-width:0;overflow:hidden;padding:9px 14px;text-overflow:ellipsis;word-break:break-all}.vpc-leases-table tbody tr:hover td{background:#8b5cf60f}.vpc-leases-table tbody tr.gateway-row td{background:#8b5cf60a}.ip-address{color:#c4b5fd;font-size:12px;white-space:nowrap}.ip-address,.lease-type{font-family:Geist Mono,monospace;font-weight:600}.lease-type{border-radius:20px;display:inline-block;font-size:10px;letter-spacing:.04em;padding:2px 8px;text-transform:uppercase}.lease-type.gateway{background:#8b5cf626;border:1px solid #8b5cf64d;color:#c4b5fd}.lease-type.dynamic{background:#10b9811f;border:1px solid #10b98140;color:#6ee7b7}.lease-type.static{background:var(--accent-dim);border:1px solid #2563eb4d;color:var(--text-accent)}.vpc-no-leases{align-items:center;background:var(--cloud-surface-2);border:1px dashed var(--cloud-border-2);border-radius:var(--radius-md);color:var(--text-muted);display:flex;font-family:Geist,sans-serif;font-size:13px;gap:10px;justify-content:center;padding:32px}.vpc-details-footer{border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;gap:10px;justify-content:flex-end;padding:12px 20px}.vpc-btn{border:1px solid var(--cloud-border);border-radius:var(--radius-md);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;outline:none;padding:7px 18px;transition:all var(--transition)}.vpc-btn-secondary{background:var(--cloud-surface-3);color:var(--text-secondary)}.vpc-btn-secondary:hover{background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.port-mapping-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.port-mapping-modal{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:700px;width:90%}.port-mapping-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 20px}.port-mapping-header h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}.port-mapping-close{align-items:center;background:none;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;height:28px;justify-content:center;transition:all var(--transition);width:28px}.port-mapping-close:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.port-mapping-body{flex:1 1;overflow-y:auto;padding:20px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.port-mapping-info{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);display:flex;gap:20px;margin-bottom:20px;padding:12px 16px}.info-item{flex-direction:column;gap:3px}.info-label{font-family:Geist Mono,monospace;font-size:10px;letter-spacing:.05em;text-transform:uppercase}.info-value{color:var(--text-accent);font-size:13px;font-weight:600}.port-mapping-form{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);margin-bottom:20px;padding:16px}.port-mapping-form h3{color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin:0 0 14px}.form-row{align-items:center;display:flex;margin-bottom:14px}.form-group{flex:1 1}.form-group input,.form-group label{font-family:Geist Mono,monospace}.form-group input{background:var(--cloud-surface);font-size:12px;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.arrow{color:var(--text-accent);font-size:18px;font-weight:700;margin-top:18px}.btn-add-mapping{background:var(--accent);border:1px solid #0000;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:9px;transition:all var(--transition);width:100%}.btn-add-mapping:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.btn-add-mapping:disabled{cursor:not-allowed;opacity:.4}.port-mapping-list{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);padding:16px}.port-mapping-list h3{color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin:0 0 12px}.no-mappings{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:12px;padding:32px;text-align:center}.mappings-table{overflow-x:auto}.mappings-table table{border-collapse:collapse;width:100%}.mappings-table th{color:var(--text-muted);font-size:10px;font-weight:600;letter-spacing:.05em;text-align:left;text-transform:uppercase}.mappings-table td,.mappings-table th{border-bottom:1px solid var(--cloud-border);font-family:Geist Mono,monospace;padding:8px 10px}.mappings-table td{color:var(--text-secondary);font-size:12px}.mappings-table tbody tr:hover{background:var(--cloud-surface-3)}.btn-delete-mapping{background:var(--danger-dim);border:1px solid #ef444459;border-radius:var(--radius-sm);color:#fca5a5;cursor:pointer;font-size:12px;padding:4px 10px;transition:all var(--transition)}.btn-delete-mapping:hover:not(:disabled){background:#ef444440;border-color:#ef44448c;color:#fecaca}.btn-delete-mapping:disabled{cursor:not-allowed;opacity:.4}.port-mapping-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:flex-end;padding:14px 20px}.btn-close{padding:7px 18px}.domain-modal{max-height:90vh;max-width:700px;overflow-y:auto;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.domain-check-section{display:flex;flex-direction:column;gap:20px}.domain-register-section{display:flex;flex-direction:column;gap:24px}.availability-success{background:#10b9811a;border:1px solid #10b9814d;border-radius:var(--radius-md);color:#6ee7b7;font-weight:600;text-align:center}.availability-success,.domain-unavailable{font-family:Geist,sans-serif;font-size:13px;padding:12px 14px}.domain-unavailable{background:var(--danger-dim);border:1px solid #ef44444d;border-radius:var(--radius-md);color:#fca5a5}.domain-unavailable p{margin:0 0 6px}.domain-unavailable p:last-child{margin:0}.premium-info{color:#fcd34d;font-family:Geist Mono,monospace;font-size:12px}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.form-group.full-width{grid-column:1/-1}.form-group label{font-size:11px}.form-input{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;padding:9px 12px;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.form-input:disabled{background:var(--cloud-surface-2);color:var(--text-muted);cursor:not-allowed}.error-message{border-radius:var(--radius-sm);font-weight:500}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.btn-primary{padding:8px 18px}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.btn-primary:disabled{cursor:not-allowed;opacity:.4}.btn-secondary{font-weight:600;padding:8px 18px}.btn-secondary:hover:not(:disabled){background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.btn-secondary:disabled{cursor:not-allowed;opacity:.4}.vps-config-overlay{align-items:center;animation:fadeIn .15s ease-in;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.vps-config-modal{animation:slideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;width:90%}.vps-config-header{align-items:flex-start;border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 18px}.vps-config-header>div{display:flex;flex-direction:column;gap:6px}.vps-config-header h3{color:var(--text-primary);font-family:Geist,sans-serif;font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}.credit-badge-header{align-items:center;background:#10b98126;border:1px solid #10b9814d;border-radius:20px;color:#6ee7b7;display:inline-flex;font-family:Geist Mono,monospace;font-size:11px;font-weight:600;gap:4px;padding:3px 10px}.credit-badge-header strong{font-weight:700}.vps-config-body{flex:1 1;overflow-y:auto;padding:14px 18px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.config-info{background:var(--accent-dim);border-left:3px solid var(--accent);border-radius:var(--radius-sm);margin-bottom:12px;padding:8px 12px}.config-info p{color:var(--text-accent);font-family:Geist Mono,monospace;font-size:12px;margin:0}.config-section{margin-bottom:14px}.config-section label{color:var(--text-secondary);display:block;font-family:Geist,sans-serif;font-size:11px;font-weight:600;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.config-options{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.config-option{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:Geist Mono,monospace;font-size:11px;font-weight:600;padding:6px 10px;text-align:center;transition:border-color var(--transition),background var(--transition)}.config-option:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border-2);color:var(--text-secondary)}.config-option.selected{background:var(--accent-dim);border-color:var(--accent);color:var(--text-accent)}.config-summary{background:var(--cloud-surface-2)!important;border:1px solid var(--cloud-border)!important;border-radius:var(--radius-sm)!important;margin-top:8px!important;padding:4px 8px!important}.config-summary h4{display:none!important}.summary-grid{display:flex!important;flex-wrap:nowrap!important;gap:0!important}.summary-grid,.summary-item{align-items:center!important}.summary-item{background:#0000!important;border:none!important;border-radius:0!important;border-right:1px solid var(--cloud-border)!important;display:inline-flex!important;gap:3px!important;padding:2px 6px!important}.summary-item:last-child{border-right:none!important}.summary-label{color:var(--text-muted)!important;font-weight:400!important}.summary-label,.summary-value{font-family:Geist Mono,monospace!important;font-size:9px!important}.summary-value{color:var(--text-secondary)!important;font-weight:600!important}.config-os-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.config-os-option{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:8px;padding:8px 12px;text-align:left;transition:border-color var(--transition),background var(--transition)}.config-os-option:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border-2)}.config-os-option.selected{background:var(--accent-dim);border-color:var(--accent)}.config-os-option .os-icon{font-size:18px}.config-os-option .os-label{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:11px;font-weight:600;line-height:1.2}.config-os-option.selected .os-label{color:var(--text-accent)}.vps-config-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:12px 18px}.btn-cancel,.btn-next{border-radius:var(--radius-md);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:8px 18px;transition:all var(--transition)}.btn-next{align-items:center;background:var(--accent);border:1px solid #0000;color:#fff;display:flex;gap:7px}.btn-next:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.btn-next:disabled{cursor:not-allowed;opacity:.4}@media (max-width:768px){.vps-config-modal{max-height:95vh;width:95%}.config-options{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.summary-grid{gap:12px;grid-template-columns:1fr}}.vps-config-modal.category-selection{max-width:900px}.vps-config-modal.offering-selection{max-width:1000px}.category-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:20px}.category-card{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;gap:12px;overflow:hidden;position:relative;transition:border-color var(--transition),box-shadow var(--transition)}.category-card:before{background:linear-gradient(90deg,var(--accent) 0,#6366f1cc 100%);content:"";height:2px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .25s ease}.category-card:hover:before{transform:scaleX(1)}.category-card:hover{border-color:var(--cloud-border-2);box-shadow:0 8px 24px #0006}.category-icon{font-size:36px;margin-bottom:4px}.category-card h4{color:var(--text-primary);font-size:16px;font-weight:700}.category-card h4,.category-description{font-family:Geist,sans-serif;margin:0;text-align:center}.category-description{color:var(--text-muted);flex:1 1;font-size:13px;line-height:1.5}.category-preview{align-items:center;background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:3px;margin-top:4px;padding:10px}.preview-label{color:var(--text-muted);font-size:11px;font-weight:500}.preview-label,.preview-price{font-family:Geist Mono,monospace}.preview-price{color:#6ee7b7;font-size:16px;font-weight:700}.btn-select-category{background:var(--accent);border:1px solid #0000;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin-top:4px;padding:10px;transition:all var(--transition);width:100%}.btn-select-category:hover{background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.offering-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:20px}.offering-card{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;gap:14px;overflow:hidden;padding:18px;position:relative;transition:border-color var(--transition),box-shadow var(--transition)}.offering-card.recommended{border-color:#f59e0b66}.offering-card.recommended:before{background:linear-gradient(90deg,#f59e0b,#fcd34d);content:"";height:2px;left:0;position:absolute;right:0;top:0}.offering-card:hover{border-color:var(--cloud-border-2);box-shadow:0 8px 24px #0006}.offering-card.recommended:hover{border-color:#f59e0b99;box-shadow:0 8px 24px #f59e0b26}.recommended-badge{background:#f59e0b2e;border:1px solid #f59e0b59;border-radius:20px;color:#fcd34d;font-family:Geist Mono,monospace;font-size:10px;font-weight:700;letter-spacing:.05em;padding:2px 10px;position:absolute;right:10px;text-transform:uppercase;top:10px}.offering-header{border-bottom:1px solid var(--cloud-border);display:flex;flex-direction:column;gap:6px;padding-bottom:12px}.offering-header h4{color:var(--text-primary);font-family:Geist,sans-serif;font-size:15px;font-weight:700;margin:0}.offering-price{display:flex;flex-direction:column;gap:2px}.price-amount{color:#6ee7b7;font-size:20px;font-weight:800}.price-amount,.price-unit{font-family:Geist Mono,monospace}.price-unit{color:var(--text-muted);font-size:11px;font-weight:500}.offering-specs{display:flex;flex:1 1;flex-direction:column;gap:8px}.spec-item{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);gap:8px;padding:7px 10px}.spec-icon{font-size:14px}.spec-label{color:var(--text-muted);flex:1 1;font-weight:500}.spec-item strong,.spec-label{font-family:Geist Mono,monospace;font-size:12px}.spec-item strong{color:var(--text-secondary);font-weight:700}.btn-select-offering{background:var(--accent);border:1px solid #0000;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:10px;transition:all var(--transition);width:100%}.btn-select-offering:hover{background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.subtitle{color:var(--text-muted);font-family:Geist,sans-serif;font-size:12px;font-weight:400;margin:4px 0 0}@media (max-width:768px){.vps-config-modal.category-selection,.vps-config-modal.offering-selection{max-width:95%}.category-grid{grid-template-columns:1fr}.offering-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}.vps-details-overlay{align-items:center;animation:fadeIn .15s ease-in;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.vps-details-modal{animation:slideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;max-height:90vh;max-width:700px;overflow-y:auto;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin;width:90%}.vps-details-header{align-items:flex-start;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;justify-content:space-between;padding:18px 22px;position:-webkit-sticky;position:sticky;top:0;z-index:1}.vps-details-header h3{color:var(--text-primary);font-family:Geist,sans-serif;font-size:18px;font-weight:700;letter-spacing:-.02em;margin:0 0 6px}.node-type-label{background:var(--accent-dim);border:1px solid #2563eb4d;border-radius:20px;color:var(--text-accent);display:inline-block;font-family:Geist Mono,monospace;font-size:11px;font-weight:600;letter-spacing:.04em;padding:2px 10px;text-transform:uppercase}.vps-details-header .close-btn{align-items:center;background:none;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;height:30px;justify-content:center;transition:all var(--transition);width:30px}.vps-details-header .close-btn:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.vps-details-body{padding:20px 22px}.status-alert{border-left:3px solid;border-radius:var(--radius-md);display:flex;gap:12px;margin-bottom:20px;padding:12px 14px}.status-alert.expired{background:#f59e0b1a;border-color:#f59e0b;color:#fcd34d}.status-alert.blocked{background:var(--danger-dim);border-color:#ef444499;color:#fca5a5}.alert-icon{font-size:24px}.alert-content strong{display:block;font-size:15px;margin-bottom:4px}.alert-content p{font-size:14px;line-height:1.5;margin:0}.details-section{margin-bottom:24px}.details-section h4{color:var(--text-muted);font-size:11px;letter-spacing:.06em;margin:0 0 12px;text-transform:uppercase}.details-section h4,.offering-badge{font-family:Geist Mono,monospace;font-weight:600}.offering-badge{background:var(--accent-dim);border:1px solid #2563eb4d;border-radius:20px;color:var(--text-accent);display:inline-block;font-size:12px;margin-bottom:12px;padding:4px 14px}.resources-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.resource-item{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);gap:12px;padding:14px}.resource-icon,.resource-item{align-items:center;display:flex}.resource-icon{border-radius:var(--radius-sm);color:#fff;flex-shrink:0;height:36px;justify-content:center;width:36px}.resource-icon.cpu{background:#6366f140;color:#a5b4fc}.resource-icon.ram{background:#ec489933;color:#f9a8d4}.resource-icon.storage{background:#0ea5e933;color:#7dd3fc}.resource-info{display:flex;flex-direction:column;gap:3px}.resource-label{color:var(--text-muted);font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.resource-label,.resource-value{font-family:Geist Mono,monospace}.resource-value{color:var(--text-primary);font-size:16px;font-weight:700}.billing-grid{display:flex;flex-direction:column;gap:12px}.billing-item{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);display:flex;gap:12px;padding:12px 14px}.billing-item.highlight{background:var(--accent-dim);border-color:#2563eb4d}.billing-icon{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-secondary);flex-shrink:0;height:32px;justify-content:center;width:32px}.billing-icon,.billing-info{align-items:center;display:flex}.billing-info{flex:1 1;justify-content:space-between}.billing-label{color:var(--text-muted);font-family:Geist,sans-serif;font-size:13px;font-weight:500}.billing-value{color:var(--text-secondary);font-family:Geist Mono,monospace;font-size:13px;font-weight:700}.billing-value.total{color:#6ee7b7;font-size:16px}.expiration-info{display:flex;flex-direction:column;gap:16px}.expiration-item{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);display:flex;gap:12px;padding:12px 14px}.expiration-item svg{color:var(--text-accent);flex-shrink:0}.expiration-item>div{display:flex;flex-direction:column;gap:3px}.expiration-label{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.expiration-value{color:var(--text-primary);font-family:Geist Mono,monospace;font-size:13px;font-weight:700}.days-remaining{align-items:center;border-radius:var(--radius-md);display:flex;flex-direction:column;padding:18px;text-align:center}.days-remaining.ok{background:#10b9811a;border:1px solid #10b9814d}.days-remaining.warning{background:#f59e0b1a;border:1px solid #f59e0b4d}.days-remaining.expired{background:var(--danger-dim);border:1px solid #ef44444d}.days-number{font-family:Geist Mono,monospace;font-size:32px;font-weight:800;line-height:1;margin-bottom:4px}.days-remaining.ok .days-number{color:#6ee7b7}.days-remaining.warning .days-number{color:#fcd34d}.days-remaining.expired .days-number{color:#fca5a5}.days-text{font-family:Geist Mono,monospace;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.days-remaining.ok .days-text{color:#6ee7b7}.days-remaining.warning .days-text{color:#fcd34d}.days-remaining.expired .days-text{color:#fca5a5}.info-grid{display:flex;flex-direction:column;gap:12px}.info-item{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:10px 14px}.info-label{color:var(--text-muted);font-family:Geist,sans-serif;font-size:12px;font-weight:600}.info-value{color:var(--text-secondary);font-family:Geist Mono,monospace;font-size:12px;font-weight:700}.status-badge{font-weight:700;letter-spacing:.05em;padding:2px 10px}.status-badge.active,.status-badge.running{background:#10b98126;border:1px solid #10b9814d;color:#6ee7b7}.status-badge.stopped{background:#ffffff0d;border:1px solid var(--cloud-border);color:#475569}.status-badge.creating,.status-badge.provisioning{background:var(--accent-dim);border:1px solid #2563eb4d;color:#93c5fd}.status-badge.blocked{background:#f59e0b1f;border:1px solid #f59e0b4d;color:#fcd34d}.vps-details-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);bottom:0;display:flex;justify-content:flex-end;padding:16px 22px;position:-webkit-sticky;position:sticky}.btn-close{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:8px 20px;transition:all var(--transition)}.btn-close:hover{background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}@media (max-width:768px){.vps-details-modal{max-height:95vh;width:95%}.resources-grid{grid-template-columns:1fr}.vps-details-header h3{font-size:20px}}.vscode-modal-overlay{align-items:center;animation:fadeIn .15s ease-in;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:20000}.vscode-modal{animation:slideUp .2s ease-out;background:#0d1117;border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000e6;display:flex;flex-direction:column;height:95vh;overflow:hidden;width:95vw}.vscode-modal-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:10px 16px}.vscode-header-left h3{align-items:center;color:var(--text-primary);display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:8px;margin:0}.vscode-header-actions{align-items:center;display:flex;gap:6px}.vscode-action-btn{align-items:center;background:#0000;border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:12px;gap:5px;padding:5px 9px;transition:all var(--transition)}.vscode-action-btn:hover{background:var(--cloud-surface-3);border-color:var(--accent);color:var(--text-accent)}.vscode-close-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;padding:4px;transition:all var(--transition)}.vscode-close-btn:hover{background:var(--danger-dim);border-color:#ef444459;color:#fca5a5}.vscode-loading{align-items:center;background:#0d1117;color:var(--text-secondary);display:flex;flex-direction:column;gap:16px;height:100%;justify-content:center}.vscode-spinner{animation:vsSpin .7s linear infinite;border:2px solid var(--cloud-border);border-radius:50%;border-top-color:var(--accent);height:40px;width:40px}@keyframes vsSpin{to{transform:rotate(1turn)}}.vscode-loading p{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:14px;margin:0}.vscode-loading-hint{color:var(--text-muted)!important;font-family:Geist Mono,monospace!important;font-size:12px!important}.vscode-provisioning-title{color:var(--text-accent)!important;font-family:Geist,sans-serif!important;font-size:16px!important;font-weight:600;margin-bottom:16px!important}.vscode-provisioning-steps{display:flex;flex-direction:column;gap:10px;max-width:500px;width:100%}.provisioning-step{align-items:center;background:var(--cloud-surface-2);border-left-color:var(--accent);border-left-width:2px;border:1px solid var(--cloud-border);border-left:2px solid var(--accent);border-radius:var(--radius-md);display:flex;gap:10px;padding:10px 14px}.vscode-loading-content{align-items:center;display:flex;flex-direction:column;gap:24px;max-width:500px;padding:40px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;color:#007acc}.loading-success{animation:scaleIn .3s ease-out;color:#10b981}.loading-error{animation:shake .5s ease-in-out;color:#ef4444}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.loading-title{color:var(--text-primary);font-family:Geist,sans-serif;font-size:18px;font-weight:600;margin:0}.loading-description{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:13px;margin:0}.retry-button{background:var(--accent);border:1px solid #0000;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;margin-top:6px;padding:8px 20px;transition:all var(--transition)}.retry-button:hover{background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.progress-bar-container{display:flex;flex-direction:column;gap:8px;width:100%}.progress-bar-bg{background:var(--cloud-border);border-radius:4px;height:4px;overflow:hidden;width:100%}.progress-bar-fill{background:linear-gradient(90deg,var(--accent) 0,#60a5fa 100%);border-radius:4px;box-shadow:0 0 8px #2563eb66;height:100%;transition:width .3s ease-out}.progress-text{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:12px;text-align:center}.step-icon{color:var(--text-accent);flex-shrink:0}.step-icon.spinning{animation:vsSpin 1s linear infinite}.step-text{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:13px}.provisioning-progress-bar{background:var(--cloud-border);border-radius:4px;height:4px;overflow:hidden;position:relative;width:100%}.vscode-iframe-container{background:#0d1117;flex:1 1;overflow:hidden;position:relative}.vscode-iframe{border:none;display:block;height:100%;width:100%}@media (max-width:768px){.vscode-modal{border-radius:0;height:100vh;width:100vw}}.function-modal-overlay{align-items:center;animation:fadeIn .15s ease-in;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.function-modal{animation:slideUp .2s ease-out;background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:800px;width:90%}.spinner-small{animation:spin .6s linear infinite;border:1.5px solid #ffffff26;border-radius:50%;border-top-color:initial;display:inline-block;height:13px;width:13px}.function-modal-header{align-items:center;border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:16px 20px}.function-modal-header h3{color:var(--text-primary);font-family:Geist,sans-serif;font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}.function-close-btn{align-items:center;background:none;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;height:30px;justify-content:center;padding:0;transition:all var(--transition);width:30px}.function-close-btn:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.function-modal-body{flex:1 1;overflow-y:auto;padding:20px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.functions-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.functions-count{align-items:center;display:flex;gap:12px}.count-badge{background:var(--accent-dim);border:1px solid #2563eb4d;border-radius:20px;color:var(--text-accent);font-family:Geist Mono,monospace;font-size:14px;font-weight:700;padding:4px 14px}.count-label{color:var(--text-muted);font-weight:500}.add-function-btn,.count-label{font-family:Geist,sans-serif;font-size:13px}.add-function-btn{align-items:center;background:#10b98126;border:1px solid #10b9814d;border-radius:var(--radius-md);color:#6ee7b7;cursor:pointer;display:flex;font-weight:600;gap:7px;padding:8px 16px;transition:all var(--transition)}.add-function-btn:hover:not(:disabled){background:#10b98140;border-color:#10b98180}.add-function-btn:disabled{cursor:not-allowed;opacity:.4}.functions-list{display:flex;flex-direction:column;gap:16px}.empty-state{color:var(--text-muted);font-family:Geist,sans-serif}.empty-state p{font-size:14px;margin:8px 0}.empty-hint{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:13px}.function-card{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);padding:16px;transition:border-color var(--transition),box-shadow var(--transition)}.function-card:hover{border-color:var(--cloud-border-2);box-shadow:0 4px 16px #0000004d}.function-card.inactive{opacity:.5}.function-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.function-info h4{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;margin:0 0 4px}.function-tech{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:3px;color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px;padding:2px 7px}.function-status{display:flex;gap:8px}.deployed-badge{background:#10b98126;border:1px solid #10b9814d;border-radius:20px;color:#6ee7b7}.deployed-badge,.inactive-badge{font-family:Geist Mono,monospace;font-size:10px;font-weight:700;letter-spacing:.04em;padding:2px 10px;text-transform:uppercase}.inactive-badge{background:var(--danger-dim);border:1px solid #ef44444d;border-radius:20px;color:#fca5a5}.function-card-body{margin-bottom:12px}.function-detail{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:12px;margin:4px 0}.function-detail strong{color:var(--text-secondary);font-family:Geist,sans-serif;margin-right:4px}.function-card-actions{border-top:1px solid var(--cloud-border);display:flex;gap:6px;padding-top:12px}.action-btn{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-muted);padding:7px;transition:all var(--transition)}.action-btn:hover:not(:disabled){background:var(--cloud-surface);border-color:var(--cloud-border-2);color:var(--text-secondary)}.action-btn:disabled{opacity:.35}.vscode-btn:hover:not(:disabled){background:#0ea5e91a;border-color:#0ea5e980;color:#7dd3fc}.edit-btn:hover:not(:disabled){background:var(--accent-dim);border-color:#2563eb80;color:#93c5fd}.deploy-btn:hover:not(:disabled){background:#10b9811a;border-color:#10b98180;color:#6ee7b7}.ports-btn:hover:not(:disabled){background:#f59e0b1a;border-color:#f59e0b80;color:#fcd34d}.toggle-btn:hover:not(:disabled){background:#6366f11a;border-color:#6366f180;color:#a5b4fc}.delete-btn:hover:not(:disabled){background:var(--danger-dim);border-color:#ef444480;color:#fca5a5}.function-form{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);padding:20px}.function-form h4{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;margin:0 0 18px}.form-group input,.form-group select,.form-group textarea{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;padding:9px 12px;transition:border-color var(--transition),box-shadow var(--transition)}.form-group select option{background:var(--cloud-surface-2);color:var(--text-primary)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-group textarea{font-family:Geist Mono,monospace;font-size:12px}.form-group small{color:var(--text-muted);display:block;font-family:Geist Mono,monospace;font-size:11px;margin-top:4px}.checkbox-group label{align-items:center;cursor:pointer;display:flex;gap:8px}.checkbox-group input[type=checkbox]{cursor:pointer;width:auto}.btn-cancel,.btn-save{border-radius:var(--radius-md);cursor:pointer;flex:1 1;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:9px 20px;transition:all var(--transition)}.btn-cancel{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);color:var(--text-secondary)}.btn-cancel:hover{background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.btn-save{background:var(--accent);border:1px solid #0000;color:#fff}.btn-save:hover{background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.function-modal-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;gap:10px;justify-content:flex-end;padding:14px 20px}.btn-primary,.btn-secondary{border-radius:var(--radius-md);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:8px 20px;transition:all var(--transition)}.btn-secondary{background:var(--cloud-surface-3)}.btn-secondary:hover{background:var(--cloud-surface-2)}.btn-primary{border:1px solid #0000}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 12px #2563eb66}.lxc-monitor-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.lxc-monitor-modal{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.lxc-monitor-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:12px 18px}.header-info svg{color:#c4b5fd}.header-info .node-type{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;letter-spacing:.05em;text-transform:uppercase}.header-actions{gap:6px}.close-btn,.refresh-btn{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;padding:6px;transition:all var(--transition)}.close-btn:hover,.refresh-btn:hover{background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.refresh-btn:disabled{opacity:.4}.spin{animation:lxcSpin .7s linear infinite}@keyframes lxcSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.lxc-monitor-content{flex:1 1;overflow-y:auto;padding:16px 18px;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.error-message{background:var(--danger-dim);border:1px solid #ef44444d;border-radius:var(--radius-md);font-family:Geist,sans-serif;font-size:12px;margin-bottom:14px;padding:10px 12px}.status-offline{align-items:center;color:var(--text-muted);display:flex;font-family:Geist,sans-serif;font-size:13px;gap:10px;justify-content:center;padding:40px}.status-offline svg{color:#ef4444}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.metric-header{color:var(--text-muted);font-family:Geist,sans-serif;font-size:11px;gap:7px;letter-spacing:.04em;text-transform:uppercase}.metric-header svg{color:#c4b5fd}.metric-value{font-size:24px;margin-bottom:3px}.metric-detail{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px;margin-bottom:7px}.metric-detail.network{color:var(--text-secondary);display:flex;flex-direction:column;font-size:11px;gap:3px}.progress-bar{background:var(--cloud-border);border-radius:3px;height:4px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .3s ease}.services-section{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);padding:12px 14px}.services-section h3{align-items:center;color:var(--text-primary);display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:7px;margin:0 0 12px}.services-section h3 svg{color:#c4b5fd}.services-table{max-height:280px;overflow-x:auto;overflow-y:auto;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.services-table table{border-collapse:collapse;font-size:12px;width:100%}.services-table th{background:var(--cloud-surface-3);color:var(--text-muted);font-family:Geist Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.05em;padding:7px 10px;position:-webkit-sticky;position:sticky;text-align:left;text-transform:uppercase;top:0}.services-table td{border-bottom:1px solid var(--cloud-border);color:var(--text-secondary);font-family:Geist,sans-serif;font-size:12px;padding:7px 10px}.services-table tr:hover td{background:var(--cloud-surface-2)}.services-table td.service-name{color:#a5b4fc;font-family:Geist Mono,monospace;font-weight:600}.services-table td.description{color:var(--text-muted);font-size:11px;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.services-table td.no-data{color:var(--text-muted);padding:16px;text-align:center}.services-table td.no-data,.status-badge{font-family:Geist Mono,monospace}.status-badge.running{background:#10b9811f;border:1px solid #10b98140;color:#6ee7b7}.status-badge.stopped{background:var(--danger-dim);border:1px solid #ef444440;color:#fca5a5}.loading-state,.no-metrics{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:10px;justify-content:center;padding:48px 20px;text-align:center}.loading-state svg,.no-metrics svg{opacity:.4}.loading-state p,.no-metrics p{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:14px;margin:0}.no-metrics span{font-family:Geist Mono,monospace;font-size:12px}.lxc-monitor-footer{align-items:center;background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;flex-shrink:0;justify-content:space-between;padding:10px 18px}.footer-info{align-items:center;color:var(--text-muted);display:flex;font-family:Geist Mono,monospace;font-size:11px;gap:6px}.footer-info svg{color:#c4b5fd}.last-update{color:var(--text-secondary)}.auto-refresh{background:#10b9811a;border:1px solid #10b98140;border-radius:20px;color:#6ee7b7;font-family:Geist Mono,monospace;font-size:10px;padding:2px 8px}@media (max-width:640px){.lxc-monitor-modal{border-radius:0;max-height:100vh}.metrics-grid{grid-template-columns:1fr 1fr}}.react-flow{direction:ltr}.react-flow__container{height:100%;left:0;position:absolute;top:0;width:100%}.react-flow__pane{cursor:grab;z-index:1}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:grabbing}.react-flow__viewport{pointer-events:none;transform-origin:0 0;z-index:2}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{overflow:visible;pointer-events:none}.react-flow__connection-path,.react-flow__edge-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{cursor:pointer;pointer-events:visibleStroke}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{box-sizing:border-box;cursor:grab;pointer-events:all;position:absolute;transform-origin:0 0;-webkit-user-select:none;user-select:none}.react-flow__node.dragging{cursor:grabbing}.react-flow__nodesselection{pointer-events:none;transform-origin:left top;z-index:3}.react-flow__nodesselection-rect{cursor:grab;pointer-events:all;position:absolute}.react-flow__handle{background:#1a192b;border:1px solid #fff;border-radius:100%;height:6px;min-height:5px;min-width:5px;pointer-events:none;position:absolute;width:6px}.react-flow__handle.connectionindicator{cursor:crosshair;pointer-events:all}.react-flow__handle-bottom{bottom:-4px;left:50%;top:auto;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{left:-4px;top:50%;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{margin:15px;position:absolute;z-index:5}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translateX(-50%)}.react-flow__attribution{background:#ffffff80;font-size:10px;margin:0;padding:2px 3px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{height:100%;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;width:100%}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-group,.react-flow__node-input,.react-flow__node-output{background-color:#fff;border:1px solid #1a192b;border-radius:3px;color:#222;font-size:12px;padding:10px;text-align:center;width:150px}.react-flow__node-default.selectable:hover,.react-flow__node-group.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted #0059dccc}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{align-items:center;background:#fefefe;border:none;border-bottom:1px solid #eee;box-sizing:initial;cursor:pointer;display:flex;height:16px;justify-content:center;padding:5px;-webkit-user-select:none;user-select:none;width:16px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{max-height:12px;max-width:12px;width:100%}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.bottom,.react-flow__resize-control.top{cursor:ns-resize}.react-flow__resize-control.bottom.right,.react-flow__resize-control.top.left{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:#3367d9;border:1px solid #fff;border-radius:1px;height:4px;transform:translate(-50%,-50%);width:4px}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.bottom.left,.react-flow__resize-control.handle.top.left{left:0}.react-flow__resize-control.handle.bottom.right,.react-flow__resize-control.handle.top.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{height:100%;top:0;transform:translate(-50%);width:1px}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.bottom,.react-flow__resize-control.line.top{height:1px;left:0;transform:translateY(-50%);width:100%}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.flow-editor-page{background:var(--cloud-bg);color:var(--text-primary);height:100vh;min-height:100vh;overflow:hidden;padding:0;position:relative}.floating-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);left:14px;padding:10px 14px;position:fixed;top:14px;width:260px;z-index:1001}.header-content{display:flex;flex-direction:column;gap:7px}.header-left{gap:8px;min-width:0}.header-actions{gap:5px;width:100%}.mapata-logo-header{height:22px;object-fit:contain;width:auto}.btn-toggle-palette{align-items:center;background:var(--accent-dim);border:1px solid #2563eb4d;border-radius:var(--radius-sm);color:var(--accent-bright);cursor:pointer;display:flex;flex:1 1;font-family:Geist,sans-serif;font-size:11px;font-weight:600;gap:4px;justify-content:center;padding:5px 8px;transition:all var(--transition);white-space:nowrap}.btn-toggle-palette:hover{background:var(--accent);border-color:var(--accent);color:#fff}.btn-toggle-palette svg{flex-shrink:0}.floating-palette{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);left:14px;max-height:calc(100vh - 108px);overflow:hidden;position:fixed;top:108px;width:260px;z-index:999}.insufficient-credits-modal{max-width:460px}.insufficient-credits-content{padding:16px 0;text-align:center}.insufficient-credits-icon{font-size:48px;margin-bottom:14px;opacity:.8}.insufficient-credits-message{color:var(--text-secondary);font-size:14px;line-height:1.5;margin-bottom:14px}.insufficient-credits-info{background:var(--danger-dim);border:1px solid #ef444433;border-radius:var(--radius-md);color:var(--danger);font-family:Geist Mono,monospace;font-size:15px;margin-bottom:14px;padding:12px}.insufficient-credits-info strong{font-size:18px;font-weight:700}.insufficient-credits-action{color:var(--text-muted);font-size:13px;margin:0}.modal-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;gap:10px;justify-content:flex-end;padding:14px 20px}.btn-secondary{background:#0000;border:1px solid var(--cloud-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:500;padding:7px 16px;transition:all var(--transition)}.btn-secondary:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border-2);color:var(--text-primary)}.btn-primary{background:var(--accent);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:600;padding:7px 16px;transition:all var(--transition)}.btn-primary:hover{background:#1d4ed8;box-shadow:0 4px 14px #2563eb66;transform:translateY(-1px)}.neteditor-title{color:var(--text-primary);font-size:13px;font-weight:600;letter-spacing:-.01em;margin:0;overflow:hidden;text-overflow:ellipsis}.btn-close-editor,.neteditor-title{font-family:Geist,sans-serif;white-space:nowrap}.btn-close-editor{align-items:center;background:#0000;border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;font-size:11px;font-weight:500;gap:4px;justify-content:center;padding:5px 8px;transition:all var(--transition)}.btn-close-editor:hover{background:var(--danger-dim);border-color:#ef44444d;color:var(--danger)}.flow-container-fullscreen{background:var(--cloud-bg);height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100vw;z-index:1}.react-flow__background{background-color:var(--cloud-bg)!important}.react-flow__node{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-md);color:var(--text-primary);font-weight:600;padding:0;transition:box-shadow .15s}.react-flow__node:hover{box-shadow:0 4px 16px #00000080}.react-flow__node.selected{box-shadow:0 0 0 2px var(--accent)}.react-flow__node.selected:hover{box-shadow:0 0 0 2px var(--accent),0 4px 16px #00000080}.react-flow__edge-path{stroke:#2563eb80;stroke-width:1.5;cursor:pointer}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:hover .react-flow__edge-path{stroke:var(--accent-bright);stroke-width:2}.react-flow__controls{background:var(--cloud-surface)!important;border:1px solid var(--cloud-border)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-md)!important}.react-flow__controls-button{fill:var(--text-secondary)!important;background:#0000!important;border-bottom:1px solid var(--cloud-border)!important;color:var(--text-secondary)!important}.react-flow__controls-button:hover{fill:var(--text-primary)!important;background:var(--cloud-surface-3)!important;color:var(--text-primary)!important}.react-flow__minimap{background:var(--cloud-surface)!important;border:1px solid var(--cloud-border)!important;border-radius:var(--radius-md)!important}.react-flow__minimap-mask{fill:#080c14b3!important}.not-found-page{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:60vh;text-align:center}.not-found-page svg{margin-bottom:2rem;opacity:.8}.not-found-page h1{font-size:6rem;font-weight:700;margin-bottom:1rem}.not-found-page h2{font-size:2rem;margin-bottom:1rem}.not-found-page p{font-size:1.2rem;margin-bottom:2rem;opacity:.8}.home-button{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;color:#667eea;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.home-button:hover{background:#f8f9ff;box-shadow:0 6px 12px #00000026;transform:translateY(-2px)}.checkout-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;justify-content:center;min-height:100vh;padding:20px}.checkout-card{animation:slideUp .4s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:500px;overflow:hidden;width:100%}.checkout-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;position:relative;text-align:center}.checkout-header h1{font-size:24px;font-weight:600;margin:0 0 15px}.checkout-header .logo{font-size:48px;margin-bottom:10px}.payment-details{background:#f8f9fa;border-bottom:1px solid #e9ecef;padding:25px 30px}.detail-row{font-size:14px;justify-content:space-between;margin-bottom:12px}.detail-row:last-child{margin-bottom:0}.detail-row .label{color:#6c757d;font-weight:500}.detail-row .value{color:#212529;font-weight:600}.amount-row{border-top:1px solid #dee2e6;margin-top:15px;padding-top:15px}.amount-row .amount{color:#667eea;font-size:24px}.checkout-form{padding:30px}.form-group{margin-bottom:25px}.form-group label{color:#495057;font-size:14px}.phone-input-wrapper{border:2px solid #e9ecef;border-radius:10px;display:flex;overflow:hidden;transition:border-color .3s}.phone-input-wrapper:focus-within{border-color:#667eea}.country-code{align-items:center;background:#f8f9fa;border-right:1px solid #e9ecef;color:#495057;display:flex;font-weight:600;padding:12px 15px;white-space:nowrap}.phone-input-wrapper input{border:none;color:#212529;flex:1 1;font-size:16px;outline:none;padding:12px 15px}.phone-input-wrapper input.valid{background:#d4edda}.phone-input-wrapper input.invalid{background:#f8d7da}.validation-error{color:#dc3545}.validation-error,.validation-success{display:block;font-size:12px;font-weight:500;margin-top:8px}.validation-success{color:#28a745}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:10px;color:#721c24;font-size:14px;gap:10px;margin-bottom:20px;padding:12px 15px}.error-icon{font-size:18px}.success-message{animation:fadeIn .5s ease-out;padding:40px 30px;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.success-icon{animation:scaleUp .5s ease-out;background:#28a745;border-radius:50%;color:#fff;font-size:48px;height:80px;margin:0 auto 20px;width:80px}@keyframes scaleUp{0%{transform:scale(0)}to{transform:scale(1)}}.success-message h2{color:#28a745;font-size:22px;margin-bottom:10px}.success-message p{color:#6c757d;font-size:14px;line-height:1.6}.submit-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;padding:15px;transition:all .3s;width:100%}.submit-button:hover:not(:disabled){box-shadow:0 10px 25px #667eea66;transform:translateY(-2px)}.submit-button:disabled{cursor:not-allowed;opacity:.6}.spinner{animation:spin .8s linear infinite;border:3px solid #ffffff4d;height:20px;width:20px}.security-note{align-items:center;color:#6c757d;display:flex;font-size:13px;gap:8px;justify-content:center;margin-top:20px;text-align:center}.lock-icon{font-size:16px}.checkout-footer{background:#f8f9fa;border-top:1px solid #e9ecef;padding:20px 30px;text-align:center}.checkout-footer p{color:#6c757d;font-size:13px;margin:0}@media (max-width:576px){.checkout-container{padding:10px}.checkout-card{border-radius:15px}.checkout-header{padding:20px}.checkout-header h1{font-size:20px}.checkout-header .logo{font-size:40px}.checkout-form,.payment-details{padding:20px}.amount-row .amount{font-size:20px}}.theme-toggle{align-items:center;background:var(--cloud-surface-2);border:1px solid var(--cloud-border-2);border-radius:24px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:Geist,sans-serif;font-size:12px;font-weight:500;gap:8px;letter-spacing:.02em;padding:6px 12px 6px 6px;transition:background .3s ease,border-color .3s ease,color .3s ease,box-shadow .2s ease;-webkit-user-select:none;user-select:none;white-space:nowrap}.theme-toggle:hover{border-color:var(--accent);box-shadow:var(--shadow-accent);color:var(--text-primary)}.theme-toggle:active{transform:scale(.97)}.theme-toggle__track{background:var(--cloud-surface-3);border:1px solid var(--cloud-border-2);border-radius:10px;flex-shrink:0;height:20px;position:relative;transition:background .3s ease,border-color .3s ease;width:36px}.theme-toggle--dark .theme-toggle__track{background:var(--accent-dim);border-color:var(--accent)}.theme-toggle--light .theme-toggle__track{background:#0085c91f;border-color:var(--accent)}.theme-toggle__thumb{align-items:center;background:var(--accent);border-radius:50%;box-shadow:0 1px 4px #00000059;color:#fff;display:flex;height:14px;justify-content:center;position:absolute;top:2px;transition:transform .28s cubic-bezier(.34,1.56,.64,1);width:14px}.theme-toggle--dark .theme-toggle__thumb{transform:translateX(2px)}.theme-toggle--light .theme-toggle__thumb{background:var(--brand-primary);transform:translateX(18px)}.theme-toggle__label{color:var(--text-secondary);font-family:Geist Mono,monospace;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;transition:color .3s ease}.theme-toggle:hover .theme-toggle__label{color:var(--text-primary)}.login-page{align-items:center;background:var(--cloud-bg);background-image:linear-gradient(#0085c90a 1px,#0000 0),linear-gradient(90deg,#0085c90a 1px,#0000 0);background-size:48px 48px;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative;transition:background .3s ease}.login-theme-toggle{position:absolute;right:24px;top:20px;z-index:10}.login-background{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0;z-index:0}.login-gradient-1,.login-gradient-2,.login-gradient-3{animation:loginFloat 28s ease-in-out infinite;border-radius:50%;filter:blur(120px);opacity:.18;position:absolute}.login-gradient-1{animation-delay:0s;background:radial-gradient(circle,#0085c9 0,#0000 70%);height:700px;right:-200px;top:-350px;width:700px}.login-gradient-2{animation-delay:10s;background:radial-gradient(circle,#36bee5 0,#0000 70%);bottom:-250px;height:500px;left:-150px;width:500px}.login-gradient-3{animation-delay:20s;background:radial-gradient(circle,#0d3f72 0,#0000 70%);height:400px;left:40%;top:45%;width:400px}@keyframes loginFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(40px,-30px) scale(1.08)}66%{transform:translate(-25px,25px) scale(.94)}}.login-container{max-width:440px;position:relative;width:100%;z-index:1}.login-card{animation:loginSlideUp .5s cubic-bezier(.16,1,.3,1) both;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:var(--cloud-surface);border:1px solid var(--cloud-border-2);border-radius:var(--radius-xl);box-shadow:0 24px 64px #0000008c,0 0 0 1px #0085c91a;overflow:hidden;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease}@keyframes loginSlideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-header{background:linear-gradient(180deg,#2563eb14,#0000);border-bottom:1px solid var(--cloud-border);padding:2.5rem 2rem 1.75rem;text-align:center}.login-logo{filter:drop-shadow(0 4px 16px rgba(37,99,235,.4));height:56px;margin-bottom:1.25rem;object-fit:contain;width:auto}.login-header h1{color:var(--text-primary);font-family:Geist,sans-serif;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .5rem}.login-subtitle{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:.85rem;font-weight:400;letter-spacing:.02em;margin:0}.login-body{padding:2rem}.login-form{width:100%}.login-description{color:var(--text-secondary);font-size:.875rem;line-height:1.6;margin-bottom:1.5rem;text-align:center}.login-description strong{color:var(--accent-bright);font-weight:600}.login-form-group{margin-bottom:1.5rem}.login-form-group label{color:var(--text-secondary);display:block;font-family:Geist Mono,monospace;font-size:.8rem;font-weight:500;letter-spacing:.06em;margin-bottom:.4rem;text-transform:uppercase}.login-form-group input{background:var(--cloud-bg);border:1px solid var(--cloud-border-2);border-radius:var(--radius-md);box-sizing:border-box;color:var(--text-primary);font-family:Geist,sans-serif;font-size:.9rem;padding:.75rem 1rem;transition:all var(--transition);width:100%}.login-form-group input::placeholder{color:var(--text-muted)}.login-form-group input:focus{background:var(--cloud-bg);border-color:var(--accent);box-shadow:0 0 0 3px #0085c933;outline:none}.login-form-group input:disabled{cursor:not-allowed;opacity:.4}.login-error{background:var(--danger-dim);border-left:3px solid var(--danger);border-radius:var(--radius-md);color:#fca5a5;font-family:Geist Mono,monospace;font-size:.85rem;margin-bottom:1rem;padding:.75rem 1rem}.login-submit-btn{align-items:center;background:var(--accent);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;letter-spacing:.01em;padding:.75rem 1rem;transition:all var(--transition);width:100%}.login-submit-btn:hover:not(:disabled){background:#13599f;box-shadow:var(--shadow-brand);transform:translateY(-1px)}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{cursor:not-allowed;opacity:.45;transform:none}.login-actions{display:flex;gap:1rem}.login-back-btn{background:#0000;border:1px solid var(--cloud-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;flex:1 1;font-family:Geist,sans-serif;font-size:.9rem;font-weight:500;padding:.75rem 1rem;transition:all var(--transition)}.login-back-btn:hover:not(:disabled){background:var(--cloud-surface-3);border-color:var(--cloud-border-2);color:var(--text-primary)}.login-back-btn:disabled{cursor:not-allowed;opacity:.4}.login-actions .login-submit-btn{flex:2 1}.login-spinner{animation:loginSpin .7s linear infinite;border:2px solid #fff3;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;width:14px}@keyframes loginSpin{to{transform:rotate(1turn)}}.login-footer{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);padding:1.25rem 2rem;text-align:center;transition:background .3s ease}.login-footer p{color:var(--text-secondary);font-family:Geist Mono,monospace;font-size:.8rem;margin:0}.login-brand{color:var(--accent-bright);font-weight:600}.login-register-link{border-top:1px solid var(--cloud-border);margin-top:1rem;padding-top:1rem}.login-register-link p{color:var(--text-secondary);font-size:.9rem;margin:0}.login-register-link a{border-bottom:1px solid #0000;color:var(--accent-bright);font-weight:600;text-decoration:none;transition:all var(--transition)}.login-register-link a:hover{border-bottom-color:var(--accent-bright);color:var(--text-primary)}@media (max-width:640px){.login-card{border-radius:16px}.login-header{padding:2rem 1.5rem 1.5rem}.login-logo{height:60px;margin-bottom:1rem}.login-header h1{font-size:1.5rem}.login-subtitle{font-size:.875rem}.login-body{padding:2rem 1.5rem}.login-footer{padding:1.25rem 1.5rem}.login-actions{flex-direction:column}.login-actions .login-submit-btn,.login-back-btn{flex:1 1}}.registration-form-container{animation:regSlideUp .4s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;margin:0 auto;max-width:900px;padding:24px 28px;position:relative;transition:background .3s ease,border-color .3s ease;width:100%;z-index:1}@keyframes regSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.registration-form-header{margin-bottom:20px;text-align:center}.registration-form-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--accent) 0,#10b981 100%);-webkit-background-clip:text;background-clip:text;font-family:Geist,sans-serif;font-size:20px;font-weight:700;margin-bottom:5px}.registration-form-header p{color:var(--text-muted);font-family:Geist,sans-serif;font-size:12px}.registration-form{grid-gap:16px 24px;align-items:start;display:grid;gap:16px 24px;grid-template-columns:1fr 1fr;grid-template-rows:auto}.registration-form .form-section:first-child{grid-column:1;grid-row:1}.registration-form .form-section:nth-child(2){grid-column:2;grid-row:1}.registration-form .form-section:nth-child(3){grid-column:2;grid-row:2}.registration-form .form-actions,.registration-form .submit-error{grid-column:1/-1}.registration-form .camera-modal{grid-column:auto;grid-row:auto}.form-section{display:flex;flex-direction:column;gap:10px;min-width:0}.form-section h3{border-bottom:1px solid var(--cloud-border);color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;margin-bottom:2px;padding-bottom:5px}.form-row{grid-gap:12px;gap:12px}.form-group{gap:4px;margin-bottom:10px!important}.form-group label{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.form-group input{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Geist,sans-serif;font-size:13px;padding:8px 10px;transition:border-color var(--transition)}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.form-group input.error{background:var(--danger-dim);border-color:#ef444499}.error-message{align-items:center;color:#fca5a5;display:flex;font-family:Geist Mono,monospace;font-size:11px;gap:5px;margin-top:3px}.upload-options{display:flex;gap:10px;margin-top:4px}.camera-btn,.upload-btn{align-items:center;background:var(--cloud-surface-2);border:1px dashed var(--cloud-border-2);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;display:flex;flex:1 1;font-family:Geist,sans-serif;font-size:12px;font-weight:500;gap:6px;justify-content:center;padding:10px;transition:all var(--transition)}.camera-btn:hover,.upload-btn:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--text-accent)}.id-card-preview{border:1px solid var(--cloud-border);border-radius:var(--radius-md);margin-top:4px;max-width:400px;overflow:hidden;position:relative}.id-card-preview img{display:block;height:auto;width:100%}.remove-btn{align-items:center;background:#ef4444e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:26px;justify-content:center;position:absolute;right:6px;top:6px;transition:all var(--transition);width:26px}.remove-btn:hover{background:#ef4444;transform:scale(1.1)}.camera-modal{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.camera-content{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000c;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.camera-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;justify-content:space-between;padding:12px 16px}.camera-header h3{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;margin:0}.close-camera-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;height:28px;justify-content:center;transition:all var(--transition);width:28px}.close-camera-btn:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.camera-view{align-items:center;background:#000;display:flex;flex:1 1;justify-content:center;min-height:360px;overflow:hidden;position:relative}.camera-video{display:block;height:100%;max-height:60vh;object-fit:cover;width:100%}.camera-guide{align-items:center;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.guide-frame{aspect-ratio:16/10;border:2px solid #2563eb99;border-radius:var(--radius-md);box-shadow:0 0 0 9999px #00000080;max-width:500px;position:relative;width:85%}.guide-corner{border:2px solid var(--accent);height:24px;position:absolute;width:24px}.guide-corner-tl{border-bottom:none;border-right:none;border-top-left-radius:12px;left:-2px;top:-2px}.guide-corner-tr{border-bottom:none;border-left:none;border-top-right-radius:12px;right:-2px;top:-2px}.guide-corner-bl{border-bottom-left-radius:12px;border-right:none;border-top:none;bottom:-2px;left:-2px}.guide-corner-br{border-bottom-right-radius:12px;border-left:none;border-top:none;bottom:-2px;right:-2px}.guide-text{animation:regPulse 2s ease-in-out infinite;bottom:-36px;color:var(--text-accent);font-family:Geist,sans-serif;font-size:12px;font-weight:600;left:50%;position:absolute;text-align:center;text-shadow:0 2px 4px #000c;transform:translateX(-50%);white-space:nowrap}@keyframes regPulse{0%,to{opacity:1}50%{opacity:.5}}.camera-controls{background:var(--cloud-surface-2);border-top:1px solid var(--cloud-border);display:flex;justify-content:center;padding:16px}.capture-btn{align-items:center;background:var(--accent);border:1px solid #0000;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:14px;font-weight:600;gap:6px;padding:10px 24px;transition:all var(--transition)}.capture-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 16px #2563eb66}.capture-btn:active:not(:disabled){transform:translateY(1px)}.capture-btn:disabled{cursor:not-allowed;opacity:.4}.submit-error{align-items:center;background:var(--danger-dim);border:1px solid #ef444466;border-radius:var(--radius-md);color:#fca5a5;display:flex;font-family:Geist,sans-serif;font-size:13px;gap:10px;padding:10px 14px}.form-actions{border-top:1px solid var(--cloud-border);gap:10px;margin-top:8px;padding-top:12px}.cancel-btn,.submit-btn{align-items:center;border-radius:var(--radius-md);display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:8px 18px;transition:all var(--transition)}.cancel-btn{background:var(--cloud-surface-3);border:1px solid var(--cloud-border);color:var(--text-secondary)}.cancel-btn:hover:not(:disabled){background:var(--cloud-surface-2);border-color:var(--cloud-border-2);color:var(--text-primary)}.submit-btn{background:var(--accent);border:1px solid #0000}.submit-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 14px #2563eb66}.submit-btn:active:not(:disabled){transform:translateY(1px)}.cancel-btn:disabled,.submit-btn:disabled{cursor:not-allowed;opacity:.4;transform:none}.spinner{animation:regSpin .6s linear infinite;height:14px;width:14px}@keyframes regSpin{to{transform:rotate(1turn)}}@media (max-width:860px){.registration-form-container{max-width:100%;padding:16px 18px}.registration-form{grid-template-columns:1fr}.registration-form .form-section:first-child,.registration-form .form-section:nth-child(2),.registration-form .form-section:nth-child(3){grid-column:1;grid-row:auto}.form-row{grid-template-columns:1fr}.upload-options{flex-direction:column}.form-actions{flex-direction:column-reverse}.cancel-btn,.submit-btn{justify-content:center;width:100%}}.registration-page{align-items:center;background:#0f1419;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.registration-background{bottom:0;left:0;position:absolute;right:0;top:0;z-index:0}.registration-gradient-1,.registration-gradient-2,.registration-gradient-3{animation:float 20s ease-in-out infinite;border-radius:50%;filter:blur(100px);opacity:.4;position:absolute}.registration-gradient-1{animation-delay:0s;background:radial-gradient(circle,#06b6d4 0,#0000 70%);height:600px;right:-300px;top:-300px;width:600px}.registration-gradient-2{animation-delay:7s;background:radial-gradient(circle,#10b981 0,#0000 70%);bottom:-250px;height:500px;left:-250px;width:500px}.registration-gradient-3{animation-delay:14s;background:radial-gradient(circle,#0891b2 0,#0000 70%);height:400px;left:50%;top:50%;transform:translate(-50%,-50%);width:400px}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.registration-success{animation:slideUp .6s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1e1e1ed9;border:1px solid #06b6d44d;border-radius:24px;box-shadow:0 20px 60px #00000080,0 0 100px #06b6d41a;max-width:600px;padding:32px 28px;position:relative;text-align:center;width:100%;z-index:1}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.success-icon{align-items:center;animation:scaleIn .5s ease-out;color:#10b981;display:flex;filter:drop-shadow(0 4px 12px rgba(16,185,129,.3));justify-content:center;margin-bottom:16px}@keyframes scaleIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.registration-success h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#06b6d4,#10b981);-webkit-background-clip:text;background-clip:text;font-size:26px;font-weight:700;margin-bottom:12px}.registration-success p{color:#f5f5f5b3;font-size:14px;line-height:1.5;margin-bottom:8px}.registration-success p strong{color:#06b6d4;font-weight:600}.success-message{background:#10b98126;border-left:4px solid #10b981;border-radius:12px;color:#f5f5f5e6;font-size:14px;padding:12px;text-align:left}.success-details,.success-message{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin:16px 0}.success-details{background:#14141499;border:1px solid #06b6d433;border-radius:12px;display:flex;flex-direction:column;gap:8px;padding:16px}.detail-item{justify-content:space-between;padding:6px 0}.detail-label{color:#f5f5f599}.detail-value{color:#f5f5f5;font-family:Courier New,monospace;font-size:13px}.status-badge{padding:4px 10px}.status-badge.pending{background:#fbbf2433;border:1px solid #fbbf244d;color:#fbbf24}.back-home-btn{background:linear-gradient(135deg,#06b6d4,#0891b2);border:none;border-radius:12px;box-shadow:0 4px 12px #06b6d44d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:16px;padding:10px 24px;transition:all .3s}.back-home-btn:hover{box-shadow:0 6px 20px #06b6d480;transform:translateY(-2px)}.back-home-btn:active{transform:translateY(0)}@media (max-width:768px){.registration-page{padding:16px}.registration-success{padding:24px 20px}.registration-success h2{font-size:22px}.detail-item{align-items:flex-start;flex-direction:column;gap:4px}}.admin-login-page{align-items:center;background:#060d1a;display:flex;font-family:DM Sans,sans-serif;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.admin-login-background{background:radial-gradient(ellipse 70% 50% at 50% 0,#29abe21a 0,#0000 55%),radial-gradient(ellipse 40% 30% at 100% 100%,#0077b614 0,#0000 50%);inset:0;position:absolute;z-index:0}.admin-login-background:after{background-image:linear-gradient(#29abe20a 1px,#0000 0),linear-gradient(90deg,#29abe20a 1px,#0000 0);background-size:48px 48px;content:"";inset:0;position:absolute}.admin-login-gradient-1{animation:mpFloat 18s ease-in-out infinite;background:radial-gradient(circle,#29abe21f 0,#0000 70%);border-radius:50%;height:480px;position:absolute;right:-240px;top:-240px;width:480px;z-index:0}.admin-login-gradient-2{animation:mpFloat 14s ease-in-out infinite reverse;background:radial-gradient(circle,#0077b61a 0,#0000 70%);border-radius:50%;bottom:-180px;height:360px;left:-180px;position:absolute;width:360px;z-index:0}@keyframes mpFloat{0%,to{transform:translate(0) scale(1)}50%{transform:translate(24px,-24px) scale(1.08)}}.admin-login-container{animation:mpSlideUp .55s cubic-bezier(.22,1,.36,1);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#08132ae0;border:1px solid #29abe247;border-radius:20px;box-shadow:0 24px 64px #0009,inset 0 0 0 1px #29abe20f,0 0 80px #29abe214;max-width:420px;padding:40px 36px 36px;position:relative;width:100%;z-index:1}.admin-login-container:before{background:linear-gradient(90deg,#0000,#29abe2,#00d4f5,#0000);border-radius:0 0 4px 4px;content:"";height:2px;left:12%;position:absolute;right:12%;top:0}@keyframes mpSlideUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.admin-login-header{margin-bottom:32px;text-align:center}.admin-login-header svg{color:#29abe2;filter:drop-shadow(0 4px 12px rgba(41,171,226,.35));margin-bottom:16px}.admin-login-logo{display:flex;justify-content:center;margin-bottom:16px}.admin-login-logo img{filter:drop-shadow(0 0 16px rgba(41,171,226,.5));height:72px;object-fit:contain;width:72px}.admin-login-header h1{color:#29abe2;font-family:Sora,sans-serif;font-size:26px;font-weight:800;letter-spacing:-.5px;margin-bottom:6px}.admin-login-header p{color:#b0d2e88c;font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase}.admin-login-form{display:flex;flex-direction:column;gap:18px}.admin-login-error{align-items:center;animation:mpShake .45s ease-in-out;background:#f0506817;border:1px solid #f050684d;border-radius:10px;color:#f05068;display:flex;font-size:13px;gap:10px;padding:11px 14px}@keyframes mpShake{0%,to{transform:translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}.admin-form-group{display:flex;flex-direction:column;gap:7px}.admin-form-group label{align-items:center;color:#b0d2e8cc;display:flex;font-size:12px;font-weight:600;gap:7px;letter-spacing:.8px;text-transform:uppercase}.admin-form-group label svg{color:#29abe2}.admin-form-group input{background:#060d1ab3;border:1px solid #29abe238;border-radius:10px;color:#e8f4fc;font-family:DM Sans,sans-serif;font-size:14px;outline:none;padding:12px 14px;transition:all .2s}.admin-form-group input::placeholder{color:#b0d2e84d}.admin-form-group input:focus{background:#060d1ae6;border-color:#29abe2;box-shadow:0 0 0 3px #29abe21f,0 0 16px #29abe226}.admin-form-group input:disabled{cursor:not-allowed;opacity:.45}.admin-login-btn{align-items:center;background:linear-gradient(135deg,#0077b6,#29abe2);border:none;border-radius:10px;box-shadow:0 4px 16px #29abe24d;color:#fff;cursor:pointer;display:flex;font-family:Sora,sans-serif;font-size:15px;font-weight:700;gap:10px;justify-content:center;letter-spacing:.3px;margin-top:6px;padding:13px 24px;transition:all .2s}.admin-login-btn:hover:not(:disabled){background:linear-gradient(135deg,#0090c8,#40c0f0);box-shadow:0 8px 24px #29abe273;transform:translateY(-2px)}.admin-login-btn:active:not(:disabled){transform:translateY(0)}.admin-login-btn:disabled{cursor:not-allowed;opacity:.6}.spinner{animation:mpSpin .7s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:15px;width:15px}@keyframes mpSpin{to{transform:rotate(1turn)}}@media (max-width:768px){.admin-login-page{padding:16px}.admin-login-container{padding:32px 24px}.admin-login-header h1{font-size:22px}}:root{--mp-bg:#060d1a;--mp-sidebar:#08132a;--mp-card:#0c1b31;--mp-card-2:#101f38;--mp-border:#29abe22e;--mp-border-hi:#29abe273;--mp-primary:#29abe2;--mp-primary-d:#0077b6;--mp-primary-l:#60c8f0;--mp-accent:#00d4f5;--mp-text:#e8f4fc;--mp-text-mute:#b0d2e88c;--mp-danger:#f05068;--mp-warn:#f5a623;--mp-success:#22c5a0}.admin-dashboard{background:#060d1a;background:var(--mp-bg);display:flex;font-family:DM Sans,sans-serif;min-height:100vh}.admin-sidebar{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#08132a;background:var(--mp-sidebar);border-right:1px solid #29abe22e;border-right:1px solid var(--mp-border);box-shadow:4px 0 32px #00000073;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:width .28s cubic-bezier(.4,0,.2,1);z-index:1000}.admin-sidebar:before{background:linear-gradient(90deg,#0000,#29abe2,#00d4f5,#0000);background:linear-gradient(90deg,#0000,var(--mp-primary),var(--mp-accent),#0000);content:"";height:3px;left:0;opacity:.8;position:absolute;right:0;top:0}.admin-sidebar.open{width:268px}.admin-sidebar.closed{width:76px}.sidebar-header{border-bottom:1px solid #29abe22e;border-bottom:1px solid var(--mp-border);justify-content:space-between;padding:20px 16px 18px}.sidebar-header,.sidebar-logo{align-items:center;display:flex}.sidebar-logo{gap:10px;overflow:hidden}.sidebar-logo img{filter:drop-shadow(0 0 6px rgba(41,171,226,.5));flex-shrink:0;height:38px;object-fit:contain;width:38px}.sidebar-logo-text{display:flex;flex-direction:column;overflow:hidden}.sidebar-logo-text span:first-child{color:#29abe2;color:var(--mp-primary);font-family:Sora,sans-serif;font-size:17px;font-weight:800;letter-spacing:-.3px;line-height:1.1;white-space:nowrap}.sidebar-logo-text span:last-child{color:#b0d2e88c;color:var(--mp-text-mute);font-size:10px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;white-space:nowrap}.sidebar-toggle{align-items:center;background:none;border:none;border-radius:8px;color:#b0d2e88c;color:var(--mp-text-mute);cursor:pointer;display:flex;flex-shrink:0;padding:6px;transition:all .2s}.sidebar-toggle:hover{background:#29abe21f;color:#29abe2;color:var(--mp-primary)}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px;overflow-y:auto;padding:16px 10px;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-item{align-items:center;border-radius:10px;color:#b0d2e88c;color:var(--mp-text-mute);display:flex;font-size:14px;font-weight:500;gap:12px;overflow:hidden;padding:11px 14px;position:relative;text-decoration:none;transition:all .2s;white-space:nowrap}.nav-item:hover{background:#29abe214;color:#60c8f0;color:var(--mp-primary-l)}.nav-item.active{background:#29abe224;color:#29abe2;color:var(--mp-primary);font-weight:600}.nav-item.active:before{background:linear-gradient(180deg,#29abe2,#00d4f5);background:linear-gradient(180deg,var(--mp-primary),var(--mp-accent));border-radius:0 3px 3px 0;bottom:20%;content:"";left:0;position:absolute;top:20%;width:3px}.nav-item svg{flex-shrink:0}.admin-sidebar.closed .nav-item span,.admin-sidebar.closed .sidebar-logo-text{display:none}.sidebar-footer{border-top:1px solid #29abe22e;border-top:1px solid var(--mp-border);padding:14px 10px}.admin-profile{background:#29abe20f;border:1px solid #29abe22e;border:1px solid var(--mp-border);border-radius:10px;gap:10px;margin-bottom:8px;padding:10px 12px}.admin-avatar,.admin-profile{align-items:center;display:flex}.admin-avatar{background:linear-gradient(135deg,#0077b6,#29abe2);background:linear-gradient(135deg,var(--mp-primary-d) 0,var(--mp-primary) 100%);border:2px solid #29abe266;border-radius:50%;color:#fff;flex-shrink:0;font-family:Sora,sans-serif;font-size:15px;font-weight:700;height:36px;justify-content:center;width:36px}.admin-details{flex:1 1;min-width:0}.admin-name{color:#e8f4fc;color:var(--mp-text);font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-role{color:#b0d2e88c;color:var(--mp-text-mute);font-size:10px;letter-spacing:1px;text-transform:uppercase}.logout-btn{align-items:center;background:#f0506814;border:1px solid #f0506840;border-radius:10px;color:#f05068;color:var(--mp-danger);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:10px;justify-content:center;padding:10px 14px;transition:all .2s;width:100%}.logout-btn:hover{background:#f0506829;border-color:#f0506873}.admin-sidebar.closed .logout-btn span{display:none}.admin-sidebar.closed .admin-profile{justify-content:center;padding:8px}.admin-main{background:radial-gradient(ellipse 60% 40% at 80% -10%,#29abe212 0,#0000 60%),radial-gradient(ellipse 40% 30% at 0 80%,#0077b60d 0,#0000 50%),#060d1a;background:radial-gradient(ellipse 60% 40% at 80% -10%,#29abe212 0,#0000 60%),radial-gradient(ellipse 40% 30% at 0 80%,#0077b60d 0,#0000 50%),var(--mp-bg);flex:1 1;margin-left:268px;min-height:100vh;padding:36px 40px;transition:margin-left .28s cubic-bezier(.4,0,.2,1)}.admin-sidebar.closed~.admin-main{margin-left:76px}@media (max-width:1024px){.admin-sidebar{transform:translateX(-100%)}.admin-sidebar.open{transform:translateX(0)}.admin-main{margin-left:0!important}.sidebar-toggle{background:#08132a;background:var(--mp-sidebar);border:1px solid #29abe22e;border:1px solid var(--mp-border);left:16px;position:fixed;top:16px;z-index:1001}}@media (max-width:768px){.admin-main{padding:20px 16px}}.admin-home{margin:0 auto;max-width:1400px}.admin-home-header{border-bottom:1px solid #29abe22e;border-bottom:1px solid var(--mp-border,#29abe22e);margin-bottom:36px;padding-bottom:24px}.admin-home-header h1{color:#e8f4fc;color:var(--mp-text,#e8f4fc);font-family:Sora,sans-serif;font-size:30px;font-weight:800;letter-spacing:-.5px;margin-bottom:6px}.admin-home-header h1 span{color:#29abe2;color:var(--mp-primary,#29abe2)}.admin-home-header p{color:#b0d2e88c;color:var(--mp-text-mute,#b0d2e88c);font-size:14px;font-weight:500}.loading-container{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.loading-container p{color:#b0d2e88c;color:var(--mp-text-mute,#b0d2e88c);font-size:14px}.spinner-large{animation:mpHomeSpin .75s linear infinite;border:3px solid #29abe22e;border-radius:50%;border-top:3px solid var(--mp-primary,#29abe2);height:44px;width:44px}@keyframes mpHomeSpin{to{transform:rotate(1turn)}}.stats-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:36px}.stat-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0c1b31;background:var(--mp-card,#0c1b31);border:1px solid #29abe22e;border:1px solid var(--mp-border,#29abe22e);border-radius:14px;gap:18px;overflow:hidden;padding:22px 24px;position:relative;transition:transform .2s,box-shadow .2s,border-color .2s}.stat-card:after{background:radial-gradient(circle,#29abe240 0,#0000 70%);background:radial-gradient(circle,var(--stat-color,#29abe240) 0,#0000 70%);border-radius:50%;bottom:-20px;content:"";height:80px;left:-20px;opacity:.5;position:absolute;width:80px}.stat-card:hover{border-color:#29abe273;border-color:var(--mp-border-hi,#29abe273);box-shadow:0 8px 28px #00000059;transform:translateY(-3px)}.stat-icon{background:#29abe214;border:1px solid #29abe226;flex-shrink:0;height:52px;width:52px}.stat-content{flex:1 1}.stat-title{color:#b0d2e88c;color:var(--mp-text-mute,#b0d2e88c);font-size:11px;font-weight:600;letter-spacing:1px;margin-bottom:6px;text-transform:uppercase}.stat-value{color:#e8f4fc;color:var(--mp-text,#e8f4fc);font-family:Sora,sans-serif;font-size:34px;font-weight:800;letter-spacing:-1px;line-height:1}.admin-home-info{margin-top:8px}.info-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0c1b31;background:var(--mp-card,#0c1b31);border:1px solid #29abe22e;border:1px solid var(--mp-border,#29abe22e);border-radius:14px;padding:28px 32px}.info-card h3{color:#e8f4fc;color:var(--mp-text,#e8f4fc);font-family:Sora,sans-serif;font-size:17px;font-weight:700;margin-bottom:12px}.info-card p{color:#b0d2e899;color:var(--mp-text-mute,#b0d2e899);font-size:14px;line-height:1.65;margin-bottom:14px}.info-card ul{list-style:none;margin:0;padding:0}.info-card li{color:#b0d2e899;color:var(--mp-text-mute,#b0d2e899);font-size:14px;line-height:1.9;padding-left:22px;position:relative}.info-card li:before{color:#29abe2;color:var(--mp-primary,#29abe2);content:"›";font-size:16px;font-weight:700;left:0;position:absolute}.info-card li strong{color:#60c8f0;color:var(--mp-primary-l,#60c8f0);font-weight:600}@media (max-width:768px){.admin-home-header h1{font-size:24px}.stats-grid{gap:14px;grid-template-columns:1fr}.stat-card{padding:18px 20px}.stat-icon{height:46px;width:46px}.stat-value{font-size:28px}.info-card{padding:20px 22px}}.admin-registrations{margin:0 auto;max-width:1600px}.registrations-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:32px}.registrations-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0077b6,#29abe2);-webkit-background-clip:text;background-clip:text;font-family:Sora,sans-serif;font-size:32px;font-weight:700;margin-bottom:8px}.registrations-header p{color:#b0d2e88c;font-size:16px}.refresh-btn{background:#29abe21a;border:1px solid #29abe24d;border-radius:12px;color:#29abe2;font-weight:600;padding:12px 20px;transition:all .3s}.refresh-btn:hover{background:#29abe233;border-color:#29abe2}.registrations-filters{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.search-box{align-items:center;background:#0c1b3199;border:1px solid #29abe24d;border-radius:12px;display:flex;flex:1 1;gap:12px;min-width:300px;padding:12px 16px;transition:all .3s}.search-box:focus-within{border-color:#29abe2;box-shadow:0 0 0 3px #29abe21a}.search-box svg{color:#b0d2e859;flex-shrink:0}.search-box input{background:none;border:none;color:#e8f4fc;flex:1 1;font-size:15px;outline:none}.search-box input::placeholder{color:#b0d2e859}.filter-group{align-items:center;background:#0c1b3199;border:1px solid #29abe24d;border-radius:12px;gap:12px;padding:12px 16px}.filter-group svg{color:#b0d2e859;flex-shrink:0}.filter-group select{background:none;border:none;color:#e8f4fc;cursor:pointer;font-size:15px;outline:none;padding-right:8px}.filter-group select option{background:#1a1a1a;color:#e8f4fc}.registrations-table{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0c1b3199;border:1px solid #29abe233;border-radius:16px;overflow:hidden}.registrations-table table{border-collapse:collapse;width:100%}.registrations-table thead{background:#29abe21a}.registrations-table th{color:#29abe2;font-size:14px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.registrations-table td{border-top:1px solid #29abe21a;color:#e8f4fce6;font-size:15px;padding:16px}.registrations-table tbody tr{transition:background .2s}.registrations-table tbody tr:hover{background:#29abe20d}.name-cell,.status-badge{font-weight:600}.status-badge{border-radius:20px;display:inline-block;font-size:12px;letter-spacing:.5px;padding:4px 12px}.action-btn{background:#29abe21a;border:1px solid #29abe24d;color:#29abe2;transition:all .3s}.action-btn:hover{background:#29abe233;border-color:#29abe2}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;z-index:2000}.modal-content{background:#141414f2;border:1px solid #29abe24d;border-radius:24px;box-shadow:0 20px 60px #00000080;max-width:900px}.modal-header{border-bottom:1px solid #29abe233;padding:24px 32px}.modal-header h2{color:#e8f4fc;font-size:24px;font-weight:700}.close-btn{border-radius:8px;color:#b0d2e88c;font-size:32px;height:32px;justify-content:center;padding:0;transition:all .3s;width:32px}.close-btn:hover{background:#ef44441a;color:#ef4444}.modal-body{padding:32px}.detail-section{margin-bottom:32px}.detail-section:last-child{margin-bottom:0}.detail-section h3{border-bottom:1px solid #29abe233;color:#29abe2;font-size:18px;font-weight:600;margin-bottom:16px;padding-bottom:8px}.detail-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.detail-item{flex-direction:column;gap:4px}.detail-label{color:#b0d2e873;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:#e8f4fc;font-size:15px;font-weight:500}.id-cards-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.id-card-item{display:flex;flex-direction:column;gap:12px}.id-card-label{color:#b0d2e899;font-size:14px;font-weight:600}.id-card-image{background:#0000004d;border:1px solid #29abe24d;border-radius:12px;height:auto;width:100%}.no-image{background:#0000004d;border:1px dashed #29abe24d;border-radius:12px;color:#b0d2e859;font-style:italic;padding:48px;text-align:center}.action-buttons{display:flex;flex-direction:column;gap:16px}.verify-btn{align-items:center;background:linear-gradient(135deg,#0077b6,#059669);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;padding:14px 24px;transition:all .3s}.verify-btn:hover:not(:disabled){box-shadow:0 6px 20px #0077b666;transform:translateY(-2px)}.verify-btn:disabled{cursor:not-allowed;opacity:.5}.reject-section{display:flex;gap:12px}.reject-section input{background:#0c1b3199;border:1px solid #ef44444d;border-radius:12px;color:#e8f4fc;flex:1 1;font-size:15px;outline:none;padding:12px 16px}.reject-section input:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.reject-btn{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;padding:12px 24px;transition:all .3s;white-space:nowrap}.reject-btn:hover:not(:disabled){box-shadow:0 6px 20px #ef444466;transform:translateY(-2px)}.reject-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:1024px){.registrations-table{overflow-x:auto}.registrations-table table{min-width:800px}}@media (max-width:768px){.registrations-header{flex-direction:column;gap:16px}.registrations-filters{flex-direction:column}.search-box{min-width:100%}.modal-content{max-height:95vh}.modal-body,.modal-header{padding:20px}.detail-grid,.id-cards-grid{grid-template-columns:1fr}.reject-section{flex-direction:column}}.admin-recharges{margin:0 auto;max-width:1400px}.recharges-header{margin-bottom:32px}.recharges-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0077b6,#29abe2);-webkit-background-clip:text;background-clip:text;font-family:Sora,sans-serif;font-size:32px;font-weight:700;margin-bottom:8px}.recharges-header p{color:#b0d2e88c;font-size:16px}.recharges-filters{margin-bottom:24px}.clients-table-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0c1b3199;border:1px solid #29abe233;border-radius:16px;overflow:hidden}.clients-table{border-collapse:collapse;width:100%}.clients-table thead{background:#29abe21a}.clients-table th{border-bottom:1px solid #29abe233;color:#29abe2;font-size:14px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.clients-table td{border-bottom:1px solid #29abe21a;color:#e8f4fce6;font-size:15px;padding:16px}.clients-table tbody tr{transition:background .2s}.clients-table tbody tr:hover{background:#29abe20d}.clients-table tbody tr:last-child td{border-bottom:none}.client-name-cell{align-items:center;display:flex;gap:12px}.email-cell{color:#b0d2e899;font-size:14px}.balance-amount{color:#0077b6;font-size:16px;font-weight:700}.nodes-count{color:#29abe2;font-size:15px;font-weight:600}.action-buttons-cell,.recharge-btn-table{align-items:center;display:flex;gap:8px}.recharge-btn-table{background:linear-gradient(135deg,#29abe2,#0891b2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .3s;white-space:nowrap}.recharge-btn-table:hover{box-shadow:0 6px 20px #29abe266;transform:translateY(-2px)}.limits-btn-table{align-items:center;background:#0077b61a;border:1px solid #0077b64d;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:18px;height:36px;justify-content:center;padding:0;transition:all .3s;width:36px}.limits-btn-table:hover{background:#0077b633;border-color:#0077b6;transform:translateY(-2px)}.no-data{color:#b0d2e873;font-style:italic;padding:48px 16px;text-align:center}.client-summary{align-items:center;background:#29abe20d;border:1px solid #29abe233;border-radius:16px;display:flex;gap:20px;margin-bottom:24px;padding:24px}.client-avatar-large{font-size:32px;height:72px;width:72px}.client-summary h3{color:#e8f4fc;font-size:18px;font-weight:600;margin-bottom:4px}.current-balance{color:#b0d2e899;font-size:14px;margin-top:8px}.current-balance strong{color:#0077b6;font-size:16px}.recharge-form{display:flex;flex-direction:column;gap:20px}.balance-mode-selector{background:#14141499;border:1px solid #29abe233;border-radius:12px;display:flex;gap:12px;padding:4px}.mode-btn{background:#0000;border:none;border-radius:8px;color:#b0d2e88c;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:10px 16px;transition:all .3s}.mode-btn:hover{background:#29abe21a;color:#e8f4fce6}.mode-btn.active{background:linear-gradient(135deg,#29abe2,#0891b2);box-shadow:0 4px 12px #29abe24d;color:#fff}.balance-hint{color:#b0d2e873;font-size:13px;font-style:italic;margin-top:8px}.recharge-form .form-group{display:flex;flex-direction:column;gap:8px}.recharge-form label{align-items:center;color:#e8f4fce6;display:flex;font-size:14px;font-weight:600;gap:8px}.recharge-form label svg{color:#29abe2}.recharge-form input,.recharge-form textarea{background:#14141499;border:1px solid #29abe24d;border-radius:12px;color:#e8f4fc;font-family:inherit;font-size:15px;outline:none;padding:12px 16px;transition:all .3s}.recharge-form input::placeholder,.recharge-form textarea::placeholder{color:#b0d2e859}.recharge-form input:focus,.recharge-form textarea:focus{background:#141414cc;border-color:#29abe2;box-shadow:0 0 0 3px #29abe21a}.recharge-form input:disabled,.recharge-form textarea:disabled{cursor:not-allowed;opacity:.5}.submit-recharge-btn{align-items:center;background:linear-gradient(135deg,#0077b6,#059669);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;margin-top:8px;padding:14px 24px;transition:all .3s}.submit-recharge-btn:hover:not(:disabled){box-shadow:0 6px 20px #0077b666;transform:translateY(-2px)}.submit-recharge-btn:disabled{cursor:not-allowed;opacity:.5}.limits-modal{max-width:900px}.limits-form{display:flex;flex-direction:column;gap:24px}.limits-grid{grid-gap:16px;background:#29abe20d;border:1px solid #29abe233;border-radius:12px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));padding:20px}.limit-item{display:flex;flex-direction:column;gap:6px}.limit-item label{color:#b0d2e88c;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.limit-item input{background:#14141499;border:1px solid #29abe24d;border-radius:8px;color:#e8f4fc;font-size:14px;font-weight:600;outline:none;padding:8px 12px;text-align:center;transition:all .3s}.limit-item input:focus{background:#141414cc;border-color:#29abe2;box-shadow:0 0 0 3px #29abe21a}.limit-item input:disabled{cursor:not-allowed;opacity:.5}.submit-limits-btn{align-items:center;background:linear-gradient(135deg,#0077b6,#059669);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;margin-top:8px;padding:14px 24px;transition:all .3s}.submit-limits-btn:hover:not(:disabled){box-shadow:0 6px 20px #0077b666;transform:translateY(-2px)}.submit-limits-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:1024px){.clients-table-container{overflow-x:auto}.clients-table{min-width:800px}}@media (max-width:768px){.clients-table td,.clients-table th{font-size:13px;padding:12px}.client-avatar-small{font-size:14px;height:32px;width:32px}.recharge-btn-table{font-size:13px;padding:6px 12px}.recharge-btn-table span{display:none}.client-summary{flex-direction:column;text-align:center}}.reset-prod-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf}.reset-prod-modal{border:1.5px solid #ef4444;box-shadow:0 0 0 4px #ef44441f,0 24px 48px #0006;max-width:560px}.reset-prod-header{align-items:center;background:linear-gradient(135deg,#1a0a0a,#2d1515);border-bottom:1px solid #ef44444d;border-radius:12px 12px 0 0;display:flex;gap:14px;padding:20px 24px}.reset-prod-header h2{color:#fca5a5;font-size:18px;font-weight:700;margin:0 0 2px}.reset-prod-subtitle{color:#f87171;font-size:12px;margin:0;opacity:.8}.reset-prod-icon{color:#ef4444;flex-shrink:0}.reset-prod-header .close-btn{color:#f87171;margin-left:auto}.reset-client-info{align-items:center;background:#ffffff0a;border-radius:8px;display:flex;gap:14px;margin-bottom:16px;padding:16px}.reset-avatar{background:linear-gradient(135deg,#7f1d1d,#b91c1c)!important;border:2px solid #ef444466!important}.reset-resources-box{background:#ef44440f;border:1px solid #ef444433;border-radius:8px;margin-bottom:14px;padding:14px 16px}.reset-resources-title{align-items:center;color:#f87171;display:flex;font-size:13px;font-weight:500;gap:6px;margin:0 0 12px}.reset-resources-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}.reset-resource-item{align-items:center;background:#ffffff08;border:1px solid #ffffff0f;border-radius:6px;display:flex;flex-direction:column;gap:2px;padding:8px 6px;text-align:center}.reset-resource-item.has-data{background:#ef44440f;border-color:#ef44444d}.reset-resource-icon{font-size:16px}.reset-resource-label{color:#94a3b8;font-size:11px;white-space:nowrap}.reset-resource-count{color:#f1f5f9;font-size:18px;font-weight:700}.reset-resource-item.has-data .reset-resource-count{color:#fca5a5}.reset-nodes-detail{border-top:1px solid #ffffff0f;margin-top:12px;padding-top:10px}.reset-nodes-detail-title{color:#64748b;font-size:11px;letter-spacing:.5px;margin:0 0 6px;text-transform:uppercase}.reset-nodes-types{display:flex;flex-wrap:wrap;gap:6px}.reset-node-type-badge{background:#ef44441a;border:1px solid #ef444433;border-radius:20px;color:#fca5a5;font-size:11px;padding:2px 8px}.reset-warning-box{align-items:flex-start;background:#f59e0b14;border:1px solid #f59e0b40;border-radius:8px;color:#fbbf24;display:flex;font-size:13px;gap:8px;line-height:1.5;margin-bottom:16px;padding:12px 14px}.reset-warning-box svg{color:#f59e0b;flex-shrink:0;margin-top:1px}.reset-confirm-section{margin-bottom:20px}.reset-confirm-label{color:#94a3b8;display:block;font-size:13px;line-height:1.5;margin-bottom:8px}.reset-confirm-label strong{background:#ef444426;border-radius:4px;color:#f1f5f9;font-family:Courier New,monospace;padding:1px 6px}.reset-confirm-input{background:#ffffff0a;border:1.5px solid #ef44444d;border-radius:8px;box-sizing:border-box;color:#f1f5f9;font-family:Courier New,monospace;font-size:16px;font-weight:700;letter-spacing:2px;padding:10px 14px;text-align:center;transition:border-color .2s,box-shadow .2s;width:100%}.reset-confirm-input:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef444426;outline:none}.reset-confirm-input.valid{border-color:#22c55e;box-shadow:0 0 0 3px #22c55e26;color:#4ade80}.reset-prod-footer{display:flex;gap:12px;justify-content:flex-end}.reset-prod-confirm-btn{align-items:center;background:linear-gradient(135deg,#dc2626,#b91c1c);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s}.reset-prod-confirm-btn:hover:not(:disabled){background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef444459;transform:translateY(-1px)}.reset-prod-confirm-btn:disabled{cursor:not-allowed;opacity:.4;transform:none}.admin-charges{margin:0 auto;max-width:1600px}.charges-header{margin-bottom:32px}.charges-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0077b6,#29abe2);-webkit-background-clip:text;background-clip:text;font-family:Sora,sans-serif;font-size:32px;font-weight:700;margin-bottom:8px}.charges-header p{color:#b0d2e88c;font-size:16px}.charges-layout{grid-gap:24px;display:grid;gap:24px;grid-template-columns:320px 1fr;min-height:600px}.clients-sidebar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0c1b3199;border:1px solid #29abe233;border-radius:16px;display:flex;flex-direction:column;gap:16px;padding:20px}.sidebar-search{align-items:center;background:#14141499;border:1px solid #29abe24d;border-radius:10px;display:flex;gap:10px;padding:10px 14px}.sidebar-search svg{color:#b0d2e859;flex-shrink:0}.sidebar-search input{background:none;border:none;color:#e8f4fc;flex:1 1;font-size:14px;outline:none}.clients-list{display:flex;flex:1 1;flex-direction:column;gap:8px;overflow-y:auto}.client-item{align-items:center;background:#14141466;border:1px solid #29abe233;border-radius:12px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .3s}.client-item:hover{background:#29abe21a;border-color:#29abe266}.client-item.active{background:#29abe233;border-color:#29abe2;box-shadow:0 0 20px #29abe233}.client-avatar-small{align-items:center;background:linear-gradient(135deg,#0077b6,#29abe2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:40px;justify-content:center;width:40px}.client-info-small{flex:1 1;min-width:0}.client-name{color:#e8f4fc;font-size:14px;font-weight:600;margin-bottom:2px}.client-email-small,.client-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.client-email-small{color:#b0d2e873;font-size:12px}.charges-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0c1b3199;border:1px solid #29abe233;border-radius:16px;gap:24px;padding:24px}.charges-content,.no-selection{display:flex;flex-direction:column}.no-selection{align-items:center;color:#b0d2e859;gap:16px;justify-content:center;min-height:400px}.no-selection svg{opacity:.3}.no-selection h3{color:#b0d2e88c;font-size:20px;font-weight:600}.no-selection p{font-size:14px}.charges-filters{align-items:center;border-bottom:1px solid #29abe233;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;padding-bottom:24px}.client-header{align-items:center;display:flex;gap:16px}.client-avatar-large{align-items:center;background:linear-gradient(135deg,#0077b6,#29abe2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:28px;font-weight:700;height:64px;justify-content:center;width:64px}.client-header h2{color:#e8f4fc;font-size:20px;font-weight:600;margin-bottom:4px}.date-filters{align-items:flex-end;display:flex;gap:12px}.date-input{display:flex;flex-direction:column;gap:6px}.date-input label{color:#b0d2e88c;font-size:12px;font-weight:600}.date-input input{background:#14141499;border:1px solid #29abe24d;border-radius:10px;color:#e8f4fc;font-size:14px;outline:none;padding:10px 14px;transition:all .3s}.date-input input:focus{border-color:#29abe2;box-shadow:0 0 0 3px #29abe21a}.filter-btn{background:#29abe21a;border:1px solid #29abe24d;border-radius:10px;color:#29abe2;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s;white-space:nowrap}.filter-btn:hover{background:#29abe233;border-color:#29abe2}.charges-summary{align-items:center;display:flex;gap:16px}.summary-card{background:#29abe20d;border:1px solid #29abe233;border-radius:12px;flex:1 1;padding:20px}.summary-label{color:#b0d2e873;font-size:12px;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.summary-value{color:#29abe2;font-size:28px;font-weight:700}.export-btn{align-items:center;background:#0077b61a;border:1px solid #0077b64d;border-radius:10px;color:#0077b6;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 20px;transition:all .3s;white-space:nowrap}.export-btn:hover{background:#0077b633;border-color:#0077b6}.charges-table{overflow-x:auto}.charges-table table{border-collapse:collapse;width:100%}.charges-table thead{background:#29abe21a}.charges-table th{color:#29abe2;font-size:13px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.charges-table td{border-top:1px solid #29abe21a;color:#e8f4fce6;font-size:14px;padding:14px 16px}.charges-table tbody tr{transition:background .2s}.charges-table tbody tr:hover{background:#29abe20d}.charge-type{background:#29abe21a;border:1px solid #29abe24d;border-radius:12px;color:#29abe2;display:inline-block;font-size:12px;font-weight:600;padding:4px 10px}.charge-amount{color:#0077b6;font-size:15px;font-weight:700}@media (max-width:1024px){.charges-layout{grid-template-columns:1fr}.clients-sidebar{max-height:300px}.charges-filters{align-items:flex-start;flex-direction:column}.date-filters{flex-wrap:wrap;width:100%}.date-input{flex:1 1;min-width:120px}}@media (max-width:768px){.charges-summary{flex-direction:column}.summary-card{width:100%}.export-btn{justify-content:center;width:100%}.charges-table{overflow-x:auto}.charges-table table{min-width:600px}}.monitoring-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.monitoring-modal{background:var(--cloud-surface);border:1px solid var(--cloud-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #000000b3;max-height:90vh;max-width:800px;overflow-y:auto;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin;width:100%}.monitoring-header{align-items:center;background:var(--cloud-surface-2);border-bottom:1px solid var(--cloud-border);display:flex;justify-content:space-between;padding:12px 18px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.header-info{align-items:center;display:flex;gap:10px}.header-info svg{color:#a5b4fc}.header-info h2{color:var(--text-primary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;margin:0}.header-info .server-ip{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px}.header-actions{align-items:center;gap:8px}.collect-btn{align-items:center;background:var(--accent-dim);border:1px solid #2563eb4d;border-radius:var(--radius-sm);color:var(--text-accent);cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:12px;gap:6px;padding:5px 12px;transition:all var(--transition)}.collect-btn:hover:not(:disabled){background:#2563eb26;border-color:var(--accent)}.collect-btn:disabled{cursor:not-allowed;opacity:.4}.close-btn{align-items:center;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);display:flex;padding:5px;transition:all var(--transition)}.close-btn:hover{background:var(--cloud-surface-3);border-color:var(--cloud-border);color:var(--text-primary)}.live-indicator{align-items:center;border-radius:20px;display:flex;font-family:Geist Mono,monospace;font-size:11px;font-weight:500;gap:5px;padding:3px 10px;transition:all var(--transition)}.live-indicator.connected{background:#10b9811f;border:1px solid #10b9814d;color:#6ee7b7}.live-indicator.connected svg{animation:monitorPulse 2s ease-in-out infinite}.live-indicator.disconnected{background:var(--danger-dim);border:1px solid #ef44444d;color:#fca5a5}@keyframes monitorPulse{0%,to{opacity:1}50%{opacity:.4}}.spin{animation:monitorSpin .7s linear infinite}@keyframes monitorSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.monitoring-error{align-items:center;background:var(--danger-dim);border-bottom:1px solid #ef444440;color:#fca5a5;display:flex;font-family:Geist,sans-serif;font-size:13px;gap:10px;padding:10px 18px}.monitoring-loading{font-family:Geist,sans-serif;font-size:13px}.monitoring-loading,.monitoring-no-data{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:12px;justify-content:center;padding:48px 20px}.monitoring-no-data svg{opacity:.4}.monitoring-no-data button{align-items:center;background:var(--accent);border:1px solid #0000;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-family:Geist,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:7px 16px;transition:all var(--transition)}.monitoring-no-data button:hover{background:var(--accent-hover)}.monitoring-content{padding:16px 18px}.status-bar{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);flex-wrap:wrap;gap:20px;margin-bottom:16px;padding:10px 14px}.status-bar,.status-indicator{align-items:center;display:flex}.status-indicator{font-family:Geist,sans-serif;font-size:13px;font-weight:500;gap:6px}.status-indicator.online{color:#6ee7b7}.status-indicator.offline{color:#fca5a5}.last-update,.uptime{align-items:center;color:var(--text-muted);display:flex;font-family:Geist Mono,monospace;font-size:11px;gap:5px}.metrics-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-bottom:16px}.metric-card{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);padding:12px 14px}.metric-header{align-items:center;display:flex;gap:8px;margin-bottom:10px}.metric-header svg{color:#a5b4fc}.metric-label{color:var(--text-secondary);flex:1 1;font-family:Geist,sans-serif;font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:uppercase}.metric-value{color:var(--text-primary);font-family:Geist Mono,monospace;font-size:20px;font-weight:700}.metric-bar{background:var(--cloud-border);border-radius:3px;height:4px;margin-bottom:6px;overflow:hidden}.metric-fill{border-radius:3px;height:100%;transition:width .3s ease}.metric-details{color:var(--text-muted);font-family:Geist Mono,monospace;font-size:11px}.lxc-section,.partitions-section{background:var(--cloud-surface-2);border:1px solid var(--cloud-border);border-radius:var(--radius-md);margin-bottom:12px;padding:12px 14px}.section-header{gap:8px;margin-bottom:12px}.section-header svg{color:#a5b4fc}.section-header h3{color:var(--text-primary);flex:1 1;font-family:Geist,sans-serif;font-size:12px;font-weight:600;letter-spacing:.04em;margin:0;text-transform:uppercase}.lxc-stats{display:flex;font-family:Geist Mono,monospace;font-size:11px;gap:10px}.lxc-stats .running{color:#6ee7b7}.lxc-stats .stopped{color:#fca5a5}.lxc-stats .total{color:var(--text-muted)}.lxc-list{max-height:280px;overflow-y:auto;scrollbar-color:var(--cloud-border-2) #0000;scrollbar-width:thin}.lxc-item{grid-gap:10px;align-items:center;background:var(--cloud-surface);border:1px solid #0000;border-radius:var(--radius-sm);display:grid;gap:10px;grid-template-columns:20px 1fr 110px 70px;margin-bottom:3px;padding:8px 10px}.lxc-item.running{border-left:2px solid #10b98180}.lxc-item.stopped{border-left:2px solid #ef444466}.lxc-status{align-items:center;display:flex;justify-content:center}.lxc-item.running .lxc-status{color:#6ee7b7}.lxc-item.stopped .lxc-status{color:#fca5a5}.lxc-name{color:var(--text-primary);font-family:Geist Mono,monospace;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lxc-ip{font-size:11px}.lxc-ip,.lxc-state{color:var(--text-muted);font-family:Geist Mono,monospace}.lxc-state{font-size:10px;letter-spacing:.04em;text-transform:uppercase}.no-containers{color:var(--text-muted);font-family:Geist,sans-serif;font-size:12px;padding:16px;text-align:center}.partitions-list{gap:10px}.partition-item,.partitions-list{display:flex;flex-direction:column}.partition-item{gap:5px}.partition-info{display:flex;font-size:11px;justify-content:space-between}.partition-device{color:var(--text-secondary);font-family:Geist Mono,monospace}.partition-mount{color:var(--text-muted);font-family:Geist Mono,monospace}.partition-bar{background:var(--cloud-border);border-radius:3px;height:4px;overflow:hidden}.partition-fill{border-radius:3px;height:100%}.partition-stats{color:var(--text-muted);display:flex;font-family:Geist Mono,monospace;font-size:10px;justify-content:space-between}.error-section{align-items:center;background:var(--danger-dim);border:1px solid #ef444440;border-radius:var(--radius-md);color:#fca5a5;display:flex;font-family:Geist,sans-serif;font-size:12px;gap:7px;padding:10px 12px}@media (max-width:768px){.monitoring-modal{margin:10px;max-width:100%}.monitoring-header{align-items:flex-start;flex-direction:column;gap:8px}.header-actions{justify-content:space-between;width:100%}.status-bar{align-items:flex-start;flex-direction:column;gap:6px}.metrics-grid{grid-template-columns:1fr}.lxc-item{grid-template-columns:20px 1fr}.lxc-ip,.lxc-state{display:none}}.admin-servers{margin:0 auto;max-width:1400px;padding:24px}.admin-servers-loading{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:16px;height:400px;justify-content:center}.admin-servers-loading .spin{animation:spin 1s linear infinite}.admin-servers-header{justify-content:space-between}.admin-servers-error,.admin-servers-header{align-items:center;display:flex;margin-bottom:24px}.admin-servers-error{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#f87171;gap:12px;padding:12px 16px}.admin-servers-error button{background:none;border:none;color:#f87171;cursor:pointer;margin-left:auto;padding:4px}.stats-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.stat-card{background:#1e293b80;border:1px solid #6366f133}.stat-icon{align-items:center;background:#6366f11a;border-radius:12px;color:#818cf8;display:flex;height:48px;justify-content:center;width:48px}.stat-icon.active{background:#22c55e1a;color:#22c55e}.stat-icon.nodes{background:#f59e0b1a;color:#f59e0b}.stat-content{display:flex;flex-direction:column}.stat-value{font-weight:600}.stat-label{font-size:13px}.servers-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.server-card{background:#1e293b80;border:1px solid #6366f133;border-radius:12px;padding:20px;transition:all .2s}.server-card:hover{border-color:#6366f166;transform:translateY(-2px)}.server-card.inactive{opacity:.6}.server-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.server-info h3{color:#f1f5f9;font-size:16px;font-weight:600;margin:0 0 4px}.server-ip{color:#94a3b8;font-family:monospace;font-size:13px}.server-status{align-items:center;border-radius:20px;display:flex;font-size:12px;gap:6px;padding:4px 10px}.server-status.active{background:#22c55e1a;color:#22c55e}.server-status.inactive{background:#ef44441a;color:#ef4444}.server-details{display:flex;gap:16px;margin-bottom:12px}.detail-item{color:#94a3b8;gap:6px}.server-specs{background:#0f172a80;border-radius:8px;display:flex;gap:16px;margin-bottom:16px;padding:12px}.spec-item{align-items:center;color:#cbd5e1;display:flex;font-size:13px;gap:6px}.spec-item svg{color:#6366f1}.server-usage{margin-bottom:16px}.usage-header{color:#94a3b8;display:flex;font-size:13px;justify-content:space-between;margin-bottom:8px}.usage-value{color:#f1f5f9;font-weight:500}.usage-bar{background:#0f172acc;border-radius:4px;height:8px;overflow:hidden}.usage-fill{border-radius:4px;height:100%;transition:width .3s ease}.usage-footer{color:#64748b;display:flex;font-size:12px;justify-content:space-between;margin-top:6px}.connection-result{align-items:center;border-radius:6px;display:flex;font-size:12px;gap:8px;margin-bottom:12px;padding:8px 12px}.connection-result.success{background:#22c55e1a;color:#22c55e}.connection-result.error{background:#ef44441a;color:#ef4444}.server-actions{display:flex;gap:8px}.action-btn{border-radius:6px;flex:1 1;font-size:12px;font-weight:500;gap:6px;padding:8px 12px}.action-btn.test{background:#6366f11a;color:#818cf8}.action-btn.test:hover{background:#6366f133}.action-btn.monitor{background:#22c55e1a;color:#22c55e}.action-btn.monitor:hover{background:#22c55e33}.action-btn:disabled{cursor:not-allowed;opacity:.5}.action-btn .spin{animation:spin 1s linear infinite}.no-servers{align-items:center;background:#1e293b4d;border:2px dashed #6366f14d;border-radius:12px;color:#94a3b8;display:flex;flex-direction:column;grid-column:1/-1;justify-content:center;padding:60px 20px}.no-servers svg{opacity:.5}.no-servers p,.no-servers svg{margin-bottom:16px}.no-servers button{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:10px 20px}.modal-content{max-width:600px}.server-form{padding:24px}.form-section{margin-bottom:24px}.form-section h3{color:#818cf8;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase}.form-row{grid-template-columns:1fr 1fr}.form-row.three{grid-template-columns:1fr 1fr 1fr}.form-group{margin-bottom:16px}.form-group label{margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{background:#0f172acc;border:1px solid #6366f133;border-radius:8px;color:#f1f5f9;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#6366f1;outline:none}.form-group.checkbox label{align-items:center;cursor:pointer;display:flex;gap:8px}.form-group.checkbox input{width:auto}.form-hint{margin-top:8px}@media (max-width:768px){.admin-servers-header{align-items:flex-start;flex-direction:column;gap:16px}.form-row,.form-row.three,.servers-grid{grid-template-columns:1fr}}.admin-sshkeys{margin:0 auto;max-width:1200px;padding:24px}.admin-sshkeys-loading{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:16px;height:400px;justify-content:center}.admin-sshkeys-loading .spin{animation:spin 1s linear infinite}.admin-sshkeys-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.header-title{align-items:center;display:flex;gap:12px}.header-title h1{color:#f1f5f9;font-family:Sora,sans-serif;font-size:24px;font-weight:600;margin:0}.header-title svg{color:#6366f1}.add-btn,.refresh-btn{align-items:center;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s}.refresh-btn{background:#6366f11a;border:1px solid #6366f14d;color:#818cf8}.refresh-btn:hover{background:#6366f133}.add-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.add-btn:hover{box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.admin-sshkeys-error{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#f87171;display:flex;gap:12px;margin-bottom:24px;padding:12px 16px}.admin-sshkeys-error button{background:none;border:none;color:#f87171;cursor:pointer;margin-left:auto;padding:4px}.sshkeys-list{display:flex;flex-direction:column;gap:16px}.sshkey-card{align-items:flex-start;background:#1e293b80;border:1px solid #6366f133;border-radius:12px;display:flex;gap:16px;padding:20px;transition:all .2s}.sshkey-card:hover{border-color:#6366f166}.sshkey-icon{align-items:center;background:#6366f11a;border-radius:12px;color:#818cf8;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.sshkey-content{flex:1 1;min-width:0}.sshkey-header{align-items:center;display:flex;gap:12px;margin-bottom:8px}.sshkey-header h3{color:#f1f5f9;font-size:16px;font-weight:600;margin:0}.key-type{background:#6366f133;border-radius:4px;color:#818cf8;font-size:11px;font-weight:500;padding:2px 8px;text-transform:uppercase}.sshkey-description{color:#94a3b8;font-size:13px;margin:0 0 12px}.sshkey-details{display:flex;flex-direction:column;gap:8px}.detail-item{align-items:center;display:flex;font-size:13px;gap:8px}.detail-item .label{color:#64748b}.detail-item span:not(.label){color:#cbd5e1}.detail-item.fingerprint{background:#0f172a80;border-radius:6px;padding:8px 12px}.detail-item.fingerprint code{color:#22c55e;flex:1 1;font-family:monospace;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.copy-btn{align-items:center;background:none;border:none;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:color .2s}.copy-btn:hover{color:#818cf8}.detail-row{display:flex;gap:24px}.sshkey-actions{display:flex;flex-direction:column;gap:8px}.action-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.action-btn.edit{background:#f59e0b1a;color:#f59e0b}.action-btn.edit:hover{background:#f59e0b33}.action-btn.delete{background:#ef44441a;color:#ef4444}.action-btn.delete:hover{background:#ef444433}.no-keys{align-items:center;background:#1e293b4d;border:2px dashed #6366f14d;border-radius:12px;color:#94a3b8;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.no-keys svg{opacity:.5}.no-keys p,.no-keys svg{margin-bottom:16px}.no-keys button{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:10px 20px}.modal-content{border:1px solid #6366f14d}.modal-header{border-bottom:1px solid #6366f133;padding:20px 24px}.close-btn{background:none}.sshkey-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:13px;margin-bottom:8px}.form-group input,.form-group textarea{background:#0f172acc;border:1px solid #6366f133;border-radius:8px;color:#f1f5f9;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-group textarea{font-family:monospace;resize:vertical}.form-group input:focus,.form-group textarea:focus{border-color:#6366f1;outline:none}.form-group input::placeholder,.form-group textarea::placeholder,.form-hint{color:#64748b}.form-hint{font-size:12px;margin-top:6px}.form-actions{border-top:1px solid #6366f133;padding-top:16px}.cancel-btn,.submit-btn{border-radius:8px}.cancel-btn{background:#64748b33;border:1px solid #64748b4d}.cancel-btn:hover{background:#64748b4d}@media (max-width:768px){.admin-sshkeys-header{align-items:flex-start;flex-direction:column;gap:16px}.sshkey-card{flex-direction:column}.sshkey-actions{flex-direction:row;justify-content:flex-end;width:100%}.detail-row{flex-direction:column;gap:8px}}.admin-event-logs{margin:0 auto;max-width:1400px;padding:24px}.header-actions{display:flex;gap:12px}.filter-btn,.refresh-btn{align-items:center;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s}.filter-btn{background:#6366f11a;border:1px solid #6366f14d;color:#818cf8}.filter-btn:hover{background:#6366f133}.filter-btn .rotated{transform:rotate(180deg)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{text-align:center}.stat-value{font-size:28px;margin-bottom:4px}.stat-label{letter-spacing:.5px;text-transform:uppercase}.filters-panel{align-items:flex-end;background:#0f172a80;border:1px solid #6366f11a;border-radius:12px;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:20px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{color:#94a3b8;font-size:12px;font-weight:500}.filter-group select{background:#0f172acc;border:1px solid #6366f133;border-radius:6px;color:#f1f5f9;font-size:14px;min-width:150px;padding:8px 12px}.filter-group select:focus{border-color:#6366f1;outline:none}.filter-actions{display:flex;gap:8px;margin-left:auto}.apply-btn,.reset-btn{align-items:center;border-radius:6px;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.apply-btn{background:#6366f1;border:none;color:#fff}.apply-btn:hover{background:#5558e3}.reset-btn{background:#0000;border:1px solid #94a3b84d;color:#94a3b8}.reset-btn:hover{border-color:#94a3b8;color:#f1f5f9}.logs-table-container{background:#0f172a80;border:1px solid #6366f11a;border-radius:12px;overflow:hidden}.logs-table{border-collapse:collapse;width:100%}.logs-table th{background:#6366f11a;border-bottom:1px solid #6366f11a;color:#94a3b8;font-size:12px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.logs-table td{border-bottom:1px solid #6366f10d;color:#f1f5f9;font-size:13px;padding:12px 16px}.logs-table tr:hover{background:#6366f10d}.logs-table tr.failed{background:#ef44440d}.date-cell{align-items:center;color:#94a3b8;display:flex;font-size:12px;gap:6px;white-space:nowrap}.category-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:11px;font-weight:500;gap:6px;padding:4px 10px;text-transform:uppercase}.action-cell{color:#818cf8;font-family:monospace;font-size:12px}.actor-cell .actor-type{align-items:center;display:inline-flex;font-size:12px;gap:6px}.actor-type.admin{color:#f59e0b}.actor-type.client{color:#22c55e}.actor-type.system{color:#94a3b8}.description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.target-cell{color:#64748b;font-family:monospace;font-size:12px}.status-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:11px;gap:4px;padding:4px 8px}.status-badge.success{background:#22c55e1a;color:#22c55e}.status-badge.failed{background:#ef44441a;color:#ef4444}.empty-state{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center;padding:60px 20px}.empty-state svg{opacity:.5}@media (max-width:1024px){.logs-table-container{overflow-x:auto}.logs-table{min-width:900px}}@media (max-width:768px){.page-header{align-items:flex-start;gap:16px}.filters-panel,.page-header{flex-direction:column}.filter-actions{margin-left:0;width:100%}.apply-btn,.reset-btn{flex:1 1;justify-content:center}}.admin-catalog{margin:0 auto;max-width:1400px;padding:24px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.header-left{gap:16px}.header-left svg{color:#6366f1}.header-left h1{color:#f1f5f9;font-family:Sora,sans-serif;font-size:24px;font-weight:600;margin:0}.header-left p{color:#94a3b8;font-size:14px;margin:4px 0 0}.refresh-btn{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s}.refresh-btn:hover:not(:disabled){box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.refresh-btn:disabled{cursor:not-allowed;opacity:.6}.spin{animation:spin 1s linear infinite}.error-banner{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#f87171;display:flex;gap:12px;margin-bottom:24px;padding:12px 16px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.stat-card{align-items:center;background:#0f172a80;border:1px solid #6366f11a;border-radius:12px;display:flex;gap:16px;padding:20px}.stat-card svg{color:#6366f1}.stat-info{display:flex;flex-direction:column}.stat-value{color:#f1f5f9;font-size:24px;font-weight:700}.stat-label{color:#94a3b8;font-size:12px}.tabs{border-bottom:1px solid #6366f11a;margin-bottom:24px;padding-bottom:12px}.tab,.tabs{display:flex;gap:8px}.tab{align-items:center;background:#0000;border:1px solid #6366f133;border-radius:8px;color:#94a3b8;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.tab:hover{background:#6366f11a;color:#f1f5f9}.tab.active{background:#6366f133;border-color:#6366f1;color:#818cf8}.loading-state{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:60px 20px}.section{background:#0f172a80;border:1px solid #6366f11a;border-radius:12px;padding:20px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.section-header h2{color:#f1f5f9;font-size:18px;font-weight:600;margin:0}.add-btn{align-items:center;background:#22c55e;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.add-btn:hover{background:#16a34a}.items-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.durations-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.item-card{background:#0f172acc;border:1px solid #6366f126;border-radius:10px;padding:16px;transition:all .2s}.item-card:hover{border-color:#6366f14d}.item-card.inactive{background:#0f172a66;opacity:.6}.item-header{align-items:center;display:flex;gap:8px;margin-bottom:8px}.item-icon{font-size:20px}.item-name{color:#f1f5f9;flex:1 1;font-size:16px;font-weight:600}.status-badge{border-radius:10px;font-size:10px;font-weight:500;padding:2px 8px;text-transform:uppercase}.status-badge.active{background:#22c55e1a;color:#22c55e}.status-badge.inactive{background:#ef44441a;color:#ef4444}.item-id{color:#64748b;font-family:monospace;font-size:11px;margin-bottom:6px}.item-category{color:#818cf8;font-size:12px;margin-bottom:8px}.item-description{color:#94a3b8;font-size:12px;line-height:1.4;margin-bottom:8px}.item-specs{display:flex;gap:12px;margin-bottom:8px}.item-specs span{align-items:center;color:#94a3b8;display:flex;font-size:11px;gap:4px}.item-price{color:#22c55e;font-size:14px;font-weight:600;margin-bottom:8px}.hidden-badge,.recommended-badge{border-radius:10px;display:inline-block;font-size:10px;font-weight:500;margin-bottom:8px;padding:2px 8px}.recommended-badge{background:#f59e0b1a;color:#f59e0b}.hidden-badge{background:#94a3b81a;color:#94a3b8}.duration-details{display:flex;gap:16px;margin-bottom:8px}.duration-details span{color:#94a3b8;font-size:13px}.item-actions{border-top:1px solid #6366f11a;display:flex;gap:8px;margin-top:12px;padding-top:12px}.item-actions button{background:#6366f11a;border:none;border-radius:4px;color:#818cf8;cursor:pointer;padding:6px 10px;transition:all .2s}.item-actions button:hover{background:#6366f133}.item-actions button:last-child{background:#ef44441a;color:#ef4444}.item-actions button:last-child:hover{background:#ef444433}.empty-state{color:#64748b;grid-column:1/-1;padding:40px;text-align:center}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#1e293b;border:1px solid #6366f133;border-radius:16px;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #6366f11a;display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:#f1f5f9;font-size:18px;font-weight:600;margin:0}.close-btn{background:#0000;border:none;color:#94a3b8;cursor:pointer;padding:4px}.close-btn:hover{color:#f1f5f9}.modal-form{padding:20px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-bottom:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:#94a3b8;font-size:12px;font-weight:500}.form-group input,.form-group select{background:#0f172acc;border:1px solid #6366f133;border-radius:6px;color:#f1f5f9;font-size:14px;padding:10px 12px}.form-group input:focus,.form-group select:focus{border-color:#6366f1;outline:none}.form-group input:disabled{cursor:not-allowed;opacity:.5}.checkboxes{display:flex;gap:20px;margin-bottom:16px}.checkboxes label{align-items:center;color:#f1f5f9;cursor:pointer;display:flex;font-size:13px;gap:8px}.checkboxes input[type=checkbox]{accent-color:#6366f1;height:16px;width:16px}.form-actions{border-top:1px solid #6366f11a;display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px}.cancel-btn,.submit-btn{border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.cancel-btn{background:#0000;border:1px solid #94a3b84d;color:#94a3b8}.cancel-btn:hover{border-color:#94a3b8;color:#f1f5f9}.submit-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff}.submit-btn:hover{box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.categories-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.category-card{align-items:center;background:#1e293b99;border:1px solid #94a3b833;border-radius:12px;display:flex;gap:16px;padding:20px;transition:all .3s}.category-card:hover{border-color:#6366f166;transform:translateY(-2px)}.category-card.inactive{background:#ef44440d;border-color:#ef44444d;opacity:.6}.category-icon{font-size:40px;min-width:60px;text-align:center}.category-info{flex:1 1}.category-info h3{color:#f1f5f9;font-size:18px;font-weight:600;margin:0 0 6px}.category-info p{color:#94a3b8;font-size:13px;line-height:1.4;margin:0 0 8px}.category-id{background:#6366f133;border-radius:4px;color:#a5b4fc;display:inline-block;font-family:monospace;font-size:11px;padding:2px 8px}.category-toggle,.toggle-btn{align-items:center;display:flex;flex-direction:column}.toggle-btn{background:#0000;border:none;border-radius:8px;cursor:pointer;gap:6px;padding:10px 16px;transition:all .2s}.toggle-btn.active{color:#22c55e}.toggle-btn.active:hover{background:#22c55e1a}.toggle-btn.inactive{color:#ef4444}.toggle-btn.inactive:hover{background:#ef44441a}.toggle-btn span{font-size:12px;font-weight:500}.section-description{color:#94a3b8;font-size:14px;margin:4px 0 0}.hint{color:#64748b;font-size:12px;margin-top:8px}.domain-ext-table{border-collapse:collapse;font-size:13px;width:100%}.domain-ext-table th{background:#0d1526;border-bottom:1px solid #1a2340;color:#64748b;font-size:11px;font-weight:500;letter-spacing:.5px;padding:8px 12px;text-align:left;text-transform:uppercase}.domain-ext-table td{border-bottom:1px solid #111827;padding:7px 12px;vertical-align:middle}.domain-ext-table tr:hover td{background:#00d4ff08}.domain-ext-table tr.row-inactive td{opacity:.45}.ext-badge{background:#00d4ff1a;border:1px solid #00d4ff40;border-radius:6px;color:#00d4ff;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.3px;padding:2px 8px}.ext-badge,.price-input{font-family:JetBrains Mono,monospace}.price-input{background:#0d1526;border:1px solid #1e2d45;border-radius:6px;color:#e2e8f0;font-size:13px;padding:5px 10px;transition:border-color .15s;width:120px}.price-input:focus{background:#111d35;border-color:#00d4ff;outline:none}.price-input::placeholder{color:#334155;font-size:11px}.toggle-mini{border:1px solid #0000;border-radius:5px;cursor:pointer;font-size:11px;font-weight:600;padding:3px 10px;transition:all .15s}.toggle-mini.on{background:#34d3991f;border-color:#34d3994d;color:#34d399}.toggle-mini.off{background:#64748b1f;border-color:#64748b4d;color:#64748b}.save-ext-btn{align-items:center;background:#6366f126;border:1px solid #6366f159;border-radius:6px;color:#818cf8;cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;gap:5px;padding:4px 12px;transition:all .15s}.save-ext-btn:hover:not(:disabled){background:#6366f140;color:#a5b4fc}.save-ext-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.page-header{align-items:flex-start;flex-direction:column;gap:16px}.tabs{flex-wrap:wrap}.categories-grid,.items-grid{grid-template-columns:1fr}.category-card{flex-direction:column;text-align:center}}.websocket-status{align-items:center;border-radius:20px;display:inline-flex;font-family:Geist Mono,monospace;font-size:11px;font-weight:600;gap:6px;letter-spacing:.04em;padding:4px 10px;text-transform:uppercase;transition:all var(--transition);-webkit-user-select:none;user-select:none}.websocket-status.connected{background:#10b9811f;border:1px solid #10b98140;color:#6ee7b7}.websocket-status.poor{background:#f59e0b1f;border:1px solid #f59e0b40;color:#fcd34d}.websocket-status.reconnecting{animation:wsPulse 2s ease-in-out infinite;background:var(--accent-dim);border:1px solid #2563eb4d;color:#93c5fd}.websocket-status.disconnected{background:var(--danger-dim);border:1px solid #ef444440;color:#fca5a5}@keyframes wsPulse{0%,to{opacity:1}50%{opacity:.6}}.status-icon{animation:none;font-size:10px}.websocket-status.reconnecting .status-icon{animation:wsSpin 1.2s linear infinite}@keyframes wsSpin{to{transform:rotate(1turn)}}.status-text{font-size:11px;white-space:nowrap}.reconnect-btn{background:none;border:none;border-radius:3px;color:currentColor;cursor:pointer;font-size:12px;opacity:.6;padding:2px 4px;transition:all var(--transition)}.reconnect-btn:hover{background:#ffffff14;opacity:1;transform:scale(1.1)}@media (max-width:768px){.websocket-status{padding:3px 7px}}.layout{background:var(--cloud-bg);display:flex;flex-direction:column;min-height:100vh}.top-header{background:var(--cloud-surface);border-bottom:1px solid var(--cloud-border);flex-shrink:0;height:56px;justify-content:space-between;padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-left,.top-header{align-items:center;display:flex;flex-direction:row}.header-left{cursor:pointer;gap:12px;text-decoration:none}.header-left:hover .logo-wordmark{color:var(--text-primary)}.logo-mark{align-items:center;background:var(--accent);border-radius:6px;color:#fff;display:flex;flex-shrink:0;font-family:Geist Mono,monospace;font-size:13px;font-weight:800;height:28px;justify-content:center;letter-spacing:-1px;width:28px}.logo-wordmark{color:var(--text-secondary);font-family:Geist,sans-serif;font-size:14px;font-weight:600;letter-spacing:.02em;transition:color var(--transition)}.logo,.logo-wordmark strong{color:var(--text-primary);font-weight:700}.logo{font-family:Geist Mono,monospace;font-size:14px;letter-spacing:.05em;text-transform:uppercase}.header-divider{background:var(--cloud-border-2);height:20px;width:1px}.header-nav{gap:2px;left:50%;position:absolute;transform:translateX(-50%)}.header-nav,.header-nav-link{align-items:center;display:flex}.header-nav-link{border:1px solid #0000;border-radius:8px;color:var(--text-secondary);font-family:Sora,Geist,sans-serif;font-size:13px;font-weight:500;gap:6px;padding:6px 14px;text-decoration:none;transition:all .15s ease;white-space:nowrap}.header-nav-link:hover{background:var(--cloud-surface);border-color:var(--cloud-border);color:var(--text-primary)}.header-nav-link.active{background:#00d4ff14;border-color:#00d4ff40;color:#00d4ff}.header-right{gap:8px}.btn-logout,.header-right{align-items:center;display:flex;flex-direction:row}.btn-logout{background:#0000;border:1px solid var(--cloud-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:Geist,sans-serif;font-size:13px;font-weight:500;gap:6px;padding:6px 14px;transition:all var(--transition)}.btn-logout:hover{background:var(--danger-dim);border-color:#ef444466;color:var(--danger)}.btn-logout span{display:inline}.main-content{flex:1 1;min-height:0;overflow-y:auto;width:100%}@media (max-width:768px){.top-header{height:52px;padding:0 16px}.btn-logout span,.logo-wordmark{display:none}.btn-logout{padding:6px 10px}}.dm-root{background:#080d18;color:#dde4f0;font-family:Sora,sans-serif;height:calc(100vh - 56px);position:relative}.dm-root,.dm-sidebar{display:flex;overflow:hidden}.dm-sidebar{background:#0a0f1e;border-right:1px solid #1a2340;flex-direction:column;flex-shrink:0;width:264px}.dm-sidebar-head{align-items:center;border-bottom:1px solid #1a2340;display:flex;justify-content:space-between;padding:16px 14px 12px}.dm-sidebar-title{align-items:center;color:#6b7fa3;display:flex;font-size:12px;font-weight:600;gap:7px;letter-spacing:.08em;text-transform:uppercase}.dm-count-chip{background:#00d4ff1f;border:1px solid #00d4ff40;border-radius:20px;color:#00d4ff;font-size:11px;font-weight:600;padding:1px 7px}.dm-sidebar-search{align-items:center;background:#0d1526;border:1px solid #1e2d48;border-radius:8px;color:#4a5a7a;display:flex;gap:8px;margin:10px 12px;padding:7px 10px}.dm-sidebar-search input{background:none;border:none;color:#c0cce0;flex:1 1;font-family:Sora,sans-serif;font-size:12px;outline:none}.dm-sidebar-search input::placeholder{color:#3a4a6a}.dm-sidebar-spinner{color:#00d4ff;display:flex;justify-content:center;padding:32px}.dm-sidebar-empty{align-items:center;color:#3a4a6a;display:flex;flex-direction:column;gap:10px;padding:40px 20px;text-align:center}.dm-sidebar-empty p{color:#4a5a7a;font-size:12px;margin:0}.dm-domain-list{flex:1 1;list-style:none;margin:0;overflow-y:auto;padding:6px 8px}.dm-domain-list::-webkit-scrollbar{width:4px}.dm-domain-list::-webkit-scrollbar-track{background:#0000}.dm-domain-list::-webkit-scrollbar-thumb{background:#1e2d48;border-radius:2px}.dm-domain-item{border:1px solid #0000;border-radius:8px;cursor:pointer;margin-bottom:2px;padding:9px 10px;transition:all .15s ease}.dm-domain-item:hover{background:#0d1526;border-color:#1e2d48}.dm-domain-item.active{background:#00d4ff12;border-color:#00d4ff40}.dm-di-top{align-items:center;color:#8896b0;display:flex;gap:7px;margin-bottom:4px}.dm-di-top svg{color:#4a6a90;flex-shrink:0}.dm-domain-item.active .dm-di-top svg{color:#00d4ff}.dm-di-name{color:#b0bcd4;flex:1 1;font-family:JetBrains Mono,monospace;font-size:12.5px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dm-domain-item.active .dm-di-name{color:#e0ecff}.dm-di-top .dm-domain-item.active svg:last-child{color:#00d4ff}.dm-di-bottom{align-items:center;display:flex;gap:8px;padding-left:19px}.dm-status-pip{border-radius:4px;font-size:10px;font-weight:600;letter-spacing:.05em;padding:1px 6px;text-transform:uppercase}.dm-status--active{background:#34d3991a;border:1px solid #34d39933;color:#34d399}.dm-status--expired{background:#f871711a;border:1px solid #f8717133;color:#f87171}.dm-status--pending{background:#fbbf241a;border:1px solid #fbbf2433;color:#fbbf24}.dm-di-expiry{color:#4a5a7a;font-family:JetBrains Mono,monospace;font-size:10.5px}.dm-di-expiry.expiring{color:#fbbf24}.dm-sidebar-refresh{align-items:center;background:none;border:1px solid #1e2d48;border-radius:7px;color:#4a5a7a;cursor:pointer;display:flex;font-family:Sora,sans-serif;font-size:11px;gap:6px;justify-content:center;padding:6px 10px;transition:all .15s;width:100%}.dm-sidebar-refresh:hover{background:#0d1526;border-color:#2a3a5a;color:#6a8ab0}.dm-main{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow-y:auto}.dm-main::-webkit-scrollbar{width:5px}.dm-main::-webkit-scrollbar-track{background:#0000}.dm-main::-webkit-scrollbar-thumb{background:#1e2d48;border-radius:3px}.dm-domain-header{background:linear-gradient(180deg,#00d4ff08,#0000);border-bottom:1px solid #131d30;justify-content:space-between;padding:20px 28px 16px}.dm-dh-left,.dm-domain-header{align-items:center;display:flex}.dm-dh-left{gap:14px}.dm-domain-orb{align-items:center;background:#00d4ff1a;border:1px solid #00d4ff33;border-radius:10px;color:#00d4ff;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.dm-domain-title{color:#e8f0ff;font-family:JetBrains Mono,monospace;font-size:20px;font-weight:700;letter-spacing:-.01em;margin:0 0 4px}.dm-domain-meta{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.dm-meta-dot{color:#4a5a7a;font-family:JetBrains Mono,monospace;font-size:12px}.dm-meta-dot:before{color:#2a3a5a;content:"·";margin-right:6px}.dm-meta-dot:first-child:before{content:"";margin:0}.dm-dh-actions{align-items:center;display:flex;gap:8px}.dm-tabs{border-bottom:1px solid #131d30;display:flex;gap:2px;padding:12px 28px 0}.dm-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#4a5a7a;cursor:pointer;display:flex;font-family:Sora,sans-serif;font-size:13px;font-weight:500;gap:6px;margin-bottom:-1px;padding:8px 16px;transition:all .15s}.dm-tab:hover{color:#8896b0}.dm-tab.active{border-bottom-color:#00d4ff;color:#00d4ff}.dm-tab-badge{background:#00d4ff1f;border:1px solid #00d4ff33;border-radius:20px;color:#00d4ff;font-size:10.5px;font-weight:600;padding:0 6px}.dm-records-section{flex:1 1;padding:20px 28px}.dm-records-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.dm-search-wrap{align-items:center;background:#0d1526;border:1px solid #1e2d48;border-radius:8px;color:#4a6a90;display:flex;gap:8px;min-width:200px;padding:7px 12px;transition:border-color .15s}.dm-search-wrap:focus-within{border-color:#00d4ff59}.dm-search-wrap input{background:none;border:none;color:#c0cce0;flex:1 1;font-family:Sora,sans-serif;font-size:12.5px;outline:none}.dm-search-wrap input::placeholder{color:#3a4a6a}.dm-type-filters{display:flex;flex-wrap:wrap;gap:4px}.dm-type-btn{background:none;border:1px solid #1e2d48;border-radius:6px;color:#4a5a7a;cursor:pointer;font-family:JetBrains Mono,monospace;font-size:11.5px;font-weight:600;letter-spacing:.02em;padding:5px 10px;transition:all .15s}.dm-type-btn:hover{border-color:#2a3a5a;color:#6a8ab0}.dm-type-btn.active{font-weight:700}.dm-add-form{background:#0a0f1e;border:1px solid #00d4ff33;border-radius:10px;margin-bottom:16px;padding:16px 18px}.dm-add-form-title{align-items:center;color:#00d4ff;display:flex;font-size:12px;font-weight:600;gap:7px;letter-spacing:.08em;margin-bottom:14px;text-transform:uppercase}.dm-add-form-fields{align-items:flex-end;display:flex;flex-wrap:wrap;gap:10px}.dm-fg{display:flex;flex-direction:column;gap:5px}.dm-fg label{color:#4a6a90;font-size:11px;font-weight:500;letter-spacing:.07em;text-transform:uppercase}.dm-fg-grow{flex:1 1;min-width:140px}.dm-fg-grow2{flex:2 1;min-width:200px}.dm-add-form-actions{border-top:1px solid #131d30;display:flex;gap:8px;margin-top:14px;padding-top:12px}.dm-table{border:1px solid #131d30;border-radius:10px;overflow:hidden}.dm-table-head{grid-gap:0;background:#0a0f1e;border-bottom:1px solid #1a2340;display:grid;gap:0;grid-template-columns:72px 1fr 2fr 64px 100px;padding:0 16px}.dm-table-head span{color:#3a4a6a;font-size:10.5px;font-weight:600;letter-spacing:.08em;padding:10px 8px;text-transform:uppercase}.dm-table-body{background:#080d18}.dm-row{grid-gap:0;align-items:center;border-bottom:1px solid #0d1526;display:grid;gap:0;grid-template-columns:72px 1fr 2fr 64px 100px;min-height:48px;padding:0 16px;transition:background .12s}.dm-row:last-child{border-bottom:none}.dm-row:hover{background:#0d1526cc}.dm-row--editing{background:#00d4ff0a!important;border-color:#00d4ff26!important}.dm-type-badge{align-items:center;border:1px solid #0000;border-radius:5px;display:inline-flex;font-size:11px;font-weight:700;justify-content:center;letter-spacing:.04em;padding:3px 8px}.dm-rec-name,.dm-type-badge{font-family:JetBrains Mono,monospace;white-space:nowrap}.dm-rec-name{color:#c0cce0;font-size:13px;text-overflow:ellipsis}.dm-rec-content,.dm-rec-name{overflow:hidden;padding:0 8px}.dm-rec-content code{color:#7a9abf;display:block;font-size:12.5px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dm-rec-content code,.dm-ttl{font-family:JetBrains Mono,monospace}.dm-ttl{color:#3a4a6a;font-size:11.5px;padding:0 8px}.dm-row-actions{align-items:center;display:flex;gap:4px;opacity:0;padding:0 4px;transition:opacity .15s}.dm-row--editing .dm-row-actions,.dm-row:hover .dm-row-actions{opacity:1}.dm-inline-edit{align-items:center;display:flex;gap:8px;grid-column:1/-1;padding:8px 0}.dm-empty-state,.dm-loading,.dm-records-empty{align-items:center;color:#2a3a5a;display:flex;flex-direction:column;gap:12px;justify-content:center;padding:60px 20px}.dm-loading{color:#4a6a90;flex-direction:row;font-size:13px;gap:10px}.dm-records-empty svg{color:#1e2d48}.dm-records-empty p{color:#3a4a6a;font-size:13px;margin:0}.dm-empty-state{flex:1 1}.dm-empty-orb{align-items:center;background:#00d4ff0d;border:1px solid #00d4ff1f;border-radius:20px;color:#00d4ff66;display:flex;height:80px;justify-content:center;margin-bottom:4px;width:80px}.dm-empty-state h3{color:#8896b0;font-size:18px;font-weight:600;margin:0}.dm-empty-state p{color:#3a4a6a;font-size:13px;margin:0;max-width:360px;text-align:center}.dm-ns-section{max-width:680px;padding:24px 28px}.dm-ns-header{align-items:flex-start;display:flex;gap:14px;margin-bottom:20px}.dm-ns-icon{align-items:center;background:#00d4ff14;border:1px solid #00d4ff26;border-radius:9px;color:#00d4ff;display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.dm-ns-header h3{color:#dde4f0;font-size:16px;font-weight:600;margin:0 0 4px}.dm-ns-header p{color:#4a5a7a;font-size:13px;margin:0}.dm-ns-header strong{color:#8896b0;font-family:JetBrains Mono,monospace}.dm-ns-notice{align-items:center;background:#00d4ff0d;border:1px solid #00d4ff1a;border-radius:8px;color:#4a6a90;display:flex;font-size:12.5px;gap:8px;margin-bottom:18px;padding:10px 14px}.dm-ns-notice code{color:#00b8e0;font-family:JetBrains Mono,monospace;font-size:12px}.dm-ns-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.dm-ns-row{align-items:center;background:#0a0f1e;border:1px solid #1a2340;border-radius:8px;display:flex;gap:10px;padding:10px 14px}.dm-ns-idx{color:#3a4a6a;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;min-width:32px}.dm-ns-row svg{color:#4a5a7a;flex-shrink:0}.dm-ns-actions{align-items:center;display:flex;gap:10px}.dm-btn-primary{align-items:center;background:#00d4ff1f;border:1px solid #00d4ff59;border-radius:8px;color:#00d4ff;cursor:pointer;display:inline-flex;font-family:Sora,sans-serif;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .15s;white-space:nowrap}.dm-btn-primary:hover:not(:disabled){background:#00d4ff33;border-color:#00d4ff99;box-shadow:0 0 16px #00d4ff26}.dm-btn-primary:disabled{cursor:not-allowed;opacity:.45}.dm-btn-ghost{align-items:center;background:none;border:1px solid #1e2d48;border-radius:8px;color:#6a7a9a;cursor:pointer;display:inline-flex;font-family:Sora,sans-serif;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .15s;white-space:nowrap}.dm-btn-ghost:hover{background:#0d1526;border-color:#2a3a5a;color:#8896b0}.dm-btn-sm{border-radius:7px;font-size:12px;padding:6px 12px}.dm-btn-xs{border-radius:6px;font-size:11px;padding:4px 10px}.dm-btn-full{justify-content:center;margin-top:16px;padding:11px;width:100%}.dm-btn-icon{padding:6px 9px}.dm-icon-btn{align-items:center;background:none;border:1px solid #0000;border-radius:6px;color:#3a4a6a;cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;transition:all .12s;width:28px}.dm-icon-btn:hover{background:#0d1526;border-color:#1e2d48;color:#6a8ab0}.dm-icon-btn--danger:hover{background:#f871711a;border-color:#f871714d;color:#f87171}.dm-icon-btn--confirm:hover{background:#34d3991a;border-color:#34d3994d;color:#34d399}.dm-icon-btn:disabled{cursor:not-allowed;opacity:.4}.dm-input{background:#080d18;border:1px solid #1e2d48;border-radius:7px;box-sizing:border-box;color:#c0cce0;font-family:JetBrains Mono,monospace;font-size:13px;outline:none;padding:7px 11px;transition:border-color .15s;width:100%}.dm-input:focus{border-color:#00d4ff66}.dm-input::placeholder{color:#2a3a5a}.dm-input-short{max-width:80px}.dm-input-wide{flex:1 1}.dm-select{background:#080d18;border:1px solid #1e2d48;border-radius:7px;color:#c0cce0;cursor:pointer;font-family:JetBrains Mono,monospace;font-size:12.5px;outline:none;padding:7px 10px;transition:border-color .15s}.dm-select:focus{border-color:#00d4ff66}.dm-auth-gate{background:#080d18;font-family:Sora,sans-serif;height:100%;justify-content:center}.dm-auth-box,.dm-auth-gate{align-items:center;display:flex}.dm-auth-box{background:#0a0f1e;border:1px solid #1a2340;border-radius:16px;box-shadow:0 0 60px #0006;flex-direction:column;gap:16px;max-width:380px;padding:40px 36px;text-align:center;width:100%}.dm-auth-icon-wrap{align-items:center;background:#00d4ff1a;border:1px solid #00d4ff33;border-radius:14px;color:#00d4ff;display:flex;height:52px;justify-content:center;width:52px}.dm-auth-box h2{color:#e8f0ff;font-size:20px;font-weight:700;margin:0}.dm-auth-box p{color:#4a5a7a;font-size:13px;line-height:1.5;margin:0}.dm-auth-box strong{color:#8896b0}.dm-auth-email-chip{background:#080d18;border:1px solid #1e2d48;border-radius:8px;color:#6a8ab0;font-family:JetBrains Mono,monospace;font-size:12.5px;padding:8px 16px;width:100%}.dm-auth-error{align-items:center;background:#f8717114;border:1px solid #f8717133;border-radius:7px;color:#f87171;display:flex;font-size:12px;gap:7px;padding:8px 12px;width:100%}.dm-auth-box .dm-btn-primary{justify-content:center;padding:11px;width:100%}.dm-auth-box .dm-btn-ghost{background:none;border:none;color:#3a4a6a;cursor:pointer;font-size:12px;padding:0;text-decoration:underline}.dm-auth-box .dm-btn-ghost:hover{color:#6a8ab0}.dm-otp-input{background:#080d18;border:1px solid #1e2d48;border-radius:10px;color:#e8f0ff;font-family:JetBrains Mono,monospace;font-size:26px;letter-spacing:.4em;outline:none;padding:12px 20px;text-align:center;transition:border-color .15s;width:100%}.dm-otp-input:focus{border-color:#00d4ff66}.dm-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.dm-modal{background:#0a0f1e;border:1px solid #1a2340;border-radius:14px;box-shadow:0 20px 60px #00000080,0 0 0 1px #00d4ff14;max-height:90vh;max-width:560px;overflow-y:auto;width:100%}.dm-modal::-webkit-scrollbar{width:4px}.dm-modal::-webkit-scrollbar-thumb{background:#1e2d48;border-radius:2px}.dm-modal-head{align-items:center;border-bottom:1px solid #131d30;display:flex;justify-content:space-between;padding:18px 20px}.dm-modal-title{color:#dde4f0;font-size:15px;font-weight:600}.dm-modal-title,.dm-search-domain-bar{align-items:center;display:flex;gap:8px}.dm-search-domain-bar{border-bottom:1px solid #131d30;color:#4a6a90;padding:16px 20px}.dm-search-domain-bar input{background:#080d18;border:1px solid #1e2d48;border-radius:8px;color:#c0cce0;flex:1 1;font-family:JetBrains Mono,monospace;font-size:13.5px;outline:none;padding:9px 13px;transition:border-color .15s}.dm-search-domain-bar input:focus{border-color:#00d4ff66}.dm-avail-result{align-items:center;border-bottom:1px solid #131d30;display:flex;font-size:13.5px;gap:10px;padding:13px 20px}.dm-avail-result.avail{background:#34d3990f;color:#34d399}.dm-avail-result.taken{background:#f871710f;color:#f87171}.dm-avail-result.err{background:#fbbf240f;color:#fbbf24}.dm-avail-price{color:#00d4ff;font-family:JetBrains Mono,monospace;font-size:13px}.dm-reg-form{padding:20px}.dm-reg-form h4{color:#6a8ab0;font-size:13px;font-weight:600;letter-spacing:.07em;margin:0 0 14px;text-transform:uppercase}.dm-reg-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.dm-reg-field{display:flex;flex-direction:column;gap:5px}.dm-reg-field label{color:#4a6a90;font-size:11px;font-weight:500;letter-spacing:.07em;text-transform:uppercase}.dm-reg-field--full{grid-column:1/-1}.dm-toast{align-items:center;animation:toastIn .2s ease;border-radius:10px;bottom:28px;box-shadow:0 8px 30px #0006;display:flex;font-family:Sora,sans-serif;font-size:13px;font-weight:500;gap:8px;padding:11px 18px;position:fixed;right:28px;z-index:2000}.dm-toast--success{background:#34d3991f;border:1px solid #34d3994d;color:#34d399}.dm-toast--error{background:#f871711f;border:1px solid #f871714d;color:#f87171}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.spin{animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(1turn)}}.dm-balance-chip{align-items:center;background:#00d4ff0f;border:1px solid #00d4ff26;border-radius:8px;display:flex;justify-content:space-between;margin:12px 12px 0;padding:8px 14px}.dm-balance-label{color:#4a5a7a;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.dm-balance-val{color:#00d4ff;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700}.dm-price-summary{background:#0f172acc;border:1px solid #1e2d45;border-radius:10px;display:flex;flex-direction:column;gap:7px;margin-bottom:18px;padding:14px 16px}.dm-price-summary.dm-price-insufficient{background:#f871710a;border-color:#f871714d}.dm-ps-row{align-items:center;display:flex;font-size:13px;justify-content:space-between}.dm-ps-row,.dm-ps-row span{color:#64748b}.dm-ps-row strong{color:#cbd5e1;font-weight:600}.dm-ps-total{border-top:1px solid #1e2d45;margin-top:2px;padding-top:8px}.dm-ps-total strong{color:#e2e8f0;font-family:JetBrains Mono,monospace;font-size:15px}.dm-ps-ok{color:#34d399!important;font-weight:600}.dm-ps-err{color:#f87171!important;font-weight:600}.dm-ps-alert{align-items:center;background:#f8717114;border-radius:6px;color:#f87171;display:flex;font-size:12px;gap:6px;margin-top:4px;padding:6px 10px}.dm-sidebar-footer{border-top:1px solid #1a2340;display:flex;gap:6px;padding:10px 12px}.dm-sidebar-ext{align-items:center;background:#a78bfa14;border:1px solid #a78bfa33;border-radius:6px;color:#a78bfa;cursor:pointer;display:flex;flex:1 1;font-size:11px;font-weight:600;gap:5px;padding:5px 10px;transition:background .15s;white-space:nowrap}.dm-sidebar-ext:hover{background:#a78bfa26}.dm-ext-intro{border-bottom:1px solid #1a2340;padding:14px 20px}.dm-ext-intro p{color:#64748b;font-size:13px;line-height:1.6;margin:0 0 8px}.dm-ext-intro p:last-child{margin:0}.dm-ns-instructions{background:#0f172acc;border:1px solid #1e2d45;border-radius:10px;margin:16px 20px;padding:14px 16px}.dm-nsi-title{align-items:center;color:#4a5a7a;display:flex;font-size:11px;font-weight:700;gap:7px;letter-spacing:.05em;margin-bottom:12px;text-transform:uppercase}.dm-nsi-ns{background:#0085c91a;border:1px solid #0085c933;border-radius:6px;margin-bottom:6px;padding:8px 12px}.dm-nsi-ns code{color:#00d4ff;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700}.dm-nsi-note{color:#f59e0b;font-size:12px;margin:10px 0}.dm-nsi-steps{display:flex;flex-direction:column;gap:5px;margin:0;padding-left:18px}.dm-nsi-steps li{color:#64748b;font-size:12px;line-height:1.5}.dm-ext-success{align-items:center;display:flex;flex-direction:column;gap:12px;padding:32px 24px;text-align:center}.dm-ext-success h3{color:#e2e8f0;font-size:18px;font-weight:700;margin:0}.dm-ext-success p{color:#64748b;font-size:13px;line-height:1.6;margin:0}.dm-ext-success-ns{background:#0085c912;border:1px solid #0085c933;border-radius:10px;display:flex;flex-direction:column;gap:8px;padding:14px 20px;width:100%}.dm-ext-success-ns p{color:#64748b;font-size:12px;margin:0 0 4px}.dm-ext-success-ns code{background:#00d4ff0f;border:1px solid #00d4ff26;border-radius:6px;color:#00d4ff;font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;padding:6px 12px}.dm-ext-success-note{color:#34d399!important;font-size:12px!important}@media (max-width:768px){.dm-root{flex-direction:column}.dm-sidebar{border-bottom:1px solid #1a2340;border-right:none;height:auto;max-height:220px;width:100%}.dm-domain-list{padding:4px 8px}.dm-domain-header{align-items:flex-start;flex-direction:column;gap:12px;padding:14px 16px}.dm-ns-section,.dm-records-section{padding:14px 16px}.dm-row,.dm-table-head{grid-template-columns:60px 1fr 1fr 50px 80px}.dm-rec-content,.dm-table-head span:nth-child(3),.dm-type-filters{display:none}}.App{min-height:100vh}