body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--bg:#050816;--bg-elevated:#0b1020;--bg-card:#111827;--accent:#ec4899;--accent-soft:#ec489926;--accent-strong:#db2777;--text:#f9fafb;--text-muted:#e5e7eb;--danger:#ef4444;--success:#22c55e;--border-subtle:#1f2937;--radius-lg:18px;--radius-md:12px;--shadow-soft:0 18px 40px #0f172a99}*{box-sizing:border-box}body{background:radial-gradient(circle at top,#ffb6c1 0,#ec4899 45%,#7e22ce 100%);color:#f9fafb;color:var(--text);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0}.app-root{display:flex;justify-content:center;min-height:100vh;padding:5px}.app-shell{background:linear-gradient(180deg,#0f172a40,#0f172ab3);border:1px solid #f8fafc33;border-radius:28px;box-shadow:0 18px 40px #0f172a99;box-shadow:var(--shadow-soft);max-height:calc(100vh - 30px);max-width:1400px;min-height:calc(100vh - 36px);padding:18px 22px 22px;width:100%}.app-header{gap:16px;justify-content:space-between;margin-bottom:10px}.app-header,.app-title{align-items:center;display:flex}.app-title{gap:10px}.app-title h1{font-size:26px;letter-spacing:.12em;margin:0}.app-pill,.app-title h1{text-transform:uppercase}.app-pill{background:#0f172a4d;border:1px solid #f8fafcb3;border-radius:999px;color:#f9fafb;color:var(--text);font-size:11px;letter-spacing:.14em;padding:4px 10px}.app-status{font-size:13px;text-align:right}.app-status span{display:block}.badge-connection{align-items:center;background:#0f172ab3;border:1px solid #f8fafc80;border-radius:999px;display:inline-flex;font-size:12px;gap:6px;padding:2px 10px}.badge-dot{border-radius:999px;height:8px;width:8px}.team-card-avatar-main{align-items:center;background:radial-gradient(circle at top,#f9a8d4,#ec4899);border:2px solid #f8fafcb3;border-radius:14px;cursor:pointer;display:flex;height:80px;justify-content:center;margin-bottom:6px;margin-top:4px;overflow:hidden;width:100px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideUpCard{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes glowPulse{0%{box-shadow:0 0 0 0 #22c55e99,0 12px 30px #0f172ae6;transform:translateY(0) scale(1)}50%{box-shadow:0 0 0 8px #22c55e00,0 20px 40px #22c55e80;transform:translateY(-2px) scale(1.02)}to{box-shadow:0 0 0 0 #22c55e99,0 12px 30px #0f172ae6;transform:translateY(0) scale(1)}}@keyframes popIn{0%{opacity:0;transform:scale(.9)}70%{opacity:1;transform:scale(1.04)}to{transform:scale(1)}}.team-card-avatar-img{height:100px;width:100px}.team-card-avatar-placeholder{font-size:32px;font-weight:800;letter-spacing:.1em}@keyframes shakeWrong{0%{transform:translateX(0)}15%{transform:translateX(-8px)}30%{transform:translateX(8px)}45%{transform:translateX(-6px)}60%{transform:translateX(6px)}75%{transform:translateX(-3px)}to{transform:translateX(0)}}.shake-wrong{animation:shakeWrong .4s ease}@keyframes scorePop{0%{opacity:0;transform:translateY(0) scale(.7)}25%{opacity:1;transform:translateY(-8px) scale(1.2)}70%{opacity:1;transform:translateY(-8px) scale(1)}to{opacity:0;transform:translateY(0) scale(.7)}}.game-main-area{animation:fadeIn .3s ease-out;display:flex;flex:1 1;flex-direction:column;max-height:60vh;min-height:0;width:100%}.game-screen{gap:12px;overflow:hidden}.game-bottom{flex-shrink:0;height:100px}.score-change{animation:scorePop 1s ease-out forwards;color:#fef08a;font-size:20px;font-weight:800;left:50%;pointer-events:none;position:absolute;text-shadow:0 0 6px #000c;top:-10px;transform:translateX(-50%)}.avatar-picker{animation:fadeIn .2s ease-out;display:flex;flex-wrap:wrap;gap:4px;margin:6px 0 8px}.btn-avatar{height:42px;width:42px}.btn-avatar--selected{outline:2px solid #22c55e;outline-offset:2px}.badge-dot--ok{background:#22c55e;box-shadow:0 0 8px #22c55ecc}.badge-dot--bad{background:#ef4444;box-shadow:0 0 8px #ef4444cc}.panel{background:radial-gradient(circle at top left,#0f172ae6,#0f172afa);border:1px solid #1f2937;border:1px solid var(--border-subtle);border-radius:18px;border-radius:var(--radius-lg);padding:16px 18px 18px}.panel--primary{box-shadow:0 14px 30px #0f172ab3}.panel-header{align-items:baseline;display:flex;gap:10px;justify-content:space-between;margin-bottom:12px}.panel-header h2{font-size:16px;letter-spacing:.08em;margin:0;text-transform:uppercase}.panel-subtitle{color:#e5e7eb;color:var(--text-muted);font-size:12px}.error-text{color:#ef4444;color:var(--danger);font-size:13px;margin:4px 0}.form-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.form-row label{color:#e5e7eb;color:var(--text-muted);font-size:12px}.input{background:#0f172ab3;border:1px solid #f8fafc80;border-radius:12px;border-radius:var(--radius-md);color:#f9fafb;color:var(--text);font-size:13px;min-width:160px;padding:7px 9px}.input:focus{border-color:#f9a8d4;box-shadow:0 0 0 1px #f9a8d499;outline:none}.btn{align-items:center;background:#0f172ae6;border:1px solid #f8fafc80;border-radius:12px;border-radius:var(--radius-md);color:#f9fafb;color:var(--text);cursor:pointer;display:inline-flex;font-size:13px;gap:6px;padding:7px 12px;transition:transform .05s ease,box-shadow .05s ease,background .1s ease}.btn:hover:not(:disabled){background:#0f172afa;box-shadow:0 9px 18px #0f172ae6;transform:translateY(-1px)}.btn:disabled{box-shadow:none;cursor:default;opacity:.45}.btn--primary{background:linear-gradient(135deg,#f472b6,#ec4899);border-color:#0000}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,#ec4899,#f472b6)}.btn--ghost{background:#0000}.tag{background:#0f172ad9;border:1px solid #f8fafc99;border-radius:999px;color:#f9fafb;color:var(--text);display:inline-block;font-size:11px;padding:2px 8px}.tag--gm{background:radial-gradient(circle at top,#f8fafc1a,#f59e0be6);border-color:#fde68a;color:#fef9c3}.lobby-body,.mainmenu{align-items:center;display:flex;justify-content:center}.mainmenu{gap:14px;width:30vw}.mainmenu,.team-card{flex-direction:column}.team-card{align-items:center;background:linear-gradient(135deg,#f8fafc1a,#f8fafc0d);border:1px solid #f8fafc99;border-radius:12px;border-radius:var(--radius-md);display:flex;justify-content:space-around;margin-bottom:8px;padding:10px 11px;width:100%}.team-name-label{font-size:14px;font-weight:600}.team-name-input-edit{background:#0f172ab3;border:1px solid #f8fafc80;border-radius:8px;color:#f9fafb;color:var(--text);font-size:14px;padding:4px 8px;width:100%}.team-name-actions{display:flex;gap:6px;margin-left:auto}.team-name-btn{background:#0f172ae6;border:1px solid #f8fafc80;border-radius:6px;cursor:pointer;font-size:14px;padding:2px 8px;transition:background .1s ease}.team-card--mine{background:linear-gradient(135deg,#0f172aeb,#0f172afa);border-color:#a5f3fc!important;box-shadow:0 0 14px #38bdf899,0 0 28px #38bdf84d;position:relative;transition:box-shadow .25s ease,border-color .25s ease}@keyframes memberJoin{0%{opacity:0;transform:translateX(-12px)}50%{opacity:1;transform:translateX(4px)}to{transform:translateX(0)}}.team-member-join{animation:memberJoin .6s ease-out}.avatar-picker-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a99;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:500}.avatar-picker-panel{animation:popIn .25s ease-out;background:linear-gradient(180deg,#0f172af2,#0f172afa);border:1px solid #f8fafc40;border-radius:18px;box-shadow:0 16px 40px #00000080;padding:18px;width:320px}.avatar-picker-title{font-size:16px;letter-spacing:.04em;margin:0 0 12px;text-align:center}.avatar-picker-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr);margin-bottom:12px}.avatar-picker-close{background:#0f172ad9;border:1px solid #f8fafc66;border-radius:10px;color:#f9fafb;color:var(--text);cursor:pointer;margin-top:10px;padding:8px;width:100%}.board-info-bar{align-items:center;animation:fadeIn .3s ease-out;background:#0f172ad9;border:1px solid #f8fafc40;border-radius:12px;display:flex;font-size:13px;gap:8px;justify-content:center;margin-top:16px;padding:8px 12px}.cat-color-0 .category-title{background:linear-gradient(180deg,#bfdbfe,#60a5fa);color:#1e3a8a}.cat-color-0 .question-button:not(.question-button--answered){background:linear-gradient(180deg,#bfdbfe4d,#3b82f640);border-color:#bfdbfee6}.cat-color-1 .category-title{background:linear-gradient(180deg,#fed7aa,#fb923c);color:#7c2d12}.cat-color-1 .question-button:not(.question-button--answered){background:linear-gradient(180deg,#fed7aa4d,#f9731640);border-color:#fed7aae6}.cat-color-2 .category-title{background:linear-gradient(180deg,#bbf7d0,#4ade80);color:#14532d}.cat-color-2 .question-button:not(.question-button--answered){background:linear-gradient(180deg,#bbf7d04d,#22c55e40);border-color:#bbf7d0e6}.cat-color-3 .category-title{background:linear-gradient(180deg,#f9a8d4,#ec4899);color:#831843}.cat-color-3 .question-button:not(.question-button--answered){background:linear-gradient(180deg,#f9a8d44d,#ec489940);border-color:#f9a8d4e6}.cat-color-4 .category-title{background:linear-gradient(180deg,#a5b4fc,#6366f1);color:#1e1b4b}.cat-color-4 .question-button:not(.question-button--answered){background:linear-gradient(180deg,#a5b4fc4d,#6366f140);border-color:#a5b4fce6}.cat-color-5 .category-title{background:linear-gradient(180deg,#facc15,#eab308);color:#713f12}.cat-color-5 .question-button:not(.question-button--answered){background:linear-gradient(180deg,#facc154d,#eab30840);border-color:#facc15e6}.board-info-label{color:#e5e7eb;color:var(--text-muted);letter-spacing:.03em}.board-info-title{color:#f9fafb;color:var(--text);font-weight:600;letter-spacing:.04em}.board-select{align-items:center;display:flex;gap:4px}.team-member-badge{background:#7dd3fc;border-radius:8px;box-shadow:0 0 6px #38bdf899;color:#0f172a;font-size:11px;font-weight:600;margin-left:6px;padding:1px 6px}.team-member-name{background:#f8fafc14;border-radius:6px;color:#f1f5f9;display:inline-block;font-weight:600;letter-spacing:.02em;margin:1px 0;padding:2px 6px}.team-card--mine .team-member-name{background:#38bdf82e;color:#e0f2fe;font-weight:700}.team-card--mine:after{background:#22d3ee;border-radius:50%;box-shadow:0 0 12px #22d3ee;content:"";height:14px;left:-4px;position:absolute;top:-4px;width:14px}.team-name-save{color:#22c55e}.team-name-cancel{color:#ef4444}.team-name-edit{color:#e5e7eb;margin-left:auto;padding:2px 8px}.team-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.team-card-title{font-size:14px;font-weight:600}.team-members{font-size:13px;list-style:none;margin:0 0 6px;padding-left:0}.team-members li{color:#e5e7eb;color:var(--text-muted)}.players-list{font-size:13px;list-style:none;margin:6px 0 0;padding-left:0}.players-list li{color:#e5e7eb;color:var(--text-muted)}.game-screen{animation:fadeIn .4s ease-out;display:flex;flex-direction:column;gap:10px;height:calc(100vh - 110px);margin-top:10px}.game-top{display:flex;flex:1 1;flex-direction:column}.game-bottom{margin-top:6px}.scoreboard{font-size:14px;margin-bottom:8px}.board{background:linear-gradient(180deg,#f472b6e6,#ec4899e6);border:2px solid #f8fafcb3;border-radius:20px;display:flex;flex:1 1;flex-direction:column;gap:10px;min-height:0;padding:10px 15px;width:100%}.board-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.board-current-team,.board-header{font-size:13px}.board-grid{grid-gap:10px;display:grid;flex:1 1;gap:10px;grid-auto-rows:1fr;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));min-height:0}.category-column{display:flex;flex-direction:column;gap:8px;min-height:0}.category-title{background:linear-gradient(180deg,#f8fafccc,#f8fafcf2);border-radius:14px;color:#db2777;font-size:13px;font-weight:600;letter-spacing:.06em;padding:8px 6px;text-align:center;text-transform:uppercase}.question-cell{flex:1 1;min-height:0}.question-button{align-items:center;background:linear-gradient(180deg,#f8fafc2e,#f8fafc0d);border:1px solid #fff6;border-radius:12px;display:flex;font-size:18px;font-weight:700;height:100%;justify-content:center;min-height:50px;width:100%}.question-button:hover:not(:disabled){background:linear-gradient(180deg,#f8fafc4d,#f8fafc14);box-shadow:0 10px 20px #a21cafb3;transform:translateY(-2px)}.question-button:disabled{box-shadow:none;cursor:default}.question-button--answered{background:#f8fafc14;border-color:#f8fafc59;border-style:solid;color:#f8fafc80;opacity:.4}.question-button:hover:not(:disabled):not(.question-button--answered){background:linear-gradient(180deg,#f8fafc4d,#f8fafc14);box-shadow:0 10px 20px #a21cafb3;transform:translateY(-2px) scale(1.03)}.question-button--disabled:not(.question-button--answered){background:#f8fafc14;border-color:#f8fafc47;color:#f8fafcb3}.question-button--disabled{cursor:default;opacity:.4;pointer-events:none}.question-view{animation:slideUpCard .35s ease-out;background:linear-gradient(180deg,#0f172aeb,#0f172af7);border:1px solid #f8fafccc;border-radius:12px;border-radius:var(--radius-md);margin-top:8px;padding:12px 13px 13px}.question-heading{align-items:baseline;display:flex;font-size:13px;justify-content:space-between}.question-heading-title{font-weight:600;letter-spacing:.06em;text-transform:uppercase}.question-points{color:#f9a8d4;font-size:12px}.question-body{animation:popIn .3s ease-out;font-size:18px;margin-top:10px}.question-answer{color:#bbf7d0;font-size:16px;margin-top:10px}.question-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.helper-text{color:#e5e7eb;color:var(--text-muted);font-size:12px;margin-top:10px}.teams-bar{display:flex;gap:10px;justify-content:space-around;max-height:20vh}@media (max-width:900px){.teams-bar{flex-wrap:wrap;justify-content:center}}.team-card-game{align-items:stretch;background:linear-gradient(145deg,#0f172ae6,#0f172af5);border:2px solid #f8fafc99;border-radius:18px;box-shadow:0 8px 24px #0f172ae6;display:flex;flex:1 1;flex-direction:column;height:250px;max-width:260px;min-width:160px;padding:6px 8px 10px}.team-card-game--active{animation:glowPulse 1.8s ease-in-out infinite;border-color:#22c55e;border-color:var(--success);box-shadow:0 0 0 3px #22c55e80,0 12px 30px #22c55e66}.team-avatar-wrap{align-items:center;border-radius:14px;display:flex;flex:1 1;justify-content:center;overflow:hidden}.endscreen{animation:fadeIn .6s ease-out;padding-top:40px;text-align:center}.endscreen-title{font-size:32px;letter-spacing:.06em;margin-bottom:24px;text-shadow:0 0 10px #fff6}.endscreen-results{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin-bottom:20px}.endscreen-card{animation:popIn .5s ease-out;background:linear-gradient(180deg,#0f172ae6,#0f172af5);border:2px solid #f8fafc80;border-radius:18px;box-shadow:0 12px 20px #0006;padding:14px;width:200px}.endscreen-place{font-size:32px;margin-bottom:8px}.endscreen-avatar img{background:#ffffff1a;border-radius:12px;height:90px;margin-bottom:8px;object-fit:contain;width:90px}.endscreen-name{font-size:16px;font-weight:700;margin-bottom:6px}.endscreen-score{color:#f9a8d4;font-size:14px}.team-avatar-placeholder{font-size:38px;font-weight:800;letter-spacing:.1em}.team-info-row{align-items:center;display:flex;font-size:20px;justify-content:center;margin:6px 0}.team-info-name{font-weight:600}.team-info-score{font-weight:700}.avatar-choices{display:flex;flex-wrap:wrap;gap:4px;margin:4px 0 6px}.btn-avatar{align-items:center;background:#0f172ad9;border:1px solid #f8fafc99;border-radius:999px;display:inline-flex;font-size:17px;height:28px;justify-content:center;transition:transform .05s ease,box-shadow .05s ease,background .1s ease;width:28px}.btn-avatar:hover{background:#0f172afa;box-shadow:0 6px 10px #0f172ae6;transform:translateY(-1px)}.btn-avatar--selected{background:linear-gradient(135deg,#f472b6,#ec4899);border-color:#0000;box-shadow:0 0 0 2px #f8fafce6}.avatar-preview{border-radius:6px;height:100%;object-fit:cover;width:100%}.btn-avatar{border-radius:8px;cursor:pointer;height:48px;overflow:hidden;padding:0;width:48px}.btn-avatar--selected{outline:3px solid #22c55e}.team-info-players{text-align:center;width:100%}.team-avatar-img{border:2px solid #f8fafcb3;height:100%;object-fit:contain}.lobby-players{margin-top:10px;text-align:center}.lobbyCodeFont{display:flex}.lobby-players h3{font-size:14px;margin:0 0 6px}.lobby-players-list{display:flex;flex-wrap:wrap;font-size:13px;gap:6px 10px;justify-content:center}.lobby-player-pill{background:#0f172acc;border:1px solid #f8fafc66;border-radius:999px;padding:2px 10px}.lobby-teams-section{margin-top:18px}.lobby-teams-title{font-size:14px;letter-spacing:.08em;margin-bottom:10px;text-align:center;text-transform:uppercase}.teams-grid-lobby{display:flex;flex-wrap:wrap;gap:18px;justify-content:space-around}.team-slot{flex:1 1;max-width:260px;min-width:180px}.team-card-empty,.team-slot{display:flex;justify-content:center}.team-card-empty{align-items:center;background:linear-gradient(180deg,#f472b666,#4c1d95b3);border:3px solid #f8fafce6;border-radius:18px;cursor:pointer;min-height:230px;width:100%}.team-card-empty-plus{font-size:40px;line-height:1}.team-name-input{background:#0000;border:none;color:#f9fafb;color:var(--text);font-size:14px;font-weight:600;outline:none;padding:0}
/*# sourceMappingURL=main.617ac8bb.css.map*/