@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-base: #07090f;--bg-surface: #0c1018;--bg-card: #101724;--bg-hover: #162035;--bg-border: #1d2d47;--primary: #00e5b0;--primary-hover: #00cfA0;--primary-muted: rgba(0,229,176,.12);--primary-glow: rgba(0,229,176,.25);--accent: #b44bff;--accent-hover: #9f3ee8;--accent-muted: rgba(180,75,255,.12);--accent-glow: rgba(180,75,255,.25);--green: #00e5b0;--green-bg: rgba(0,229,176,.1);--green-border: rgba(0,229,176,.35);--yellow: #ffe04b;--yellow-bg: rgba(255,224,75,.1);--yellow-border:rgba(255,224,75,.35);--red: #ff5e7d;--red-bg: rgba(255,94,125,.12);--red-border: rgba(255,94,125,.35);--blue: #38cfff;--blue-bg: rgba(56,207,255,.1);--blue-border: rgba(56,207,255,.3);--purple: #b44bff;--purple-bg: rgba(180,75,255,.1);--purple-border:rgba(180,75,255,.35);--orange: #ff8c42;--orange-bg: rgba(255,140,66,.1);--orange-border:rgba(255,140,66,.35);--text-primary: #eef2ff;--text-secondary: #8fa1c0;--text-muted: #4e6080;--text-disabled: #2a3a52;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--radius-sm: 7px;--radius: 12px;--radius-lg: 18px;--transition: .16s ease;--sidebar-w: 240px;--sidebar-w-collapsed: 64px;--topbar-h: 56px}[data-theme=light]{--bg-base: #f0f4ff;--bg-surface: #ffffff;--bg-card: #f5f7ff;--bg-hover: #e8eeff;--bg-border: #c8d4f0;--text-primary: #0f1929;--text-secondary: #334a6e;--text-muted: #64748b;--text-disabled: #94a3b8}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font);background:var(--bg-base);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit;background:#121b28;border:1px solid #1d2d47;color:var(--text-primary);border-radius:var(--radius-sm);padding:7px 11px;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}select option{background:#121b28;color:var(--text-primary)}select option:checked{background:#00e5b0;color:#07090f}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}input:hover:not(:focus),select:hover:not(:focus),textarea:hover:not(:focus){border-color:#2a3f5e}input:disabled,select:disabled,textarea:disabled{background:var(--bg-card);color:var(--text-muted);cursor:not-allowed;opacity:.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-surface)}::-webkit-scrollbar-thumb{background:var(--bg-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);height:100vh;position:fixed;top:0;left:0;background:linear-gradient(180deg,#0c1018,#0a0f1a);border-right:1px solid rgba(0,229,176,.08);display:flex;flex-direction:column;z-index:100;transition:width var(--transition),min-width var(--transition);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-w-collapsed);min-width:var(--sidebar-w-collapsed)}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:16px 14px;border-bottom:1px solid rgba(0,229,176,.1);white-space:nowrap;overflow:hidden}.sidebar-logo .logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;font-weight:800;color:#07090f;box-shadow:0 0 14px var(--primary-glow)}.sidebar-logo .logo-text h2{font-size:12px;font-weight:700;color:var(--text-primary);line-height:1.2}.sidebar-logo .logo-text span{font-size:10px;color:var(--text-muted)}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 0}.sidebar-section{margin-bottom:4px}.sidebar-section-label{font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--text-disabled);text-transform:uppercase;padding:10px 16px 4px;white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-section-label{opacity:0}.sidebar-item{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:var(--radius-sm);margin:2px 6px;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--transition),color var(--transition),box-shadow var(--transition);white-space:nowrap;text-decoration:none;position:relative;border-left:2px solid transparent}.sidebar-item:hover{background:#00e5b012;color:var(--primary);border-left-color:#00e5b04d}.sidebar-item.active{background:#00e5b01a;color:var(--primary);border-left-color:var(--primary);box-shadow:inset 0 0 20px #00e5b00d;font-weight:600}.sidebar-item .icon{flex-shrink:0;width:18px;height:18px}.sidebar-item .badge{margin-left:auto;background:#ff5e7d33;color:var(--red);border:1px solid rgba(255,94,125,.3);font-size:10px;font-weight:700;padding:1px 5px;border-radius:10px;min-width:18px;text-align:center}.sidebar-collapse-btn{padding:12px 16px;border-top:1px solid rgba(0,229,176,.08);display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:13px;cursor:pointer;transition:color var(--transition)}.sidebar-collapse-btn:hover{color:var(--primary)}.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition)}.main-content.sidebar-collapsed{margin-left:var(--sidebar-w-collapsed)}.topbar{height:var(--topbar-h);background:#07090fe6;backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,229,176,.08);display:flex;align-items:center;padding:0 24px;gap:12px;position:sticky;top:0;z-index:90}.topbar-title{flex:1}.topbar-title h1{font-size:16px;font-weight:600;color:var(--text-primary)}.topbar-title p{font-size:11px;color:var(--text-muted);margin-top:1px}.topbar-actions{display:flex;align-items:center;gap:8px}.topbar-search{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--bg-border);border-radius:var(--radius-sm);padding:0 12px;height:34px;width:300px;color:var(--text-muted);transition:border-color var(--transition),box-shadow var(--transition)}.topbar-search:focus-within{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-muted)}.topbar-search input{border:none!important;background:none!important;flex:1;color:var(--text-primary);font-size:13px;padding:0!important;outline:none}.topbar-icon-btn{width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--bg-card);color:var(--text-secondary);transition:background var(--transition),color var(--transition);position:relative}.topbar-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.topbar-icon-btn .alert-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;background:var(--red);border-radius:50%;border:1.5px solid var(--bg-surface)}.topbar-user{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition)}.topbar-user:hover{background:var(--bg-hover)}.topbar-user .avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}.topbar-user .user-info{line-height:1}.topbar-user .user-name{font-size:12px;font-weight:600}.topbar-user .user-role{font-size:10px;color:var(--text-muted)}.page-content{padding:24px;flex:1}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h2{font-size:20px;font-weight:700}.page-header p{font-size:12px;color:var(--text-muted);margin-top:2px}.card{background:var(--bg-card);border:1px solid var(--bg-border);border-radius:var(--radius);padding:20px;transition:border-color var(--transition)}.card:hover{border-color:#00e5b026}.card-sm{padding:14px 16px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:14px;font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:11px;color:var(--text-muted);margin-top:2px}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:24px}.metric-card{background:var(--bg-card);border:1px solid var(--bg-border);border-radius:var(--radius);padding:18px 20px;display:flex;align-items:flex-start;justify-content:space-between;transition:border-color var(--transition),transform var(--transition)}.metric-card:hover{border-color:var(--primary-muted);transform:translateY(-1px)}.metric-card .mc-left .mc-label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.metric-card .mc-left .mc-value{font-size:28px;font-weight:800;color:var(--text-primary);line-height:1.1;margin-top:4px}.metric-card .mc-left .mc-sub{font-size:11px;color:var(--text-muted);margin-top:3px}.metric-card .mc-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px}.charts-grid-3{display:grid;grid-template-columns:2fr 1fr;gap:14px;margin-bottom:24px}.chart-title{font-size:13px;font-weight:600;margin-bottom:4px}.chart-sub{font-size:11px;color:var(--text-muted);margin-bottom:14px}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse}thead th{text-align:left;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:10px 14px;border-bottom:1px solid var(--bg-border);white-space:nowrap}tbody tr{border-bottom:1px solid rgba(29,45,71,.6);transition:background var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#00e5b00a}td{padding:11px 14px;font-size:13px;color:var(--text-primary);vertical-align:middle}td.muted{color:var(--text-secondary)}td.mono{font-family:monospace;font-size:12px;color:var(--text-secondary)}td a,.table-link{color:var(--primary);font-weight:600;transition:color var(--transition),text-shadow var(--transition)}td a:hover,.table-link:hover{color:#fff;text-shadow:0 0 10px var(--primary)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap;letter-spacing:.03em;border:1px solid transparent}.badge-green{background:var(--green-bg);color:var(--green);border-color:var(--green-border);box-shadow:0 0 8px #00e5b01f}.badge-yellow{background:var(--yellow-bg);color:var(--yellow);border-color:var(--yellow-border);box-shadow:0 0 8px #ffe04b1a}.badge-red{background:var(--red-bg);color:var(--red);border-color:var(--red-border);box-shadow:0 0 8px #ff5e7d1a}.badge-blue{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}.badge-purple{background:var(--purple-bg);color:var(--purple);border-color:var(--purple-border);box-shadow:0 0 8px #b44bff1a}.badge-orange{background:var(--orange-bg);color:var(--orange);border-color:var(--orange-border)}.badge-gray{background:#64748b1a;color:var(--text-secondary);border-color:#64748b33}.badge-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block;animation:pulse-dot 2s infinite;box-shadow:0 0 0 0 currentColor}@keyframes pulse-dot{0%{box-shadow:0 0 rgba(currentColor,.5)}70%{box-shadow:0 0 0 4px #0000}to{box-shadow:0 0 #0000}}select.select-green{border-color:var(--green-border);color:var(--green);background:var(--green-bg)}select.select-yellow{border-color:var(--yellow-border);color:var(--yellow);background:var(--yellow-bg)}select.select-red{border-color:var(--red-border);color:var(--red);background:var(--red-bg)}.capacity-wrap{display:flex;flex-direction:column;gap:3px;min-width:120px}.capacity-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}.capacity-bar{height:6px;background:var(--bg-hover);border-radius:3px;overflow:hidden}.capacity-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.capacity-bar-fill.green{background:var(--green)}.capacity-bar-fill.yellow{background:var(--yellow)}.capacity-bar-fill.red{background:var(--red)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:all var(--transition);cursor:pointer}.btn-primary{background:var(--primary);color:#07090f;border:1px solid var(--primary);box-shadow:0 0 16px var(--primary-glow);font-weight:600}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 0 28px var(--primary-glow),0 4px 16px #00e5b040;transform:translateY(-1px)}.btn-secondary{background:#ffffff0a;color:var(--text-primary);border:1px solid var(--bg-border)}.btn-secondary:hover{background:#ffffff12;border-color:#00e5b04d;color:var(--primary)}.btn-sm{padding:5px 10px;font-size:12px}.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}.btn-danger:hover{background:#ff5e7d33;box-shadow:0 0 12px #ff5e7d26}.btn-success{background:var(--primary);color:#07090f;border:1px solid var(--primary);box-shadow:0 0 14px var(--primary-glow);font-weight:600}.btn-success:hover{background:var(--primary-hover);box-shadow:0 0 24px var(--primary-glow)}.btn-danger-solid{background:var(--red);color:#fff;border:1px solid var(--red)}.btn-danger-solid:hover{box-shadow:0 0 16px #ff5e7d59}.btn-xs{padding:3px 8px;font-size:11px;border-radius:5px}.toolbar{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.toolbar-search{display:flex;align-items:center;gap:6px;background:#121b28;border:1px solid #1d2d47;border-radius:var(--radius-sm);padding:6px 10px;flex:1;max-width:300px;color:var(--text-muted);transition:border-color var(--transition),box-shadow var(--transition)}.toolbar-search:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.toolbar-search input{border:none;background:none;flex:1;color:var(--text-primary);padding:0}.toolbar-search input::placeholder{color:var(--text-muted)}.toolbar-filters{display:flex;gap:6px;align-items:center}.toolbar-filters select{padding:6px 8px;font-size:12px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.dc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.dc-card{background:var(--bg-card);border:1px solid var(--bg-border);border-radius:var(--radius);padding:18px;cursor:pointer;transition:all var(--transition);position:relative;overflow:hidden}.dc-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,229,176,.04),transparent);opacity:0;transition:opacity var(--transition)}.dc-card:hover:before{opacity:1}.dc-card:hover{border-color:#00e5b059;transform:translateY(-2px);box-shadow:0 8px 30px #00e5b01a}.dc-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.dc-card-icon{width:42px;height:42px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--primary-muted)}.dc-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}.dc-stat{text-align:center;background:var(--bg-surface);padding:8px;border-radius:var(--radius-sm)}.dc-stat .val{font-size:18px;font-weight:700;color:var(--text-primary)}.dc-stat .lbl{font-size:10px;color:var(--text-muted);margin-top:1px}.rack-visual{display:flex;flex-direction:column;width:220px;border:2px solid var(--bg-border);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-surface)}.rack-unit{display:flex;align-items:center;min-height:20px;border-bottom:1px solid var(--bg-border);padding:0 6px;font-size:10px;gap:4px}.rack-unit .ru-num{width:20px;color:var(--text-disabled);text-align:right;flex-shrink:0}.rack-unit .ru-device{flex:1;padding:2px 4px;border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rack-unit.server .ru-device{background:var(--blue-bg);color:var(--blue)}.rack-unit.switch .ru-device{background:var(--green-bg);color:var(--green)}.rack-unit.firewall .ru-device{background:var(--red-bg);color:var(--red)}.rack-unit.storage .ru-device{background:var(--purple-bg);color:var(--purple)}.rack-unit.empty .ru-device{color:var(--text-disabled)}.alert-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--bg-border)}.alert-item:last-child{border-bottom:none}.alert-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.alert-icon.green{background:var(--green-bg);color:var(--green)}.alert-icon.yellow{background:var(--yellow-bg);color:var(--yellow)}.alert-icon.red{background:var(--red-bg);color:var(--red)}.alert-body{flex:1}.alert-title{font-size:13px;font-weight:500}.alert-desc{font-size:11px;color:var(--text-muted);margin-top:2px}.alert-time{font-size:11px;color:var(--text-disabled);white-space:nowrap}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--bg-border);margin-bottom:20px}.tab-btn{padding:9px 16px;font-size:13px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition);margin-bottom:-1px;background:none}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.progress-ring-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.report-card{background:var(--bg-card);border:1px solid var(--bg-border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:12px;transition:all var(--transition)}.report-card:hover{border-color:var(--primary-muted)}.report-icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.report-title{font-size:14px;font-weight:600}.report-desc{font-size:12px;color:var(--text-muted);line-height:1.5}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.form-group{display:flex;flex-direction:column;gap:4px}.form-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group select{width:100%}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:14px}.detail-section{margin-bottom:20px}.detail-section h3{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em}.detail-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--bg-border);font-size:13px}.detail-row:last-child{border-bottom:none}.detail-row .dk{color:var(--text-muted)}.detail-row .dv{font-weight:500}.empty-state{text-align:center;padding:48px;color:var(--text-muted)}.empty-state svg{margin-bottom:12px;opacity:.4}.empty-state p{font-size:13px}.toast{position:fixed;bottom:24px;right:24px;background:var(--bg-card);border:1px solid var(--green);color:var(--green);border-radius:var(--radius-sm);padding:12px 18px;font-size:13px;font-weight:500;z-index:1000;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:1100px){.charts-grid,.charts-grid-3{grid-template-columns:1fr}.grid-4{grid-template-columns:1fr 1fr}.detail-grid{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{width:var(--sidebar-w-collapsed)}.main-content{margin-left:var(--sidebar-w-collapsed)}.grid-2,.grid-3{grid-template-columns:1fr}}.util-cell{display:flex;align-items:center;gap:8px}.util-cell span{font-size:11px;color:var(--text-muted);min-width:32px}.ip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(28px,1fr));gap:3px}.ip-dot{width:28px;height:18px;border-radius:3px;cursor:default;transition:transform .1s}.ip-dot:hover{transform:scale(1.2)}.ip-dot.used{background:var(--primary-muted)}.ip-dot.free{background:var(--bg-hover)}.ip-dot.reserved{background:var(--yellow-bg)}.ip-dot.dhcp{background:var(--green-bg)}.rack-detail-page{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top right,var(--primary-muted),transparent),radial-gradient(circle at bottom left,var(--accent-muted),transparent),var(--bg-base);padding:20px}.login-card{width:100%;max-width:400px;background:var(--bg-card);border:1px solid var(--bg-border);border-radius:var(--radius-lg);padding:40px;box-shadow:0 20px 50px #00000080;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:48px;height:48px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#fff;margin:0 auto 16px}.login-header h1{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.login-header p{font-size:13px;color:var(--text-muted)}.login-form{display:flex;flex-direction:column;gap:20px}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:12px;color:var(--text-muted)}.input-wrapper input{padding-left:40px;height:44px;background:var(--bg-surface)}.login-submit-btn{height:44px;background:var(--primary);color:#fff;border-radius:var(--radius-sm);font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--transition);margin-top:8px}.login-submit-btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}.error-banner{background:var(--red-bg);color:var(--red);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;display:flex;align-items:center;gap:10px}.login-footer{text-align:center;margin-top:24px;font-size:11px;color:var(--text-disabled)}.flex{display:flex}.items-center{align-items:center}.justify-content{justify-content:center}.h-screen{height:100vh}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-overlay{position:fixed;inset:0;background:#04060cd9;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-card{background:#101724;border:1px solid rgba(0,229,176,.15);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 60px #000000b3,0 0 50px #00e5b00f;animation:modalIn .25s ease-out}.modal-content{background:#101724;border:1px solid rgba(0,229,176,.15);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 60px #000000b3,0 0 50px #00e5b00f;overflow:hidden}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:16px 20px;border-bottom:1px solid rgba(0,229,176,.1);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(90deg,rgba(0,229,176,.04),transparent)}.modal-header h3{font-size:16px;font-weight:700}.modal-close{color:var(--text-muted);transition:color var(--transition)}.modal-close:hover{color:var(--red)}.modal-body{padding:20px;overflow-y:auto}.modal-footer{padding:16px 20px;border-top:1px solid rgba(0,229,176,.08);display:flex;justify-content:flex-end;gap:12px}.search-autocomplete-container{position:relative;z-index:1000}.search-suggestions-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-card);border:1px solid var(--bg-border);border-radius:var(--radius);box-shadow:0 10px 25px -5px #00000080;overflow:hidden;animation:autocompleteSlideIn .2s ease-out;width:450px}@keyframes autocompleteSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.suggestion-item{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--bg-border)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:var(--bg-hover)}.suggestion-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-surface);display:flex;align-items:center;justify-content:center}.suggestion-content{flex:1}.suggestion-header{display:flex;align-items:center;gap:8px}.suggestion-name{font-size:13px;font-weight:600;color:var(--text-primary)}.suggestion-meta{font-size:11px;color:var(--text-muted);margin-top:2px}.suggestion-customer{color:var(--orange);font-weight:500}.suggestion-arrow{color:var(--text-disabled);opacity:0;transition:opacity var(--transition)}.suggestion-item:hover .suggestion-arrow{opacity:1}.suggestion-footer{padding:10px;font-size:11px;color:var(--primary);text-align:center;background:var(--bg-surface);cursor:pointer;border-top:1px solid var(--bg-border)}.suggestion-footer:hover{text-decoration:underline}.topology-preview{margin-top:10px}.topology-node-wrapper{position:relative;padding-left:20px}.topology-node{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-surface);border:1px solid var(--bg-border);border-left:3px solid transparent;border-radius:var(--radius-sm);margin-bottom:4px;width:fit-content}.topology-icon{display:flex;align-items:center}.topology-name{font-size:12px;font-weight:600}.topology-type{font-size:9px;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;background:var(--bg-base);padding:1px 4px;border-radius:4px}.topology-children{position:relative;margin-left:10px;border-left:1px dashed var(--bg-border)}.topology-children:before{content:"";position:absolute;top:15px;left:-1px;width:10px;border-top:1px dashed var(--bg-border)}.text-blue{color:var(--blue)}.text-primary{color:var(--primary)}.text-purple{color:var(--purple)}.text-indigo{color:var(--indigo)}.text-green{color:var(--green)}.text-orange{color:var(--orange)}.text-red{color:var(--red)}.animate-spin{animation:spin-animate 1s linear infinite}@keyframes spin-animate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.wizard-container{max-width:900px;margin:0 auto}.wizard-steps{display:flex;justify-content:space-between;margin-bottom:2rem;position:relative}.wizard-steps:before{content:"";position:absolute;top:18px;left:0;right:0;height:2px;background:var(--bg-border);z-index:0}.wizard-step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}.step-number{width:36px;height:36px;border-radius:50%;background:var(--bg-card);border:2px solid var(--bg-border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all var(--transition)}.wizard-step.active .step-number{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 4px var(--primary-muted)}.wizard-step.completed .step-number{background:var(--accent);border-color:var(--accent);color:#fff}.step-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.wizard-step.active .step-label{color:var(--text-primary)}.form-section{padding:1rem}.section-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;margin-bottom:1.5rem;color:var(--primary)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full-width{grid-column:span 2}.form-group label{font-size:12px;font-weight:500;color:var(--text-secondary)}.review-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;background:var(--bg-surface);padding:1.5rem}.review-item{display:flex;flex-direction:column;gap:4px}.review-item .label{font-size:10px;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em}.review-item .value{font-size:14px;font-weight:500;color:var(--text-primary)}.sw-item{display:flex;align-items:center;gap:1rem;padding:12px;margin-bottom:10px;background:var(--bg-surface)}.sw-item input[type=text]{flex:1}.wizard-actions{display:flex;align-items:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--bg-border)}.final-actions{display:flex;gap:10px}.animate-slide-in{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.id-badge{background:var(--bg-surface);border:1px solid var(--bg-border);padding:3px 6px;border-radius:4px;font-family:monospace;font-size:12px;color:var(--primary)}.status-pill{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid transparent;letter-spacing:.02em}.modal-content{background:var(--bg-card);border:1px solid #253653;border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 60px #0009;overflow:hidden}.modal-title{font-size:15px;font-weight:700;color:var(--text-primary)}.close-btn{width:28px;height:28px;border-radius:var(--radius-sm);background:var(--bg-hover);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1;transition:background var(--transition),color var(--transition)}.close-btn:hover{background:var(--red-bg);color:var(--red)}.animate-in{animation:modalIn .25s ease-out}.ip-dot.used{background:#60a5fa80}.ip-dot.free{background:#22c55e40}.ip-dot.reserved{background:#fbbf2459}.ip-dot.dhcp{background:#a78bfa59}.label-green{color:var(--green)!important}.label-yellow{color:var(--yellow)!important}.label-red{color:var(--red)!important}*,input[type=checkbox],input[type=radio],input[type=range]{accent-color:var(--primary)}::selection{background:#00e5b040;color:var(--text-primary)}.select-card{background:var(--bg-hover);border:2px solid var(--bg-border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;transition:border-color var(--transition),background var(--transition),box-shadow var(--transition);user-select:none}.select-card:hover{border-color:#00e5b080;background:#00e5b012}.select-card.selected{border-color:#00e5b0!important;background:#00e5b02e!important;box-shadow:0 0 0 2px #00e5b0,0 0 20px #00e5b059!important;color:#fff}.wizard-stepper{display:flex;align-items:center;justify-content:center;margin-bottom:32px;gap:0}.wizard-step{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;flex:1}.step-circle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;background:var(--bg-hover);border:2px solid var(--bg-border);color:var(--text-muted);transition:all var(--transition);z-index:1}.wizard-step.active .step-circle{background:var(--primary);border-color:var(--primary);color:#07090f;box-shadow:0 0 12px var(--primary-glow)}.wizard-step.completed .step-circle{background:#00e5b026;border-color:var(--primary);color:var(--primary)}.step-label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.wizard-step.active .step-label{color:var(--primary);font-weight:700}.wizard-step.completed .step-label{color:#00e5b0b3}.step-connector{position:absolute;top:18px;left:50%;width:100%;height:2px;background:var(--bg-border);z-index:0}.wizard-step.completed .step-connector{background:var(--primary)}
