:root{--ink-900: #152226;--ink-700: #2f474e;--surface-100: #f7f4ec;--surface-200: #ece6da;--panel: #fffdf8;--accent: #bc5e2c;--accent-strong: #944117;--line: #d7cebd;--strain-line: #721e1b;--shadow: 0 14px 30px rgba(37, 40, 26, .12);--focus-ring: #1d6f68;--button-text: #fffaf5;--input-bg: #fffffd;--skip-link-bg: #ffffff;--strain-surface-1: #edd3d3;--strain-surface-2: #e08d8b;--summary-surface: #fffdf8;--summary-item-row: #fff7e9;--summary-pill-bg: #fffaf2;--error-bg: #fff5f1;--warning-bg: #fffbe8;--spinner-border: rgba(47, 71, 78, .2);--spinner-border-top: rgba(47, 71, 78, .7);--shell-glow-a: #fffdf0;--shell-glow-b: #e3efe7;--tab-active-bg: #ffffff;--tab-active-shadow: 0 3px 8px rgba(22, 32, 28, .12)}:root[data-theme=dark]{--ink-900: #eff5f7;--ink-700: #b8c7ce;--surface-100: #0d1418;--surface-200: #172229;--panel: #1a252c;--accent: #e08a56;--accent-strong: #c06c3b;--line: #32444d;--strain-line: #ffc1b9;--shadow: 0 14px 30px rgba(0, 0, 0, .45);--focus-ring: #72d4cc;--button-text: #1a2329;--input-bg: #0f171c;--skip-link-bg: #223038;--strain-surface-1: #5e3436;--strain-surface-2: #874446;--summary-surface: #1d2b33;--summary-item-row: #25343c;--summary-pill-bg: #2c3d47;--error-bg: #45292c;--warning-bg: #4a3a24;--spinner-border: rgba(184, 199, 206, .22);--spinner-border-top: rgba(184, 199, 206, .78);--shell-glow-a: #1f2e36;--shell-glow-b: #21352f;--tab-active-bg: #2a3942;--tab-active-shadow: 0 3px 12px rgba(0, 0, 0, .4)}.app-shell{min-width:400px;min-height:100dvh;padding:clamp(.9rem,1.8vw,1.5rem);background:radial-gradient(circle at 15% 20%,var(--shell-glow-a) 0%,transparent 38%),radial-gradient(circle at 85% 88%,var(--shell-glow-b) 0%,transparent 42%),linear-gradient(140deg,var(--surface-100),var(--surface-200));color:var(--ink-900)}.dice-layout{position:relative;z-index:1;max-width:1040px;margin:0 auto}.skip-link{position:absolute;left:-999px;top:.75rem;padding:.5rem .75rem;background:var(--skip-link-bg);color:var(--ink-900);border:1px solid var(--line);border-radius:.5rem;box-shadow:var(--shadow);z-index:20}.skip-link:focus{left:.75rem}.top-bar{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.top-bar-actions{display:inline-flex;align-items:flex-start;gap:.8rem}.theme-select{display:grid;gap:.3rem;min-width:120px}.theme-select span{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-700);font-weight:600}.theme-select select{width:100%;border:1px solid var(--line);border-radius:.6rem;padding:.48rem .55rem;font:inherit;color:var(--ink-900);background:var(--input-bg)}.eyebrow{margin:0 0 .2rem;font-size:.73rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-700)}h1,h2{margin:0}h1{font-size:clamp(1.5rem,2.8vw,2rem)}h2{font-size:1.15rem}.strain-pill{display:grid;gap:.08rem;min-width:150px;padding:.65rem .8rem;border:1px solid var(--strain-line);border-radius:.75rem;background:linear-gradient(165deg,var(--strain-surface-1) 0%,var(--strain-surface-2) 100%);color:var(--strain-line)}.strain-pill-head{display:flex;align-items:center;justify-content:space-between;gap:.45rem}.strain-pill span{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em}.strain-reset-button{border:1px solid var(--strain-line);background:var(--summary-pill-bg);color:var(--strain-line);border-radius:.45rem;width:1.5rem;height:1.5rem;line-height:1;padding:0;cursor:pointer}.strain-reset-button:disabled{cursor:not-allowed;opacity:.5}.strain-pill strong{font-size:1.35rem}.content-grid{display:grid;grid-template-columns:1fr;grid-template-rows:auto minmax(340px,1fr);gap:1rem}.panel{background:var(--panel);border:1px solid var(--line);border-radius:1rem;padding:clamp(.9rem,1.8vw,1.2rem);box-shadow:var(--shadow)}.panel-copy{margin:.5rem 0 .8rem;color:var(--ink-700)}.controls-panel{padding:clamp(.85rem,1.5vw,1.05rem)}.panel-action-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;margin-top:.9rem}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.panel-reset-button{border:1px solid transparent;border-radius:.7rem;padding:.25rem 1rem;font:inherit;font-weight:700;color:var(--button-text);background:linear-gradient(160deg,var(--accent),var(--accent-strong));cursor:pointer}.control-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;align-items:end}.number-field{display:grid;gap:.4rem}.number-field span{font-weight:600}.number-field input{width:100%;border:1px solid var(--line);border-radius:.6rem;padding:.55rem .6rem;font:inherit;color:var(--ink-900);background:var(--input-bg)}.pool-action-button{border:1px solid transparent;border-radius:.7rem;padding:.55rem .95rem;font:inherit;font-weight:700;color:var(--button-text);background:linear-gradient(160deg,var(--accent),var(--accent-strong));cursor:pointer}.pool-action-button:disabled,.panel-reset-button:disabled{cursor:not-allowed;opacity:.58}.pool-action-button:focus-visible,.panel-reset-button:focus-visible,.number-field input:focus-visible,.strain-reset-button:focus-visible,.pool-tab:focus-visible,.theme-select select:focus-visible,.import-summary-item:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.pool-tabs{display:inline-flex;gap:.4rem;margin:.2rem 0 .9rem;padding:.3rem;border:1px solid var(--line);border-radius:.7rem;background:var(--surface-200)}.pool-tab{border:1px solid transparent;border-radius:.6rem;padding:.35rem .8rem;font:inherit;font-weight:600;color:var(--ink-700);background:transparent;cursor:pointer}.pool-tab.is-active{color:var(--ink-900);background:var(--tab-active-bg);border-color:var(--line);box-shadow:var(--tab-active-shadow)}.import-panel{display:grid;gap:.85rem}.import-controls{display:grid;grid-template-columns:minmax(180px,1.2fr) minmax(160px,1fr) minmax(160px,1fr);gap:.75rem;align-items:end}.import-status-row{display:flex;justify-content:space-between;gap:1rem;align-items:center}.import-clear-button{margin-left:auto;align-self:center}.import-summary{border:1px solid var(--line);border-radius:.75rem;padding:.75rem;background:var(--summary-surface)}.import-summary-content{display:grid;gap:.45rem;list-style:none;margin:0;padding:0}.import-summary-title{margin:0 0 .35rem;font-weight:600;color:var(--ink-900)}.import-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2rem;align-items:start}.import-summary-content li{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.25rem .5rem;border-radius:.5rem;background:var(--summary-item-row);color:var(--ink-700)}.import-summary-content li span{color:var(--ink-700);flex:1}.import-summary-item{display:inline-flex;align-items:center;justify-content:center;min-width:1.6rem;padding:.1rem .45rem;border:1px solid var(--line);border-radius:.5rem;background:var(--summary-pill-bg);color:var(--ink-900);font:inherit;font-weight:600;cursor:pointer}.import-summary-item:hover{border-color:var(--accent-strong);color:var(--ink-900)}.import-summary-item:focus-visible{border-radius:.5rem}.import-summary-item:disabled{opacity:.6;cursor:not-allowed;border-color:var(--line)}.import-summary-empty{margin:0;color:var(--ink-700)}.file-field,.select-field{display:grid;gap:.4rem}.file-field span,.select-field span{font-weight:600}.file-field input,.select-field select{width:100%;border:1px solid var(--line);border-radius:.6rem;padding:.55rem .6rem;font:inherit;color:var(--ink-900);background:var(--input-bg)}.import-status p{margin:0 0 .2rem;color:var(--ink-700)}.import-errors,.import-warnings{border:1px solid var(--line);border-radius:.6rem;padding:.6rem .75rem;background:var(--error-bg)}.import-warnings{background:var(--warning-bg)}.import-errors p,.import-warnings p{margin:0 0 .35rem;font-weight:600;color:var(--ink-900)}.import-errors ul,.import-warnings ul{margin:0;padding-left:1.1rem;color:var(--ink-700)}.import-selectors{display:grid;gap:.75rem}.import-character-name{margin:0 0 0 .75rem;color:var(--ink-900);font-size:1.5rem;font-weight:700}.secondary-action-button{white-space:nowrap}.dice-stage-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5;pointer-events:none!important}.dice-stage-fullscreen canvas{width:100%!important;height:100%!important;display:block;pointer-events:none!important}.dice-stage-fullscreen *{pointer-events:none!important}.tray-loading{display:grid;place-items:center;gap:.5rem;height:100%;color:var(--ink-700);font-weight:600}.tray-spinner{width:2.4rem;height:2.4rem;border-radius:50%;border:3px solid var(--spinner-border);border-top-color:var(--spinner-border-top);animation:tray-spin .9s linear infinite}@keyframes tray-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 760px){.top-bar{flex-direction:column}.top-bar-actions{width:100%;flex-direction:column}.theme-select,.strain-pill{width:100%}.control-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pool-action-button{grid-column:1 / -1}.import-controls{grid-template-columns:1fr}.import-controls .pool-action-button{width:100%}.import-status-row{flex-direction:column;align-items:stretch}.import-clear-button{align-self:flex-end}.import-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.panel-action-row{grid-template-columns:1fr}.secondary-action-button{width:100%}}@media (max-width: 550px){.app-shell{min-width:0}.import-controls,.import-summary-grid{grid-template-columns:1fr}.import-summary-section{grid-column:auto}.import-summary-section:nth-child(3){margin-top:-1.5rem}.import-summary-section:nth-child(3) .import-summary-title{display:none}.import-clear-button{width:100%;align-self:stretch}}.toast-viewport{position:fixed;right:1rem;bottom:1rem;display:flex;flex-direction:column;gap:.65rem;z-index:30;pointer-events:none}.toast-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:31;display:grid;place-items:center;padding:1rem;background:#00000059}.toast-confirm-viewport{width:min(30rem,100%);display:grid;gap:.65rem}.toast-item{pointer-events:auto;display:grid;gap:.5rem;padding:1rem 1.5rem;border:1px solid var(--line);border-radius:5px;background:var(--panel);color:var(--ink-900);box-shadow:var(--shadow);position:relative;overflow:hidden}.toast-item[data-kind=diceResult]{border-color:var(--accent)}.toast-title{font-weight:700;line-height:1.2}.toast-message,.toast-breakdown{color:var(--ink-700);line-height:1.35}.toast-result-text{color:var(--ink-900);font-size:1.5rem;font-weight:700;line-height:1.5;padding-bottom:.5rem}.toast-total{font-size:1.35rem;font-weight:800;color:var(--ink-900)}.toast-dismiss-button,.toast-confirm-cancel,.toast-confirm-accept{justify-self:end;border:1px solid var(--line);border-radius:.5rem;padding:.25rem .5rem;font:inherit;font-size:1rem;color:var(--ink-900);background:var(--surface-200);cursor:pointer}.toast-confirm-actions{display:inline-flex;justify-self:end;gap:.5rem}.toast-progress-bar{position:absolute;left:0;bottom:0;height:.3rem;width:0;background:var(--accent);animation-name:toast-progress-fill;animation-timing-function:linear;animation-fill-mode:forwards;pointer-events:none}@keyframes toast-progress-fill{0%{width:0%}to{width:100%}}.toast-confirm-accept{border-color:transparent;color:var(--button-text);background:linear-gradient(160deg,var(--accent),var(--accent-strong))}.toast-dismiss-button:focus-visible,.toast-confirm-cancel:focus-visible,.toast-confirm-accept:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}@media (max-width: 760px){.toast-viewport{left:1rem;right:1rem;max-width:none}.toast-item{width:100%}}:root{color-scheme:light;font-family:Avenir Next,Trebuchet MS,Segoe UI,sans-serif;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility}:root[data-theme=dark]{color-scheme:dark}:root[data-theme=light]{color-scheme:light}@media (prefers-color-scheme: dark){:root:not([data-theme]){color-scheme:dark}}*,*:before,*:after{box-sizing:border-box}body{margin:0}
