.setup-page{padding:0 1rem 4rem;max-width:900px}.step-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1rem;transition:opacity .2s,filter .2s}.step-locked{opacity:.45;pointer-events:none;filter:grayscale(.15)}.step-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.step-badge{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#0a0505;font-size:.78rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.step-title{font-family:var(--font-serif);font-size:1rem;color:var(--text);font-weight:600}.step-desc{font-size:.78rem;color:var(--text-dim);margin-top:.15rem}.step-info{font-size:.85rem;display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.player-count-row{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.75rem}.count-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.count-btn:hover{border-color:var(--border-accent);color:var(--text)}.count-btn.active{background:var(--accent);border-color:var(--accent);color:#0a0505}.comp-bar{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;padding-top:.5rem;border-top:1px solid var(--border);margin-top:.5rem}.comp-lbl{font-size:.78rem;color:var(--text-dim);margin-right:.1rem}.comp-chip{padding:.15rem .5rem;border-radius:99px;font-size:.73rem;border:1px solid}.townsfolk-chip{border-color:#6a9be8;color:#6a9be8}.outsider-chip{border-color:#4ab878;color:#4ab878}.minion-chip{border-color:#e05888;color:#e05888}.demon-chip{border-color:#e04848;color:#e04848}.traveller-chip{border-color:#d4a030;color:#d4a030}.collection-toggles{display:flex;flex-wrap:wrap;gap:.5rem}.col-btn{padding:.4rem .9rem;border-radius:99px;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:all .15s}.col-btn:hover{border-color:var(--border-accent);color:var(--text)}.col-btn.active{background:#c4882a26;border-color:var(--accent);color:var(--accent);font-weight:600}.mode-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.mode-bar-spacer{flex:1;min-width:.5rem}.hat-area{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);min-height:88px;padding:.75rem;margin-bottom:1rem}.hat-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;border-radius:99px;background:var(--accent);color:#0a0505;font-size:.7rem;font-weight:700}.hat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;min-height:60px;color:var(--text-muted);font-size:.85rem}.hat-tokens{display:flex;flex-wrap:wrap;gap:.6rem}.hat-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:.25rem}.hat-token{width:60px;height:60px;border-radius:50%;border:2px solid var(--team-color, var(--border-accent));background:var(--team-bg, rgba(196,136,42,.1));overflow:hidden;display:flex;align-items:center;justify-content:center}.hat-token img{width:100%;height:100%;object-fit:cover}.custom-initial{font-size:1.3rem;font-weight:700;color:var(--text-muted)}.hat-token-label{font-size:.6rem;color:var(--text-dim);text-align:center;max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hat-remove-btn{position:absolute;top:-3px;right:-3px;width:17px;height:17px;border-radius:50%;background:var(--red);color:#fff;font-size:.55rem;display:none;align-items:center;justify-content:center;border:none;cursor:pointer;z-index:5}.hat-item:hover .hat-remove-btn{display:flex}.farol-subsection{margin-bottom:1rem;padding:.85rem 1rem;background:#8b1a1a12;border:1px solid rgba(220,50,50,.3);border-radius:var(--radius)}.farol-subheader{display:flex;justify-content:space-between;align-items:center;margin-bottom:.65rem;gap:.5rem}.farol-sub-title{font-family:var(--font-serif);font-size:.9rem;color:var(--accent);font-weight:600}.farol-sub-desc{font-size:.75rem;color:var(--text-muted)}.farol-slots-inline{display:flex;flex-direction:column;gap:.4rem}.farol-slot-row{display:flex;align-items:center;gap:.65rem;padding:.45rem .6rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.farol-token-sm{width:40px;height:40px;flex-shrink:0;border-radius:50%;border:2px solid var(--team-color, var(--border-accent));background:var(--team-bg, rgba(196,136,42,.1));overflow:hidden;display:flex;align-items:center;justify-content:center}.farol-token-sm img{width:100%;height:100%;object-fit:cover}.farol-slot-info{flex:1;min-width:0}.farol-slot-name{font-size:.85rem;font-weight:600;color:var(--text)}.farol-slot-ability{font-size:.72rem;color:var(--text-muted);font-style:italic;display:block;line-height:1.35}.start-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding-top:1rem;border-top:1px solid var(--border)}.selector-toolbar{display:flex;gap:.5rem;align-items:center;margin-bottom:.6rem}#btn-toggle-desc.active{background:#c4882a26;border-color:var(--accent);color:var(--accent)}.selector-comp{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.65rem;padding:.45rem .6rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:.75rem}.cslot{padding:.15rem .45rem;border-radius:99px;border:1px solid;font-size:.72rem}.cslot-need{border-color:var(--accent);color:var(--accent);background:#c4882a14}.cslot-done{border-color:#4ab878;color:#4ab878;background:#3a8a5a1a}.selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:.5rem;max-height:420px;overflow-y:auto}.selector-grid.show-abilities{grid-template-columns:1fr;gap:.3rem}.sel-char{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.5rem .25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:.65rem;color:var(--text-muted);transition:all .15s;position:relative}.sel-char:hover{border-color:var(--accent);color:var(--text)}.sel-char.in-hat{background:#c4882a14;border-color:var(--accent)}.sel-char.team-locked{opacity:.28;cursor:not-allowed}.sel-char.team-locked:hover{border-color:var(--border);color:var(--text-muted)}.show-abilities .sel-char{flex-direction:row;align-items:center;text-align:left;padding:.5rem .75rem;gap:.75rem}.sel-img{width:46px;height:46px;flex-shrink:0;border-radius:50%;border:1.5px solid var(--team-color, var(--border-accent));background:var(--team-bg);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--text-muted)}.sel-img img{width:100%;height:100%;object-fit:cover}.sel-char-info{display:contents}.show-abilities .sel-char-info{display:flex;flex-direction:column;flex:1;min-width:0}.sel-name{font-size:.65rem}.show-abilities .sel-name{font-size:.85rem;font-weight:600;color:var(--text)}.sel-ability{display:none}.show-abilities .sel-ability{display:block;font-size:.73rem;color:var(--text-dim);font-style:italic;line-height:1.35;margin-top:.1rem}.sel-overlay{position:absolute;top:2px;right:4px;font-size:.7rem;color:var(--accent);font-weight:700}.show-abilities .sel-overlay{position:static;flex-shrink:0}.sheet-char-list{display:flex;flex-direction:column;gap:.6rem;margin-top:.6rem}.sheet-char{display:flex;align-items:center;gap:.75rem}.sheet-token{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--team-color, var(--border-accent));background:var(--team-bg);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text-muted)}.sheet-token img{width:100%;height:100%;object-fit:cover}.btn-sm{padding:.25rem .5rem;font-size:.75rem}@media (max-width: 640px){.mode-bar-spacer{display:none}.farol-subheader{flex-direction:column;align-items:flex-start}}
