.brand-link[data-v-8ad952a3]{display:flex;align-items:center;gap:.7rem;color:inherit}.nav-tabs[data-v-8ad952a3]{display:flex;gap:.25rem}.nav-tab[data-v-8ad952a3]{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .75rem;border-radius:8px;font-size:.85rem;font-weight:600;color:var(--text-muted);transition:background .15s,color .15s}.nav-tab[data-v-8ad952a3]:hover{background:var(--surface-2);color:var(--text)}.nav-tab.active[data-v-8ad952a3]{background:var(--accent-soft);color:var(--accent)}.nav-tab svg[data-v-8ad952a3]{width:15px;height:15px}@media(max-width:640px){.nav-tab span.label[data-v-8ad952a3]{display:none}}:root{--font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--p-brand-300: oklch(.806 .115 276);--p-brand-400: oklch(.715 .158 277);--p-brand-500: oklch(.638 .188 277);--p-brand-600: oklch(.566 .2 278);--p-brand-700: oklch(.492 .182 279);--p-violet-400: oklch(.722 .168 300);--p-violet-500: oklch(.65 .205 300);--p-neutral-0: oklch(1 0 0);--p-neutral-50: oklch(.984 .004 268);--p-neutral-100: oklch(.968 .006 268);--p-neutral-200: oklch(.927 .009 268);--p-neutral-300: oklch(.874 .012 268);--p-neutral-400: oklch(.715 .018 268);--p-neutral-500: oklch(.585 .021 268);--p-neutral-600: oklch(.492 .022 268);--p-neutral-700: oklch(.4 .024 268);--p-neutral-800: oklch(.305 .024 268);--p-neutral-850: oklch(.252 .023 268);--p-neutral-900: oklch(.205 .022 268);--p-neutral-925: oklch(.172 .021 268);--p-neutral-950: oklch(.145 .018 268);--p-green-400: oklch(.76 .15 160);--p-green-600: oklch(.56 .13 158);--p-amber-400: oklch(.82 .14 85);--p-amber-600: oklch(.62 .12 70);--p-red-400: oklch(.7 .19 25);--p-red-500: oklch(.62 .215 25);--scrim: oklch(.145 .018 268 / .62)}:root,[data-theme=dark]{color-scheme:dark;--bg: var(--p-neutral-950);--bg-glow: radial-gradient(1100px 560px at 50% -8%, oklch(.638 .188 277 / .13), transparent 70%);--surface: var(--p-neutral-925);--surface-2: var(--p-neutral-900);--surface-hover: var(--p-neutral-850);--border: oklch(.305 .024 268);--border-strong: oklch(.4 .024 268);--text: var(--p-neutral-100);--text-muted: oklch(.715 .018 268);--text-faint: oklch(.56 .02 268);--accent: var(--p-brand-400);--accent-hover: oklch(.76 .15 277);--accent-2: var(--p-violet-400);--accent-fg: #fff;--accent-grad: linear-gradient(135deg, oklch(.57 .195 277), oklch(.57 .21 300));--accent-soft: oklch(.715 .158 277 / .18);--ring: oklch(.715 .158 277 / .6);--green: var(--p-green-400);--green-soft: oklch(.76 .15 160 / .16);--amber: var(--p-amber-400);--amber-soft: oklch(.82 .14 85 / .15);--red: var(--p-red-400);--red-soft: oklch(.7 .19 25 / .16);--shadow: 0 12px 32px -14px oklch(.1 .02 268 / .7)}[data-theme=light]{color-scheme:light;--bg: var(--p-neutral-100);--bg-glow: radial-gradient(1100px 560px at 50% -8%, oklch(.638 .188 277 / .08), transparent 70%);--surface: var(--p-neutral-0);--surface-2: var(--p-neutral-50);--surface-hover: oklch(.955 .008 268);--border: oklch(.912 .01 268);--border-strong: oklch(.858 .014 268);--text: oklch(.255 .024 268);--text-muted: oklch(.492 .022 268);--text-faint: oklch(.585 .021 268);--accent: var(--p-brand-600);--accent-hover: var(--p-brand-700);--accent-2: var(--p-violet-500);--accent-fg: #fff;--accent-grad: linear-gradient(135deg, oklch(.57 .195 277), oklch(.57 .205 300));--accent-soft: oklch(.566 .2 278 / .12);--ring: oklch(.566 .2 278 / .45);--green: var(--p-green-600);--green-soft: oklch(.7 .165 158 / .16);--amber: var(--p-amber-600);--amber-soft: oklch(.82 .15 82 / .2);--red: var(--p-red-500);--red-soft: oklch(.62 .215 25 / .12);--shadow: 0 12px 30px -16px oklch(.255 .05 268 / .18)}*{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100vh}body{font-family:var(--font);background:var(--bg);background-image:var(--bg-glow);background-repeat:no-repeat;color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.5}a{color:inherit;text-decoration:none}::selection{background:var(--accent-soft);color:var(--text)}:where(a,button,.switch,[tabindex]):focus-visible{outline:2px solid var(--ring);outline-offset:2px;border-radius:8px}.switch input:focus-visible+.slider{outline:2px solid var(--ring);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}.shell{max-width:880px;margin:0 auto;padding:1.5rem 1.25rem 4rem}.shell-wide{max-width:720px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 0 1.75rem;flex-wrap:wrap}.brand{display:flex;align-items:center;gap:.7rem}.brand-logo{width:40px;height:40px;border-radius:11px;background:var(--accent-grad);display:grid;place-items:center;color:#fff;box-shadow:0 6px 18px -6px var(--accent)}.brand-logo svg{width:22px;height:22px}.brand-title{font-size:1.15rem;font-weight:700;letter-spacing:-.02em}.brand-sub{font-size:.78rem;color:var(--text-muted);margin-top:-2px}.topbar-actions{display:flex;align-items:center;gap:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.6rem 1rem;font-family:var(--font);font-size:.9rem;font-weight:600;border:1px solid transparent;border-radius:10px;cursor:pointer;transition:transform .08s ease,background .15s ease,border-color .15s ease,opacity .15s ease;white-space:nowrap;color:var(--text);background:transparent}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:16px;height:16px}.btn-primary{background:var(--accent-grad);color:var(--accent-fg);border:none;box-shadow:0 8px 20px -10px var(--accent)}.btn-primary:hover:not(:disabled){filter:brightness(1.06) saturate(1.05)}.btn-ghost{background:var(--surface-2);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-strong)}.btn-danger{color:var(--red);background:var(--red-soft)}.btn-danger:hover:not(:disabled){background:color-mix(in oklch,var(--red) 24%,transparent)}.btn-icon{padding:.5rem;width:38px;height:38px;border-radius:10px}.icon-btn{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:9px;border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .15s ease,color .15s ease}.icon-btn:hover{background:var(--surface-hover);color:var(--text)}.icon-btn.danger:hover{background:var(--red-soft);color:var(--red)}.icon-btn svg{width:17px;height:17px}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}.card-pad{padding:1.35rem}.section-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin:2rem 0 1rem}.section-head h2{font-size:1.05rem;font-weight:700;margin:0;letter-spacing:-.01em}.muted{color:var(--text-muted)}.faint{color:var(--text-faint)}.iface{display:flex;flex-wrap:wrap;align-items:center;gap:1.25rem 2rem}.iface-main{display:flex;align-items:center;gap:.85rem;min-width:0}.iface-name{font-size:1.05rem;font-weight:700}.iface-stats{display:flex;flex-wrap:wrap;gap:1.1rem 2rem;margin-left:auto}.stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint)}.stat-value{font-size:.95rem;font-weight:600;margin-top:1px}.stat-value.mono{font-family:var(--mono);font-size:.82rem}.copyable{cursor:pointer;display:inline-flex;align-items:center;gap:.35rem}.copyable:hover{color:var(--accent)}.copyable svg{width:13px;height:13px;opacity:.6}.dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.dot.on{background:var(--green);box-shadow:0 0 0 0 var(--green);animation:pulse 2s infinite}.dot.off{background:var(--text-faint)}@keyframes pulse{0%{box-shadow:0 0 color-mix(in oklch,var(--green) 55%,transparent)}70%{box-shadow:0 0 0 7px transparent}to{box-shadow:0 0 0 0 transparent}}.pill{display:inline-flex;align-items:center;gap:.35rem;padding:.18rem .6rem;border-radius:999px;font-size:.72rem;font-weight:600}.pill.on{background:var(--green-soft);color:var(--green)}.pill.off{background:var(--surface-2);color:var(--text-muted)}.pill.ext{background:var(--accent-soft);color:var(--accent-2)}.toolbar{display:flex;align-items:center;gap:.6rem;flex:1;justify-content:flex-end}.search{position:relative;flex:1;max-width:280px}.search svg{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--text-faint)}.search input{padding-left:2rem;margin:0}.peers{display:flex;flex-direction:column;gap:.7rem}.peer{display:flex;align-items:center;gap:.9rem;padding:.85rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:14px;transition:border-color .15s ease,transform .1s ease,background .15s ease}.peer:hover{border-color:var(--border-strong);background:var(--surface-hover)}.avatar{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:.95rem;flex-shrink:0;position:relative}.avatar .dot{position:absolute;right:-2px;bottom:-2px;border:2px solid var(--surface);width:12px;height:12px}.peer-info{min-width:0;flex:1}.peer-name{display:flex;align-items:center;gap:.5rem;font-weight:600}.peer-name .truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.peer-meta{display:flex;gap:.9rem;font-size:.8rem;color:var(--text-muted);margin-top:1px}.peer-meta .mono{font-family:var(--mono);font-size:.76rem}.peer-transfer{display:flex;gap:.9rem;font-size:.78rem;color:var(--text-muted)}.xfer{display:flex;align-items:center;gap:.35rem}.xfer-col{display:flex;flex-direction:column;gap:.1rem;line-height:1.2}.xfer-total{font-weight:600;color:var(--text);font-size:.8rem}.xfer-rate{font-size:.7rem;color:var(--text-faint)}.xfer svg{width:13px;height:13px;flex-shrink:0;margin-top:.1rem}.xfer.up svg{color:var(--accent-2)}.xfer.down svg{color:var(--green)}.peer-actions{display:flex;align-items:center;gap:.15rem}.switch{position:relative;display:inline-block;width:38px;height:22px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border-strong);border-radius:999px;transition:background .2s ease;cursor:pointer}.slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s ease}.switch input:checked+.slider{background:var(--green)}.switch input:checked+.slider:before{transform:translate(16px)}.empty{text-align:center;padding:3rem 1rem}.empty-icon{width:56px;height:56px;margin:0 auto 1rem;border-radius:16px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center}.empty-icon svg{width:26px;height:26px}.empty h3{margin:0 0 .35rem;font-size:1rem}.field{margin-bottom:1rem}.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.4rem;color:var(--text-muted)}input[type=text],input[type=password],input[type=number]{width:100%;padding:.7rem .85rem;font-family:var(--font);font-size:.95rem;color:var(--text);background:var(--surface-2);border:1px solid var(--border);border-radius:10px;transition:border-color .15s ease,box-shadow .15s ease;outline:none}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}input:disabled{opacity:.65;cursor:not-allowed}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.page-head h1{margin:0 0 .25rem;font-size:1.35rem;letter-spacing:-.02em}.page-head .muted{margin:0;font-size:.9rem}.settings-section h2{display:flex;align-items:center;gap:.5rem;margin:0 0 .35rem;font-size:1rem;font-weight:700}.settings-section h2 svg{width:18px;height:18px;color:var(--accent)}.section-desc{margin:0 0 1.1rem;font-size:.88rem;color:var(--text-muted)}.section-desc code{font-family:var(--mono);font-size:.82rem;background:var(--surface-2);padding:.1rem .35rem;border-radius:4px}.settings-form{display:flex;flex-direction:column;gap:1rem}.settings-section{margin:0}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 1.25rem}.field-grid .span-2{grid-column:1 / -1}.field-grid .field{margin-bottom:.85rem}.field-hint{font-size:.78rem;color:var(--text-faint);margin:.35rem 0 0}.field-hint code{font-family:var(--mono);font-size:.76rem}.field-meta{display:flex;gap:.35rem;margin-top:.35rem;flex-wrap:wrap}.pill.locked{background:var(--amber-soft);color:var(--amber)}.pill.src{background:var(--surface-2);color:var(--text-faint);font-size:.68rem}.input-row{display:flex;gap:.35rem}.input-row input{flex:1}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:var(--text);cursor:pointer}.checkbox-label input{width:auto;accent-color:var(--accent)}.callout{display:flex;align-items:flex-start;gap:.6rem;padding:.75rem .9rem;border-radius:10px;font-size:.85rem;margin-bottom:1rem}.callout svg{width:18px;height:18px;flex-shrink:0;margin-top:1px}.callout.warn{background:var(--amber-soft);border:1px solid color-mix(in oklch,var(--amber) 38%,transparent);color:var(--amber)}.test-panel{margin-bottom:1rem}.test-panel.test-ok{border-color:color-mix(in oklch,var(--green) 38%,transparent)}.test-panel.test-fail{border-color:color-mix(in oklch,var(--red) 38%,transparent)}.test-summary{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.test-summary svg{width:20px;height:20px}.test-ok .test-summary svg{color:var(--green)}.test-fail .test-summary svg{color:var(--red)}.test-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.test-steps li{display:flex;gap:.65rem;align-items:flex-start;font-size:.88rem}.step-icon{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}.step-icon svg{width:13px;height:13px}.step-icon.ok{background:var(--green-soft);color:var(--green)}.step-icon.warn{background:var(--amber-soft);color:var(--amber)}.step-icon.fail{background:var(--red-soft);color:var(--red)}.step-label{font-weight:600}.step-detail{color:var(--text-muted);font-size:.82rem;margin-top:1px}.step-warn{color:var(--amber);font-size:.8rem;margin-top:.25rem}.form-actions{display:flex;justify-content:flex-end;gap:.6rem;padding:1rem 0 0}.form-actions.sticky{position:sticky;bottom:0;background:linear-gradient(transparent,var(--bg) 20%);padding:1.25rem 0 .5rem;margin-top:.5rem}@media(max-width:560px){.field-grid{grid-template-columns:1fr}.field-grid .span-2{grid-column:auto}}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--scrim);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:100;padding:1rem}.modal{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:1.5rem;animation:modalIn .18s ease}.modal.qr{text-align:center}@keyframes modalIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}.modal h2{margin:0 0 .25rem;font-size:1.15rem}.modal-actions{display:flex;gap:.6rem;margin-top:1.25rem}.modal-actions .btn{flex:1}.qr-frame{background:#fff;border-radius:14px;padding:1rem;width:fit-content;margin:1.25rem auto;box-shadow:var(--shadow)}.qr-frame img{display:block;width:220px;height:220px}.share-modal .share-warn{margin:.5rem 0 0;font-size:.88rem;color:var(--warning)}.share-kind{display:flex;flex-direction:column;gap:.55rem;margin-top:1rem}.share-option{display:flex;gap:.65rem;align-items:flex-start;padding:.75rem .85rem;border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:border-color .15s,background .15s}.share-option.active{border-color:var(--accent);background:color-mix(in oklch,var(--accent) 10%,transparent)}.share-option input{margin-top:.2rem;accent-color:var(--accent)}.share-option strong{display:block;font-size:.92rem}.share-option .muted{display:block;font-size:.82rem;margin-top:.15rem}.share-result,.share-active{margin-top:1rem}.share-url-row{display:flex;gap:.45rem;margin-top:.35rem}.share-url-row input{flex:1;min-width:0;font-size:.82rem}.share-active-row{display:flex;align-items:center;gap:.5rem;margin-top:.45rem}.share-active-row .truncate{flex:1;min-width:0;font-size:.78rem}.share-page{max-width:420px;text-align:center}.share-page h1{margin:.5rem 0 0;font-size:1.35rem}.share-error{text-align:center}.share-error svg{width:2rem;height:2rem;color:var(--danger);margin-bottom:.5rem}.share-note{font-size:.88rem;margin:1rem 0 0}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:1.5rem}.auth-card{width:100%;max-width:380px}.auth-logo{width:56px;height:56px;border-radius:16px;background:var(--accent-grad);display:grid;place-items:center;color:#fff;margin:0 auto 1.1rem;box-shadow:0 10px 26px -10px var(--accent)}.auth-logo svg{width:30px;height:30px}.auth-card h1{text-align:center;margin:0 0 .3rem;font-size:1.4rem}.auth-card .muted{text-align:center;margin-bottom:1.5rem}.toasts{position:fixed;bottom:1.25rem;right:1.25rem;display:flex;flex-direction:column;gap:.6rem;z-index:200}.toast{display:flex;align-items:center;gap:.6rem;padding:.8rem 1rem;background:var(--surface);border:1px solid var(--border);border-left-width:3px;border-radius:11px;box-shadow:var(--shadow);font-size:.88rem;min-width:240px;animation:toastIn .2s ease}.toast.ok{border-left-color:var(--green)}.toast.err{border-left-color:var(--red)}.toast svg{width:17px;height:17px;flex-shrink:0}.toast.ok svg{color:var(--green)}.toast.err svg{color:var(--red)}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}.error-text{color:var(--red);font-size:.85rem;margin:.5rem 0 0}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:560px){.iface-stats{margin-left:0;width:100%}.peer-transfer{display:none}.section-head{flex-direction:column;align-items:stretch}.search{max-width:none}}
