@import"https://fonts.googleapis.com/css2?family=Mulish:wght@300;400;600;800&display=swap";:root{--bg: #080a12;--bg1: #0d1018;--bg2: #12151f;--bg3: #1a1f2e;--rail: #0f1218;--accent: #ffd93d;--accent-glow: rgba(255, 217, 61, .4);--accent-soft: rgba(255, 217, 61, .15);--text: #f0f4ff;--text-bright: #ffffff;--ink1: #d0d7f7;--muted: #8b96c7;--muted-dark: #5a6491;--border: #2a3346;--border-light: #3a4558;--shadow: 0 10px 40px rgba(0, 0, 0, .6);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .7);--shadow-glow: 0 0 20px var(--accent-glow);--glass-bg: rgba(18, 21, 31, .75);--glass-border: rgba(255, 255, 255, .08);--glass-blur: blur(12px);--gradient-accent: linear-gradient(135deg, #ffd93d 0%, #ffb03d 100%);--gradient-dark: linear-gradient(180deg, rgba(13, 16, 24, .95) 0%, rgba(8, 10, 18, .98) 100%);--rail-w: 280px;--tray-h: 60px;--gap: 16px;--header-h: 48px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--bounce: cubic-bezier(.68, -.55, .265, 1.55)}*{box-sizing:border-box}body,html,#root{margin:0;height:100%;font-family:Mulish,system-ui,sans-serif;color:var(--text);background:var(--bg);overflow:hidden}.app{width:100%;height:100vh;overflow:hidden;position:relative}.app-background{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1}.bg-img{width:100%;height:100%;object-fit:cover;object-position:center center;opacity:.9;filter:brightness(.85) contrast(1.05);transition:filter var(--transition-slow)}.bg-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,.5) 100%);pointer-events:none}.app-canvas{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2}canvas{position:fixed!important;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none}.app-content{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3;display:grid;grid-template-columns:1fr var(--rail-w);grid-template-rows:1fr;grid-template-areas:"main sidebar";overflow:hidden;contain:layout style}.content-main{grid-area:main;position:relative;overflow:hidden;display:flex;flex-direction:column;contain:layout style}.ui-bottom{position:absolute;bottom:0;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:var(--gap);padding:var(--gap);z-index:4}.content-sidebar{grid-area:sidebar;display:flex;flex-direction:column;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-left:1px solid var(--glass-border);box-shadow:-10px 0 30px #0000004d;width:var(--rail-w);min-width:var(--rail-w);max-width:var(--rail-w);overflow:hidden;contain:layout style size;transition:all var(--transition-normal)}.sidebar-header{height:var(--header-h);display:flex;align-items:center;justify-content:flex-end;padding:0 12px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-content{flex:1;overflow:hidden;min-height:0}.dice-tray{display:flex;gap:8px;align-items:center;background:color-mix(in oklab,var(--bg2) 80%,transparent);padding:8px 12px;border-radius:16px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--border);height:var(--tray-h);width:min(100%,800px)}.die-btn{background:var(--bg1);border:1px solid var(--border);color:var(--accent);padding:6px 10px;border-radius:10px;font-weight:800;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;box-shadow:0 2px 8px #00000040}.die-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #00000059}.composer-inline{margin-left:8px;opacity:.8;color:var(--ink1)}.composer-container{width:min(100%,900px);max-height:40vh;overflow:auto}.composer{background:color-mix(in oklab,var(--bg2) 75%,transparent);padding:24px;border-radius:20px;border:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;gap:20px;min-width:700px;max-width:900px}.expression-display{text-align:center;margin-bottom:8px}.current-expression{font-size:24px;font-weight:800;color:var(--accent);font-family:Courier New,monospace;letter-spacing:.5px}.expression-hint{font-size:16px;color:var(--muted);font-style:italic}.composer-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.modifiers{display:flex;flex-direction:column;gap:6px}.modifier-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.modifier-buttons{display:flex;gap:4px}.adv-dis-controls{display:flex;gap:6px;margin-left:8px}.chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center;margin:8px 0}.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:12px;font-weight:800;box-shadow:0 2px 8px #00000040}.chip-die{background:var(--accent);color:#111}.chip-const{background:var(--bg1);color:var(--ink1);border:1px solid var(--border)}.hint{color:var(--muted)}.pill{height:28px;width:42px;font-size:12px;border-radius:8px;background:var(--bg1);color:var(--ink1);border:1px solid var(--border);cursor:pointer}.pill.on{background:var(--accent);color:#111}.expr-input{position:absolute;opacity:0;pointer-events:none;height:0;width:0}.actions .roll{background:var(--accent);color:#111;border:0;padding:10px 14px;border-radius:12px;font-weight:800;margin-right:4px;box-shadow:0 6px 18px #00000059;cursor:pointer}.actions .hidden{background:var(--bg1);border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:12px;cursor:pointer}.actions .clear{background:transparent;border:0;color:var(--muted);margin-left:6px;cursor:pointer}.roll-rail{height:100%;width:100%;overflow-y:auto;overflow-x:hidden;padding:12px;box-sizing:border-box}.roll-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:16px;padding:14px;margin-bottom:12px;box-shadow:var(--shadow);width:100%;max-width:100%;box-sizing:border-box;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition-normal);animation:slideInRight .3s ease}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.roll-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 20px #ffd93d1a;border-color:var(--border-light)}.roll-card .card-head{display:flex;align-items:center;justify-content:space-between}.roll-card .user{font-size:12px;color:var(--muted)}.roll-card .user-info{display:flex;align-items:center;gap:6px}.roll-card .user-name{font-size:12px;color:var(--muted);font-weight:500}.roll-card .assignment-info{display:flex;align-items:center;gap:4px;margin-left:6px;font-size:11px}.roll-card .assignment-arrow{color:var(--muted);font-size:12px}.roll-card .assigned-user{display:flex;align-items:center;gap:2px;background:#f7d76c33;padding:2px 6px;border-radius:8px;border:1px solid rgba(247,215,108,.3)}.roll-card .person-icon{font-size:10px;opacity:.8}.roll-card .assigned-name{color:var(--accent);font-weight:600;font-size:10px}.roll-card .hidden-tag{font-size:12px;color:var(--muted)}.roll-card .expr{font-size:14px;color:var(--ink1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:4px;max-width:100%;word-break:break-all;overflow-wrap:break-word}.roll-card .total{font-size:28px;font-weight:800;margin:6px 0 4px;color:var(--accent)}.roll-card .mini{display:flex;flex-wrap:wrap;gap:6px;max-width:100%;overflow:hidden}.roll-card .mini .pip{display:inline-flex;align-items:center;gap:6px;background:var(--bg2);border:1px solid var(--border);padding:4px 8px;border-radius:8px;font-size:12px;color:var(--ink1);max-width:60px;overflow:hidden;flex-shrink:1}.roll-card .mini .pip .pip-type{opacity:.85;font-weight:700}.roll-card .actions{display:flex;gap:8px;margin-top:8px}.btn-ghost{padding:.45rem .7rem;border:1px solid var(--border);background:var(--bg2);color:var(--ink1);border-radius:10px;cursor:pointer}.btn-ghost:hover{border-color:var(--accent);color:var(--text)}.settings-btn{background:var(--bg1);color:var(--text);border:1px solid var(--border);padding:10px 14px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;min-width:48px;min-height:48px}.settings-btn:hover{border-color:var(--accent);background:color-mix(in oklab,var(--bg1) 95%,var(--accent) 5%)}.settings-icon{width:28px;height:28px;filter:brightness(.9)}.action-icon{width:24px;height:24px;margin:0;filter:brightness(.9)}.header-actions{display:flex;gap:8px}.action-btn{background:var(--glass-bg);color:var(--text);border:1px solid var(--border);padding:8px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:40px;min-height:40px;position:relative;transition:all var(--transition-normal);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #0003}.action-btn:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px) scale(1.05);box-shadow:0 4px 16px #ffd93d40,0 0 0 1px var(--accent)}.action-btn:active{transform:translateY(0) scale(.98);transition:all var(--transition-fast)}.action-btn:after{content:attr(title);position:absolute;bottom:-35px;left:50%;transform:translate(-50%);background:#000000e6;color:#fff;padding:6px 8px;border-radius:4px;font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1000}.action-btn:hover:after{opacity:1}.sidebar-header{height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 12px;border-bottom:1px solid var(--border);flex-shrink:0}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0000009e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-modal{position:fixed;z-index:101;left:50%;top:50%;transform:translate(-50%,-50%);width:720px;max-width:92vw;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;background:#0f1320fa;border:1px solid #262c42;border-radius:16px;box-shadow:0 18px 60px #0000008c}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 8px}.settings-title{font-size:28px;font-weight:800;color:#f3f6ff;margin:0}.settings-close{height:36px;width:36px;border-radius:12px;display:grid;place-items:center;background:#121725;border:1px solid #262c42;color:#cbd3f5;cursor:pointer}.settings-scroll{overflow:auto;padding:8px 4px 18px}.settings-section{padding:14px 20px 6px}.theme-selector{padding:0}.theme-selector-title{display:flex;align-items:center;gap:8px;margin:0 0 8px;font-size:16px;font-weight:600;color:var(--text)}.section-icon{width:20px;height:20px;filter:brightness(.9)}.theme-selector-description{color:var(--muted);font-size:14px;margin:0 0 16px}.theme-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:20px}.theme-card{background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:14px;cursor:pointer;display:flex;align-items:center;gap:12px;transition:all .2s ease;text-align:left;min-height:60px;width:100%}.theme-card:hover{border-color:var(--accent);background:color-mix(in oklab,var(--bg1) 95%,var(--accent) 5%)}.theme-card.active{border-color:var(--accent);background:color-mix(in oklab,var(--bg1) 90%,var(--accent) 10%);box-shadow:0 0 0 1px var(--accent)}.theme-icon{font-size:24px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:color-mix(in oklab,var(--bg2) 80%,transparent)}.theme-info{flex:1}.theme-name{margin:0 0 4px;font-size:14px;font-weight:600;color:var(--text)}.theme-description{margin:0;font-size:12px;color:var(--muted);line-height:1.3}.theme-preview{background:color-mix(in oklab,var(--bg2) 50%,transparent);border:1px solid var(--border);border-radius:10px;padding:12px}.theme-preview h4{margin:0 0 8px;font-size:14px;color:var(--text)}.dice-preview{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:6px}.dice-preview-item{display:flex;flex-direction:column;align-items:center;background:var(--bg1);border:1px solid var(--border);border-radius:6px;padding:6px}.dice-type{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:2px}.material-name{font-size:10px;color:var(--muted);text-transform:capitalize}.row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:12px;border-radius:12px}.row+.row{margin-top:4px}.row:hover{background:#ffffff05}.row-label{color:#cbd3f5;display:flex;gap:8px;align-items:center}.row-value{color:#f3f6ff;font-weight:600}.row-edit button{padding:6px 10px;border-radius:10px;background:#121725;border:1px solid #262c42;color:#f3f6ff;cursor:pointer}@media (max-width: 1024px){:root{--rail-w: 0px}.app-content{grid-template-columns:1fr}.content-sidebar{display:none}.dice-tray,.composer-container{width:calc(100vw - (var(--gap) * 2));max-width:100%}}.players-list{display:flex;flex-direction:column;gap:8px}.players-header{padding:8px 12px;border-bottom:1px solid var(--border)}.players-header h4{margin:0;font-size:14px;font-weight:600;color:var(--text)}.players-grid{display:flex;flex-direction:column;gap:6px;padding:8px}.player-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:color-mix(in oklab,var(--bg1) 50%,transparent);border-radius:8px;border:1px solid transparent;transition:all .2s ease;position:relative}.player-item:hover{background:color-mix(in oklab,var(--bg1) 70%,transparent);border-color:var(--border)}.player-info{flex:1;display:flex;flex-direction:column;gap:2px}.player-name{font-size:13px;font-weight:500;color:var(--text)}.player-badges{display:flex;gap:6px}.player-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.player-badge.guest{background:color-mix(in oklab,var(--muted) 30%,transparent);color:var(--muted)}.player-badge.admin{background:color-mix(in oklab,var(--accent) 30%,transparent);color:var(--accent)}.kick-btn{width:24px;height:24px;border:none;background:color-mix(in oklab,#ff4444 20%,transparent);color:#f44;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:.7}.kick-btn:hover{background:color-mix(in oklab,#ff4444 40%,transparent);color:#f66;opacity:1;transform:scale(1.1)}.kick-btn:active{transform:scale(.95)}.player-item .kick-btn{opacity:0;transition:opacity .2s ease}.player-item:hover .kick-btn{opacity:.7}.player-item:hover .kick-btn:hover{opacity:1}.ui-modal-open .ui-bottom{visibility:hidden;pointer-events:none}.ui-modal-open .sidebar-content{filter:blur(2px) brightness(.85);pointer-events:none}.app-loading{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:1000}.loading-spinner{text-align:center}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top:3px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px}.user-section{display:flex;align-items:center;gap:8px}.invite-btn{width:32px;height:32px;border-radius:50%;background:var(--bg1);border:2px solid var(--border);color:var(--accent);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:18px;font-weight:700}.invite-btn:hover{background:var(--accent);color:var(--bg);transform:scale(1.1)}.user-info{display:flex;flex-direction:column;min-width:0}.username{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.user-role{font-size:10px;color:var(--accent);text-transform:uppercase;font-weight:600}.user-avatar-clickable:hover{transform:scale(1.1);box-shadow:0 0 0 3px #f7d76c4d}.header-actions{display:flex;gap:4px}.logout-btn{background:#ff6b6b1a!important;border-color:#ff6b6b4d!important}.logout-btn:hover{background:#ff6b6b33!important;transform:scale(1.1)}.logout-icon{font-size:14px;color:#ff6b6b}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.invite-modal{background:var(--bg2);border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow);max-width:480px;width:calc(100vw - 32px);max-height:calc(100vh - 32px);overflow:auto;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;font-size:24px;font-weight:600;color:var(--text)}.close-btn{width:32px;height:32px;border:none;background:transparent;color:var(--muted);font-size:24px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn:hover{background:var(--border);color:var(--text)}.modal-content{padding:24px}.modal-description{margin:0 0 20px;color:var(--ink1);font-size:16px}.url-section{margin-bottom:24px}.url-input-group{display:flex;gap:8px;background:var(--bg1);padding:4px;border-radius:12px;border:1px solid var(--border)}.url-input{flex:1;background:transparent;border:none;padding:12px 16px;color:var(--text);font-family:Courier New,monospace;font-size:14px;border-radius:8px}.url-input:focus{outline:none;background:#ffffff0d}.copy-btn{background:var(--accent);color:var(--bg);border:none;padding:12px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:80px}.copy-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f7d76c4d}.copy-btn.copied{background:#4ecdc4;transform:scale(1.05)}.qr-section{text-align:center}.qr-description{margin:0 0 16px;color:var(--muted);font-size:14px}.qr-container{display:inline-block;padding:12px;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0003}.qr-code{display:block;border-radius:4px}.login-prompt-compact{display:flex;align-items:center;gap:4px;background:var(--bg1);border:1px solid var(--border);color:var(--accent);padding:4px 8px;border-radius:6px;font-size:10px;font-weight:600;cursor:pointer;transition:all .2s ease}.login-prompt-compact:hover{background:var(--accent);color:var(--bg);transform:scale(1.05)}.login-icon{font-size:12px}.login-prompt{position:fixed;bottom:20px;right:20px;background:var(--bg2);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow);padding:16px;max-width:300px;z-index:100;animation:slideInFromBottom .3s ease}@keyframes slideInFromBottom{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.login-prompt-content{display:flex;flex-direction:column;gap:12px;text-align:center}.login-prompt-icon{font-size:24px}.login-prompt-text h3{margin:0;font-size:14px;font-weight:600;color:var(--text)}.login-prompt-text p{margin:0;font-size:12px;color:var(--muted);line-height:1.4}.login-prompt-button{background:var(--accent);color:var(--bg);border:none;padding:8px 16px;border-radius:8px;font-weight:600;font-size:12px;cursor:pointer;transition:all .2s ease}.login-prompt-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f7d76c4d}.user-info .login-prompt-compact{margin-top:2px}.user-section{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.header-actions .invite-btn{width:32px;height:32px;border-radius:50%;background:var(--bg1);border:2px solid var(--border);color:var(--accent);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:18px;font-weight:700}.header-actions .invite-btn:hover{background:var(--accent);color:var(--bg);transform:scale(1.1)}.user-info .login-prompt-compact{margin-top:2px;font-size:9px;padding:2px 6px;min-width:fit-content}.username{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;min-height:var(--header-h)}.user-corner{position:fixed;top:16px;left:16px;z-index:10;background:color-mix(in oklab,var(--rail) 85%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:12px;padding:8px 12px;box-shadow:var(--shadow)}.user-corner .user-section{display:flex;align-items:center;gap:8px;min-width:0}.user-corner .user-info{display:flex;flex-direction:column;min-width:0}.user-corner .username{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.user-corner .user-role{font-size:10px;color:var(--accent);text-transform:uppercase;font-weight:600}.user-corner .login-prompt-compact{margin-top:2px;font-size:9px;padding:2px 6px}.user-invite-btn{width:28px;height:28px;border-radius:50%;background:var(--bg1);border:2px solid var(--border);color:var(--accent);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:16px;font-weight:700;margin-left:4px}.user-invite-btn:hover{background:var(--accent);color:var(--bg);transform:scale(1.1)}.user-invite-btn .plus-icon{line-height:1}.expression-center{text-align:center;margin-bottom:16px}.dice-expression{font-size:48px;font-weight:700;color:var(--text);margin-bottom:8px;font-family:Courier New,monospace}.expression-hint{font-size:18px;color:var(--muted);font-style:italic}.roll-tag{display:inline-block;background:var(--accent);color:var(--bg);padding:6px 16px;border-radius:16px;font-size:14px;font-weight:600;margin-top:8px}.send-target{text-align:center;margin-bottom:20px}.target-label{display:block;font-size:18px;color:var(--muted);margin-bottom:12px}.target-selector{display:flex;flex-direction:column;align-items:center;gap:8px}.target-name{font-size:14px;color:var(--text);font-weight:500}.modifier-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.modifier-btn{width:60px;height:40px;border-radius:8px;border:1px solid var(--border);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.modifier-btn.positive{background:var(--bg1);color:var(--accent)}.modifier-btn.negative{background:var(--bg1);color:#f99}.modifier-btn.advantage{width:80px;background:var(--bg1);color:var(--accent)}.modifier-btn.disadvantage{width:80px;background:var(--bg1);color:#f99}.modifier-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.modifier-btn.active{background:var(--accent);color:var(--bg)}.action-row{display:flex;gap:20px;align-items:center}.roll-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px solid}.roll-btn.primary{background:var(--bg);color:var(--accent);border-color:var(--accent)}.roll-btn.secondary{background:var(--text);color:var(--muted);border-color:var(--border)}.roll-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}.clear-btn{width:40px;height:40px;border-radius:50%;background:transparent;border:1px solid var(--border);color:var(--muted);font-size:20px;cursor:pointer;transition:all .2s ease}.clear-btn:hover{background:var(--bg1);color:var(--text)}.composer-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.composer-modal{position:relative;max-width:90vw;max-height:90vh;overflow:auto;animation:slideInScale .3s ease}.composer-modal .composer{background:var(--bg1);border:2px solid var(--border);box-shadow:0 20px 60px #0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.composer-single-line{position:fixed;bottom:50%;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:16px;background:#000c;padding:12px 20px;border-radius:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:999;border:1px solid rgba(255,255,255,.2)}.send-to-section{display:flex;align-items:center;gap:8px}.send-to-label{color:#fff;font-size:14px;font-weight:600;margin-right:4px}.send-to-section .user-avatar.selected{border:2px solid #f7d76c!important;box-shadow:0 0 8px #f7d76c80!important}.send-to-section .user-avatar:hover{border:2px solid rgba(247,215,108,.7)!important;transform:scale(1.05)!important}.modifiers-line{display:flex;gap:4px;align-items:center}.mod-btn-compact{padding:6px 10px;border-radius:4px;border:1px solid rgba(255,255,255,.3);background:#0009;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:32px;height:28px}.mod-btn-compact.positive{color:#4ecdc4}.mod-btn-compact.negative{color:#f99}.mod-btn-compact.advantage{color:#4ecdc4;min-width:38px}.mod-btn-compact.disadvantage{color:#f99;min-width:32px}.mod-btn-compact:hover{background:#fff3;transform:translateY(-1px)}.mod-btn-compact.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.roll-btn-compact{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px solid;height:36px}.roll-btn-compact.primary{background:#f7d76c;color:#000;border-color:#f7d76c}.roll-btn-compact.secondary{background:#ffffffe6;color:#666;border-color:#ccc}.roll-btn-compact:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0000004d}.clear-btn-compact{width:28px;height:28px;border-radius:50%;background:#f003;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:18px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.clear-btn-compact:hover{background:#f006;transform:scale(1.1)}.user-top-left{position:fixed;top:0;left:0;z-index:100;pointer-events:none}.main-user-avatar{position:absolute;top:20px;left:20px;width:48px;height:48px;pointer-events:auto}.main-user-avatar .user-avatar{width:48px!important;height:48px!important;border:3px solid rgba(255,105,180,.8)!important;border-radius:50%;box-shadow:0 2px 8px #ff69b44d;transition:all .2s ease}.main-user-avatar .user-avatar:hover{border-color:#ff69b4!important;box-shadow:0 2px 12px #ff69b480}.user-status-dot{position:absolute;top:2px;left:2px;width:12px;height:12px;background:#4ade80;border-radius:50%;border:2px solid rgba(0,0,0,.8);box-shadow:0 1px 3px #0006;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.6}}.invite-plus-btn{position:absolute;top:30px;left:80px;width:28px;height:28px;border-radius:50%;background:#000000b3;border:2px solid rgba(247,215,108,.5);color:#f7d76c;font-size:20px;line-height:1;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;pointer-events:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:0}.invite-plus-btn:hover{background:#f7d76ce6;border-color:#f7d76c;color:#000;transform:scale(1.15) rotate(90deg);box-shadow:0 2px 12px #f7d76c99}.other-players{position:relative;pointer-events:auto}.other-player{position:absolute;top:25px}.other-player .user-avatar{border:2px solid rgba(255,255,255,.6)!important;opacity:.9}.other-player .user-status-dot{width:10px;height:10px;top:-1px;left:-1px}.room-players-top-left{position:fixed;top:80px;left:20px;z-index:99;pointer-events:auto;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:8px;padding:8px;border:1px solid rgba(255,255,255,.2);max-width:200px}.room-players-top-left .roll-rail{max-height:200px;padding:4px}.room-players-top-left .players-list{display:flex;flex-direction:column;gap:6px}.room-players-top-left .player-item{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:6px;background:#ffffff1a;font-size:12px}.room-players-top-left .user-avatar{width:24px!important;height:24px!important}.right-icon-row{position:fixed;top:20px;right:20px;z-index:100;pointer-events:auto}.right-icon-row .header-actions{display:flex;gap:16px;align-items:center}.right-icon-row .action-btn{width:40px;height:40px;border-radius:50%;background:#0009;border:1px solid rgba(255,255,255,.3);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.right-icon-row .action-btn:hover{background:#f7d76ccc;color:#000;transform:scale(1.05);box-shadow:0 2px 8px #f7d76c66}.right-icon-row .action-icon{width:24px;height:24px;filter:brightness(1)}.right-icon-row .logout-btn{background:#ff450099}.right-icon-row .logout-btn:hover{background:#ff4500cc;color:#fff}.composer-wireframe{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;pointer-events:none;background:transparent}.composer-wireframe>*{pointer-events:auto;position:absolute}.central-roll-display{left:50%;top:120px;transform:translate(-50%);text-align:center}.dice-expression{font-size:48px;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5);margin-bottom:8px}.roll-tag{display:inline-block;background:#f7d76c;color:#000;padding:6px 16px;border-radius:16px;font-size:14px;font-weight:600;min-width:90px;height:32px;line-height:20px}.send-target-section{left:50%;top:250px;transform:translate(-50%);text-align:center}.send-label{font-size:18px;color:#ccc;margin-bottom:12px}.target-avatar{display:flex;justify-content:center}.target-avatar .user-avatar{border:3px solid #ff69b4!important;box-shadow:0 2px 8px #0000004d;cursor:pointer}.target-avatars-horizontal{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:8px;flex-wrap:wrap}.target-avatar-option{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:all .3s ease;padding:8px;border-radius:12px;border:2px solid transparent;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);min-width:70px}.target-avatar-option:hover{transform:scale(1.05);background:#ffffff1a;border-color:#ffffff4d}.target-avatar-option.selected{background:#f7d76c4d;border-color:#f7d76c;box-shadow:0 0 12px #f7d76c80}.target-avatar-option.clicked{transform:scale(.95);transition:transform .1s ease}.avatar-label{color:#fff;font-size:12px;font-weight:500;text-align:center;max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.gm-indicator{background:#f7d76c;color:#000;font-size:8px;font-weight:600;padding:1px 4px;border-radius:3px;text-transform:uppercase;margin-left:4px;display:inline-block}.selection-indicator{position:absolute;top:-2px;right:-2px;background:#4caf50;color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid white;animation:checkmark-appear .3s ease}@keyframes checkmark-appear{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.no-other-players{color:#ccc;font-size:12px;font-style:italic;text-align:center;padding:8px}.modifier-grid{left:50%;top:380px;transform:translate(-50%);display:flex;flex-direction:column;gap:10px}.modifier-row{display:flex;gap:10px;justify-content:center}.mod-btn-wire{border:1px solid var(--glass-border);background:var(--glass-bg);color:#fff;cursor:pointer;transition:all var(--transition-normal);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-weight:600;border-radius:8px;box-shadow:0 2px 8px #0000004d}.mod-btn-wire:nth-child(1),.mod-btn-wire:nth-child(2),.mod-btn-wire:nth-child(3){width:52px;height:36px;font-size:13px}.mod-btn-wire.advantage,.mod-btn-wire.disadvantage{width:70px;height:36px;font-size:13px}.mod-btn-wire.positive{color:#5ff5e8;border-color:#5ff5e84d}.mod-btn-wire.negative{color:#ffb3ba;border-color:#ffb3ba4d}.mod-btn-wire:hover{background:var(--accent-soft);border-color:var(--accent);transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #ffd93d4d}.mod-btn-wire.active{background:var(--gradient-accent);color:#000;border-color:var(--accent);box-shadow:0 4px 16px var(--accent-glow),0 0 20px var(--accent-glow);font-weight:700}.action-buttons{left:50%;top:490px;transform:translate(-50%);display:flex;gap:20px;justify-content:center}@media (max-height: 800px){.action-buttons{top:450px}.modifier-grid{top:350px}.send-target-section{top:230px}.central-roll-display{top:100px}}.roll-btn-primary{width:200px;height:60px;background:var(--gradient-accent);border:2px solid var(--accent);color:#000;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--transition-normal);box-shadow:0 4px 16px #ffd93d4d,0 0 0 0 var(--accent-glow);position:relative;overflow:hidden}.roll-btn-primary:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.3) 0%,transparent 100%);opacity:0;transition:opacity var(--transition-normal)}.roll-btn-primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 24px #ffd93d80,0 0 30px var(--accent-glow);animation:pulse 1.5s ease-in-out infinite}.roll-btn-primary:hover:before{opacity:1}.roll-btn-primary:active{transform:translateY(-1px) scale(.98);transition:all var(--transition-fast)}@keyframes pulse{0%,to{box-shadow:0 8px 24px #ffd93d80,0 0 30px var(--accent-glow)}50%{box-shadow:0 8px 32px #ffd93db3,0 0 40px var(--accent-glow)}}.roll-btn-hidden{width:220px;height:60px;background:#fff;border:2px solid #ccc;color:#666;border-radius:8px;font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease}.roll-btn-hidden:hover{background:#f8f8f8;border-color:#999;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.dice-icon,.eye-slash-icon{font-size:16px}.clear-btn-wire{position:absolute;left:1050px;top:500px;width:40px;height:40px;border-radius:50%;background:#f003;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.clear-btn-wire:hover{background:#f006;transform:scale(1.1)}.composer-two-line{position:fixed;left:50%;bottom:200px;transform:translate(-50%);background:#000c;border-radius:12px;padding:16px 20px;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:999;display:flex;flex-direction:column;gap:12px;min-width:600px}.composer-line-1{display:flex;align-items:center;justify-content:center;gap:12px}.send-to-label{color:#fff;font-size:16px;font-weight:600}.composer-line-1 .user-avatar{border:2px solid rgba(255,255,255,.5)!important;cursor:pointer;transition:all .2s ease}.composer-line-1 .user-avatar:hover,.composer-line-1 .user-avatar.selected{border-color:#f7d76c!important;box-shadow:0 0 8px #f7d76c80!important}.composer-line-2{display:flex;align-items:center;gap:16px;justify-content:space-between}.modifiers-grid{display:flex;flex-direction:column;gap:4px}.modifier-row{display:flex;gap:6px;align-items:center}.mod-btn-inline{padding:6px 10px;border-radius:4px;border:1px solid rgba(255,255,255,.3);background:#0009;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:28px;height:28px}.mod-btn-inline.positive{color:#4ecdc4}.mod-btn-inline.negative{color:#f99}.mod-btn-inline.advantage,.mod-btn-inline.disadvantage{min-width:32px}.mod-btn-inline:hover{background:#fff3;transform:translateY(-1px)}.mod-btn-inline.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.roll-buttons-inline{display:flex;gap:8px}.roll-btn-inline{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px solid;height:36px}.roll-btn-inline.primary{background:#f7d76c;color:#000;border-color:#f7d76c}.roll-btn-inline.secondary{background:#ffffffe6;color:#666;border-color:#ccc}.roll-btn-inline:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0000004d}.clear-btn-inline{width:28px;height:28px;border-radius:50%;background:#f003;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:18px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.clear-btn-inline:hover{background:#f006;transform:scale(1.1)}.fairness-info-button{position:fixed;bottom:20px;left:20px;width:48px;height:48px;border-radius:50%;background:#000000b3;border:2px solid #4ecdc4;color:#4ecdc4;font-size:24px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:900;transition:all .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.fairness-info-button:hover{background:#4ecdc4;color:#000;transform:scale(1.1);box-shadow:0 0 20px #4ecdc480}.fairness-panel{position:fixed;bottom:80px;left:20px;width:400px;max-height:600px;background:#1a1a1afa;border:2px solid #4ecdc4;border-radius:12px;z-index:950;display:flex;flex-direction:column;box-shadow:0 8px 32px #000c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.fairness-header{padding:20px;border-bottom:1px solid #333;display:flex;justify-content:space-between;align-items:center}.fairness-header h2{margin:0;color:#4ecdc4;font-size:24px}.fairness-header .close-btn{background:transparent;border:none;color:#ccc;font-size:32px;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.fairness-header .close-btn:hover{background:#ffffff1a;color:#fff}.fairness-content{padding:20px;overflow-y:auto;overflow-x:hidden;flex:1;font-size:14px;max-height:520px;color:#ccc;line-height:1.6}.fairness-content::-webkit-scrollbar{width:8px}.fairness-content::-webkit-scrollbar-track{background:#0000004d;border-radius:4px}.fairness-content::-webkit-scrollbar-thumb{background:#4ecdc4;border-radius:4px}.fairness-content::-webkit-scrollbar-thumb:hover{background:#3ab0a7}.fairness-summary{background:#4ecdc41a;border:1px solid rgba(78,205,196,.3);border-radius:6px;padding:12px;color:#ccc;line-height:1.8;margin:0}.fairness-summary strong{color:#4ecdc4}.no-data-compact{color:#888;font-style:italic;font-size:13px;padding:20px;text-align:center}.stats-compact{display:flex;flex-direction:column;gap:12px}.stat-card-compact{background:#0006;border:1px solid #333;border-radius:6px;padding:12px}.stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;color:#f7d76c;font-size:13px}.stat-header span{color:#888;font-size:12px}.insufficient-data-compact{color:#888;font-style:italic;font-size:12px;margin:8px 0 0}.tech-details{background:#0000004d;border:1px solid #333;border-radius:6px;padding:8px}.tech-details summary{color:#4ecdc4;cursor:pointer;font-size:13px;font-weight:600;padding:4px}.tech-details summary:hover{color:#f7d76c}.rng-explanation{padding:12px;color:#ccc;line-height:1.8}.rng-explanation h4{color:#f7d76c;margin:16px 0 12px;font-size:16px;font-weight:600}.rng-explanation p{margin:0 0 12px;color:#ccc}.rng-explanation ul,.rng-explanation ol{margin:8px 0;color:#ccc}.rng-explanation li{margin:6px 0}.rng-explanation code{background:#4ecdc41a;color:#4ecdc4;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:13px}.formula-highlight{text-align:center;background:#4ecdc426;border:1px solid #4ecdc4;border-radius:6px;padding:16px;margin:0 0 16px}.formula-highlight code{font-size:18px;font-weight:700;color:#4ecdc4;background:none;padding:0}.formula-highlight em{display:block;margin-top:8px;color:#888;font-size:13px}.code-block-compact{background:#0a0a0a;border:1px solid #222;border-radius:4px;padding:8px;margin-top:8px;font-family:Courier New,monospace;font-size:11px;color:#4ecdc4}.fairness-section{margin-bottom:30px}.fairness-section h3{color:#f7d76c;margin:0 0 16px;font-size:18px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.info-card{background:#4ecdc41a;border:1px solid rgba(78,205,196,.3);border-radius:8px;padding:16px;display:flex;gap:12px;align-items:flex-start}.info-icon{font-size:32px;flex-shrink:0}.info-text strong{color:#4ecdc4;display:block;margin-bottom:8px}.info-text p{color:#ccc;margin:0;font-size:14px;line-height:1.5}.no-data{color:#888;font-style:italic;text-align:center;padding:40px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.stat-card{background:#0000004d;border:1px solid #333;border-radius:8px;padding:16px}.stat-card h4{margin:0 0 8px;color:#f7d76c;font-size:16px}.roll-count{color:#ccc;font-size:14px;margin:0 0 16px}.distribution-chart{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.chart-bar-container{display:grid;grid-template-columns:30px 1fr 40px;gap:8px;align-items:center}.chart-label{color:#ccc;font-size:12px;text-align:right;font-weight:700}.chart-bar-wrapper{background:#ffffff0d;border-radius:3px;height:20px;position:relative}.chart-bar{height:100%;border-radius:3px;transition:all .3s ease;min-width:2px}.chart-count{color:#ccc;font-size:12px;text-align:right}.chi-square{background:#4ecdc41a;border:1px solid rgba(78,205,196,.3);border-radius:6px;padding:10px;font-size:14px;color:#ccc;display:flex;justify-content:space-between;align-items:center}.chi-square.warning{background:#ffb4001a;border-color:#ffb4004d}.badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700}.badge.success{background:#4ecdc4;color:#000}.badge.warning{background:#ffb400;color:#000}.insufficient-data{color:#888;font-style:italic;font-size:14px;text-align:center;margin:20px 0}.code-block{background:#0a0a0a;border:1px solid #333;border-radius:6px;padding:16px;font-family:Courier New,monospace;font-size:13px;color:#4ecdc4;margin-bottom:12px;overflow-x:auto}.code-block .comment{color:#888}.explanation-text{color:#ccc;font-size:14px;line-height:1.6;margin:0}.composer-fullscreen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000}.composer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeIn var(--transition-slow)}@keyframes fadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}}.composer-wireframe-positioned{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none}.composer-wireframe-positioned>*{pointer-events:auto;position:absolute}.composer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.composer-content{display:flex;flex-direction:column;align-items:center;gap:40px;padding:40px;max-width:800px;width:90%}.expression-display{text-align:center}.current-expression{font-size:36px;font-weight:800;color:var(--accent);font-family:Courier New,monospace;text-shadow:0 2px 4px rgba(0,0,0,.5);min-height:45px;display:flex;align-items:center;justify-content:center}.send-to-section-large{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:-20px}.send-to-label-large{font-size:24px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8)}.send-to-section-large .user-avatar{border:4px solid rgba(255,255,255,.6)!important;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #0000004d}.send-to-section-large .user-avatar:hover,.send-to-section-large .user-avatar.selected{border-color:#f7d76c!important;box-shadow:0 4px 20px #f7d76c99!important;transform:scale(1.05)}.selected-user-name{font-size:18px;font-weight:600;color:var(--accent);text-shadow:0 1px 2px rgba(0,0,0,.8)}.controls-section{display:flex;align-items:center;gap:60px;justify-content:center}.modifiers-grid-large{display:flex;flex-direction:column;gap:12px}.modifier-row{display:flex;gap:12px;justify-content:center}.mod-btn-large{padding:12px 20px;border-radius:8px;border:2px solid rgba(255,255,255,.4);background:#0009;color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;min-width:60px;height:48px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.mod-btn-large.positive{color:#4ecdc4;border-color:#4ecdc466}.mod-btn-large.negative{color:#f99;border-color:#f996}.mod-btn-large.advantage{color:#4ecdc4;border-color:#4ecdc466;min-width:80px}.mod-btn-large.disadvantage{color:#f99;border-color:#f996;min-width:80px}.mod-btn-large:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.mod-btn-large.active{background:var(--accent);color:#000;border-color:var(--accent);box-shadow:0 4px 16px #f7d76c66}.roll-section{display:flex;flex-direction:column;gap:16px;justify-content:center}.roll-btn-large{padding:16px 32px;border-radius:12px;font-size:20px;font-weight:700;cursor:pointer;transition:all .3s ease;border:3px solid;height:64px;display:flex;align-items:center;gap:8px;box-shadow:0 6px 20px #0000004d}.roll-btn-large.primary{background:#f7d76c;color:#000;border-color:#f7d76c}.roll-btn-large.secondary{background:#ffffffe6;color:#666;border-color:#ccc}.roll-btn-large:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0006}.roll-btn-large.primary:hover{box-shadow:0 8px 24px #f7d76c66}.clear-btn-large{position:absolute;top:20px;right:20px;padding:12px 20px;border-radius:8px;background:#f003;border:2px solid rgba(255,255,255,.3);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.clear-btn-large:hover{background:#f006;transform:scale(1.05)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.expression-display-bar{position:fixed;bottom:130px;left:50%;transform:translate(-50%);z-index:1001;background:var(--gradient-accent);border:2px solid var(--accent);border-radius:16px;padding:16px 32px;cursor:pointer;transition:all var(--transition-normal);box-shadow:0 8px 24px #ffd93d66;animation:slideUpIn .3s ease}.expression-display-bar:hover{transform:translate(-50%) translateY(-4px) scale(1.02);box-shadow:0 12px 32px #ffd93d99}.expression-text{font-size:24px;font-weight:700;color:#000;text-align:center;margin-bottom:4px;font-family:Courier New,monospace}.expression-hint{font-size:12px;color:#000000b3;text-align:center;font-weight:600}@keyframes slideUpIn{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.dice-tray-bottom{position:fixed;bottom:0;left:0;right:0;height:80px;z-index:1000;display:flex;align-items:center;justify-content:center;background:var(--gradient-dark);border-top:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 -10px 30px #00000080;transition:all var(--transition-normal)}.dice-tray-container{display:flex;align-items:center;justify-content:center;width:100%;max-width:1200px;padding:8px 0}.dice-row-simple{display:flex;gap:12px;align-items:center;justify-content:center;padding:0 20px}.theme-set{display:flex;flex-direction:column;align-items:center;gap:12px;background:#0006;padding:16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.theme-set.secondary{border-color:#f7d76c4d}.theme-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.theme-icon{font-size:20px}.theme-name{font-size:14px;font-weight:600;color:var(--text)}.dice-row{display:flex;gap:12px;align-items:center}.dice-tray-item{display:flex;flex-direction:column;align-items:center;gap:0;cursor:pointer;position:relative;pointer-events:auto}.dice-label{font-size:10px;color:#ffffffb3;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.main-dice-preview{width:50px!important;height:50px!important;border:none!important;background:transparent!important;border-radius:0!important;pointer-events:auto!important;cursor:pointer!important;transition:transform var(--transition-normal),filter var(--transition-normal)!important;opacity:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.4))}.main-dice-preview:hover{transform:translateY(-8px) scale(1.1)!important;filter:drop-shadow(0 8px 16px rgba(255,217,61,.4)) brightness(1.2)!important}.main-dice-preview canvas,.dice-preview canvas{position:relative!important;inset:auto!important;z-index:auto!important;pointer-events:auto!important;width:100%!important;height:100%!important}.main-dice-preview:hover{transform:scale(1.2) translateY(-10px)!important;filter:brightness(1.3) drop-shadow(0 8px 24px rgba(247,215,108,1))!important}.secondary-dice{border-color:#f7d76c66!important}.secondary-dice:hover{border-color:#ff69b4!important;box-shadow:0 2px 12px #ff69b466!important}.theme-set-controls{display:flex;flex-direction:column;align-items:center;gap:12px;background:#0000004d;padding:16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.toggle-second-set{width:40px;height:40px;border-radius:50%;background:#f7d76c33;border:2px solid rgba(247,215,108,.5);color:var(--accent);font-size:20px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.toggle-second-set:hover{background:#f7d76c66;transform:scale(1.1);box-shadow:0 2px 8px #f7d76c4d}.theme-selector{background:#000c;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;padding:8px 12px;font-size:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;min-width:150px}.theme-selector:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #f7d76c4d}.theme-selector option{background:#000000e6;color:#fff;padding:4px}.right-metadata{position:fixed;right:20px;bottom:248px;z-index:90;pointer-events:auto}.logo-section{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:6px}.geometric-dice-logo{width:64px;height:64px;font-size:48px;display:flex;align-items:center;justify-content:center;background:#0006;border-radius:12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.25);transition:all .2s ease}.geometric-dice-logo:hover{background:#0009;border-color:#f7d76c66;transform:scale(1.05)}.version-text{font-size:14px;color:#999;font-weight:400;opacity:.8}.support-link{font-size:14px}.support-link a{color:#777;text-decoration:none;transition:color .2s ease;opacity:.7}.support-link a:hover{color:var(--accent);text-decoration:underline;opacity:1}.background-modal{background:var(--bg1);border:2px solid var(--border);border-radius:16px;width:90vw;max-width:800px;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0009;display:flex;flex-direction:column;position:relative}.background-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;padding:20px;overflow-y:auto;flex:1;max-height:calc(70vh - 120px)}.background-option{border:2px solid transparent;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;background:var(--bg2)}.background-option:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #0006}.background-option.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.background-thumbnail{width:100%;height:120px;overflow:hidden;background:#000}.background-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.background-option:hover .background-thumbnail img{transform:scale(1.05)}.background-info{padding:12px;display:flex;justify-content:space-between;align-items:center}.background-info h4{margin:0;font-size:14px;color:var(--text);font-weight:600}.selected-indicator{color:var(--accent);font-size:18px;font-weight:700}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 20px;border-top:1px solid var(--border);background:var(--bg2);flex-shrink:0;position:sticky;bottom:0;z-index:10}.btn{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--bg)}.btn.secondary{background:transparent;border-color:var(--border);color:var(--text)}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.players-list{background:var(--bg2);border-radius:12px;margin-bottom:16px;padding:12px}.players-header{margin-bottom:12px}.players-header h4{margin:0;font-size:14px;color:var(--text);font-weight:600}.players-grid{display:flex;flex-direction:column;gap:8px}.player-item{display:flex;align-items:center;gap:8px;padding:6px;border-radius:8px;transition:background-color .2s ease}.player-item:hover{background:var(--bg1)}.player-name{font-size:13px;color:var(--text);flex:1}.player-badge{font-size:10px;padding:2px 6px;border-radius:12px;background:var(--muted);color:var(--bg);font-weight:600}@keyframes slideInScale{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.sidebar-header{display:flex;align-items:center;justify-content:flex-end;padding:8px 12px;min-height:var(--header-h)}.header-actions{display:flex;align-items:center;gap:4px}
