*{margin:0;padding:0;box-sizing:border-box}:root{--body-background: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);--canvas-background: radial-gradient(circle at center, #2a4d7c 0%, #1a2f4f 100%)}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--body-background);overflow:hidden;height:100vh;display:flex;flex-direction:column;transition:background .6s ease}#menuToggle{position:absolute;top:20px;left:20px;z-index:40;display:none;align-items:center;gap:10px;background:#000c;color:#fff;border:none;padding:12px 18px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 8px 20px #00000073;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}#menuToggle:hover,#menuToggle:focus-visible{background:#2554a3f2;transform:translateY(-2px);box-shadow:0 10px 24px #00000080}#menuToggle:active{transform:translateY(0);box-shadow:0 6px 14px #00000073}#menuToggle .icon{font-size:20px}#menuBackdrop{display:none}#container{position:relative;width:100%;height:100%;display:flex;flex-direction:row}#canvas-container{flex:1;position:relative;background:var(--canvas-background);transition:background .6s ease}canvas{display:block;width:100%;height:100%}#controls{background:#000c;padding:20px;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;gap:20px;min-width:250px;max-width:250px;height:100%;overflow-y:auto;overflow-x:hidden}.menu-footer{margin-top:auto;width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;box-sizing:border-box;max-width:100%;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}.menu-footer__button{background:transparent;background-image:none;border:none;box-shadow:none;padding:6px 10px;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:none;color:#fff9;border-radius:999px;cursor:pointer;transition:color .2s ease,background .2s ease,transform .2s ease,box-shadow .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;min-width:0}.menu-footer__button:hover,.menu-footer__button:focus-visible{color:#ffffffe6;background:#4a90e22e;box-shadow:0 4px 12px #4a90e240;transform:translateY(-1px);outline:none}.menu-footer__button:focus-visible{box-shadow:0 0 0 3px #4a90e266}.menu-footer__button:active{transform:translateY(0);background:#4a90e23d}.menu-footer__button-icon{font-size:14px;line-height:1}.menu-footer__button-label{letter-spacing:inherit}.menu-header{width:100%;display:flex;justify-content:center;align-items:center;padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}.menu-logo{width:min(160px,70%);height:auto;filter:drop-shadow(0 4px 10px rgba(0,0,0,.55))}button{background:linear-gradient(145deg,#4a90e2,#357abd);color:#fff;border:none;padding:15px 30px;font-size:18px;border-radius:8px;cursor:pointer;box-shadow:0 4px 6px #0000004d;transition:all .3s ease;font-weight:700}.roll-controls{width:100%;display:flex;justify-content:center;gap:12px}.control-button{padding:10px 18px;font-size:15px;border-radius:999px;box-shadow:0 3px 6px #00000047;text-transform:none;letter-spacing:.02em}.control-button--secondary{background:#ffffff29;color:#ffffffeb;box-shadow:none;border:1px solid rgba(255,255,255,.24)}.control-button--secondary:hover,.control-button--secondary:focus-visible{background:#ffffff38;color:#fff;box-shadow:0 5px 10px #00000059}button:hover{background:linear-gradient(145deg,#5aa0f2,#4580cd);transform:translateY(-2px);box-shadow:0 6px 8px #0006}button:active{transform:translateY(0);box-shadow:0 2px 4px #0000004d}.dice-button-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:16px;width:100%}.dice-button{background:#ffffff14;padding:0;border:none;border-radius:16px;overflow:hidden;width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 6px 14px #00000059;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.dice-button img{width:100%;height:100%;object-fit:contain;display:block;pointer-events:none}.dice-button:hover,.dice-button:focus-visible{background:#ffffff29;transform:translateY(-4px) scale(1.02);box-shadow:0 10px 22px #00000073}.dice-button:active{transform:translateY(0) scale(.98);box-shadow:0 4px 10px #0006}.dice-button:focus-visible{outline:3px solid rgba(74,144,226,.9);outline-offset:4px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.toggle-control{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px 18px;border-radius:8px;background:#ffffff14;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s ease,transform .2s ease}.toggle-control:hover,.toggle-control:focus-within{background:#ffffff29;transform:translateY(-1px)}.toggle-control input[type=checkbox]{width:20px;height:20px;accent-color:#4a90e2;cursor:pointer}body.fast-physics-enabled .settings-toggle{background:#4a90e259;box-shadow:0 6px 12px #00000059}body.fast-physics-enabled .menu-footer__button--settings{color:#fffffff2;background:#4a90e238;box-shadow:0 4px 14px #4a90e259}body.fast-physics-enabled .menu-footer__button--settings:hover,body.fast-physics-enabled .menu-footer__button--settings:focus-visible{background:#4a90e24d;box-shadow:0 6px 18px #4a90e266}.settings-modal-backdrop{position:fixed;inset:0;background:#0000008c;backdrop-filter:blur(3px);z-index:90}.settings-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(840px,92vw);max-height:92vh;border-radius:20px;background:#091220eb;color:#fff;box-shadow:0 40px 70px #0000008c;z-index:100}.settings-modal[hidden],.settings-modal-backdrop[hidden]{display:none}.settings-modal__content{display:flex;flex-direction:column;gap:16px;padding:26px;max-height:calc(92vh - 52px);overflow-y:auto}.settings-modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.settings-modal__header h2{font-size:24px;font-weight:700;letter-spacing:.02em}.settings-modal__close{border:none;background:#ffffff1f;color:#fff;border-radius:999px;width:36px;height:36px;font-size:18px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,transform .2s ease}.settings-modal__close:hover,.settings-modal__close:focus-visible{background:#fff3;transform:rotate(90deg)}.settings-modal__body{display:flex;flex-direction:column;gap:24px}.about-modal-backdrop{position:fixed;inset:0;background:#0000008c;backdrop-filter:blur(3px);z-index:95}.about-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(420px,92vw);border-radius:20px;background:#091220f0;color:#fff;box-shadow:0 40px 70px #0000008c;z-index:105}.about-modal[hidden],.about-modal-backdrop[hidden]{display:none}.about-modal__content{display:flex;flex-direction:column;gap:18px;padding:28px}.about-modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.about-modal__header h2{font-size:22px;font-weight:700;letter-spacing:.02em}.about-modal__close{border:none;background:#ffffff1f;color:#fff;border-radius:999px;width:36px;height:36px;font-size:18px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,transform .2s ease}.about-modal__close:hover,.about-modal__close:focus-visible{background:#fff3;transform:rotate(90deg)}.about-modal__body{display:flex;flex-direction:column;gap:16px;font-size:15px;line-height:1.6;color:#ffffffd1}.about-modal__body p{margin:0}.settings-section{display:flex;flex-direction:column;gap:14px;padding:18px;border-radius:16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.05);box-shadow:inset 0 1px #ffffff14}.settings-section h3{font-size:18px;font-weight:600}.settings-section__description{font-size:14px;line-height:1.5;color:#ffffffb3}.dice-settings-table-wrapper{border-radius:14px;overflow:hidden;overflow-x:auto;max-width:100%;border:1px solid rgba(255,255,255,.08);background:#070d1ab8;box-shadow:inset 0 1px #ffffff0a}.dice-settings-actions{display:flex;justify-content:flex-end;margin-top:12px}.dice-settings-reset-button{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fff;padding:10px 20px;border-radius:999px;font-size:14px;font-weight:600;text-transform:none;box-shadow:0 6px 16px #00000059;transition:background .2s ease,box-shadow .2s ease,transform .2s ease}.dice-settings-reset-button:hover,.dice-settings-reset-button:focus-visible{background:#4a90e240;box-shadow:0 8px 20px #4a90e259;transform:translateY(-1px);outline:none}.dice-settings-reset-button:active{transform:translateY(0);background:#4a90e252}.dice-settings-table{width:100%;border-collapse:collapse;min-width:100%}.dice-settings-table thead{background:#0c182ed9}.dice-settings-table th,.dice-settings-table td{padding:12px 14px;font-size:14px;color:#ffffffd9}.dice-settings-table th{text-align:left;font-weight:600;letter-spacing:.02em;text-transform:uppercase;font-size:12px;color:#ffffff9e}.dice-settings-table__col--enabled{width:1%;text-align:center}.dice-settings-table tbody tr:nth-of-type(2n){background:#ffffff05}.dice-settings-table tbody tr:hover{background:#ffffff0d}.dice-settings-enable-checkbox{width:18px;height:18px;accent-color:#4a90e2;cursor:pointer}.dice-settings-color-control{display:flex;align-items:center;gap:10px}.dice-settings-color-swatch{width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,.22);box-shadow:0 3px 8px #00000073;flex-shrink:0;transition:transform .2s ease}.dice-settings-color-control:focus-within .dice-settings-color-swatch,.dice-settings-color-control:hover .dice-settings-color-swatch{transform:scale(1.05);border-color:#4a90e2e6}.dice-settings-select{width:100%;border-radius:10px;background:#070d1ad1;border:1px solid rgba(255,255,255,.14);color:#fff;padding:9px 12px;font-size:14px;font-weight:500;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.dice-settings-select:hover,.dice-settings-select:focus-visible{border-color:#4a90e2cc;box-shadow:0 0 0 3px #4a90e23d;outline:none}.dice-settings-table td{vertical-align:middle}.dice-button.is-hidden{display:none}.settings-toggle{display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:12px 16px;border-radius:12px;background:#ffffff14;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s ease,transform .2s ease}.settings-toggle:hover,.settings-toggle:focus-within{background:#ffffff29;transform:translateY(-1px)}.settings-toggle input[type=checkbox]{width:20px;height:20px;accent-color:#4a90e2;cursor:pointer}.settings-toggle__label{display:inline-flex;align-items:center;gap:8px;line-height:1.3}.settings-toggle__icon{width:24px;height:24px;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.35))}.settings-toggle__text{display:inline-block}.settings-select{font-size:14px;font-weight:500;color:#fffc}#backgroundSelect{width:100%;border-radius:12px;background:#070d1ad9;border:1px solid rgba(255,255,255,.12);color:#fff;padding:12px 14px;font-size:15px;font-weight:500;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}#backgroundSelect:hover,#backgroundSelect:focus-visible{border-color:#4a90e2cc;box-shadow:0 0 0 4px #4a90e233}body.settings-open,body.about-open{overflow:hidden}#clearBtn{background:linear-gradient(145deg,#e24a4a,#bd3535)}#clearBtn:hover{background:linear-gradient(145deg,#f25a5a,#cd4545)}#result{color:#f8fafc;font-size:16px;font-weight:500;width:100%;text-align:left;background:#ffffff14;padding:16px 18px;border-radius:12px;backdrop-filter:blur(10px);line-height:1.4}.result-message{margin:0;text-align:center;font-size:15px}.result-summary{display:flex;flex-direction:column;gap:10px}.result-summary__header{display:flex;justify-content:space-between;align-items:baseline;gap:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-size:13px;color:#f8fafcd9}.result-summary__title{font-size:13px}.result-summary__total{font-size:13px;display:flex;align-items:baseline;gap:8px}.result-summary__total-value{font-size:22px;font-weight:700;color:#4aa0ff}.result-table{width:100%;border-collapse:collapse;font-size:13px}.result-table thead th{font-weight:600;color:#f8fafcb3;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.12)}.result-table tbody th,.result-table tbody td{padding:6px 0;border-top:1px solid rgba(255,255,255,.08)}.result-table tbody tr:first-child th,.result-table tbody tr:first-child td{border-top:none}.result-table th{text-align:left;font-weight:600;color:#f8fafce6}.result-table td{text-align:left;color:#f8fafcd9}.result-table__subtotal{text-align:right;white-space:nowrap;font-weight:600}.loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:24px}@media(max-width:900px){body{height:100vh;min-height:100vh;min-height:100dvh;padding-bottom:env(safe-area-inset-bottom,0px)}#container{flex-direction:column;height:100%;min-height:100%}#canvas-container{flex:1 1 auto;min-height:100vh;min-height:100dvh}#menuToggle{display:flex;position:fixed;top:calc(16px + env(safe-area-inset-top,0px));left:calc(16px + env(safe-area-inset-left,0px));z-index:70;padding:12px 22px}body.menu-open #menuToggle{background:#000000f2;box-shadow:0 12px 26px #0000008c}#controls{position:fixed;top:0;left:0;width:min(320px,82vw);height:100vh;max-height:100vh;transform:translate(-110%);transition:transform .3s ease,box-shadow .3s ease;align-items:stretch;padding:28px 24px 36px;gap:18px;box-shadow:10px 0 30px #00000073;z-index:50;overflow-y:auto;-webkit-overflow-scrolling:touch}.menu-header{padding-bottom:20px;margin-bottom:20px}.menu-logo{width:min(200px,80%)}#controls button{width:100%}body.menu-open #controls,#controls.open{transform:translate(0)}#menuBackdrop{display:block;position:fixed;inset:0;background:#00000073;opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:45}body.menu-open #menuBackdrop{opacity:1;pointer-events:auto}.settings-modal{width:min(92vw,420px)}}
