*,:after,:before{box-sizing:border-box}:root{--color-text:#000;--color-bg:#ddd;--color-ui-bg:#ffffffe6;font-size:16px}[data-theme=dark]{--color-text:#fff;--color-bg:#1a1a1a;--color-ui-bg:#282828e6}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#ddd;background-color:var(--color-bg);color:#000;color:var(--color-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;margin:0;overflow:hidden}.App{display:flex;flex-direction:column;height:100vh}.dice-roller{align-items:center;display:flex;flex:1 1;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%}canvas{left:0;position:absolute;top:0}.app-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffe6;background:var(--color-ui-bg);border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;left:20px;padding:12px 20px;position:absolute;top:20px;transition:all .3s ease;z-index:1000}.app-header:hover{box-shadow:0 12px 40px #00000026;transform:translateY(-2px)}.app-logo{align-items:center;display:flex;gap:12px}.logo-icon{animation:subtle-bounce 3s ease-in-out infinite;font-size:2em}@keyframes subtle-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.logo-text{display:flex;flex-direction:column;line-height:1.1}.brand-name{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background-clip:text;-webkit-background-clip:text;font-size:1.4em;font-weight:800;letter-spacing:-.02em}[data-theme=dark] .brand-name{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#a8edea,#fed6e3);background-clip:text;-webkit-background-clip:text}.brand-subtitle{font-size:.9em;font-weight:500;letter-spacing:.1em;opacity:.8;text-transform:uppercase}.brand-subtitle,.panel-toggle{color:#000;color:var(--color-text)}.panel-toggle{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;background:var(--color-ui-bg);border:none;border-radius:50%;box-shadow:0 4px 12px #00000026;cursor:pointer;display:flex;font-size:1.2em;height:50px;justify-content:center;position:absolute;right:20px;top:20px;transition:all .3s ease;width:50px;z-index:1001}.panel-toggle:hover{box-shadow:0 6px 20px #0003;transform:scale(1.1)}.panel-toggle:active{transform:scale(.95)}.hamburger{display:flex;flex-direction:column;height:16px;justify-content:space-between;position:relative;width:20px}.hamburger span{background-color:#000;background-color:var(--color-text);border-radius:1px;display:block;height:2px;transform-origin:center;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);width:100%}.hamburger.active span:first-child{transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.dice-selector{animation:slideIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;background:var(--color-ui-bg);border-radius:12px;box-shadow:0 4px 12px #00000026;min-width:250px;padding:20px;position:absolute;right:20px;top:80px;z-index:1000}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.selector-row{align-items:center;border-bottom:1px solid #cccccc4d;display:flex;gap:10px;margin-bottom:15px;padding-bottom:15px}.dice-selector label{color:#000;color:var(--color-text);font-size:.9em;font-weight:600}.dice-selector select{background:#fff;border:1px solid #ccc;border-radius:6px;cursor:pointer;font-size:.9em;padding:8px 12px;transition:border-color .2s ease}.dice-selector select:focus{border-color:#273e9a;outline:none}.ui-controls{align-items:center;display:flex;flex-direction:column;font-family:inherit;justify-content:center;line-height:1.5;margin-top:-20vh;max-width:500px;padding:10px;pointer-events:none;position:relative;-webkit-user-select:none;user-select:none;width:100%}.score{font-weight:700;margin-bottom:1em}.ui-controls .score span{color:#2e4cd4;display:inline-block;min-width:1.8em}.ui-controls button{background-color:#273e9a;border:none;border-radius:1.5em;color:#fff;cursor:pointer;display:inline-block;font-weight:700;margin:1em 0;padding:1em 1.5em;pointer-events:auto;text-decoration:none;transition:background-color .2s,transform .1s}.ui-controls button:active{transform:translateY(2px)}.ui-controls button:hover{background-color:#3737af}.shake-hint{color:#666;font-size:.9em;margin-top:.5em;text-align:center}.theme-control{padding-bottom:6px;padding-top:6px}.theme-toggle{align-items:center;cursor:pointer;display:flex;gap:8px;justify-content:space-between}.empty-history,.theme-toggle{color:#000;color:var(--color-text);font-size:.9em}.empty-history{margin:5px 0;opacity:.7}.switch{display:inline-block;height:20px;position:relative;width:40px}.switch input{height:0;opacity:0;width:0}.slider{background-color:#ccc;border-radius:20px;bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{background-color:#fff;border-radius:50%;bottom:2px;content:"";height:16px;left:2px;width:16px}input:checked+.slider{background-color:#273e9a}input:checked+.slider:before{transform:translateX(20px)}.history-container{border-top:1px solid #ccc;margin-top:15px;max-height:200px;overflow-y:auto;padding-top:10px}.history-container h3{color:#000;color:var(--color-text);font-size:.9em;font-weight:700;margin:0 0 10px;text-align:center}.history-list{list-style-type:none;margin:0;padding:0}.history-item{align-items:center;border-bottom:1px solid #cccccc4d;display:flex;font-size:.9em;justify-content:space-between;padding:6px 0}.history-result{color:#273e9a;font-weight:700}.history-timestamp{color:#666;font-size:.8em;margin-left:10px}@media (max-width:768px){.app-header{left:10px;padding:8px 16px;top:10px}.app-logo{gap:8px}.logo-icon{font-size:1.6em}.brand-name{font-size:1.1em}.brand-subtitle{font-size:.75em}.panel-toggle{font-size:1.1em;height:45px;right:10px;top:10px;width:45px}.dice-selector{left:10px;max-width:calc(100vw - 20px);min-width:auto;right:10px;top:65px}.ui-controls{margin-top:-15vh;padding:5px}.selector-row{align-items:flex-start;flex-direction:column;gap:8px}.dice-selector select{padding:10px 12px;width:100%}.theme-toggle{width:100%}}@media (max-width:480px){.app-header{padding:6px 12px}.logo-icon{font-size:1.4em}.brand-name{font-size:1em}.brand-subtitle{font-size:.7em}.panel-toggle{font-size:1em;height:40px;width:40px}.dice-selector{padding:15px;top:60px}}
/*# sourceMappingURL=main.515fef81.css.map*/