@import"https://fonts.googleapis.com/css2?family=Mulish:wght@300;400;600;800&display=swap";:root{--bg:#0b0e14;--bg1:#0f1320;--bg2:#121725;--rail:#111521;--accent:#f7d76c;--text:#e7ecff;--ink1:#c6cdf0;--muted:#99a3c7;--border:#293047;--shadow:0 10px 30px rgba(0,0,0,.45);--rail-w: 280px;--tray-h: 60px;--gap: 16px;--header-h: 48px}*{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:.85}.bg-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 60%,rgba(0,0,0,.4) 100%)}.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:color-mix(in oklab,var(--rail) 85%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-left:1px solid var(--border);width:var(--rail-w);min-width:var(--rail-w);max-width:var(--rail-w);overflow:hidden;contain:layout style size}.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:color-mix(in oklab,var(--bg1) 90%,transparent);border:1px solid var(--border);border-radius:16px;padding:12px;margin-bottom:12px;box-shadow:var(--shadow);width:100%;max-width:100%;box-sizing:border-box;overflow:hidden;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.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(--bg1);color:var(--text);border:1px solid var(--border);padding:8px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:40px;min-height:40px;position:relative;transition:all .2s ease}.action-btn:hover{border-color:var(--accent);background:color-mix(in oklab,var(--bg1) 95%,var(--accent) 5%)}.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:140px;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:280px;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:420px;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 rgba(255,255,255,.4);background:#0009;color:#fff;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-weight:600;border-radius:4px}.mod-btn-wire:nth-child(1),.mod-btn-wire:nth-child(2),.mod-btn-wire:nth-child(3){width:60px;height:40px;font-size:14px}.mod-btn-wire.advantage,.mod-btn-wire.disadvantage{width:80px;height:40px;font-size:14px}.mod-btn-wire.positive{color:#4ecdc4}.mod-btn-wire.negative{color:#f99}.mod-btn-wire:hover{background:#fff3;transform:translateY(-1px)}.mod-btn-wire.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.action-buttons{left:50%;top:540px;transform:translate(-50%);display:flex;gap:20px;justify-content:center}.roll-btn-primary{width:200px;height:60px;background:#000;border:2px solid #f7d76c;color:#f7d76c;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-primary:hover{background:#f7d76c;color:#000;transform:translateY(-2px);box-shadow:0 4px 12px #f7d76c66}.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:550px;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)}.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:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.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}}.dice-tray-bottom{position:fixed;bottom:0;left:0;right:0;height:118px;background:transparent;z-index:3000;display:flex;align-items:center;justify-content:center;pointer-events:none}.dice-tray-container{display:flex;align-items:center;justify-content:center;width:100%;max-width:1200px;padding:16px 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 .3s ease,filter .3s ease,opacity .3s ease!important;opacity:1}.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}
