:root{--bg: #0c0e14;--bg-card: #151821;--bg-hover: #1c2030;--border: #252a3a;--text: #d4d4d8;--text-dim: #71717a;--text-bright: #fafafa;--accent: #6366f1;--accent-hover: #818cf8;--accent-glow: rgba(99, 102, 241, .15);--danger: #ef4444;--success: #22c55e;--warning: #f59e0b;--star-filled: #f59e0b;--star-empty: #333848;--radius: 8px;--radius-lg: 12px;--slot-a: #22c55e;--slot-b: #3b82f6;--slot-c: #f59e0b;--slot-d: #ef4444}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;background-image:radial-gradient(ellipse 60% 40% at 50% -10%,rgba(99,102,241,.07),transparent)}#root{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}h1{font-size:2.25rem;font-weight:700;color:var(--text-bright);letter-spacing:-.02em;background:linear-gradient(135deg,#e0e0ff,#a5b4fc,#818cf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:1.15rem;font-weight:600;color:var(--text-bright);margin-bottom:.75rem}.subtitle{color:var(--text-dim);margin-top:.35rem;font-size:.95rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);font-size:.9rem;font-family:inherit;cursor:pointer;transition:background .2s,border-color .2s}.btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-accent{background:var(--accent);border-color:var(--accent);color:#fff}.btn-accent:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-sm{padding:.35rem .7rem;font-size:.8rem}input[type=text],input[type=password],input[type=email],select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.6rem .85rem;font-size:.9rem;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.loading{text-align:center;padding:3rem;color:var(--text-dim)}.error-msg{color:var(--danger);padding:.5rem 0;font-size:.9rem}.text-dim{color:var(--text-dim);font-size:.85rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-dim)}.landing-header{text-align:center;margin-bottom:2.5rem}.campaign-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.campaign-card{display:block;transition:border-color .2s,transform .15s;cursor:pointer;text-decoration:none;color:inherit}.campaign-card:hover{border-color:var(--accent);transform:translateY(-2px)}.campaign-card h2{margin-bottom:.5rem}.campaign-desc{color:var(--text-dim);font-size:.9rem;margin-bottom:1rem}.campaign-meta{display:flex;justify-content:space-between;color:var(--text-dim);font-size:.8rem;border-top:1px solid var(--border);padding-top:.75rem;margin-top:.75rem}.voting-header{margin-bottom:1.5rem}.back-link{display:inline-block;margin-bottom:.5rem;font-size:.85rem}.progress-text{color:var(--text-dim);font-size:.9rem;margin-top:.35rem}.pagination{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-dots{display:flex;gap:.25rem;flex-wrap:wrap}.page-dot{width:2rem;height:2rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-dim);font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.page-dot:hover{border-color:var(--accent);color:var(--text)}.page-dot.active{background:var(--accent);border-color:var(--accent);color:#fff}.page-dot.voted:not(.active){border-color:var(--success);color:var(--success)}.scenario-context{margin-bottom:1.5rem}.sc-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem;flex-wrap:wrap}.sc-title-row h2{margin:0}.sc-tags{display:flex;gap:.35rem;flex-wrap:wrap;align-items:center}.sc-tag{font-size:.68rem;font-weight:600;padding:.12rem .5rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.04em}.sc-weight-routine{background:#6366f11a;color:var(--accent-hover)}.sc-weight-significant{background:#f59e0b1f;color:var(--warning)}.sc-weight-dramatic{background:#ef44441f;color:var(--danger)}.sc-mood{background:#a855f71a;color:#c084fc;text-transform:lowercase}.sc-purpose{background:#22c55e14;color:var(--success);text-transform:lowercase}.scenario-summary{color:var(--text);margin-bottom:.75rem;font-size:.95rem;font-weight:500;line-height:1.5}.sc-grid{display:flex;flex-direction:column;gap:1rem;border-top:1px solid var(--border);padding-top:1rem}.sc-section{display:flex;flex-direction:column;gap:.35rem}.sc-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.sc-text{font-size:.85rem;color:var(--text-dim);line-height:1.5;margin:0}.sc-scene-details{display:flex;flex-direction:column;gap:.3rem}.sc-scene-location{font-size:.88rem;color:var(--text);font-weight:500;margin:0}.sc-scene-atmosphere{font-size:.82rem;color:var(--text-dim);line-height:1.5;margin:0}.sc-env-tags{display:flex;gap:.35rem;flex-wrap:wrap}.sc-env-tag{font-size:.72rem;padding:.1rem .45rem;border-radius:4px;background:#ffffff0a;border:1px solid var(--border);color:var(--text-dim)}.sc-party-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.sc-party-member{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.55rem .7rem}.sc-member-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.2rem}.sc-member-name{font-weight:600;font-size:.85rem;color:var(--text-bright)}.sc-member-class{font-size:.72rem;color:var(--accent-hover);font-weight:500}.sc-hp-bar-wrap{display:flex;align-items:center;gap:.4rem;margin-bottom:.2rem}.sc-hp-bar{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.sc-hp-fill{height:100%;background:var(--success);border-radius:2px}.sc-hp-text{font-size:.68rem;color:var(--text-dim);font-variant-numeric:tabular-nums;white-space:nowrap}.sc-member-desc{font-size:.72rem;color:var(--text-dim);line-height:1.4;margin:0}.sc-event-list{display:flex;flex-direction:column;gap:.5rem}.sc-event-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.6rem .75rem}.sc-event-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}.sc-event-type{font-size:.68rem;font-weight:700;padding:.1rem .45rem;border-radius:4px;background:#eab3081f;color:var(--star-filled);font-family:Fira Code,Consolas,monospace;text-transform:uppercase}.sc-outcome{font-size:.68rem;font-weight:700;padding:.1rem .45rem;border-radius:4px}.sc-out-hit{background:#22c55e1f;color:var(--success)}.sc-out-miss{background:#ef44441a;color:var(--danger)}.sc-out-crit{background:#f59e0b26;color:var(--warning)}.sc-out-fumble{background:#ef444426;color:var(--danger)}.sc-event-body{display:flex;flex-direction:column;gap:.3rem}.sc-event-actors{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;font-size:.85rem}.sc-actor-name{color:var(--text-bright);font-weight:600}.sc-actor-detail{color:var(--text-dim)}.sc-actor-arrow{color:var(--text-dim);font-size:.8rem}.sc-event-stats{display:flex;flex-wrap:wrap;gap:.3rem}.sc-stat{font-size:.7rem;padding:.1rem .4rem;border-radius:4px;font-variant-numeric:tabular-nums}.sc-stat-damage{background:#ef444414;color:#f87171}.sc-stat-heal{background:#22c55e14;color:var(--success)}.sc-stat-special{background:#a855f714;color:#c084fc}.sc-stat-hp{background:#6366f114;color:var(--accent-hover)}.sc-stat-dc{background:#f59e0b14;color:var(--warning)}.sc-stat-roll{background:#ffffff0d;color:var(--text);font-weight:600}.sc-event-descs{margin-top:.3rem;padding-top:.3rem;border-top:1px solid var(--border)}.sc-event-desc{font-size:.75rem;color:var(--text-dim);line-height:1.4;margin:0 0 .15rem}.sc-event-desc strong{color:var(--text)}.sc-prev-narration{font-style:italic;font-size:.85rem;color:var(--text);line-height:1.6;border-left:3px solid var(--accent);padding-left:.75rem;margin:0}.response-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-bottom:1.5rem}.response-card{padding:0;overflow:hidden;display:flex;flex-direction:column}.response-header{padding:.6rem 1rem;border-top:3px solid var(--accent);background:#ffffff05}.slot-label{font-weight:700;font-size:.85rem;letter-spacing:.02em}.response-body{padding:1rem;flex:1}.response-text{font-size:.9rem;line-height:1.7;white-space:pre-wrap}.response-footer{padding:.75rem 1rem;border-top:1px solid var(--border);display:flex;justify-content:center}.star-rating{display:flex;gap:.15rem}.star{font-size:1.5rem;cursor:pointer;color:var(--star-empty);transition:color .1s;-webkit-user-select:none;user-select:none}.star.filled{color:var(--star-filled)}.star.disabled{cursor:default;opacity:.5}.nav-buttons{display:flex;justify-content:space-between;margin-bottom:2rem}.complete-screen{text-align:center;padding:3rem 2rem}.complete-screen h2{font-size:1.5rem;margin-bottom:1rem}.complete-screen p{color:var(--text-dim);margin-bottom:.5rem}.complete-stats{margin-top:2rem;text-align:left}.complete-section{margin-top:1.5rem}.complete-section-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:.75rem}.complete-leaderboard{display:flex;flex-direction:column;gap:.5rem}.complete-lb-row{display:flex;align-items:center;gap:.75rem}.complete-rank{font-weight:700;color:var(--text-dim);font-size:.8rem;min-width:1.5rem;text-align:right}.complete-slot-label{font-weight:700;font-size:.85rem;min-width:4.5rem}.slot-a{color:var(--slot-a)}.slot-b{color:var(--slot-b)}.slot-c{color:var(--slot-c)}.slot-d{color:var(--slot-d)}.complete-bar-wrap{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.complete-bar{height:100%;border-radius:3px;transition:width .4s ease}.complete-avg{font-size:.82rem;color:var(--star-filled);min-width:4rem;text-align:right;font-variant-numeric:tabular-nums}.complete-pct{font-size:.82rem;color:var(--text-dim);min-width:2.5rem;text-align:right;font-variant-numeric:tabular-nums}.complete-reveal{border-top:1px solid var(--border);padding-top:1.5rem}.complete-reveal-grid{display:flex;flex-direction:column;gap:.5rem}.complete-reveal-row{display:flex;align-items:center;gap:1rem}.complete-model-name{font-size:.9rem;color:var(--text-bright);font-weight:500}.email-float{position:fixed;bottom:1.5rem;right:1.5rem;z-index:100;display:flex;align-items:center;gap:.5rem}.email-trigger{padding:.6rem 1rem;background:var(--accent);border:none;border-radius:999px;color:#fff;font-size:.85rem;cursor:pointer;font-family:inherit;box-shadow:0 4px 20px #6366f14d;transition:background .2s}.email-trigger:hover{background:var(--accent-hover)}.email-dismiss{width:1.5rem;height:1.5rem;border:none;border-radius:50%;background:var(--bg-card);color:var(--text-dim);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.email-expanded{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem;flex-direction:column;align-items:stretch;box-shadow:0 4px 30px #0006}.email-form{display:flex;gap:.5rem}.email-form input{flex:1;min-width:180px}.email-inline{margin-top:1.5rem}.email-inline .email-form{justify-content:center}.email-success{color:var(--success);font-size:.9rem;padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--success);border-radius:var(--radius)}.email-error{color:var(--danger);font-size:.8rem;margin-top:.35rem}.admin h1{margin-bottom:1.5rem}.admin-login{max-width:320px;margin:2rem auto;display:flex;flex-direction:column;gap:.75rem}.admin-controls{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.admin-controls select{min-width:200px}.filter-toggle{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-dim);cursor:pointer}.filter-toggle input{accent-color:var(--accent)}.vote-count{color:var(--text-dim);font-size:.85rem;margin-left:auto}.admin-section{margin-bottom:1.5rem}.leaderboard{display:flex;flex-direction:column;gap:.5rem}.leaderboard-row{display:flex;align-items:center;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.leaderboard-row:last-child{border-bottom:none}.rank{font-weight:700;color:var(--accent);min-width:2rem}.model-name{font-weight:600;color:var(--text-bright);flex:1}.stars{color:var(--star-filled);font-size:.9rem}.vote-count-small{color:var(--text-dim);font-size:.8rem}.scenario-table-wrap{overflow-x:auto;margin-top:.75rem}.scenario-table{width:100%;border-collapse:collapse;font-size:.85rem}.scenario-table th,.scenario-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border);text-align:left}.scenario-table th{color:var(--text-dim);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.rating-cell{text-align:center;color:var(--star-filled)}.subscriber-list{margin-top:.75rem;display:flex;flex-direction:column;gap:.3rem}.subscriber-row{display:flex;justify-content:space-between;padding:.3rem 0;border-bottom:1px solid var(--border);font-size:.85rem}@media(max-width:768px){#root{padding:1rem}h1{font-size:1.75rem}.campaign-grid,.response-grid{grid-template-columns:1fr}.page-dots{display:none}.pagination{justify-content:space-between}.admin-controls{flex-direction:column;align-items:stretch}.vote-count{margin-left:0}.email-float{bottom:1rem;right:1rem;left:1rem}.email-form{flex-direction:column}.email-form input{min-width:unset}.nav-buttons{gap:1rem}.nav-buttons .btn{flex:1;justify-content:center}}
