:root{--ink: #2a1d10;--ink-soft: #4f3a23;--parch: #efdcb4;--parch-2: #e4cf9f;--parch-edge: #c9ad77;--gold: #c79a3f;--gold-bright: #e9c66a;--wood: #1a1109;--wood-2: #2c1c0e;--blood: #7c241c;--good: #2f6fb0;--good-2: #3fa7a0;--evil: #b8543a;--demon: #8d1414;--shadow: 0 10px 28px rgba(0, 0, 0, .5);--serif: "EB Garamond", Georgia, serif;--title: "Cinzel", serif;--display: "Cinzel Decorative", "Cinzel", serif}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:var(--serif);color:var(--ink);background:radial-gradient(120% 90% at 50% -10%,#3a2613,#1d1208 55%,#120b05);overflow:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.06;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}#app{position:relative;z-index:1;display:flex;flex-direction:column;height:100vh}button{font-family:inherit;cursor:pointer}.topbar{display:flex;align-items:center;gap:22px;padding:12px 22px;background:linear-gradient(180deg,#2c1c0e,#1d130a);border-bottom:2px solid #3c2814;box-shadow:0 6px 18px #00000073;flex:none}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:38px;height:38px;color:var(--gold-bright);flex:none;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}.brand h1{font-family:var(--display);font-weight:900;font-size:22px;line-height:1;color:var(--parch);letter-spacing:.5px;text-shadow:0 1px 0 #000,0 0 14px rgba(201,154,64,.25)}.brand p{font-family:var(--title);font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-top:4px}.count-block{display:flex;align-items:center;gap:12px;margin-left:auto}.count-num{font-family:var(--display);font-size:30px;color:var(--gold-bright);line-height:1}.count-lbl{font-family:var(--title);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:#b79a6d;margin-left:-6px}.dist{display:flex;gap:6px;margin-left:8px}.chip{display:inline-flex;align-items:center;gap:4px;font-family:var(--title);font-size:12px;padding:4px 8px;border-radius:999px;background:#241809;color:var(--parch);border:1px solid #3d2914}.chip b{font-size:11px;opacity:.8}.chip.team-townsfolk{box-shadow:inset 0 0 0 1px #2f6fb080}.chip.team-outsider{box-shadow:inset 0 0 0 1px #3fa7a080}.chip.team-minion{box-shadow:inset 0 0 0 1px #b8543a80}.chip.team-demon{box-shadow:inset 0 0 0 1px #8d141499}.chip.ok{color:var(--gold-bright)}.chip.over,.chip.warn{color:#e6a15a}.chip.under{color:#cdb78c}.actions{display:flex;gap:8px}.btn{font-family:var(--title);font-size:13px;letter-spacing:.5px;color:var(--parch);background:linear-gradient(180deg,#3a2614,#2a1a0c);border:1px solid #4d3318;border-radius:8px;padding:9px 13px;transition:transform .08s ease,box-shadow .15s ease,background .15s ease;box-shadow:0 2px #160d05,inset 0 1px #ffdc9614}.btn:hover{background:linear-gradient(180deg,#4a3119,#34200f);transform:translateY(-1px)}.btn:active{transform:translateY(1px);box-shadow:0 0 #160d05}.btn.primary{color:#20140a;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-color:#8a6a26;font-weight:700}.btn.primary:hover{background:linear-gradient(180deg,#f4d684,#d3a847)}.btn.ghost{background:transparent;color:#b79a6d;border-color:#44301a;box-shadow:none}.btn.ghost:hover{color:var(--parch);background:#ffffff0a}.stage{flex:1;display:flex;min-height:0}.board{position:relative;flex:1;overflow:hidden}.table-felt{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(74vmin,70%);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle at 50% 42%,#355a3c,#244430 48%,#16301f);box-shadow:0 0 0 14px #2c1c0e,0 0 0 16px #4a3219,inset 0 0 60px #0009,0 30px 60px #0000008c}.table-ring{position:absolute;top:7%;right:7%;bottom:7%;left:7%;border-radius:50%;border:2px dashed rgba(201,154,64,.35)}.table-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#e9c66a80}.center-crest{width:23%;max-width:120px}.center-sub{font-family:var(--display);font-size:clamp(13px,2.4vmin,22px);letter-spacing:4px;text-transform:uppercase;color:#e9c66a6b}.tokens,.reminders{position:absolute;top:0;right:0;bottom:0;left:0}.reminders{pointer-events:none}.reminder{pointer-events:auto}.token{position:absolute;transform:translate(-50%,-50%);width:104px;display:flex;flex-direction:column;align-items:center;touch-action:none;-webkit-user-select:none;user-select:none;cursor:grab}.token.dragging{cursor:grabbing;z-index:60}.token .disc{position:relative;width:92px;height:92px;border-radius:50%;background:radial-gradient(circle at 38% 32%,#fff6e2,var(--parch) 55%,var(--parch-2) 100%);border:2px solid var(--parch-edge);box-shadow:0 0 0 4px #2a1a0c,0 0 0 6px var(--gold),var(--shadow),inset 0 2px 6px #ffffff80;display:flex;align-items:center;justify-content:center;overflow:hidden}.token .char-img{width:100%;height:100%;object-fit:contain;padding:6px;mix-blend-mode:multiply}.token.empty .disc{background:radial-gradient(circle at 40% 32%,#efe2c4,#cdb585)}.disc-empty{color:#8a6f43;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.token .name-band{margin-top:-10px;position:relative;z-index:2;font-family:var(--title);font-size:12px;font-weight:600;letter-spacing:.3px;color:var(--parch);padding:3px 12px;border-radius:4px;max-width:118px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center;background:linear-gradient(180deg,#4a3119,#2c1b0c);border:1px solid var(--gold);box-shadow:0 2px 6px #00000080}.token .player-name{margin-top:5px;font-style:italic;font-size:15px;color:#f0e2bf;text-shadow:0 1px 3px rgba(0,0,0,.8);text-align:center;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.token.t-townsfolk .disc{box-shadow:0 0 0 4px #2a1a0c,0 0 0 6px var(--good),var(--shadow),inset 0 2px 6px #ffffff80}.token.t-outsider .disc{box-shadow:0 0 0 4px #2a1a0c,0 0 0 6px var(--good-2),var(--shadow),inset 0 2px 6px #ffffff80}.token.t-minion .disc{box-shadow:0 0 0 4px #2a1a0c,0 0 0 6px var(--evil),var(--shadow),inset 0 2px 6px #ffffff80}.token.t-demon .disc{box-shadow:0 0 0 4px #2a1a0c,0 0 0 6px var(--demon),0 0 22px #a01e1e99,var(--shadow),inset 0 2px 6px #ffffff80}.token.dead .disc{filter:grayscale(.7) brightness(.82)}.token.dead .char-img{opacity:.8}.token.dead .player-name{color:#b6a988}.shroud{position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;color:#20140a;opacity:.82;pointer-events:none}.vote{position:absolute;right:-4px;bottom:-2px;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;z-index:4;background:radial-gradient(circle at 38% 32%,#fff6e2,var(--parch));border:2px solid var(--gold);color:#4a3119;box-shadow:0 2px 5px #00000080}.vote.used{color:var(--blood);background:#d8c49a}.token-del{position:absolute;top:-3px;right:3px;width:20px;height:20px;border-radius:50%;border:2px solid #2a1a0c;background:radial-gradient(circle at 35% 30%,#b54035,#6b1f18);color:#fff;font-size:13px;line-height:1;z-index:6;cursor:pointer;padding:0;display:none;align-items:center;justify-content:center;box-shadow:0 2px 5px #00000080}.token-del:hover{background:radial-gradient(circle at 35% 30%,#c8493c,#7d231b)}.token:hover .token-del{display:flex}.reminder{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;gap:5px;padding:3px 9px 3px 4px;border-radius:999px;background:radial-gradient(circle at 30% 25%,#fff6e2,var(--parch) 70%);border:1.5px solid var(--gold);box-shadow:0 3px 8px #00000073;font-family:var(--title);font-size:11px;color:#3a2714;white-space:nowrap;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;z-index:30}.reminder.dragging{cursor:grabbing;z-index:70}.reminder .rem-img{width:22px;height:22px;object-fit:contain;mix-blend-mode:multiply}.reminder.generic{border-color:#9a7f4f}.reminder.generic .rem-label:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:#7c5a2c;margin-right:5px;vertical-align:middle}.reminder.t-minion{border-color:var(--evil)}.reminder.t-demon{border-color:var(--demon)}.reminder.t-townsfolk{border-color:var(--good)}.reminder.t-outsider{border-color:var(--good-2)}.rem-del{border:none;background:#6b1f18;color:#fff;width:16px;height:16px;border-radius:50%;font-size:12px;line-height:1;display:none;align-items:center;justify-content:center}.reminder:hover .rem-del{display:flex}.sidebar{width:350px;flex:none;display:flex;flex-direction:column;min-height:0;background:linear-gradient(180deg,#26180b99,#1c120999),radial-gradient(140% 100% at 100% 0%,#efdcb4,#e1cb98 70%,#d3ba84);border-left:3px solid #4a3219;box-shadow:-10px 0 30px #0006;color:var(--ink)}.tabs{display:flex;flex:none;background:#2c1c0e}.tab{flex:1;padding:12px 0;border:none;background:transparent;font-family:var(--title);font-size:13px;letter-spacing:1px;text-transform:uppercase;color:#a98a5b;border-bottom:2px solid transparent}.tab.active{color:var(--gold-bright);border-bottom-color:var(--gold);background:#0003}.tab-body{overflow-y:auto;padding:16px;flex:1}.panel{display:flex;flex-direction:column;gap:16px}.panel h3{font-family:var(--title);font-size:14px;letter-spacing:1px;text-transform:uppercase;color:#5a3f22;margin-bottom:8px;border-bottom:1px solid rgba(90,63,34,.3);padding-bottom:4px}.hint{font-size:13px;font-style:italic;color:#6e5733;line-height:1.4}.hint.warn{color:var(--blood)}.bluff-row{display:flex;gap:10px}.bluff-slot{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;background:#fff8e68c;border:1.5px dashed #9a7f4f;border-radius:10px;padding:8px 4px;color:#5a3f22;font-family:var(--title);font-size:11px}.bluff-slot:hover{border-color:var(--gold);background:#fff8e6d9}.bluff-slot img{width:48px;height:48px;object-fit:contain;mix-blend-mode:multiply}.bluff-slot.t-minion,.bluff-slot.t-demon{border-style:solid}.bluff-plus{width:28px;height:28px;color:#9a7f4f;display:flex;align-items:center;justify-content:center}.setup-row{display:flex;align-items:center;gap:10px;padding:7px 4px;border-bottom:1px dashed rgba(90,63,34,.25);font-size:15px}.dot{width:12px;height:12px;border-radius:50%;flex:none}.team-townsfolk,.dot.team-townsfolk{background:var(--good)}.team-outsider,.dot.team-outsider{background:var(--good-2)}.team-minion,.dot.team-minion{background:var(--evil)}.team-demon,.dot.team-demon{background:var(--demon)}.setup-name{flex:1}.setup-need{color:#6e5733;font-size:13px}.setup-have{font-family:var(--title);font-weight:700;width:26px;text-align:right}.setup-row.ok .setup-have{color:#2c6b34}.setup-row.under .setup-have{color:#b8772a}.setup-row.over .setup-have{color:var(--blood)}.count-ctl{display:flex;gap:10px}.count-ctl .btn{flex:1}.seg{display:flex;background:#2c1c0e;border-radius:8px;padding:3px;gap:3px}.seg-b{flex:1;border:none;background:transparent;color:#a98a5b;padding:8px;border-radius:6px;font-family:var(--title);font-size:12px;letter-spacing:1px;text-transform:uppercase}.seg-b.on{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#2a1a0c;font-weight:700}.night-list{list-style:none;counter-reset:step;display:flex;flex-direction:column;gap:8px}.night-step{display:flex;gap:11px;align-items:flex-start;padding:9px 10px;background:#fff8e680;border-radius:9px;border:1px solid rgba(154,127,79,.35);counter-increment:step}.night-step:before{content:counter(step);font-family:var(--display);font-size:14px;color:var(--gold);min-width:18px;text-align:center;margin-top:2px}.night-step.absent{opacity:.5}.night-step.info{background:#2c1c0ed9;color:var(--parch);border-color:#4a3219}.night-step.info b{color:var(--gold-bright)}.ns-img{width:40px;height:40px;object-fit:contain;mix-blend-mode:multiply;flex:none}.night-step.info .ns-img,.ns-mark{width:30px;height:30px;color:var(--gold);flex:none;margin-top:2px}.night-step b{font-family:var(--title);font-size:14px}.night-step p{font-size:13.5px;color:#5a3f22;line-height:1.35;margin-top:2px}.night-step.info p{color:#d8c096}.absent-tag{font-family:var(--serif);font-style:italic;font-size:11px;color:var(--blood);margin-left:8px;text-transform:none;letter-spacing:0}.night-hint{font-size:12px;font-style:italic;color:#6e5733;margin:2px 2px 8px}.night-step.active{cursor:pointer;transition:background .12s,border-color .12s,transform .06s}.night-step.active:hover{background:#fffcf4e6;border-color:var(--gold)}.night-step.active:active{transform:translateY(1px)}.night-step.info[role=button]{cursor:pointer}.ns-text{flex:1;min-width:0}.ns-who{font-family:var(--serif);font-style:normal;font-size:12px;color:#2a1a0c;margin-left:8px;padding:1px 8px;border-radius:10px;letter-spacing:.2px;background:linear-gradient(180deg,#ecd187,#d6b25a);border:1px solid var(--gold)}.ns-go{width:16px;height:16px;color:var(--gold);flex:none;align-self:center;opacity:.8}.night-step.info .ns-go{color:var(--gold-bright)}.night-card{width:min(440px,96vw);--tc: var(--gold)}.night-card.team-townsfolk{--tc: var(--good)}.night-card.team-outsider{--tc: var(--good-2)}.night-card.team-minion{--tc: var(--evil)}.night-card.team-demon{--tc: var(--demon)}.nc-body{overflow-y:auto;padding:22px 20px 20px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}.nc-img{width:132px;height:132px;object-fit:contain;mix-blend-mode:multiply;border-radius:50%;box-shadow:0 0 0 3px var(--tc),0 6px 18px #0000004d;background:radial-gradient(circle at 50% 38%,#fbf1d6,#e7d3a4);padding:6px}.nc-youare{font-family:var(--title);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:#6e5733;margin-top:10px}.nc-name{font-family:var(--display);font-size:30px;line-height:1.05;color:#2a1a0c}.nc-prompt{white-space:pre-line;font-size:18px;line-height:1.4;color:#3a2714;margin-top:8px;font-family:var(--serif)}.nc-note{font-style:italic;font-size:13px;color:var(--blood);margin-top:2px}.reveal-stage{width:100%;margin-top:12px;border-radius:14px;display:flex;align-items:center;justify-content:center;transition:min-height .15s}.reveal-stage.empty{min-height:0}.reveal-stage.num,.reveal-stage.good,.reveal-stage.evil{min-height:168px;border:2px solid}.reveal-stage.num{border-color:var(--gold);background:#fffaebb3}.reveal-stage.good{border-color:var(--good);background:#3c78461f}.reveal-stage.evil{border-color:var(--blood);background:#961e1e1a}.big-num{font-family:var(--display);font-size:120px;line-height:1;color:#2a1a0c}.big-stamp{font-family:var(--display);font-size:46px;letter-spacing:2px}.reveal-stage.good .big-stamp{color:#2f7a43}.reveal-stage.evil .big-stamp{color:var(--blood)}.sig-tools{width:100%;margin-top:16px;padding-top:14px;display:flex;flex-direction:column;gap:8px;border-top:1px dashed rgba(90,63,34,.35)}.sig-label{font-family:var(--title);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:#6e5733}.sig-row{display:flex;gap:8px}.sig-btn{flex:1;min-height:44px;border-radius:10px;border:1.5px solid #b69a64;background:#fffaebcc;color:#3a2714;font-family:var(--title);font-size:16px}.sig-btn:hover{border-color:var(--gold);background:#fff}.sig-btn:active{transform:translateY(1px)}.sig-btn.good{border-color:#2f7a4399}.sig-btn.evil{border-color:#961e1e80}.ic-body{text-align:left;align-items:stretch}.ic-group{margin-top:12px}.ic-lbl{font-family:var(--title);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:#6e5733}.ic-people{display:flex;flex-direction:column;gap:6px;margin-top:6px}.ic-chip{display:flex;align-items:center;gap:9px;padding:6px 9px;border-radius:9px;background:#fffaebb3;border:1px solid rgba(154,127,79,.45)}.ic-chip img{width:30px;height:30px;object-fit:contain;mix-blend-mode:multiply;flex:none}.ic-chip b{font-family:var(--title);font-size:14px;color:#2a1a0c}.ic-chip em{font-size:12px;color:#6e5733;margin-left:auto}.ic-chip.t-minion b,.ic-chip.t-demon b{color:var(--blood)}.roles-ref section{margin-bottom:14px}.team-h{color:#fff;padding:5px 10px;border-radius:6px;font-family:var(--title);font-size:13px;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;border:none}.ref-row{display:flex;gap:10px;align-items:flex-start;padding:7px 4px;border-bottom:1px dashed rgba(90,63,34,.22)}.ref-row img{width:40px;height:40px;object-fit:contain;mix-blend-mode:multiply;flex:none}.ref-row b{font-family:var(--title);font-size:14px}.ref-row p{font-size:13px;color:#5a3f22;line-height:1.35}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100}.modal-overlay{background:#0c0804ad;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px}.popover{position:fixed;z-index:101;min-width:232px;max-width:280px;background:radial-gradient(130% 100% at 0% 0%,#f4e6c4,#e1cb98 75%,#d2b984);border:2px solid var(--gold);border-radius:12px;padding:12px;box-shadow:var(--shadow),0 0 0 4px #00000040}.pop-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.pop-head span{font-family:var(--title);font-weight:700;font-size:15px;color:#3a2714}.pop-head em{font-size:13px;color:#6e5733}.pop-ability{font-size:13px;color:#5a3f22;line-height:1.35;margin:7px 0 4px;font-style:italic;border-top:1px dashed rgba(90,63,34,.3);padding-top:7px}.pop-actions{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:8px}.mbtn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 2px;border:1px solid #b69a64;border-radius:8px;background:#fffaebb3;color:#3a2714}.mbtn:hover{background:#fff;border-color:var(--gold)}.mbtn-i{font-size:17px;line-height:1}.mbtn-l{font-family:var(--title);font-size:10px;letter-spacing:.3px}.modal{width:min(720px,96vw);max-height:88vh;display:flex;flex-direction:column;background:radial-gradient(120% 90% at 0% 0%,#f4e6c4,#e2cd9a 70%,#d0b681);border:3px solid var(--gold);border-radius:16px;overflow:hidden;box-shadow:0 30px 70px #000000b3,0 0 0 6px #0000004d}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:linear-gradient(180deg,#3a2614,#2a1a0c);border-bottom:2px solid var(--gold)}.modal-head h2{font-family:var(--display);font-size:19px;color:var(--parch)}.modal-head .x{width:32px;height:32px;border-radius:8px;border:1px solid #4d3318;background:#241809;color:var(--parch);font-size:20px;line-height:1}.modal-head .x:hover{background:var(--blood)}.role-scroll{overflow-y:auto;padding:16px}.role-group{margin-bottom:16px}.role-group h3{font-family:var(--title);font-size:13px;letter-spacing:1px;text-transform:uppercase;color:#fff;padding:4px 10px;border-radius:5px;margin-bottom:10px;display:inline-block}.role-group.team-townsfolk h3{background:var(--good)}.role-group.team-outsider h3{background:var(--good-2)}.role-group.team-minion h3{background:var(--evil)}.role-group.team-demon h3{background:var(--demon)}.role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:10px}.role-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border:1.5px solid #b69a64;border-radius:10px;background:#fffaeba6;color:#3a2714}.role-card:hover{border-color:var(--gold);background:#fff;transform:translateY(-2px)}.role-card img{width:60px;height:60px;object-fit:contain;mix-blend-mode:multiply}.role-card span{font-family:var(--title);font-size:11.5px;text-align:center;line-height:1.1}.role-clear{text-align:center;padding-top:6px}.rem-grid{overflow-y:auto;padding:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.rem-opt{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1.5px solid #b69a64;border-radius:10px;background:#fffaebb3;color:#3a2714;text-align:left}.rem-opt:hover{border-color:var(--gold);background:#fff}.rem-opt img{width:30px;height:30px;object-fit:contain;mix-blend-mode:multiply;flex:none}.rem-opt .rem-dot{width:14px;height:14px;border-radius:50%;background:#7c5a2c;flex:none}.rem-opt span{font-family:var(--title);font-size:13px;flex:1}.rem-opt em{font-size:11px;color:#6e5733}.rem-opt.t-minion{border-color:var(--evil)}.rem-opt.t-demon{border-color:var(--demon)}.setup-modal{width:min(560px,96vw)}.setup-body{overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}.setup-count-bar{display:flex;align-items:center;justify-content:space-between;gap:12px}.sc-label{font-family:var(--title);font-size:14px;letter-spacing:1px;text-transform:uppercase;color:#5a3f22}.sc-ctl{display:flex;align-items:center;gap:12px}.sc-btn{width:44px;height:44px;border-radius:10px;border:1.5px solid #8a6e3e;background:#fffaebcc;color:#3a2714;font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center}.sc-btn.primary{background:linear-gradient(180deg,#e9c66a,#c99a40);border-color:var(--gold);color:#2a1a0c}.sc-btn:active{transform:translateY(1px)}.sc-num{font-family:var(--display);font-size:26px;color:#3a2714;min-width:34px;text-align:center}.setup-dist-line{font-size:13px;color:#5a3f22;font-style:italic;text-align:center;background:#fff8e699;border:1px solid rgba(154,127,79,.5);border-radius:8px;padding:7px 10px}.setup-dist-line.warn{color:var(--blood);font-style:normal}.setup-paste-wrap summary{font-family:var(--title);font-size:12.5px;letter-spacing:.4px;color:#6e5733;cursor:pointer}.setup-paste{width:100%;margin-top:8px;resize:vertical;font-family:var(--serif);font-size:14px;padding:8px 10px;border:1.5px solid #b69a64;border-radius:8px;background:#fffcf4e6;color:#3a2714}.setup-paste-wrap .btn{margin-top:8px}.setup-rows-head{display:grid;grid-template-columns:26px 1fr 44%;gap:8px;padding:0 2px;font-family:var(--title);font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:#8a6e3e}.setup-rows{display:flex;flex-direction:column;gap:8px}.setup-row-edit{display:grid;grid-template-columns:26px 1fr 44%;gap:8px;align-items:center}.seat-num{font-family:var(--display);font-size:15px;color:#8a6e3e;text-align:center}.setup-name{width:100%;font-family:var(--serif);font-size:16px;padding:10px 12px;border:1.5px solid #b69a64;border-radius:9px;background:#fffcf4f2;color:#2a1a0c}.setup-name:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #c99a404d}.setup-role{width:100%;font-family:var(--serif);font-size:15px;padding:10px 8px;border:1.5px solid #b69a64;border-radius:9px;background:#fffcf4f2;color:#2a1a0c}.setup-role.t-townsfolk{border-color:var(--good)}.setup-role.t-outsider{border-color:var(--good-2)}.setup-role.t-minion{border-color:var(--evil)}.setup-role.t-demon{border-color:var(--demon)}.setup-tools{display:flex;gap:10px}.setup-tools .btn{flex:1}.setup-foot{padding:12px 16px;border-top:2px solid rgba(90,63,34,.25);display:flex;gap:10px;background:linear-gradient(180deg,#3a261414,#3a261429)}.setup-foot .btn.big{flex:1}.btn.big{padding:13px;font-size:15px}.share-modal{width:min(520px,96vw)}.share-body{padding:18px;display:flex;flex-direction:column;gap:14px}.share-input{width:100%;font-family:var(--mono, monospace);font-size:13px;padding:11px 12px;border:1.5px solid #b69a64;border-radius:9px;background:#fffcf4f2;color:#3a2714}.share-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #c99a404d}.share-body .btn.big{width:100%}@media(max-width:880px){html,body{overflow-y:auto;height:auto}#app{height:auto;min-height:100vh}.stage{flex-direction:column}.board{flex:none;height:78vw;min-height:320px;max-height:64vh}.sidebar{width:100%;border-left:none;border-top:3px solid #4a3219}.tab-body{max-height:none;padding:14px}.topbar{flex-wrap:wrap;gap:10px;padding:10px 14px}.count-block{order:3;width:100%}.actions{order:2;flex-wrap:wrap;gap:8px}.actions .btn{flex:1 1 auto;min-height:40px}.token{width:92px}.token .disc{width:78px;height:78px}.mbtn{padding:9px 2px}.mbtn-i{font-size:19px}.setup-modal{width:100vw;height:100vh;max-height:100vh;border-radius:0;border-width:0}.setup-rows-head,.setup-row-edit{grid-template-columns:22px 1fr 42%}.setup-name,.setup-role{font-size:16px}}
