:root{color-scheme:light;--bg: #f6f0e8;--ink: #1e1a14;--accent: #b83b2d;--accent-soft: #f2c9b8;--panel: #ffffff;--shadow: rgba(30, 26, 20, .12);--radius: 18px;--font-title: "Fraunces", "Bodoni MT", "Didot", serif;--font-body: "IBM Plex Serif", "Georgia", serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-body);color:var(--ink);background:radial-gradient(circle at top,#fff7ea,#f6f0e8 45%,#e9dfd2)}.page{min-height:100vh;display:grid;grid-template-columns:minmax(0,1fr);gap:2rem;padding:4rem clamp(1.5rem,4vw,5rem);position:relative;overflow:hidden}.page:before,.page:after{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(184,59,45,.25),transparent 70%);z-index:0}.page:before{top:-120px;right:-120px}.page:after{bottom:-140px;left:-100px}.hero{max-width:700px;z-index:1;animation:rise .6s ease-out}.tag{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;font-weight:600;color:var(--accent)}.hero h1{font-family:var(--font-title);font-size:clamp(2.5rem,4vw,4rem);margin:1rem 0 .75rem}.hero p{font-size:1.1rem;max-width:520px;margin:0;line-height:1.6}.panel{background:var(--panel);border-radius:var(--radius);padding:2rem;box-shadow:0 16px 40px var(--shadow);display:grid;gap:1.5rem;z-index:1;animation:rise .6s ease-out .1s both}.status{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.status div{padding:1rem 1.25rem;border-radius:14px;background:var(--accent-soft);display:grid;gap:.35rem}.label{text-transform:uppercase;letter-spacing:.12em;font-size:.7rem}.identity h2{font-family:var(--font-title);margin:0 0 .5rem}.identity p{margin:0 0 1rem;line-height:1.5}.note{margin:.5rem 0 0;font-size:.95rem;color:#6b4f3d}.leader h2{font-family:var(--font-title);margin:0 0 .5rem}.leader p{margin:0 0 1rem;line-height:1.5}.leader-summary{font-weight:600;margin-bottom:1rem}.role-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.role-card{padding:1rem;border-radius:16px;background:#f8efe5;box-shadow:inset 0 0 0 1px #e5d5c6}.role-card h3{margin:0 0 .75rem;font-family:var(--font-title);font-size:1.05rem}.role-controls{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.role-controls button{width:36px;height:36px;border-radius:50%;border:none;background:#1e1a14;color:#fffaf4;font-size:1.1rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.role-controls button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.role-controls button:hover{transform:translateY(-1px);box-shadow:0 8px 16px #1e1a1433}.role-controls span{font-size:1.05rem;font-weight:600}.leader-players{margin-top:1.5rem;display:grid;gap:.75rem}.leader-players h3{margin:0;font-family:var(--font-title)}.player-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 1rem;border-radius:12px;background:#f2e7da}.player-row button{border:none;border-radius:999px;padding:.4rem .9rem;background:#a4392d;color:#fffaf4;cursor:pointer;font-weight:600}.player-row button:disabled{opacity:.6;cursor:not-allowed}.phase-info{display:flex;gap:1rem;font-weight:600}.action-panel{display:grid;gap:.75rem;max-width:320px}.action-panel label{font-weight:600}.action-panel select{border-radius:12px;border:1px solid #d7c9bb;padding:.6rem .9rem;font-size:1rem;font-family:var(--font-body)}.action-panel button{border:none;border-radius:999px;padding:.65rem 1.3rem;font-size:.95rem;font-weight:600;background:#1e1a14;color:#fffaf4;cursor:pointer}.vote-list{display:grid;gap:.5rem}.vote-option{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem .9rem;border-radius:12px;border:1px solid #d7c9bb;background:#fffaf4;cursor:pointer}.vote-option.selected{border-color:#b83b2d;background:#f5d9cf}.vote-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;border-radius:999px;background:#1e1a14;color:#fffaf4;font-size:.85rem;font-weight:600}.witch-actions{display:flex;flex-wrap:wrap;gap:.5rem}.toggle-button{border:1px solid #d7c9bb;border-radius:999px;padding:.45rem 1rem;background:#fffaf4;color:var(--ink);cursor:pointer;font-weight:600}.toggle-button.active{border-color:#b83b2d;background:#f5d9cf;color:#7e1b12}.observer-panel{padding:1rem;border-radius:14px;background:#efe6da;display:grid;gap:.5rem}.players-grid{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}.player-pill{padding:.4rem .9rem;border-radius:999px;background:#f2e7da;color:var(--ink);font-size:.95rem}.player-pill.dead{background:#ddd2c6;color:#7b6d60;text-decoration:line-through}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e1a1459;display:grid;place-items:center;padding:1.5rem;z-index:10}.modal{background:#fffaf4;padding:1.5rem;border-radius:16px;box-shadow:0 18px 40px #1e1a1433;max-width:320px;width:100%;text-align:center}.modal h3{margin:0 0 .5rem;font-family:var(--font-title)}.modal button{margin-top:1rem;border:none;border-radius:999px;padding:.6rem 1.3rem;font-weight:600;background:var(--accent);color:#fff8f1;cursor:pointer}.chat-toggle{position:fixed;right:1.25rem;bottom:1.25rem;z-index:11;border:none;border-radius:999px;padding:.7rem 1.1rem;font-weight:700;background:var(--accent);color:#fff8f1;box-shadow:0 12px 24px #1e1a1433;cursor:pointer}.chat-modal{background:#fffaf4;border-radius:16px;box-shadow:0 18px 40px #1e1a1433;width:min(520px,100%);max-height:min(80vh,680px);display:grid;grid-template-rows:auto 1fr auto}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.9rem 1rem .8rem;border-bottom:1px solid #e5d5c6}.chat-header h3{margin:0;font-family:var(--font-title)}.chat-close{border:none;background:transparent;color:#7e1b12;font-size:1.2rem;font-weight:700;cursor:pointer}.chat-list{overflow:auto;padding:.9rem 1rem;display:grid;gap:.6rem}.chat-message{background:#f2e7da;border-radius:12px;padding:.6rem .75rem}.chat-meta{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.chat-message p{margin:.35rem 0 0;line-height:1.4;word-break:break-word}.chat-empty{margin:0;color:#6b4f3d}.chat-form{display:grid;grid-template-columns:1fr auto;gap:.6rem;padding:.9rem 1rem 1rem;border-top:1px solid #e5d5c6}.chat-form input{border-radius:999px;border:1px solid #d7c9bb;padding:.65rem 1rem;font-size:.95rem;font-family:var(--font-body)}.chat-form button{border:none;border-radius:999px;padding:.65rem 1rem;font-weight:600;background:#1e1a14;color:#fffaf4;cursor:pointer}.chat-form button:disabled{opacity:.6;cursor:not-allowed}.primary-action{border:none;border-radius:999px;padding:.75rem 1.6rem;font-size:1rem;font-weight:600;background:var(--accent);color:#fff8f1;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;margin-bottom:1rem}.primary-action:disabled{opacity:.7;cursor:not-allowed}.primary-action:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #b83b2d40}.secondary-action{border:1px solid #b83b2d;border-radius:999px;padding:.7rem 1.5rem;font-size:.95rem;font-weight:600;background:transparent;color:#b83b2d;cursor:pointer;margin-bottom:1rem}.secondary-action:disabled{opacity:.6;cursor:not-allowed}.state-actions{display:flex;flex-wrap:wrap;gap:.75rem}.state-actions button{border:none;border-radius:999px;padding:.6rem 1.3rem;font-size:.95rem;font-weight:600;background:#1e1a14;color:#fffaf4;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.state-actions button:disabled{opacity:.7;cursor:not-allowed}.state-actions button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #1e1a1433}.name-form{display:flex;flex-wrap:wrap;gap:.75rem}.name-form input{flex:1 1 220px;border-radius:999px;border:1px solid #d7c9bb;padding:.75rem 1.25rem;font-size:1rem;font-family:var(--font-body)}.name-form button{border:none;border-radius:999px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;background:var(--accent);color:#fff8f1;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.name-form button:disabled{opacity:.7;cursor:not-allowed}.name-form button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #b83b2d40}.players-list{display:flex;flex-wrap:wrap;gap:.5rem}.players-list span{padding:.4rem .9rem;border-radius:999px;background:#efe6da;font-size:.95rem}.error{padding:.75rem 1rem;border-radius:12px;background:#fbe2df;color:#7e1b12;font-size:.95rem}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 720px){.page{padding:2.5rem 1.5rem}.panel{padding:1.5rem}.chat-toggle{right:1rem;bottom:1rem;padding:.65rem 1rem}.chat-modal{width:100%;max-height:85vh}}
