@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: 340px;--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}.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:16px;border-radius:16px;border:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;flex-direction:column;gap:12px;min-width:600px}.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,.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%}}.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}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.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}.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}
