.landing-header{position:absolute;top:0;left:0;right:0;z-index:20;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:24px 40px}.landing-header-logo{justify-self:start;color:#ffd166;font-size:1.1rem;font-weight:900;letter-spacing:4px;text-shadow:0 0 10px rgba(255,209,102,.5),0 0 25px rgba(255,159,28,.3)}.landing-music-player{justify-self:center;display:flex;align-items:center;gap:12px;min-width:340px;padding:12px 20px;border-radius:16px;color:#ffd166;background:#0a0a0fbf;border:1px solid rgba(255,209,102,.25);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 0 20px #ffd16614,0 10px 35px #00000059}.landing-song-name{flex:1;font-size:.9rem;font-weight:700;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.landing-music-player button{width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;border-radius:10px;color:#ffd166;background:#ffd16614;transition:all .2s ease}.landing-music-player button:hover{background:#ffd16633;box-shadow:0 0 15px #ffd16640;transform:translateY(-2px)}.landing-language-button{display:flex;align-items:center;gap:8px;padding:12px 18px;border-radius:12px;border:1px solid rgba(255,209,102,.3);cursor:pointer;color:#ffd166;background:#0f0f14cc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease}.landing-language-button:hover{border-color:#ffd166;box-shadow:0 0 15px #ffd1664d}.landing-volume{display:flex;align-items:center;gap:6px;margin-left:4px;color:#ffd166}.landing-volume input[type=range]{width:100px;height:4px;cursor:pointer;appearance:none;-webkit-appearance:none;background:#ffd16626;border-radius:999px}.landing-volume input[type=range]::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:#ffd166;box-shadow:0 0 8px #ffd16699}.landing-volume input[type=range]::-moz-range-thumb{width:10px;height:10px;border:none;border-radius:50%;background:#ffd166;box-shadow:0 0 8px #ffd16699}.landing-header-user{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:12px;color:#ffffffd9;background:#ffffff0f;border:1px solid rgba(255,255,255,.08)}.landing-header-user span{font-size:.85rem;font-weight:700}.landing-logout-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:8px;cursor:pointer;color:#ff5a66;background:#ff5a661a;transition:all .2s ease}.landing-logout-btn:hover{background:#ff5a6633}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff0f;color:#ffffffd9;cursor:pointer;transition:all .2s ease;font-size:.85rem;font-weight:700}.user-menu-trigger:hover{background:#ffffff1a;border-color:#ffd1664d}.user-menu-icon{font-size:1.1rem;line-height:1}.user-menu-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-chevron{transition:transform .2s ease;color:#ffffff80}.user-menu-chevron.open{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;padding:6px;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:#121016f2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 12px 40px #00000073;z-index:100;animation:userMenuFadeIn .15s ease}@keyframes userMenuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;border-radius:8px;background:transparent;color:#fffc;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease}.user-menu-item:hover{background:#ffd1661a;color:#ffd166}.user-menu-item svg{flex-shrink:0;opacity:.7}.user-menu-item:hover svg{opacity:1}.user-menu-item-danger:hover{background:#ff5a661a;color:#ff5a66}.user-menu-divider{height:1px;margin:4px 6px;background:#ffffff14}.landing-header-actions{justify-self:end;display:flex;align-items:center;gap:12px}.lobby-screen{min-height:100vh;background:#09080d;color:#f4f0ea}.lobby-body{display:flex;justify-content:center;padding:100px 24px 40px;min-height:100vh}.lobby-panel{width:min(960px,100%);display:flex;flex-direction:column;gap:20px}.lobby-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.lobby-header h1{margin:0;font-size:clamp(1.4rem,3vw,2rem);font-weight:900;letter-spacing:2px;color:#ffd166;text-shadow:0 0 20px rgba(255,209,102,.3)}.lobby-header-actions{display:flex;margin-top:10px;gap:10px;align-items:center;flex-wrap:wrap}.lobby-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border:1px solid rgba(255,255,255,.12);border-radius:10px;color:#f7f0e6;background:#ffffff12;font-weight:700;font-size:.85rem;cursor:pointer;transition:all .2s ease}.lobby-btn:hover{background:#ffffff1f;border-color:#ffffff40;transform:translateY(-1px)}.lobby-btn.primary{background:#ffd166;color:#111;border-color:#ffd166;box-shadow:0 4px 15px #ffd16640}.lobby-btn.primary:hover{background:#ffd76e;box-shadow:0 6px 20px #ffd16659}.lobby-btn.teal{background:var(--teal, #2ee6c8);color:#111;border-color:var(--teal, #2ee6c8)}.lobby-btn.teal:hover{box-shadow:0 4px 15px #2ee6c84d}.lobby-filters{display:flex;gap:14px;padding:16px;border-radius:18px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.lobby-filter-input{min-height:42px;padding:0 14px;border:1px solid rgba(255,255,255,.12);border-radius:10px;color:#f8f4ef;background:#ffffff0f;outline:none;font-size:.85rem;min-width:160px}.lobby-filter-input:focus{border-color:#ffd166;box-shadow:0 0 0 3px #ffd1661f}.lobby-filter-input option{background:#1a1820;color:#f8f4ef}.lobby-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.lobby-card{position:relative;overflow:hidden;padding:22px 22px 10px;border-radius:20px;background:linear-gradient(180deg,#ffffff0a,#ffffff05);border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:.3s}.lobby-card:before{content:"";z-index:-1;position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(255,209,102,.15),transparent 50%);opacity:0;transition:.3s}.lobby-card:hover{transform:translateY(-6px) scale(1.02);border-color:#ffd16659;box-shadow:0 15px 40px #0006,0 0 30px #ffd1661f}.lobby-card:hover:before{opacity:1}.lobby-card-name{font-size:1.05rem;font-weight:800;color:#f7f0e6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lobby-card-details{display:flex;gap:8px;align-items:center}.lobby-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:700;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--text-muted, #b9b0c1)}.lobby-badge-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.lobby-badge.country{color:var(--amber, #ffbb55);border-color:#ffbb5540;background:#ffbb5514}.lobby-badge.players{color:var(--teal, #2ee6c8);border-color:#2ee6c840;background:#2ee6c814}.lobby-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;gap:10px}.lobby-player-bar{height:8px;border-radius:999px;background:#ffffff0d;overflow:hidden}.lobby-player-bar-fill{background:linear-gradient(90deg,#2ee6c8,#5cf2d9);box-shadow:0 0 15px #2ee6c880}.lobby-player-bar-fill.full{background:linear-gradient(90deg,#ff6f4a,#ff8c6b)}.lobby-card-join{padding:10px 18px;margin-top:20px;width:100%;border-radius:12px;background:linear-gradient(135deg,#ffd166,#ffb347);color:#111;font-weight:900;letter-spacing:.5px;transition:.25s}.lobby-card-join:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 0 25px #ffd16673}.lobby-empty{grid-column:1 / -1;text-align:center;padding:48px 20px;color:var(--text-muted, #b9b0c1);font-size:.95rem}.lobby-join-code{display:flex;gap:10px;align-items:center;padding:14px 18px;border:1px solid var(--line, rgba(255, 255, 255, .12));border-radius:12px;background:var(--panel, rgba(18, 16, 22, .88))}.lobby-join-code span{font-weight:700;font-size:.88rem;color:var(--text-muted, #b9b0c1);white-space:nowrap}.lobby-join-code input{flex:1;min-height:40px;padding:0 12px;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#f8f4ef;background:#ffffff0f;outline:none;font-size:.9rem;text-transform:uppercase;letter-spacing:2px;font-weight:700}.lobby-join-code input:focus{border-color:#ffd166;box-shadow:0 0 0 3px #ffd1661f}.lobby-error{color:var(--danger, #ff5a66);font-size:.85rem;font-weight:600}.lobby-loading{display:flex;justify-content:center;padding:40px;color:var(--text-muted, #b9b0c1)}@media(max-width:600px){.lobby-body{padding:90px 14px 24px}.lobby-grid{grid-template-columns:1fr}.lobby-header{flex-direction:column;align-items:flex-start}.lobby-filters{flex-direction:column;align-items:stretch}.lobby-filter-input{min-width:auto}.lobby-join-code{flex-wrap:wrap}.lobby-join-code input{min-width:120px}}.lobby-hero{position:relative;overflow:hidden;padding:40px;border-radius:24px;background:radial-gradient(circle at top left,rgba(255,209,102,.18),transparent 50%),#0f0f14bf;border:1px solid rgba(255,209,102,.15);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 0 40px #ffd16614,0 20px 50px #00000059}.lobby-hero-content h1{margin:0 0 10px;font-size:clamp(2rem,5vw,3rem);color:#ffd166;font-weight:900}.lobby-hero-content p{max-width:500px;color:#ffffffbf;line-height:1.6}.lobby-hero-glow{position:absolute;top:-120px;right:-120px;width:280px;height:280px;border-radius:50%;background:#ffd16633;filter:blur(100px)}.lobby-code{font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:#ffffff73}.modal-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.modal-container{position:relative;max-width:1100px;background:#141419e6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:32px;border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 50px -12px #00000080;scrollbar-width:thin;scrollbar-color:#ffd166 rgba(255,255,255,.2);width:min(1100px,95vw);overflow-y:hidden;overflow-x:hidden}.modal-container::-webkit-scrollbar{width:6px}.modal-container::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}.modal-container::-webkit-scrollbar-thumb{background:#ffd166;border-radius:10px}@media(max-height:800px){.modal-layout{padding:24px 32px 32px;gap:24px}.modal-title{font-size:clamp(2.2rem,4vw,3.5rem);margin-bottom:8px}.modal-description{margin-bottom:20px;font-size:.85rem}.modal-card{padding:18px}.modal-field input,.modal-field select{height:42px}.robot-head{width:130px;height:105px}.robot-face{width:100px;height:60px;font-size:12px}.robot-body{width:90px;height:130px}}@media(max-height:650px){.modal-layout{padding:16px 24px 24px;gap:16px}.modal-devices{gap:10px}.modal-actions{margin-top:16px}.robot-head{width:110px;height:90px}.robot-face{width:85px;height:50px}.robot-body{width:75px;height:110px}}.modal-close{position:absolute;top:20px;right:24px;background:#ffffff1a;border:none;border-radius:30px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:.2s;z-index:20}.modal-close:hover{background:#ffd16633;color:#ffd166;transform:scale(1.05)}.modal-layout{display:flex;flex-wrap:wrap;gap:32px;padding:40px 40px 48px}.modal-settings{flex:2;min-width:280px}.modal-preview{flex:1;min-width:260px;display:flex;flex-direction:column;align-items:center;position:relative}.modal-title{font-size:clamp(2.8rem,5vw,5rem);font-weight:900;line-height:.95;color:#fff;text-shadow:0 0 10px #ffd166,0 0 30px #ff9f1c,0 0 60px #ff9f1c;margin:0 0 16px}.modal-description{color:#ffffffd9;line-height:1.6;margin-bottom:28px;font-size:.95rem}.modal-card{background:#00000073;border-radius:24px;padding:24px;border:1px solid rgba(255,255,255,.08)}.modal-card-header{display:flex;align-items:center;gap:10px;color:#ffd166;font-weight:700;margin-bottom:20px}.modal-field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.modal-field span{color:#ffffffbf;font-size:.85rem}.modal-field input,.modal-field select{appearance:none;height:48px;padding:0 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:14px;color:#fff;font-size:.9rem}.modal-field input:focus,.modal-field select:focus{outline:none;border-color:#ffd166;box-shadow:0 0 12px #ffd1664d}.modal-field select option{background-color:#1e1e2f;color:#fff}.modal-devices{display:grid;grid-template-columns:1fr 1fr;gap:16px}.hidden-checkbox{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.custom-checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none;margin:20px 0 16px}.custom-checkbox{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;background:#00000080;border:2px solid rgba(255,209,102,.6);border-radius:8px;transition:all .2s ease;color:#ffd166}.custom-checkbox-label:hover .custom-checkbox{border-color:#ffd166;background:#ffd16626;transform:scale(1.05);box-shadow:0 0 8px #ffd16666}.custom-checkbox-label input:checked~.custom-checkbox{background:#ffd166;border-color:#ffd166;color:#1a1a1a;box-shadow:0 0 12px #ffd16699}.rules-text{color:#ffffffe6;font-size:.95rem;transition:color .2s}.custom-checkbox-label:hover .rules-text{color:#ffd166}.modal-rules-row{display:flex;align-items:center;gap:12px;margin:20px 0 16px}.modal-rules-row .custom-checkbox-label{margin:0;flex:1}.rules-view-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid rgba(255,209,102,.3);border-radius:20px;background:#ffd16614;color:#ffd166;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.rules-view-btn:hover{background:#ffd1662e;border-color:#ffd166;transform:scale(1.03)}.rules-view-btn svg{flex-shrink:0}.rules-overlay{position:absolute;inset:0;background:#0a080ef7;border-radius:32px;z-index:10;display:flex;align-items:center;justify-content:center;padding:32px;overflow-y:auto}.rules-overlay-content{width:100%;max-width:520px;display:flex;flex-direction:column;gap:20px}.rules-overlay-header{display:flex;align-items:center;gap:12px;color:#ffd166}.rules-overlay-header h2{margin:0;font-size:1.3rem;font-weight:900}.rules-overlay-intro{color:#ffffffb3;line-height:1.6;font-size:.88rem;margin:0}.rules-overlay-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.rules-overlay-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:10px;color:#ffffffe6;font-size:.88rem;line-height:1.5;transition:all .2s ease}.rules-overlay-item:hover{background:#ffffff0f;border-color:#ffd16626}.rules-overlay-number{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:#ffd1661f;color:#ffd166;font-weight:900;font-size:.75rem;flex-shrink:0;margin-top:2px}.rules-overlay-footer{display:flex;justify-content:flex-end;margin-top:8px}.rules-overlay-close{display:flex;align-items:center;gap:8px;padding:10px 24px;border:none;border-radius:30px;background:#ffd166;color:#111;font-weight:800;font-size:.9rem;cursor:pointer;transition:all .2s ease}.rules-overlay-close:hover{transform:translateY(-2px);box-shadow:0 4px 16px #ffd16659}.modal-error{color:#ff8080;font-size:.85rem;margin:8px 0}.modal-message{color:#ffd166;font-size:.85rem}.modal-actions{display:flex;gap:14px;margin-top:24px}.modal-primary,.modal-secondary{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 24px;border-radius:40px;font-weight:700;cursor:pointer;transition:.2s;border:none;font-size:.9rem}.modal-primary{background:#ffd166;color:#111;flex:2;box-shadow:0 5px 15px #ffd1664d}.modal-primary:hover{transform:translateY(-2px);box-shadow:0 8px 22px #ffd16666}.modal-secondary{background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.15);flex:1}.modal-secondary:hover{background:#ffffff26}.preview-glow{position:absolute;inset:-40px;background:radial-gradient(circle,rgba(255,209,102,.25),transparent 70%);filter:blur(40px);pointer-events:none}.robot-frame{margin-top:20px;display:flex;flex-direction:column;align-items:center;width:100%}.robot-head{width:160px;height:130px;background:linear-gradient(180deg,#2a2d36,#17191f);border-radius:24px;border:2px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center}.robot-face{width:120px;height:70px;background:#000;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#ffd166;box-shadow:inset 0 0 20px #ffd16666}.robot-body{width:110px;height:160px;margin-top:12px;background:linear-gradient(180deg,#2f323d,#17191f);border-radius:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:800px){.modal-layout{flex-direction:column;padding:32px 24px}.modal-preview{order:-1;margin-bottom:20px}.modal-close{top:12px;right:16px}}.robot-color-selector{display:flex;align-items:center;justify-content:space-between;margin:16px 0 12px;gap:12px;background:#0000004d;padding:8px 16px;border-radius:40px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.robot-color-selector label{display:flex;align-items:center;gap:8px;color:#ffffffe6;font-size:.85rem;font-weight:500;letter-spacing:.3px}.robot-color-selector label svg{width:18px;height:18px;color:#ffd166}.robot-color-selector input[type=color]{width:44px;height:44px;border:2px solid rgba(255,209,102,.6);border-radius:30px;background:#14141ee6;cursor:pointer;padding:0;outline:none;box-shadow:0 2px 8px #0000004d;transition:all .2s ease}.robot-color-selector input[type=color]::-webkit-color-swatch-wrapper{padding:0}.robot-color-selector input[type=color]::-webkit-color-swatch{border:none;border-radius:30px}.robot-color-selector input[type=color]:hover{border-color:#ffd166;transform:scale(1.05);box-shadow:0 0 12px #ffd16666}.robot-color-selector input[type=color]:focus{border-color:#ffd166;box-shadow:0 0 0 2px #ffd1664d}.curtain-panel{position:fixed;top:0;width:50%;height:100%;z-index:10000;overflow:hidden;will-change:transform;background:radial-gradient(ellipse at center,rgba(255,255,255,.12) 0%,transparent 70%),repeating-linear-gradient(90deg,#3b0707,#8b1e1e,#4b0909 80px);box-shadow:inset -20px 0 40px #0006,inset 20px 0 40px #ffffff0d,0 0 30px #00000080}.curtain-panel:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,#ffffff14,#ffffff05,#00000026,#ffffff0d 60px);mix-blend-mode:soft-light;pointer-events:none}.curtain-left{left:0;animation:slideLeft 1s ease-in-out forwards;border-right:4px solid #d4af37}.curtain-right{right:0;animation:slideRight 1s ease-in-out forwards;border-left:4px solid #d4af37}@keyframes slideLeft{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes slideRight{0%{transform:translate(0)}to{transform:translate(100%)}}.settings-page{min-height:100vh;background:#09080d;color:#f4f0ea;display:flex;justify-content:center;padding:100px 24px 48px}.settings-container{width:min(560px,100%);display:flex;flex-direction:column;gap:24px}.settings-header{display:flex;align-items:center;gap:16px}.settings-back{display:flex;align-items:center;gap:6px;padding:10px 16px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:#ffffff0f;color:#fffc;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease}.settings-back:hover{background:#ffffff1a;border-color:#ffd1664d;color:#ffd166}.settings-title{margin:0;font-size:1.5rem;font-weight:900;color:#ffd166;text-shadow:0 0 10px rgba(255,209,102,.3)}.settings-card{display:flex;flex-direction:column;gap:24px;padding:28px;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:#121016eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 24px 80px #0000005c}.settings-section{display:flex;flex-direction:column;gap:8px}.settings-label{color:#ffffffbf;font-size:.82rem;font-weight:800}.settings-field{display:flex;flex-direction:column;gap:8px}.settings-field span{color:#ffffffbf;font-size:.82rem;font-weight:800}.settings-field input,.settings-section select{width:100%;min-height:44px;padding:0 14px;border:1px solid rgba(255,255,255,.14);border-radius:10px;color:#f8f4ef;background:#ffffff0f;outline:none;font-size:.9rem}.settings-field input:focus,.settings-section select:focus{border-color:#ffd166;box-shadow:0 0 0 3px #ffd1661f}.settings-section select option{background-color:#1e1e2f;color:#fff}.settings-icons{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.settings-icon-option{position:relative;display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;border:2px solid rgba(255,255,255,.1);border-radius:12px;background:#ffffff0d;cursor:pointer;transition:all .2s ease;padding:0}.settings-icon-option:hover{border-color:#ffd16666;background:#ffd16614;transform:translateY(-2px)}.settings-icon-option.active{border-color:#ffd166;background:#ffd1661f;box-shadow:0 0 12px #ffd16640}.settings-icon-emoji{font-size:1.5rem;line-height:1}.settings-icon-check{position:absolute;top:-4px;right:-4px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#ffd166;color:#111}.settings-message{margin:0;padding:12px 16px;border-radius:10px;font-size:.85rem;font-weight:700}.settings-message.success{color:#0f0;background:#00ff0014;border:1px solid rgba(0,255,0,.2)}.settings-message.error{color:#ff5a66;background:#ff5a661a;border:1px solid rgba(255,90,102,.2)}.settings-save{display:flex;align-items:center;justify-content:center;gap:8px;min-height:46px;border:none;border-radius:10px;color:#100b12;background:#2ee6c8;font-weight:850;font-size:.95rem;cursor:pointer;transition:all .2s ease}.settings-save:hover{transform:translateY(-1px);box-shadow:0 4px 20px #2ee6c84d}.settings-save:disabled{opacity:.5;transform:none;box-shadow:none}.settings-divider{height:1px;background:#ffffff14;margin:4px 0}.settings-color-row{display:flex;align-items:center;gap:12px}.settings-color-swatch{width:44px;height:44px;border-radius:30px;border:2px solid rgba(255,209,102,.6);flex-shrink:0}.settings-color-input{width:44px;height:44px;border:2px solid rgba(255,209,102,.6);border-radius:30px;background:#14141ee6;cursor:pointer;padding:0;outline:none}.settings-color-input::-webkit-color-swatch-wrapper{padding:0}.settings-color-input::-webkit-color-swatch{border:none;border-radius:30px}.settings-color-input:hover{border-color:#ffd166;transform:scale(1.05)}.settings-checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.settings-hidden-checkbox{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.settings-custom-checkbox{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;background:#00000080;border:2px solid rgba(255,209,102,.6);border-radius:8px;transition:all .2s ease;color:#ffd166;flex-shrink:0}.settings-checkbox-label:hover .settings-custom-checkbox{border-color:#ffd166;background:#ffd16626;transform:scale(1.05)}.settings-hidden-checkbox:checked~.settings-custom-checkbox{background:#ffd166;border-color:#ffd166;color:#1a1a1a;box-shadow:0 0 12px #ffd16699}.settings-rules-text{color:#ffffffe6;font-size:.9rem}.settings-checkbox-label:hover .settings-rules-text{color:#ffd166}.settings-rules-row{display:flex;align-items:center;gap:12px}.settings-rules-row .settings-checkbox-label{flex:1}.settings-rules-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid rgba(255,209,102,.3);border-radius:20px;background:#ffd16614;color:#ffd166;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.settings-rules-btn:hover{background:#ffd1662e;border-color:#ffd166;transform:scale(1.03)}.settings-camera-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:44px;border:1px solid rgba(255,255,255,.14);border-radius:10px;color:#f8f4ef;background:#ffffff0f;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease}.settings-camera-btn:hover{background:#ffffff1a;border-color:#ffd1664d;color:#ffd166}.settings-error-text{margin:6px 0 0;font-size:.8rem;color:#ff5a66}.settings-success-text{margin:6px 0 0;font-size:.8rem;color:#2ee6c8}@media(max-width:480px){.settings-icons{grid-template-columns:repeat(4,1fr)}}.rules-page{min-height:100vh;background:#09080d;color:#f4f0ea;display:flex;justify-content:center;padding:100px 24px 48px}.rules-container{width:min(640px,100%);display:flex;flex-direction:column;gap:24px}.rules-back{display:flex;align-items:center;gap:6px;padding:10px 16px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:#ffffff0f;color:#fffc;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease;align-self:flex-start}.rules-back:hover{background:#ffffff1a;border-color:#ffd1664d;color:#ffd166}.rules-card{display:flex;flex-direction:column;gap:24px;padding:36px;border:1px solid rgba(255,255,255,.1);border-radius:20px;background:#121016eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 24px 80px #0000005c}.rules-header{display:flex;align-items:center;gap:14px;color:#ffd166}.rules-header svg{flex-shrink:0}.rules-title{margin:0;font-size:1.6rem;font-weight:900;color:#ffd166;text-shadow:0 0 10px rgba(255,209,102,.3)}.rules-intro{color:#ffffffbf;line-height:1.7;font-size:.95rem;margin:0}.rules-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.rules-item{display:flex;align-items:flex-start;gap:14px;padding:16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:12px;transition:all .2s ease}.rules-item:hover{background:#ffffff0f;border-color:#ffd16626}.rules-item-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#ffd1661f;color:#ffd166;font-weight:900;font-size:.85rem;flex-shrink:0;margin-top:4px}.rules-item-text{color:#ffffffe6;line-height:1.5;font-size:.92rem;padding-top:6px}.rules-footer{display:flex;align-items:center;gap:10px;padding:16px;background:#ff5a5a14;border:1px solid rgba(255,90,90,.15);border-radius:12px;color:#ff8080;font-size:.85rem;font-weight:600}.rules-footer svg{flex-shrink:0}@media(max-width:480px){.rules-card{padding:24px}}:root{color:#f4f0ea;background:#09080d;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--panel: rgba(18, 16, 22, .88);--panel-strong: rgba(26, 23, 31, .94);--line: rgba(255, 255, 255, .12);--text-muted: #b9b0c1;--teal: #2ee6c8;--amber: #ffbb55;--coral: #ff6f4a;--violet: #9d7cff;--danger: #ff5a66}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}#root{min-height:100vh}.setup-screen,.game-screen{min-height:100vh;color:#f4f0ea}.setup-screen{display:grid;place-items:center;padding:28px;background:linear-gradient(180deg,rgba(46,230,200,.12),transparent 24%),radial-gradient(circle at 20% 20%,rgba(255,187,85,.14),transparent 28%),#09080d}.setup-panel{width:min(1120px,100%);padding:24px;border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:0 24px 80px #0000005c}.brand-row,.modal-title,.panel-title{display:flex;align-items:center;gap:12px}.brand-mark{display:grid;width:48px;height:48px;place-items:center;border:1px solid rgba(46,230,200,.45);border-radius:8px;color:var(--teal);background:#2ee6c814}.eyebrow{margin:0 0 4px;color:var(--amber);font-size:.74rem;font-weight:800;letter-spacing:0;text-transform:uppercase}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:clamp(2rem,5vw,4.7rem);line-height:.96;letter-spacing:0}h2{margin-bottom:12px;font-size:clamp(1.45rem,3vw,2.45rem);line-height:1.05;letter-spacing:0}.setup-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);gap:26px;margin-top:28px;align-items:stretch}.setup-copy{display:flex;min-width:0;flex-direction:column;gap:16px}.setup-copy p{max-width:54ch;color:var(--text-muted);line-height:1.55}.field{display:grid;gap:8px}.field span{color:#e9e0ec;font-size:.84rem;font-weight:800}input,select{width:100%;min-height:44px;border:1px solid rgba(255,255,255,.16);border-radius:8px;color:#f8f4ef;background:#ffffff12;outline:none;padding:0 12px}input:focus,select:focus{border-color:var(--teal);box-shadow:0 0 0 3px #2ee6c829}.device-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.rules-check{display:grid;grid-template-columns:18px 1fr;gap:10px;align-items:start;color:#d9d1df;line-height:1.45}.rules-check input{width:18px;min-height:18px;margin-top:2px;accent-color:var(--teal)}.message{margin:0;color:var(--amber);font-weight:750}.message.error{color:var(--danger)}.setup-actions,.modal-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.primary-button,.secondary-button,.text-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:8px;font-weight:850;letter-spacing:0;transition:transform .12s ease,border-color .12s ease,background .12s ease}.primary-button,.secondary-button,.text-button{min-height:44px;padding:0 16px}.primary-button{color:#100b12;background:var(--teal)}.secondary-button,.text-button,.icon-button{color:#f7f0e6;border-color:#ffffff24;background:#ffffff14}.primary-button:hover,.secondary-button:hover,.text-button:hover,.icon-button:hover{transform:translateY(-1px);border-color:#ffffff47}.danger-fill{background:var(--danger)}.danger{color:#ffd3d7;border-color:#ff5a6659}.setup-preview{position:relative;display:grid;min-height:430px;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:linear-gradient(180deg,rgba(255,255,255,.08),transparent 26%),linear-gradient(135deg,#2ee6c829,#ff6f4a1a),#151218}.setup-preview .video-frame{position:absolute;inset:18px 18px auto auto;width:min(320px,calc(100% - 36px));height:180px;z-index:2}.video-frame{overflow:hidden;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#111015}.video-frame video,.video-placeholder{width:100%;height:100%}.video-frame video{display:block;object-fit:cover;transform:scaleX(-1)}.video-placeholder{display:grid;place-items:center;gap:8px;color:#cfc6d9;background:repeating-linear-gradient(135deg,#17141b,#17141b 10px,#1d1923 10px 20px);text-align:center}.video-placeholder span{font-size:.82rem;font-weight:800}.video-frame.compact{width:100%;height:100%}.robot-preview{position:absolute;left:50%;bottom:18px;width:min(320px,64%);height:330px;transform:translate(-50%)}.robot-head{position:absolute;left:50%;top:20px;display:grid;width:168px;height:168px;place-items:center;border:12px solid #2ee6c8;border-radius:50%;background:#141117;box-shadow:0 0 28px #2ee6c861,inset 0 0 24px #ffffff14;transform:translate(-50%)}.robot-face{display:grid;width:118px;height:118px;place-items:center;border-radius:50%;color:#09080d;background:#fb5;font-size:1.25rem;font-weight:950}.robot-body{position:absolute;left:50%;top:180px;width:96px;height:118px;border-radius:28px 28px 18px 18px;background:linear-gradient(180deg,#4b4653,#1c1921);transform:translate(-50%)}.robot-lights{position:absolute;left:50%;top:226px;width:160px;height:80px;border-left:10px solid #ff6f4a;border-right:10px solid #9d7cff;transform:translate(-50%)}.game-screen{position:relative;overflow:hidden;background:#09080d}.stage-scene{position:fixed;inset:0}.stage-scene canvas{width:100%!important;height:100%!important;display:block}.room-hud,.players-panel,.control-bar,.self-preview,.notice-stack{position:fixed;z-index:4}.room-hud{top:18px;left:18px;display:flex;align-items:center;gap:16px;max-width:min(420px,calc(100vw - 36px));padding:14px 16px;border:1px solid var(--line);border-radius:8px;background:var(--panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.room-hud h2{margin:0;font-size:1.25rem}.connection-pill{padding:6px 9px;border-radius:999px;color:#120e13;background:var(--amber);font-size:.76rem;font-weight:900}.connection-pill.online{background:var(--teal)}.connection-pill.offline{background:var(--danger)}.players-panel{top:18px;right:18px;width:270px;max-width:calc(100vw - 36px);padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.panel-title{justify-content:space-between;margin-bottom:10px;color:#f7f0e6;font-weight:900}.player-list{display:grid;max-height:310px;gap:8px;overflow:auto;padding-right:2px}.player-row{display:grid;grid-template-columns:12px 1fr auto;gap:10px;align-items:center;min-height:44px;padding:8px;border:1px solid rgba(255,255,255,.08);border-radius:8px;background:#ffffff0d}.player-color{width:12px;height:32px;border-radius:999px}.player-row strong,.player-row span{display:block}.player-row strong{overflow:hidden;color:#f8f2e6;font-size:.9rem;text-overflow:ellipsis;white-space:nowrap}.player-row span{color:var(--text-muted);font-size:.76rem;font-weight:750}.notice-stack{left:18px;bottom:96px;display:grid;width:min(360px,calc(100vw - 36px));gap:8px;pointer-events:none}.notice{padding:10px 12px;border:1px solid rgba(255,255,255,.14);border-radius:8px;color:#f7f0e6;background:#121016db;box-shadow:0 10px 40px #0000003d}.control-bar{left:50%;bottom:18px;display:flex;max-width:calc(100vw - 36px);min-height:60px;gap:8px;align-items:center;padding:8px;border:1px solid var(--line);border-radius:8px;background:var(--panel-strong);box-shadow:0 16px 64px #00000057;transform:translate(-50%)}.reaction-group{display:flex;gap:6px;padding:0 6px;border-right:1px solid rgba(255,255,255,.12);border-left:1px solid rgba(255,255,255,.12)}.icon-button{width:44px;height:44px;flex:0 0 44px;padding:0}.icon-button.compact{width:32px;height:32px;flex-basis:32px}.self-preview{right:18px;bottom:92px;width:220px;height:132px;border-radius:8px;box-shadow:0 16px 56px #0000005c}.self-preview-actions{position:absolute;right:8px;bottom:8px;display:flex;gap:6px}.modal-backdrop{position:fixed;inset:0;z-index:8;display:grid;place-items:center;padding:24px;background:#050407b8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal{display:grid;width:min(430px,100%);gap:16px;padding:20px;border:1px solid var(--line);border-radius:8px;background:#141218;box-shadow:0 24px 80px #00000073}.modal h2{margin:0;font-size:1.35rem}.modal-actions{justify-content:flex-end}@media(max-width:860px){.setup-screen{min-height:auto;padding:14px}.setup-panel{padding:18px}.setup-grid,.device-grid{grid-template-columns:1fr}.setup-preview{min-height:360px}.players-panel{display:none}.room-hud{right:18px}.control-bar{right:12px;left:12px;flex-wrap:wrap;justify-content:center;max-width:none;transform:none}.self-preview{width:138px;height:84px;right:12px;bottom:206px}.notice-stack{bottom:302px}}.auth-modal{width:min(420px,100%);padding:28px 24px 20px;border:1px solid var(--line);border-radius:16px;background:#141218;box-shadow:0 24px 80px #0009}.auth-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.auth-modal-header h2{margin:0;font-size:1.3rem}.auth-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-muted);background:transparent;cursor:pointer;transition:.2s}.auth-close:hover{border-color:#ffffff40;color:#fff}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-form-title{margin:0 0 4px;font-size:1.3rem}.auth-form-desc{margin:0 0 8px;color:var(--text-muted);font-size:.9rem;line-height:1.5}.auth-error{margin:0;padding:10px 14px;border-radius:8px;color:#ffd3d7;background:#ff5a661f;font-size:.85rem;font-weight:600}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field span{color:#e9e0ec;font-size:.82rem;font-weight:800}.auth-field input{width:100%;min-height:44px;border:1px solid rgba(255,255,255,.14);border-radius:10px;color:#f8f4ef;background:#ffffff0f;outline:none;padding:0 14px}.auth-field input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #2ee6c81f}.auth-submit{display:flex;align-items:center;justify-content:center;gap:8px;min-height:46px;border:none;border-radius:10px;color:#100b12;background:var(--teal);font-weight:850;cursor:pointer;transition:.2s}.auth-submit:hover{transform:translateY(-1px);box-shadow:0 4px 20px #2ee6c84d}.auth-submit:disabled{opacity:.5;transform:none}.auth-divider{display:flex;align-items:center;gap:12px;color:var(--text-muted);font-size:.8rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.auth-google-button{display:flex;align-items:center;justify-content:center;gap:10px;min-height:46px;border:1px solid rgba(255,255,255,.14);border-radius:10px;color:#f7f0e6;background:#ffffff0f;font-weight:750;cursor:pointer;transition:.2s}.auth-google-button:hover{background:#ffffff1a;border-color:#ffffff40}.auth-google-button:disabled{opacity:.5}.auth-switch{margin:4px 0 0;color:var(--text-muted);font-size:.85rem;text-align:center}.auth-link{border:none;padding:0;color:var(--teal);background:transparent;font-weight:700;cursor:pointer;text-decoration:underline}.auth-link:hover{color:#5cf0d4}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.landing-auth-buttons{display:flex;gap:10px;margin-top:12px}.landing-auth-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border:1px solid rgba(255,255,255,.12);border-radius:12px;color:#f7f0e6;background:#ffffff12;font-weight:750;font-size:.85rem;cursor:pointer;transition:.2s}.landing-auth-btn:hover{background:#ffffff1f;border-color:#ffffff40;transform:translateY(-2px)}.landing-user-info{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:12px;padding:10px 16px;border-radius:12px;color:var(--teal);background:#2ee6c814;border:1px solid rgba(46,230,200,.2);font-weight:700;font-size:.9rem}.landing-user-badge{display:flex;align-items:center;gap:8px;padding:4px 10px;border-radius:999px;color:#2ee6c8;background:#2ee6c81f}.landing-screen{position:relative;width:100vw;height:100vh;overflow:hidden;background:radial-gradient(circle at center,#1b1318,#09080d 70%)}.landing-screen:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 60% 45%,rgba(255,180,0,.18),transparent 45%);z-index:1}.landing-stage{position:absolute;inset:0;z-index:1;transform:translate(180px)}.landing-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(90deg,#000000f2,#000000e0,#0000008c 50%,#0000000d)}.landing-content{position:absolute;top:50%;left:clamp(24px,6vw,90px);transform:translateY(-50%);z-index:10;max-width:650px;padding:42px;border:1px solid rgba(255,255,255,.08);border-radius:28px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f0f1459;box-shadow:0 20px 60px #00000059}.landing-tag{display:inline-block;margin-bottom:18px;color:#ffd166;font-size:12px;font-weight:800;letter-spacing:5px}.landing-title{margin:0;color:#fff;line-height:.95;font-size:clamp(4rem,7vw,7rem);font-weight:900;text-shadow:0 0 10px #ffd166,0 0 30px #ff9f1c,0 0 60px #ff9f1c,0 0 100px #ff9f1c}.landing-description{margin-top:24px;max-width:560px;color:#ffffffd1;line-height:1.8;font-size:1.1rem}.landing-features{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}.landing-feature{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;color:#fff;background:#ffffff0f;border:1px solid rgba(255,255,255,.08)}.landing-actions{margin-top:36px}.landing-actions .landing-button{margin-bottom:4px}.landing-button{display:inline-flex;align-items:center;gap:12px;padding:18px 38px;border:none;border-radius:14px;cursor:pointer;color:#111;font-weight:800;font-size:1rem;background:linear-gradient(135deg,#ffd166,#ffb703);box-shadow:0 15px 40px #ffb70340;transition:transform .25s ease,box-shadow .25s ease}.landing-button:hover{transform:translateY(-4px);box-shadow:0 20px 55px #ffb70366}.landing-stats{display:flex;gap:32px;margin-top:32px;color:#ffffffbf;font-size:.95rem}.landing-stats strong{color:#ffd166;font-size:1.3rem}@media(max-width:900px){.landing-stage{transform:none}.landing-content{left:20px;right:20px;max-width:none;padding:28px}.landing-title{font-size:clamp(3rem,12vw,5rem)}.landing-features{flex-direction:column}.landing-stats{gap:20px;flex-wrap:wrap}}
