@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:wght@300;400;500&display=swap";@import "https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{flex-direction:column;min-height:100vh;display:flex}.login-root{background:#0a1628;min-height:100vh;font-family:DM Sans,sans-serif;display:flex}.login-hero{background:linear-gradient(135deg,#0a1628 0%,#0d2240 50%,#0a1e38 100%);flex:1.1;justify-content:center;align-items:center;min-width:0;display:flex;position:relative;overflow:hidden}.hero-overlay{pointer-events:none;background:radial-gradient(60% 50% at 50% 40%,#00d4aa0a 0%,#0000 70%),radial-gradient(40% 60% at 20% 70%,#00aaff08 0%,#0000 60%);position:absolute;inset:0}.hero-network{opacity:.85;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.network-svg{width:90%;max-width:480px;height:auto}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.08;transform:scale(1.4)}}@keyframes pulse-slow{0%,to{opacity:.15;transform:scale(1)}50%{opacity:.04;transform:scale(1.6)}}.pulse-ring{transform-origin:240px 110px;animation:2.4s ease-in-out infinite pulse}.pulse-ring-slow{transform-origin:240px 110px;animation:3.2s ease-in-out infinite pulse-slow}.hero-content{z-index:2;text-align:center;color:#fff;padding:2rem;position:relative}.hero-logo{justify-content:center;align-items:center;gap:10px;margin-bottom:2rem;display:flex}.hero-logo-text{color:#00d4aa;letter-spacing:2px;font-family:Syne,sans-serif;font-size:2rem;font-weight:800}.hero-tagline{color:#e8f4ff;margin:0;font-family:Syne,sans-serif;font-size:1.55rem;font-weight:700;line-height:1.4}.hero-tagline .accent{color:#00d4aa}.float-label{color:#00d4aa;letter-spacing:1px;pointer-events:none;background:#00d4aa15;border:1px solid #00d4aa30;border-radius:4px;padding:3px 8px;font-family:Syne,sans-serif;font-size:.7rem;font-weight:700;position:absolute}.fl-1{top:22%;left:18%}.fl-2{top:55%;left:12%}.fl-3{top:38%;right:14%}.login-panel{background:#f0f4f8;flex:.9;justify-content:center;align-items:center;min-width:340px;padding:2rem;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:2.4rem 2.2rem 2rem;animation:.5s cubic-bezier(.22,1,.36,1) both slideUp;box-shadow:0 8px 40px #0a162818}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.card-logo{align-items:center;gap:8px;margin-bottom:1.4rem;display:flex}.card-logo-text{color:#0d2240;letter-spacing:1.5px;font-family:Syne,sans-serif;font-size:1.3rem;font-weight:800}.card-title{color:#0d2240;align-items:center;gap:6px;margin:0 0 1.6rem;font-family:Syne,sans-serif;font-size:1.15rem;font-weight:700;display:flex}.card-title .divider{color:#00d4aa;font-weight:400}.card-title .subtitle-text{color:#4a6080;font-size:1rem;font-weight:500}.field-wrap{background:#f5f8fb;border:1.5px solid #dde4ec;border-radius:9px;align-items:center;transition:border-color .2s,box-shadow .2s;display:flex;position:relative}.field-wrap:focus-within{background:#fff;border-color:#00d4aa;box-shadow:0 0 0 3px #00d4aa1a}.field-wrap.compact{border-radius:9px}.field-wrap.field-err{border-color:#e74c3c!important;box-shadow:0 0 0 3px #e74c3c18!important}.field-icon{color:#8a9bb0;flex-shrink:0;align-items:center;padding:0 12px 0 14px;display:flex}.field-input{color:#1a2e45;background:0 0;border:none;outline:none;flex:1;min-width:0;padding:13px 12px 13px 0;font-family:DM Sans,sans-serif;font-size:.92rem}.field-input::placeholder{color:#a8b8ca}.eye-btn{cursor:pointer;color:#8a9bb0;background:0 0;border:none;align-items:center;padding:0 14px;transition:color .15s;display:flex}.eye-btn:hover{color:#00d4aa}.error-banner{color:#c0392b;background:#fff0f0;border:1px solid #ffb3b3;border-radius:8px;margin-bottom:1rem;padding:10px 14px;font-size:.85rem}.login-form{flex-direction:column;gap:14px;display:flex}.forgot-row{text-align:right;margin-top:-4px}.forgot-link{color:#4a6080;font-size:.82rem;text-decoration:none;transition:color .15s}.forgot-link:hover{color:#00d4aa}.login-btn{color:#fff;letter-spacing:.5px;cursor:pointer;background:linear-gradient(135deg,#00c49a 0%,#00d4aa 60%,#00e0b5 100%);border:none;border-radius:9px;justify-content:center;align-items:center;width:100%;min-height:48px;padding:14px;font-family:Syne,sans-serif;font-size:1rem;font-weight:700;transition:transform .15s,box-shadow .15s,filter .15s;display:flex;box-shadow:0 4px 18px #00d4aa35}.login-btn:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 8px 24px #00d4aa50}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.65;cursor:not-allowed}.spinner{border:2.5px solid #fff5;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.register-row{text-align:center;color:#6a7f96;margin:1.2rem 0 0;font-size:.85rem}.register-link-btn{color:#00b899;cursor:pointer;background:0 0;border:none;margin-left:4px;padding:0;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;transition:color .15s}.register-link-btn:hover{color:#009e82;text-decoration:underline}.reg-overlay{z-index:200;pointer-events:none;background:#0a162800;justify-content:flex-end;align-items:stretch;transition:background .35s;display:flex;position:fixed;inset:0}.reg-overlay--visible{pointer-events:all;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0a16288c}.reg-drawer{background:#fff;flex-direction:column;width:min(680px,96vw);height:100vh;transition:transform .38s cubic-bezier(.22,1,.36,1);display:flex;overflow:hidden;transform:translate(100%);box-shadow:-8px 0 40px #0a162830}.reg-drawer--open{transform:translate(0)}.reg-header{background:#0d2240;flex-shrink:0;justify-content:space-between;align-items:center;padding:1.3rem 1.8rem;display:flex}.reg-header-left{align-items:center;gap:12px;display:flex}.reg-title{color:#fff;margin:0;font-family:Syne,sans-serif;font-size:1.1rem;font-weight:800}.reg-subtitle{color:#7aa5cc;margin:2px 0 0;font-size:.78rem}.reg-close{color:#fff;cursor:pointer;background:#ffffff18;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;transition:background .15s;display:flex}.reg-close:hover{background:#ff4d4d}.reg-form{scrollbar-width:thin;scrollbar-color:#dde4ec transparent;flex-direction:column;flex:1;gap:0;padding:1.6rem 1.8rem 2rem;display:flex;overflow-y:auto}.reg-form::-webkit-scrollbar{width:5px}.reg-form::-webkit-scrollbar-thumb{background:#dde4ec;border-radius:3px}.section-label{color:#0d2240;text-transform:uppercase;letter-spacing:.8px;border-bottom:2px solid #e8eef5;align-items:center;gap:8px;margin:1.4rem 0 .9rem;padding-bottom:6px;font-family:Syne,sans-serif;font-size:.82rem;font-weight:700;display:flex}.section-label:first-child{margin-top:0}.section-icon{font-size:1rem}.reg-row{gap:14px;margin-bottom:14px;display:grid}.reg-row.two-col{grid-template-columns:1fr 1fr}.reg-row.three-col{grid-template-columns:1fr 1fr 1fr}.reg-field{flex-direction:column;gap:5px;display:flex}.reg-label{color:#4a6080;letter-spacing:.2px;font-size:.78rem;font-weight:500}.finput{color:#1a2e45;background:#f5f8fb;border:1.5px solid #dde4ec;border-radius:9px;outline:none;width:100%;padding:11px 13px;font-family:DM Sans,sans-serif;font-size:.9rem;transition:border-color .2s,box-shadow .2s,background .2s}.finput:focus{background:#fff;border-color:#00d4aa;box-shadow:0 0 0 3px #00d4aa1a}.finput--err{border-color:#e74c3c!important;box-shadow:0 0 0 3px #e74c3c18!important}.finput--disabled{color:#999;cursor:not-allowed;background:#f0f0f0}.finput::placeholder{color:#a8b8ca}.textarea-field{resize:vertical;min-height:64px;line-height:1.5}.field-error{color:#e74c3c;margin:0;font-size:.75rem;line-height:1.4}.phone-wrap{overflow:hidden}.country-select{color:#1a2e45;cursor:pointer;background:0 0;border:none;outline:none;flex-shrink:0;max-width:130px;padding:11px 6px 11px 12px;font-family:DM Sans,sans-serif;font-size:.85rem}.phone-divider{background:#dde4ec;align-self:stretch;width:1px;margin:8px 0}.phone-wrap .field-input{padding-left:10px}.strength-wrap{align-items:center;gap:8px;margin-top:6px;display:flex}.strength-bars{flex:1;gap:3px;display:flex}.strength-bar{border-radius:2px;flex:1;height:4px;transition:background .3s}.strength-label{white-space:nowrap;min-width:62px;font-size:.72rem;font-weight:600}.match-ok{color:#27ae60;margin:4px 0 0;font-size:.75rem;font-weight:500}.pwd-hint{color:#8a9bb0;margin:0 0 6px;font-size:.75rem;line-height:1.5}.same-addr-label{color:#4a6080;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;margin:4px 0 10px;font-size:.82rem;display:flex}.same-addr-label input[type=checkbox]{accent-color:#00d4aa;cursor:pointer;width:15px;height:15px}.reg-actions{border-top:1.5px solid #e8eef5;justify-content:flex-end;gap:12px;margin-top:1.8rem;padding-top:1.2rem;display:flex}.cancel-btn{color:#4a6080;cursor:pointer;background:#fff;border:1.5px solid #dde4ec;border-radius:9px;padding:12px 28px;font-family:DM Sans,sans-serif;font-size:.92rem;font-weight:500;transition:border-color .15s,color .15s}.cancel-btn:hover{color:#00b899;border-color:#00d4aa}.reg-success{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:3rem 2rem;display:flex}.success-icon{margin-bottom:1.2rem;font-size:4rem}.reg-success h3{color:#0d2240;margin:0 0 .5rem;font-family:Syne,sans-serif;font-size:1.5rem}.reg-success p{color:#6a7f96;margin:0}@media (width<=700px){.login-root{flex-direction:column}.login-hero{flex:none;min-height:200px}.hero-tagline{font-size:1.2rem}.login-panel{min-width:unset}.float-label{display:none}}@media (width<=580px){.reg-row.two-col,.reg-row.three-col{grid-template-columns:1fr}.reg-form{padding:1.2rem 1.1rem 1.5rem}.reg-actions{flex-direction:column-reverse}.cancel-btn{text-align:center;width:100%}}.reg-page-panel{flex:1.4;align-items:flex-start;padding:2.4rem 2rem;overflow-y:auto}.reg-page-card{background:#fff;border-radius:16px;width:100%;max-width:720px;margin:0 auto;animation:.4s cubic-bezier(.22,1,.36,1) both slideUp;overflow:hidden;box-shadow:0 8px 40px #0a162818}.reg-page-header{background:#0d2240;border-radius:16px 16px 0 0;justify-content:space-between;align-items:center;padding:1.2rem 1.8rem;display:flex}.reg-page-header .reg-subtitle{color:#7aa5cc}.reg-page-header .reg-title{color:#fff!important}.reg-page-header .cancel-btn{color:#fff;background:#ffffff18;border-color:#0000;padding:9px 18px;font-size:.85rem}.reg-page-header .cancel-btn:hover{color:#00d4aa;background:#ffffff28;border-color:#0000}.reg-page-form{padding:1.6rem 1.8rem 2rem;flex:unset!important;overflow:visible!important}.reg-page-panel .reg-success{background:#fff;border-radius:16px;max-width:480px;margin:auto;padding:4rem 2rem;animation:.4s cubic-bezier(.22,1,.36,1) both slideUp;box-shadow:0 8px 40px #0a162818}@media (width<=700px){.reg-page-panel{padding:1.2rem 1rem}.reg-page-form{padding:1.2rem 1rem 1.5rem}}.db-root{color:#1a2e45;background:#f0f4f8;min-height:100vh;font-family:DM Sans,sans-serif;font-size:.875rem;display:flex}.db-sidebar{background:#0d2240;flex-direction:column;flex-shrink:0;width:200px;height:100vh;min-height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid #1a3455;flex-shrink:0;align-items:center;gap:10px;padding:1.2rem 1rem 1rem;display:flex}.sidebar-logo-text{color:#fff;letter-spacing:.5px;white-space:nowrap;font-family:Syne,sans-serif;font-size:.95rem;font-weight:800}.sidebar-nav{flex-direction:column;flex:1;padding:.5rem 0;display:flex}.nav-item{color:#7aa5cc;cursor:pointer;text-align:left;background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:10px;width:100%;padding:10px 1rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:flex}.nav-item:hover{color:#c8e0f4;background:#112840}.nav-item--active{color:#fff;background:#1a3a5e;border-left-color:#00d4aa}.nav-icon{text-align:center;flex-shrink:0;width:18px;font-size:.95rem}.nav-label{white-space:nowrap}.db-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.db-topbar{background:#fff;border-bottom:1px solid #e0e8f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:.9rem 1.6rem;display:flex;box-shadow:0 1px 4px #0a162808}.topbar-title{color:#0d2240;margin:0;font-family:Syne,sans-serif;font-size:1.35rem;font-weight:800}.topbar-date{color:#7a90a8;margin:2px 0 0;font-size:.78rem}.topbar-actions{align-items:center;gap:8px;display:flex}.topbar-icon-btn{color:#5a7a9a;cursor:pointer;background:#f5f8fb;border:1px solid #e0e8f0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex;position:relative}.topbar-icon-btn:hover{color:#0d2240;background:#e8f0f8}.notif-dot{background:#e74c3c;border:1.5px solid #fff;border-radius:50%;width:7px;height:7px;position:absolute;top:7px;right:7px}.topbar-avatar{color:#00d4aa;cursor:pointer;-webkit-user-select:none;user-select:none;background:#0d2240;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-family:Syne,sans-serif;font-size:.9rem;font-weight:700;transition:opacity .15s;display:flex}.topbar-avatar:hover{opacity:.85}.db-content{flex:1;padding:1.4rem 1.6rem;overflow-y:auto}.stat-cards{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:1.4rem;display:grid}.stat-card{background:#fff;border:1px solid #e8eef5;border-radius:12px;justify-content:space-between;align-items:center;padding:1rem 1.1rem;transition:box-shadow .2s;display:flex;box-shadow:0 2px 10px #0a162810}.stat-card:hover{box-shadow:0 4px 18px #0a162818}.stat-card--storage{flex-direction:column;align-items:flex-start;gap:8px}.stat-card-left{flex-direction:column;gap:4px;display:flex}.stat-label{color:#7a90a8;text-transform:uppercase;letter-spacing:.4px;margin:0;font-size:.75rem;font-weight:600}.stat-value{color:#0d2240;margin:0;font-family:Syne,sans-serif;font-size:1.55rem;font-weight:800;line-height:1.1}.stat-slash{color:#9ab0c8;font-size:1rem;font-weight:600}.stat-sub{color:#9ab0c8;margin:0;font-size:.75rem}.stat-sub-small{color:#9ab0c8;font-size:.7rem}.stat-badge{border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.stat-badge--green{color:#27ae60;background:#eafaf1}.stat-badge--red{color:#e74c3c;background:#fdf0f0}.storage-row{align-items:center;gap:10px;display:flex}.storage-bar-wrap{align-items:center;gap:8px;width:100%;display:flex}.storage-bar{background:#e8eef5;border-radius:4px;flex:1;height:7px;overflow:hidden}.storage-fill{background:linear-gradient(90deg,#3498db,#2980b9);border-radius:4px;height:100%}.storage-pct{color:#3498db;white-space:nowrap;font-size:.72rem;font-weight:600}.body-grid{grid-template-columns:1fr 260px;align-items:start;gap:14px;display:grid}.body-left,.body-right{flex-direction:column;gap:14px;display:flex}.card{background:#fff;border:1px solid #e8eef5;border-radius:12px;padding:1.1rem 1.2rem;box-shadow:0 2px 10px #0a162810}.section-title{color:#0d2240;margin:0 0 2px;font-family:Syne,sans-serif;font-size:.95rem;font-weight:700}.section-sub{color:#9ab0c8;margin:0 0 .9rem;font-size:.75rem}.table-wrap{overflow-x:auto}.db-table{border-collapse:collapse;width:100%;font-size:.8rem}.db-table th{text-align:left;color:#7a90a8;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;border-bottom:1.5px solid #e8eef5;padding:7px 10px;font-size:.72rem;font-weight:600}.db-table td{vertical-align:middle;border-bottom:1px solid #f0f4f8;padding:9px 10px}.db-table tr:last-child td{border-bottom:none}.db-table tr:hover td{background:#f8fafc}.node-id{color:#0d2240;font-weight:600}.muted{color:#9ab0c8}.status-pill{white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.status-pill--on{color:#27ae60;background:#eafaf1}.status-pill--off{color:#e74c3c;background:#fdf0f0}.mem-cell{align-items:center;gap:6px;display:flex}.mini-bar{background:#e8eef5;border-radius:3px;width:50px;height:6px;overflow:hidden}.mini-fill{border-radius:3px;height:100%;transition:width .3s}.row-menu{color:#9ab0c8;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:1rem}.row-menu:hover{color:#0d2240;background:#f0f4f8}.show-more-btn{color:#00b899;cursor:pointer;background:0 0;border:none;margin-top:.7rem;padding:0;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:600;transition:color .15s}.show-more-btn:hover{color:#009e82;text-decoration:underline}.activity-list{flex-direction:column;gap:12px;display:flex}.activity-item{border-bottom:1px solid #f0f4f8;align-items:flex-start;gap:10px;padding-bottom:12px;display:flex}.activity-item:last-child{border-bottom:none;padding-bottom:0}.activity-avatar{color:#00d4aa;background:#0d2240;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-family:Syne,sans-serif;font-size:.82rem;font-weight:700;display:flex}.activity-body{flex:1;min-width:0}.activity-name{color:#0d2240;margin:0 0 2px;font-size:.8rem;font-weight:600}.activity-role{color:#7a90a8;font-weight:400}.activity-desc{color:#9ab0c8;margin:0;font-size:.75rem}.activity-ago{color:#b0c4d8;white-space:nowrap;flex-shrink:0;padding-top:2px;font-size:.72rem}.chart-area{flex-direction:column;gap:6px;display:flex}.sparkline-svg{border-radius:6px;width:100%;height:80px;display:block;overflow:visible}.chart-labels{color:#b0c4d8;justify-content:space-between;padding:0 2px;font-size:.68rem;display:flex}.quick-links{flex-direction:column;gap:8px;margin-top:4px;display:flex}.quick-link{color:#2c5282;cursor:pointer;text-align:left;background:0 0;border:1px solid #e8eef5;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;transition:background .15s,border-color .15s,color .15s;display:flex}.quick-link:hover{color:#00b899;background:#eafaf1;border-color:#00d4aa}.gauges-row{justify-content:space-around;align-items:center;padding:.5rem 0;display:flex}.gauge-item{flex-direction:column;align-items:center;gap:6px;display:flex}.gauge-label{color:#7a90a8;font-size:.75rem;font-weight:600}.alerts-table th,.alerts-table td{padding:6px 8px;font-size:.75rem}.priority-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.priority-dot--red{background:#e74c3c}.priority-dot--yellow{background:#f39c12}.priority-dot--green{background:#27ae60}.db-content::-webkit-scrollbar{width:5px}.db-content::-webkit-scrollbar-thumb{background:#d0dbe8;border-radius:3px}.db-sidebar::-webkit-scrollbar{width:4px}.db-sidebar::-webkit-scrollbar-thumb{background:#1a3455;border-radius:3px}@media (width<=1100px){.stat-cards{grid-template-columns:repeat(2,1fr)}.body-grid{grid-template-columns:1fr}.body-right{grid-template-columns:1fr 1fr;display:grid}}@media (width<=700px){.db-sidebar{width:52px}.nav-label,.sidebar-logo-text{display:none}.sidebar-logo{justify-content:center;padding:1rem 0}.stat-cards{grid-template-columns:1fr 1fr}.body-right{grid-template-columns:1fr}.db-content{padding:1rem}}@media (width<=480px){.stat-cards{grid-template-columns:1fr}}
