: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%}.whisper-thread{flex-direction:column;height:100%;min-height:0;display:flex}.whisper-thread__header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;padding:10px 16px;display:flex}.whisper-thread__back{border:1px solid var(--border);color:var(--text);border-radius:var(--radius);cursor:pointer;background:0 0;padding:4px 10px;font-size:14px;line-height:1}.whisper-thread__back:hover{color:var(--text-h);border-color:var(--accent-border)}.whisper-thread__partner{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.whisper-thread__messages{flex-direction:column;flex:1;gap:6px;min-height:0;padding:12px 16px;display:flex;overflow-y:auto}.whisper-thread__empty{color:var(--text);text-align:center;margin-top:24px;font-size:13px}.whisper-msg{flex-direction:column;max-width:80%;display:flex}.whisper-msg--mine{align-self:flex-end;align-items:flex-end}.whisper-msg--theirs{align-self:flex-start;align-items:flex-start}.whisper-msg__text{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-h);word-break:break-word;white-space:pre-wrap;padding:7px 11px;font-size:13px;line-height:1.45}.whisper-msg--mine .whisper-msg__text{background:var(--accent);color:#fff;border-color:#0000}.whisper-msg__time{color:var(--text);margin-top:2px;padding:0 2px;font-size:11px}.whisper-thread__compose{border-top:1px solid var(--border);flex-shrink:0;gap:8px;padding:10px 16px;display:flex}.whisper-thread__input{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-h);resize:none;flex:1;padding:8px 10px;font-family:inherit;font-size:13px;line-height:1.4}.whisper-thread__input:focus{border-color:var(--accent-border);outline:none}.whisper-thread__input::placeholder{color:var(--text)}.whisper-thread__send{background:var(--accent);border-radius:var(--radius);color:#fff;cursor:pointer;border:none;align-self:flex-end;height:36px;padding:0 14px;font-size:13px;font-weight:600}.whisper-thread__send:disabled{opacity:.4;cursor:not-allowed}.whisper-thread__send:not(:disabled):hover{opacity:.85}.whisper-list{flex-direction:column;gap:4px;height:100%;padding:12px 16px;display:flex;overflow-y:auto}.whisper-list__empty{color:var(--text);text-align:center;margin-top:24px;font-size:13px}.whisper-list__item{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;align-items:center;gap:10px;width:100%;padding:10px 12px;transition:border-color .15s;display:flex}.whisper-list__item:hover{border-color:var(--accent-border)}.whisper-list__avatar{border-radius:50%;flex-shrink:0;width:32px;height:32px}.whisper-list__info{flex-direction:column;flex:1;min-width:0;display:flex}.whisper-list__name{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.whisper-list__char{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.whisper-list__badge{background:var(--accent);color:#fff;border-radius:99px;flex-shrink:0;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:700;display:flex}.notes-panel{flex-direction:column;gap:6px;height:100%;min-height:0;padding:12px 16px 8px;display:flex}.notes-panel__editor{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-h);resize:none;flex:1;min-height:0;padding:12px;font-family:inherit;font-size:13px;line-height:1.6}.notes-panel__editor:focus{border-color:var(--accent-border);outline:none}.notes-panel__editor::placeholder{color:var(--text)}.notes-panel__hint{color:var(--text);text-align:right;flex-shrink:0;font-size:11px}:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px;--surface:#1e1f28;--surface-raised:#252631;--crit:#22c55e;--fumble:#ef4444;--online:#22c55e;--offline:#6b7280;--dice-inactive:#2e303a;--dice-active:var(--accent);--radius:8px;--radius-lg:12px}#root{text-align:left;border-inline:none;width:100%;max-width:100%}*,:before,:after{box-sizing:border-box}h1,h2,h3{margin:0}button{cursor:pointer;font:inherit;border-radius:var(--radius);border:none;transition:opacity .15s}button:disabled{opacity:.5;cursor:not-allowed}input[type=text],input[type=number]{font:inherit;background:var(--surface);color:var(--text-h);border:1px solid var(--border);border-radius:var(--radius);outline:none;padding:8px 12px}input[type=text]:focus,input[type=number]:focus{border-color:var(--accent-border)}.onboarding{justify-content:center;align-items:center;min-height:100svh;padding:24px;display:flex}.onboarding__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow);padding:40px 32px}.onboarding__title{letter-spacing:-.5px;color:var(--text-h);margin-bottom:8px;font-size:28px}.onboarding__subtitle{color:var(--text);margin-bottom:24px}.onboarding__form{flex-direction:column;gap:12px;display:flex}.onboarding__input{width:100%;padding:10px 14px;font-size:16px}.onboarding__btn{background:var(--accent);color:#fff;padding:10px 20px;font-size:15px;font-weight:600}.onboarding__btn:hover:not(:disabled){opacity:.85}.onboarding__error{color:var(--fumble);margin:0;font-size:14px}.lobby{max-width:1000px;margin:0 auto;padding:32px 20px}.lobby__header{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:28px;display:flex}.lobby__title{color:var(--text-h);margin-bottom:0;font-size:24px}.lobby__title span{color:var(--accent)}.lobby__logout-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:4px 12px;font-size:13px;transition:color .15s,border-color .15s}.lobby__logout-btn:hover{color:var(--text-h);border-color:var(--text-dim)}.lobby__panels{grid-template-columns:1fr auto 1fr;align-items:start;display:grid}@media (width<=768px){.lobby__panels{grid-template-columns:1fr}.lobby__divider{background:var(--border);width:100%;height:1px;margin:24px 0}}.lobby__divider{background:var(--border);align-self:stretch;width:1px;margin:0 28px}.lobby__panel{flex-direction:column;gap:16px;display:flex}.lobby__panel-title{color:var(--text-h);font-size:18px;font-weight:600}.lobby__section-label{letter-spacing:.5px;text-transform:uppercase;color:var(--text);margin-top:8px;font-size:13px;font-weight:600}.lobby__form{flex-direction:column;gap:8px;display:flex}.lobby__form-row{gap:8px;display:flex}.lobby__input{flex:1;min-width:0}.lobby__input--code{text-transform:uppercase;letter-spacing:2px;font-weight:600}.lobby__btn{background:var(--accent);color:#fff;white-space:nowrap;padding:8px 16px;font-weight:600}.lobby__btn:hover:not(:disabled){opacity:.85}.lobby__error{color:var(--fumble);margin:0;font-size:13px}.found-session-card{background:var(--surface-raised);border:1px solid var(--accent-border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:16px;display:flex}.found-session-card__name{color:var(--text-h);font-size:16px;font-weight:600}.found-session-card__dm{color:var(--text);font-size:14px}.found-session-card__warning{color:#f59e0b;border-radius:var(--radius);background:#f59e0b1a;padding:8px 10px;font-size:13px}.session-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.session-list__empty{color:var(--text);font-size:14px}.session-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;transition:border-color .15s;display:flex}.session-card:hover:not([aria-disabled=true]){border-color:var(--accent-border)}.session-card[aria-disabled=true]{cursor:default;opacity:.6}.session-card--offline{opacity:.65}.session-card__info{flex-direction:column;gap:2px;min-width:0;display:flex}.session-card__name{color:var(--text-h);font-size:15px;font-weight:600}.session-card__code{font-family:var(--mono);color:var(--accent);letter-spacing:1px;font-size:12px}.session-card__dm,.session-card__char{color:var(--text);font-size:12px}.session-card__badge{letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;border-radius:99px;padding:3px 8px;font-size:11px;font-weight:700}.session-card__badge--online{color:var(--online);background:#22c55e26}.session-card__badge--offline{color:var(--offline);background:#6b728026}.session-card__actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.session-card__delete-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:99px;padding:3px 8px;font-size:11px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.session-card__delete-btn:hover{color:#ef4444;background:#ef44441f;border-color:#ef444466}.session-room{flex-direction:column;height:100svh;display:flex;overflow:hidden}.session-room--loading,.session-room--error,.session-room--offline{min-height:100svh;color:var(--text);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.session-room--offline h2{color:var(--text-h)}.session-room--error button,.session-room--offline button{background:var(--surface-raised);color:var(--text-h);border:1px solid var(--border);padding:8px 20px}.session-room__header{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 20px;display:flex}.session-room__header-left{align-items:center;gap:12px;min-width:0;display:flex}.session-room__header-right{align-items:center;gap:10px;display:flex}.session-room__back{color:var(--text);border:1px solid var(--border);border-radius:var(--radius);background:0 0;padding:6px 12px;font-size:13px}.session-room__back:hover{color:var(--text-h);border-color:var(--accent-border)}.session-room__title{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:18px;font-weight:600;overflow:hidden}.session-room__code{align-items:center;gap:6px;display:flex}.session-room__copy{background:var(--surface-raised);color:var(--text);border:1px solid var(--border);padding:4px 10px;font-size:12px}.session-room__copy:hover{color:var(--text-h)}.session-room__export{background:var(--surface-raised);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:4px 10px;font-size:12px}.session-room__export:hover{color:var(--text-h);border-color:var(--accent-border)}.session-room__status-btn{border:1px solid var(--border);padding:6px 14px;font-size:13px;font-weight:600}.session-room__status-btn--online{color:var(--fumble);background:#ef444426;border-color:#ef44444d}.session-room__status-btn--offline{color:var(--crit);background:#22c55e26;border-color:#22c55e4d}.session-room__status-badge{letter-spacing:.5px;text-transform:uppercase;border-radius:99px;padding:3px 8px;font-size:11px;font-weight:700}.session-room__status-badge--online{color:var(--online);background:#22c55e26}.session-room__status-badge--offline{color:var(--offline);background:#6b728026}.session-room__you{color:var(--text);font-size:13px}.session-room__main{flex:1;grid-template-columns:340px 1fr;align-items:stretch;min-height:0;display:grid;overflow:hidden}@media (width<=768px){.session-room__main{grid-template-columns:1fr;overflow-y:auto}}.session-room__right{flex-direction:column;min-height:0;display:flex;overflow:hidden}.session-room__right-tabs{border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.session-room__right-tab{color:var(--text);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}.session-room__right-tab:hover{color:var(--text-h)}.session-room__right-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.session-room__tab-badge{background:var(--accent);color:#fff;border-radius:99px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:11px;font-weight:700;display:inline-flex}.presence-strip{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:16px;min-height:72px;padding:12px 20px;display:flex;overflow-x:auto}.presence-strip__item{flex-direction:column;align-items:center;gap:4px;display:flex}.presence-strip__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:70px;font-size:11px;overflow:hidden}.presence-strip__badge--dm{letter-spacing:.5px;text-transform:uppercase;background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border);border-radius:99px;padding:1px 5px;font-size:9px;font-weight:700}.presence-strip__empty{color:var(--text);font-size:13px}.avatar{color:#fff;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.avatar--md{width:40px;height:40px;font-size:16px}.avatar--sm{width:28px;height:28px;font-size:12px}.dice-roller{border-right:1px solid var(--border);flex-direction:column;gap:16px;padding:20px;display:flex;overflow-y:auto}@media (width<=768px){.dice-roller{border-right:none;border-bottom:1px solid var(--border);gap:12px;max-height:none;padding:14px;position:static}}.dice-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.dice-btn{background:var(--dice-inactive);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:12px 8px;font-size:15px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.dice-btn:hover{color:var(--text-h);border-color:var(--accent-border)}.dice-btn--active{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-border)}.roller-controls{flex-direction:column;gap:16px;display:flex}.roller-controls__row{gap:12px;display:flex}.roller-controls__row .roller-controls__field{flex:1;min-width:0}.roller-controls__field{color:var(--text);align-items:center;gap:8px;font-size:13px;display:flex}.roller-controls__field span:first-child{min-width:36px;font-weight:500}.roller-controls__field input[type=number]{width:72px}.roller-controls__field--label{align-items:flex-start}.roller-controls__field--label span:first-child{padding-top:9px}.roller-controls__field--label input{flex:1}.roller-controls__field--private{cursor:pointer;flex-direction:row;align-items:center;gap:8px}.roller-controls__field--private input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.modifier-stepper{border:1px solid var(--border);border-radius:var(--radius);flex:1;align-items:center;min-width:0;display:flex;overflow:hidden}.modifier-stepper__btn{background:var(--surface-raised);color:var(--text-h);border:none;border-radius:0;justify-content:center;align-items:center;width:32px;height:36px;font-size:18px;line-height:1;transition:background .15s;display:flex}.modifier-stepper__btn:hover:not(:disabled){background:var(--accent-bg);color:var(--accent)}.modifier-stepper__value{text-align:center;font-family:var(--mono);color:var(--text-h);background:var(--surface);flex:1;padding:0 4px;font-size:14px;font-weight:600}.label-field{flex-direction:column;flex:1;gap:6px;display:flex}.label-presets{flex-wrap:wrap;gap:4px;display:flex}.label-preset{border:1px solid var(--border);color:var(--text);background:0 0;border-radius:99px;padding:3px 8px;font-size:11px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.label-preset:hover{border-color:var(--accent-border);color:var(--text-h)}.label-preset--active{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-border)}.roll-button{background:var(--accent);color:#fff;letter-spacing:.3px;border-radius:var(--radius);width:100%;padding:12px;font-size:15px;font-weight:700}.roll-button:hover:not(:disabled){opacity:.85}.macro-bar{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding-top:16px;display:flex}.macro-bar__header{justify-content:space-between;align-items:center;display:flex}.macro-bar__title{text-transform:uppercase;letter-spacing:.5px;color:var(--text);font-size:12px;font-weight:600}.macro-bar__save-btn{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border);border-radius:99px;padding:4px 10px;font-size:12px;font-weight:600;transition:opacity .15s}.macro-bar__save-btn:hover:not(:disabled){opacity:.8}.macro-bar__save-row{align-items:center;gap:6px;display:flex}.macro-bar__save-row input{flex:1;padding:6px 10px;font-size:13px}.macro-bar__confirm-btn{background:var(--accent);color:#fff;border-radius:var(--radius);padding:6px 12px;font-size:12px;font-weight:600}.macro-bar__cancel-btn{background:var(--surface-raised);color:var(--text);border-radius:var(--radius);padding:6px 10px;font-size:12px}.macro-bar__error{color:var(--fumble);margin:0;font-size:12px}.macro-bar__empty{color:var(--text);margin:0;font-size:12px;font-style:italic}.macro-bar__list{flex-direction:column;gap:6px;display:flex}.macro-pill{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-raised);align-items:center;transition:border-color .15s;display:flex;overflow:hidden}.macro-pill:hover{border-color:var(--accent-border)}.macro-pill__trigger{color:inherit;text-align:left;background:0 0;border-radius:0;flex-direction:column;flex:1;align-items:flex-start;gap:1px;min-width:0;padding:7px 10px;display:flex}.macro-pill__name{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:13px;font-weight:600;overflow:hidden}.macro-pill__config{color:var(--accent);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:11px;overflow:hidden}.macro-pill__actions{border-left:1px solid var(--border);align-items:center;display:flex}.macro-pill__action{width:30px;height:100%;min-height:36px;color:var(--text);background:0 0;border-radius:0;justify-content:center;align-items:center;font-size:13px;transition:background .15s,color .15s;display:flex}.macro-pill__action:hover{background:var(--accent-bg);color:var(--accent)}.macro-pill__action--delete:hover{color:var(--fumble);background:#ef44441f}.macro-pill__rename{flex:1;align-items:center;gap:4px;padding:4px 8px;display:flex}.macro-pill__rename input{flex:1;padding:4px 8px;font-size:13px}.macro-pill__rename button{background:var(--surface);color:var(--text-h);border-radius:var(--radius);padding:4px 8px;font-size:13px}.roll-log{flex-direction:column;gap:8px;padding:16px 20px;display:flex;overflow-y:auto}@media (width<=768px){.roll-log{max-height:none;overflow-y:visible}}.roll-log__empty{color:var(--text);text-align:center;padding:32px 0;font-size:14px}.log-entry{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:10px;padding:10px 12px;display:flex}.log-entry--crit{background:#22c55e0d;border-color:#22c55e66;animation:.6s ease-out critFlash}.log-entry--fumble{background:#ef44440d;border-color:#ef444466;animation:.5s ease-out fumbleShake}.log-entry--private{opacity:.8}.log-entry__avatar{flex-shrink:0}.log-entry__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.log-entry__who{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.log-entry__notation{font-family:var(--mono);color:var(--text);font-size:12px}.log-entry__label{color:var(--accent);font-size:12px;font-style:italic}.log-entry__placeholder{color:var(--text);font-size:13px;font-style:italic}.log-entry__total{color:var(--text-h);text-align:right;flex-shrink:0;min-width:40px;font-size:24px;font-weight:800}.log-entry--crit .log-entry__total{color:var(--crit)}.log-entry--fumble .log-entry__total{color:var(--fumble)}.log-entry__time{color:var(--text);font-size:11px;font-family:var(--mono);flex-shrink:0}.narration-entry{background:var(--surface);border:1px solid var(--accent-border);border-left:3px solid var(--accent);border-radius:var(--radius);align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.narration-entry__body{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.narration-entry__who{color:var(--accent);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:600}.narration-entry__message{color:var(--text-h);white-space:pre-wrap;word-break:break-word;margin:0;font-size:14px;font-style:italic;line-height:1.5}.narration-entry__time{color:var(--text);font-size:11px;font-family:var(--mono);flex-shrink:0;padding-top:2px}.narration-input{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding-top:16px;display:flex}.narration-input__textarea{font:inherit;background:var(--surface);color:var(--text-h);border:1px solid var(--border);border-radius:var(--radius);resize:none;outline:none;padding:8px 12px;font-size:13px;line-height:1.5;transition:border-color .15s}.narration-input__textarea:focus{border-color:var(--accent-border)}.narration-input__textarea::placeholder{color:var(--text);font-style:italic}.narration-input__send{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border);letter-spacing:.3px;border-radius:var(--radius);padding:8px 16px;font-size:13px;font-weight:700;transition:opacity .15s}.narration-input__send:hover:not(:disabled){opacity:.8}@keyframes critFlash{0%{box-shadow:0 0 #22c55e99}50%{box-shadow:0 0 0 8px #22c55e00}to{box-shadow:0 0 #22c55e00}}@keyframes fumbleShake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.adv-toggle{border:1px solid var(--border);border-radius:var(--radius);display:flex;overflow:hidden}.adv-toggle__btn{color:var(--text);background:0 0;border:none;border-radius:0;flex:1;padding:7px 0;font-size:12px;font-weight:600;transition:background .15s,color .15s}.adv-toggle__btn+.adv-toggle__btn{border-left:1px solid var(--border)}.adv-toggle__btn:hover:not(.adv-toggle__btn--active){background:var(--surface-raised);color:var(--text-h)}.adv-toggle__btn--active{background:var(--accent-bg);color:var(--accent)}.dice-grid--disabled{opacity:.4;pointer-events:none}.initiative-tracker{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding-top:16px;display:flex}.initiative-tracker__header{justify-content:space-between;align-items:center;gap:8px;display:flex}.initiative-tracker__title{letter-spacing:.5px;text-transform:uppercase;color:var(--text);font-size:12px;font-weight:700}.initiative-tracker__header-actions{gap:6px;display:flex}.initiative-tracker__next-btn{border:1px solid var(--accent-border);background:var(--accent-bg);color:var(--accent);cursor:pointer;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:600;transition:opacity .15s}.initiative-tracker__next-btn:hover{opacity:.8}.initiative-tracker__clear-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:3px 8px;font-size:12px;transition:opacity .15s}.initiative-tracker__clear-btn:hover{opacity:.7}.initiative-tracker__empty{color:var(--text);margin:0;font-size:13px}.initiative-tracker__list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.initiative-tracker__entry{border:1px solid var(--border);background:var(--bg);border-radius:8px;align-items:center;gap:8px;padding:6px 8px;font-size:14px;transition:background .15s,border-color .15s;display:flex}.initiative-tracker__entry--active{background:var(--accent-bg);border-color:var(--accent-border)}.initiative-tracker__turn-arrow{width:12px;color:var(--accent);flex-shrink:0;font-size:10px}.initiative-tracker__value{color:var(--text-h);text-align:center;border-radius:4px;min-width:28px;padding:1px 4px;font-size:15px;font-weight:700}.initiative-tracker__value--editable{cursor:pointer}.initiative-tracker__value--editable:hover{background:var(--accent-bg);color:var(--accent)}.initiative-tracker__edit-input{text-align:center;border:1px solid var(--accent-border);background:var(--bg);width:48px;color:var(--text-h);border-radius:4px;padding:2px 4px;font-size:14px;font-weight:700}.initiative-tracker__name{text-overflow:ellipsis;white-space:nowrap;color:var(--text-h);flex:1;overflow:hidden}.initiative-tracker__remove-btn{cursor:pointer;color:var(--text);opacity:.5;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:2px 4px;font-size:11px;transition:opacity .15s}.initiative-tracker__remove-btn:hover{opacity:1;color:#ef4444}.initiative-tracker__add-form{gap:6px;margin-top:4px;display:flex}.initiative-tracker__name-input{border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:6px;flex:1;min-width:0;padding:5px 8px;font-size:13px}.initiative-tracker__name-input:focus{border-color:var(--accent-border);outline:none}.initiative-tracker__init-input{border:1px solid var(--border);background:var(--bg);width:54px;color:var(--text-h);text-align:center;border-radius:6px;padding:5px 6px;font-size:13px}.initiative-tracker__init-input:focus{border-color:var(--accent-border);outline:none}.initiative-tracker__add-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;flex-shrink:0;padding:5px 12px;font-size:13px;font-weight:600;transition:opacity .15s}.initiative-tracker__add-btn:hover:not(:disabled){opacity:.85}.initiative-tracker__add-btn:disabled{opacity:.4;cursor:default}.hp-tracker{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding-top:16px;display:flex}.hp-tracker__header{justify-content:space-between;align-items:center;display:flex}.hp-tracker__title{letter-spacing:.5px;text-transform:uppercase;color:var(--text);font-size:12px;font-weight:700}.hp-tracker__clear-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:3px 8px;font-size:12px;transition:opacity .15s}.hp-tracker__clear-btn:hover{opacity:.7}.hp-tracker__empty{color:var(--text);margin:0;font-size:13px}.hp-tracker__list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.hp-tracker__entry{border:1px solid var(--border);background:var(--bg);border-radius:8px;flex-direction:column;gap:5px;padding:8px 10px;transition:border-color .15s;display:flex}.hp-tracker__entry--downed{opacity:.7;border-color:#ef4444}.hp-tracker__entry-top{align-items:center;gap:8px;display:flex}.hp-tracker__name{color:var(--text-h);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:600;overflow:hidden}.hp-tracker__hp-display{flex-shrink:0}.hp-tracker__hp-text{color:var(--text-h);font-variant-numeric:tabular-nums;border-radius:4px;padding:1px 4px;font-size:14px;font-weight:700}.hp-tracker__hp-text--editable{cursor:pointer}.hp-tracker__hp-text--editable:hover{background:var(--accent-bg);color:var(--accent)}.hp-tracker__edit-group{align-items:center;gap:3px;display:flex}.hp-tracker__edit-input{text-align:center;border:1px solid var(--accent-border);background:var(--bg);width:46px;color:var(--text-h);border-radius:4px;padding:2px 4px;font-size:13px;font-weight:700}.hp-tracker__edit-sep{color:var(--text);font-size:13px}.hp-tracker__remove-btn{cursor:pointer;color:var(--text);opacity:.5;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:2px 4px;font-size:11px;transition:opacity .15s}.hp-tracker__remove-btn:hover{opacity:1;color:#ef4444}.hp-bar{background:var(--border);border-radius:99px;height:5px;overflow:hidden}.hp-bar__fill{background:#22c55e;border-radius:99px;height:100%;transition:width .3s,background .3s}.hp-bar__fill--low{background:#f97316}.hp-bar__fill--critical{background:#ef4444}.hp-tracker__controls{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.hp-tracker__adjust-input{text-align:center;border:1px solid var(--border);background:var(--bg);width:52px;color:var(--text-h);border-radius:6px;padding:3px 5px;font-size:13px}.hp-tracker__adjust-input:focus{border-color:var(--accent-border);outline:none}.hp-tracker__heal-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:6px;padding:3px 8px;font-size:12px;font-weight:600;transition:opacity .15s}.hp-tracker__heal-btn:hover{opacity:.85}.hp-tracker__dmg-btn{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:6px;padding:3px 8px;font-size:12px;font-weight:600;transition:opacity .15s}.hp-tracker__dmg-btn:hover{opacity:.85}.hp-tracker__cond-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;margin-left:auto;padding:3px 7px;font-size:13px;transition:opacity .15s}.hp-tracker__cond-btn:hover{opacity:.7}.hp-tracker__condition-picker{flex-wrap:wrap;gap:4px;padding:6px 0 2px;display:flex}.hp-tracker__cond-tag{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:99px;padding:2px 8px;font-size:11px;transition:background .15s,color .15s}.hp-tracker__cond-tag--active{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent)}.hp-tracker__conditions{flex-wrap:wrap;gap:4px;display:flex}.hp-tracker__condition-badge{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border);border-radius:99px;align-items:center;gap:3px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-flex}.hp-tracker__condition-remove{cursor:pointer;color:var(--accent);opacity:.7;background:0 0;border:none;padding:0;font-size:13px;line-height:1;transition:opacity .15s}.hp-tracker__condition-remove:hover{opacity:1}.hp-tracker__add-form{gap:6px;margin-top:4px;display:flex}.hp-tracker__name-input{border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:6px;flex:1;min-width:0;padding:5px 8px;font-size:13px}.hp-tracker__name-input:focus{border-color:var(--accent-border);outline:none}.hp-tracker__maxhp-input{border:1px solid var(--border);background:var(--bg);width:70px;color:var(--text-h);text-align:center;border-radius:6px;padding:5px 6px;font-size:13px}.hp-tracker__maxhp-input:focus{border-color:var(--accent-border);outline:none}.hp-tracker__add-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;flex-shrink:0;padding:5px 12px;font-size:13px;font-weight:600;transition:opacity .15s}.hp-tracker__add-btn:hover:not(:disabled){opacity:.85}.hp-tracker__add-btn:disabled{opacity:.4;cursor:default}@media (width<=480px){.onboarding__card{padding:28px 20px}.lobby{padding:20px 14px}.session-room__header{padding:10px 14px}.session-room__you{display:none}.session-card{flex-wrap:wrap}.session-card__actions{justify-content:flex-end;width:100%;margin-top:4px}.dice-btn{padding:10px 6px;font-size:14px}.log-entry__time{display:none}}
