:root{--dr-primary:#6366f1;--dr-primary-light:#818cf8;--dr-primary-dark:#4f46e5;--dr-primary-glow:#6366f166;--dr-primary-bg:#6366f114;--dr-gradient-primary:linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--dr-gradient-surface:linear-gradient(135deg, #fffc 0%, #fff6 100%);--dr-bg:#fff;--dr-bg-secondary:#f8fafc;--dr-bg-tertiary:#f1f5f9;--dr-bg-glass:#ffffffb3;--dr-bg-input:#fff;--dr-text:#0f172a;--dr-text-secondary:#475569;--dr-text-muted:#64748b;--dr-text-placeholder:#94a3b8;--dr-border:#e2e8f0;--dr-border-light:#f1f5f9;--dr-glass-border:#ffffff80;--dr-shadow-sm:0 1px 2px #0000000a;--dr-shadow:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--dr-shadow-md:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a;--dr-shadow-lg:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--dr-shadow-focus:0 0 0 4px #6366f126;--dr-success:#10b981;--dr-success-bg:#10b9811a;--dr-critical:#f59e0b;--dr-critical-bg:#f59e0b1a;--dr-fail:#ef4444;--dr-fail-bg:#ef444414;--dr-radius:1.25rem;--dr-radius-md:.875rem;--dr-radius-sm:.625rem;--dr-radius-xs:.5rem}._dr-container{flex-direction:column;gap:1.5rem;width:100%;max-width:620px;margin:1.5rem auto;display:flex}@media (max-width:768px){._dr-container{gap:1.25rem;margin:1rem auto;padding:0 1rem}}._dr-selector-section{background:var(--dr-bg-glass);-webkit-backdrop-filter:blur(12px);border-radius:var(--dr-radius);border:1px solid var(--dr-glass-border);box-shadow:var(--dr-shadow-md);z-index:10;flex-direction:column;gap:1.25rem;padding:1.75rem;display:flex;position:relative}._dr-dice-types{scrollbar-width:none;-webkit-overflow-scrolling:touch;align-items:center;gap:.375rem;padding:2px 0;display:flex;overflow:auto hidden}._dr-dice-types::-webkit-scrollbar{display:none}._dr-dice-btn{background:var(--dr-bg);height:2.25rem;color:var(--dr-text-secondary);border:1px solid var(--dr-border);border-radius:var(--dr-radius-sm);font-size:.8125rem;font-weight:700;font-family:var(--main-font-mono);cursor:pointer;white-space:nowrap;box-shadow:var(--dr-shadow-sm);flex-shrink:0;justify-content:center;align-items:center;gap:.25rem;padding:0 .625rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}._dr-dice-btn:before{content:"";opacity:.35;background:currentColor;border-radius:1px;flex-shrink:0;width:10px;height:10px;transition:opacity .2s;display:inline-block}._dr-dice-btn._dr-dice-active:before{opacity:.9}._dr-dice-btn[data-faces="4"]:before{clip-path:polygon(50% 0%,0% 100%,100% 100%);border-radius:0}._dr-dice-btn[data-faces="6"]:before{border-radius:2px}._dr-dice-btn[data-faces="8"]:before{clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);border-radius:0}._dr-dice-btn[data-faces="10"]:before{clip-path:polygon(50% 0%,100% 40%,70% 100%,30% 100%,0% 40%);border-radius:0}._dr-dice-btn[data-faces="12"]:before{clip-path:polygon(50% 0%,100% 38%,82% 100%,18% 100%,0% 38%);border-radius:0}._dr-dice-btn[data-faces="20"]:before{clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);border-radius:0}._dr-dice-btn[data-faces="100"]:before{border-radius:50%}._dr-dice-btn:hover{color:var(--dr-primary);border-color:var(--dr-primary-light);background:var(--dr-primary-bg);box-shadow:0 4px 6px -1px #6366f11a}._dr-dice-btn._dr-dice-active{color:#fff;background:var(--dr-gradient-primary);box-shadow:0 4px 12px var(--dr-primary-glow);border-color:#0000}._dr-custom-wrap{background:var(--dr-bg);border:1px solid var(--dr-border);border-radius:var(--dr-radius-sm);height:2.25rem;box-shadow:var(--dr-shadow-sm);flex-shrink:0;align-items:center;transition:all .2s;display:flex;overflow:hidden}._dr-custom-wrap:focus-within{border-color:var(--dr-primary);box-shadow:var(--dr-shadow-focus)}._dr-custom-label{font-size:.8125rem;font-weight:700;font-family:var(--main-font-mono);color:var(--dr-text-muted);padding-left:.625rem}._dr-custom-input{width:3.25rem;height:100%;font-size:.8125rem;font-weight:700;font-family:var(--main-font-mono);color:var(--dr-text);text-align:center;background:0 0;border:none;padding:0 .5rem}._dr-custom-input:focus{outline:none}._dr-custom-input::placeholder{color:var(--dr-text-placeholder)}._dr-controls-row{align-items:center;gap:1.5rem;padding-top:.25rem;display:flex}._dr-control-field{flex-direction:row;align-items:center;gap:.75rem;display:flex}._dr-control-label{color:var(--dr-text-secondary);white-space:nowrap;font-size:.8125rem;font-weight:600}._dr-control-sound{margin-left:auto}._dr-stepper{background:var(--dr-bg);border:1px solid var(--dr-border);border-radius:var(--dr-radius-sm);height:2.25rem;box-shadow:var(--dr-shadow-sm);align-items:center;display:flex;overflow:hidden}._dr-stepper-btn{width:2.25rem;height:100%;color:var(--dr-text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}._dr-stepper-btn:hover{color:var(--dr-primary);background:var(--dr-primary-bg)}._dr-stepper-btn svg{width:12px;height:12px}._dr-stepper-input{border:none;border-left:1px solid var(--dr-border);border-right:1px solid var(--dr-border);width:2.75rem;height:100%;font-size:.9375rem;font-weight:700;font-family:var(--main-font-mono);color:var(--dr-text);text-align:center;background:0 0;padding:0}._dr-stepper-input:focus{outline:none}._dr-advanced-section{border-top:1px solid var(--dr-border);padding-top:.5rem}._dr-advanced-toggle{width:100%;color:var(--dr-text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:.75rem 0;font-size:.8125rem;font-weight:600;transition:color .2s;display:flex}._dr-advanced-toggle:hover{color:var(--dr-text-secondary)}._dr-advanced-toggle svg{width:14px;height:14px}._dr-advanced-chevron{margin-left:auto;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex}._dr-advanced-toggle.active ._dr-advanced-chevron{transform:rotate(180deg)}._dr-advanced-panel{flex-direction:column;gap:1rem;padding-bottom:.5rem;display:none}._dr-advanced-panel.active{display:flex}._dr-advanced-item{justify-content:space-between;align-items:center;gap:1rem;display:flex}._dr-advanced-label{color:var(--dr-text-secondary);white-space:nowrap;font-size:.8125rem;font-weight:500}._dr-autoroll-wrap{align-items:center;gap:.75rem;display:flex}._dr-autoroll-seconds{background:var(--dr-bg);border:1px solid var(--dr-border);border-radius:var(--dr-radius-xs);height:2.25rem;box-shadow:var(--dr-shadow-sm);align-items:center;gap:.375rem;display:flex;overflow:hidden}._dr-autoroll-input{width:2.75rem;height:100%;font-size:.875rem;font-weight:700;font-family:var(--main-font-mono);color:var(--dr-text);text-align:center;background:0 0;border:none;padding:0 .25rem}._dr-autoroll-input:focus{outline:none}._dr-autoroll-unit{color:var(--dr-text-muted);padding-right:.625rem;font-size:.75rem;font-weight:600}._dr-modifier-wrap{background:var(--dr-bg);border:1px solid var(--dr-border);border-radius:var(--dr-radius-sm);height:2.75rem;box-shadow:var(--dr-shadow-sm);align-items:center;display:flex;overflow:hidden}._dr-mod-sign{background:var(--dr-bg-secondary);border:none;border-right:1px solid var(--dr-border);width:2.5rem;height:100%;font-size:1.125rem;font-weight:700;font-family:var(--main-font-mono);color:var(--dr-text-secondary);cursor:pointer;justify-content:center;align-items:center;transition:all .2s;display:flex}._dr-mod-sign:hover{color:var(--dr-primary);background:var(--dr-primary-bg)}._dr-modifier-input{width:3.5rem;height:100%;font-size:1rem;font-weight:700;font-family:var(--main-font-mono);color:var(--dr-text);text-align:center;background:0 0;border:none;padding:0 .5rem}._dr-modifier-input:focus{outline:none}._dr-switch{flex-shrink:0;width:2.75rem;height:1.5rem;display:inline-block;position:relative}._dr-switch input{opacity:0;width:0;height:0}._dr-switch-slider{cursor:pointer;background:var(--dr-border);border-radius:1rem;transition:background .3s;position:absolute;top:0;bottom:0;left:0;right:0}._dr-switch-slider:before{content:"";width:1.125rem;height:1.125rem;box-shadow:var(--dr-shadow-sm);background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);position:absolute;bottom:.1875rem;left:.1875rem}._dr-switch input:checked+._dr-switch-slider{background:var(--dr-primary)}._dr-switch input:checked+._dr-switch-slider:before{transform:translate(1.25rem)}._dr-roll-row{align-items:stretch;gap:.75rem;display:flex}._dr-roll-btn{background:var(--dr-gradient-primary);color:#fff;border-radius:var(--dr-radius-md);cursor:pointer;border:none;flex:1;justify-content:center;align-items:center;gap:.75rem;height:3.5rem;padding:0 2rem;font-size:1.25rem;font-weight:700;transition:all .3s;display:flex;box-shadow:0 8px 16px -4px #6366f166}._dr-roll-btn:hover{filter:brightness(1.05);box-shadow:0 12px 20px -4px #6366f180}._dr-roll-btn:active{filter:brightness(.95);box-shadow:0 4px 8px -2px #6366f166}._dr-roll-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;filter:grayscale(.5)}._dr-roll-btn svg{width:24px;height:24px}._dr-roll-btn:focus-visible{outline:2px solid var(--dr-primary);outline-offset:2px}._dr-adv-buttons{flex-direction:column;gap:.375rem;display:none}._dr-adv-buttons.active{display:flex}._dr-adv-btn{background:var(--dr-success-bg);height:1.5625rem;color:var(--dr-success);border-radius:var(--dr-radius-xs);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.375rem;padding:0 .875rem;font-size:.75rem;font-weight:700;transition:background .2s,color .2s;display:flex}._dr-adv-btn:hover{background:var(--dr-success);color:#fff}._dr-adv-btn svg{width:12px;height:12px}._dr-dis-btn{background:var(--dr-fail-bg);color:var(--dr-fail)}._dr-dis-btn:hover{background:var(--dr-fail);color:#fff}@media (max-width:480px){._dr-selector-section{gap:1rem;padding:1.25rem}._dr-dice-btn{height:2.5rem;padding:0 .75rem;font-size:.8125rem}._dr-controls-row{flex-wrap:wrap;gap:1rem}._dr-roll-btn{height:3.25rem;font-size:1.125rem}}@keyframes dr-rolling{0%,to{opacity:.5}25%{opacity:.8}50%{opacity:.4}75%{opacity:.7}}@keyframes dr-bounce-in{0%{opacity:0;transform:scale(.6)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes dr-critical-pulse{0%,to{filter:drop-shadow(0 0 #f59e0b00)}50%{filter:drop-shadow(0 0 12px #f59e0b80)}}@keyframes dr-fail-pulse{0%,to{filter:drop-shadow(0 0 #ef444400)}50%{filter:drop-shadow(0 0 12px #ef444466)}}@keyframes dr-total-pop{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}._dr-result-section{background:var(--dr-bg-glass);-webkit-backdrop-filter:blur(12px);border-radius:var(--dr-radius);border:1px solid var(--dr-glass-border);box-shadow:var(--dr-shadow-md);flex-direction:column;align-items:center;gap:1rem;min-height:160px;padding:2.5rem 1.5rem;display:flex;position:relative;overflow:hidden}._dr-result-section:before{content:"";background:radial-gradient(circle, var(--dr-primary-bg) 0%, transparent 70%);opacity:.5;pointer-events:none;z-index:0;width:60%;height:60%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}._dr-result-dice{z-index:1;flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;width:100%;min-height:3.5rem;max-height:280px;padding:.5rem;display:flex;position:relative;overflow-y:auto}._dr-result-total{z-index:1;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;min-height:4rem;display:flex;position:relative}._dr-result-total:empty:after{content:"—";color:var(--dr-text-placeholder);opacity:.3;font-size:2rem;font-weight:700}._dr-result-total.active{animation:.4s cubic-bezier(.175,.885,.32,1.275) forwards dr-total-pop}._dr-result-total-value{font-size:3.5rem;font-weight:900;font-family:var(--main-font-mono);background:var(--dr-gradient-primary);-webkit-text-fill-color:transparent;letter-spacing:-.04em;filter:drop-shadow(0 2px 4px #6366f133);-webkit-background-clip:text;background-clip:text;line-height:1}._dr-tai-xiu{text-transform:uppercase;letter-spacing:.12em;box-shadow:var(--dr-shadow-sm);border-radius:2rem;align-items:center;gap:.625rem;padding:.375rem 1.25rem;font-size:.8125rem;font-weight:800;display:inline-flex}._dr-tai-xiu:before,._dr-tai-xiu:after{content:"";opacity:.25;background:currentColor;width:1.5rem;height:1.5px}._dr-tx-tai{color:#ef4444;background:#fee2e2}._dr-tx-xiu{color:#3b82f6;background:#dbeafe}._dr-tx-triple{color:#d97706;background:#fef3c7}._dr-tx-tie{background:var(--dr-primary-bg);color:var(--dr-primary)}._dr-result-notation{z-index:1;font-size:.875rem;font-weight:600;font-family:var(--main-font-mono);color:var(--dr-text-muted);text-align:center;word-break:break-all;letter-spacing:.02em;opacity:.8;min-height:1.25rem;position:relative}._dr-result-notation:empty:after{content:"···";color:var(--dr-text-placeholder);letter-spacing:.2em;opacity:.4}@media (max-width:480px){._dr-result-section{min-height:140px;padding:2rem 1.25rem}._dr-result-total-value{font-size:2.75rem}._dr-tai-xiu{padding:.25rem 1rem;font-size:.75rem}}._dr-die-3d{--cube-size:56px;--cube-half:calc(var(--cube-size) / 2);width:var(--cube-size);height:var(--cube-size);perspective:250px;opacity:0;animation:.3s ease-out forwards dr-3d-appear;position:relative}@keyframes dr-3d-appear{0%{opacity:0;scale:.6}to{opacity:1;scale:1}}._dr-die-3d:after{content:"";pointer-events:none;background:radial-gradient(#0000001f 0%,#0000 70%);border-radius:50%;height:6px;position:absolute;bottom:-6px;left:12%;right:12%}._dr-die-cube{width:100%;height:100%;transform-style:preserve-3d;transition:transform 1.3s cubic-bezier(.12,.75,.2,1.01);position:relative}._dr-die-face{width:var(--cube-size);height:var(--cube-size);-webkit-backface-visibility:hidden;backface-visibility:hidden;background:linear-gradient(145deg,#fff 0%,#f1f5f9 100%);border:1.5px solid #cbd5e1;border-radius:20%;grid-template:repeat(3,1fr)/repeat(3,1fr);padding:16%;display:grid;position:absolute;box-shadow:inset 0 2px 4px #fffc,inset 0 -2px 4px #0000000d,0 4px 6px -1px #0000001a}._dr-face-1{transform:rotateY(0deg) translateZ(var(--cube-half))}._dr-face-6{transform:rotateY(180deg) translateZ(var(--cube-half))}._dr-face-2{transform:rotateX(90deg) translateZ(var(--cube-half))}._dr-face-5{transform:rotateX(-90deg) translateZ(var(--cube-half))}._dr-face-3{transform:rotateY(90deg) translateZ(var(--cube-half))}._dr-face-4{transform:rotateY(-90deg) translateZ(var(--cube-half))}._dr-pip{background:radial-gradient(circle at 38% 38%,#374151 0%,#1e293b 100%);border-radius:50%;place-self:center;width:100%;max-width:80%;height:100%;max-height:80%;box-shadow:inset 0 1px 2px #0006,0 .5px #ffffff26}._dr-pip-1{grid-area:1/1}._dr-pip-2{grid-area:1/2}._dr-pip-3{grid-area:1/3}._dr-pip-4{grid-area:2/1}._dr-pip-5{grid-area:2/2}._dr-pip-6{grid-area:2/3}._dr-pip-7{grid-area:3/1}._dr-pip-8{grid-area:3/2}._dr-pip-9{grid-area:3/3}._dr-die-tile{opacity:0;background:linear-gradient(145deg,#fff 0%,#f1f5f9 100%);border:1.5px solid #cbd5e1;border-radius:20%;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;animation:.4s cubic-bezier(.175,.885,.32,1.275) forwards dr-3d-appear;display:inline-flex;box-shadow:inset 0 2px 4px #fffc,inset 0 -2px 4px #0000000d,0 4px 10px -2px #0000001a}._dr-die-tile-value{font-size:1.25rem;font-weight:800;font-family:var(--main-font-mono);color:#334155;line-height:1}._dr-die-tile-value._dr-tile-lg{font-size:1rem}._dr-die-tile._dr-tile-critical{animation:.3s ease-out forwards dr-3d-appear,1.5s ease-in-out .4s infinite dr-3d-crit-glow}._dr-die-tile._dr-tile-critical ._dr-die-tile-value{color:#b45309}._dr-die-tile._dr-tile-fail{animation:.3s ease-out forwards dr-3d-appear,1.5s ease-in-out .4s infinite dr-3d-fail-glow}._dr-die-tile._dr-tile-fail ._dr-die-tile-value{color:#dc2626}._dr-die-tile._dr-tile-dropped{opacity:.3;text-decoration:line-through}._dr-die-tile._dr-tile-idle{opacity:.4;background:var(--dr-bg-tertiary);animation:none}._dr-die-tile._dr-tile-idle ._dr-die-tile-value{color:var(--dr-text-placeholder)}._dr-die-tile.rolling{animation:.45s ease-in-out infinite dr-rolling}._dr-die-tile.rolling ._dr-die-tile-value{color:var(--dr-text-muted)}._dr-result-dice._dr-single-die ._dr-die-tile{width:5rem;height:5rem}._dr-result-dice._dr-single-die ._dr-die-tile-value{font-size:2rem}._dr-result-dice._dr-single-die ._dr-die-tile-value._dr-tile-lg{font-size:1.5rem}._dr-result-dice:has(._dr-die-tile){gap:.625rem;max-height:none;overflow:visible}._dr-result-dice:has(._dr-die-3d){gap:1rem;max-height:none;padding:.75rem .25rem 1rem;overflow:visible}._dr-die-3d._dr-die-3d-idle{opacity:.4;animation:none}._dr-die-3d._dr-die-3d-idle ._dr-die-face{background:var(--dr-bg-tertiary)}._dr-result-dice._dr-single-die ._dr-die-3d{--cube-size:84px}._dr-die-3d._dr-die-3d-critical{animation:.3s ease-out forwards dr-3d-appear,1.5s ease-in-out 1.4s infinite dr-3d-crit-glow}._dr-die-3d._dr-die-3d-fail{animation:.3s ease-out forwards dr-3d-appear,1.5s ease-in-out 1.4s infinite dr-3d-fail-glow}@keyframes dr-3d-crit-glow{0%,to{filter:drop-shadow(0 0 #f59e0b00)}50%{filter:drop-shadow(0 0 14px #f59e0b8c)}}@keyframes dr-3d-fail-glow{0%,to{filter:drop-shadow(0 0 #ef444400)}50%{filter:drop-shadow(0 0 14px #ef444473)}}._dr-die-3d._dr-die-3d-dropped{opacity:.3}@media (max-width:480px){._dr-die-3d{--cube-size:46px}._dr-result-dice._dr-single-die ._dr-die-3d{--cube-size:68px}._dr-die-face{padding:14%}._dr-die-tile{width:2.625rem;height:2.625rem}._dr-die-tile-value{font-size:1rem}._dr-die-tile-value._dr-tile-lg{font-size:.8125rem}._dr-result-dice._dr-single-die ._dr-die-tile{width:4rem;height:4rem}._dr-result-dice._dr-single-die ._dr-die-tile-value{font-size:1.625rem}}._dr-history-section{background:var(--dr-bg-glass);-webkit-backdrop-filter:blur(12px);border-radius:var(--dr-radius);border:1px solid var(--dr-glass-border);box-shadow:var(--dr-shadow);flex-direction:column;min-height:200px;display:flex;overflow:hidden}._dr-history-header{border-bottom:1px solid var(--dr-border-light);background:#ffffff4d;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}._dr-history-title{color:var(--dr-text-secondary);align-items:center;gap:.625rem;font-size:.875rem;font-weight:700;display:flex}._dr-history-title svg{width:16px;height:16px;color:var(--dr-primary);opacity:.8}._dr-history-actions-wrap{align-items:center;gap:.875rem;display:flex}._dr-stats-summary{font-size:.75rem;font-weight:600;font-family:var(--main-font-mono);color:var(--dr-text-muted)}._dr-history-clear{color:var(--dr-text-muted);cursor:pointer;border-radius:var(--dr-radius-sm);background:0 0;border:none;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:600;transition:all .2s;display:flex}._dr-history-clear:hover{color:#ef4444;background:#fee2e2}._dr-history-clear svg{width:14px;height:14px}._dr-history-list{max-height:300px;overflow-y:auto}._dr-history-item{border-bottom:1px solid var(--dr-border-light);cursor:pointer;align-items:center;gap:1rem;padding:.75rem 1.25rem;transition:background .2s;display:flex}._dr-history-item:last-child{border-bottom:none}._dr-history-item:hover{background:#fff6}._dr-history-time{color:var(--dr-text-placeholder);white-space:nowrap;font-size:.75rem;font-weight:600;font-family:var(--main-font-mono);flex-shrink:0}._dr-history-notation{font-size:.8125rem;font-weight:700;font-family:var(--main-font-mono);color:var(--dr-text-secondary);white-space:nowrap;flex-shrink:0}._dr-history-result{font-size:1rem;font-weight:800;font-family:var(--main-font-mono);color:var(--dr-primary);text-align:right;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}._dr-history-critical-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:1rem;flex-shrink:0;justify-content:center;align-items:center;padding:.125rem .5rem;font-size:.625rem;font-weight:800;display:inline-flex}._dr-history-crit{color:#d97706;background:#fef3c7}._dr-history-fail{color:#ef4444;background:#fee2e2}._dr-history-empty{text-align:center;color:var(--dr-text-placeholder);padding:2.5rem;font-size:.875rem}@media (max-width:480px){._dr-history-item{gap:.75rem;padding:.625rem 1rem}._dr-history-notation{font-size:.75rem}}
