: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){html:not([data-theme]){--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}html:not([data-theme]) #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}html[data-app-shell] #root{text-align:left;border-inline:none;width:100%;max-width:none;margin:0}html[data-app-shell],html[data-auth-theme]{font:18px/145% var(--sans);color:var(--text);background:var(--bg)}@media (width<=1024px){html[data-app-shell]{font-size:16px}}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%}html[data-app-shell],html[data-auth-theme]{--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--glow:none;--surface-emphasis:var(--surface-muted);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}html[data-theme=default]{--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;--surface:#fafafa;--surface-muted:#0000000a;--danger:#dc2626;--warning:#ca8a04;--success:#16a34a;--focus-ring:#aa3bff73}html[data-theme=light]{--text:#4b5563;--text-h:#111827;--bg:#f9fafb;--border:#e5e7eb;--code-bg:#f3f4f6;--accent:#2563eb;--accent-bg:#2563eb1a;--accent-border:#2563eb73;--social-bg:#f3f4f6cc;--shadow:#00000014 0 10px 15px -3px, #0000000a 0 4px 6px -2px;--surface:#fff;--surface-muted:#00000008;--danger:#dc2626;--warning:#d97706;--success:#059669;--focus-ring:#2563eb66}html[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#a78bfa;--accent-bg:#a78bfa26;--accent-border:#a78bfa73;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px;--surface:#1c1d24;--surface-muted:#ffffff0d;--danger:#f87171;--warning:#fbbf24;--success:#4ade80;--focus-ring:#a78bfa80}html[data-theme=midnight]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--text:#94a3b8;--text-h:#e2e8f0;--bg:#0f172a;--border:#1e293b;--code-bg:#1e293b;--accent:#22d3ee;--accent-bg:#22d3ee1f;--accent-border:#22d3ee73;--social-bg:#1e293b99;--shadow:#00000080 0 12px 20px -4px;--surface:#1e293b;--surface-muted:#ffffff0a;--danger:#fb7185;--warning:#fcd34d;--success:#34d399;--focus-ring:#22d3ee73}html[data-theme=parchment]{--text:#5c4a3a;--text-h:#3d2c1e;--bg:#f5f0e6;--border:#d4c4a8;--code-bg:#ebe3d4;--accent:#92400e;--accent-bg:#92400e1f;--accent-border:#92400e66;--social-bg:#ebe3d4b3;--shadow:#3d2c1e1f 0 8px 16px -4px;--surface:#faf6ef;--surface-muted:#3d2c1e0d;--danger:#b91c1c;--warning:#b45309;--success:#15803d;--focus-ring:#92400e59}html[data-theme=arcane]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--text:#c4b5fd;--text-h:#f5f3ff;--bg:#1a1028;--border:#3b2d55;--code-bg:#251a38;--accent:#a855f7;--accent-bg:#a855f726;--accent-border:#a855f780;--social-bg:#251a3899;--shadow:#5eead414 0 0 24px, #0006 0 12px 20px -4px;--surface:#251a38;--surface-muted:#5eead40f;--danger:#f472b6;--warning:#fde047;--success:#5eead4;--focus-ring:#a855f78c;--glow:0 0 12px #a855f759}html[data-theme=cozy-hearth]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--text:#d6c4b8;--text-h:#fde68a;--bg:#2c1810;--border:#4a2c1a;--code-bg:#3d2218;--accent:#f59e0b;--accent-bg:#f59e0b26;--accent-border:#f59e0b73;--social-bg:#3d221899;--shadow:#00000073 0 10px 18px -4px;--surface:#3d2218;--surface-muted:#fde68a0f;--danger:#ef4444;--warning:#fbbf24;--success:#84cc16;--focus-ring:#f59e0b73}html[data-theme=forest-court]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--text:#a8c9a0;--text-h:#d9f99d;--bg:#1a2e1a;--border:#2d4a2d;--code-bg:#243824;--accent:#4ade80;--accent-bg:#4ade801f;--accent-border:#4ade8066;--social-bg:#24382499;--shadow:#0006 0 10px 18px -4px;--surface:#243824;--surface-muted:#d9f99d0f;--danger:#f87171;--warning:#facc15;--success:#86efac;--focus-ring:#4ade8073}html[data-theme=slate]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--text:#94a3b8;--text-h:#f1f5f9;--bg:#1e293b;--border:#334155;--code-bg:#273549;--accent:#38bdf8;--accent-bg:#38bdf81f;--accent-border:#38bdf873;--social-bg:#27354999;--shadow:#00000059 0 10px 18px -4px;--surface:#273549;--surface-muted:#ffffff0a;--danger:#f87171;--warning:#fbbf24;--success:#4ade80;--focus-ring:#38bdf873}html[data-theme=blood-moon]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--text:#d4a5a5;--text-h:#fecaca;--bg:#1c0a0a;--border:#3f1515;--code-bg:#2a0e0e;--accent:#ef4444;--accent-bg:#ef444426;--accent-border:#ef444473;--social-bg:#2a0e0e99;--shadow:#ef444414 0 0 20px, #00000073 0 10px 18px -4px;--surface:#2a0e0e;--surface-muted:#fecaca0d;--danger:#fca5a5;--warning:#fcd34d;--success:#86efac;--focus-ring:#ef444480}html[data-theme=high-contrast]{--text:#1a1a1a;--text-h:#000;--bg:#fff;--border:#000;--code-bg:#f0f0f0;--accent:#000;--accent-bg:#fff;--accent-border:#000;--social-bg:#f5f5f5;--shadow:none;--surface:#fff;--surface-muted:#f0f0f0;--danger:#c00;--warning:#960;--success:#060;--focus-ring:#000;--radius-sm:2px;--radius-md:2px;--radius-lg:4px}html[data-theme=terminal]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--text:#86efac;--text-h:#bbf7d0;--bg:#0a0a0a;--border:#166534;--code-bg:#0f1f0f;--accent:#22c55e;--accent-bg:#22c55e1f;--accent-border:#22c55e80;--social-bg:#0f1f0fcc;--shadow:none;--surface:#0f1f0f;--surface-muted:#22c55e0f;--danger:#f87171;--warning:#fde047;--success:#4ade80;--focus-ring:#22c55e8c;--radius-sm:0;--radius-md:2px;--radius-lg:2px}html[data-theme=retro-8bit]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--text:#9bbc0f;--text-h:#e8f5a0;--bg:#0f380f;--border:#306230;--code-bg:#1a4a1a;--accent:#fc0;--accent-bg:#ffcc0026;--accent-border:#fc0;--social-bg:#1a4a1acc;--shadow:none;--surface:#1a4a1a;--surface-muted:#9bbc0f14;--danger:#e74c3c;--warning:#fc0;--success:#9bbc0f;--focus-ring:#fc09;--radius-sm:0;--radius-md:0;--radius-lg:2px;image-rendering:pixelated}html[data-theme=neon-arcade]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--text:#e9d5ff;--text-h:#fff;--bg:#12001f;--border:#4a0080;--code-bg:#1f0033;--accent:#f0f;--accent-bg:#ff00ff1f;--accent-border:#ff00ff8c;--social-bg:#1f0033b3;--shadow:0 0 16px #00ffff40, 0 0 32px #ff00ff26;--surface:#1f0033;--surface-muted:#00ffff0f;--danger:#ff6b9d;--warning:#fde047;--success:#0ff;--focus-ring:#00ffff8c;--glow:0 0 10px #f0f6, 0 0 20px #0ff3}html[data-pixel-headings] .app-header-title,html[data-pixel-headings] .app-nav a,html[data-pixel-headings] h1,html[data-pixel-headings] h2,html[data-pixel-headings] h3,html[data-pixel-headings] .settings-section-title,html[data-pixel-headings] .auth-card h1,html[data-pixel-headings] button,html[data-pixel-headings] .theme-card-name{font-family:var(--heading-display,var(--heading))}.app-shell{background:var(--bg);min-height:100vh;color:var(--text);flex-direction:column;display:flex}.app-header{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:.75rem 1rem;padding:.85rem 1.25rem;display:flex;position:relative}.app-header-brand{flex-shrink:0;align-items:center;gap:.65rem;display:flex}.app-nav-toggle{min-height:44px;font:inherit;color:var(--text);background:var(--surface-muted,#0000000a);border:1px solid var(--border);border-radius:var(--radius-md,8px);cursor:pointer;padding:.4rem .75rem;font-weight:600;display:none}.app-nav-toggle:hover{border-color:var(--accent-border);color:var(--accent)}.app-user-chip{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:10rem;font-size:.9rem;overflow:hidden}.app-user-chip strong{color:var(--text-h);font-weight:600}.app-header-title{color:var(--text-h);flex-shrink:0;margin:0;font-size:1.15rem;font-weight:600;text-decoration:none}.app-header-title:hover{color:var(--accent)}.app-header-title.active{color:var(--text-h)}.app-nav{flex-wrap:wrap;gap:.5rem 1rem;display:flex}.app-nav a{color:var(--text);font-weight:600;text-decoration:none}.app-nav a:hover,.app-nav a.active{color:var(--accent)}.app-header-spacer{flex:1;min-width:.5rem}.app-sign-out{font:inherit;color:var(--text);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;padding:.4rem .85rem;font-weight:600}.app-sign-out:hover{border-color:var(--accent-border);color:var(--text-h)}.app-main{box-sizing:border-box;flex:1;padding:1.5rem}@media (width<=768px){.app-nav-toggle{align-items:center;display:inline-flex}.app-header-spacer{display:none}.app-nav{border-top:1px solid var(--border);flex-direction:column;order:10;align-items:stretch;gap:.25rem;width:100%;padding:.5rem 0 .25rem;display:none}.app-nav.is-open{display:flex}.app-nav a{border-radius:var(--radius-md,8px);padding:.55rem .65rem}.app-nav a:hover,.app-nav a.active{background:var(--surface-muted,#0000000d)}.app-user-chip{order:5;max-width:7rem;margin-left:auto;font-size:.82rem}.app-sign-out{order:6}}@media (width<=640px){.app-main{padding:1rem}.app-header{padding:.65rem 1rem}}.app-breadcrumbs{margin:0 0 .85rem}.app-breadcrumbs-list{flex-wrap:wrap;align-items:center;gap:.35rem .5rem;margin:0;padding:0;font-size:.88rem;list-style:none;display:flex}.app-breadcrumbs-item{color:var(--text);align-items:center;gap:.5rem;display:flex}.app-breadcrumbs-item:not(:last-child):after{content:"›";color:var(--text);opacity:.55;font-weight:600}.app-breadcrumbs-item a{color:var(--accent);font-weight:600;text-decoration:none}.app-breadcrumbs-item a:hover{text-decoration:underline}.app-breadcrumbs-item span[aria-current=page]{color:var(--text-h);font-weight:600}.game-detail-header{margin-top:0}.settings-page{max-width:52rem;margin:0 auto}.settings-header{margin-bottom:1.5rem}.settings-header h2{margin:0 0 .35rem}.settings-status{margin:.5rem 0 0;font-size:.9rem}.settings-status-ok{color:var(--success)}.settings-status-error{color:var(--danger)}.settings-section{border:1px solid var(--border);border-radius:var(--radius-lg,12px);background:var(--surface,var(--bg));box-shadow:var(--shadow);margin-bottom:2rem;padding:1.25rem 1.5rem}.settings-validation-row select{max-width:100%}.settings-validation-hint{margin:.35rem 0 0;font-size:.88rem;line-height:1.4}.game-characters-validation-note{max-width:36rem;margin:.25rem 0 0;font-size:.9rem}.character-ac-suggested{font-size:.9em}.add-to-char-qty-row{margin-top:.5rem}.settings-section-title{color:var(--text-h);margin:0 0 .35rem;font-size:1.1rem}.settings-lede{margin:0 0 1rem;font-size:.9rem}.settings-coming-soon{opacity:.85}.theme-grid{grid-template-columns:repeat(auto-fill,minmax(10.5rem,1fr));gap:.65rem;margin:0;padding:0;list-style:none;display:grid}.theme-card{text-align:left;width:100%;min-height:44px;font:inherit;color:inherit;background:var(--surface-muted,transparent);border:2px solid var(--border);border-radius:var(--radius-md,8px);cursor:pointer;flex-direction:column;align-items:flex-start;gap:.35rem;padding:.65rem .75rem;transition:border-color .15s,box-shadow .15s;display:flex}.theme-card:hover{border-color:var(--accent-border)}.theme-card.is-selected{border-color:var(--accent);box-shadow:var(--glow,0 0 0 1px var(--accent-border))}.theme-card:disabled{opacity:.6;cursor:wait}.theme-card-swatch{border-radius:var(--radius-sm,4px);border:1px solid var(--border);width:100%;height:.65rem;display:flex;overflow:hidden}.theme-card-swatch span{flex:1}.theme-card-name{color:var(--text-h);font-size:.9rem;font-weight:700}.theme-card-desc{font-size:.72rem;line-height:1.35}.settings-font-row select{min-width:12rem;min-height:44px;font:inherit}.settings-font-sample{border-radius:var(--radius-md,8px);border:1px solid var(--border);background:var(--surface-muted,#00000008);font-family:var(--sans);margin:1rem 0 0;padding:.85rem 1rem;line-height:1.5}.settings-font-sample-label{color:var(--text-h);font-weight:600}.app-panel{border:1px solid var(--border);background:var(--bg);max-width:36rem;box-shadow:var(--shadow);border-radius:12px;padding:1.25rem 1.5rem}.app-panel-wide{max-width:48rem}.app-panel h2{color:var(--text-h);margin:0 0 .5rem;font-size:1.2rem}.game-detail-header{margin-bottom:.75rem}.game-detail-header h2{margin:0 0 .35rem}.game-detail-meta{margin:.25rem 0 0;line-height:1.45}.game-detail-tabs{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.35rem;margin:.75rem 0 1rem;padding-bottom:.5rem;display:flex}.game-detail-tabs .tab{font:inherit;color:var(--text);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;padding:.4rem .75rem;font-weight:600}.game-detail-tabs .tab:hover{color:var(--accent);border-color:var(--border)}.game-detail-tabs .tab.active{color:var(--accent);border-color:var(--accent-border,var(--border));background:var(--surface-emphasis,#0000000d)}.game-tab-panel{gap:1rem;display:grid}.game-tab-panel[hidden]{display:none!important}.game-tab-panel section{margin:0}.game-tab-placeholder h3{margin:0 0 .35rem}.phase-badge{border:1px solid var(--border);border-radius:6px;padding:.2rem .5rem;font-size:.85rem;font-weight:600;display:inline-block}.game-detail-back{margin-top:1.25rem}.create-game-ruleset-hint{text-align:left;margin:0}.tools-coming-list{text-align:left;margin:.75rem 0 1rem;padding-left:1.25rem}.tools-coming-list li{margin:.35rem 0}.game-card-list{text-align:left;gap:.65rem;margin:.75rem 0 0;padding:0;list-style:none;display:grid}.game-card{border:1px solid var(--border);background:var(--surface-emphasis,#0000000d);border-radius:10px;overflow:hidden}.game-card-summary{cursor:pointer;align-items:center;gap:.6rem;padding:.65rem .85rem;list-style:none;display:flex}.game-card-summary::-webkit-details-marker{display:none}.game-card-summary::marker{content:""}.game-card-chevron{border-right:2px solid var(--text);border-bottom:2px solid var(--text);flex-shrink:0;width:.45rem;height:.45rem;margin-top:-.15rem;transition:transform .15s;transform:rotate(-45deg)}.game-card[open] .game-card-chevron{margin-top:.1rem;transform:rotate(45deg)}.game-card-summary-main{flex:1;gap:.2rem;min-width:0;display:grid}.game-card-title{color:var(--text-h);word-break:break-word;font-size:1rem;font-weight:700;line-height:1.3}.game-card-meta{color:var(--text);opacity:.9;font-size:.85rem;line-height:1.35}.game-card-open{white-space:nowrap;flex-shrink:0;font-weight:600}.game-card-body{border-top:1px solid var(--border);padding:0 .85rem .75rem 2rem}.game-card-description{white-space:pre-wrap;word-break:break-word;margin:.65rem 0 0;font-size:.95rem;line-height:1.45}.game-session-layout,.dice-tools-layout{gap:1.25rem;margin-top:.5rem;display:grid}@media (width>=52rem){.game-session-layout,.dice-tools-layout{grid-template-columns:minmax(0,1fr) minmax(14rem,22rem);align-items:start}.game-session-side{gap:1rem;display:grid}}.encounter-helper{text-align:left}.encounter-helper-form{gap:.65rem;margin:.75rem 0;display:grid}@media (width>=32rem){.encounter-helper-form{grid-template-columns:repeat(2,minmax(0,1fr))}}.encounter-helper-actions{flex-wrap:wrap;gap:.4rem;display:flex}.encounter-result{border:1px solid var(--border);background:var(--surface-emphasis,#0000000d);border-radius:8px;margin-top:.75rem;padding:.65rem .85rem}.encounter-result ul{margin:.5rem 0;padding-left:1.1rem}.initiative-tracker{text-align:left;margin-bottom:1rem}.initiative-list{gap:.35rem;margin:.5rem 0;padding:0;list-style:none;display:grid}.initiative-row{border:1px solid var(--border);border-radius:6px;grid-template-columns:1.5rem 1fr auto auto;align-items:center;gap:.5rem;padding:.4rem .55rem;display:grid}.initiative-rank{opacity:.7;font-weight:700}.initiative-value{text-align:right;min-width:1.5rem;font-weight:700}.initiative-remove{padding:.1rem .45rem;line-height:1}.initiative-add-form{gap:.5rem;margin-top:.75rem;display:grid}.initiative-add-row{flex-wrap:wrap;align-items:flex-end;gap:.5rem;display:flex}.bestiary-filters{gap:.65rem;margin:.75rem 0;display:grid}@media (width>=32rem){.bestiary-filters{grid-template-columns:1fr 12rem}}.bestiary-list{text-align:left;gap:.4rem;max-height:28rem;margin:0;padding:0;list-style:none;display:grid;overflow-y:auto}.bestiary-item{border:1px solid var(--border);border-radius:6px;gap:.1rem;padding:.45rem .6rem;display:grid}.equipment-filters{margin-top:.75rem}.equipment-list{margin-top:.5rem}.equipment-list-item{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.equipment-list-item-text{flex:1;gap:.1rem;min-width:0;display:grid}.equipment-add-to-char{flex-shrink:0;font-size:.85rem}.starting-equipment-chooser{border:1px solid var(--border);background:var(--surface-emphasis,#00000008);border-radius:8px;gap:.65rem;padding:.65rem .75rem;display:grid}.starting-equipment-choices{gap:.75rem;margin:0;padding:0 0 0 1.1rem;display:grid}.starting-equipment-choice{gap:.35rem;display:grid}.starting-equipment-prompt{margin:0;font-size:.9rem;font-weight:600}.starting-equipment-options{gap:.25rem;display:grid}.starting-equipment-option{cursor:pointer;align-items:flex-start;gap:.4rem;font-size:.9rem;display:flex}.starting-equipment-actions{flex-wrap:wrap;gap:.5rem;display:flex}.muted-button{opacity:.85}.character-ac-suggest-wrap{align-self:end}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.equipment-picker-backdrop{z-index:200;background:#00000073;justify-content:center;align-items:flex-start;padding:2rem 1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.equipment-picker-dialog{gap:.65rem;width:min(36rem,100%);max-height:min(32rem,100vh - 4rem);display:grid;overflow:hidden}.equipment-picker-header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.equipment-picker-header h3{margin:0;font-size:1.05rem}.equipment-picker-close{flex-shrink:0}.equipment-picker-filters{gap:.5rem;display:grid}@media (width>=28rem){.equipment-picker-filters{grid-template-columns:1fr 9rem}}.equipment-picker-list{gap:.35rem;max-height:16rem;margin:0;padding:0;list-style:none;display:grid;overflow-y:auto}.equipment-picker-row{text-align:left;border:1px solid var(--border);background:var(--surface,transparent);cursor:pointer;border-radius:6px;gap:.1rem;width:100%;padding:.45rem .55rem;display:grid}.equipment-picker-row:hover{border-color:var(--accent,currentColor)}.equipment-picker-row-name{font-weight:600}.equipment-list-item-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.equipment-list-name-button{text-align:left;cursor:pointer;color:inherit;background:0 0;border:none;padding:0}.equipment-list-name-button:hover strong{text-decoration:underline}.character-inventory-warnings{background:var(--color-surface-raised,#ffc86414);border-radius:4px;margin-bottom:.75rem;padding:.5rem .75rem}.character-inventory-warnings-title,.character-spellcasting-warnings-title{margin:0 0 .25rem;font-weight:600}.character-inventory-weight{margin:0 0 .75rem}.character-weapon-attacks ul,.character-weapon-attacks-view ul{margin:0;padding-left:1.25rem}.character-classes-list{margin:0 0 1rem;padding:0;list-style:none}.character-class-row{border-bottom:1px solid var(--color-border,#ffffff14);flex-wrap:wrap;align-items:flex-end;gap:.75rem;margin-bottom:.75rem;padding-bottom:.75rem;display:flex}.character-inventory-weight-side{align-items:center;gap:.25rem;display:flex}.character-inventory-row{flex-wrap:wrap}.character-inventory-row-notes{flex:100%;margin:.25rem 0 .5rem}.character-inventory-row-notes textarea{width:100%;min-height:2.5rem}.character-inventory-notes-toggle{font-size:.85rem}.character-inventory-additional-hint{margin:.35rem 0 0;font-size:.85rem}.character-inventory-view-row-main{justify-content:space-between;gap:.5rem;display:flex}.character-inventory-item-note{margin:.2rem 0 .5rem;font-size:.9rem}.legacy-inventory-migrate{border:1px solid var(--color-border,#ffc86440);background:var(--color-surface-raised,#ffc8640f);border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.legacy-inventory-migrate h5{margin:0 0 .5rem}.legacy-inventory-preview-source{max-height:6rem;margin:.5rem 0;font-size:.85rem;overflow:auto}.legacy-inventory-preview-list{margin:.5rem 0 .75rem;padding-left:1.25rem;font-size:.9rem}.legacy-inventory-migrate-actions{flex-wrap:wrap;gap:.5rem;display:flex}.character-spell-class-block{border-bottom:1px solid var(--color-border,#ffffff14);margin-bottom:1.25rem;padding-bottom:1rem}.character-spell-rest-actions{flex-wrap:wrap;gap:.5rem;display:flex}.spell-detail-material-action{margin:.75rem 0}.equipment-picker-row-meta{font-size:.85rem}.character-inventory-section h4{margin:.75rem 0 .35rem;font-size:.95rem}.character-inventory-currency-block{gap:.5rem;margin:.35rem 0 .65rem;display:grid}.character-inventory-currency-block .character-currency-fieldset,.character-inventory-currency-block .character-currency-summary{margin:0}.character-inventory-additional{border-top:1px solid var(--border);margin-top:.65rem;padding-top:.65rem}.character-inventory-additional-label{margin:0 0 .35rem;font-size:.85rem;font-weight:600}.character-inventory-list-disclosure{margin:0}.character-inventory-list-disclosure .disclosure-trigger{padding:.4rem .55rem;font-size:.9rem}.character-inventory-list-disclosure .disclosure-panel{padding-top:.35rem}.character-sheet-block .character-inventory-list-disclosure{margin-top:.25rem}.spell-filters{margin-top:.75rem}@media (width>=40rem){.spell-filters{grid-template-columns:1fr 10rem 11rem}}.spell-level-sections{gap:1rem;margin-top:.5rem;display:grid}.spell-level-heading{margin:0 0 .35rem;font-size:1rem}.spell-list{max-height:none}.spell-list-item{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:0;display:flex}.spell-list-button{text-align:left;cursor:pointer;min-width:0;font:inherit;color:inherit;background:0 0;border:none;border-radius:6px;flex:1;gap:.1rem;padding:.45rem .6rem;display:grid}.spell-list-button:hover{background:var(--surface-emphasis,#0000000d)}.spell-detail-dialog{width:min(40rem,100%);max-height:min(36rem,100vh - 4rem);overflow-y:auto}.spell-detail-subtitle{margin:.15rem 0 0;font-size:.9rem}.spell-detail-stats{grid-template-columns:repeat(auto-fill,minmax(9rem,1fr));gap:.5rem .75rem;margin:0;display:grid}.spell-detail-stats dt{text-transform:uppercase;letter-spacing:.03em;opacity:.75;font-size:.75rem}.spell-detail-stats dd{margin:.1rem 0 0;font-weight:600}.spell-detail-desc h4{margin:.75rem 0 .35rem;font-size:.95rem}.spell-detail-desc p{white-space:pre-wrap;margin:0;line-height:1.5}.character-spellcasting-section{margin-top:.75rem}.character-spellcasting-section h4{margin:0 0 .5rem}.character-spell-block{margin-top:.65rem}.character-spell-block-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.35rem;display:flex}.character-spell-block-header h5{margin:0;font-size:.95rem}.character-spell-list{gap:.35rem;margin:0;padding:0;list-style:none;display:grid}.character-spell-row{flex-wrap:wrap;align-items:baseline;gap:.35rem .75rem;display:flex}.character-spell-name{font:inherit;color:var(--link-color,#2563eb);cursor:pointer;text-align:left;background:0 0;border:none;padding:0;font-weight:600}.character-spell-name:hover{text-decoration:underline}.character-spell-meta{font-size:.85rem}.character-spell-remove{margin-left:auto;font-size:.85rem}.character-spell-slots{gap:.35rem;margin:0;padding:0;list-style:none;display:grid}.character-spell-slot-row{align-items:center;gap:.5rem;display:flex}.character-spell-slot-row .numeric-input-wrap{max-width:4rem}.character-spellcasting-warnings{background:#b478001f;border:1px solid #b4780059;border-radius:6px;margin-top:.75rem;padding:.65rem .75rem;font-size:.9rem}.character-spellcasting-warnings-title{margin:0 0 .35rem;font-weight:600}.character-spellcasting-warnings ul{margin:0;padding-left:1.25rem}.character-spell-view-heading{margin:.5rem 0 .25rem;font-size:.9rem}.character-spell-slots-view{gap:.2rem;margin:0;padding:0;list-style:none;display:grid}.character-inventory-editor{text-align:left;gap:.65rem;display:grid}.character-inventory-kit{gap:.35rem;display:grid}.character-inventory-actions{flex-wrap:wrap;align-items:flex-end;gap:.5rem;display:flex}.character-inventory-custom{flex-wrap:wrap;flex:1;gap:.35rem;min-width:12rem;display:flex}.character-inventory-custom input{flex:1;min-width:8rem}.character-inventory-list{gap:.4rem;margin:0;padding:0;list-style:none;display:grid}.character-inventory-row{border:1px solid var(--border);border-radius:6px;align-items:center;gap:.35rem .65rem;padding:.45rem .55rem;display:grid}@media (width>=36rem){.character-inventory-row{grid-template-columns:1fr auto auto}}.character-inventory-row-main{gap:.1rem;min-width:0;display:grid}.character-inventory-row-name{font-weight:600}.character-inventory-row-kind{text-transform:capitalize;font-size:.8rem}.character-inventory-qty-side{font-variant-numeric:tabular-nums;justify-content:flex-end;align-items:center;min-width:3.25rem;font-weight:600;display:flex}.character-inventory-qty-side input{text-align:center;width:3.25rem}.character-inventory-row-controls{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.character-inventory-equipped{align-items:center;gap:.3rem;font-size:.85rem;display:inline-flex}.character-currency-fieldset{border:1px solid var(--border);border-radius:8px;margin:0;padding:.5rem .65rem}.character-currency-fieldset legend{padding:0 .25rem;font-size:.9rem}.character-currency-grid{grid-template-columns:repeat(auto-fill,minmax(5.5rem,1fr));gap:.4rem;display:grid}.character-inventory-view-list{gap:.25rem;margin:0 0 .35rem;padding:0;font-size:.9rem;list-style:none;display:grid}.character-inventory-view-row{justify-content:space-between;align-items:baseline;gap:.75rem;display:flex}.character-inventory-view-qty{font-variant-numeric:tabular-nums;color:var(--muted,inherit);opacity:.9;flex-shrink:0;font-weight:600}.character-currency-summary{margin:0 0 .35rem;font-size:.9rem;font-weight:600}.dice-tray{text-align:left;gap:.75rem;display:grid}.dice-tray--compact{gap:.55rem}.dice-tray-d20-block{gap:.4rem;display:grid}.dice-tray-mod-label{font-size:.85rem;font-weight:600}.dice-tray-mod-input{width:5rem}.dice-tray-adv-row{flex-wrap:wrap;gap:.4rem;display:flex}.dice-tray-presets{flex-wrap:wrap;gap:.35rem;display:flex}.dice-preset-btn{padding:.3rem .55rem;font-size:.85rem}.dice-tray-form{gap:.6rem;display:grid}.dice-tray-hint{margin:0;font-size:.85rem}.dice-tray-error{color:var(--danger);margin:0}.dice-result{border:1px solid var(--border);background:var(--surface-emphasis,#0000000d);border-radius:8px;padding:.65rem .85rem}.dice-result-total{margin:0;font-size:1.75rem;line-height:1.2}.dice-result-breakdown{margin:.35rem 0 0;font-size:.9rem}.roll-log-panel{border:1px solid var(--border);background:var(--surface-emphasis,#0000000d);text-align:left;border-radius:10px}.roll-log-summary{cursor:pointer;justify-content:space-between;align-items:center;gap:.5rem;padding:.55rem .75rem;font-weight:600;list-style:none;display:flex}.roll-log-summary::-webkit-details-marker{display:none}.roll-log-body{max-height:24rem;padding:0 .75rem .65rem;overflow-y:auto}.roll-log-list{gap:.5rem;margin:0;padding:0;list-style:none;display:grid}.roll-log-item{border:1px solid var(--border);border-radius:8px;padding:.5rem .6rem}.roll-log-item-head{align-items:baseline;gap:.5rem;display:flex}.roll-log-item-head strong{font-size:1.15rem}.roll-log-item-meta,.roll-log-item-detail{margin:.2rem 0 0;font-size:.85rem}.dice-tools-reference{text-align:left;margin-top:1.5rem}.conditions-ref summary{cursor:pointer;margin:.5rem 0;font-weight:600}.conditions-list{gap:.45rem;margin:.5rem 0 0;padding-left:1.1rem;font-size:.9rem;display:grid}.rules-reference-page{text-align:left}.rules-reference-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.rules-reference-dice-link{white-space:nowrap;font-weight:600}.rules-reference-filters{margin-bottom:.75rem}.rules-reference-count{margin-bottom:1rem}.rules-reference-sections{flex-direction:column;gap:1.75rem;display:flex}.rules-reference-section-title{margin:0 0 .35rem;font-size:1.15rem}.rules-reference-section-intro{max-width:52rem;margin:0 0 .75rem}.rules-reference-list{gap:.5rem;margin:0;padding:0;list-style:none;display:grid}@media (width>=640px){.rules-reference-list{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=1024px){.rules-reference-list{grid-template-columns:repeat(3,minmax(0,1fr))}}.rules-reference-card{margin:0}.rules-reference-details{border:1px solid var(--color-border,#ffffff1a);background:var(--color-surface-raised,#ffffff08);border-radius:6px}.rules-reference-details summary{cursor:pointer;padding:.6rem .75rem;font-weight:600;list-style:none}.rules-reference-details summary::-webkit-details-marker{display:none}.rules-reference-card-name{display:block}.rules-reference-card-body{color:var(--color-text-muted,inherit);opacity:.92;margin:0;padding:0 .75rem .75rem;font-size:.9rem;line-height:1.45}.rules-reference-footer{border-top:1px solid var(--color-border,#ffffff14);margin-top:2rem;padding-top:1rem;font-size:.85rem}.rules-reference-footer code{font-size:.8rem}.rules-reference-highlight-warn{background:#ffb4501f;border-radius:6px;margin:0 0 1rem;padding:.5rem .75rem}.rules-reference-card--highlight .rules-reference-details{border-color:var(--color-accent,#c9a227);box-shadow:0 0 0 1px var(--color-accent,#c9a227)}.character-conditions-panel{margin-bottom:1rem}.character-conditions-header{justify-content:space-between;align-items:baseline;gap:.75rem;margin-bottom:.5rem;display:flex}.character-conditions-header h4{margin:0}.character-conditions-rules-link{font-size:.85rem;font-weight:600}.character-exhaustion-row{flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin-bottom:.65rem;display:flex}.character-exhaustion-row label{font-size:.9rem}.character-exhaustion-row .numeric-input-wrap{max-width:4rem}.character-conditions-info-btn{cursor:pointer;border-radius:50%;width:1.6rem;height:1.6rem;padding:0;font-size:.85rem;line-height:1}.character-condition-chips{flex-wrap:wrap;gap:.4rem;display:flex}.character-condition-chip{border:1px solid var(--color-border,#ffffff26);cursor:pointer;background:var(--color-surface-raised,#ffffff0a);border-radius:999px;align-items:center;gap:.35rem;padding:.25rem .55rem;font-size:.8rem;display:inline-flex}.character-condition-chip input{margin:0}.character-condition-chip--active{border-color:var(--color-accent,#c9a227);background:#c9a22726}.character-condition-chip--view{font:inherit;color:inherit}.app-panel p{margin:0;line-height:1.45}.games-intro{margin:0 0 1.25rem;line-height:1.5}.games-intro a{color:var(--accent);font-weight:600}.games-empty-state{margin:0}.games-empty-actions{margin:.5rem 0 0}.link-button{font:inherit;color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-weight:600;text-decoration:underline}.link-button:hover{color:var(--text-h)}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.skeleton{border-radius:var(--radius-sm,4px);background:linear-gradient(90deg, var(--surface-muted,#0000000f) 0%, var(--surface,#ffffff14) 50%, var(--surface-muted,#0000000f) 100%);background-size:200% 100%;animation:1.2s ease-in-out infinite skeleton-shimmer;display:block}.game-card-list-skeleton{pointer-events:none}.game-card-skeleton{border:1px solid var(--border);border-radius:var(--radius-md,8px);background:var(--surface,var(--bg));align-items:center;gap:.65rem;padding:.65rem .75rem;display:flex}.game-card-skeleton-main{flex-direction:column;flex:1;gap:.4rem;min-width:0;display:flex}.skeleton-chevron{flex-shrink:0;width:.55rem;height:.55rem}.skeleton-title{width:55%;height:1rem}.skeleton-meta{width:40%;height:.75rem}.skeleton-button{border-radius:var(--radius-md,8px);flex-shrink:0;width:5.5rem;height:2rem}@media (prefers-reduced-motion:reduce){.skeleton{animation:none}}.games-section{margin-bottom:1.5rem}.games-section h3{color:var(--text-h);margin:0 0 .65rem;font-size:1rem}.games-create-section{margin-bottom:0}.disclosure-trigger{width:100%;min-height:44px;font:inherit;color:var(--text-h);text-align:left;background:var(--surface-muted,#0000000a);border:1px solid var(--border);border-radius:var(--radius-md,8px);cursor:pointer;justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem .85rem;font-weight:600;display:flex}.disclosure-trigger:hover{border-color:var(--accent-border);color:var(--accent)}.disclosure-trigger[aria-expanded=true]{border-color:var(--accent-border);border-bottom-right-radius:0;border-bottom-left-radius:0}.disclosure-trigger-label{flex:1}.disclosure-chevron{border-bottom:2px solid;border-right:2px solid;flex-shrink:0;width:.5rem;height:.5rem;margin-top:-.2rem;transition:transform .15s;transform:rotate(45deg)}.disclosure-trigger[aria-expanded=true] .disclosure-chevron{margin-top:.15rem;transform:rotate(-135deg)}.disclosure-panel{border:1px solid var(--accent-border,var(--border));border-radius:0 0 var(--radius-md,8px) var(--radius-md,8px);background:var(--surface,var(--bg));border-top:none;padding:1rem .85rem .85rem}.disclosure-panel[hidden]{display:none!important}.overview-disclosure{margin-bottom:1rem}.overview-disclosure .disclosure-panel .create-game-form{margin:0}.overview-disclosure-lede{margin:0 0 1rem;font-size:.9rem;line-height:1.45}.form-error{color:var(--danger);margin:.5rem 0 0}.settings-profile-form{margin-top:.75rem}.settings-email{margin:0 0 .25rem}.settings-profile-hint{margin:.75rem 0 0;font-size:.9rem}.create-game-form{gap:.75rem;width:min(100%,32rem);margin:.75rem auto 0;display:grid}.form-row{text-align:left;gap:.35rem;display:grid}.form-row input[type=text],.form-row input[type=number],.form-row select,.form-row textarea{box-sizing:border-box;width:100%}.form-row textarea{resize:vertical;min-height:5.5rem}.form-row-inline{justify-content:flex-start;align-items:center;gap:.5rem;display:flex}.search-form,.search-status{margin-top:.75rem}.search-results{gap:.75rem;margin-top:.75rem;padding:0;list-style:none;display:grid}.search-results li{text-align:left}.mailbox-tabs{flex-wrap:wrap;gap:.5rem;margin:.75rem 0;display:flex}.mailbox-tabs .tab{cursor:pointer;padding:.4rem .75rem}.mailbox-tabs .tab.active{font-weight:600;text-decoration:underline}.mailbox-actions{margin:.5rem 0 .75rem}.mailbox-list{gap:.75rem;padding:0;list-style:none;display:grid}.mailbox-item{text-align:left;border:1px solid var(--border,#ccc);border-radius:6px;padding:.6rem .75rem}.mailbox-item.unread{background:var(--surface-emphasis,#0000000d)}.members-list{gap:.5rem;padding:0;list-style:none;display:grid}.member-row{border:1px solid var(--border,#ccc);text-align:left;border-radius:6px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.member-meta{min-width:0}.member-actions{flex-wrap:wrap;gap:.5rem;display:flex}.leave-game-row{gap:.4rem;margin-top:1rem;display:grid}.leave-game-row .danger{background:#dc26261a;border-color:#dc262680}.leave-game-row .danger:disabled{opacity:.55;cursor:not-allowed}.leave-hint{opacity:.85;margin:0;font-size:.85rem}.muted{opacity:.85;font-size:.9rem}.reference-block{text-align:left;margin-top:.75rem}.reference-block h4{margin:0 0 .35rem}.reference-body{background:var(--surface-emphasis,#0000000d);border:1px solid var(--border,#ccc);white-space:pre-wrap;word-break:break-word;font:inherit;border-radius:6px;margin:0;padding:.6rem .75rem;font-size:.95rem;line-height:1.4}.game-characters{text-align:left}.game-characters-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.game-characters-toolbar h3{margin:0}.character-card-list{gap:.5rem;margin:0 0 1rem;padding:0;list-style:none;display:grid}.character-card{text-align:left;border:1px solid var(--border);background:var(--surface-emphasis,#0000000d);cursor:pointer;width:100%;font:inherit;color:inherit;border-radius:8px;gap:.15rem;padding:.6rem .75rem;display:grid}.character-card--active{border-color:var(--accent-border,var(--accent,#7c9cff));box-shadow:0 0 0 1px var(--accent-border,var(--accent,#7c9cff))}.character-card--compact{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.character-card-main{gap:.1rem;display:grid}.character-card-owner{font-size:.8rem}.attach-characters-panel{border:1px solid var(--border);border-radius:8px;margin-bottom:1rem;padding:.5rem .75rem}.attach-characters-panel summary{cursor:pointer;font-weight:600}.character-detail{border-top:1px solid var(--border);margin-top:1rem;padding-top:1rem}.character-detail-toolbar{flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem;display:flex}.character-wizard{border:1px solid var(--border);background:var(--surface-emphasis,#0000000d);border-radius:10px;margin:.75rem 0 1rem;padding:.85rem}.character-wizard-steps{flex-wrap:wrap;gap:.5rem .75rem;margin-bottom:.75rem;font-size:.85rem;display:flex}.character-wizard-steps .active{color:var(--accent,#7c9cff);font-weight:700}.character-wizard-steps .done{opacity:.7}.character-wizard-panel{gap:.65rem;display:grid}.character-wizard-actions{flex-wrap:wrap;gap:.4rem;margin-top:.75rem;display:flex}.character-editor-row{gap:.65rem;display:grid}@media (width>=36rem){.character-editor-row{grid-template-columns:repeat(3,minmax(0,1fr))}}.character-fieldset{border:1px solid var(--border);border-radius:8px;margin:0;padding:.6rem .75rem}.character-fieldset legend{padding:0 .25rem;font-weight:600}.ability-editor-grid,.standard-array-grid{gap:.5rem;display:grid}@media (width>=28rem){.ability-editor-grid,.standard-array-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.skill-editor-grid{grid-template-columns:repeat(auto-fill,minmax(10rem,1fr));gap:.35rem .75rem;display:grid}.skill-check-label{cursor:pointer;align-items:center;gap:.35rem;font-size:.9rem;display:flex}.character-assign-mode{gap:.35rem;display:grid}.character-assign-mode label{cursor:pointer;align-items:center;gap:.4rem;display:flex}.character-review-dl{gap:.4rem;margin:0;display:grid}.character-review-dl div{grid-template-columns:6rem 1fr;gap:.5rem;display:grid}.character-review-dl dt{margin:0;font-weight:600}.character-review-dl dd{margin:0}.character-suggest-hp{justify-self:start;margin-bottom:.5rem}.character-sheet-header h3{margin:0 0 .25rem}.character-sheet-subtitle{margin:0 0 .75rem}.character-sheet-grid{gap:.75rem;display:grid}@media (width>=40rem){.character-sheet-grid{grid-template-columns:1fr 1fr}.character-sheet-block--wide{grid-column:1/-1}}.character-sheet-block h4{margin:0 0 .5rem;font-size:.95rem}.ability-scores{gap:.35rem;margin:0;padding:0;list-style:none;display:grid}.ability-scores li{grid-template-columns:1fr auto auto;align-items:center;gap:.5rem;display:grid}.ability-label{font-size:.9rem}.ability-score{text-align:center;min-width:1.5rem;font-weight:700}.ability-mod{opacity:.9;text-align:right;min-width:2rem;font-size:.9rem}.character-sheet-prof{margin:.5rem 0 0;font-size:.85rem}.character-stat-dl{gap:.35rem;margin:0;display:grid}.character-stat-dl div{justify-content:space-between;gap:.5rem;display:flex}.character-stat-dl dt{font-weight:600}.character-stat-dl dd{margin:0}.character-skill-list{flex-wrap:wrap;gap:.35rem .75rem;margin:0;padding:0;font-size:.9rem;list-style:none;display:flex}.character-sheet-pre{background:var(--surface-emphasis,#0000000d);border:1px solid var(--border);white-space:pre-wrap;font:inherit;border-radius:6px;margin:0;padding:.5rem .65rem;font-size:.9rem}.session-presence{flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin-bottom:.5rem;font-size:.85rem;display:flex}.session-presence ul{flex-wrap:wrap;gap:.4rem .75rem;margin:0;padding:0;list-style:none;display:flex}.session-presence li{align-items:center;gap:.35rem;display:inline-flex}.presence-dot{background:var(--success);border-radius:999px;width:.55rem;height:.55rem;display:inline-block;box-shadow:0 0 0 2px #4ade8040}.session-chat{border:1px solid var(--border);background:var(--surface-emphasis,#0000000d);text-align:left;border-radius:10px;gap:.5rem;padding:.65rem .75rem;display:grid}.session-chat h3{margin:0;font-size:1rem}.session-chat-list{gap:.4rem;max-height:16rem;margin:0;padding:.25rem 0;list-style:none;display:grid;overflow-y:auto}.session-chat-row{border:1px solid var(--border);background:var(--surface,transparent);border-radius:8px;padding:.35rem .5rem}.session-chat-meta{margin-bottom:.15rem;font-size:.75rem}.session-chat-body{white-space:pre-wrap;word-break:break-word;font-size:.92rem}.session-chat-form{gap:.4rem;display:flex}.session-chat-form input[type=text]{flex:1;min-width:0}.session-chat-error{color:var(--danger);margin:0;font-size:.85rem}.vtt-panel{text-align:left;gap:.75rem;display:grid}.vtt-canvas-wrapper{gap:.5rem;display:grid}.vtt-canvas-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;font-size:.85rem;display:flex}.vtt-spike-badge{background:var(--surface);color:var(--warning);letter-spacing:.04em;text-transform:uppercase;border-radius:999px;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.vtt-canvas-host{border:1px solid var(--border);background:var(--bg);cursor:crosshair;border-radius:12px;width:100%;height:clamp(20rem,60vh,40rem);position:relative;overflow:hidden}.vtt-canvas-host canvas{width:100%;height:100%;display:block}.vtt-canvas-error{color:var(--danger);margin:0;font-size:.85rem}.vtt-skeleton{background:linear-gradient(90deg, var(--surface-emphasis,#0000000f) 0%, #ffffff14 50%, var(--surface-emphasis,#0000000f) 100%);background-size:200% 100%;border-radius:12px;width:100%;height:clamp(20rem,60vh,40rem);animation:1.2s ease-in-out infinite vtt-skeleton-shimmer}@keyframes vtt-skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.vtt-setup-form,.vtt-gm-tools{text-align:left;max-width:28rem}.vtt-gm-tools{border:1px solid var(--border);border-radius:10px;margin-bottom:.75rem;padding:.5rem .75rem}.vtt-gm-tools summary{cursor:pointer;font-weight:600}.vtt-grid-form,.vtt-replace-form{gap:.5rem;margin-top:.75rem;display:grid}.vtt-canvas-loading{margin:.35rem 0 0}.vtt-stage{grid-template-columns:minmax(12rem,18rem) 1fr;align-items:start;gap:.75rem;display:grid}.vtt-sidebar{gap:.75rem;max-height:clamp(20rem,60vh,40rem);display:grid;overflow-y:auto}@media (width<=768px){.vtt-stage{grid-template-columns:1fr}}.vtt-token-tray,.vtt-fog-tools,.vtt-drawing-tools{border:1px solid var(--border);background:var(--surface,#00000005);border-radius:10px;gap:.75rem;padding:.65rem .75rem;display:grid}.vtt-fog-tool-row{gap:.35rem;display:flex}.vtt-fog-tool-row button.is-active{border-color:var(--warning);background:#facc151f}.vtt-fog-hint{margin:0;font-size:.85rem}.vtt-fog-preview{font-size:.85rem}.vtt-fog-preview summary{cursor:pointer;font-weight:600}.vtt-checkbox-row{align-items:center;gap:.45rem;margin:.35rem 0;display:flex}.vtt-fog-clear{color:var(--danger);border-color:#f8717159;justify-self:start}.vtt-fog-tools-player .muted{margin:0;font-size:.85rem}.vtt-tray-heading{margin:0 0 .35rem;font-size:.85rem;font-weight:600}.vtt-tray-section{gap:.35rem;display:grid}.vtt-placement-hint{background:var(--surface);color:var(--text-h);border-radius:8px;margin:0;padding:.45rem .55rem;font-size:.85rem}.vtt-cancel-place{color:var(--accent);cursor:pointer;font:inherit;background:0 0;border:none;margin-left:.35rem;padding:0;text-decoration:underline}.vtt-npc-form{gap:.45rem;display:grid}.vtt-place-list,.vtt-token-list{gap:.25rem;margin:0;padding:0;list-style:none;display:grid}.vtt-place-btn,.vtt-token-row{text-align:left;width:100%;color:inherit;cursor:pointer;font:inherit;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:.45rem;padding:.35rem .45rem;display:flex}.vtt-place-btn:hover,.vtt-token-row:hover{background:#ffffff0f}.vtt-token-list li{align-items:center;gap:.25rem;display:flex}.vtt-token-list li.is-selected .vtt-token-row,.vtt-drawing-list li.is-selected .vtt-drawing-row{border-color:var(--warning);background:#facc151f}.vtt-drawing-list{gap:.25rem;margin:0;padding:0;list-style:none;display:grid}.vtt-drawing-list li{align-items:center;gap:.25rem;display:flex}.vtt-drawing-row{text-align:left;width:100%;color:inherit;cursor:pointer;font:inherit;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:.45rem;padding:.35rem .45rem;display:flex}.vtt-drawing-row:hover{background:#ffffff0f}.vtt-drawing-row-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.vtt-tray-subheading{margin:0;font-size:.8rem;font-weight:600}.vtt-fog-token-fieldset{border:none;margin:0;padding:.35rem 0}.vtt-fog-token-fieldset legend{margin-bottom:.25rem;font-size:.85rem;font-weight:600}.vtt-token-swatch{border:1px solid #ffffff40;border-radius:999px;flex-shrink:0;width:1.1rem;height:1.1rem}.vtt-color-picker{flex-shrink:0;position:relative}.vtt-color-swatch-btn{cursor:pointer;padding:0;display:block}.vtt-color-swatch-btn:disabled{cursor:default;opacity:.6}.vtt-color-swatch-btn:not(:disabled):hover{box-shadow:0 0 0 2px var(--accent-border,#7c9cff80)}.vtt-color-popover{border:1px solid var(--border,#ffffff26);background:var(--surface,#1e293b);border-radius:10px;width:min(14.5rem,100vw - 1rem);padding:.65rem;box-shadow:0 8px 28px #00000073}.vtt-color-wheel-wrap{width:fit-content;margin:0 auto .5rem;position:relative}.vtt-color-wheel{cursor:crosshair;touch-action:none;border-radius:999px;width:168px;height:168px;display:block}.vtt-color-wheel-marker{pointer-events:none;border:2px solid #fff;border-radius:999px;width:.75rem;height:.75rem;margin:-.375rem 0 0 -.375rem;position:absolute;box-shadow:0 0 0 1px #00000080}.vtt-color-lightness-row input[type=range]{flex:1;min-width:0}.vtt-color-hex-row input.is-invalid{border-color:var(--danger)}.vtt-color-hex-error{color:var(--danger);margin:.25rem 0 0;font-size:.75rem}.vtt-color-apply{width:100%;margin-top:.35rem;font-size:.85rem}.vtt-color-tool-row{flex-wrap:wrap;align-items:center;gap:.45rem;display:flex}.vtt-color-tool-label{font-size:.85rem;font-weight:600}.vtt-color-presets{flex-wrap:wrap;gap:.3rem;display:flex}.vtt-color-preset{cursor:pointer;border:1px solid #ffffff40;border-radius:999px;width:1.25rem;height:1.25rem;padding:0}.vtt-color-preset:hover{transform:scale(1.08)}.vtt-token-list .vtt-token-row,.vtt-drawing-list .vtt-drawing-row{flex:1;min-width:0}.vtt-token-row-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.vtt-token-kind{opacity:.65;font-size:.8em}.vtt-token-fog-select{flex-shrink:0;max-width:4.5rem;padding:.2rem .25rem;font-size:.75rem}.vtt-token-remove{width:1.75rem;height:1.75rem;color:var(--danger);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;font-size:1.1rem;line-height:1}.vtt-token-remove:hover{background:#f8717126}.vtt-stage .vtt-canvas-wrapper{min-width:0}.vtt-canvas-host{cursor:default}.session-loading-screen{box-sizing:border-box;background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.session-loading-card{border:1px solid var(--border);background:var(--bg);width:100%;max-width:20rem;box-shadow:var(--shadow);border-radius:12px;flex-direction:column;align-items:center;gap:1rem;padding:1.75rem;display:flex}.session-loading-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:2rem;height:2rem;animation:.65s linear infinite session-loading-spin}@keyframes session-loading-spin{to{transform:rotate(360deg)}}.session-loading-text{text-align:center;color:var(--text-h);margin:0;font-size:.95rem}.auth-page{box-sizing:border-box;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.auth-card{border:1px solid var(--border);background:var(--bg);width:100%;max-width:22rem;box-shadow:var(--shadow);border-radius:12px;padding:1.75rem}.auth-card h1{color:var(--text-h);margin:0 0 .35rem;font-size:1.35rem}.auth-lede{margin:0 0 1.25rem;font-size:.95rem}.auth-form label{color:var(--text-h);margin-bottom:.35rem;font-size:.9rem;display:block}.auth-form input{width:100%;font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);box-sizing:border-box;border-radius:8px;margin-bottom:1rem;padding:.5rem .65rem}.auth-form input:focus{outline:2px solid var(--accent-border);outline-offset:1px}.auth-form .password-field{align-items:stretch;margin-bottom:1rem;display:flex}.auth-form .password-field input{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0;flex:1;min-width:0;margin-bottom:0}.auth-form .password-field input:focus{z-index:1;position:relative}.auth-form .password-peek{font:inherit;color:var(--text-h);background:var(--bg);border:1px solid var(--border);cursor:pointer;border-top-right-radius:8px;border-bottom-right-radius:8px;flex-shrink:0;padding:.5rem .75rem;font-size:.85rem}.auth-form .password-peek:hover:not(:disabled){border-color:var(--accent-border);background:var(--accent-bg)}.auth-form .password-peek:disabled{opacity:.6;cursor:not-allowed}.auth-form button[type=submit]{width:100%;font:inherit;color:var(--text-h);background:var(--accent-bg);border:1px solid var(--accent-border);cursor:pointer;border-radius:8px;margin-top:.25rem;padding:.55rem 1rem;font-weight:600}.auth-form button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.auth-button-secondary{width:100%;font:inherit;color:var(--text);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;padding:.55rem 1rem;font-weight:600}.auth-button-secondary:hover{border-color:var(--accent-border);color:var(--text-h)}.auth-footer{text-align:center;margin-top:1.25rem;font-size:.9rem}.auth-footer a{color:var(--accent);font-weight:600}.auth-callout{border:1px solid var(--accent-border);background:var(--accent-bg);color:var(--text-h);border-radius:8px;margin:0 0 1rem;padding:.65rem .75rem;font-size:.88rem}.auth-error{color:var(--text-h);background:#dc262614;border:1px solid #dc262673;border-radius:8px;margin:0 0 1rem;padding:.65rem .75rem;font-size:.88rem}.die-graphic{flex-direction:column;align-items:center;gap:.15rem;display:inline-flex}.die-graphic-svg{width:100%;height:auto;display:block;overflow:visible}.die-graphic--sm .die-graphic-svg{width:2.25rem}.die-graphic--md .die-graphic-svg{width:3.25rem}.die-graphic--lg .die-graphic-svg{width:4.5rem}.die-graphic-shape{fill:var(--die-fill,#3d4f6f);stroke:var(--die-stroke,#8eb4e8);stroke-width:2px;transition:fill .2s,stroke .2s}.die-graphic-shape--d4{fill:var(--die-d4-fill,#5c4a7a);stroke:var(--die-d4-stroke,#b8a0e8)}.die-graphic-shape--d6{fill:var(--die-d6-fill,#2d6a4f);stroke:var(--die-d6-stroke,#95d5b2)}.die-graphic-shape--d8{fill:var(--die-d8-fill,#6b3a2a);stroke:var(--die-d8-stroke,#e8a87c)}.die-graphic-shape--d10{fill:var(--die-d10-fill,#1d4e6f);stroke:var(--die-d10-stroke,#7ec8e3)}.die-graphic-shape--d12{fill:var(--die-d12-fill,#5c4a1a);stroke:var(--die-d12-stroke,#e8d47c)}.die-graphic-shape--d20{fill:var(--die-d20-fill,#4a2d6b);stroke:var(--die-d20-stroke,#c9a0e8)}.die-graphic-shape--d100{fill:var(--die-d100-fill,#1a3d52);stroke:var(--die-d100-stroke,#7ec8e3)}.die-graphic-d100-mark{fill:var(--die-d100-stroke,#9ed8f0);opacity:.85;pointer-events:none;font-size:11px;font-weight:700}.die-graphic-value{fill:var(--die-text,#f4f7fb);pointer-events:none;font-family:inherit;font-size:18px;font-weight:700}.die-graphic--d100 .die-graphic-value{font-size:16px}.die-graphic-label{color:var(--text);opacity:.85;font-size:.65rem;font-weight:600}.die-graphic--rolling .die-graphic-svg{animation:.48s ease-in-out die-tumble}.die-graphic--rolling .die-graphic-value{opacity:.6}.die-graphic--revealed .die-graphic-svg{animation:.35s ease-out die-settle}.die-graphic--dropped{opacity:.4}.die-graphic--dropped .die-graphic-value{text-decoration:line-through}@keyframes die-tumble{0%{transform:rotate(0)scale(1)}35%{transform:rotate(120deg)scale(1.12)}70%{transform:rotate(260deg)scale(.95)}to{transform:rotate(360deg)scale(1)}}@keyframes die-settle{0%{transform:scale(1.15)}60%{transform:scale(.96)}to{transform:scale(1)}}.dice-roll-display{border:1px solid var(--border);background:var(--surface-emphasis,#0000000d);text-align:center;border-radius:10px;padding:.85rem 1rem}.dice-roll-display-faces{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:.65rem;display:flex}.dice-roll-display-total{flex-direction:column;align-items:center;gap:.1rem;display:flex}.dice-roll-display-total-label{text-transform:uppercase;letter-spacing:.06em;opacity:.75;font-size:.75rem}.dice-roll-display-total-value{color:var(--text-h);font-size:2rem;line-height:1.1}.dice-roll-display-breakdown{margin:.5rem 0 0;font-size:.85rem;line-height:1.4}.dice-roll-display--compact .dice-roll-display-total-value{font-size:1.5rem}.dice-tray-graphics-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.45rem;font-size:.9rem;display:flex}.dice-tray-graphics-toggle input{accent-color:var(--accent,#7c9cff)}.dice-preset-btn--graphic{flex-direction:column;align-items:center;gap:.2rem;min-width:2.75rem;padding:.35rem .5rem;display:inline-flex}.dice-preset-btn--text{min-width:3rem;padding:.45rem .55rem;font-size:.85rem;font-weight:600}.dice-tray-presets--graphic{gap:.5rem}
