*,:before,:after{box-sizing:border-box}html,body{min-height:100dvh;margin:0;padding:0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0c0c1a;--surface:#151528;--surface2:#1a1a38;--accent:#e94560;--accent2:#f5a623;--text:#eaeaf8;--text-muted:#77a;--radius:18px;--seam:#f5a623}body{color:var(--text);background:linear-gradient(160deg,#0d0d1f 0%,#110f2b 40%,#0c0f22 100%) fixed;flex-direction:column;align-items:center;min-height:100dvh;font-family:Segoe UI,system-ui,sans-serif;display:flex}#root{flex-direction:column;width:100%;max-width:560px;min-height:100dvh;display:flex}.app-loading,.app-error{height:100dvh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.app-error{color:var(--accent)}.hybrid-builder{flex-direction:column;flex:1;align-items:center;gap:0;padding:16px 16px 32px;display:flex}.builder-header{text-align:center;margin-bottom:18px}.app-title{background:linear-gradient(135deg, var(--accent), var(--accent2));-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-family:"Baloo 2",Segoe UI,system-ui,sans-serif;font-size:2.2rem;font-weight:900}.app-subtitle{color:var(--text-muted);margin-top:2px;font-size:.9rem}.creature-stage{background:var(--surface);border-radius:var(--radius);flex-direction:column;align-items:stretch;width:100%;display:flex;overflow:hidden;box-shadow:0 0 40px #e9456014,0 0 80px #f5a6230a,0 8px 32px #0006}.half-selector{align-items:stretch;width:100%;height:220px;display:flex;position:relative;overflow:hidden}.half-selector--top:after{content:"";pointer-events:none;z-index:2;background:linear-gradient(#0000,#151528cc);height:44px;position:absolute;bottom:0;left:0;right:0}.half-selector--bottom:before{content:"";pointer-events:none;z-index:2;background:linear-gradient(#151528cc,#0000);height:44px;position:absolute;top:0;left:0;right:0}.half-image-wrap{flex:1;height:100%;position:relative;overflow:hidden}@keyframes slotEnter{0%{opacity:0;transform:translateY(55%)}to{opacity:1;transform:translateY(0)}}.half-image{object-fit:cover;-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:100%;display:block}.half-image--top{object-position:center bottom}.half-image--bottom{object-position:center top}.half-image--enter{animation:.34s cubic-bezier(.34,1.4,.64,1) both slotEnter}.half-label{color:#ffffffe6;-webkit-backdrop-filter:blur(6px);white-space:nowrap;z-index:3;letter-spacing:.3px;background:#0000008c;border-radius:99px;padding:2px 10px;font-size:.72rem;font-weight:600;position:absolute;left:50%;transform:translate(-50%)}.half-label--top{top:10px}.half-label--bottom{bottom:10px}.nav-btn{-webkit-backdrop-filter:blur(4px);color:#ffffff8c;cursor:pointer;z-index:3;background:#0000004d;border:none;flex-shrink:0;justify-content:center;align-items:center;width:44px;font-size:2rem;transition:color .15s,background .15s;display:flex}.nav-btn:hover{color:#fffffff2;background:#ffffff1a}.nav-btn:active{opacity:.7}.seam-zone{z-index:4;background:var(--surface);flex-shrink:0;width:100%;height:20px;position:relative}.seam-svg{width:100%;height:100%;overflow:visible}.seam-zigzag{fill:none;stroke:var(--seam);stroke-width:2.5px;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 4px var(--seam)) drop-shadow(0 0 10px #f5a62366);stroke-dasharray:600;stroke-dashoffset:600px;animation:1s ease-out .2s forwards seamDraw,3s ease-in-out 1.3s infinite alternate seamPulse}@keyframes seamDraw{to{stroke-dashoffset:0}}@keyframes seamPulse{0%{filter:drop-shadow(0 0 3px var(--seam)) drop-shadow(0 0 6px #f5a6234d)}to{filter:drop-shadow(0 0 7px var(--seam)) drop-shadow(0 0 16px #f5a623a6)}}.creature-info{text-align:center;width:100%;padding:18px 16px 14px}.creature-name{color:var(--accent2);letter-spacing:-.5px;text-shadow:0 0 24px #f5a62359;margin-bottom:8px;font-family:"Baloo 2",Segoe UI,system-ui,sans-serif;font-size:2rem;font-weight:900}.creature-steckbrief{color:var(--text-muted);max-width:360px;margin:0 auto;font-size:.88rem;line-height:1.65}.builder-actions{justify-content:center;gap:10px;width:100%;margin-top:14px;display:flex}.btn{cursor:pointer;border:none;border-radius:99px;padding:11px 22px;font-size:.95rem;font-weight:700;transition:transform .1s,opacity .15s,box-shadow .15s}.btn:active{transform:scale(.95)}.btn--random{background:var(--surface2);color:var(--text);border:1px solid #ffffff1f}.btn--random:hover{background:#1e2048;box-shadow:0 0 14px #ffffff0f}.btn--share{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;flex:1;max-width:200px}.btn--share:hover{opacity:.88;box-shadow:0 4px 20px #e9456066}.btn--build{background:var(--accent);color:#fff}.btn--build:hover{opacity:.9}.counter-display{margin-top:16px}.counter-label{color:var(--text-muted);font-size:.72rem}.hybrid-builder--compact{padding-top:0}@keyframes partyPulse{0%,to{box-shadow:0 0 #e9456073}60%{box-shadow:0 0 0 12px #e9456000}}.btn--party-entry{color:var(--accent);cursor:pointer;background:0 0;border:1.5px solid #e9456080;border-radius:99px;margin:10px auto 28px;padding:11px 32px;font-size:.95rem;font-weight:700;transition:background .15s,border-color .15s,transform .1s;animation:2.5s ease-in-out infinite partyPulse;display:block}.btn--party-entry:hover{border-color:var(--accent);background:#e945601a;transform:scale(1.03)}.btn--party-entry:active{animation:none;transform:scale(.97)}.party-phase{flex-direction:column;align-items:center;gap:16px;width:100%;min-height:100dvh;padding:28px 16px 36px;display:flex}.party-badge{letter-spacing:2px;background:var(--accent);color:#fff;border-radius:99px;padding:3px 12px;font-size:.65rem;font-weight:900}.party-header{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.party-title{color:var(--text);font-family:"Baloo 2",Segoe UI,system-ui,sans-serif;font-size:1.7rem;font-weight:900;line-height:1.2}.party-lobby{gap:14px}.lobby-count-row{align-items:center;gap:28px;margin:4px 0;display:flex}.count-btn{background:var(--surface);width:48px;height:48px;color:var(--text);cursor:pointer;border:2px solid #ffffff1f;border-radius:50%;font-size:1.6rem;line-height:1;transition:background .15s}.count-btn:hover:not(:disabled){background:var(--surface2)}.count-btn:disabled{opacity:.3;cursor:default}.count-display{color:var(--accent2);text-align:center;min-width:52px;font-size:3.5rem;font-weight:900}.count-label{color:var(--text-muted);margin-top:-8px;font-size:.85rem}.lobby-names{flex-direction:column;gap:8px;width:100%;max-height:280px;display:flex;overflow-y:auto}.name-input{background:var(--surface);width:100%;color:var(--text);border:1px solid #ffffff1a;border-radius:10px;outline:none;padding:12px 16px;font-size:1rem;transition:border-color .15s}.name-input:focus{border-color:var(--accent)}.btn--party-primary{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;cursor:pointer;border:none;border-radius:99px;width:100%;margin-top:auto;padding:15px;font-size:1.1rem;font-weight:900;transition:opacity .15s,transform .1s}.btn--party-primary:active{transform:scale(.97)}.btn--party-primary:disabled{opacity:.35;cursor:default;transform:none}.btn--secondary{background:var(--surface2);color:var(--text);cursor:pointer;border:1px solid #ffffff1a;border-radius:99px;flex:1;padding:14px;font-size:1rem}.btn--party-ready{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:99px;margin-top:auto;padding:14px 40px;font-size:1.1rem;font-weight:700;transition:opacity .15s,transform .1s}.btn--party-ready:active{transform:scale(.97)}.btn--done{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2a9d8f,#52b788);border:none;border-radius:99px;width:100%;max-width:260px;padding:14px;font-size:1.1rem;font-weight:900;transition:opacity .15s,transform .1s}.btn--done:active{transform:scale(.97)}.party-handoff{text-align:center;background:var(--surface2);justify-content:center;gap:20px}.handoff-icon{font-size:5rem;line-height:1}.handoff-headline{color:var(--text);font-family:"Baloo 2",Segoe UI,system-ui,sans-serif;font-size:2rem;font-weight:900}.handoff-sub{color:var(--text-muted);max-width:280px;font-size:1rem}.party-build{gap:0;padding:0}.build-header{background:var(--surface2);border-bottom:1px solid #ffffff0d;flex-shrink:0;justify-content:space-between;align-items:center;width:100%;padding:12px 16px;display:flex}.build-player-name{color:var(--accent2);font-size:1.05rem;font-weight:700}.timer-ring{width:52px;height:52px}.party-vote{gap:14px}.vote-grid{grid-template-columns:1fr 1fr;gap:10px;width:100%;display:grid}.vote-card{background:var(--surface);cursor:pointer;border:2px solid #ffffff14;border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:10px 8px 8px;transition:border-color .15s,background .15s,transform .1s;display:flex;position:relative}.vote-card:hover{border-color:#fff3}.vote-card--selected{border-color:var(--accent2);background:#f5a62314}.vote-card:active{transform:scale(.97)}.vote-creature{flex-direction:column;align-items:center;width:100%;display:flex}.vote-img{object-fit:cover;width:88px;height:88px}.vote-img--top{object-position:center bottom;margin-bottom:-3px}.vote-img--bottom{object-position:center top;margin-top:-3px}.vote-seam{background:linear-gradient(90deg, transparent, var(--seam), transparent);opacity:.7;width:100%;height:2px}.vote-name{color:var(--accent2);text-align:center;word-break:break-word;font-size:.82rem;font-weight:700}.vote-check{color:var(--accent2);font-size:1rem;font-weight:900;position:absolute;top:6px;right:8px}.party-results{gap:20px}.results-podium{text-align:center}.winner-crown{margin-bottom:6px;font-size:3.5rem;line-height:1}.winner-headline{color:var(--accent2);font-family:"Baloo 2",Segoe UI,system-ui,sans-serif;font-size:1.8rem;font-weight:900;line-height:1.2}.winner-creature{color:var(--text-muted);margin-top:4px;font-size:1rem}.results-list{flex-direction:column;gap:8px;width:100%;display:flex}.result-row{background:var(--surface);border:1px solid #ffffff0d;border-radius:12px;align-items:center;gap:10px;padding:10px 12px;display:flex}.result-row--winner{border-color:var(--accent2);background:#f5a6230f}.result-rank{color:var(--text-muted);min-width:22px;font-size:1.1rem;font-weight:900}.result-mini{flex-direction:column;flex-shrink:0;width:40px;display:flex}.result-img{object-fit:cover;width:40px;height:40px}.result-img--top{object-position:center bottom;margin-bottom:-3px}.result-img--bottom{object-position:center top;margin-top:-3px}.result-info{flex-direction:column;flex:1;gap:2px;display:flex;overflow:hidden}.result-creature-name{color:var(--accent2);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:700;overflow:hidden}.result-player{color:var(--text-muted);font-size:.78rem}.result-votes{white-space:nowrap;font-size:.85rem}.result-vote-num{color:var(--text-muted)}.results-actions{gap:12px;width:100%;margin-top:auto;display:flex}.results-actions .btn--party-primary{flex:1;width:auto;margin-top:0}
