*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0e0d0b;--surface: #181510;--border: #50463d;--text: #e8e0d0;--muted: #b8b3af;--accent: #c8a96e;--surface-panel: rgba(14,13,11,.97);--surface-overlay: rgba(14,13,11,.6);--surface-btn: rgba(14,13,11,.55);--surface-topbar: rgba(14,13,11,.95);--text-secondary: #b0a898;--border-secondary: #807971}[data-theme=light]{--bg: #f5f0e8;--surface: #ece7de;--border: #ccc5b8;--text: #2a2520;--muted: #8a7d72;--accent: #8a6028;--surface-panel: rgba(245,240,232,.97);--surface-overlay: rgba(245,240,232,.75);--surface-btn: rgba(245,240,232,.75);--surface-topbar: rgba(245,240,232,.95);--text-secondary: #7a7060;--border-secondary: #b0a898}body{background:var(--bg);color:var(--text);font-family:Space Mono,monospace;overflow:hidden;height:100vh;width:100vw;-webkit-user-select:none;user-select:none}#canvas-container{position:fixed;top:0;right:0;bottom:0;left:0}canvas{display:block}#topbar{position:fixed;top:0;left:0;right:0;height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:linear-gradient(to bottom,var(--surface-topbar),transparent);z-index:25;pointer-events:none}#title{font-family:Bebas Neue,sans-serif;font-size:28px;letter-spacing:4px;color:var(--accent)}#menu-btn{pointer-events:all;background:transparent;border:1px solid var(--border);color:var(--muted);font-size:18px;width:36px;height:36px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;margin-left:8px}#menu-btn:hover{border-color:var(--accent);color:var(--accent)}#topbar-right{display:flex;align-items:center;pointer-events:all}#menu-panel{position:fixed;top:56px;right:20px;z-index:50;background:var(--surface-panel);border:1px solid var(--border);min-width:210px;display:none}#menu-panel.open{display:block}.menu-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;transition:background .15s;font-family:Space Mono,monospace;font-size:11px;color:var(--muted);letter-spacing:1px;-webkit-user-select:none;user-select:none}.menu-item:hover{background:#8080800f;color:var(--text)}.menu-item-label{pointer-events:none}.menu-toggle{position:relative;width:36px;height:20px;pointer-events:none;flex-shrink:0}.menu-toggle input{opacity:0;width:0;height:0}.menu-toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:10px;transition:background .2s}.menu-toggle input:checked+.menu-toggle-track{background:var(--accent)}.menu-toggle-thumb{position:absolute;width:14px;height:14px;top:3px;left:3px;background:var(--text);border-radius:50%;transition:transform .2s}.menu-toggle input:checked~.menu-toggle-thumb{transform:translate(16px)}#above-drawer{position:fixed;bottom:calc(var(--drawer-height, 185px) + 10px);left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:14;pointer-events:none;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .3s}#above-drawer.hidden{transform:translateY(100vh);opacity:0;pointer-events:none}#summary{display:flex;flex-direction:column;align-items:center;gap:4px;max-width:90vw;transition:opacity .3s;pointer-events:all}.summary-buttons{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px}.action-hint{font-family:Space Mono,monospace;font-size:11px;letter-spacing:2px;color:var(--muted);pointer-events:none;text-align:center}#select-hint{font-family:Space Mono,monospace;font-size:13px;letter-spacing:3px;color:var(--muted);text-transform:lowercase;pointer-events:none}.summary-die-btn{font-family:Space Mono,monospace;font-size:13px;letter-spacing:1px;background:transparent;border:1.5px solid currentColor;padding:3px 10px;cursor:pointer;border-radius:3px;transition:background .15s,opacity .15s;opacity:.85;line-height:1.3}.summary-die-btn:hover{opacity:1;filter:brightness(1.2)}.summary-die-btn:active{opacity:.6}.summary-plus{font-family:Bebas Neue,sans-serif;font-size:16px;color:var(--muted);pointer-events:none;line-height:1}#tray-3d-container{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;max-width:90vw;transition:opacity .3s;pointer-events:none}.tray-die-wrap{width:58px;height:58px;position:relative;pointer-events:all;cursor:pointer;transition:transform .15s;flex-shrink:0}.tray-die-wrap:hover{transform:scale(1.15) translateY(-4px)}.tray-die-canvas{width:58px;height:58px;border-radius:4px;display:block}.tray-collapse-label{position:absolute;top:-5px;right:-6px;background:var(--accent);color:var(--bg);font-family:Bebas Neue,sans-serif;font-size:13px;padding:0 4px;border-radius:3px;pointer-events:none;z-index:1;line-height:18px}#results-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:20;pointer-events:none;opacity:0;transition:opacity .5s;background:radial-gradient(ellipse at center,var(--surface-overlay) 0%,transparent 70%)}#results-overlay.visible{opacity:1;pointer-events:all}#results-equation{font-family:Space Mono,monospace;font-size:16px;color:var(--text);letter-spacing:1px;margin-bottom:8px;text-align:center;max-width:80vw;line-height:1.8;word-break:break-word;text-shadow:0 1px 4px rgba(0,0,0,.3)}#results-total{font-family:Bebas Neue,sans-serif;font-size:100px;color:var(--accent);line-height:1;letter-spacing:4px}#results-detail{font-family:Space Mono,monospace;font-size:13px;color:var(--text-secondary);letter-spacing:2px;margin-top:6px}#roll-again-btn{margin-top:32px;border:1px solid var(--accent);color:var(--accent);font-family:Bebas Neue,sans-serif;font-size:18px;letter-spacing:4px;padding:10px 32px;cursor:pointer;transition:all .2s;background:var(--surface-btn);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}#roll-again-btn:hover{background:var(--accent);color:var(--bg)}#result-action-row{display:flex;gap:10px;margin-top:20px}.result-action-btn{display:flex;flex-direction:column;align-items:center;gap:5px;border:1px solid var(--border-secondary);color:var(--text);padding:10px 18px;cursor:pointer;transition:all .2s;background:var(--surface-btn);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-family:Bebas Neue,sans-serif;font-size:11px;letter-spacing:2px;min-width:64px}.result-action-btn:hover{border-color:var(--text)}#drawer{position:fixed;bottom:0;left:0;right:0;background:var(--surface-panel);border-top:1px solid var(--border);z-index:15;transition:transform .4s cubic-bezier(.16,1,.3,1)}#drawer.hidden{transform:translateY(100vh)}#drawer-inner{padding:14px 20px 26px}.action-hint{display:block;margin-bottom:10px}#drawer-dice-row{display:flex;gap:8px;justify-content:center;margin-bottom:14px;flex-wrap:wrap}.dice-card{display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .15s;position:relative}.dice-card:hover{transform:translateY(-3px)}.dice-card:active{transform:scale(.95)}.dice-canvas-wrap{width:66px;height:66px;position:relative}.dice-mini-canvas{width:66px;height:66px;border-radius:4px;display:block}.dice-count-badge{position:absolute;top:-6px;right:-6px;background:var(--accent);color:var(--bg);font-family:Bebas Neue,sans-serif;font-size:13px;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,transform .2s;transform:scale(.5)}.dice-count-badge.visible{opacity:1;transform:scale(1)}.dice-label{font-family:Space Mono,monospace;font-size:12px;letter-spacing:1px;color:var(--muted);margin-top:3px;transition:color .2s}.dice-card:hover .dice-label{color:var(--text)}.drawer-shared-canvas{position:absolute;top:0;left:0;pointer-events:none;border-radius:4px}#roll-btn{display:block;width:100%;background:var(--accent);color:var(--bg);border:none;font-family:Bebas Neue,sans-serif;font-size:24px;letter-spacing:6px;padding:14px;cursor:pointer;transition:opacity .2s,transform .1s;border-radius:8px}#roll-btn:hover{opacity:.9}#roll-btn:active{transform:scale(.99)}#roll-btn:disabled{opacity:.3;cursor:not-allowed}#history-panel{position:fixed;top:0;right:0;width:320px;height:100vh;background:var(--surface-panel);border-left:1px solid var(--border);z-index:30;transform:translate(100%);transition:transform .35s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column}#history-panel.open{transform:translate(0)}#history-header{padding:20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}#history-title{font-family:Bebas Neue,sans-serif;font-size:20px;letter-spacing:3px;color:var(--accent)}#history-close{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;padding:4px 8px}#history-close:hover{color:var(--text)}#history-list{flex:1;overflow-y:auto;padding:12px}#history-list::-webkit-scrollbar{width:4px}#history-list::-webkit-scrollbar-thumb{background:var(--border)}.history-item{border:1px solid var(--border);border-radius:2px;padding:12px 14px;margin-bottom:8px;transition:border-color .2s}.history-item:hover{border-color:var(--accent)}.history-item-setup{font-family:Space Mono,monospace;font-size:12px;letter-spacing:1px;color:var(--text);margin-bottom:4px}.history-item-result{font-family:Space Mono,monospace;font-size:10px;color:var(--muted);line-height:1.6}.history-item-total{font-family:Bebas Neue,sans-serif;font-size:20px;color:var(--accent);float:right}.history-btn-row{display:flex;gap:6px;margin-top:8px}.history-roll-again{flex:1;display:block;border:1px solid var(--border-secondary);color:var(--text-secondary);font-family:Space Mono,monospace;font-size:10px;letter-spacing:2px;padding:6px;cursor:pointer;transition:all .2s;background:var(--surface-btn);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.history-roll-again:hover{border-color:var(--accent);color:var(--accent)}.history-edit-btn,.history-share-btn,.history-copy-btn{display:flex;align-items:center;justify-content:center;flex:0 0 auto;padding:6px 10px;border:1px solid var(--border-secondary);color:var(--text-secondary);cursor:pointer;transition:all .2s;background:var(--surface-btn);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.history-edit-btn:hover{border-color:var(--accent);color:var(--accent)}.history-share-btn:hover,.history-copy-btn:hover{border-color:var(--border);color:var(--text)}.history-delete-btn{display:flex;align-items:center;justify-content:center;flex:0 0 auto;padding:6px 10px;border:1px solid #7a3030;color:#c06060;cursor:pointer;transition:all .2s;background:var(--surface-btn);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.history-delete-btn:hover{border-color:#c06060;color:#e08080}#history-footer{padding:12px;border-top:1px solid var(--border);flex-shrink:0}#history-clear-btn{display:block;width:100%;border:1px solid #7a3030;color:#c06060;font-family:Space Mono,monospace;font-size:11px;letter-spacing:2px;padding:10px;cursor:pointer;transition:all .2s;background:var(--surface-btn);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}#history-clear-btn:hover{border-color:#c06060;color:#e08080}@media (min-width: 640px){#drawer{left:50%;right:auto;width:375px;transform:translate(-50%);border-radius:12px;border-top:none;border:1px solid var(--border);box-shadow:0 4px 40px #00000080;bottom:16px}#drawer.hidden{transform:translate(-50%) translateY(200%)}#above-drawer{left:50%;right:auto;transform:translate(-50%);width:375px;bottom:calc(var(--drawer-height, 185px) + 26px);align-items:stretch}#above-drawer.hidden{transform:translate(-50%) translateY(100vh)}#tray-3d-container{max-width:375px;justify-content:center}#summary{max-width:375px}}@media (min-width: 640px) and (min-height: 600px){#drawer{bottom:calc((100vh - var(--drawer-height, 185px) - 26px - var(--above-drawer-height, 120px)) / 2)}#above-drawer{bottom:calc((100vh - var(--drawer-height, 185px) - 26px - var(--above-drawer-height, 120px)) / 2 + var(--drawer-height, 185px) + 26px)}}
