:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--bg:#0f172a;--panel:#1e293b;--panel-light:#334155;--text:#e2e8f0;--muted:#94a3b8;--accent:#38bdf8;--accent-hover:#0ea5e9;--danger:#ef4444}body{background:var(--bg);color:var(--text);margin:0;font-family:system-ui,sans-serif}.app-header{box-sizing:border-box;justify-content:center;width:100%;padding:1.5rem 1rem .5rem;display:flex}.app-header-image{background:0 0;border-radius:14px;width:min(100%,720px);height:auto;margin:0 auto;display:block}.container{max-width:900px;margin:0 auto;padding:2rem}.card{background:var(--panel);border-radius:10px;margin-bottom:1.5rem;padding:1.5rem}input,select{background:var(--panel-light);width:100%;color:var(--text);box-sizing:border-box;border:none;border-radius:6px;margin-top:.4rem;margin-bottom:1rem;padding:.6rem}button{background:var(--accent);color:#000;cursor:pointer;border:none;border-radius:6px;padding:.7rem 1.2rem}button:hover{background:var(--accent-hover)}.sheet-pill{color:#cbd5e1;background:#0f172a;border:1px solid #334155;border-radius:999px;align-items:center;padding:.2rem .55rem;font-size:.8rem;display:inline-flex}.sheet-stat-card{background:#0f172a;border:1px solid #334155;border-radius:10px;padding:.85rem}.sheet-stat-card span{color:#94a3b8;margin-bottom:.35rem;font-size:.8rem;display:block}.sheet-stat-card strong{font-size:1.15rem}.muted{color:var(--muted)}.auth-container{max-width:520px}.auth-card{margin-top:1rem}.auth-card form{gap:.35rem;display:grid}.form-error{color:var(--danger);margin-top:0}.auth-switch{color:var(--muted);margin-top:1rem}.auth-switch a{color:var(--accent);font-weight:700}.pdf-button{background:var(--accent);color:#000;cursor:pointer;margin-bottom:0.;border:none;border-radius:6px;padding:.4rem .5rem;display:block}.result-card{background:#111827;border:1px solid #334155;border-radius:10px;margin-top:.75rem;padding:.75rem}.result-card strong{margin-top:.25rem;margin-bottom:.35rem;display:block}.characteristics-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:.75rem;width:100%;display:grid}.characteristic-card{text-align:center;box-sizing:border-box;background:#1e293b;border:2px solid #38bdf8;border-radius:10px;width:100%;min-width:0;padding:.75rem}.characteristic-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;font-size:.8rem}.characteristic-value{color:#e2e8f0;font-size:1.4rem;font-weight:800;display:block}.characteristic-dm{color:#94a3b8;font-size:.85rem;font-weight:700}@media (width<=520px){.characteristics-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem}.characteristic-card{padding:.65rem .45rem}.characteristic-label{letter-spacing:.04em;margin-bottom:.35rem;font-size:.7rem}.characteristic-value{font-size:1.25rem}.characteristic-dm{font-size:.75rem}}@media (width<=340px){.characteristics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.roll-pool{box-sizing:border-box;background:#0f172a;border:1px solid #334155;border-radius:16px;grid-template-columns:repeat(6,minmax(56px,1fr));gap:.75rem;width:100%;margin-bottom:1.25rem;padding:.75rem;display:grid}.roll-pool-tile{color:#e2e8f0;text-align:center;-webkit-user-select:none;user-select:none;box-sizing:border-box;cursor:pointer;background:#334155;border:1px solid #475569;border-radius:14px;width:100%;min-width:0;padding:.9rem 1rem;font-size:1.1rem;font-weight:800}.roll-pool-tile.selected{color:#020617;background:#38bdf8;border:2px solid #7dd3fc}.roll-pool-tile.assigned{color:#64748b;opacity:.35;background:#111827;border:1px dashed #334155}@media (width<=520px){.roll-pool{grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem;padding:.75rem}.roll-pool-tile{min-height:52px;padding:.75rem .5rem;font-size:1.15rem}}@media (width<=340px){.roll-pool{grid-template-columns:repeat(2,minmax(0,1fr))}}.assignment-help{color:#94a3b8;font-size:1rem;line-height:1.5}@media (width<=520px){.assignment-help{font-size:.95rem;line-height:1.35}}.phase-badge{color:#cbd5e1;background:#0f172a;border:1px solid #334155;border-radius:999px;align-items:center;padding:.25rem .65rem;font-size:.85rem;font-weight:700;display:inline-flex}.admin-table{border-collapse:collapse;width:100%;margin-top:.75rem}.admin-table th,.admin-table td{text-align:left;vertical-align:middle;border-bottom:1px solid #334155;padding:.75rem}.admin-table th{color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem}.role-badge{color:#cbd5e1;background:#0f172a;border:1px solid #334155;border-radius:999px;align-items:center;padding:.25rem .65rem;font-size:.8rem;font-weight:700;display:inline-flex}.role-badge-admin{color:#e0f2fe;background:#38bdf81f;border-color:#38bdf8}input[type=file]{color:#cbd5e1}input[type=file]::file-selector-button{color:#e2e8f0;cursor:pointer;background:#1e293b;border:1px solid #334155;border-radius:10px;margin-right:.75rem;padding:.55rem .85rem;font-weight:700}input[type=file]::file-selector-button:hover{background:#334155}.breadcrumbs{color:#94a3b8;flex-wrap:wrap;align-items:center;gap:.4rem;margin-bottom:1rem;font-size:.9rem;display:flex}.breadcrumb-item{align-items:center;gap:.4rem;display:inline-flex}.breadcrumbs a{color:#38bdf8;font-weight:700;text-decoration:none}.breadcrumbs a:hover{text-decoration:underline}.breadcrumb-current{color:#cbd5e1;font-weight:700}.breadcrumb-separator{color:#475569}.admin-dashboard-hero{background:radial-gradient(circle at 100% 0,#38bdf82e,#0000 35%),#0f172a;margin-bottom:1rem;padding:2rem}.admin-dashboard-hero-content{text-align:center;max-width:760px;margin:0 auto}.admin-dashboard-kicker{color:#7dd3fc;letter-spacing:.12em;text-transform:uppercase;background:#38bdf81a;border:1px solid #38bdf866;border-radius:999px;justify-content:center;align-items:center;margin-bottom:.65rem;padding:.25rem .7rem;font-size:.75rem;font-weight:800;display:inline-flex}.admin-dashboard-hero h2{margin:0 0 .65rem;font-size:clamp(1.8rem,4vw,2.6rem);line-height:1.1}.admin-dashboard-hero p{color:#94a3b8;max-width:640px;margin:0 auto;line-height:1.55}.eyebrow{letter-spacing:.14em;text-transform:uppercase;margin:0 0 .35rem;font-size:.8rem;font-weight:800;color:#38bdf8!important}.admin-dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;display:grid}.admin-dashboard-card{color:#e2e8f0;background:linear-gradient(135deg,#1e293bfa,#0f172afa);border:1px solid #334155;border-radius:18px;grid-template-columns:auto 1fr auto;align-items:start;gap:1rem;min-height:150px;padding:1.25rem;text-decoration:none;transition:transform .16s,border-color .16s,background .16s,box-shadow .16s;display:grid;position:relative;box-shadow:0 18px 40px #00000038}.admin-dashboard-card:hover{background:linear-gradient(135deg,#1e293b,#082f49bf);border-color:#38bdf8;transform:translateY(-3px);box-shadow:0 24px 55px #00000052}.admin-dashboard-card-icon{background:#38bdf81f;border:1px solid #38bdf873;border-radius:16px;place-items:center;width:48px;height:48px;font-size:1.5rem;display:grid}.admin-dashboard-card h3{margin:0 0 .45rem;font-size:1.2rem}.admin-dashboard-card p{color:#94a3b8;margin:0;line-height:1.45}.admin-dashboard-card-arrow{color:#38bdf8;font-size:1.5rem;font-weight:900;line-height:1}@media (width<=520px){.admin-dashboard-card{grid-template-columns:auto 1fr}.admin-dashboard-card-arrow{grid-column:2;justify-self:end}}.button-link{color:#e2e8f0;background:#1e293b;border:1px solid #334155;border-radius:10px;justify-content:center;align-items:center;padding:.65rem .95rem;font-weight:700;text-decoration:none;display:inline-flex}.button-link:hover{background:#334155;border-color:#38bdf8}.character-card-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.85rem;margin-top:1rem;display:grid}.character-summary-card{color:#e2e8f0;background:#0f172a;border:1px solid #334155;border-radius:16px;flex-direction:column;justify-content:space-between;min-height:150px;padding:1rem;text-decoration:none;transition:transform .15s,border-color .15s,background .15s;display:flex}.character-summary-card:hover{background:#172033;border-color:#38bdf8;transform:translateY(-2px)}.character-summary-card h3{margin:0 0 .35rem}.character-summary-card p{color:#94a3b8;margin:0}.character-summary-meta{flex-wrap:wrap;gap:.4rem;margin-top:1rem;display:flex}.character-summary-meta span{color:#cbd5e1;background:#020617;border:1px solid #334155;border-radius:999px;padding:.2rem .55rem;font-size:.8rem;font-weight:700;display:inline-flex}.error-banner{color:#fecaca;background:#ef444414;border:1px solid #ef4444;border-radius:10px;padding:.75rem}.benefit-card{background:#0f172a;border:1px solid #334155;border-radius:12px;padding:.75rem}.benefit-card strong{color:#e2e8f0}.benefit-card p{color:#94a3b8}.home-character-list-header{flex-direction:column;align-items:center;gap:1rem;display:flex}.home-section-heading{text-align:center}.home-section-heading h2{margin:0 0 .35rem}.home-section-heading p{color:#94a3b8;margin:0}.home-character-list-header input[type=search]{width:min(100%,360px)}
