@font-face{font-family:Chelsea Market;src:url(./ChelseaMarket-Regular-Dg5P9Kdj.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{--bg: #ffffff;--bg-secondary: #f7f7f7;--bg-card: #eeeeee;--text: #1d1d1f;--text-muted: #5c5c60;--text-dim: #6e6e74;--border: #e5e5e7;--accent: #2383e2;--accent-hover: #1a6fc7;--accent-bg: rgba(35, 131, 226, .08);--accent-glass: rgba(35, 131, 226, .04);--green: #0f9d58;--green-bg: rgba(15, 157, 88, .1);--yellow: #e8a838;--yellow-bg: rgba(232, 168, 56, .1);--red: #e03e3e;--red-bg: rgba(224, 62, 62, .1);--radius: 6px;--radius-sm: 4px;--shadow: 0 1px 4px rgba(0,0,0,.06);--glow: none;--font-mono: ui-monospace, "SF Mono", "Cascadia Code", Consolas, monospace}[data-theme=dark]{--bg: #1a1a1e;--bg-secondary: #222226;--bg-card: #2c2c30;--text: #eaeaec;--text-muted: #9a9aa0;--text-dim: #7a7a80;--border: #3a3a3e;--accent: #5b9cf5;--accent-hover: #7ab0ff;--accent-bg: rgba(91, 156, 245, .1);--accent-glass: rgba(91, 156, 245, .05);--green: #34d080;--green-bg: rgba(52, 208, 128, .1);--yellow: #f0c040;--yellow-bg: rgba(240, 192, 64, .1);--red: #f06060;--red-bg: rgba(240, 96, 96, .1);--shadow: 0 1px 4px rgba(0,0,0,.2);--glow: none}*{margin:0;padding:0;box-sizing:border-box}body{overflow:hidden;font-family:Chelsea Market,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans TC,sans-serif;font-size:14px;line-height:1.5;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}#root{display:flex;height:100vh;width:100vw}button{cursor:pointer;border:none;background:none;color:inherit;font:inherit}input{font:inherit;color:inherit}:root{--tl-color: #6d5df4;--tl-rounded: 9999px;--tl-bullet-size: 28px;--tl-line-width: 2px;--tl-offset: calc(var(--tl-bullet-size) / 2 + var(--tl-line-width) + 6px);--warning: #f5a623;--warning-bg: rgba(255, 193, 7, .15)}.sidebar{width:300px;min-width:300px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:20px 16px 16px;border-bottom:1px solid var(--border)}.logo{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.5px}.logo span{color:var(--accent)}.subtitle{font-size:12px;color:var(--text-dim);margin-top:4px}.sidebar-id-panel{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.sid-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);margin-bottom:6px}.sid-id-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.sid-icon{font-size:18px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:6px}.sid-id{font-size:18px;font-weight:700;font-family:var(--font-mono);letter-spacing:2px;color:var(--accent)}.sid-device-name{margin-bottom:8px}.sid-device-label{font-size:12px;color:var(--text-dim);display:inline-flex;align-items:center;gap:4px}.sid-btn-icon{background:none;border:none;padding:2px;cursor:pointer;color:var(--text-muted);display:inline-flex;align-items:center;opacity:.5;transition:opacity .15s}.sid-btn-icon:hover{opacity:1}.sid-device-input{font-size:12px;padding:4px 8px;border-radius:6px;border:1px solid var(--accent);background:var(--bg-card);color:var(--text);outline:none;width:100%;max-width:180px;font-family:inherit}.sid-actions{display:flex;gap:4px;margin-bottom:4px}.sid-btn{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s,background .15s;font-family:inherit}.sid-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.sid-divider{height:1px;background:var(--border);margin:10px 0}.sid-connect-form{display:flex;gap:6px}.sid-input{flex:1;padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;font-family:var(--font-mono);letter-spacing:2px;outline:none;transition:border-color .15s;min-width:0}.sid-input:focus{border-color:var(--accent)}.sid-input:disabled{opacity:.5}.sid-go-btn{padding:6px 14px;border-radius:var(--radius-sm);border:none;background:var(--accent);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s;font-family:inherit;white-space:nowrap}.sid-go-btn:disabled{opacity:.35;cursor:not-allowed}.sid-go-btn:hover:not(:disabled){opacity:.85}.sid-msg{font-size:11px;margin-top:6px;padding:3px 8px;border-radius:var(--radius-sm)}.sid-msg-ok{color:var(--green);background:var(--green-bg)}.sid-msg-err{color:var(--red);background:var(--red-bg)}.sid-connected-row{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:12px;color:var(--accent);font-weight:600;font-family:var(--font-mono)}.sid-peer-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sid-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:10px;line-height:1;text-transform:uppercase;letter-spacing:.5px}.sid-badge-pending{background:var(--yellow-bg);color:var(--yellow)}.sid-badge-ok{background:var(--green-bg);color:var(--green)}.sid-badge-err{background:var(--red-bg);color:var(--red)}.sid-share-btn{margin-left:auto}.sid-share-btn:hover{border-color:var(--green);color:var(--green);background:var(--green-bg)}.sid-connected-panel{display:flex;align-items:center;gap:8px;margin-top:6px;padding:6px 8px;background:var(--green-bg);border-radius:var(--radius-sm)}.sid-disconnect-btn{margin-left:auto;border-color:var(--red);color:var(--red);font-size:10px;padding:2px 8px}.sid-disconnect-btn:hover{background:var(--red-bg)}.sid-online-list{display:flex;flex-direction:column;gap:2px;margin-top:4px}.sid-online-row{display:flex;align-items:center;gap:6px;font-size:12px;padding:4px 6px;border-radius:var(--radius-sm);transition:background .1s;cursor:default}.sid-online-row:hover{background:var(--bg-card)}.sid-online-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0}.sid-online-name{font-weight:600;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sid-online-id{font-family:var(--font-mono);font-size:10px;color:var(--text-dim)}.device-list{flex:1;overflow-y:auto;padding:8px 0}.list-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);padding:8px 16px}.device-card{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .15s}.device-card:hover{background:var(--bg-card)}.device-card.selected{background:var(--accent-bg);border-left:3px solid var(--accent)}.device-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.device-info{flex:1;min-width:0}.device-name{font-weight:500;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-status{font-size:12px;color:var(--text-dim);display:flex;align-items:center;gap:6px;margin-top:2px}.dot{width:7px;height:7px;border-radius:50%;background:var(--text-dim)}.dot.online{background:var(--green)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.main-header{padding:16px 20px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px}.main-header h2{font-size:16px;font-weight:600;color:var(--text)}.peer-hint{font-size:12px;color:var(--accent);background:var(--accent-bg);padding:2px 10px;border-radius:20px}.drop-zone{margin:12px 20px;border:2px dashed var(--border);border-radius:var(--radius);padding:16px;text-align:center;transition:all .2s}.drop-zone.dragging{border-color:var(--accent);background:var(--accent-bg)}.drop-zone.no-peer{opacity:.4}.drop-hint{color:var(--text-dim);font-size:13px}.drop-hint.active{color:var(--accent);font-weight:500}.main-upper{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;min-height:200px}.main-upper-center{display:flex;flex-direction:column;align-items:center;max-width:380px;width:100%}.dual-timeline{flex:1;display:flex;overflow:hidden}.tl-pane{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.tl-pane-header{display:flex;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);flex-shrink:0}.tl-pane-header svg{color:var(--accent)}.tl-pane-count{margin-left:auto;font-size:11px;background:var(--bg-card);padding:1px 8px;border-radius:10px;color:var(--text-dim)}.tl-clear-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:12px;padding:0 4px;margin-left:4px;opacity:.4;transition:opacity .15s}.tl-clear-btn:hover{opacity:1;color:var(--red)}.tl-pane-body{flex:1;overflow-y:auto;padding:12px 16px 40px}.tl-divider{width:1px;background:var(--border);flex-shrink:0}.tl-item{position:relative;text-align:left;padding-left:var(--tl-offset);padding-bottom:16px}.tl-item:not(:last-of-type):before{content:"";position:absolute;pointer-events:none;top:calc(var(--tl-bullet-size) + 4px);left:calc(var(--tl-bullet-size) / 2 + var(--tl-line-width) / 2 - var(--tl-line-width) / 2);bottom:0;width:var(--tl-line-width);display:block;border-inline-start:var(--tl-line-width) var(--tli-border-style, solid) var(--border);transform:translate(-50%)}.tl-item[data-line-active]:before{border-color:var(--tl-color)}.tl-bullet{position:absolute;top:0;left:0;width:var(--tl-bullet-size);height:var(--tl-bullet-size);border-radius:var(--tl-rounded);background:var(--bg-secondary);border:var(--tl-line-width) solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1;transition:border-color .3s}.tl-active .tl-bullet{border-color:var(--tl-color)}.tl-done .tl-bullet{border-color:var(--green)}.tl-bullet-done{background:var(--green);border-color:var(--green)}.tl-icon{font-size:14px;line-height:1}.tl-body{position:relative}.tl-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.tl-title{font-size:13px;font-weight:600;font-family:var(--font-mono);color:#38bdf8;line-height:1.2}.tl-peer{font-size:12px;color:var(--text-dim);font-family:var(--font-mono)}.tl-file-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.tl-filename{font-size:13px;color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-size{font-size:11px;color:var(--text-dim);font-family:var(--font-mono);flex-shrink:0}.tl-content{font-size:13px;color:var(--text-muted);transition:max-height .2s;overflow:hidden}.tl-clamp{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2}.tl-progress{display:flex;align-items:center;gap:8px;margin-bottom:4px}.tl-progress-bar{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.tl-progress-fill{height:100%;background:var(--tl-color);border-radius:2px;transition:width .3s ease}.tl-speed{font-size:11px;color:var(--text-dim);font-family:var(--font-mono);flex-shrink:0}.tl-status{margin-bottom:2px}.tl-badge{font-size:12px;color:var(--text-dim);font-family:var(--font-mono)}.badge-done{color:var(--green)}.badge-fail{color:var(--red)}.tl-expand{font-size:12px;color:#38bdf8;background:none;border:none;font-family:var(--font-mono);cursor:pointer;padding:0;margin-top:2px}.tl-expand:hover{text-decoration:underline}.tl-actions{display:flex;gap:6px;margin-top:6px}.tl-time{display:block;font-size:12px;color:var(--text-dim);font-family:var(--font-mono);margin-top:6px}.btn-open-folder{margin-top:6px;padding:3px 10px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--accent);cursor:pointer}.btn-open-folder:hover{background:var(--accent);color:var(--bg)}.btn{padding:5px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:background .15s,opacity .15s;cursor:pointer;border:none;font-family:inherit}.btn-accept{background:var(--accent);color:#fff}.btn-accept:hover{opacity:.85}.btn-reject{background:transparent;border:1px solid var(--border);color:var(--text-dim)}.btn-reject:hover{background:var(--red-bg);border-color:var(--red);color:var(--red)}.empty{color:var(--text-dim);text-align:center;padding:40px 16px;font-size:13px}.dcard{--w: 260px;--h: 180px;--perf: 10px;position:relative;display:grid;grid-template-rows:auto auto auto auto;gap:.2rem;grid-template-areas:"header" "body" "ip" "footer";width:var(--w);height:var(--h);margin:10px auto;padding:var(--perf) 0;font-family:Inter,sans-serif;font-size:.85rem;-webkit-user-select:none;user-select:none;overflow:hidden;border-radius:10px;filter:drop-shadow(0 1px 1px #0003) drop-shadow(0 2px 2px #0003) drop-shadow(0 4px 4px #0003) drop-shadow(0 8px 8px #0003);cursor:pointer;transition:filter .3s,transform .3s,outline .15s;outline:2px solid transparent;outline-offset:2px}.dcard:hover{filter:drop-shadow(0 2px 2px #0002) drop-shadow(0 4px 4px #0002) drop-shadow(0 8px 8px #0002) drop-shadow(0 16px 16px #0002);transform:translateY(-4px) scale(1.02)}.dcard-sel{outline-color:var(--accent)}.dcard-bg{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background-color:#fff;mask:radial-gradient(circle at 50% 0,#0000 calc(var(--perf) - 4px),#000 calc(var(--perf) - 3px)),radial-gradient(circle at 50% 100%,#0000 calc(var(--perf) - 4px),#000 calc(var(--perf) - 3px)),radial-gradient(circle 6px at left center,#000 98%,#0000 100%),radial-gradient(circle 6px at right center,#000 98%,#0000 100%),repeating-linear-gradient(90deg,#000 8px,#000 12px,#0000 13px,#0000 20px);-webkit-mask-repeat:repeat-x,repeat-x,no-repeat,no-repeat,repeat-x;mask-repeat:repeat-x,repeat-x,no-repeat,no-repeat,repeat-x;-webkit-mask-size:calc(var(--perf) * 2) 100%,calc(var(--perf) * 2) 100%,12px 12px,12px 12px,8px 2px;mask-size:calc(var(--perf) * 2) 100%,calc(var(--perf) * 2) 100%,12px 12px,12px 12px,8px 2px;-webkit-mask-position:calc(.5 * var(--perf)) top,calc(.5 * var(--perf)) bottom,left 50px,right 50px,0 57px;mask-position:calc(.5 * var(--perf)) top,calc(.5 * var(--perf)) bottom,left 50px,right 50px,0 57px;-webkit-mask-composite:source-in,xor,source-over,source-over;mask-composite:intersect,exclude,add,add}.dcard-holo{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background-image:linear-gradient(to bottom,#fff5,90%,#0002),conic-gradient(at 60% 50%,#ccc,#ff6bfe,#00f9f8,#ddd,#0081fd,#eef0bc,#0081fd,#ff6bfe,#0002,#0081fd,#ddd,#01fefb,#ccc)}.dcard-holo:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(circle at 70% 20%,#f0f,#0000),repeating-radial-gradient(circle at 30% 80%,#fff,#f4a 38px,#eee 120px);mix-blend-mode:color-burn}.dcard-holo:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(to bottom,#f205,red,#0f0,#f205);mix-blend-mode:difference;animation:dcard-bgpos 3s ease-in-out infinite alternate;background-position:0 0;background-size:100% 300%;background-repeat:repeat}@keyframes dcard-bgpos{to{background-position:0 400px}}.dcard-name{position:relative;grid-area:header;text-align:center;z-index:1;font-family:Inter,Segoe UI,sans-serif;font-size:1.1rem;font-weight:700;letter-spacing:.5px;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#ffffff80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:2px 8px;border-radius:6px;display:inline-block;width:fit-content;margin:6px auto 0}.dcard-bt-badge{display:inline-flex;vertical-align:middle;margin-left:4px;color:#2a7de1}.dcard-transport-label{font-size:.65rem;background:#2a7de1;color:#fff;padding:1px 5px;border-radius:4px;font-weight:500;letter-spacing:.3px}.dcard-meta{grid-area:body;display:flex;align-items:center;justify-content:center;gap:6px;font-size:.8rem;font-weight:600;color:#222;margin:2px 0;z-index:1}.dcard-ip{grid-area:ip;text-align:center;font-size:.7rem;font-family:var(--font-mono);color:#444;font-weight:500;z-index:1;background:#ffffff4d;padding:1px 6px;border-radius:4px;width:fit-content;margin:0 auto}.dcard-dot{width:6px;height:6px;border-radius:50%;background:#999}.dcard-dot.on{background:var(--green)}.dcard-host{font-size:.7rem;color:#666;font-family:var(--font-mono)}.dcard-footer{grid-area:footer;z-index:1;margin:0 .8em .2em}.dcard-number{margin-bottom:.4rem;text-align:center;border-radius:999px 0;color:#000;font-weight:200;font-size:.75rem}.dcard-bold{font-weight:600}.dcard-barcode{justify-self:center;width:0;height:26px;box-shadow:0 0 0 1px #000,4px 0 0 1px #000,6px 0 0 1px #000,9px 0 0 1px #000,12px 0 0 1px #000,13px 0 0 1px #000,18px 0 0 1px #000,22px 0 0 1px #000,24px 0 0 1px #000,28px 0 0 1px #000,29px 0 0 1px #000,32px 0 0 1px #000,35px 0 0 1px #000,38px 0 0 1px #000,40px 0 0 1px #000,44px 0 0 1px #000,47px 0 0 1px #000,48px 0 0 1px #000,52px 0 0 1px #000,56px 0 0 1px #000,57px 0 0 1px #000,60px 0 0 1px #000;transform:translate(calc(var(--w) / 2 - 60px))}.dcard-symbol{position:absolute;top:1em;right:4px;rotate:185deg;font-size:.7em;color:#fff;line-height:.5;opacity:.15;z-index:1;pointer-events:none}.dcard-notes{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;font-size:3.5rem;color:#e7e7e7;mix-blend-mode:color-burn;transform:translateY(20%);z-index:1;pointer-events:none}.dcard-notes:nth-of-type(2){transform:translateY(40%)}.dcard-notes:nth-of-type(3){transform:translateY(60%)}.device-list{flex:1;overflow-y:auto;padding:4px 0 20px;display:flex;flex-direction:column;align-items:center}.ncard{--folder-W: 120px;--folder-H: 80px;--transition: .35s;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;background:var(--bg-secondary);border:2px dashed var(--border);border-radius:var(--radius);width:100%;min-height:200px;position:relative;cursor:pointer;transition:border-color .2s,background .2s,opacity .3s;-webkit-tap-highlight-color:transparent}.ncard:hover:not(.ncard-disabled){border-color:var(--accent);background:var(--accent-bg)}.ncard-disabled{border-style:dashed;cursor:default}.ncard-disabled:hover{border-color:var(--border);background:var(--bg-secondary)}.ncard-dragging{border-style:solid;border-color:var(--accent);background:var(--accent-bg);filter:drop-shadow(0 0 20px rgba(109,93,244,.3))}.ncard-dragging{filter:drop-shadow(0 0 20px rgba(109,93,244,.6))}.ncard-counter{position:absolute;top:-12px;right:-12px;background:#a18cd1;color:#fff;font-size:12px;font-weight:700;padding:2px 8px;border-radius:20px;display:flex;align-items:center;gap:5px;box-shadow:0 4px 12px #0000004d;z-index:10}.ncard-dot{width:6px;height:6px;background:#34d399;border-radius:50%;box-shadow:0 0 6px #34d399}.ncard-disconnected{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.ncard-dis-icon{color:var(--text-dim);opacity:.3}.ncard-dis-label{font-size:18px;font-weight:600;color:var(--text-dim);opacity:.5}.ncard-dis-hint{font-size:13px;color:var(--text-dim);opacity:.35;max-width:240px;line-height:1.5}.ncard-upload-form{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.ncard-upload-label{cursor:pointer;background:var(--bg-card);padding:24px 40px;border-radius:32px;border:2px dashed var(--border);box-shadow:0 0 200px -50px #0000004d;transition:border-color .2s,background .2s;display:flex;align-items:center;justify-content:center}.ncard-upload-label:hover{border-color:var(--accent);background:var(--accent-bg)}.wc-upload-dragging{border-color:var(--accent);background:var(--accent-bg, rgba(109,93,244,.08))}.ncard-upload-design{display:flex;flex-direction:column;align-items:center;gap:6px}.ncard-upload-design svg{height:44px;fill:var(--text-dim);margin-bottom:12px}.ncard-upload-design p{margin:0;font-size:14px;color:var(--text-muted)}.ncard-or{font-size:13px;color:var(--text-dim)}.ncard-browse-btn{background:var(--text-dim);padding:5px 15px;border-radius:10px;color:#fff;font-size:13px;transition:background .2s;cursor:pointer}.ncard-browse-btn:hover{background:var(--text)}.topbar{position:fixed;top:0;left:0;right:0;height:36px;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 12px;z-index:200;-webkit-user-select:none;user-select:none}.topbar-left{display:flex;align-items:center;gap:8px}.topbar-blob{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:6px;background:var(--border);color:var(--text-dim);cursor:pointer;transition:background .15s,color .15s;-webkit-user-select:none;user-select:none;border:none;font-family:inherit}.webapp-wordmark{font-family:Chelsea Market,cursive;font-size:15px;font-weight:400;color:var(--accent);letter-spacing:-.3px;line-height:1;cursor:pointer}.topbar-right{display:flex;align-items:center;gap:4px}.topbar-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--text-dim);transition:background .15s,color .15s}.topbar-btn:hover{background:var(--bg-card);color:var(--text)}.topbar-btn:disabled{pointer-events:none}.status-dot-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:background .3s,box-shadow .3s}.status-dot-indicator.green{background:var(--green);box-shadow:0 0 6px var(--green)}.status-dot-indicator.yellow{background:var(--yellow);box-shadow:0 0 6px var(--yellow);animation:pulse-dot 1.5s ease-in-out infinite}.status-dot-indicator.red{background:var(--red);box-shadow:0 0 6px var(--red)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.device-id-badge{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:6px;font-family:var(--font-mono)}.os-icon{font-size:13px}.os-name{font-size:10px;color:var(--text-dim);padding:1px 5px;border-radius:4px;background:var(--bg-card)}.sidebar{padding-top:36px}.sidebar.web{padding-top:68px}.main{padding-top:36px}.main.web{padding-top:68px}.security-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;color:var(--green);background:var(--green-bg);padding:2px 8px;border-radius:20px;margin-top:6px;font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:300;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-dialog{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:24px;min-width:320px;max-width:400px;text-align:center;animation:slideUp .25s ease}.modal-narrow{min-width:280px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-icon{width:48px;height:48px;border-radius:50%;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;color:var(--accent)}.modal-dialog h3{font-size:16px;font-weight:600;margin-bottom:8px}.modal-peer{font-size:13px;color:var(--text-muted);margin-bottom:12px}.modal-file-info{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;background:var(--bg-card);border-radius:var(--radius-sm);margin-bottom:16px}.modal-filename{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.modal-filesize{font-size:11px;color:var(--text-dim);font-family:var(--font-mono);flex-shrink:0}.modal-actions{display:flex;gap:8px;justify-content:center}.modal-btn{display:flex;align-items:center;gap:6px;padding:8px 20px!important;font-size:13px!important}.text-share-input{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;color:var(--text);resize:vertical;font-size:13px;margin:12px 0 16px;outline:none;transition:border-color .15s}.text-share-input:focus{border-color:var(--accent)}.tl-progress-info{display:flex;align-items:center;gap:8px}.tl-eta{font-size:11px;color:var(--text-dim);font-family:var(--font-mono)}.app-footer{padding:10px 20px;border-top:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:4px;font-size:11px;color:var(--text-dim);text-align:center}.footer-legal{font-weight:500;color:var(--text-muted)}.footer-links{display:flex;align-items:center;gap:6px}.footer-links a{color:var(--accent);text-decoration:none}.footer-links a:hover{text-decoration:underline}.footer-sep{color:var(--border)}.footer-disclaimer{font-size:10px;color:var(--text-dim)}.tl-just-done .tl-bullet{animation:pop-check .4s cubic-bezier(.34,1.56,.64,1)}@keyframes pop-check{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.tl-failed .tl-bullet{animation:shake-x .4s ease}@keyframes shake-x{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.tl-icon-check{color:var(--green)}.tl-icon-x{color:var(--red)}.tl-bullet-fail{border-color:var(--red)!important}.tl-done .tl-body:after{content:"檔案已儲存至 download/ 目錄";display:block;font-size:10px;color:var(--text-dim);margin-top:4px;opacity:.7}.lang-switch{font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;font-family:inherit;letter-spacing:.3px;transition:border-color .15s,color .15s;line-height:1.4}.lang-switch:hover{border-color:var(--accent);color:var(--accent)}@media(max-width:768px){.sidebar{width:220px;min-width:220px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.download-page{width:100%;height:100vh;overflow-y:auto;background:var(--bg);color:var(--text);display:flex;flex-direction:column;align-items:center}.download-topbar{position:fixed;top:12px;right:12px;z-index:100}.download-hero{text-align:center;padding:80px 20px 40px}.download-logo{font-family:Chelsea Market,cursive;font-size:48px;font-weight:400;letter-spacing:-1px;margin-bottom:12px}.download-logo span{color:var(--accent)}.download-tagline{font-size:16px;color:var(--text-dim);margin-bottom:20px}.feature-bar{display:flex;justify-content:center;gap:0;margin-top:24px}.feature-item{font-size:13px;font-weight:700;padding:10px 20px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);letter-spacing:.5px}.feature-e2e{background:#ff6b6b;border-radius:8px 0 0 8px}.feature-stream{background:#ffa502}.feature-auto{background:#2ed573;border-radius:0 8px 8px 0}.download-section{max-width:560px;width:100%;padding:0 20px 40px}.download-section h2{font-size:22px;font-weight:600;margin-bottom:6px}.download-sub{font-size:14px;color:var(--text-dim);margin-bottom:24px}.download-loading{text-align:center;padding:40px;color:var(--text-dim)}.dp-offline-banner{background:#fff3cd;color:#856404;text-align:center;padding:12px;border-radius:8px;margin-bottom:16px;font-size:14px;font-weight:500}.download-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:16px}.download-web-card{border-color:var(--accent);border-style:dashed}.download-btn-web{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important}.download-btn-web:hover{opacity:.9}.download-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.download-version{font-size:16px;font-weight:600}.download-date{font-size:12px;color:var(--text-dim)}.download-card-body{margin-bottom:16px}.download-note{font-size:13px;color:var(--text-muted);line-height:1.6;margin:0}.download-webview2{display:flex;gap:10px;padding:12px;margin-top:8px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border);align-items:flex-start}.download-webview2-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--warning-bg, rgba(255,193,7,.15));color:var(--warning, #f5a623);flex-shrink:0;margin-top:2px}.download-webview2-body{display:flex;flex-direction:column;gap:4px}.download-webview2-title{font-size:13px;font-weight:600;color:var(--text)}.download-webview2-desc{font-size:11px;color:var(--text-muted);line-height:1.4}.download-webview2-btn{display:inline-flex;align-items:center;padding:6px 14px;margin-top:4px;border-radius:6px;background:var(--accent);color:#fff;font-size:12px;font-weight:500;text-decoration:none;transition:opacity .15s;width:fit-content}.download-webview2-btn:hover{opacity:.85}.download-assets{display:flex;flex-direction:column;gap:8px}.download-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;background:var(--bg-card);border:1px solid var(--border);text-decoration:none;color:var(--text);transition:background .15s,border-color .15s}.download-btn:hover{background:var(--accent-bg);border-color:var(--accent)}.download-btn-icon{font-size:20px;width:36px;height:36px;border-radius:8px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.download-btn-text{flex:1;font-size:14px;font-weight:500;display:flex;justify-content:space-between;align-items:center;gap:8px}.download-btn-size{font-size:12px;color:var(--text-dim);font-family:var(--font-mono);flex-shrink:0}.download-bottom{text-align:center;padding:20px}.download-gh-link{font-size:14px;color:var(--accent);text-decoration:none}.download-gh-link:hover{text-decoration:underline}.download-footer{text-align:center;padding:20px;font-size:12px;color:var(--text-dim);display:flex;flex-direction:column;gap:4px}.download-footer-links{font-size:12px}.download-footer-links a{color:var(--accent);text-decoration:none}.download-footer-links a:hover{text-decoration:underline}.download-footer-sep{margin:0 6px;color:var(--border)}@media(max-width:640px){.download-section{padding:0 20px 40px}.feature-bar{flex-wrap:wrap;justify-content:center}.feature-item{min-width:100%;text-align:center}}.privacy-group{display:flex;flex-direction:column;gap:4px;margin:12px 0}.privacy-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;cursor:pointer;border-bottom:1px solid var(--border);gap:12px}.privacy-row span{display:flex;flex-direction:column;gap:2px;min-width:0}.privacy-row strong{font-size:13px;font-weight:500;color:var(--text)}.privacy-row small{font-size:11px;color:var(--text-dim)}.privacy-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);flex-shrink:0}.privacy-row input[type=checkbox]:disabled{opacity:.3}.privacy-note{font-size:12px;color:var(--text-dim);text-align:center;margin:12px 0;line-height:1.5}.web-banner{position:fixed;top:36px;left:0;right:0;height:28px;background:linear-gradient(135deg,#6d5df4,#f162ba);display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:#fff;z-index:199;font-weight:500;cursor:pointer;transition:opacity .15s}.web-banner:hover{opacity:.9}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border);padding:12px 20px;display:flex;align-items:center;justify-content:center;gap:12px;z-index:500;font-size:13px;color:var(--text-muted);flex-wrap:wrap;text-align:center}.cookie-banner .btn{flex-shrink:0}.guide-dialog{max-width:440px;text-align:left}.guide-section{margin:14px 0}.guide-section h4{font-size:14px;font-weight:600;margin:0 0 4px;color:var(--text)}.guide-section p{font-size:13px;color:var(--text-muted);margin:0 0 4px;line-height:1.5}.guide-steps{list-style:decimal;padding:0 0 0 20px;margin:12px 0;display:flex;flex-direction:column;gap:10px}.guide-steps li{font-size:13px;color:var(--text-muted);line-height:1.4}.guide-steps li strong{display:block;font-size:14px;color:var(--text);margin-bottom:2px}.guide-steps li span{font-size:12px;color:var(--text-dim)}.guide-extra{font-size:12px;color:var(--green);background:var(--green-bg);padding:8px 12px;border-radius:var(--radius-sm);margin:8px 0 12px}.guide-extra p{margin:0}.guide-actions{display:flex;align-items:center;justify-content:space-between;margin-top:12px}.guide-dont-show{font-size:12px;color:var(--text-dim);display:flex;align-items:center;gap:6px;cursor:pointer}.guide-dont-show input{accent-color:var(--accent)}.qrcode-wrapper{display:flex;justify-content:center;margin:16px 0}.qrcode-wrapper canvas{border-radius:8px}.qrcode-label{font-size:13px;color:var(--text-muted);text-align:center;font-family:var(--font-mono);margin-bottom:12px}.qrcode-error{font-size:14px;color:var(--text-dim);text-align:center;padding:40px 20px}.webapp-root{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--text);font-family:var(--font-body, ui-sans-serif, system-ui, sans-serif)}.webapp-bg{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 19px,rgba(75,85,99,.08) 19px,rgba(75,85,99,.08) 20px,transparent 20px,transparent 39px,rgba(75,85,99,.08) 39px,rgba(75,85,99,.08) 40px),repeating-linear-gradient(90deg,transparent,transparent 19px,rgba(75,85,99,.08) 19px,rgba(75,85,99,.08) 20px,transparent 20px,transparent 39px,rgba(75,85,99,.08) 39px,rgba(75,85,99,.08) 40px),radial-gradient(circle at 20px 20px,rgba(55,65,81,.12) 2px,transparent 2px),radial-gradient(circle at 40px 40px,rgba(55,65,81,.12) 2px,transparent 2px);background-size:40px 40px,40px 40px,40px 40px,40px 40px;background-color:transparent}.webapp-main{flex:1;display:flex;flex-direction:column;position:relative;min-height:0;background:transparent}.webapp-main-scroll{flex:1;display:flex;flex-direction:column;align-items:center;overflow-y:auto;padding:36px 0 0;position:relative;z-index:1;min-height:0}.webapp-layout-inner{display:flex;flex-direction:row;justify-content:center;align-items:flex-start;width:100%;max-width:1320px;gap:32px;padding:0 24px;margin:0 auto}.webapp-doc-panel{width:400px;flex-shrink:0;display:flex;flex-direction:column;gap:12px;padding:12px 0;overflow-y:auto;max-height:calc(100vh - 100px)}.dp-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:16px}.dp-card-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);margin-bottom:12px;display:flex;align-items:center;gap:6px}.dp-card-title svg{width:14px;height:14px;color:var(--accent)}.dp-stats-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.dp-stat{text-align:center;padding:10px 6px;background:var(--bg-card);border-radius:8px}.dp-stat-value{display:block;font-size:22px;font-weight:700;font-family:var(--font-mono);color:var(--accent);line-height:1.2}.dp-stat-label{display:block;font-size:10px;color:var(--text-dim);margin-top:2px;font-weight:500}.dp-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:14px 16px}.dp-section-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim);margin-bottom:10px;display:flex;align-items:center;gap:6px}.dp-item{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:13px;color:var(--text-muted);line-height:1.4}.dp-item svg{width:14px;height:14px;flex-shrink:0;color:var(--green)}.dp-item-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0}.dp-item kbd{font-family:var(--font-mono);font-size:10px;padding:1px 5px;background:var(--bg-card);border:1px solid var(--border);border-radius:4px;color:var(--text)}.dp-community{display:flex;gap:8px;flex-wrap:wrap}.dp-link-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);font-size:12px;font-weight:500;cursor:pointer;text-decoration:none;transition:border-color .15s,color .15s,background .15s;font-family:inherit}.dp-link-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.dp-link-btn svg{width:14px;height:14px}.dp-footer{text-align:center;font-size:11px;color:var(--text-dim);line-height:1.6;padding:4px 0}.dp-footer a{color:var(--accent);text-decoration:none}.dp-footer a:hover{text-decoration:underline}.dp-footer-sep{margin:0 6px;color:var(--border)}@media(max-width:1050px){.webapp-layout-inner{flex-direction:column;align-items:center;padding:0 16px}.webapp-doc-panel{width:100%;max-width:420px;max-height:none}}.wc-section{width:100%;padding:20px 0;display:flex;flex-direction:column;gap:10px;border-bottom:1px solid var(--border)}.wc-section:last-of-type{border-bottom:none}.wc-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);display:flex;align-items:center;gap:6px}.wc-id{font-size:28px;font-weight:700;font-family:var(--font-mono);letter-spacing:4px;color:var(--accent);line-height:1.2}.wc-btns{display:flex;gap:6px;flex-wrap:wrap}.wc-btn{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:6px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s,background .15s;font-family:inherit;white-space:nowrap}.wc-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.wc-device-name{margin:4px 0 8px}.wc-device-label{font-size:12px;color:var(--text-dim);display:inline-flex;align-items:center;gap:4px}.wc-btn-icon{background:none;border:none;padding:2px;cursor:pointer;color:var(--text-muted);display:inline-flex;align-items:center;opacity:.5;transition:opacity .15s}.wc-btn-icon:hover{opacity:1}.wc-device-input{font-size:12px;padding:4px 8px;border-radius:6px;border:1px solid var(--accent);background:var(--bg-card);color:var(--text);outline:none;width:100%;max-width:220px;font-family:inherit}.wc-err{font-size:12px;color:var(--red);background:var(--red-bg);padding:6px 10px;border-radius:6px;line-height:1.4}.wc-connecting{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:8px;margin-top:8px}.wc-connecting-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border);border-top:2px solid var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.wc-muted{font-size:14px;color:var(--text-muted);font-weight:500}.wc-connect-form{display:flex;gap:8px}.wc-input{flex:1;min-width:0;padding:10px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:16px;font-family:var(--font-mono);letter-spacing:4px;outline:none;transition:border-color .15s}.wc-input:focus{border-color:var(--accent)}.wc-input:disabled{opacity:.5}.wc-go-btn{padding:10px 20px;border-radius:8px;border:none;background:var(--accent);color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .15s;font-family:inherit;white-space:nowrap}.wc-go-btn:disabled{opacity:.35;cursor:not-allowed}.wc-go-btn:hover:not(:disabled){opacity:.85}.wc-connected{display:flex;align-items:center;gap:8px;padding:5px 10px;background:var(--green-bg);border-radius:6px}.wc-remote-id{font-size:13px;font-weight:600;font-family:var(--font-mono);letter-spacing:2px;color:var(--accent)}.wc-disc-btn{margin-left:auto;padding:3px 10px;border-radius:4px;border:1px solid var(--red);background:transparent;color:var(--red);font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.wc-disc-btn:hover{background:var(--red-bg)}.wc-peer-list{display:flex;flex-wrap:wrap;gap:4px}.wc-peer-search{width:100%;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;font-family:var(--font-mono);outline:none;transition:border-color .15s;box-sizing:border-box}.wc-peer-search:focus{border-color:var(--accent)}.wc-peer-search::placeholder{color:var(--text-dim);font-family:inherit}.wc-peer-chip{padding:3px 10px;border-radius:999px;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);font-size:11px;font-weight:500;cursor:pointer;font-family:inherit;transition:border-color .15s,color .15s,background .15s;white-space:nowrap;max-width:100px;overflow:hidden;text-overflow:ellipsis}.wc-peer-chip:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.wc-peer-chip:disabled{opacity:.4;cursor:default}.wc-peer-active{border-color:var(--green);color:var(--green);background:var(--green-bg)}.webapp-tech{display:flex;gap:8px;justify-content:flex-start;margin:12px 0 4px}.webapp-tech-pill{font-size:10px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-dim);letter-spacing:.3px}.bt-scan-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.bt-scan-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:13px;cursor:pointer;transition:all .15s}.bt-scan-btn:hover:not(:disabled){border-color:var(--accent);background:var(--accent-bg)}.bt-scan-btn:disabled{opacity:.4;cursor:not-allowed}.bt-clear-btn{padding:6px 10px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer}.bt-clear-btn:hover{color:var(--text)}.bt-device-list{display:flex;flex-direction:column;gap:4px;margin-top:6px}.bt-device-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;background:var(--bg-card);border:1px solid var(--border)}.bt-device-item.bt-connected{border-color:var(--green);background:var(--green-bg)}.bt-device-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--accent-bg);color:var(--accent);flex-shrink:0}.bt-device-name{font-size:13px;font-weight:500;color:var(--text);flex:1}.bt-device-badge{font-size:9px;font-weight:600;padding:1px 5px;border-radius:4px;background:var(--accent-bg);color:var(--accent);letter-spacing:.3px}.bt-connect-btn{padding:4px 12px;border-radius:6px;border:1px solid var(--accent);background:var(--accent);color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:opacity .15s}.bt-connect-btn:hover{opacity:.85}.webapp-idle{width:100%;margin:0 auto;padding:18px 0}.webapp-idle-steps{display:flex;flex-direction:column;gap:10px}.webapp-idle-step{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-muted);padding:10px 14px;border-radius:10px;background:var(--bg-secondary);border:1px solid var(--border)}.webapp-idle-num{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.webapp-tips{width:100%;margin:8px auto 0}.webapp-tips-header{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim);margin-bottom:6px}.webapp-tips-list{display:flex;flex-direction:column;gap:4px}.webapp-tips-item{font-size:12px;color:var(--text-muted);padding:8px 12px;border-radius:8px;background:var(--bg-secondary);border:1px solid var(--border);display:flex;align-items:center;gap:8px}.webapp-tips-item:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}.webapp-dash{width:100%;margin:0 auto;display:flex;flex-direction:column;gap:12px}.webapp-dash-row{display:flex;gap:10px;flex-wrap:wrap}.webapp-dash-card{flex:1;min-width:140px;padding:14px 18px;border-radius:10px;background:var(--bg-secondary);border:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.webapp-dash-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim)}.webapp-dash-value{font-size:16px;font-weight:700;color:var(--text);font-family:var(--font-mono)}.webapp-dash-value.green{color:var(--green)}.webapp-dash-value.accent{color:var(--accent)}.webapp-dash-peer{display:flex;align-items:center;gap:6px}.webapp-dash-actions{display:flex;gap:6px;margin-top:4px}.webapp-dash-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:12px;cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s}.webapp-dash-btn:hover{border-color:var(--accent);background:var(--accent-bg);color:var(--accent)}.webapp-dash-btn.invite:hover{border-color:var(--green);background:var(--green-bg);color:var(--green)}.webapp-main-center{width:100%;max-width:900px;display:flex;flex-direction:column;align-items:center;gap:0;padding:8px 40px 40px;margin:auto}.text-send-bar{width:100%;display:flex;gap:8px;align-items:center}.text-send-input{flex:1;padding:10px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:14px;outline:none;transition:border-color .15s}.text-send-input:focus{border-color:var(--accent)}.text-send-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;border:none;background:var(--accent);color:#fff;cursor:pointer;transition:opacity .15s}.text-send-btn:disabled{opacity:.4;cursor:default}.text-send-btn:not(:disabled):hover{opacity:.85}.file-upload-form{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.file-upload-label{cursor:pointer;background-color:var(--bg-card);padding:40px 80px;border-radius:40px;border:2px dashed var(--border);box-shadow:0 0 200px -50px #0000004d;transition:border-color .2s,background .2s,opacity .2s}.file-upload-label:hover{border-color:var(--accent);background:var(--accent-bg)}.file-upload-label input{display:none}.file-upload-label svg{height:50px;fill:var(--text-dim);margin-bottom:20px}.file-upload-label-dim{cursor:default;opacity:.45}.file-upload-label-dim:hover{border-color:var(--border);background:var(--bg-card)}.file-upload-design{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px}.file-upload-design p{margin:0;font-size:14px;color:var(--text-muted)}.browse-button{background-color:var(--text-dim);padding:5px 15px;border-radius:10px;color:#fff;transition:all .3s;cursor:pointer;font-size:13px}.browse-button:hover{background-color:var(--text)}.dz-text-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:12px;cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s}.dz-text-btn:hover{border-color:var(--accent);background:var(--accent-bg)}.webapp-history{flex:1}.webapp-history-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 6px;font-size:12px;font-weight:600}.webapp-history-clear{background:none;border:none;color:var(--text-dim);font-size:11px;cursor:pointer;padding:2px 6px;border-radius:4px;transition:color .15s,background .15s}.webapp-history-clear:hover{color:var(--red);background:var(--red-bg)}.webapp-history-col{display:flex;flex-direction:column;gap:8px}.webapp-col-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-dim);margin-bottom:4px}.webapp-col-count{background:var(--bg-secondary);border-radius:999px;padding:1px 6px;font-size:10px;font-weight:600}.webapp-col-empty{font-size:12px;color:var(--text-muted);padding:12px;border:1px dashed var(--border);border-radius:8px;text-align:center}.webapp-tx{background:var(--bg-secondary);border-radius:var(--radius-sm);padding:10px 14px;display:flex;flex-direction:column;gap:6px;transition:background .15s}.webapp-tx:hover{background:var(--bg-card)}.webapp-tx.done{border-left:3px solid var(--green)}.webapp-tx.error{border-left:3px solid var(--red)}.webapp-tx-row{display:flex;align-items:center;gap:10px}.webapp-tx-icon{width:28px;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.webapp-tx-icon.file-blue{background:#3b82f6}.webapp-tx-icon.file-green{background:#22c55e}.webapp-tx-icon.file-purple{background:#a855f7}.webapp-tx-icon.file-orange{background:#f97316}.webapp-tx-icon.file-yellow{background:#eab308}.webapp-tx-icon.file-indigo{background:#6366f1}.webapp-tx-icon.file-red{background:#ef4444}.webapp-tx-icon.file-sky{background:#06b6d4}.webapp-tx-icon.file-gray{background:#6b7280}.webapp-tx-body{flex:1;min-width:0}.webapp-tx-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.webapp-tx-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-dim)}.webapp-tx-badge{padding:1px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:500}.webapp-tx-badge.transferring{background:var(--accent-bg);color:var(--accent)}.webapp-tx-badge.done{background:var(--green-bg);color:var(--green)}.webapp-tx-badge.error{background:var(--red-bg);color:var(--red)}.webapp-tx-bar{height:4px;border-radius:2px;background:var(--border);overflow:hidden}.webapp-tx-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .2s}.webapp-tx-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0;align-items:center}.webapp-tx-action-btn{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--accent);text-decoration:none;padding:6px 10px;border-radius:var(--radius-sm);transition:background .15s;cursor:pointer;font-family:inherit;border:none;background:transparent}.webapp-tx-action-btn:hover{background:var(--accent-bg)}.webapp-tx-download{color:var(--green)}.webapp-tx-download:hover{background:var(--green-bg)}.webapp-tx-err{font-size:11px;color:#f87171}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.green{background:#4ade80}.status-dot.yellow{background:#facc15}.status-dot.red{background:#f87171}.webapp-history-section{width:100%;margin-top:8px}.webapp-history-inner{display:grid;grid-template-columns:1fr 1fr;gap:16px}.status-dot-indicator{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-dot-indicator.green{background:#4ade80;box-shadow:0 0 4px #4ade80}.status-dot-indicator.yellow{background:#facc15;box-shadow:0 0 4px #facc15}.main-toggle{position:relative;display:block;width:90px;height:40px;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.main-checkbox{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.main-track{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#2ecc71;border:4px solid #000000;box-sizing:border-box;box-shadow:inset 2px 2px #0000001a;transition:background-color .3s ease}.main-knob{position:absolute;top:50%;left:0;transform:translate(-4px,-50%);width:40px;height:46px;background:#fff;border:4px solid #000000;box-shadow:3px 3px #000;display:flex;align-items:center;justify-content:center;z-index:2;transition:transform .3s cubic-bezier(.7,-.4,.4,1.4)}.main-toggle:active .main-knob{box-shadow:1px 1px #000;margin-top:2px;margin-left:2px}.main-knob:after{content:":)";font-weight:900;font-size:24px;color:#000;transform:rotate(90deg)}.main-checkbox:checked+.main-track{background-color:#e74c3c}.main-checkbox:checked~.main-knob{transform:translate(50px,-50%)}.main-checkbox:checked~.main-knob:after{content:":("}.ble-btn-wrapper{position:relative;transform-style:preserve-3d;transition:transform .2s ease;padding:8px 0;display:flex;justify-content:center}.ble-spiderverse-btn{position:relative;padding:8px 20px;font-size:16px;font-weight:900;border:none;border-radius:50px;cursor:pointer;background:#fff;color:#000;text-transform:uppercase;letter-spacing:3px;transform-style:preserve-3d;transition:all .15s ease;font-family:Arial,sans-serif}.ble-glitch-text{position:relative;display:inline-block}.ble-glitch-layers{position:absolute;top:0;left:0;width:100%;height:100%}.ble-glitch-layer{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:50px;opacity:0;transition:all .15s ease;pointer-events:none;mix-blend-mode:screen}.ble-layer-1{color:#0ff;transform-origin:center}.ble-layer-2{color:#f0f;transform-origin:center}.ble-btn-wrapper:hover .ble-layer-1{opacity:1;animation:bleGlitchLayer1 .4s steps(2) infinite}.ble-btn-wrapper:hover .ble-layer-2{opacity:1;animation:bleGlitchLayer2 .4s steps(2) infinite}.ble-btn-wrapper:hover .ble-spiderverse-btn{animation:bleButtonGlitch .3s steps(2) infinite;box-shadow:0 0 20px #ffffff80,0 0 30px #00ffff80,0 0 40px #ff00ff80}.ble-noise{position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:48px;background:repeating-radial-gradient(circle at 50% 50%,transparent 0,rgba(0,0,0,.06) 1px,transparent 2px);pointer-events:none;opacity:0;transition:opacity .3s;animation:bleNoise .2s steps(2) infinite}.ble-btn-wrapper:hover .ble-noise{opacity:1}@keyframes bleButtonGlitch{0%{transform:translate(0) scale(1.1)}25%{transform:translate(-10px,5px) scale(1.15) skew(-5deg)}50%{transform:translate(10px,-5px) scale(1.1) skew(5deg)}75%{transform:translate(-15px,-5px) scale(1.05) skew(-3deg)}to{transform:translate(0) scale(1.1)}}@keyframes bleGlitchLayer1{0%{transform:translate(-20px,-10px) scale(1.1) skew(-10deg);clip-path:polygon(0 20%,100% 20%,100% 50%,0 50%)}25%{transform:translate(20px,10px) scale(1.2) skew(10deg);clip-path:polygon(0 30%,100% 30%,100% 60%,0 60%)}50%{transform:translate(-15px,5px) scale(.9) skew(-5deg);clip-path:polygon(0 10%,100% 10%,100% 40%,0 40%)}75%{transform:translate(15px,-5px) scale(1.3) skew(5deg);clip-path:polygon(0 40%,100% 40%,100% 70%,0 70%)}to{transform:translate(-20px,-10px) scale(1.1) skew(-10deg);clip-path:polygon(0 20%,100% 20%,100% 50%,0 50%)}}@keyframes bleGlitchLayer2{0%{transform:translate(20px,10px) scale(1.1) skew(10deg);clip-path:polygon(0 50%,100% 50%,100% 80%,0 80%)}25%{transform:translate(-20px,-10px) scale(1.2) skew(-10deg);clip-path:polygon(0 60%,100% 60%,100% 90%,0 90%)}50%{transform:translate(15px,-5px) scale(.9) skew(5deg);clip-path:polygon(0 40%,100% 40%,100% 70%,0 70%)}75%{transform:translate(-15px,5px) scale(1.3) skew(-5deg);clip-path:polygon(0 70%,100% 70%,100% 100%,0 100%)}to{transform:translate(20px,10px) scale(1.1) skew(10deg);clip-path:polygon(0 50%,100% 50%,100% 80%,0 80%)}}@keyframes bleNoise{0%{transform:translate(0)}10%{transform:translate(-5%,-5%)}20%{transform:translate(10%,5%)}30%{transform:translate(-5%,10%)}40%{transform:translate(15%,-5%)}50%{transform:translate(-10%,15%)}60%{transform:translate(5%,-10%)}70%{transform:translate(-15%,5%)}80%{transform:translate(10%,10%)}90%{transform:translate(-5%,15%)}to{transform:translate(0)}}@media(max-width:640px){.webapp-layout{flex-direction:column}.webapp-panel{width:100%;max-width:none;border-right:none;border-bottom:1px solid var(--border)}.webapp-main-center{max-width:100%;padding:8px 20px 40px}.file-upload-label{padding:30px 40px}.webapp-history-row{grid-template-columns:1fr}.webapp-main{padding:16px}}@media(max-width:1050px){.webapp-layout-inner{flex-direction:column;align-items:center;padding:0 16px}.webapp-doc-panel{width:100%;max-width:420px}}.earth-loader{--watercolor: #3344c1;--landcolor: #7cc133;width:7.5em;height:7.5em;background-color:var(--watercolor);position:relative;overflow:hidden;border-radius:50%;box-shadow:inset 0 .5em #ffffff40,inset 0 -.5em #00000040;border:solid .15em white;animation:startround 1s;animation-iteration-count:1}.earth{display:flex;flex-direction:column;align-items:center;gap:.5em}.earth p{color:var(--text-muted);font-size:.9em;margin:0}.earth-loader svg:nth-child(1){position:absolute;bottom:-2em;width:7em;height:auto;animation:round1 5s infinite linear .75s}.earth-loader svg:nth-child(2){position:absolute;top:-3em;width:7em;height:auto;animation:round1 5s infinite linear}.earth-loader svg:nth-child(3){position:absolute;top:-2.5em;width:7em;height:auto;animation:round2 5s infinite linear}.earth-loader svg:nth-child(4){position:absolute;bottom:-2.2em;width:7em;height:auto;animation:round2 5s infinite linear .75s}@keyframes startround{0%{filter:brightness(500%);box-shadow:none}75%{filter:brightness(500%);box-shadow:none}to{filter:brightness(100%);box-shadow:inset 0 .5em #ffffff40,inset 0 -.5em #00000040}}@keyframes round1{0%{left:-2em;opacity:100%;transform:skew(0) rotate(0)}30%{left:-6em;opacity:100%;transform:skew(-25deg) rotate(25deg)}31%{left:-6em;opacity:0%;transform:skew(-25deg) rotate(25deg)}35%{left:7em;opacity:0%;transform:skew(25deg) rotate(-25deg)}45%{left:7em;opacity:100%;transform:skew(25deg) rotate(-25deg)}to{left:-2em;opacity:100%;transform:skew(0) rotate(0)}}@keyframes round2{0%{left:5em;opacity:100%;transform:skew(0) rotate(0)}75%{left:-7em;opacity:100%;transform:skew(-25deg) rotate(25deg)}76%{left:-7em;opacity:0%;transform:skew(-25deg) rotate(25deg)}77%{left:8em;opacity:0%;transform:skew(25deg) rotate(-25deg)}80%{left:8em;opacity:100%;transform:skew(25deg) rotate(-25deg)}to{left:5em;opacity:100%;transform:skew(0) rotate(0)}}.wl-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);position:sticky;top:0;z-index:100}.wl-header-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;gap:24px;padding:10px 18px}.wl-logo{font-size:20px;font-weight:700;font-family:var(--font-mono);letter-spacing:-.5px}.wl-logo span{color:var(--accent)}.wl-nav{display:flex;gap:16px;margin-left:24px}.wl-nav a{font-size:14px;color:var(--text-dim);text-decoration:none;transition:color .15s}.wl-nav a:hover{color:var(--text)}.wl-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 18px;gap:32px}.wl-hero{display:flex;flex-direction:column;align-items:center;gap:24px}.wl-cta{display:flex;justify-content:center}.wl-enter-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:999px;border:none;background:var(--accent);color:#fff;font-size:16px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .2s,transform .15s}.wl-enter-btn:hover{opacity:.85;transform:translateY(-1px)}.wl-card{max-width:24rem;width:100%;margin:0 auto;padding:2rem;border-radius:.75rem;border:1px solid rgba(255,255,255,.1);background:#f3f4f6;box-shadow:2px 4px 16px #f8f8f80f inset}[data-theme=dark] .wl-card{background:#282828b3}.wl-card-canvas{height:15rem;border-radius:.75rem;z-index:40;background:#d4d4d4;position:relative;overflow:hidden;mask-image:radial-gradient(50% 50% at 50% 50%,white 0%,transparent 100%);-webkit-mask-image:radial-gradient(50% 50% at 50% 50%,white 0%,transparent 100%)}[data-theme=dark] .wl-card-canvas{background:#282828b3}@media(min-width:768px){.wl-card-canvas{height:20rem}}.wl-canvas-inner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px}.wl-icon-row{display:flex;flex-shrink:0;justify-content:center;align-items:center;gap:8px}.wl-icon-btn{display:flex;align-items:center;justify-content:center;border-radius:9999px;background:#f8f8f803;box-shadow:0 0 8px #f8f8f840 inset,0 32px 24px -16px #0006;color:var(--text)}[data-theme=dark] .wl-icon-btn{color:#fff}.wl-icon-btn-sm{width:32px;height:32px}.wl-icon-btn-md{width:48px;height:48px}.wl-icon-btn-lg{width:64px;height:64px}.wl-icon-svg-sm{width:16px;height:16px}.wl-icon-svg-md{width:24px;height:24px}.wl-icon-svg-lg{width:32px;height:32px}.wl-glow-line{height:160px;width:1px;position:absolute;top:80px;margin:auto;z-index:40;background:linear-gradient(to bottom,transparent,#06b6d4,transparent);animation:wl-move 3s ease-in-out infinite}.wl-eq-wrap{width:40px;height:128px;position:absolute;top:50%;left:-40px;transform:translateY(-50%)}.wl-card-title{font-size:1.125rem;font-weight:600;color:#1f2937;padding:.5rem 0}[data-theme=dark] .wl-card-title{color:#fff}.wl-card-desc{font-size:.875rem;font-weight:400;color:#525252;max-width:24rem}[data-theme=dark] .wl-card-desc{color:#a3a3a3}.circle-1{animation:wl-float1 4s ease-in-out infinite}.circle-2{animation:wl-float2 4.5s ease-in-out infinite}.circle-3{animation:wl-float3 5s ease-in-out infinite}.circle-4{animation:wl-float4 4.8s ease-in-out infinite}.circle-5{animation:wl-float5 4.2s ease-in-out infinite}@keyframes wl-float1{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes wl-float2{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}@keyframes wl-float3{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes wl-float4{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes wl-float5{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes wl-move{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}.animate-move{animation:wl-move 3s ease-in-out infinite}.wl-eq{display:flex;align-items:center;gap:2px;height:100%}.wl-bar{display:inline-block;width:3px;background:var(--text);border-radius:2px;animation:wl-eq 1.2s ease-in-out infinite}.wl-bar:nth-child(1){height:20%;animation-delay:0s}.wl-bar:nth-child(2){height:40%;animation-delay:.1s}.wl-bar:nth-child(3){height:60%;animation-delay:.2s}.wl-bar:nth-child(4){height:30%;animation-delay:.3s}.wl-bar:nth-child(5){height:70%;animation-delay:.4s}.wl-bar:nth-child(6){height:50%;animation-delay:.5s}.wl-bar:nth-child(7){height:80%;animation-delay:.6s}.wl-bar:nth-child(8){height:25%;animation-delay:.7s}.wl-bar:nth-child(9){height:55%;animation-delay:.8s}.wl-bar:nth-child(10){height:65%;animation-delay:.9s}.wl-bar:nth-child(11){height:35%;animation-delay:1s}.wl-bar:nth-child(12){height:45%;animation-delay:1.1s}@keyframes wl-eq{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.webapp-static-root{min-height:100vh}.webapp-static-body{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:48px 24px;gap:1.5em;text-align:center;min-height:calc(100vh - 56px);gap:16px}.webapp-static-icon{color:var(--text-dim);opacity:.4;margin-bottom:8px}.webapp-static-title{font-size:22px;font-weight:700;margin:0;color:var(--text)}.webapp-static-desc{font-size:14px;color:var(--text-muted);line-height:1.7;max-width:420px;margin:0}.webapp-static-btns{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:8px}.webapp-static-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;background:var(--accent);color:var(--bg);font-size:14px;font-weight:700;text-decoration:none;transition:opacity .15s}.webapp-static-btn-primary:hover{opacity:.85}.webapp-static-btn-ghost{display:inline-flex;align-items:center;padding:10px 20px;border-radius:8px;border:1px solid var(--border);color:var(--text-dim);font-size:14px;text-decoration:none;transition:border-color .15s,color .15s}.webapp-static-btn-ghost:hover{border-color:var(--accent);color:var(--text)}.modal-wide{min-width:420px;max-width:560px}.text-preview{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;font-size:13px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-all;overflow-wrap:break-word;max-height:300px;overflow-y:auto;text-align:left;margin:12px 0 16px;font-family:var(--font-mono)}.webapp-bt-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}.webapp-bt-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);padding:8px 10px;background:var(--bg-secondary);border-radius:var(--radius-sm);transition:background .15s}.webapp-bt-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.webapp-bt-name{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.webapp-bt-peer{font-size:11px;color:var(--accent);font-family:var(--font-mono);letter-spacing:1px;font-weight:600}.webapp-bt-connect-btn{flex-shrink:0;padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text);font-size:11px;cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s}.webapp-bt-connect-btn:hover:not(:disabled){border-color:var(--accent);background:var(--accent-bg)}.webapp-bt-connect-btn:disabled{opacity:.4;cursor:default}.webapp-bt-remove{flex-shrink:0;width:20px;height:20px;border-radius:4px;border:none;background:transparent;color:var(--text-dim);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.webapp-bt-remove:hover{background:var(--red-bg);color:var(--red)}.webapp-bt-item.online-peer{cursor:pointer;transition:border-color .15s,background .15s}.webapp-footer{border-top:1px solid var(--border);padding:10px 18px;flex-shrink:0;background:var(--bg-secondary)}.webapp-footer-inner{display:flex;align-items:center;gap:12px;font-size:11px;color:var(--text-dim);max-width:900px;margin:0 auto}.webapp-footer-brand{font-weight:600;font-family:var(--font-mono);color:var(--text)}.webapp-footer-brand span{color:var(--accent)}.webapp-footer-ver{font-weight:400;color:var(--text-dim);font-size:10px}.webapp-footer-tag{color:var(--text-dim)}.webapp-footer-links{margin-left:auto;display:flex;gap:6px}.webapp-footer-links a{color:var(--text-dim);text-decoration:none}.webapp-footer-links a:hover{color:var(--accent);text-decoration:underline}.webapp-footer-sep{color:var(--border)}.webapp-bt-item.online-peer:hover{border-color:var(--accent);background:var(--accent-bg)}.webapp-bt-connected-tag{flex-shrink:0;font-size:10px;color:var(--green);font-weight:600;background:var(--green-bg);padding:2px 8px;border-radius:999px}.room-toggle{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;cursor:pointer;padding:4px 0;font-family:inherit;width:100%;text-align:left}.room-toggle:hover{color:var(--accent)}.room-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;display:flex;flex-direction:column;gap:10px}.room-url{font-size:12px;font-family:var(--font-mono);color:var(--text-muted);word-break:break-all;background:var(--bg);padding:8px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);margin:0}.preview-modal-dialog{min-width:480px;max-width:720px;width:90vw}.preview-content{margin:12px 0 16px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:var(--radius-sm);overflow:hidden;min-height:200px;max-height:60vh}.preview-image{max-width:100%;max-height:60vh;object-fit:contain}.preview-pdf{width:100%;height:60vh;border:none}.preview-text{width:100%;height:60vh;border:none;background:var(--bg)}.webapp-tx-cancel{color:var(--red)!important}.webapp-tx-cancel:hover{background:var(--red-bg)!important}.webapp-tx-badge.cancelled{background:var(--yellow-bg);color:var(--yellow)}.webapp-tx-badge.paused{background:var(--orange-bg, rgba(255, 165, 0, .15));color:var(--orange, #f5a623)}.webapp-tx.cancelled{border-left:3px solid var(--yellow);opacity:.7}.webapp-tx.paused{border-left:3px solid var(--orange, #f5a623);opacity:.85}.docs-page{min-height:100vh;background:var(--bg);color:var(--text);display:flex;flex-direction:column;font-family:var(--font-body, ui-sans-serif, system-ui, sans-serif)}.docs-topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:12px;padding:8px 18px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.docs-back-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);font-size:13px;cursor:pointer;font-family:inherit;transition:border-color .15s,color .15s}.docs-back-btn:hover{border-color:var(--accent);color:var(--accent)}.docs-wordmark{font-family:Chelsea Market,cursive;font-size:18px;color:var(--accent);letter-spacing:-.3px}.docs-wordmark span{color:var(--accent)}.docs-toggle{margin-left:auto;transform:scale(.7);transform-origin:right center}.docs-layout{display:flex;flex:1;max-width:1100px;width:100%;margin:0 auto;padding:0 24px}.docs-sidebar{width:200px;flex-shrink:0;padding:32px 16px 32px 0;position:sticky;top:56px;align-self:flex-start;display:flex;flex-direction:column;gap:4px}.docs-sidebar-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);margin-bottom:8px}.docs-sidebar-link{font-size:13px;color:var(--text-muted);text-decoration:none;padding:4px 8px;border-radius:4px;transition:background .1s,color .1s}.docs-sidebar-link:hover{background:var(--accent-bg);color:var(--accent)}.docs-content{flex:1;min-width:0;padding:32px 0 64px}.docs-h1{font-size:32px;font-weight:700;margin:0 0 8px;letter-spacing:-.5px}.docs-section{margin:40px 0;scroll-margin-top:72px}.docs-h2{font-size:20px;font-weight:600;margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid var(--border)}.docs-p{font-size:14px;line-height:1.7;color:var(--text-muted);margin:0 0 12px}.docs-ol{margin:0;padding:0 0 0 20px;display:flex;flex-direction:column;gap:8px}.docs-li{font-size:14px;line-height:1.6;color:var(--text-muted)}.docs-items{display:flex;flex-direction:column;gap:8px}.docs-tech-item{display:flex;flex-direction:column;gap:2px;padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px}.docs-tech-item strong{font-size:13px;font-weight:600;color:var(--text)}.docs-tech-item span{font-size:13px;color:var(--text-muted);line-height:1.5}.docs-faq{display:flex;flex-direction:column;gap:8px}.docs-details{border:1px solid var(--border);border-radius:8px;overflow:hidden}.docs-summary{font-size:14px;font-weight:500;color:var(--text);padding:12px 16px;cursor:pointer;background:var(--bg-secondary);transition:background .1s;-webkit-user-select:none;user-select:none}.docs-summary:hover{background:var(--bg-card)}.docs-details[open] .docs-summary{border-bottom:1px solid var(--border)}.docs-details[open] .docs-p{padding:12px 16px;margin:0}.docs-changelog{display:flex;flex-direction:column;gap:16px}.docs-cl-item{border:1px solid var(--border);border-radius:8px;overflow:hidden}.docs-cl-header{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.docs-cl-version{font-size:14px;font-weight:700;font-family:var(--font-mono);color:var(--accent)}.docs-cl-date{font-size:12px;color:var(--text-dim)}.docs-cl-list{margin:0;padding:10px 16px 10px 32px;display:flex;flex-direction:column;gap:4px}.docs-cl-list li{font-size:13px;color:var(--text-muted);line-height:1.5}.docs-footer{border-top:1px solid var(--border);margin-top:48px;padding-top:24px;text-align:center;font-size:12px;color:var(--text-dim)}.docs-footer p{margin:4px 0}.docs-footer a{color:var(--accent);text-decoration:none}.docs-footer a:hover{text-decoration:underline}.docs-footer-sep{margin:0 8px;color:var(--border)}@media(max-width:768px){.docs-sidebar{display:none}.docs-layout{padding:0 16px}}.pwa-prompt-overlay{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:9999;max-width:420px;width:calc(100% - 32px);animation:pwaSlideUp .3s ease-out}@keyframes pwaSlideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.pwa-prompt{display:flex;align-items:center;gap:12px;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:0 8px 32px #0000004d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.pwa-prompt-icon{flex-shrink:0}.pwa-prompt-text{flex:1;display:flex;flex-direction:column;gap:2px;font-size:13px;line-height:1.4}.pwa-prompt-text strong{color:var(--text)}.pwa-prompt-text span{color:var(--text-dim)}.pwa-prompt-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0}.pwa-prompt-btn{border:none;border-radius:6px;padding:6px 14px;font-size:12px;cursor:pointer;white-space:nowrap;transition:opacity .15s}.pwa-prompt-btn:hover{opacity:.85}.pwa-prompt-primary{background:var(--accent);color:#fff}.pwa-prompt-cancel{background:transparent;color:var(--text-dim);border:1px solid var(--border)}.update-overlay{position:fixed;bottom:16px;right:16px;z-index:9998;max-width:380px;width:calc(100% - 32px);animation:pwaSlideUp .3s ease-out}.update-prompt{display:flex;align-items:center;gap:12px;background:var(--card-bg);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:10px;padding:14px 16px;box-shadow:0 8px 32px #0000004d}.update-icon{flex-shrink:0;color:var(--accent)}.update-text{flex:1;display:flex;flex-direction:column;gap:2px;font-size:13px;line-height:1.4}.update-text strong{color:var(--text)}.update-text span{color:var(--text-dim);font-size:11px}.update-actions{display:flex;gap:6px;flex-shrink:0}.update-btn{border:none;border-radius:6px;padding:6px 14px;font-size:12px;cursor:pointer;white-space:nowrap;text-decoration:none;transition:opacity .15s}.update-btn:hover{opacity:.85}.update-primary{background:var(--accent);color:#fff}.update-skip{background:transparent;color:var(--text-dim);border:1px solid var(--border)}.wc-contacts{margin-top:4px}.wc-contact-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0;border-bottom:1px solid var(--border)}.wc-contact-row:last-child{border-bottom:none}.wc-contact-info{display:flex;flex-direction:column;gap:1px;min-width:0;overflow:hidden}.wc-contact-name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wc-contact-id{font-size:11px;color:var(--text-dim);font-family:monospace}.wc-contact-actions{display:flex;gap:4px;flex-shrink:0}.wc-contact-connect,.wc-contact-remove{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:1px solid var(--border);border-radius:6px;background:transparent;cursor:pointer;color:var(--text-dim);transition:all .15s}.wc-contact-connect:hover{color:var(--accent);border-color:var(--accent)}.wc-contact-remove:hover{color:var(--danger, #e74c3c);border-color:var(--danger, #e74c3c)}.wc-contact-add-form{display:flex;flex-direction:column;gap:4px;margin-top:6px}.wc-contact-input{font-size:12px;padding:6px 8px;border:1px solid var(--border);border-radius:6px;background:var(--input-bg, var(--bg));color:var(--text);outline:none}.wc-contact-input:focus{border-color:var(--accent)}.wc-contact-add-actions{display:flex;gap:6px}
