:root{--ink: #0b2027;--ink-2: #13343d;--ink-soft: #5b7178;--bg: #eef2f1;--card: #ffffff;--border: #dde5e3;--border-strong: #c5d1ce;--accent: #0f766e;--accent-hover: #0c5f59;--accent-soft: #d7ede9;--in-use: #2563eb;--in-use-soft: #dbe7fe;--in-stock: #16a34a;--in-stock-soft: #d6f0dd;--maintenance: #d97706;--maintenance-soft: #fcecd2;--retired: #64748b;--retired-soft: #e6eaef;--danger: #dc2626;--danger-soft: #fbe0e0;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 2px rgba(11, 32, 39, .06), 0 8px 24px -12px rgba(11, 32, 39, .18);--shadow-pop: 0 12px 40px -8px rgba(11, 32, 39, .35);--mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit;font-size:14px}.app{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.sidebar{background:var(--ink);color:#cfe0dd;display:flex;flex-direction:column;padding:20px 14px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 22px}.brand-mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(150deg,var(--accent),#134e4a);display:grid;place-items:center;flex-shrink:0;box-shadow:inset 0 0 0 1px #ffffff14}.brand-name{font-weight:700;color:#fff;letter-spacing:-.01em;line-height:1.15}.brand-name small{display:block;font-weight:500;font-size:11px;color:#6f8a86;letter-spacing:.06em;text-transform:uppercase}.nav{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);color:#9fb6b2;background:none;border:none;width:100%;text-align:left;font-size:14px;font-weight:500;transition:background .12s,color .12s}.nav-item:hover{background:var(--ink-2);color:#e4efed}.nav-item.active{background:var(--accent);color:#fff}.nav-item svg{width:18px;height:18px;flex-shrink:0}.sidebar-foot{margin-top:auto;padding:12px 12px 4px;border-top:1px solid rgba(255,255,255,.07);font-size:11px;color:#6f8a86}.sidebar-foot .dot{color:var(--in-stock)}.main{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:22px 30px;gap:16px;border-bottom:1px solid var(--border);background:#eef2f1d9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);position:sticky;top:0;z-index:5}.topbar h1{font-size:21px;font-weight:700;letter-spacing:-.02em}.topbar .sub{font-size:13px;color:var(--ink-soft);margin-top:1px}.content{padding:26px 30px 60px}.stat-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:22px}.stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 18px 16px;box-shadow:var(--shadow);position:relative;overflow:hidden}.stat:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--bar, var(--accent))}.stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);font-weight:600}.stat-value{font-family:var(--mono);font-size:32px;font-weight:700;letter-spacing:-.02em;margin-top:8px}.stat-foot{font-size:12px;color:var(--ink-soft);margin-top:2px}.panel-grid{display:grid;gap:14px;grid-template-columns:1fr 1fr;margin-bottom:14px}@media (max-width: 900px){.panel-grid{grid-template-columns:1fr}}.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border)}.panel-head h2{font-size:14px;font-weight:600}.panel-head .hint{font-size:12px;color:var(--ink-soft)}.panel-body{padding:18px}.donut-wrap{display:flex;align-items:center;gap:22px}.donut-legend{display:flex;flex-direction:column;gap:9px;flex:1}.legend-row{display:flex;align-items:center;gap:9px;font-size:13px}.legend-row .swatch{width:11px;height:11px;border-radius:3px;flex-shrink:0}.legend-row .count{margin-left:auto;font-family:var(--mono);font-weight:600}.bars{display:flex;flex-direction:column;gap:13px}.bar-row{display:grid;grid-template-columns:92px 1fr 34px;align-items:center;gap:10px;font-size:13px}.bar-row .name{color:var(--ink-soft);text-transform:capitalize}.bar-track{height:9px;background:var(--bg);border-radius:99px;overflow:hidden}.bar-fill{height:100%;border-radius:99px;background:var(--accent);transition:width .5s cubic-bezier(.2,.8,.2,1)}.bar-row .num{font-family:var(--mono);font-weight:600;text-align:right}.list{display:flex;flex-direction:column}.list-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.list-row:last-child{border-bottom:none}.list-row .grow{min-width:0}.list-row .title{font-weight:500}.list-row .meta{font-size:12px;color:var(--ink-soft)}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.search{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 12px;height:38px;min-width:240px}.search input{border:none;outline:none;background:none;width:100%}.search svg{width:16px;height:16px;color:var(--ink-soft)}.filters{display:flex;gap:6px}.chip{height:38px;padding:0 13px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--card);color:var(--ink-soft);font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:7px;transition:all .12s}.chip:hover{border-color:var(--border-strong)}.chip.on{background:var(--ink);border-color:var(--ink);color:#fff}.chip .tick{width:7px;height:7px;border-radius:99px}.btn{height:38px;padding:0 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--card);color:var(--ink);font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:all .12s}.btn:hover{border-color:var(--border-strong);background:#f7faf9}.btn svg{width:16px;height:16px}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost{border-color:transparent;background:none;padding:0 8px}.btn-ghost:hover{background:var(--bg)}.btn-danger{color:var(--danger)}.btn-danger:hover{background:var(--danger-soft);border-color:var(--danger)}.btn-sm{height:32px;padding:0 11px;font-size:13px}.btn-icon{width:34px;height:34px;padding:0;justify-content:center}.btn:disabled{opacity:.55;cursor:not-allowed}.table-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}table{width:100%;border-collapse:collapse}thead th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft);padding:12px 16px;border-bottom:1px solid var(--border);background:#f6f9f8;white-space:nowrap}tbody td{padding:13px 16px;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#f7faf9}.cell-host{font-family:var(--mono);font-weight:600;font-size:13px}.cell-model{color:var(--ink-soft);font-size:13px}.row-actions{display:flex;gap:4px;justify-content:flex-end}.tag-chip{font-family:var(--mono);font-size:11.5px;font-weight:500;color:#2a4a44;background:linear-gradient(#fbfdfc,#eef4f2);border:1px solid var(--border-strong);border-radius:5px;padding:3px 8px 3px 20px;position:relative;display:inline-block;box-shadow:inset 0 1px #fffc;letter-spacing:.02em;white-space:nowrap}.tag-chip:before{content:"";position:absolute;left:7px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:99px;background:var(--accent);box-shadow:0 0 0 2px #0f766e2e}.tag-empty{color:var(--ink-soft);font-size:12px}.mono{font-family:var(--mono)}.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px 3px 8px;border-radius:99px;font-size:12px;font-weight:600;white-space:nowrap}.pill .ind{width:7px;height:7px;border-radius:99px}.pill.in_use{background:var(--in-use-soft);color:#1d4ed8}.pill.in_use .ind{background:var(--in-use)}.pill.in_stock{background:var(--in-stock-soft);color:#15803d}.pill.in_stock .ind{background:var(--in-stock)}.pill.maintenance{background:var(--maintenance-soft);color:#b45309}.pill.maintenance .ind{background:var(--maintenance)}.pill.retired{background:var(--retired-soft);color:#475569}.pill.retired .ind{background:var(--retired)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b202773;display:grid;place-items:center;padding:20px;z-index:50;animation:fade .15s ease}.modal{background:var(--card);border-radius:var(--radius);width:100%;max-width:520px;box-shadow:var(--shadow-pop);max-height:90vh;overflow:auto;animation:rise .18s cubic-bezier(.2,.8,.2,1)}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}.modal-head h2{font-size:17px;font-weight:700;letter-spacing:-.01em}.modal-body{padding:20px 22px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border)}@keyframes fade{0%{opacity:0}}@keyframes rise{0%{opacity:0;transform:translateY(10px)}}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field.full{grid-column:1 / -1}.field label{font-size:12px;font-weight:600;color:var(--ink-soft)}.field input,.field select{height:38px;padding:0 11px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;outline:none;color:var(--ink);transition:border-color .12s,box-shadow .12s}.field input:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field.mono input{font-family:var(--mono)}.empty{text-align:center;padding:54px 20px;color:var(--ink-soft)}.empty svg{width:38px;height:38px;color:var(--border-strong);margin-bottom:12px}.empty h3{color:var(--ink);font-size:15px;font-weight:600;margin-bottom:4px}.loading{padding:60px;display:grid;place-items:center}.spinner{width:30px;height:30px;border-radius:99px;border:3px solid var(--border);border-top-color:var(--accent);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert-error{background:var(--danger-soft);border:1px solid #f4b8b8;color:#991b1b;border-radius:var(--radius-sm);padding:11px 14px;font-size:13px;margin-bottom:14px}.warn-row{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--border)}.warn-row:last-child{border-bottom:none}.warn-ic{width:30px;height:30px;border-radius:8px;background:var(--maintenance-soft);color:var(--maintenance);display:grid;place-items:center;flex-shrink:0}.warn-ic svg{width:16px;height:16px}.warn-row .days{margin-left:auto;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--maintenance);white-space:nowrap}.toast-wrap{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:8px;z-index:60}.toast{background:var(--ink);color:#fff;padding:11px 16px;border-radius:var(--radius-sm);font-size:13px;box-shadow:var(--shadow-pop);display:flex;align-items:center;gap:9px;animation:rise .18s ease}.toast.err{background:#7f1d1d}.toast svg{width:15px;height:15px}@media (max-width: 720px){.app{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;align-items:center;padding:12px 14px;overflow-x:auto}.brand{padding:0 14px 0 4px}.brand-name small{display:none}.nav{flex-direction:row}.nav-item span,.sidebar-foot{display:none}.form-grid{grid-template-columns:1fr}.content,.topbar{padding-left:16px;padding-right:16px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important}}.login-screen{min-height:100vh;display:grid;place-items:center;background:var(--ink);padding:20px}.login-card{background:var(--card);border-radius:16px;box-shadow:var(--shadow-pop);width:100%;max-width:380px;padding:32px 30px}.login-brand{display:flex;align-items:center;gap:11px;margin-bottom:24px}.login-card h1{font-size:19px;font-weight:700;letter-spacing:-.01em}.login-sub{font-size:13px;color:var(--ink-soft);margin:2px 0 20px}.login-submit{width:100%;justify-content:center;height:42px;margin-top:8px}.logout-btn{display:inline-flex;align-items:center;gap:7px;background:none;border:1px solid rgba(255,255,255,.12);color:#9fb6b2;padding:7px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:all .12s}.logout-btn:hover{background:var(--ink-2);color:#e4efed}.logout-btn svg{width:15px;height:15px}.login-notice{background:var(--accent-soft);border:1px solid #b8ddd7;color:#0c5f59;border-radius:var(--radius-sm);padding:10px 13px;font-size:13px;margin-bottom:16px}.linkish{background:none;border:none;font:inherit;color:var(--accent);cursor:pointer;padding:0;font-family:var(--mono);font-weight:600}.linkish:hover{text-decoration:underline}.detail-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.detail-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px;gap:16px}.detail-head h2{font-size:22px;font-weight:700;letter-spacing:-.01em}.detail-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:8px;font-size:13px;color:var(--ink-soft)}.kv{display:flex;flex-direction:column}.kv-row{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}.kv-row:last-child{border-bottom:none}.kv-row span{color:var(--ink-soft)}.policy-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px;font-weight:500;margin-top:4px}.switch{position:relative;width:44px;height:24px;border-radius:99px;background:var(--border-strong);border:none;transition:background .18s;flex-shrink:0}.switch.on{background:var(--accent)}.switch .knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:99px;background:#fff;transition:left .18s;box-shadow:0 1px 3px #0003}.switch.on .knob{left:23px}.switch:disabled{opacity:.6;cursor:wait}.info-min{margin-top:12px;font-size:12px;color:var(--maintenance);background:var(--maintenance-soft);padding:8px 11px;border-radius:var(--radius-sm)}.label-card{border:2px solid var(--ink);border-radius:10px;padding:16px 20px;text-align:center;max-width:320px;margin:0 auto;background:#fff}.label-org{font-size:10px;font-weight:700;letter-spacing:.14em;color:var(--ink-soft)}.label-barcode{display:block;width:100%;height:64px;margin:10px 0 6px}.label-code{font-family:var(--mono);font-size:18px;font-weight:700;letter-spacing:.05em;color:var(--ink)}.label-host{font-family:var(--mono);font-size:11px;color:var(--ink-soft);margin-top:3px}@media print{body *{visibility:hidden!important}#label-print,#label-print *{visibility:visible!important}#label-print{position:fixed;left:0;top:0;width:100%}.label-card{border-color:#000}}
