.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-topbar{position:sticky;top:0;z-index:40;border-bottom:1px solid var(--border, rgba(255, 255, 255, .08));background:#0b0d12c7;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.app-topbar-inner{max-width:1080px;margin:0 auto;padding:.65rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.app-brand{display:flex;align-items:center;gap:.75rem;min-width:0}.app-brand-mark{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#7c9eff,#5ce1c0);box-shadow:0 4px 20px #7c9eff59;flex-shrink:0}.app-brand-title{font-size:1.05rem;font-weight:650;letter-spacing:-.02em;line-height:1.2}.app-brand-tagline{font-size:.78rem;color:var(--text-muted, #9aa3b2);margin-top:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-topbar-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.profile-chip{display:flex;align-items:center;gap:.55rem;padding:.25rem .6rem .25rem .35rem;border-radius:999px;background:#ffffff0d;border:1px solid var(--border, rgba(255, 255, 255, .08));max-width:min(260px,48vw)}.profile-avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:.72rem;font-weight:700;letter-spacing:.02em;background:linear-gradient(145deg,#3d4a6b,#252b3a);color:#e8eaed;flex-shrink:0}.profile-meta{display:flex;flex-direction:column;gap:.05rem;min-width:0}.profile-name{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-role{font-size:.68rem;color:var(--text-muted, #9aa3b2);text-transform:lowercase}.app-flash{max-width:1080px;margin:0 auto;padding:.55rem 1.25rem 0;font-size:.88rem}.app-flash-err{color:#f28b82}.app-flash-ok{color:#81c995}.app-main{flex:1}.app{max-width:1080px;margin:0 auto;padding:1.35rem 1.25rem 3.5rem}.guest-hero{text-align:center;padding:2.5rem 1rem 2rem;margin-bottom:.5rem}.guest-hero-title{font-size:1.35rem;font-weight:650;margin:0 0 .5rem;letter-spacing:-.02em}.guest-hero-text{margin:0 auto;max-width:28rem;color:var(--text-muted, #9aa3b2);font-size:.95rem;line-height:1.5}.guest-hero-status{margin:0 auto .5rem;max-width:22rem;font-size:.95rem;color:#bdc1c6}.guest-hero-err{text-align:left;max-width:32rem;margin:0 auto;padding:1rem 1.15rem;border-radius:14px;background:#ea43351a;border:1px solid rgba(234,67,53,.28)}.guest-hero-err .guest-hero-title{margin-bottom:.45rem}.guest-hero-err .guest-hero-text{margin:0 0 .65rem;max-width:none;color:#f28b82}.guest-hero-hint{margin:0;font-size:.88rem;color:var(--text-muted, #9aa3b2);line-height:1.45}.app-shell--telegram .app-topbar-inner{padding-top:max(.65rem,env(safe-area-inset-top,0px))}.app-shell--telegram .app-main{padding-bottom:env(safe-area-inset-bottom,0px)}.games h2{font-size:1.1rem;margin:0 0 .75rem}.game-card{background:#1a1f2ab8;border-radius:14px;padding:1.05rem 1.15rem;margin-bottom:.85rem;border:1px solid var(--border, rgba(255, 255, 255, .08));box-shadow:0 8px 32px #0003}.game-card time{display:block;font-size:.85rem;color:#9aa0a6;margin-bottom:.35rem}.game-card .loc{font-size:.95rem}.badge{display:inline-block;font-size:.75rem;padding:.15rem .45rem;border-radius:4px;background:#2d3139;margin-top:.5rem;text-transform:lowercase}.err{color:#f28b82;font-size:.9rem}.empty{color:#9aa0a6;font-size:.95rem}.auth-panel{background:#1a1f2ab8;border-radius:14px;padding:1rem 1.15rem;margin-bottom:1.5rem;border:1px solid var(--border, rgba(255, 255, 255, .08))}.auth-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#04060aa6;display:grid;place-items:center;z-index:60;padding:1rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.auth-modal{width:min(440px,100%);background:linear-gradient(165deg,#1e2430fa,#12151cfc);border:1px solid var(--border, rgba(255, 255, 255, .1));border-radius:16px;padding:1.15rem 1.2rem 1.25rem;box-shadow:0 24px 80px #0000008c}.auth-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.65rem}.auth-modal-title{font-size:1.05rem;font-weight:650;margin:0;letter-spacing:-.02em}.auth-modal-close{border:none;background:#ffffff0f;color:#bdc1c6;width:2rem;height:2rem;border-radius:8px;font-size:1.35rem;line-height:1;cursor:pointer;display:grid;place-items:center;flex-shrink:0}.auth-modal-close:hover{background:#ffffff1f;color:#e8eaed}.auth-mode-switch{margin-bottom:.75rem}.auth-form-stack{flex-direction:column;align-items:stretch}.auth-form-stack .auth-input,.auth-form-stack .btn{width:100%;min-width:0}.auth-modal-err{margin:.85rem 0 0}.auth-title{font-size:.95rem;margin:0 0 .75rem;font-weight:600}.auth-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.auth-input{flex:1;min-width:200px;padding:.55rem .75rem;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#080a0e8c;color:#e8eaed;font-size:.9rem}.auth-input:focus{outline:none;border-color:#7c9eff8c;box-shadow:0 0 0 3px var(--accent-soft, rgba(124, 158, 255, .18))}.auth-me{margin:.75rem 0 0;font-size:.9rem;color:#bdc1c6}.err.small{margin:.5rem 0 0;font-size:.85rem}.reg-msg{margin:.5rem 0 0;font-size:.9rem;color:#81c995}.btn{padding:.5rem .95rem;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#e8eaed;font-size:.85rem;font-weight:500;cursor:pointer}.btn:hover:not(:disabled){background:#ffffff1a}.btn-ghost{border-color:transparent;background:transparent}.btn-ghost:hover:not(:disabled){background:#ffffff0f}.btn-outline{background:transparent;border-color:#ffffff2e}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#8ab4f8,#6ec8ff);color:#0d1117;border-color:transparent;box-shadow:0 4px 16px #7c9eff47}.btn-primary:hover:not(:disabled){filter:brightness(1.06);box-shadow:0 6px 22px #7c9eff59}.btn-small{padding:.25rem .6rem;font-size:.8rem}.game-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:.65rem;flex-wrap:wrap}.admin-panel{background:#1a1f2ab8;border-radius:14px;padding:1rem 1.15rem;margin-bottom:1.5rem;border:1px solid var(--border, rgba(255, 255, 255, .08))}.form-block{margin-top:.75rem}.form-block h4{margin:0 0 .45rem;font-size:.9rem;color:#bdc1c6;font-weight:600}select.auth-input{-webkit-appearance:none;-moz-appearance:none;appearance:none}.game-actions{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.action-select{min-width:165px;width:auto;flex:initial;padding:.25rem .45rem;font-size:.8rem}.leader-list{margin-top:.75rem}.leader-row{display:grid;grid-template-columns:48px 1fr 64px;gap:.5rem;font-size:.9rem;padding:.35rem 0;border-bottom:1px solid #2d3139}.users-list{margin-top:.5rem;display:grid;gap:.45rem}.user-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem}.tabs{display:flex;gap:.35rem;margin-bottom:1.15rem;flex-wrap:wrap;padding:.25rem;border-radius:12px;background:#ffffff0a;border:1px solid var(--border, rgba(255, 255, 255, .06))}.tab-btn{padding:.45rem .95rem;border-radius:9px;border:1px solid transparent;background:transparent;color:var(--text-muted, #9aa3b2);cursor:pointer;font-weight:500;font-size:.86rem}.tab-btn:hover{color:#e8eaed;background:#ffffff0d}.tab-btn.active{background:#7c9eff33;color:#e8eeff;border-color:#7c9eff59}.view-only-note{margin:-.35rem 0 .9rem;color:#9aa0a6;font-size:.86rem}.table-page{margin-bottom:1.5rem}.table-page-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;padding:.8rem;background:#0f171c;overflow:auto}.table-toolbar{display:flex;gap:.6rem;margin-bottom:.8rem;flex-wrap:wrap}.table-layout{display:grid;grid-template-columns:1.35fr .9fr;gap:.9rem}.table-subtabs{display:flex;gap:.45rem;margin-bottom:.65rem;flex-wrap:wrap}.table-arena{background:radial-gradient(circle at 30% 20%,#1f4750,#102a31 65%,#0d2026);border:1px solid #2d4f57;border-radius:16px;min-height:520px;padding:1rem}.table-felt{position:relative;width:100%;height:100%;min-height:480px;border-radius:240px;border:3px solid rgba(120,230,219,.35);background:radial-gradient(circle at 35% 35%,#1f5861a6,#09262df2)}.seat{position:absolute;transform:translate(-50%,-50%);text-align:center;width:110px}.seat-avatar-wrap{position:relative;width:58px;margin:0 auto .25rem}.seat-avatar{width:54px;height:54px;border-radius:50%;margin:0 auto .25rem;background:#d3f7ff;color:#1b2730;display:grid;place-items:center;font-weight:700;border:2px solid #7ee3dd}.seat-team-mafia .seat-avatar{background:#ffe0e0;border-color:#ff8f8f;box-shadow:0 0 0 3px #ff5f5f2e}.seat-team-town .seat-avatar{background:#d8f3ff;border-color:#6ac9ff;box-shadow:0 0 0 3px #62c2ff29}.seat-team-neutral .seat-avatar{background:#f0dcff;border-color:#bf90ff;box-shadow:0 0 0 3px #be83ff33}.seat-team-unknown .seat-avatar{background:#d3f7ff;border-color:#7ee3dd}.seat-status{position:absolute;right:-26px;top:50%;transform:translateY(-50%);font-size:.58rem;border-radius:999px;padding:.1rem .35rem;border:1px solid transparent}.seat-status.alive{color:#d2ffd9;background:#266e478c;border-color:#74e09d80}.seat-status.dead{color:#ffd6d6;background:#6e26268c;border-color:#eb808080}.seat-name{font-size:.75rem;color:#d7f2f5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.seat-role{margin-top:.12rem;font-size:.63rem;color:#9bc8cf;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.seat-team-mafia .seat-role{color:#ffb8b8}.seat-team-town .seat-role{color:#bde8ff}.seat-team-neutral .seat-role{color:#e5c8ff}.seat-dead .seat-avatar{filter:grayscale(.9);opacity:.55}.table-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);text-align:center}.moon{width:110px;height:110px;border-radius:50%;margin:0 auto .7rem;background:radial-gradient(circle at 35% 30%,#f7f7f8,#bcc4ce 65%,#8f98a5);box-shadow:0 0 35px #d5ebff59}.table-center-text{color:#effbfd}.table-side{display:grid;gap:.75rem}.table-pager{margin-top:.7rem;display:flex;align-items:center;justify-content:center;gap:.6rem;color:#d2e9ed}.table-bottom-actions{margin-top:.75rem;display:flex;gap:.55rem;flex-wrap:wrap;justify-content:center}.role-badge{border:1px solid transparent}.role-badge-mafia{background:#7521216b;color:#ffd7d7;border-color:#ff8f8f8c}.role-badge-town{background:#21507561;color:#dbf4ff;border-color:#86cdff8c}.role-badge-neutral{background:#5f2f7a61;color:#f0e1ff;border-color:#c491ff8c}.role-badge-unknown{background:#445d6159;color:#d2e9ed;border-color:#84b2ba73}@media (max-width: 860px){.app{padding:1rem .85rem 2.5rem}.app-topbar-inner{padding:.55rem .85rem}.app-flash{padding-left:.85rem;padding-right:.85rem}.auth-input{min-width:140px}.action-select{min-width:130px;max-width:100%}.leader-row{grid-template-columns:42px 1fr 56px;font-size:.85rem}.user-row{gap:.35rem}.btn,.btn-small{padding:.35rem .6rem;font-size:.78rem}.game-card-footer,.game-actions,.auth-row{align-items:stretch}.table-layout{grid-template-columns:1fr}.table-arena{min-height:460px}.table-felt{min-height:420px}.seat{width:92px}.seat-avatar{width:48px;height:48px;font-size:.78rem}.seat-status{right:-20px}}@media (max-width: 560px){.tab-btn{flex:1;text-align:center}.auth-row{display:grid;grid-template-columns:1fr}.user-row{display:grid;grid-template-columns:1fr;align-items:start}.game-card-footer,.game-actions{display:grid;grid-template-columns:1fr}.auth-input,.action-select,.btn,.btn-small{width:100%;min-width:0}}:root{font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;color:#e8eaed;background-color:#0b0d12;--surface-0: #0b0d12;--surface-1: #12151c;--surface-2: #1a1f2a;--border: rgba(255, 255, 255, .08);--accent: #7c9eff;--accent-soft: rgba(124, 158, 255, .18);--text-muted: #9aa3b2}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(1200px 600px at 10% -10%,rgba(124,158,255,.12),transparent 55%),radial-gradient(900px 500px at 100% 0%,rgba(126,234,200,.06),transparent 50%),var(--surface-0)}html[data-tg-web-app="1"] body{background:rgb(var(--tg-bg-rgb, 11 13 18) / 1)}a{color:#8ab4f8}
