:root{--color-primary: #702f8a;--color-primary-strong: #5c2772;--color-primary-soft: rgba(112, 47, 138, .12);--color-accent: #c743d8;--gradient-brand: linear-gradient(135deg, #702f8a 0%, #a23bb8 55%, #c743d8 100%);--color-bg: #f5f3f9;--color-surface: #ffffff;--color-surface-raised: #ffffff;--color-border: #e4def0;--color-text: #221833;--color-text-muted: #6f6584;--color-danger: #d3294a;--color-danger-soft: rgba(211, 41, 74, .12);--color-success: #14803c;--color-success-soft: rgba(20, 128, 60, .14);--color-warning: #92600a;--color-warning-soft: rgba(217, 150, 31, .16);--sidebar-bg: #1c1129;--sidebar-text: #cfc4e0;--sidebar-active-bg: rgba(199, 67, 216, .18);--sidebar-active-text: #ffffff;--shadow-card: 0 1px 3px rgba(28, 17, 41, .08), 0 8px 24px rgba(28, 17, 41, .06);--shadow-modal: 0 24px 64px rgba(28, 17, 41, .32);--radius: 12px}[data-theme=dark]{--color-primary: #b066d6;--color-primary-strong: #c685e2;--color-primary-soft: rgba(176, 102, 214, .16);--color-bg: #120c1d;--color-surface: #1c1429;--color-surface-raised: #251b35;--color-border: #342947;--color-text: #ece8f5;--color-text-muted: #a297b8;--color-danger: #ff6b8a;--color-danger-soft: rgba(255, 107, 138, .14);--color-success: #4ade80;--color-success-soft: rgba(74, 222, 128, .14);--color-warning: #fbbf24;--color-warning-soft: rgba(251, 191, 36, .14);--sidebar-bg: #160e22;--sidebar-text: #b3a6c9;--shadow-card: 0 1px 3px rgba(0, 0, 0, .4), 0 8px 24px rgba(0, 0, 0, .3);--shadow-modal: 0 24px 64px rgba(0, 0, 0, .6)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:Segoe UI,system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;background:var(--color-bg);color:var(--color-text);font-size:15px;line-height:1.5;transition:background-color .2s ease,color .2s ease}h1{font-size:1.6rem;font-weight:650}h2{font-size:1.25rem;font-weight:650}h3{font-size:1.05rem;font-weight:600}.layout{display:flex;height:100vh;height:100dvh;overflow:hidden}.sidebar{width:248px;flex-shrink:0;display:flex;flex-direction:column;background:var(--sidebar-bg);color:var(--sidebar-text);padding:20px 14px;gap:24px}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:4px 8px;color:#fff;font-weight:700;font-size:1.02rem;letter-spacing:.01em}.brand-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;background:var(--gradient-brand);color:#fff;flex-shrink:0}.brand-icon-lg{width:48px;height:48px;border-radius:14px}.brand-go4{background:var(--gradient-brand);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:800;filter:brightness(1.6)}.brand-labs{font-weight:400;opacity:.85}.sidebar-nav{display:flex;flex-direction:column;gap:4px;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;color:var(--sidebar-text);text-decoration:none;font-weight:500;transition:background-color .15s ease,color .15s ease}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text)}.nav-button{width:100%;border:none;background:none;font:inherit;cursor:pointer}.sidebar-footer{display:flex;flex-direction:column;gap:8px;border-top:1px solid rgba(255,255,255,.08);padding-top:14px}.sidebar-version{padding:2px 12px 0;font-size:.76rem;color:#ffffff61;letter-spacing:.02em}.user-avatar{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--gradient-brand);color:#fff;font-weight:650;font-size:.85rem;flex-shrink:0}.user-meta{display:flex;flex-direction:column;min-width:0}.user-name{color:var(--color-text);font-weight:600;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.76rem;color:var(--color-text-muted)}.main{flex:1;display:flex;flex-direction:column;min-width:0;overflow-y:auto}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:10px 28px;border-bottom:1px solid var(--color-border);background:color-mix(in srgb,var(--color-surface) 82%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);position:sticky;top:0;z-index:40}.topbar-title{font-size:1.05rem}.topbar-actions{display:flex;align-items:center;gap:12px}.user-menu{position:relative}.user-button{display:flex;align-items:center;gap:10px;padding:4px 12px 4px 5px;border:none;border-radius:999px;background:transparent;color:var(--color-text-muted);font:inherit;cursor:pointer;transition:background-color .15s ease}.user-button:hover{background:var(--color-primary-soft)}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:49}.menu-popover{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-modal);padding:6px;z-index:50}.menu-identity{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border-bottom:1px solid var(--color-border);margin-bottom:6px}.menu-email{font-size:.8rem;color:var(--color-text-muted)}.menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:none;border-radius:8px;background:none;color:var(--color-text);font:inherit;font-weight:500;cursor:pointer;transition:background-color .15s ease}.menu-item:hover{background:var(--color-primary-soft);color:var(--color-primary)}.menu-item.is-active{background:var(--color-primary-soft);color:var(--color-primary);font-weight:650}.flag{display:block;border-radius:3px;box-shadow:0 0 0 1px var(--color-border)}.lang-button{padding:8px 10px}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--color-border);border-radius:9px;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:color .15s ease,border-color .15s ease,background-color .15s ease}.icon-button:hover{color:var(--color-primary);border-color:var(--color-primary)}.icon-button-danger:hover{color:var(--color-danger);border-color:var(--color-danger)}.content{flex:1;padding:28px;display:flex;flex-direction:column}.content>.page{width:100%}.splash{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--color-text-muted)}.page{display:flex;flex-direction:column;gap:22px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.page-subtitle{color:var(--color-text-muted);margin-top:4px}.muted{color:var(--color-text-muted)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.card-grid-wide{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.about-list{display:flex;flex-direction:column;gap:10px;flex:1}.about-list>div{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid var(--color-border);padding-bottom:10px}.about-list dt{color:var(--color-text-muted);font-size:.88rem}.about-list dd{font-weight:600;font-size:.88rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:20px;display:flex;flex-direction:column;gap:12px}.card p{color:var(--color-text-muted);flex:1}.card .btn{align-self:flex-start}.card-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.table-card{padding:8px 0;overflow-x:auto}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:9px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font:inherit;font-weight:600;font-size:.9rem;text-decoration:none;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,opacity .15s ease}.btn:hover{border-color:var(--color-primary)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-strong);border-color:var(--color-primary-strong)}.btn-danger{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-block{width:100%;justify-content:center}.btn-link{border:none;background:none;color:var(--color-text-muted);font-weight:500;margin-top:6px}.btn-link:hover{color:var(--color-primary)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;min-width:0}.field>span{font-size:.85rem;font-weight:600;color:var(--color-text-muted)}.field input:not([type=checkbox]):not([type=radio]):not([type=file]),.field select{width:100%;min-width:0;padding:10px 12px;border-radius:9px;border:1px solid var(--color-border);background:var(--color-surface-raised);color:var(--color-text);font:inherit;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.field input:focus,.field select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft)}.field-checkbox{flex-direction:row;align-items:center;gap:10px}.field-checkbox input{width:16px;height:16px;accent-color:var(--color-primary)}.field-checkbox span{font-size:.9rem;color:var(--color-text);font-weight:500}.form-error{background:var(--color-danger-soft);color:var(--color-danger);border-radius:9px;padding:10px 14px;font-size:.88rem;margin-bottom:14px}.form-success{background:var(--color-success-soft);color:var(--color-success);border-radius:9px;padding:10px 14px;font-size:.88rem;margin-bottom:14px}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:12px 18px;border-bottom:1px solid var(--color-border);white-space:nowrap}.table th{font-size:.78rem;font-weight:650;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--color-primary-soft)}.table-card .muted{padding:16px 18px}.table-actions{text-align:right}.table-actions .icon-button+.icon-button{margin-left:8px}.cell-user{display:flex;align-items:center;gap:10px;font-weight:600}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:.78rem;font-weight:650}.badge-admin{background:var(--color-primary-soft);color:var(--color-primary)}.badge-trainer{background:var(--color-warning-soft);color:var(--color-warning)}.badge-trainee,.badge-active{background:var(--color-success-soft);color:var(--color-success)}.badge-inactive{background:var(--color-danger-soft);color:var(--color-danger)}.badge-soon{background:var(--color-primary-soft);color:var(--color-primary)}.card-link{text-decoration:none;color:inherit;transition:border-color .15s ease,transform .15s ease}.card-link:hover{border-color:var(--color-primary);transform:translateY(-2px)}.card-description{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.badge-row{display:flex;gap:6px;flex-wrap:wrap}.blueprint-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}.tag-row{display:flex;gap:6px;flex-wrap:wrap}.tag{padding:2px 9px;border-radius:999px;border:1px solid var(--color-border);font-size:.76rem;color:var(--color-text-muted)}.blueprint-resources{font-size:.8rem;color:var(--color-text-muted)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}.modal.modal-wide{max-width:860px}.modal.modal-xl{max-width:1080px}.field-hint{font-size:.8rem;color:var(--color-text-muted);margin:-6px 0 14px}.field textarea{padding:10px 12px;border-radius:9px;border:1px solid var(--color-border);background:var(--color-surface-raised);color:var(--color-text);font:inherit;outline:none;resize:vertical;transition:border-color .15s ease,box-shadow .15s ease}.field textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft)}.config-textarea{font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:.82rem}.cell-strong{font-weight:600}.cell-mono{font-family:Consolas,monospace;font-size:.84rem}.editor-breadcrumb{font-size:.85rem;color:var(--color-text-muted);margin-bottom:2px}.editor-breadcrumb a{color:var(--color-primary);text-decoration:none}.editor-header-actions{display:flex;align-items:center;gap:8px}.version-select{padding:8px 10px;border-radius:9px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font:inherit;font-size:.88rem}.editor-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.toolbar-spacer{flex:1}.toolbar-hint{display:inline-flex;align-items:center;gap:8px;font-size:.84rem;color:var(--color-text-muted)}.menu-popover-left{left:0;right:auto;max-height:320px;overflow-y:auto}.node-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;background:var(--color-primary)}.node-dot.node-host{background:#2e9e5b}.node-dot.node-cloud{background:#4a8fd4}.node-dot.node-firewall{background:#d4604a}.node-dot.node-router{background:#c79a3a}.editor-page{flex:1;min-height:0;gap:14px}.editor-canvas-wrap{position:relative;flex:1;min-width:0;min-height:360px;overflow:auto;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface)}.editor-canvas{display:block;touch-action:none;cursor:grab}.editor-canvas:active{cursor:grabbing}.grid-dot{fill:var(--color-border)}.canvas-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);pointer-events:none}.topo-node{cursor:grab}.topo-node .node-body{fill:var(--color-surface-raised);stroke:var(--color-primary);stroke-width:2}.topo-node.node-host .node-body{stroke:#2e9e5b}.topo-node.node-cloud .node-body{stroke:#4a8fd4}.topo-node.node-firewall .node-body{stroke:#d4604a}.topo-node.node-router .node-body{stroke:#c79a3a}.topo-node .node-glyph{fill:var(--color-text);font-size:13px;font-weight:700;text-anchor:middle;pointer-events:none}.topo-node .node-label{fill:var(--color-text);font-size:12px;font-weight:600;text-anchor:middle;pointer-events:none}.topo-node.is-selected .node-body{stroke-width:3.5;filter:drop-shadow(0 0 6px var(--color-primary))}.topo-node.is-dimmed{opacity:.42}.topo-node.is-dimmed .node-body{stroke-dasharray:5 4}.topo-link{cursor:pointer}.topo-link .link-hit{stroke:transparent;stroke-width:14}.topo-link .link-line{stroke:var(--color-text-muted);stroke-width:2}.topo-link.is-selected .link-line{stroke:var(--color-primary);stroke-width:3}.topo-link.is-dimmed .link-line{opacity:.4;stroke-dasharray:6 5}.topo-link .link-label{fill:var(--color-text-muted);font-size:10.5px;text-anchor:middle;paint-order:stroke;stroke:var(--color-surface);stroke-width:3}.topo-link.is-dimmed .link-label{opacity:.5}.iface-picker{position:absolute;z-index:30;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-modal);padding:10px;max-width:260px}.iface-picker-title{font-size:.8rem;font-weight:650;margin-bottom:8px}.iface-picker-list{display:flex;flex-wrap:wrap;gap:6px;max-height:180px;overflow-y:auto}.iface-option{padding:4px 10px;border:1px solid var(--color-border);border-radius:7px;background:var(--color-surface-raised);color:var(--color-text);font:inherit;font-size:.8rem;cursor:pointer}.iface-option:hover{border-color:var(--color-primary);color:var(--color-primary)}.panel-value{font-size:.9rem;font-weight:600;padding:10px 0}.ctx-menu{position:absolute;z-index:40;min-width:200px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-modal);padding:6px}.menu-item-danger{color:var(--color-danger)}.menu-item-danger:hover{background:var(--color-danger-soft);color:var(--color-danger)}.card-cover{margin:-20px -20px 0;height:130px;overflow:hidden;border-radius:var(--radius) var(--radius) 0 0}.card-cover img{width:100%;height:100%;object-fit:cover;display:block}.card-title-row{display:flex;align-items:center;gap:10px;min-width:0}.card-logo{width:30px;height:30px;object-fit:contain;border-radius:7px;flex-shrink:0}.artwork-row{display:flex;align-items:center;gap:12px}.artwork-preview{border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface-raised)}.artwork-logo-preview{width:44px;height:44px;object-fit:contain}.artwork-cover-preview{width:88px;height:44px;object-fit:cover}.image-cell{display:flex;align-items:center;gap:8px}.version-suggestions{display:flex;gap:8px;align-items:center;margin-bottom:14px}.version-suggestions input{width:90px;padding:9px 12px;border-radius:9px;border:1px solid var(--color-border);background:var(--color-surface-raised);color:var(--color-text);font:inherit}.editor-footnote{font-size:.8rem;color:var(--color-text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c06148c;display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-modal);padding:24px;width:100%;max-width:520px;max-height:calc(100vh - 40px);overflow-y:auto}.modal h2{margin-bottom:18px}.modal p{color:var(--color-text-muted);margin-bottom:18px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(60% 80% at 80% 10%,rgba(199,67,216,.28) 0%,transparent 60%),radial-gradient(50% 70% at 15% 90%,rgba(112,47,138,.35) 0%,transparent 60%),#150d20}.login-card{width:100%;max-width:400px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;box-shadow:var(--shadow-modal);padding:32px}.login-brand{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;margin-bottom:26px}.login-brand h1{font-size:1.35rem}.login-brand p{color:var(--color-text-muted);font-size:.88rem}.login-card h2{margin-bottom:4px}.login-subtitle{color:var(--color-text-muted);font-size:.9rem;margin-bottom:20px}@media (max-width: 760px){.layout{flex-direction:column}.sidebar{width:100%;flex-direction:row;align-items:center;gap:12px;padding:10px 14px;flex-shrink:0}.sidebar-nav{flex-direction:row;align-items:center}.sidebar-footer{border-top:none;padding-top:0;flex-direction:row;align-items:center;margin-left:auto}.sidebar-version,.brand-name,.topbar-title,.user-meta{display:none}.nav-item{padding:8px 10px}.content{padding:18px}}.settings-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:24px;align-items:start}.settings-nav{display:flex;flex-direction:column;gap:4px;padding:8px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface)}.settings-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--color-text-muted);text-decoration:none;font-weight:500;transition:background-color .15s ease,color .15s ease}.settings-nav-item:hover{color:var(--color-text);background:var(--color-surface-raised)}.settings-nav-item.active{color:var(--color-primary);background:var(--color-surface-raised)}.settings-content{display:flex;flex-direction:column;gap:20px;min-width:0}@media (max-width: 860px){.settings-layout{grid-template-columns:1fr}.settings-nav{flex-direction:row;overflow-x:auto}}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0 16px}.form-actions{display:flex;gap:10px;margin-top:4px}.server-error{max-width:260px;font-size:12px;margin-top:4px}.tenant-button{gap:8px;padding:6px 12px}.tenant-name{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;color:var(--color-text);font-size:.88rem}.tenant-item-name{flex:1;text-align:left;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.window-list{margin:10px 0 12px;padding-left:18px;display:flex;flex-direction:column;gap:4px}.window-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.window-row input{flex:1}.window-row input[type=time]{flex:0 1 130px}.window-row input[type=date]{flex:0 1 170px}.window-sep{color:var(--color-text-muted)}.member-add-form{margin-top:14px;padding-top:14px;border-top:1px solid var(--color-border)}.zone-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:6px;margin-top:6px}.zone-check{display:flex;align-items:center;gap:8px;font-size:.9rem}.zone-check input{width:16px;height:16px;accent-color:var(--color-primary)}.server-chips{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}.invite-link{display:flex;flex-direction:column;gap:4px;word-break:break-all}.session-access{display:flex;flex-direction:column;gap:8px;margin-top:8px}.session-creds code{font-size:.85rem}.link-button{border:none;background:none;color:var(--color-primary);font:inherit;cursor:pointer;padding:0;text-decoration:underline}.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 28px}.modal-col{min-width:0}.form-section{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--color-border)}.modal-col+.modal-col .form-section{margin-top:0}@media (max-width: 760px){.modal-grid{grid-template-columns:1fr}}
