:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#ff5c75;--accent-secondary:#33dfff;--accent2:#33dfff;--accent-bg:rgba(255,61,90,.15);--accent-border:rgba(255,61,90,.5);--gradient:linear-gradient(135deg, #ff5c75 0%, #d06aca 50%, #33dfff 100%);--social-bg:rgba(47,48,58,.5);--shadow:rgba(0,0,0,.4) 0 10px 15px -3px, rgba(0,0,0,.25) 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (max-width:1024px){:root{font-size:16px}}@media (max-width:768px){:root{font-size:15px}h1{margin:16px 0;font-size:28px}h2{font-size:18px}input,select,textarea{font-size:16px}}@media (max-width:480px){:root{font-size:14px}h1{margin:12px 0;font-size:22px}h2{font-size:16px}}#social .button-icon{filter:invert()brightness(2)}#root{text-align:center;width:100%;max-width:100%;min-height:calc(var(--vh,1vh) * 100);box-sizing:border-box;flex-direction:column;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (max-width:1024px){h1{margin:20px 0;font-size:36px}h2{font-size:20px}}@media (max-width:768px){h1{margin:16px 0;font-size:28px}h2{font-size:18px}}@media (max-width:480px){h1{margin:12px 0;font-size:22px}h2{font-size:16px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.admin-login-screen{min-height:calc(var(--vh,1vh) * 100);justify-content:center;align-items:center;padding:2rem;font-family:system-ui,-apple-system,sans-serif;display:flex}.admin-login-card{background:var(--code-bg,#1f2028);border:1px solid var(--border,#2e303a);text-align:center;border-radius:12px;width:100%;max-width:380px;padding:2.5rem}.btn-admin-gear{color:var(--text,#9ca3af);cursor:pointer;opacity:.6;background:0 0;border:none;align-items:center;margin:0;padding:.15rem .4rem;font-size:1rem;transition:opacity .15s,color .15s;display:flex}.btn-admin-gear:hover{opacity:1;color:var(--text-h,#f3f4f6)}.admin-layout{height:calc(var(--vh,1vh) * 100);font-family:system-ui,-apple-system,sans-serif;display:flex;overflow:hidden}.admin-sidebar{background:var(--code-bg,#1f2028);border-right:1px solid var(--border,#2e303a);flex-direction:column;width:240px;min-width:240px;height:100%;display:flex;overflow-y:auto}.admin-sidebar-brand{color:var(--text-h,#f3f4f6);letter-spacing:.02em;padding:1.5rem 1.25rem 1rem;font-size:1.1rem;font-weight:700}.admin-sidebar-brand span{color:var(--accent2,#33dfff)}.admin-sidebar-nav{flex:1;padding:.25rem 0}.admin-nav-item{width:100%;color:var(--text,#9ca3af);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:0;align-items:center;margin:0;padding:.7rem 1.25rem;font-size:.9rem;font-weight:500;transition:background .15s,color .15s;display:flex;position:relative}.admin-nav-item:hover{color:var(--text-h,#f3f4f6);background:rgba(255,255,255,.04)}.admin-nav-item-active{color:var(--text-h,#f3f4f6);background:rgba(51,223,255,.08)}.admin-nav-item-active:before{content:"";background:var(--accent2,#33dfff);border-radius:0 2px 2px 0;width:3px;position:absolute;top:.35rem;bottom:.35rem;left:0}.admin-nav-badge{color:var(--accent2,#33dfff);text-align:center;background:rgba(51,223,255,.15);border-radius:10px;min-width:1.2rem;margin-left:auto;padding:.1rem .5rem;font-size:.75rem;font-weight:600}.admin-sidebar-footer{border-top:1px solid var(--border,#2e303a);padding:1rem 1.25rem}.admin-sidebar-footer-row{margin-bottom:.5rem;display:flex}.admin-sidebar-footer-row>*+*{margin-left:.5rem}.admin-btn-footer{border:1px solid var(--border,#2e303a);color:var(--text,#9ca3af);cursor:pointer;background:0 0;border-radius:6px;flex:1;margin:0;padding:.5rem .75rem;font-size:.85rem;transition:color .15s,border-color .15s}.admin-btn-footer:hover{color:var(--text-h,#f3f4f6);border-color:#555}.admin-btn-logout{border:1px solid var(--border,#2e303a);width:100%;color:var(--text,#9ca3af);cursor:pointer;background:0 0;border-radius:6px;margin:0;padding:.5rem .75rem;font-size:.85rem;transition:color .15s,border-color .15s}.admin-btn-logout:hover{color:#f87171;border-color:#f87171}.admin-main{flex-direction:column;flex:1;min-width:0;height:100%;display:flex}.admin-topbar{border-bottom:1px solid var(--border,#2e303a);background:var(--code-bg,#1f2028);flex-shrink:0;align-items:center;padding:1rem 2rem;display:flex}.admin-topbar-info{flex:1;min-width:0}.admin-topbar-title{color:var(--text-h,#f3f4f6);margin:0;font-size:1.25rem;font-weight:700}.admin-topbar-desc{color:var(--text,#9ca3af);margin:.15rem 0 0;font-size:.85rem}.admin-topbar-actions{flex-shrink:0;align-items:center;display:flex}.admin-topbar-actions>*+*{margin-left:.75rem}.admin-save-msg{font-size:.85rem;font-weight:500}.admin-hamburger{border:1px solid var(--border,#2e303a);color:var(--text-h,#f3f4f6);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;margin-right:1rem;padding:.3rem .55rem;font-size:1.3rem;display:none}.admin-sidebar-overlay{display:none}.admin-page-content{flex:1;padding:2rem;overflow-y:auto}.admin-card{background:var(--code-bg,#1f2028);border:1px solid var(--border,#2e303a);border-radius:10px;padding:1.5rem}.admin-card-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.admin-card-title{color:var(--text-h,#f3f4f6);margin:0;font-size:1rem;font-weight:600}.admin-btn-group{flex-wrap:wrap;display:flex}.admin-btn-group>*+*{margin-left:.5rem}.admin-btn-group>*{margin-top:.25rem;margin-bottom:.25rem}.admin-btn-option{background:var(--bg,#16171d);color:var(--text,#9ca3af);cursor:pointer;border:1px solid #333;border-radius:8px;margin:0;padding:.5rem 1.2rem;font-size:.9rem;font-weight:400;transition:border-color .15s,background .15s,color .15s}.admin-btn-option:hover{color:var(--text-h,#f3f4f6);border-color:#555}.admin-btn-option-active{border:2px solid var(--accent2,#33dfff);color:#fff;background:rgba(51,223,255,.1);font-weight:600}.admin-form-grid{grid-gap:1.25rem;grid-template-columns:1fr 1fr;display:grid}.admin-form-section{margin-bottom:1.5rem}.admin-form-section:last-child{margin-bottom:0}.admin-divider{background:var(--border,#2e303a);height:1px;margin:1.25rem 0}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th{text-align:left;color:var(--text,#9ca3af);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border,#2e303a);padding:.6rem .75rem;font-size:.75rem;font-weight:600}.admin-table td{color:var(--text-h,#f3f4f6);vertical-align:middle;border-bottom:1px solid rgba(46,48,58,.5);padding:.6rem .75rem}.admin-table tr:hover td{background:rgba(255,255,255,.02)}.admin-table tr.admin-table-row-active td{background:rgba(51,223,255,.06)}.admin-table-thumb{object-fit:cover;border-radius:3px;width:48px;height:36px;display:block}.admin-table-thumb-empty{background:var(--border,#2e303a);width:48px;height:36px;color:var(--text,#9ca3af);border-radius:3px;justify-content:center;align-items:center;font-size:.6rem;display:flex}.admin-table-link{color:var(--accent2,#33dfff);text-decoration:none}.admin-table-link:hover{text-decoration:underline}.admin-table-mono{color:var(--text,#9ca3af);font-family:monospace;font-size:.8rem}.admin-table-actions{display:flex}.admin-table-actions>*+*{margin-left:.5rem}.admin-btn-action{border:1px solid var(--border,#2e303a);color:var(--text,#9ca3af);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;margin:0;padding:.25rem .6rem;font-size:.75rem;transition:color .15s,border-color .15s}.admin-btn-action:hover{color:var(--text-h,#f3f4f6);border-color:#555}.admin-btn-action-danger{border:1px solid var(--border,#2e303a);color:#f87171;cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;margin:0;padding:.25rem .6rem;font-size:.75rem;transition:border-color .15s}.admin-btn-action-danger:hover{border-color:#f87171}.admin-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.admin-status-dot-lobby{background:var(--accent2,#33dfff)}.admin-status-dot-active{background:#22c55e;animation:2s ease-in-out infinite admin-pulse}@keyframes admin-pulse{0%,to{opacity:1}50%{opacity:.4}}.admin-realms-grid{grid-gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.admin-realm-card{background:var(--code-bg,#1f2028);border:1px solid var(--border,#2e303a);border-radius:10px;flex-direction:column;padding:1.25rem;display:flex}.admin-realm-card>*+*{margin-top:.75rem}.admin-realm-top{align-items:center;display:flex}.admin-realm-top>*+*{margin-left:.5rem}.admin-realm-mode{color:var(--text-h,#f3f4f6);font-size:1rem;font-weight:600}.admin-realm-status{border-radius:10px;margin-left:auto;padding:.15rem .5rem;font-size:.75rem;font-weight:500}.admin-realm-status-lobby{color:var(--accent2,#33dfff);background:rgba(51,223,255,.12)}.admin-realm-status-active{color:#22c55e;background:rgba(34,197,94,.12)}.admin-realm-joincode{letter-spacing:.18em;color:var(--accent2,#33dfff);text-align:center;background:rgba(51,223,255,.06);border-radius:6px;padding:.5rem .75rem;font-family:monospace;font-size:1.6rem;font-weight:700}.admin-realm-connected{color:var(--text,#9ca3af);font-size:.85rem}.admin-realm-bottom{justify-content:space-between;align-items:center;margin-top:auto;padding-top:.5rem;display:flex}.admin-realm-bottom-actions{display:flex}.admin-realm-bottom-actions>*+*{margin-left:.5rem}.admin-empty-state{text-align:center;color:var(--text,#9ca3af);padding:3rem 1rem;font-size:.95rem}.admin-input{border:2px solid var(--border,#2e303a);background:var(--bg,#16171d);width:100%;color:var(--text-h,#f3f4f6);box-sizing:border-box;border-radius:6px;padding:.6rem .75rem;font-size:1rem}.admin-input:focus{border-color:var(--accent2,#33dfff);outline:none}.admin-label{color:var(--text,#9ca3af);margin-bottom:.4rem;font-size:.85rem;font-weight:500;display:block}.admin-btn-primary{background:var(--accent2,#33dfff);color:#0f172a;cursor:pointer;border:none;border-radius:8px;margin:0;padding:.6rem 1.5rem;font-size:1rem;font-weight:600}.admin-btn-primary:hover{opacity:.85}.admin-btn-primary:disabled{opacity:.5;cursor:default}.admin-btn-secondary{border:1px solid var(--border,#2e303a);color:var(--text,#9ca3af);cursor:pointer;background:0 0;border-radius:8px;margin:0;padding:.6rem 1.5rem;font-size:1rem}.admin-btn-secondary:hover{color:var(--text-h,#f3f4f6);border-color:#555}.admin-btn-back{color:var(--text,#9ca3af);cursor:pointer;background:0 0;border:none;margin-top:1rem;padding:.5rem;font-size:.9rem}.admin-btn-back:hover{color:var(--text-h,#f3f4f6);background:0 0}.admin-btn-add{border:1px dashed var(--border,#2e303a);color:var(--text,#9ca3af);cursor:pointer;background:0 0;border-radius:8px;margin:0;padding:.5rem 1.2rem;font-size:.85rem;transition:color .15s,border-color .15s}.admin-btn-add:hover{color:var(--text-h,#f3f4f6);border-color:#555}.admin-edit-panel{background:var(--bg,#16171d);border:1px solid var(--accent2,#33dfff);border-radius:8px;margin-top:1.25rem;padding:1.25rem}.admin-edit-panel>*+*{margin-top:.75rem}.admin-edit-panel-actions{display:flex}.admin-edit-panel-actions>*+*{margin-left:.5rem}.admin-slider-row{align-items:center;display:flex}.admin-slider-row>*+*{margin-left:1rem}.admin-slider-value{color:var(--text-h,#f3f4f6);min-width:70px;font-size:1.1rem;font-weight:700}.admin-thumb-section{align-items:center;display:flex}.admin-thumb-section>*+*{margin-left:.75rem}.admin-thumb-preview{object-fit:cover;border-radius:4px;width:96px;height:72px}.admin-thumb-empty{background:var(--border,#2e303a);width:96px;height:72px;color:var(--text,#9ca3af);border-radius:4px;justify-content:center;align-items:center;font-size:.75rem;display:flex}.admin-thumb-controls{flex-direction:column;display:flex}.admin-thumb-controls>*+*{margin-top:.4rem}.admin-upload-label{color:var(--text,#9ca3af);cursor:pointer;background:0 0;border:1px solid #555;border-radius:6px;padding:.25rem .75rem;font-size:.8rem;transition:color .15s,border-color .15s;display:inline-block}.admin-upload-label:hover{color:var(--text-h,#f3f4f6);border-color:#777}.admin-remove-thumb{color:#f87171;cursor:pointer;background:0 0;border:1px solid #555;border-radius:6px;margin:0;padding:.25rem .75rem;font-size:.8rem}.admin-remove-thumb:hover{border-color:#f87171}.admin-screen{height:calc(var(--vh,1vh) * 100);flex-direction:column;justify-content:center;align-items:center;padding:2rem;font-family:system-ui,-apple-system,sans-serif;display:flex}@media (max-width:767px){.admin-hamburger{justify-content:center;align-items:center;display:flex}.admin-sidebar{z-index:200;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.admin-sidebar.admin-sidebar-open{transform:translate(0)}.admin-sidebar-overlay{z-index:199;background:rgba(0,0,0,.5);display:none;position:fixed;top:0;bottom:0;left:0;right:0}.admin-sidebar-overlay.admin-sidebar-overlay-visible{display:block}.admin-topbar{padding:.75rem 1rem}.admin-topbar-info{margin-left:.75rem}.admin-page-content{padding:1rem}.admin-form-grid,.admin-realms-grid{grid-template-columns:1fr}}.app{text-align:center;max-width:800px;margin:0 auto;padding:2rem}.home-screen{min-height:calc(var(--vh,1vh) * 100);flex-direction:column;display:flex}.home-body{flex-direction:row;flex:1;display:flex}.home-body:before{content:"";flex-shrink:0;width:120px}.home-content{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:1rem 2rem;display:flex}.home-subtitle{color:var(--text,#9ca3af);margin-bottom:1.25rem;font-size:1.1rem}.mode-section{width:100%;max-width:820px}.mode-section+.mode-section{margin-top:1.5rem}.mode-section-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--text,#9ca3af);margin:0 0 .75rem .25rem;font-size:.8rem;font-weight:600}.mode-grid{grid-template-columns:repeat(3,1fr);gap:1rem;width:100%;display:grid}.mode-card{background:var(--code-bg,#1f2028);border:1px solid var(--border,#2e303a);cursor:pointer;border-radius:12px;flex-direction:column;align-items:center;margin:0;padding:1.25rem 1rem;transition:border-color .2s,transform .15s,box-shadow .2s;display:flex}.mode-card>*+*{margin-top:.5rem}.mode-card:hover:not(:disabled){border-color:var(--accent,#ff5c75);transform:translateY(-2px);box-shadow:0 4px 20px rgba(255,92,117,.15)}.mode-card:active:not(:disabled){transform:translateY(0)scale(.98)}.mode-icon{font-size:1.75rem;line-height:1}.mode-name{color:var(--text-h,#f3f4f6);font-size:1rem;font-weight:600}.mode-desc{color:var(--text,#9ca3af);font-size:.85rem}.btn-join-link{color:var(--text,#9ca3af);font-size:inherit;cursor:pointer;text-underline-offset:2px;background:0 0;border:none;margin:0;padding:0;font-weight:500;text-decoration:underline;transition:color .2s}.btn-join-link:hover{color:var(--text-h,#f3f4f6);background:0 0}.join-modal{max-width:380px}.input-join-code{width:140px;font-size:1.4rem;font-family:var(--mono,monospace);text-align:center;letter-spacing:.2em;border:2px solid var(--border,#2e303a);background:var(--code-bg,#1f2028);color:var(--text-h,#f3f4f6);border-radius:8px;margin:0 auto .75rem;padding:.6rem .75rem;display:block}.input-join-code:focus{border-color:var(--accent2,#33dfff);outline:none}.input-host-key{border:1px solid var(--border,#2e303a);background:var(--bg,#16171d);width:100%;color:var(--text-h,#f3f4f6);box-sizing:border-box;border-radius:6px;margin-bottom:.75rem;padding:.4rem .6rem;font-size:.85rem}.input-host-key:focus{border-color:var(--accent2,#33dfff);outline:none}.btn-join-go{background:var(--accent2,#33dfff);color:#0f172a;cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.5rem;font-size:1rem;font-weight:600}.btn-join-go:hover{opacity:.85}.join-modal-actions{justify-content:center;display:flex}.join-modal-actions>*+*{margin-left:.75rem}.join-modal-actions .btn-join-go,.join-modal-actions .qr-close{margin-top:0}.home-tagline{color:var(--text,#9ca3af);opacity:.5;text-align:center;max-width:500px;margin-top:1.25rem;font-size:.85rem;line-height:1.5}.server-footer{color:var(--text,#9ca3af);opacity:.7;border-top:1px solid var(--border,#2e303a);justify-content:space-between;align-items:center;padding:.75rem 1.5rem;font-size:.8rem;display:flex}.server-footer:hover{opacity:1}.footer-left,.footer-right{align-items:center;display:flex}.footer-left>*+*,.footer-right>*+*{margin-left:.75rem}.footer-right>*+:before{content:"·";opacity:.5;margin-right:.75rem}.server-version{opacity:.6;margin-left:.4rem}.btn-server-name{color:inherit;font-size:inherit;cursor:pointer;opacity:.8;background:0 0;border:none;margin:0;padding:0}.btn-server-name:hover{opacity:1;text-underline-offset:2px;background:0 0;text-decoration:underline}.btn-tos-link{color:inherit;cursor:pointer;opacity:.8;text-underline-offset:2px;background:0 0;border:none;margin:0;padding:.15rem .5rem;font-size:.75rem;text-decoration:underline}.btn-tos-link:hover{opacity:1;background:0 0}.tos-page{min-height:calc(var(--vh,1vh) * 100);text-align:left;flex-direction:column;align-items:center;display:flex}.tos-header{z-index:100;background:var(--bg,#16171d);border-bottom:1px solid var(--border,#2e303a);align-items:center;width:100%;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.tos-header>*+*{margin-left:1rem}.tos-header-title{color:var(--text,#9ca3af);font-size:.9rem}.tos-container{width:100%;max-width:720px;color:var(--text-h,#f3f4f6);padding:2rem 2rem 4rem}.tos-container h1{margin:0 0 .25rem;font-size:2rem}.tos-updated{color:var(--text,#9ca3af);border-bottom:1px solid var(--border,#2e303a);margin-bottom:2rem;padding-bottom:1.5rem;font-size:.85rem}.tos-container h2{color:var(--text-h,#f3f4f6);margin:0 0 .5rem;font-size:1.15rem}.tos-container p{color:var(--text,#9ca3af);margin:.4rem 0;font-size:.95rem;line-height:1.7}.tos-container ul{color:var(--text,#9ca3af);margin:.5rem 0;padding-left:1.5rem;font-size:.95rem;line-height:1.8}.tos-container section{border-top:1px solid var(--border,#2e303a);margin-bottom:1.5rem;padding-top:1.5rem}.tos-back{color:var(--accent-secondary,#33dfff);cursor:pointer;white-space:nowrap;background:0 0;border:none;margin:0;padding:.25rem 0;font-size:.9rem}.tos-back:hover{background:0 0;text-decoration:underline}.device-sidebar{color:var(--text,#9ca3af);opacity:.5;border-left:1px solid var(--border,#2e303a);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:120px;padding:1rem 1.25rem;font-size:.8rem;transition:opacity .2s;display:flex}.device-sidebar>*+*{margin-top:.5rem}.device-sidebar:hover{opacity:1}.device-sidebar-label{white-space:nowrap;opacity:.7;letter-spacing:.05em;margin-bottom:.25rem;font-size:.7rem}.device-link{border:1px solid var(--border,#2e303a);color:var(--text-h,#f3f4f6);cursor:pointer;text-align:center;background:0 0;border-radius:4px;width:80px;padding:.2rem .75rem;font-size:.75rem}.device-link:hover{border-color:var(--accent2,#33dfff);color:var(--accent2,#33dfff);background:rgba(255,255,255,.05)}.device-sidebar-divider{background:var(--border,#2e303a);width:60%;height:1px;margin:.5rem 0}.device-link-calibrate{color:var(--accent2,#33dfff);border-color:rgba(51,223,255,.3);font-size:.7rem}.device-link-calibrate:hover{border-color:var(--accent2,#33dfff);background:rgba(51,223,255,.1)}.qr-overlay{z-index:1000;background:rgba(0,0,0,.7);justify-content:center;align-items:center;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.qr-modal{background:var(--bg,#16171d);border:1px solid var(--border,#2e303a);text-align:center;border-radius:12px;width:90%;max-width:320px;padding:2rem}.join-bar-backdrop{z-index:1000;background:rgba(0,0,0,.7);position:fixed;top:0;bottom:0;left:0;right:0}.join-bar{z-index:1001;background:var(--bg,#16171d);border-bottom:1px solid var(--border,#2e303a);padding:.5rem .75rem;position:fixed;top:0;left:0;right:0}.join-bar-row{align-items:center;max-width:600px;margin:0 auto;display:flex}.join-bar-code{width:100px;font-size:1.1rem;font-family:var(--mono,monospace);text-align:center;letter-spacing:.15em;border:2px solid var(--border,#2e303a);background:var(--code-bg,#1f2028);color:var(--text-h,#f3f4f6);border-radius:6px;flex-shrink:0;margin-right:.5rem;padding:.5rem}.join-bar-code:focus{border-color:var(--accent2,#33dfff);outline:none}.join-bar-host{border:1px solid var(--border,#2e303a);background:var(--code-bg,#1f2028);min-width:0;color:var(--text-h,#f3f4f6);border-radius:6px;flex:1;margin-right:.5rem;padding:.5rem;font-size:.85rem}.join-bar-host:focus{border-color:var(--accent2,#33dfff);outline:none}.join-bar-go{background:var(--accent2,#33dfff);color:#0f172a;cursor:pointer;border:none;border-radius:6px;flex-shrink:0;margin-right:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600}.join-bar-go:disabled{opacity:.4;cursor:default}.join-bar-close{color:var(--text,#9ca3af);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:.25rem .5rem;font-size:1.1rem}.join-bar-close:hover{color:var(--text-h,#f3f4f6)}.join-bar-error{color:var(--accent,#ff5c75);text-align:center;margin:.25rem 0 0;font-size:.75rem}.qr-modal h3{color:var(--text-h,#f3f4f6);margin:0 0 .5rem;font-size:1.1rem}.qr-modal p{color:var(--text,#9ca3af);margin:0 0 1.25rem;font-size:.85rem}.qr-modal canvas{border-radius:8px;margin:0 auto 1rem;display:block}.qr-direct-link{color:var(--accent2,#33dfff);text-underline-offset:2px;margin-bottom:1rem;font-size:.85rem;text-decoration:underline;display:block}.qr-direct-link:hover{opacity:.8}.qr-close{border:1px solid var(--border,#2e303a);color:var(--text,#9ca3af);cursor:pointer;background:0 0;border-radius:6px;padding:.4rem 1.5rem;font-size:.85rem}.qr-close:hover{color:var(--text-h,#f3f4f6);background:rgba(255,255,255,.05)}.app-version{opacity:.5;font-size:.7rem}button{cursor:pointer;background:var(--accent,#ff5c75);color:#fff;border:none;border-radius:6px;padding:.75rem 1.5rem;font-size:1rem;transition:opacity .2s,transform .1s}button:hover{opacity:.85}button:active{transform:scale(.98)}.logo{width:120px;height:auto}.brand-title{letter-spacing:2px;background:var(--gradient,linear-gradient(135deg, #ff5c75, #c850c0, #33dfff));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .5rem;font-size:2.5rem;font-weight:800}.brand-header{z-index:10;position:fixed;top:.75rem;left:.75rem}button:disabled{opacity:.5;cursor:not-allowed}.mode-toggle{border:1px solid #334155;border-radius:8px;justify-content:center;gap:0;max-width:340px;margin:1.5rem auto 0;display:flex;overflow:hidden}.mode-btn{color:#94a3b8;cursor:pointer;background:#1e293b;border:none;flex:1;padding:.6rem 1rem;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.mode-btn:hover{color:#e2e8f0;background:#334155}.mode-btn-active{color:#0f172a;background:#33dfff}.mode-btn-active:hover{background:#5de7ff}.search-container{flex-direction:column;align-items:center;margin-top:2rem;display:flex}.search-container>*+*{margin-top:.75rem}.search-spinner{border:4px solid var(--border,#2e303a);border-top-color:var(--accent,#ff5c75);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.search-status{color:var(--text-h,#333);font-size:1.15rem;font-weight:500}.search-progress{color:var(--text,#888);font-size:.85rem;font-family:var(--mono,monospace)}.search-attempt{color:var(--text,#888);font-size:.8rem}.search-icon-fail{color:#f87171;background:rgba(248,113,113,.15);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;font-weight:700;display:flex}.search-hint{color:var(--text,#888);max-width:360px;font-size:.9rem}.search-actions{margin-top:.5rem;display:flex}.search-actions>*+*{margin-left:.75rem}.btn-retry{background:var(--accent,#ff5c75);border-color:var(--accent,#ff5c75);color:#fff}.btn-retry:hover{opacity:.85;background:var(--accent,#ff5c75)}.btn-manual{border:2px solid var(--border,#555);color:var(--text-h,#ccc);background:0 0}.btn-manual:hover{background:var(--accent-bg,rgba(170,59,255,.1))}.manual-container{flex-direction:column;align-items:center;margin-top:1.5rem;display:flex}.manual-container>*+*{margin-top:.5rem}.btn-back{color:var(--accent,#ff5c75);cursor:pointer;background:0 0;border:none;margin-bottom:.5rem;padding:.25rem .5rem;font-size:.85rem}.btn-back:hover{background:0 0;text-decoration:underline}.manual-form{flex-direction:column;align-items:center;margin-top:1rem;display:flex}.manual-form>*+*{margin-top:1rem}.manual-form label{color:var(--text,#888);flex-direction:column;align-items:flex-start;font-size:.9rem;display:flex}.input-url{border:2px solid var(--border,#555);background:var(--code-bg,#1a1a1a);width:100%;min-width:320px;max-width:420px;color:var(--text-h,#fff);font-size:1rem;font-family:var(--mono,monospace);border-radius:6px;padding:.6rem .75rem}.input-url:focus{border-color:var(--accent,#ff5c75);outline:none}.btn-connect{background:var(--accent,#ff5c75);border-color:var(--accent,#ff5c75);color:#fff}.btn-connect:hover{opacity:.85;background:var(--accent,#ff5c75)}.error-message{color:#f87171;margin-top:.5rem;font-size:.9rem}.manual-help{color:var(--text,#888);max-width:400px;margin-top:1.5rem;font-size:.85rem}.manual-help p+p{margin-top:.4rem}.lobby-app{width:1100px;max-width:100%;height:calc(var(--vh,1vh) * 100);box-sizing:border-box;flex-direction:column;padding:.75rem 2rem 0;display:flex;overflow:hidden}.lobby-header{text-align:center;flex-shrink:0;margin-bottom:.25rem}.lobby-columns{text-align:left;flex:1;grid-template-columns:minmax(0,1fr) 280px;gap:2rem;min-height:0;display:grid}.lobby-col-settings{flex-direction:column;min-width:0;padding-bottom:30px;display:flex;position:relative;overflow:hidden}.lobby-col-players{align-self:start;max-height:100%;overflow-y:auto}.lobby-col-players h3{margin-top:0}.lobby-col-players ul{margin:0}.lobby-footer{background:var(--bg,#14151a);border-top:1px solid var(--border,#2e303a);z-index:100;flex-shrink:0;justify-content:center;align-items:center;padding:.6rem 1rem;display:flex;position:relative}.lobby-footer>*+*{margin-left:1rem}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}@keyframes pulse-glow{0%,to{opacity:1;box-shadow:0 0 rgba(51,223,255,.4)}50%{opacity:.6;box-shadow:0 0 0 6px rgba(51,223,255,0)}}@media (max-width:768px){.app{padding:1rem}.lobby-app{width:100%;height:calc(var(--vh,1vh) * 100);padding:.75rem 1rem 0}.lobby-columns{grid-template-columns:1fr}.lobby-col-players{max-height:none}button{min-height:44px}.lobby-footer button{padding:.7rem 1.2rem!important;font-size:.95rem!important}.server-footer{flex-wrap:wrap;justify-content:center;padding:.5rem 1rem}.footer-left,.footer-right{justify-content:center;width:100%}.footer-right>*+:before{content:"·"}.device-sidebar,.home-body:before{display:none}.brand-header{margin-bottom:.25rem;position:static}.logo{width:60px}.brand-title{font-size:2rem}.realm-summary{padding:1rem 1.25rem!important}.summary-clients{grid-template-columns:1fr!important}}@media (max-width:480px){.app{padding:.75rem}.home-content{padding:1rem}.mode-grid{grid-template-columns:repeat(2,1fr)}.mode-card{padding:1.25rem 1rem}.logo{width:48px}.brand-title{letter-spacing:1px;font-size:1.6rem}.input-url{width:100%;min-width:0}.lobby-app{padding:.75rem .75rem 0}.lobby-footer{flex-wrap:wrap;justify-content:center;padding:.75rem}.lobby-footer>*{margin:.25rem}.lobby-footer>*+*{margin-left:.25rem}.lobby-footer>div:first-child{justify-content:center;width:100%;position:static!important}.realm-summary{padding:.75rem!important}.realm-summary h1{font-size:1.1rem!important}}.fg-row>*+*{margin-left:var(--fg)}.fg-col>*+*{margin-top:var(--fg)}.fg-wrap{margin-left:calc(var(--fg) * -1);margin-top:calc(var(--fg) * -1)}.fg-wrap>*{margin-left:var(--fg);margin-top:var(--fg)}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;align-items:center;display:flex;position:fixed;top:1.5rem;left:50%;transform:translate(-50%)}.toast-item{pointer-events:auto;cursor:pointer;color:#fff;text-align:center;border-radius:8px;max-width:420px;margin-bottom:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;animation:.3s forwards toast-in;box-shadow:0 4px 20px rgba(0,0,0,.4)}.toast-error{color:#f87171;background:rgba(248,113,113,.15);border:1px solid rgba(248,113,113,.4)}.toast-info{color:#33dfff;background:rgba(51,223,255,.15);border:1px solid rgba(51,223,255,.4)}.toast-exit{animation:.3s forwards toast-out}@keyframes toast-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-12px)}}
