.layout{display:flex;min-height:100vh;position:relative;padding-top:3.2rem}.menu-toggle{display:none;position:relative;z-index:1;width:var(--btn-height);height:var(--btn-height);min-width:var(--btn-height);min-height:var(--btn-height);padding:0;background:var(--surface);border:1px solid var(--border);color:var(--text)}.menu-toggle svg{display:block;flex-shrink:0;width:1.25rem;height:1.25rem}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:#00000080;border:none;padding:0;cursor:pointer}.sidebar{width:294px;background:var(--surface);border-right:1px solid var(--border);padding:.5rem 0;flex-shrink:0;z-index:100}.nav-group{margin-bottom:.35rem}.nav-section{font-size:var(--font-size-min);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);padding:.35rem 1rem}.nav-link{display:block;padding:.4rem 1rem;color:var(--text-muted);text-decoration:none;font-size:var(--font-size-min);font-weight:500}.nav-link:hover{background:var(--surface-hover);text-decoration:none;color:var(--text)}.nav-link.active{background:var(--surface-hover);border-left:3px solid var(--accent);padding-left:calc(1rem - 3px);color:var(--text);font-weight:600}.content{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{position:fixed;top:0;left:0;right:0;z-index:120;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:.5rem 1rem;border-bottom:1px solid var(--border);background:var(--surface);min-height:2.5rem;font-size:var(--font-size-min)}.topbar-left,.topbar-right{display:flex;align-items:center;gap:.5rem}.topbar-brand{font-size:var(--font-size-brand);font-weight:700;color:var(--text)}.topbar-logout{color:var(--text-muted);font-size:var(--font-size-min);font-weight:600;text-decoration:none}.topbar-logout:hover{color:var(--text);text-decoration:underline}.user-info{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;color:var(--text-muted);font-size:var(--font-size-min);max-width:100%}.user-name{word-break:break-word;font-weight:600;color:var(--text)}.page{padding:.75rem 1rem;flex:1;max-width:100%}.page-header{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;margin-bottom:.65rem;flex-wrap:wrap}.page-header h1{margin:0;font-size:var(--font-size-title);font-weight:700;color:var(--text);word-break:break-word}.page h1{margin:0 0 .65rem;font-size:var(--font-size-title);font-weight:700;color:var(--text);word-break:break-word}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.65rem .75rem;margin-bottom:.65rem;max-width:100%}.card h2{margin:0;font-size:var(--font-size-min);color:var(--text-muted);font-weight:700}.card-form-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;align-items:end}.form-actions{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.form-actions.form-actions-footer{grid-column:1 / -1;flex-wrap:nowrap;justify-content:flex-start;gap:.5rem;margin-top:.25rem;padding-top:.5rem;border-top:1px solid var(--border)}@media (max-width: 640px){.form-actions.form-actions-footer{flex-wrap:wrap}}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:420px}.list-row-clickable{cursor:pointer}.list-row-clickable:hover td{background:var(--surface-hover)}.grouped-list{font-size:var(--font-size-min)}.grouped-list-header{font-weight:700;color:var(--text);padding:.5rem .75rem;border-bottom:1px solid var(--border)}.grouped-list-empty{padding:.75rem;margin:0}.grouped-list-section{margin:0}.grouped-list-separator{border:none;border-top:1px dashed var(--border);margin:.35rem .75rem}.grouped-list-group-title{font-size:var(--font-size-min);font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.04em;padding:.35rem .75rem .25rem}.grouped-list-row{display:block;padding:.45rem .75rem .45rem 2rem;cursor:pointer;color:var(--text)}.grouped-list-row:hover,.grouped-list-row:focus-visible{background:var(--surface-hover);outline:none}.grouped-list-row.row-highlight{background:var(--surface-hover)}.field-full{grid-column:1 / -1}.form-grid .field-full.field-checkboxes{align-self:start}textarea{font:inherit;font-size:var(--font-size-min);padding:.45rem .55rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);width:100%;resize:vertical;min-height:5rem;line-height:1.45}.row-highlight{animation:highlight-fade 3s ease-out}@keyframes highlight-fade{0%,40%{background:#3b82f659}to{background:transparent}}.search-form{display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-end}.search-input-wrap{flex:1 1 180px;min-width:0}.search-results{list-style:none;margin:0;padding:0}.search-results li+li{border-top:1px solid var(--border)}.search-result-link{display:block;padding:.55rem 0;color:inherit;text-decoration:none}.search-result-link:hover{text-decoration:none;background:var(--surface-hover);margin:0 -.35rem;padding-left:.35rem;padding-right:.35rem;border-radius:var(--radius)}.search-result-link strong{display:block;font-size:var(--font-size-min);font-weight:600;color:var(--text)}.search-result-section{display:block;font-size:var(--font-size-min);font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.2rem}.search-result-snippet{display:block;font-size:var(--font-size-min);font-weight:400;color:var(--text-muted);margin-top:.2rem}@media (max-width: 768px){.layout{padding-top:4.4rem}.menu-toggle{display:inline-flex;align-items:center;justify-content:center}.sidebar-backdrop,.layout.menu-open .sidebar-backdrop{display:block}.sidebar{position:fixed;top:0;left:0;bottom:0;transform:translate(-100%);transition:transform .2s ease;overflow-y:auto;width:240px}.layout.menu-open .sidebar{transform:translate(0)}.content{width:100%}.topbar{padding:.45rem .75rem;min-height:4rem}.topbar-brand{display:none}.page{padding:.5rem .65rem}.page-header{padding-left:0}.page-header h1,.page h1{font-size:1.25rem}table{min-width:0}table thead{display:none}table tbody tr{display:block;border-bottom:1px solid var(--border);padding:.5rem 0}table tbody tr:last-child{border-bottom:none}table tbody td{display:flex;justify-content:flex-start;align-items:flex-start;gap:0;padding:.25rem 0;border:none;text-align:left;font-size:var(--font-size-min)}table tbody td:before{content:none}.form-grid{grid-template-columns:1fr}.page-header{margin-bottom:.5rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:.75rem}.login-card{width:100%;max-width:360px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:.65rem}.login-card h1{margin:0;text-align:center;font-size:var(--font-size-title);font-weight:700;color:var(--text)}.subtitle{margin:0;text-align:center;color:var(--text-muted);font-size:var(--font-size-min);font-weight:400}.hint{margin:0;font-size:var(--font-size-min);font-weight:400;color:var(--text-subtle);text-align:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-layer-overlay{z-index:400;background:#000000eb}.modal-obscured{visibility:hidden;pointer-events:none}.modal-card{width:100%;max-width:720px;max-height:min(90vh,640px);overflow:hidden;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 16px 48px #00000073}.modal-body-scroll{overflow:auto;flex:1}.modal-card-wide{max-width:min(96vw,1080px)}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.75rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.modal-header h2{margin:0;font-size:var(--font-size-min);font-weight:700;color:var(--text);word-break:break-word}.modal-header-titles{min-width:0;flex:1}.modal-subtitle{margin-top:.2rem;font-size:var(--font-size-min);font-weight:500;color:var(--text-muted);line-height:1.3;overflow-wrap:anywhere}.modal-body{padding:.75rem;display:flex;flex-direction:column;gap:.65rem;overflow:auto;flex:1}.modal-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end;padding:.75rem;border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--surface)}.detail-field{display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem .5rem}.detail-field-label{font-size:var(--font-size-min);font-weight:600;color:var(--text-muted);flex-shrink:0}.detail-field-label:after{content:":"}.detail-field-value{font-size:var(--font-size-min);font-weight:400;color:var(--text);word-break:break-word;min-width:0;flex:1 1 auto}.detail-field-block{flex-direction:column;align-items:stretch;gap:.35rem}.detail-field-block .detail-field-value{flex:none}.detail-field-wide{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.detail-field-wide .detail-field-label{color:var(--accent);font-size:calc(var(--font-size-min) * 1.05);margin-bottom:.5rem}@media (max-width: 768px){.modal-backdrop{padding:2%;align-items:stretch;justify-content:stretch}.modal-card,.modal-card.modal-card-wide{width:100%;max-width:none;max-height:none;flex:1;min-height:0}}.recognition-choice{position:relative;display:flex;flex-direction:row;align-items:flex-start;gap:.6rem;flex-shrink:0;width:100%;min-height:2.25rem;margin:0 0 .4rem;padding:.5rem .6rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:var(--font-size-min);font-weight:400;line-height:1.35;cursor:pointer;text-align:left;box-sizing:border-box}.recognition-choice:hover{background:var(--surface-hover);border-color:var(--text-subtle)}.recognition-choice.is-checked{border-color:var(--accent);background:#23a40e1f}.recognition-choice-input,.recognition-choice input[type=radio]{position:absolute;left:0;top:0;width:1px!important;height:1px!important;min-width:0!important;max-width:none!important;min-height:0!important;padding:0!important;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0!important;border-radius:0!important;background:transparent!important;opacity:0;pointer-events:none;flex:none!important;-moz-appearance:none;appearance:none;-webkit-appearance:none}.recognition-choice-mark{flex:0 0 1.125rem;width:1.125rem;height:1.125rem;margin-top:.15rem;border:2px solid var(--text-muted);border-radius:50%;background:var(--surface);box-sizing:border-box}.recognition-choice.is-checked .recognition-choice-mark{border-color:var(--accent);background:var(--accent);box-shadow:inset 0 0 0 3px var(--surface)}.recognition-choice-text{flex:1;min-width:0;color:var(--text);font-weight:500;overflow-wrap:anywhere;word-break:break-word}.recognition-options{display:flex;flex-direction:column;gap:0;flex-shrink:0;width:100%;min-height:min-content;max-height:min(40vh,18rem);overflow:auto;margin:0 0 .5rem;padding:0}.photo-input-hidden{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.photo-action-error{color:var(--danger);font-size:var(--font-size-min);align-self:center}.photo-action-info{color:var(--text-muted);font-size:var(--font-size-min)}.ocr-preview{margin:.75rem 0;font-size:var(--font-size-min)}.ocr-preview pre{margin:.5rem 0 0;padding:.5rem;background:var(--bg);border-radius:var(--radius);white-space:pre-wrap;word-break:break-word;max-height:8rem;overflow:auto}.recognition-section-title{font-weight:600;margin:.75rem 0 .35rem;font-size:var(--font-size-min)}.recognition-section-title:first-of-type{margin-top:0}.recognition-dialog .modal-body{gap:.5rem}.recognition-dialog .modal-body>.recognition-section-title,.recognition-dialog .modal-body>.recognition-options,.recognition-dialog .modal-body>.muted,.recognition-dialog .modal-body>details,.recognition-dialog .modal-body>.form-actions{flex-shrink:0}.recognition-dialog .recognition-choice{display:flex!important;font-weight:400;color:var(--text);margin-bottom:.4rem}.recognition-dialog .recognition-choice-text{display:block;color:var(--text)}.module-specs-line{font-size:.85em;color:var(--text-muted);margin-top:.2rem;line-height:1.35;overflow-wrap:anywhere}.module-list-model{min-width:0}.photo-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.photo-gallery-thumb{display:flex;flex-direction:column;gap:.35rem;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;overflow:hidden;text-align:left}.photo-gallery-thumb img{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block}.photo-gallery-caption{font-size:var(--font-size-min);color:var(--text-muted);padding:0 .4rem .4rem;line-height:1.3}.photo-gallery-caption strong{color:var(--text);font-weight:600}.photo-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#000;display:flex;align-items:center;justify-content:center}.photo-fullscreen-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;touch-action:manipulation}.photo-fullscreen-toolbar{position:fixed;top:0;left:0;right:0;z-index:2;display:flex;justify-content:space-between;padding:max(.75rem,env(safe-area-inset-top)) .75rem .75rem;background:linear-gradient(to bottom,rgba(0,0,0,.65),transparent);pointer-events:none}.photo-fullscreen-toolbar .btn-icon{pointer-events:auto}.photo-fullscreen-meta{position:fixed;left:0;right:0;bottom:0;z-index:2;padding:.75rem max(.75rem,env(safe-area-inset-right)) max(.75rem,env(safe-area-inset-bottom)) max(.75rem,env(safe-area-inset-left));background:linear-gradient(to top,rgba(0,0,0,.7),transparent);color:#fff;font-size:var(--font-size-min);display:flex;flex-direction:column;gap:.2rem;pointer-events:none}.photo-fullscreen-meta strong{font-weight:600}.photo-fullscreen-meta span{opacity:.85}.list-filters{display:flex;flex-wrap:wrap;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--border);justify-content:flex-start}.list-filters .field{margin:0;min-width:12rem}.list-filters .field.filter-narrow{min-width:8rem}.logs-filter-actions{min-width:auto}.logs-filter-actions .form-actions{margin:0}.logs-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 0 0;border-top:1px solid var(--border);margin-top:.75rem}.logs-pagination-buttons{display:flex;align-items:center;gap:.5rem}.modal-card-map-fullscreen{width:96vw;max-width:none;height:96vh;max-height:none}.modal-card-map-fullscreen .modal-body{overflow:hidden;padding:.75rem}.yandex-map-picker{display:flex;flex-direction:column;gap:.75rem;height:100%}.yandex-map-toolbar{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.yandex-map-coords{display:flex;flex-wrap:wrap;gap:.75rem;font-size:var(--font-size-min);color:var(--text-muted)}.yandex-map-canvas{width:100%;flex:1;min-height:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.yandex-map-canvas-loading{display:flex;align-items:center;justify-content:center;background:var(--bg)}.placement-map-page{height:calc(100dvh - 3.2rem);display:flex;flex-direction:column;padding-bottom:2dvh;min-height:0}.placement-map-card{display:flex;flex-direction:column;gap:.65rem;flex:1;min-height:0;margin-bottom:0}.placement-map-loading{margin:0}.placement-map-route-toolbar{display:flex;flex-wrap:wrap;gap:.75rem 1rem;align-items:center}.placement-map-route-edit-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.placement-map-route-hint{flex:1 1 100%;font-size:var(--font-size-min)}.placement-map-canvas{width:100%;flex:1;min-height:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}a.placement-map-balloon-edit{color:var(--accent, #2563eb);text-decoration:underline;cursor:pointer}a.placement-map-balloon-edit:hover{text-decoration:none}.rack-diagram-header{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem}.rack-frame{border:2px solid var(--border);border-radius:var(--radius);background:var(--bg);padding:.5rem;overflow:visible}.rack-units{display:flex;flex-direction:column;gap:2px}.rack-unit-row{display:grid;grid-template-columns:2.5rem 1fr;gap:.35rem;align-items:stretch;min-height:2rem}.rack-unit-num{font-size:var(--font-size-min);font-weight:600;color:var(--text-muted);display:flex;align-items:center;justify-content:center;border-right:1px solid var(--border)}.rack-unit-slot{position:relative;min-height:2rem;border:1px dashed var(--border);border-radius:4px;background:var(--surface)}.rack-unit-occupied .rack-unit-slot{border-style:solid}.rack-device{position:absolute;left:0;right:0;top:0;z-index:1;padding:.25rem .4rem;border-radius:4px;display:flex;align-items:center;overflow:hidden;box-sizing:border-box}.rack-device-network_equipment{background:#23a40e40;border:1px solid var(--accent)}.rack-device-passive_equipment{background:#6495ed40;border:1px solid #6495ed}.rack-extra-item-passive_equipment{background:#6495ed26}.rack-device-server{background:#ef341d33;border:1px solid var(--danger)}.rack-device-name{font-size:calc(var(--font-size-min) * 2 / 3);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;width:100%}.rack-extra-zones{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.rack-extra-zone{border:1px solid var(--border);border-radius:var(--radius);padding:.5rem .75rem;background:var(--surface)}.rack-extra-zone-title{margin:0 0 .5rem;font-size:var(--font-size-min);color:var(--accent)}.rack-extra-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.rack-extra-item{padding:.35rem .5rem;border-radius:4px;display:flex;flex-direction:column;gap:.15rem}.rack-extra-subtitle{font-size:var(--font-size-min)}.rack-extra-empty{margin:0;font-size:var(--font-size-min)}.server-components-editor .field-label{font-size:var(--font-size-min);font-weight:600;color:var(--text-muted);margin-bottom:.35rem}.server-components-list{list-style:none;margin:0 0 .5rem;padding:0;display:flex;flex-direction:column;gap:.35rem}.server-components-list li{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;padding:.35rem .5rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--font-size-min)}.server-component-line-main{flex:1;display:flex;flex-direction:column;gap:.35rem;min-width:0}.server-component-line-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.server-component-serial-label{display:flex;align-items:center;gap:.35rem;font-size:var(--font-size-min);color:var(--text-muted)}.server-component-serial-label input{font:inherit;font-size:var(--font-size-min);padding:.2rem .35rem;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);min-width:8rem}.server-component-detail-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem}.server-components-add{display:grid;grid-template-columns:1fr 1fr auto;gap:.5rem;align-items:end}.server-components-add .btn-icon{align-self:end;margin-bottom:.1rem}.server-components-detail{margin:0;padding-left:1.1rem;font-size:var(--font-size-min)}.server-components-detail li{margin-bottom:.25rem}@media (max-width: 640px){.server-components-add{grid-template-columns:1fr}}.device-ifaces{margin-top:.25rem}.device-ifaces-loading{margin:0}.device-ifaces-toolbar{margin-bottom:.5rem}.device-ifaces-table{width:100%;font-size:var(--font-size-min)}.device-ifaces-table th,.device-ifaces-table td{text-align:left;vertical-align:middle;padding:.35rem .5rem}.device-ifaces-actions{white-space:nowrap;text-align:right}.device-ifaces-actions .icon-btn{margin-left:.25rem}.field-inline{display:flex;align-items:center;gap:.5rem;margin:.5rem 0}.card-list .table-wrap:has(.ipam-list-table){width:fit-content;max-width:100%}table.ipam-list-table{width:max-content;max-width:100%;min-width:0}table.ipam-list-table th,table.ipam-list-table td{width:auto;white-space:nowrap}table.ipam-list-table .ipam-tree-child-spacer{width:0;padding-left:0;padding-right:0}.ipam-subnet-stats{margin-left:.5rem;color:var(--text-muted);font-size:var(--font-size-min)}.ipam-subnet-occupied{color:#ef341d}.page-header-search{margin-left:auto;min-width:min(100%,16rem);max-width:24rem;flex:1 1 12rem}.page-header-search label{display:none}.page-header-search input{width:100%}.ipam-tree-row,.ipam-tree-child.ipam-tree-link{cursor:pointer}.ipam-tree-child.ipam-tree-link:hover td{background:var(--surface-hover)}.ipam-prefix-link-cell{cursor:pointer}.ipam-prefix-link-cell:hover{color:var(--accent)}.ipam-tree-row:hover:not(:has(.ipam-tree-toggle:hover)):not(:has(.ipam-prefix-link-cell:hover)) td{background:var(--surface-hover)}.ipam-tree-toggle{display:inline;cursor:pointer;color:var(--text);-webkit-user-select:none;user-select:none;margin-right:.15rem;line-height:inherit;vertical-align:baseline}.ipam-tree-toggle:hover{color:var(--accent)}.ipam-tree-toggle:focus{outline:none}.ipam-tree-toggle:focus-visible{color:var(--accent);outline:none}.ipam-tree-name{color:var(--text);vertical-align:baseline}.ipam-tree-child td{background:color-mix(in srgb,var(--bg) 88%,var(--surface) 12%);font-size:var(--font-size-min);border-top:none}.ipam-tree-child-label{padding-left:1.35rem!important}.ipam-tree-empty td{padding-left:1.35rem!important;color:var(--text-muted);font-size:var(--font-size-min)}.ipam-row-actions{width:1%;white-space:nowrap;text-align:right}.ipam-row-actions .btn-icon+.btn-icon{margin-left:.25rem}.ipam-child-head td{font-weight:600;color:var(--text-muted);font-size:var(--font-size-min);background:color-mix(in srgb,var(--bg) 82%,var(--surface) 18%);padding-top:.35rem;padding-bottom:.35rem}@media (max-width: 768px){.card-list .table-wrap:has(.ipam-list-table){width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}table.ipam-list-table{width:max-content;max-width:none;min-width:0}table.ipam-list-table thead{display:table-header-group}table.ipam-list-table tbody tr{display:table-row;padding:0;border-bottom:none}table.ipam-list-table th,table.ipam-list-table td{display:table-cell;padding:.5rem .55rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}}.subnet-addresses-section{margin-top:.75rem}.subnet-addresses-title{margin:0 0 .5rem;font-size:var(--font-size-min);font-weight:600}.subnet-addresses-table input{width:100%}.subnet-addresses-table .subnet-address-fixed{color:var(--text-muted)}.subnet-addresses-scroll{max-height:min(50vh,420px);overflow:auto}.subnet-detail-meta{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.subnet-detail-meta-row{display:flex;gap:.5rem;flex-wrap:wrap}.subnet-detail-meta-label{color:var(--text-muted);min-width:5.5rem}.searchable-select{position:relative}.searchable-select-input{width:100%}.searchable-select-list{position:absolute;z-index:20;left:0;right:0;top:calc(100% + 2px);max-height:220px;overflow-y:auto;margin:0;padding:.25rem 0;list-style:none;background:var(--surface, #fff);border:1px solid var(--border, #ccc);border-radius:4px;box-shadow:0 4px 12px #0000001f}.searchable-select-option{display:block;width:100%;padding:.45rem .65rem;border:none;background:transparent;text-align:left;font:inherit;cursor:pointer}.searchable-select-option:hover,.searchable-select-option.is-selected{background:var(--surface-alt, rgba(100, 149, 237, .12))}.searchable-select-empty{padding:.5rem .65rem}@font-face{font-family:GOST Type A;font-style:normal;font-weight:300;font-display:swap;src:local("GOST Type A Light"),local("GOSTTypeA-Light"),url(/fonts/GOSTTypeA-Light.ttf) format("truetype"),url(/fonts/GOST_A.TTF) format("truetype"),url(/fonts/GOSTTypeA-Light.woff2) format("woff2"),url(/fonts/GOSTTypeA-Light.woff) format("woff")}.passive-diagram-wrap{overflow-x:auto;overflow-y:visible;max-width:100%;margin-top:.25rem;--passive-diagram-heading-font: calc(var(--font-size-min) * 1.05);--passive-diagram-font: calc(var(--passive-diagram-heading-font) - 2pt);--passive-diagram-header-font: "Segoe UI", system-ui, -apple-system, sans-serif;--passive-diagram-body-font: "GOST Type A", "Segoe UI", system-ui, sans-serif}.passive-diagram{display:block;height:auto;font-family:var(--passive-diagram-body-font);font-weight:300;font-size:var(--passive-diagram-font)}.passive-diagram text{font-family:inherit;font-weight:inherit;font-size:1em}.passive-diagram-header{font-family:var(--passive-diagram-header-font);fill:#fff;font-weight:600;font-size:.95em}.passive-diagram-header-equipment{font-family:var(--passive-diagram-header-font);font-weight:700;font-size:1.05em}.passive-diagram-zone-title{fill:#fff;font-weight:300}.passive-diagram-comp-box{fill:none;stroke:#6495ed;stroke-width:1}.passive-diagram-comp-title{fill:var(--text);font-weight:300}.passive-diagram-link{fill:none;stroke:var(--accent);stroke-width:1.5;opacity:.85}.passive-diagram-link-label{fill:var(--text-muted);font-size:.85em}.passive-diagram-node circle{stroke:var(--surface);stroke-width:2}.passive-diagram-node-apc circle{fill:#23a40e}.passive-diagram-node-upc circle{fill:#6495ed}.passive-diagram-node-front circle{fill:#888}.passive-diagram-socket-shape{fill:none;stroke-width:2.5}.passive-diagram-node-apc .passive-diagram-socket-shape{stroke:#23a40e}.passive-diagram-node-upc .passive-diagram-socket-shape{stroke:#6495ed}.passive-diagram-node-front .passive-diagram-socket-shape{stroke:#aaa}.passive-diagram-socket-label{fill:var(--text);font-weight:300;font-size:.9em;pointer-events:none}.passive-diagram-node-back circle{fill:#888}.passive-diagram-component-port-shape{fill:none;stroke:#6495ed;stroke-width:1}.passive-diagram-component-port-label{fill:var(--text);font-weight:300;font-size:.82em;pointer-events:none}.passive-diagram-cable-oval{fill:none;stroke:#888;stroke-width:1.5}.passive-diagram-cable-fiber{fill:#888;stroke:var(--surface);stroke-width:1.5}.passive-diagram-cable-end{fill:none;stroke:#888;stroke-width:1.5;stroke-linecap:round}.passive-diagram-node-label{fill:var(--text);font-weight:300}.passive-diagram-cable-label{font-weight:300}.passive-diagram-cable-table{font-style:italic}.passive-diagram-cable-table-leader,.passive-diagram-cable-table-frame{fill:none;stroke:#fff;stroke-width:1.25}.passive-diagram-cable-table-grid{stroke:#ffffff73;stroke-width:1}.passive-diagram-cable-table-header{fill:#fff;font-size:.9em;font-weight:600;font-style:italic;pointer-events:none}.passive-diagram-cable-table-cell{fill:#fff;font-size:.88em;font-weight:300;font-style:italic;pointer-events:none}.passive-diagram-cable-table-cell-end{font-size:.82em}.passive-diagram-node-label-vertical{font-size:1em}.passive-diagram-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:var(--bg);display:flex;flex-direction:column}.passive-diagram-fullscreen-toolbar{position:fixed;top:0;left:0;right:0;z-index:2;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-start;padding:max(.75rem,env(safe-area-inset-top)) .75rem .75rem;background:linear-gradient(to bottom,rgba(27,36,35,.95),transparent);pointer-events:none}.passive-diagram-fullscreen-toolbar .btn-icon{pointer-events:auto}.passive-diagram-fullscreen-body{flex:1;min-height:0;overflow:auto;padding:calc(var(--btn-height) + 1rem) max(.75rem,env(safe-area-inset-right)) max(.75rem,env(safe-area-inset-bottom)) max(.75rem,env(safe-area-inset-left))}.passive-diagram-fullscreen-body .passive-diagram-wrap{max-width:none}.passive-ai-diagram-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:var(--bg);display:flex;flex-direction:column}.passive-ai-diagram-fullscreen-toolbar{position:fixed;top:0;left:0;right:0;z-index:2;display:flex;justify-content:flex-start;padding:max(.75rem,env(safe-area-inset-top)) .75rem .75rem;background:linear-gradient(to bottom,rgba(27,36,35,.95),transparent);pointer-events:none}.passive-ai-diagram-fullscreen-toolbar .btn-icon{pointer-events:auto}.passive-ai-diagram-fullscreen-body{flex:1;min-height:0;overflow:auto;padding:calc(var(--btn-height) + 1rem) max(.75rem,env(safe-area-inset-right)) max(.75rem,env(safe-area-inset-bottom)) max(.75rem,env(safe-area-inset-left))}.passive-ai-diagram-svg{max-width:100%;overflow-x:auto}.passive-ai-diagram-svg{--passive-diagram-body-font: "GOST Type A", "Segoe UI", system-ui, sans-serif}.passive-ai-diagram-svg svg{display:block;max-width:none;height:auto;font-family:var(--passive-diagram-body-font);font-weight:300}.socket-wizard{display:flex;flex-direction:column;gap:1rem}.socket-wizard-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.25rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.socket-wizard-toolbar-links{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.socket-wizard-link{padding:0;border:none;background:none;font:inherit;font-size:var(--font-size-min);color:var(--accent);text-decoration:underline;text-underline-offset:2px;cursor:pointer}.socket-wizard-link:hover:not(:disabled){color:var(--text)}.socket-wizard-link:disabled{opacity:.5;cursor:not-allowed}.socket-wizard-toolbar-sep{color:var(--text-muted);-webkit-user-select:none;user-select:none}.socket-wizard-toolbar-selects{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.socket-wizard-select-field{display:flex;align-items:center;gap:.35rem;font-size:var(--font-size-min)}.socket-wizard-select-label{color:var(--text-muted);white-space:nowrap}.socket-wizard-select-field select{min-width:5.5rem;font:inherit;font-size:var(--font-size-min)}.socket-wizard-rows{display:flex;flex-direction:column;gap:1.25rem;max-height:min(50vh,420px);overflow-y:auto;padding:.25rem}.socket-wizard-row-title{font-weight:700;margin-bottom:.5rem;color:var(--accent)}.socket-wizard-block{margin-left:.75rem;margin-bottom:.75rem;padding-left:.75rem;border-left:2px solid var(--border)}.socket-wizard-block-title{font-size:var(--font-size-min);font-weight:600;margin-bottom:.35rem;color:var(--text-muted)}.socket-wizard-sockets{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.socket-wizard-chip{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:2.75rem;min-height:2.75rem;padding:.25rem .4rem;border:2px solid var(--border);background:var(--surface);cursor:pointer;font:inherit;color:var(--text)}.socket-wizard-chip-circle{border-radius:50%}.socket-wizard-chip-square{border-radius:4px}.socket-wizard-chip-front{border-color:#4a90d9}.socket-wizard-chip-upc{border-color:#1565c0;background:#1565c01a}.socket-wizard-chip-apc{border-color:#2e7d32;background:#2e7d3214}.socket-wizard-chip-selected{outline:2px solid var(--accent);outline-offset:2px}.socket-wizard-chip-pos{font-weight:700;font-size:.95rem;line-height:1.1}.socket-wizard-chip-sub{font-size:.65rem;color:var(--text-muted);max-width:4.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.socket-wizard-add-socket{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border:2px dashed var(--border);border-radius:4px;background:transparent;color:var(--text-muted);cursor:pointer}.socket-wizard-add-socket:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.socket-wizard-editor{padding:.75rem;border:1px solid var(--border);border-radius:4px;background:var(--surface-alt, var(--surface))}.socket-wizard-editor-title{font-weight:600;margin-bottom:.5rem}.socket-wizard-editor-fields{display:flex;flex-wrap:wrap;gap:.75rem}.socket-wizard-editor-fields .field{min-width:10rem}.socket-wizard-hint{margin:0}.passive-topology-editor{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.passive-topology-editor-title{margin:0;font-size:var(--font-size-min);color:var(--accent);font-weight:700}.passive-topology-section{display:flex;flex-direction:column;gap:.35rem}.passive-topology-section h3{margin:0;font-size:var(--font-size-min);color:var(--accent)}.passive-topology-header{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;margin-bottom:.5rem}.passive-add-port-actions{display:flex;flex-wrap:wrap;gap:.35rem;margin-left:auto}.passive-add-port-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;font:inherit;font-size:var(--font-size-min);font-weight:500;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer}.passive-add-port-btn:hover{border-color:var(--accent);color:var(--accent)}.passive-add-port-btn svg{width:1rem;height:1rem;flex-shrink:0}.passive-component-block{border:1px solid var(--border);border-radius:var(--radius);padding:.5rem .75rem;margin-bottom:.5rem}.passive-ports-table{width:100%;font-size:var(--font-size-min)}.passive-ports-table th,.passive-ports-table td{text-align:left;padding:.35rem .5rem;vertical-align:middle}.passive-actions{white-space:nowrap;text-align:right}.passive-actions .icon-btn{margin-left:.25rem}.passive-topology-editor .field-row{display:flex;flex-wrap:wrap;gap:.75rem}.passive-topology-editor .field-row .field{flex:1 1 5rem;min-width:5rem}.passive-component-models-layout{display:grid;grid-template-columns:minmax(280px,1fr) minmax(320px,1.4fr);gap:1.5rem;align-items:start}.passive-component-models-list table tbody tr{cursor:pointer}.passive-model-row-selected{background:var(--surface-alt, rgba(100, 149, 237, .12))}.passive-component-models-detail{min-width:0}.passive-component-models-hint{margin-bottom:1rem}@media (max-width: 900px){.passive-component-models-layout{grid-template-columns:1fr}}.backup-page{display:flex;flex-direction:column;gap:1rem}.backup-section{margin-bottom:0}.backup-section-title{margin:0 0 1rem;font-size:var(--font-size-base)}.backup-subsection-title{margin:1rem 0 .75rem;font-size:var(--font-size-min);font-weight:600}.backup-checkbox-row{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;margin:0;cursor:pointer;width:fit-content;max-width:100%}.backup-checkbox-row input[type=checkbox]{margin:0;flex:0 0 auto;width:1rem;height:1rem;padding:0}.backup-checkbox-row span{flex:0 1 auto;font-weight:600;color:var(--text-muted)}.backup-section-hint{margin:.5rem 0 .75rem}.backup-schedule-time{display:flex;flex-wrap:wrap;gap:1rem}.backup-schedule-time .field{margin:0;min-width:6rem}.backup-manual{margin-bottom:.5rem}.backup-job{margin:1rem 0 0;padding:.75rem 1rem;border:1px solid var(--border);border-radius:6px;background:var(--surface)}.backup-job-header{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;justify-content:space-between}.backup-job-message{margin:.5rem 0 0}.backup-progress{margin-top:.75rem;height:.5rem;background:var(--border);border-radius:999px;overflow:hidden}.backup-progress-bar{height:100%;background:var(--accent);transition:width .3s ease}.backup-restore-form{margin-top:.5rem}button.danger{background:#b42318;border-color:#b42318;color:#fff}button.danger:hover:not(:disabled){background:#912018}.backup-auth-fields{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.backup-auth-fields .field{margin:0;min-width:12rem;flex:1 1 12rem;max-width:20rem}.backup-public-url-cell{word-break:break-all}:root{--bg: #1b2423;--surface: #262f33;--surface-hover: #303c41;--border: #3d4a50;--text: #eeeeee;--text-muted: #8d9698;--text-subtle: #596064;--accent: #23a40e;--accent-hover: #1c8a0b;--danger: #ef341d;--success: #23a40e;--radius: 6px;--btn-height: 2.5rem;--font-size-title: calc(1.375rem - 2pt) ;--font-size-min: calc(1.292rem*(1.375rem - 2pt)/1.375rem) ;--font-size-brand: calc(1.25rem*(1.375rem - 2pt)/1.375rem) ;font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.45;color:var(--text);background:var(--bg)}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-size:var(--font-size-min)}a{color:var(--accent);text-decoration:none;font-weight:500}a:hover{text-decoration:underline;color:var(--accent-hover)}button{font:inherit;font-size:var(--font-size-min);font-weight:500;cursor:pointer;border:none;border-radius:var(--radius);padding:.5rem .85rem;min-height:var(--btn-height);background:var(--accent);color:#fff;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center}button.btn-icon{width:var(--btn-height);min-width:var(--btn-height);max-width:var(--btn-height);padding:0;flex-shrink:0}@media (max-width: 768px){:root{--btn-height: 3.75rem;--font-size-min: .875rem}button.btn-icon{width:var(--btn-height);min-width:var(--btn-height);max-width:var(--btn-height);height:var(--btn-height);min-height:var(--btn-height);aspect-ratio:1 / 1;padding:0}button.btn-sm.btn-icon{width:var(--btn-height);min-width:var(--btn-height);max-width:var(--btn-height);height:var(--btn-height);min-height:var(--btn-height)}.form-actions .btn-icon{flex:0 0 auto}}button.btn-icon svg{display:block;width:1.25rem;height:1.25rem}button.btn-icon-primary{background:var(--accent);color:#fff}button.btn-icon-primary:hover:not(:disabled){background:var(--accent-hover)}button.btn-icon-secondary{background:var(--surface-hover);color:var(--text)}button.btn-icon-secondary:hover:not(:disabled){background:var(--border)}button.btn-icon-danger{background:var(--danger);color:#fff}button.btn-sm{min-height:calc(var(--btn-height) * .85);width:calc(var(--btn-height) * .85);min-width:calc(var(--btn-height) * .85)}button:hover:not(:disabled){background:var(--accent-hover)}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:var(--surface-hover);color:var(--text)}button.danger{background:var(--danger)}input,select{font:inherit;font-size:var(--font-size-min);padding:.45rem .55rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);width:100%}label{display:block;font-size:var(--font-size-min);font-weight:600;color:var(--text-muted);margin-bottom:.2rem}.field{min-width:0}table{width:100%;border-collapse:collapse;font-size:var(--font-size-min)}.row-highlight td{background:#3b82f633}th,td{text-align:left;padding:.5rem .55rem;border-bottom:1px solid var(--border);vertical-align:middle}th{color:var(--text-muted);font-weight:600;font-size:var(--font-size-min)}td{color:var(--text);font-weight:400}.error{color:var(--danger);font-size:var(--font-size-min);font-weight:500;margin:.35rem 0 0}.muted{color:var(--text-muted);font-size:var(--font-size-min);font-weight:400;margin:0}.empty-cell{color:var(--text-muted);font-weight:400;text-align:center;padding:.75rem!important}.log-action{display:inline-block;font-size:var(--font-size-min);font-weight:600;padding:.2rem .45rem;border-radius:4px;white-space:nowrap}.log-action-create{background:#22c55e33;color:#86efac}.log-action-update{background:#3b82f633;color:#93c5fd}.log-action-delete{background:#ef444433;color:#fca5a5}.log-action-other{background:var(--surface-hover);color:var(--text-muted)}.logs-table .log-date{white-space:nowrap;color:var(--text-muted);font-weight:400}.checkbox-group{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;margin-top:.35rem;width:100%}.checkbox-label{display:flex;align-items:flex-start;justify-content:flex-start;gap:.5rem;width:100%;max-width:100%;margin:0;font-size:var(--font-size-min);font-weight:400;color:var(--text);cursor:pointer}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;min-height:0;margin:.1rem 0 0;padding:0;flex:0 0 auto}.field-label{font-size:var(--font-size-min);font-weight:600;color:var(--text-muted)}.toast{position:fixed;top:1rem;right:1rem;z-index:2000;max-width:min(28rem,calc(100vw - 2rem));background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:.65rem .85rem;box-shadow:0 8px 24px #00000059;font-size:var(--font-size-min)}.toast-success{border-color:var(--success)}.toast-error{border-color:var(--danger)}
