:root{--fg: #1a2230;--accent: #0c9486;--warn: #d62246;--dim: rgba(26, 34, 48, .5);--mono: "SF Mono", "JetBrains Mono", "Menlo", "Consolas", monospace}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden;background:#c4c9d0;font-family:var(--mono);color:var(--fg)}#scene{display:block;width:100vw;height:100vh;position:fixed;top:0;right:0;bottom:0;left:0;cursor:none}#cs-overlay{position:fixed;bottom:0;left:50%;transform:translate(-50%);max-width:96vw;max-height:96vh;display:block;pointer-events:none;z-index:6;-webkit-user-drag:none}#scoreboard{position:fixed;left:14px;top:50%;transform:translateY(-50%);z-index:7;pointer-events:none;display:flex;flex-direction:column;gap:3px;font-family:var(--mono);font-size:13px;background:#ffffff80;padding:8px 10px;border-radius:8px}.score-row{display:flex;justify-content:space-between;gap:14px;color:var(--fg)}.score-row.self .score-name{color:var(--accent);font-weight:700}.score-name{max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.score-num{color:var(--accent)}#fps-counter{position:fixed;top:10px;left:12px;z-index:50;font-family:var(--mono);font-size:13px;font-weight:600;color:var(--accent);background:#ffffff8c;padding:3px 8px;border-radius:6px;pointer-events:none;letter-spacing:1px}.gp-focus{outline:2px solid var(--accent)!important;outline-offset:3px;box-shadow:0 0 0 4px #0c948640!important}#hud{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;-webkit-user-select:none;user-select:none;text-shadow:0 0 6px rgba(255,255,255,.7)}#hud-top{position:absolute;top:24px;left:50%;transform:translate(-50%);display:flex;gap:40px;font-size:14px;letter-spacing:1px}.stat{display:flex;align-items:baseline;gap:6px}.stat .label{color:var(--accent);font-size:11px}.stat .unit{color:var(--dim);font-size:10px}.stat span:nth-child(2){font-size:18px;min-width:52px;display:inline-block;text-align:right}#target-flash{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:0;z-index:5;box-shadow:inset 0 0 70px 14px #78ffee,inset 0 0 160px 44px #29e0c9cc;background:radial-gradient(ellipse at center,rgba(120,255,238,.16),transparent 58%)}#target-flash.flash{animation:targetFlash .55s cubic-bezier(.22,1,.36,1)}@keyframes targetFlash{0%{opacity:0}8%{opacity:1}30%{opacity:.35}44%{opacity:.7}to{opacity:0}}#crash-flash{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:0;z-index:5;box-shadow:inset 0 0 80px 16px #fff,inset 0 0 180px 50px #ebf0f5cc;background:radial-gradient(ellipse at center,rgba(255,255,255,.16),transparent 58%)}#crash-flash.flash{animation:targetFlash .6s cubic-bezier(.22,1,.36,1)}#target-pop{position:absolute;top:-6px;left:50%;transform:translate(-50%);color:var(--accent);font-weight:800;font-size:22px;text-shadow:0 0 12px rgba(64,240,218,.9);pointer-events:none;animation:targetPop .7s ease-out forwards}@keyframes targetPop{0%{opacity:0;transform:translate(-50%,6px) scale(.6)}20%{opacity:1;transform:translate(-50%,-4px) scale(1.15)}to{opacity:0;transform:translate(-50%,-30px) scale(1)}}#targets-label.pulse{animation:targetPulse .4s ease-out}@keyframes targetPulse{0%{transform:scale(1);color:var(--fg)}25%{transform:scale(1.18);color:var(--accent);text-shadow:0 0 10px rgba(64,240,218,.8)}to{transform:scale(1)}}#targets{position:absolute;top:64px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:6px}#targets-bar-wrap{width:240px;height:6px;background:#1a22302e;border:1px solid var(--dim);border-radius:4px;overflow:hidden}#targets-bar{height:100%;width:0%;background:linear-gradient(to right,var(--accent),#6cf0ff);transition:width .25s ease}#targets-label{font-size:11px;letter-spacing:1px;color:var(--fg)}#crosshair{position:absolute;top:50%;left:50%;width:22px;height:22px;transform:translate(-50%,-50%);border:1px solid var(--accent);border-radius:50%;opacity:.5}#crosshair:before,#crosshair:after{content:"";position:absolute;background:var(--accent)}#crosshair:before{top:50%;left:-10px;width:7px;height:1px;box-shadow:25px 0 0 var(--accent)}#crosshair:after{left:50%;top:-10px;width:1px;height:7px;box-shadow:0 25px 0 var(--accent)}#hud-bottom{position:absolute;bottom:28px;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-end;padding:0 40px}#throttle-wrap{width:18px;height:160px;border:1px solid var(--dim);border-radius:3px;position:relative;display:flex;align-items:flex-end}#throttle-bar{width:100%;height:0%;background:linear-gradient(to top,var(--accent),#6cf0ff);transition:height .05s linear}#throttle-wrap .label{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:10px;color:var(--accent)}#status{display:flex;flex-direction:column;align-items:flex-end;gap:6px;font-size:13px}#armed-status{font-weight:700;letter-spacing:2px}#armed-status.armed{color:var(--accent)}#armed-status.disarmed{color:var(--warn)}#pad-status.pad-on{color:var(--accent)}#pad-status.pad-off,#view-status{color:var(--dim)}#sticks{position:absolute;bottom:28px;left:50%;transform:translate(-50%);display:flex;gap:24px}.stick{width:70px;height:70px;border:1px solid var(--dim);border-radius:6px;position:relative}.stick .dot{position:absolute;width:10px;height:10px;background:var(--accent);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 8px var(--accent)}#help{position:fixed;top:0;right:0;bottom:0;left:0;background:#c4c9d0f0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;z-index:10}#help h1{font-size:52px;letter-spacing:14px;color:var(--fg);font-weight:600}#help .sub{color:var(--accent);letter-spacing:4px;font-size:14px}#help .start{margin-top:30px;color:var(--fg);font-size:16px;letter-spacing:1px;animation:pulse 1.6s infinite}#help .hint-line{margin-top:14px;color:var(--dim);font-size:12px}#help .hint-line b{color:var(--accent)}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}#complete{position:fixed;top:0;right:0;bottom:0;left:0;z-index:15;display:flex;align-items:center;justify-content:center;background:#c4c9d0d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.complete-card{text-align:center;background:#eef1f5;border:1px solid #aab2bd;border-radius:14px;padding:40px 56px;box-shadow:0 24px 70px #00000047}.complete-card h1{font-size:44px;letter-spacing:10px;color:var(--accent);font-weight:700}.complete-sub{color:var(--dim);letter-spacing:2px;font-size:13px;margin-top:8px}.complete-stats{margin:22px 0 26px;font-size:16px;color:var(--fg)}#complete-next{pointer-events:auto;cursor:pointer;font-family:var(--mono);font-size:14px;letter-spacing:1px;color:#fff;background:var(--accent);border:1px solid var(--accent);border-radius:8px;padding:12px 22px;transition:background .15s}#complete-next:hover{background:#0aa996}.complete-hint{margin-top:14px;color:var(--dim);font-size:12px;animation:pulse 1.6s infinite}#settings-btn{position:fixed;top:22px;right:26px;pointer-events:auto;cursor:pointer;z-index:12;font-family:var(--mono);font-size:12px;letter-spacing:1px;color:var(--fg);background:#ffffff59;border:1px solid var(--dim);border-radius:6px;padding:6px 10px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .15s}#settings-btn:hover{background:#ffffffb3}#settings{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;background:#8c949e8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}#settings .panel{width:820px;max-width:94vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;background:#eef1f5;border:1px solid #aab2bd;border-radius:12px;padding:22px 26px;box-shadow:0 20px 60px #00000040;color:var(--fg)}.panel-head,.tabs{flex-shrink:0}.tab-page{overflow-y:auto;flex:1 1 auto;min-height:0;padding-right:6px}.set-cols{display:grid;grid-template-columns:minmax(420px,1.3fr) minmax(240px,1fr);gap:0 30px;align-items:start;margin-top:4px}.set-col{min-width:0}.col-head{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim);font-weight:700;margin:0 0 10px;padding-bottom:8px;border-bottom:1px solid #dde2e8}@media (max-width: 800px){.set-cols{grid-template-columns:1fr;gap:0}}.set-extra{margin-top:4px}.set-extra .slider-opt{max-width:560px}.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.panel-head h2{font-size:18px;letter-spacing:2px;color:var(--fg)}#settings-close{background:none;border:none;color:var(--dim);font-size:20px;cursor:pointer;line-height:1;padding:2px 6px}#settings-close:hover{color:var(--warn)}.tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid #dde2e8}.tab{font-family:var(--mono);cursor:pointer;font-size:13px;background:none;border:none;color:var(--dim);padding:8px 14px;border-bottom:2px solid transparent;margin-bottom:-1px}.tab:hover{color:var(--fg)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tuning-intro{font-size:12px;color:var(--dim);margin-bottom:12px;line-height:1.5}.perf-note{font-size:11px;color:var(--dim);margin:2px 0 10px;line-height:1.45;opacity:.85}#rate-curve{width:100%;max-width:440px;height:auto;display:block;background:#f6f8fa;border:1px solid #dde2e8;border-radius:8px}.curve-legend{display:flex;gap:16px;justify-content:center;margin:8px 0 18px;font-size:11px}.curve-legend .lg:before{content:"—";margin-right:4px;font-weight:700}.lg-roll{color:#ff3b5c}.lg-pitch{color:#12b5a0}.lg-yaw{color:#f2a900}.tune-cols{display:grid;grid-template-columns:minmax(300px,1fr) minmax(360px,1.1fr);gap:0 30px;align-items:start}@media (max-width: 800px){.tune-cols{grid-template-columns:1fr}}.rate-block{padding:10px 0;border-top:1px solid #dde2e8}#rates-ui .rate-block:first-child{border-top:none;padding-top:0}.rate-axis-title{font-size:13px;font-weight:700;margin-bottom:6px;letter-spacing:1px}.rate-val{min-width:56px;text-align:right;color:var(--accent)}.pad-line{font-size:12px;color:var(--dim);margin-bottom:10px}#settings-pad{color:var(--accent)}.hid-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}#hid-connect,#hid-calibrate,.bind-btn{font-family:var(--mono);cursor:pointer;font-size:12px;border:1px solid #aab2bd;background:#fff;color:var(--fg);border-radius:6px;padding:6px 10px}#hid-connect:hover,#hid-calibrate:hover:not(:disabled),.bind-btn:hover:not(:disabled){border-color:var(--accent);background:#f4fffe}#hid-calibrate:disabled,.bind-btn:disabled{opacity:.4;cursor:default}.hid-status-line{margin-bottom:12px}#hid-status{font-size:11px;color:var(--accent)}.hid-binds{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.binds-label{font-size:12px;color:var(--dim)}.bind-btn{padding:4px 10px}.presets{display:flex;align-items:center;gap:8px;margin-bottom:18px;flex-wrap:wrap}.presets-label{font-size:12px;color:var(--dim)}.preset,.panel-foot button,.detect-btn{font-family:var(--mono);cursor:pointer;border:1px solid #aab2bd;background:#fff;color:var(--fg);border-radius:6px;padding:6px 12px;font-size:12px;transition:background .12s,border-color .12s}.preset:hover,.panel-foot button:hover,.detect-btn:hover{border-color:var(--accent);background:#f4fffe}.preset.active{background:var(--accent);color:#fff;border-color:var(--accent)}.ch-row{display:grid;grid-template-columns:66px 64px 80px 84px 1fr;align-items:center;gap:8px;padding:8px 0;border-top:1px solid #dde2e8}#channels .ch-row:first-child{border-top:none;padding-top:2px}.ch-name{font-size:14px;font-weight:600}.ch-axis{font-size:11px;color:var(--dim);display:flex;align-items:center;gap:4px}.axis-select{font-family:var(--mono);padding:2px 4px;border-radius:4px;border:1px solid #aab2bd}.ch-inv{font-size:11px;color:var(--dim);display:flex;align-items:center;gap:4px;cursor:pointer}.detect-btn.detecting{background:var(--accent);color:#fff;border-color:var(--accent)}.ch-bar,.axis-bar{position:relative;height:10px;background:#dde2e8;border-radius:5px;overflow:hidden}.ch-bar:after,.axis-bar:after{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:#aab2bd}.ch-bar-fill,.axis-bar-fill{position:absolute;top:0;bottom:0;left:50%;width:0;background:var(--accent);border-radius:5px}.throttle-opt{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--fg);cursor:pointer;margin-top:12px;padding-top:12px;border-top:1px solid #dde2e8}.slider-opt{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--fg);margin-top:12px}.slider-opt span:first-child{min-width:150px}.slider-opt input[type=range]{flex:1;accent-color:var(--accent);cursor:pointer}#deadzone-val{min-width:42px;text-align:right;color:var(--accent)}.axes-monitor{margin-top:18px;padding-top:14px;border-top:1px solid #dde2e8}.mon-label{font-size:11px;color:var(--dim);margin-bottom:8px}#axes-list{display:grid;grid-template-columns:1fr 1fr;gap:0 28px}.axis-mon{display:grid;grid-template-columns:20px 1fr 46px;align-items:center;gap:8px;margin-bottom:5px}@media (max-width: 800px){#axes-list{grid-template-columns:1fr}}.axis-i{font-size:12px;color:var(--dim);text-align:center}.axis-v{font-size:12px;text-align:right}.no-pad{font-size:12px;color:var(--warn)}.panel-foot{display:flex;justify-content:flex-end;gap:10px;flex-shrink:0;margin-top:14px;padding-top:14px;border-top:1px solid #dde2e8}.panel-foot .primary{background:var(--accent);color:#fff;border-color:var(--accent)}.panel-foot .primary:hover{background:#0aa996}.complete-actions{display:flex;gap:10px;justify-content:center}.complete-hub{pointer-events:auto;cursor:pointer;font-family:var(--mono);font-size:14px;letter-spacing:1px;color:var(--fg);background:#fff;border:1px solid #aab2bd;border-radius:8px;padding:12px 22px;transition:border-color .15s}.complete-hub:hover{border-color:var(--accent)}#hub{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;background:linear-gradient(#c7ccd24d,#c7ccd21f)}.hub-bar{display:flex;align-items:center;gap:32px;padding:16px 32px;border-bottom:1px solid rgba(182,188,198,.7);background:#c7ccd2c7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.hub-logo{font-size:18px;font-weight:700;letter-spacing:6px;color:var(--fg)}.hub-tabs{display:flex;gap:4px;flex:1}.hub-tab{position:relative;font-family:var(--mono);cursor:pointer;background:none;border:none;color:var(--dim);font-size:14px;letter-spacing:1px;text-transform:uppercase;padding:8px 14px;border-bottom:2px solid transparent}.hub-tab:hover:not(.soon){color:var(--fg)}.hub-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.hub-tab.soon{color:var(--dim);opacity:.55;cursor:default}.tab-soon{font-size:8px;letter-spacing:1px;vertical-align:super;margin-left:4px}.hub-bar-right{display:flex;align-items:center;gap:12px}.hub-nick{font-family:var(--mono);font-size:12px;color:var(--fg);background:#fff6;border:1px solid var(--dim);border-radius:8px;padding:6px 10px;width:120px;outline:none}.hub-nick::placeholder{color:var(--dim)}.hub-nick:hover,.hub-nick:focus{border-color:var(--accent)}.lang-select{cursor:pointer;font-family:var(--mono);font-size:12px;color:var(--fg);background:#fff6;border:1px solid var(--dim);border-radius:8px;padding:6px 28px 6px 10px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.lang-select:hover{border-color:var(--accent)}.lang-select:focus{outline:none;border-color:var(--accent)}.hub-profile{display:flex;align-items:center;gap:8px;cursor:pointer;font-family:var(--mono);font-size:13px;color:var(--fg);background:#ffffff80;border:1px solid var(--dim);border-radius:999px;padding:5px 14px 5px 6px}.hub-profile:hover{background:#fff;border-color:var(--accent)}.hub-profile-name{letter-spacing:.5px}.hub-gear{cursor:pointer;font-size:16px;line-height:1;background:#ffffff80;border:1px solid var(--dim);border-radius:8px;padding:7px 9px;color:var(--fg)}.hub-gear:hover{background:#fff;border-color:var(--accent)}.hub-stage{position:relative;flex:1;min-height:0}.drone-showcase{position:absolute;left:50%;bottom:40px;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:14px}.drone-caption{text-align:center;pointer-events:none;text-shadow:0 0 10px rgba(255,255,255,.6)}.drone-caption-name{font-size:22px;font-weight:700;letter-spacing:6px;color:var(--fg)}.drone-caption-sub{font-size:12px;letter-spacing:3px;color:var(--accent);margin-top:4px;text-transform:uppercase}.drone-pills{display:flex;gap:8px}.drone-pill{cursor:pointer;font-family:var(--mono);font-size:15px;font-weight:700;color:var(--fg);background:#eef1f5d9;border:1px solid #cdd4dd;border-radius:10px;padding:8px 18px;transition:background .12s,border-color .12s}.drone-pill:hover{border-color:var(--accent)}.drone-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.play-panel{position:absolute;left:36px;bottom:36px;width:320px;display:flex;flex-direction:column;gap:12px}.size-tabs{display:flex;gap:6px}.size-tab{flex:1;cursor:pointer;font-family:var(--mono);font-size:12px;color:var(--fg);background:#eef1f5d9;border:1px solid #cdd4dd;border-radius:8px;padding:8px}.size-tab:hover{border-color:var(--accent)}.size-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.play-card{display:flex;align-items:center;gap:14px;background:#eef1f5eb;border:1px solid #cdd4dd;border-radius:12px;padding:12px}.play-thumb{width:72px;height:72px;border-radius:8px;flex-shrink:0;background:linear-gradient(135deg,#12b5a0,#3a7bff)}.play-card-title{font-size:16px;font-weight:700;color:var(--fg)}.play-card-sub{font-size:12px;color:var(--dim);margin-top:3px}.play-hint{font-size:12px;color:#8a5b00}.play-btn{cursor:pointer;font-family:var(--mono);font-weight:700;font-size:18px;letter-spacing:3px;color:#fff;background:var(--accent);border:1px solid var(--accent);border-radius:12px;padding:16px;transition:background .15s}.play-btn:hover:not(:disabled){background:#0aa996}.play-btn:disabled{opacity:.45;cursor:default}.stats-tab{padding:32px;display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap}.stats-main{flex:1 1 520px;min-width:0;max-width:640px}.leaderboard{flex:0 0 300px;background:#eef1f5eb;border:1px solid #cdd4dd;border-radius:12px;padding:16px 18px}.lb-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.lb-title{font-size:13px;font-weight:700;letter-spacing:1px;color:var(--fg);text-transform:uppercase}.lb-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--dim);cursor:pointer;white-space:nowrap}.lb-toggle input{accent-color:var(--accent)}.lb-list{max-height:460px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.lb-row{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:8px;font-size:13px;color:var(--fg)}.lb-row:nth-child(odd){background:#141a200a}.lb-row.you{background:var(--accent);color:#fff;font-weight:700}.lb-rank{flex:none;width:26px;text-align:right;font-family:var(--mono);color:var(--dim)}.lb-row.you .lb-rank{color:#fff}.lb-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-score{flex:none;font-family:var(--mono);font-weight:700}.lb-empty{color:var(--dim);font-size:13px;padding:14px 2px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.stat-card{background:#eef1f5eb;border:1px solid #cdd4dd;border-radius:12px;padding:22px 18px;text-align:center}.stat-value{font-size:30px;font-weight:700;color:var(--accent)}.stat-label{font-size:12px;color:var(--dim);margin-top:6px;letter-spacing:1px}.progress-chart{margin-top:18px;background:#eef1f5eb;border:1px solid #cdd4dd;border-radius:12px;padding:16px 18px}.chart-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px}.chart-title{font-size:13px;font-weight:700;color:var(--fg);letter-spacing:1px}.chart-now{font-size:14px;color:var(--accent);font-weight:700}.chart-svg{width:100%;height:150px;display:block}.chart-grid{stroke:#cdd4dd;stroke-width:1}.chart-area{fill:#0c94861f}.chart-line{fill:none;stroke:var(--accent);stroke-width:2;vector-effect:non-scaling-stroke}.chart-dot{fill:var(--accent)}.chart-lbl{fill:var(--dim);font-size:11px;font-family:var(--mono)}.chart-foot{font-size:11px;color:var(--dim);margin-top:8px;text-align:right}.chart-empty{margin-top:18px;padding:22px;text-align:center;font-size:13px;color:var(--dim);background:#eef1f5eb;border:1px dashed #cdd4dd;border-radius:12px}.tab-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;display:inline-flex;align-items:center;justify-content:center;background:#e0533a;color:#fff;font-size:10px;font-weight:700;border-radius:9px;line-height:1}.friends-tab{padding:32px;max-width:760px;display:flex;flex-direction:column;gap:16px}.friends-signin{text-align:center;padding:40px 20px;color:var(--dim);display:flex;flex-direction:column;align-items:center;gap:16px}.friends-top{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.friends-card,.friends-section{background:#eef1f5eb;border:1px solid #cdd4dd;border-radius:12px;padding:16px 18px}.friends-card-title{font-size:12px;font-weight:700;color:var(--fg);letter-spacing:1px;text-transform:uppercase;margin-bottom:12px}.code-chip{display:flex;align-items:center;gap:10px}.code-val{flex:1;font-family:var(--mono);font-size:24px;font-weight:700;letter-spacing:6px;color:var(--accent);background:#fff;border:1px solid #cdd4dd;border-radius:8px;padding:8px 12px;text-align:center}.code-copy{font-family:var(--mono);font-size:12px;cursor:pointer;color:var(--fg);background:#fff;border:1px solid #cdd4dd;border-radius:8px;padding:8px 12px}.code-copy:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.code-copy:disabled{opacity:.5;cursor:default}.code-meta{display:flex;align-items:center;justify-content:space-between;margin-top:10px;font-size:12px;color:var(--dim)}.code-regen{font-family:var(--mono);font-size:12px;cursor:pointer;color:var(--accent);background:none;border:none;padding:0}.code-regen:hover{text-decoration:underline}.add-row{display:flex;gap:8px}.add-input{flex:1;font-family:var(--mono);font-size:16px;letter-spacing:3px;text-transform:uppercase;background:#fff;border:1px solid #cdd4dd;border-radius:8px;padding:8px 12px;color:var(--fg)}.add-input:focus{outline:none;border-color:var(--accent)}.btn-primary{font-family:var(--mono);font-size:13px;cursor:pointer;color:#fff;background:var(--accent);border:none;border-radius:8px;padding:8px 16px;font-weight:700}.btn-primary:hover{filter:brightness(1.08)}.add-msg{margin-top:8px;font-size:12px;color:var(--accent)}.friend-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid rgba(205,212,221,.6)}.friend-row:last-child{border-bottom:none}.friend-name{display:flex;align-items:center;gap:8px;color:var(--fg);font-size:14px}.friend-nick{color:var(--dim);font-size:12px;margin-left:6px}.status-dot{width:9px;height:9px;border-radius:50%;flex:none}.status-dot.on{background:#23b26d;box-shadow:0 0 0 2px #23b26d33}.status-dot.off{background:#b8c0cc}.req-actions{display:flex;gap:6px}.req-pending{display:flex;align-items:center;gap:8px;color:var(--dim);font-size:12px}.btn-accept,.btn-decline{font-family:var(--mono);font-size:12px;cursor:pointer;border-radius:7px;padding:5px 12px;border:1px solid #cdd4dd;background:#fff}.btn-accept{color:#fff;background:var(--accent);border-color:var(--accent)}.btn-accept:hover{filter:brightness(1.08)}.btn-decline:hover{border-color:#e0533a;color:#e0533a}.btn-icon{font-family:var(--mono);font-size:13px;cursor:pointer;color:var(--dim);background:none;border:none;padding:2px 6px}.btn-icon:hover{color:#e0533a}.friends-empty{color:var(--dim);font-size:13px;padding:8px 0}.party-leave-row{margin-top:12px}.invite-flash{font-family:var(--mono);font-size:12px;color:var(--accent);white-space:nowrap}.party-invite{position:fixed;z-index:100;font-family:var(--mono)}.party-invite.full{top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0a0e148c}.party-invite.mini{top:16px;right:16px}.pi-card{background:#fff;border:1px solid #cdd4dd;border-radius:14px;padding:22px 26px;box-shadow:0 12px 40px #00000040;text-align:center;max-width:380px}.party-invite.mini .pi-card{padding:14px 16px;box-shadow:0 6px 20px #0003}.pi-text{color:var(--fg)}.party-invite.full .pi-text{font-size:20px;margin-bottom:18px}.party-invite.mini .pi-text{font-size:13px;margin-bottom:10px}.pi-text b{color:var(--accent)}.pi-actions{display:flex;gap:10px;justify-content:center}.party-invite.full .pi-actions button{padding:10px 22px;font-size:14px}.party-labels{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:12;overflow:hidden}.party-label{position:absolute;transform:translate(-50%,-100%);font-family:var(--mono);font-size:12px;font-weight:600;line-height:1;white-space:nowrap;color:#fff;background:#141a20b3;border-radius:8px;padding:4px 9px;box-shadow:0 2px 8px #00000040}.party-label.you{background:var(--accent)}.auth-avatar{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.auth-avatar.lg{width:56px;height:56px;font-size:24px;margin:0 auto}#auth-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:flex;align-items:center;justify-content:center;background:#c4c9d0eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.auth-card{position:relative;width:380px;max-width:92vw;text-align:center;background:#eef1f5;border:1px solid #aab2bd;border-radius:16px;padding:40px 36px 28px;box-shadow:0 24px 70px #00000047}.auth-close{position:absolute;top:14px;right:16px;cursor:pointer;background:none;border:none;color:var(--dim);font-size:18px}.auth-close:hover{color:var(--warn)}.auth-card h1{font-size:26px;letter-spacing:8px;color:var(--fg);font-weight:700}.auth-tagline{font-size:13px;color:var(--dim);margin:10px 0 26px;line-height:1.5}.sso-list{display:flex;flex-direction:column;gap:10px}.sso{display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;font-family:var(--mono);font-size:14px;color:var(--fg);background:#fff;border:1px solid #aab2bd;border-radius:10px;padding:12px 16px;transition:border-color .15s,background .15s}.sso:hover{border-color:var(--accent);background:#f4fffe}.sso-logo{flex-shrink:0}.sso.ghost{background:none}.auth-signed{display:flex;flex-direction:column;gap:14px;align-items:center}.auth-signed-name{font-size:16px;font-weight:700;color:var(--fg)}.auth-skip{display:block;width:100%;margin-top:18px;cursor:pointer;font-family:var(--mono);font-size:13px;color:var(--dim);background:none;border:none}.auth-skip:hover{color:var(--fg)}.auth-demo-note{font-size:10px;color:var(--dim);margin-top:12px}
