:root{--bg-primary: #0a0a0f;--bg-secondary: #14141f;--bg-panel: #1a1a2e;--text-primary: #e0e0e0;--text-secondary: #8888aa;--accent: #6c5ce7;--accent-glow: rgba(108, 92, 231, .4);--success: #00b894;--warning: #fdcb6e;--danger: #e17055;--hp-green: #00b894;--hp-yellow: #fdcb6e;--hp-red: #e17055}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;background:var(--bg-primary);color:var(--text-primary);font-family:Segoe UI,system-ui,-apple-system,sans-serif}#dice-container{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}#dice-container canvas{width:100%!important;height:100%!important}.status-bar{position:fixed;bottom:0;left:0;right:0;height:40px;background:var(--bg-secondary);border-top:1px solid rgba(108,92,231,.3);display:flex;align-items:center;justify-content:space-between;padding:0 16px;z-index:100;font-size:14px}.status-left,.status-right{display:flex;align-items:center;gap:8px;min-width:150px}.status-right{justify-content:flex-end}.status-center{font-weight:500;color:var(--text-secondary)}#ptt-touch-target{cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:none;-webkit-touch-callout:none;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:center}#ptt-touch-target:active,.status-bar[data-state=listening] #ptt-touch-target{background:#6c5ce726}.indicator{width:8px;height:8px;border-radius:50%;display:inline-block}.indicator.connected{background:var(--success);box-shadow:0 0 6px var(--success)}.indicator.disconnected{background:var(--danger)}.indicator.connecting{background:var(--warning);animation:blink 1s infinite}@keyframes blink{50%{opacity:.3}}.info-panel{position:fixed;top:0;right:0;width:380px;height:calc(100% - 40px);background:var(--bg-panel);border-left:1px solid rgba(108,92,231,.3);z-index:50;overflow-y:auto;padding:20px;transform:translate(0);transition:transform .3s ease}.info-panel.hidden{transform:translate(100%)}.info-panel-tab{position:fixed;top:50%;right:0;transform:translateY(-50%);z-index:51;width:28px;height:64px;background:var(--bg-panel);border:1px solid rgba(108,92,231,.3);border-right:none;border-radius:10px 0 0 10px;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:none;transition:opacity .3s}.info-panel-tab.hidden{opacity:0;pointer-events:none}.info-panel-tab-icon{color:var(--text-secondary);font-size:14px}@media(max-width:768px){.info-panel{width:100%;border-left:none}}.spell-card{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid var(--accent);border-radius:12px;padding:20px;margin-bottom:16px}.spell-card .spell-name{font-size:22px;font-weight:700;color:var(--accent);margin-bottom:4px}.spell-card .spell-level{font-size:13px;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}.spell-card .spell-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;font-size:13px}.spell-card .spell-meta dt{color:var(--text-secondary)}.spell-card .spell-meta dd{color:var(--text-primary);font-weight:500}.spell-card .spell-desc{font-size:14px;line-height:1.5;color:var(--text-primary);border-top:1px solid rgba(108,92,231,.2);padding-top:12px}.monster-card{background:linear-gradient(135deg,#1a1a2e,#1e1e30);border:1px solid var(--danger);border-radius:12px;padding:20px}.monster-card .monster-name{font-size:22px;font-weight:700;color:var(--danger);margin-bottom:2px}.monster-card .monster-type{font-size:13px;color:var(--text-secondary);font-style:italic;margin-bottom:12px}.monster-card .stat-row{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:14px}.monster-card .stat-label{color:var(--text-secondary)}.monster-card .stat-value{font-weight:600}.monster-card .ability-scores{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin:12px 0;text-align:center}.monster-card .ability-scores .ability{font-size:11px;color:var(--text-secondary);text-transform:uppercase}.monster-card .ability-scores .score{font-size:16px;font-weight:700}.monster-card .ability-scores .modifier{font-size:12px;color:var(--text-secondary)}.initiative-list{list-style:none}.initiative-list .init-header{font-size:16px;font-weight:700;color:var(--accent);margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}.initiative-list .init-entry{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;margin-bottom:4px;font-size:15px;transition:background .2s}.initiative-list .init-entry.active{background:#6c5ce733;border:1px solid var(--accent)}.initiative-list .init-entry .init-roll{font-weight:700;min-width:28px;text-align:center;color:var(--accent)}.initiative-list .init-entry .init-name{flex:1}.hp-bar-container{margin-bottom:12px}.hp-bar-label{display:flex;justify-content:space-between;margin-bottom:4px;font-size:14px}.hp-bar-track{height:16px;background:#ffffff14;border-radius:8px;overflow:hidden}.hp-bar-fill{height:100%;border-radius:8px;transition:width .5s ease,background-color .3s}.hp-bar-fill.hp-high{background:var(--hp-green)}.hp-bar-fill.hp-mid{background:var(--hp-yellow)}.hp-bar-fill.hp-low{background:var(--hp-red)}.dice-breakdown{padding:4px 0}.breakdown-title{font-size:16px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid rgba(108,92,231,.3)}.breakdown-group{margin-bottom:16px;padding:12px;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.06)}.breakdown-notation{font-size:14px;font-weight:600;color:var(--text-secondary);letter-spacing:.5px;margin-bottom:8px}.freq-table{width:100%;border-collapse:collapse;margin-bottom:8px;font-variant-numeric:tabular-nums}.freq-table th{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;text-align:left;padding:4px 8px;border-bottom:1px solid rgba(108,92,231,.3)}.freq-table td{padding:3px 8px;font-size:14px;border-bottom:1px solid rgba(255,255,255,.04)}.freq-roll{font-weight:700;color:var(--accent)}.freq-count{color:var(--text-primary)}.breakdown-dropped{font-size:12px;color:var(--text-secondary);opacity:.7;margin-bottom:4px;font-style:italic}.breakdown-modifier{font-size:13px;color:var(--text-secondary);margin-bottom:4px}.breakdown-total{font-size:18px;font-weight:700;color:var(--text-primary)}.breakdown-grand{display:flex;justify-content:space-between;align-items:center;padding:12px;margin-top:8px;background:#6c5ce726;border:1px solid var(--accent);border-radius:8px}.grand-label{font-size:14px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:1px}.grand-value{font-size:24px;font-weight:700;color:var(--text-primary)}.results-overlay{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:80;transition:opacity .3s}.results-overlay.hidden{opacity:0;pointer-events:none}.results-text{background:var(--bg-panel);border:1px solid var(--accent);border-radius:12px;padding:12px 24px;font-size:24px;font-weight:700;text-align:center;box-shadow:0 4px 24px #00000080,0 0 20px var(--accent-glow)}.listening-indicator{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:90;display:flex;align-items:center;justify-content:center}.listening-indicator.hidden{display:none}.pulse-ring{position:absolute;width:80px;height:80px;border-radius:50%;border:2px solid var(--accent);animation:pulse 1.5s infinite}@keyframes pulse{0%{transform:scale(.8);opacity:1}to{transform:scale(1.6);opacity:0}}.mic-icon{font-size:32px;z-index:1}.status-bar[data-state=listening]{border-top-color:var(--accent);box-shadow:0 -2px 12px var(--accent-glow)}.status-bar[data-state=processing]{border-top-color:var(--warning)}.status-bar[data-state=speaking]{border-top-color:var(--success)}@media(max-width:768px){.status-bar{height:52px}.info-panel{height:calc(100% - 52px)}.settings-panel{bottom:60px}}@media(max-width:480px){.status-bar{height:56px}#connection-text,#box-name{display:none}.status-left,.status-right{min-width:50px}.settings-btn span{display:none}.settings-btn{padding:0;width:30px;justify-content:center}}.mute-btn{background:none;border:1px solid rgba(255,255,255,.15);color:var(--text-secondary);width:28px;height:28px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}.mute-btn:hover{color:var(--text-primary);border-color:var(--accent);background:#6c5ce726}.mute-btn.muted{color:var(--danger);border-color:var(--danger)}.mute-icon.hidden{display:none}.settings-btn{background:#6c5ce726;border:1px solid rgba(108,92,231,.4);color:var(--text-primary);font-size:12px;font-weight:600;height:30px;padding:0 10px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .2s;white-space:nowrap}.settings-btn svg{flex-shrink:0}.settings-btn:hover{color:#fff;border-color:var(--accent);background:#6c5ce74d;box-shadow:0 0 8px var(--accent-glow)}.settings-panel{position:fixed;bottom:48px;right:12px;width:240px;background:var(--bg-panel);border:1px solid rgba(108,92,231,.3);border-radius:12px;padding:16px;z-index:110;box-shadow:0 8px 32px #00000080}.settings-panel.hidden{display:none}.settings-panel h3{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:10px}.settings-panel h3:not(:first-child){margin-top:14px}.skin-picker{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.skin-swatch{width:36px;height:36px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .15s}.skin-swatch:hover{transform:scale(1.15);border-color:#fff6}.skin-swatch.active{border-color:#fff;box-shadow:0 0 8px #ffffff4d}.sound-controls{display:flex;gap:8px}.sound-toggle{background:#00b89433;border:1px solid var(--success);color:var(--success);padding:4px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.sound-toggle.off{background:#ffffff0d;border-color:#ffffff26;color:var(--text-secondary)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#6c5ce74d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#6c5ce780}.texture-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center}.texture-modal.hidden{display:none}.texture-modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009}.texture-modal-content{position:relative;width:480px;max-height:80vh;background:var(--bg-panel);border:1px solid rgba(108,92,231,.3);border-radius:16px;box-shadow:0 16px 64px #0009,0 0 32px var(--accent-glow);display:flex;flex-direction:column;overflow:hidden}.texture-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(108,92,231,.2)}.texture-modal-header h2{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.texture-modal-close{background:none;border:none;color:var(--text-secondary);font-size:22px;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s}.texture-modal-close:hover{color:var(--text-primary)}.texture-modal-body{padding:16px 20px;overflow-y:auto;flex:1}.texture-section{margin-bottom:20px}.texture-section:last-child{margin-bottom:0}.texture-section h3{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:10px}.texture-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.texture-empty{grid-column:1 / -1;text-align:center;color:var(--text-secondary);font-size:13px;padding:16px 0}.texture-thumb{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:all .15s;touch-action:manipulation;user-select:none;-webkit-user-select:none}.texture-thumb[draggable]{cursor:grab}.texture-thumb.dragging{opacity:.4;transform:scale(.95)}.texture-thumb img{width:100%;height:100%;object-fit:cover;display:block}.texture-thumb:hover{border-color:#fff6;transform:scale(1.05)}.texture-thumb.active{border-color:#fff;box-shadow:0 0 8px #ffffff4d}.texture-selection-toolbar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-secondary);border:1px solid rgba(108,92,231,.3);border-radius:8px;margin-bottom:10px}.texture-selection-toolbar.hidden{display:none}.texture-selection-count{flex:1;font-size:13px;font-weight:600;color:var(--text-primary)}.texture-selection-delete{padding:4px 14px;background:#e1705533;border:1px solid var(--danger);border-radius:6px;color:var(--danger);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.texture-selection-delete:hover{background:#e1705566}.texture-selection-cancel{padding:4px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.texture-selection-cancel:hover{background:#ffffff1a;color:var(--text-primary)}.texture-thumb-check{position:absolute;top:4px;left:4px;width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:#0006;display:none;align-items:center;justify-content:center;pointer-events:none;z-index:2}.texture-grid.selection-mode .texture-thumb-check{display:flex}.texture-thumb-check.checked{background:var(--accent);border-color:var(--accent)}.texture-thumb-check.checked:after{content:"✓";color:#fff;font-size:12px;font-weight:700;line-height:1}.texture-thumb.selected{border-color:var(--accent);box-shadow:0 0 10px var(--accent-glow)}.texture-mode-toggle{display:flex;width:100%;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.12);border-radius:8px;overflow:hidden;margin-bottom:8px}.texture-mode-option{flex:1;display:flex;align-items:center;justify-content:center;padding:6px 0;font-size:13px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s;border-radius:6px;margin:2px}.texture-mode-option input[type=radio]{display:none}.texture-mode-option:has(input:checked){background:#6c5ce740;color:var(--text-primary);box-shadow:0 0 8px var(--accent-glow)}.texture-mode-option:hover:not(:has(input:checked)){background:#ffffff0f;color:var(--text-primary)}.texture-wrap-toggle{display:flex;align-items:center;gap:10px;padding:8px 12px;margin-top:8px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.08);border-radius:8px}.texture-wrap-toggle.hidden{display:none}.texture-wrap-label{font-size:12px;color:var(--text-secondary);white-space:nowrap}.texture-wrap-btns{display:flex;flex:1;background:#0003;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.texture-wrap-btn{flex:1;padding:5px 0;font-size:12px;font-weight:600;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:all .2s;border-radius:4px;margin:2px}.texture-wrap-btn.active{background:#6c5ce740;color:var(--text-primary);box-shadow:0 0 8px var(--accent-glow)}.texture-wrap-btn:hover:not(.active){background:#ffffff0f;color:var(--text-primary)}.texture-info-row{width:100%;display:flex;align-items:center;gap:6px}.texture-info-label{font-size:12px;color:var(--text-secondary);cursor:help}.texture-mode-info{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#ffffff1a;color:var(--text-secondary);font-size:10px;font-weight:700;font-style:italic;cursor:help;position:relative;flex-shrink:0}.texture-mode-info:hover{background:#6c5ce74d;color:var(--text-primary)}.texture-mode-tooltip{display:none;position:absolute;bottom:calc(100% + 8px);left:0;background:var(--bg-secondary);border:1px solid rgba(108,92,231,.4);border-radius:8px;padding:10px 12px;font-size:12px;font-style:normal;font-weight:400;color:var(--text-primary);white-space:pre-line;width:240px;z-index:210;box-shadow:0 8px 24px #00000080;pointer-events:none}.texture-mode-info:hover .texture-mode-tooltip,.texture-info-row:hover .texture-mode-tooltip{display:block}.texture-picture-opts{width:100%;display:flex;gap:10px}.texture-picture-opts.hidden{display:none}.texture-opt-label{flex:1;display:flex;flex-direction:column;gap:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.texture-style-select,.texture-res-select{padding:6px 8px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.12);border-radius:6px;color:var(--text-primary);font-size:13px;outline:none;cursor:pointer;transition:border-color .2s}.texture-style-select:focus,.texture-res-select:focus{border-color:var(--accent)}.texture-generate{display:flex;flex-wrap:wrap;gap:8px}.texture-prompt{flex:1;min-width:0;padding:8px 12px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s}.texture-prompt::placeholder{color:var(--text-secondary);opacity:.6}.texture-prompt:focus{border-color:var(--accent)}.texture-generate-btn{padding:8px 20px;background:var(--accent);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.texture-generate-btn:hover:not(:disabled){background:#7c6cf7;box-shadow:0 0 12px var(--accent-glow)}.texture-generate-btn:disabled{opacity:.5;cursor:not-allowed}.texture-status{width:100%;font-size:12px;min-height:18px;color:var(--text-secondary)}.texture-status.error{color:var(--danger)}.texture-status.success{color:var(--success)}.texture-status.loading{color:var(--warning)}.texture-search{width:100%;padding:8px 12px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text-primary);font-size:14px;outline:none;margin-bottom:10px;transition:border-color .2s}.texture-search::placeholder{color:var(--text-secondary);opacity:.6}.texture-search:focus{border-color:var(--accent)}.texture-filter-bar{display:flex;gap:4px;margin-bottom:10px}.texture-filter-btn{padding:4px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.texture-filter-btn:hover{background:#ffffff14;color:var(--text-primary)}.texture-filter-btn.active{background:#6c5ce733;border-color:#6c5ce766;color:var(--text-primary)}.texture-browser{display:flex;gap:10px;min-height:120px}.texture-browser .texture-grid{flex:1;min-width:0}.texture-sidebar{width:100px;flex-shrink:0;overflow-y:auto;border-right:1px solid rgba(255,255,255,.08);padding-right:8px}.texture-sidebar.hidden{display:none}.texture-folder-item{padding:6px 8px;border-radius:6px;font-size:12px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all .15s}.texture-folder-item:hover{background:#ffffff0f;color:var(--text-primary)}.texture-folder-item.active{background:#6c5ce733;color:var(--text-primary);font-weight:600}.texture-folder-item.drag-over{background:#6c5ce74d;border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.texture-folder-item{position:relative;display:flex;align-items:center;justify-content:space-between}.texture-folder-delete{display:none;background:none;border:none;color:var(--text-secondary);font-size:1rem;cursor:pointer;padding:0 2px;line-height:1;flex-shrink:0}.texture-folder-delete:hover{color:var(--danger)}.texture-folder-item:hover .texture-folder-delete{display:block}.texture-folder-new{color:var(--accent);font-style:italic;margin-top:4px;border-top:1px solid rgba(255,255,255,.06);padding-top:8px}.texture-folder-new:hover{color:#7c6cf7}.texture-sidebar-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);padding:8px 10px 2px;font-weight:600}.texture-sidebar-divider{height:1px;background:#ffffff14;margin:6px 0}.texture-login-required{text-align:center;padding:16px;color:var(--text-secondary);background:#ffffff08;border:1px dashed rgba(255,255,255,.1);border-radius:8px;font-style:italic}.texture-folder-actions{position:fixed;z-index:300;background:var(--bg-panel);border:1px solid rgba(108,92,231,.3);border-radius:8px;box-shadow:0 8px 24px #00000080;overflow:hidden;min-width:100px}.texture-folder-action{padding:8px 14px;font-size:13px;color:var(--text-primary);cursor:pointer;transition:background .15s}.texture-folder-action:hover{background:#6c5ce733}.texture-thumb-actions{position:absolute;top:2px;right:2px;display:flex;gap:2px;opacity:0;transition:opacity .15s}.texture-thumb:hover .texture-thumb-actions{opacity:1}.texture-thumb-move{width:20px;height:20px;background:#000000b3;border:none;border-radius:50%;color:var(--text-primary);font-size:11px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.texture-thumb-move:hover{background:#6c5ce799}.texture-move-menu{position:fixed;z-index:300;background:var(--bg-panel);border:1px solid rgba(108,92,231,.3);border-radius:8px;box-shadow:0 8px 24px #00000080;overflow:hidden;min-width:120px;max-height:200px;overflow-y:auto}.texture-move-option{padding:8px 14px;font-size:13px;color:var(--text-primary);cursor:pointer;transition:background .15s}.texture-move-option:hover{background:#6c5ce733}.texture-move-option.active{color:var(--accent);font-weight:600}.texture-move-divider{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);padding:6px 12px 2px;border-top:1px solid rgba(255,255,255,.08);margin-top:2px}.texture-opacity{display:flex;align-items:center;gap:12px}.texture-opacity input[type=range]{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:#ffffff1f;border-radius:3px;outline:none}.texture-opacity input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid #fff;box-shadow:0 0 6px var(--accent-glow)}.texture-opacity input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid #fff;box-shadow:0 0 6px var(--accent-glow)}.texture-opacity-pct{font-size:13px;font-weight:600;color:var(--text-primary);min-width:36px;text-align:right}.dice-input-panel{position:fixed;top:44px;left:50%;transform:translate(-50%);z-index:95;display:flex;flex-direction:column;align-items:center;pointer-events:none}.dice-input-body{display:flex;gap:8px;align-items:center;max-height:0;padding:0 16px;overflow:hidden;background:var(--bg-panel);border:1px solid rgba(108,92,231,.3);border-top:none;border-radius:0 0 12px 12px;box-shadow:0 4px 24px #00000080;transition:max-height .3s ease,padding .3s ease;pointer-events:auto}.dice-input-panel.open .dice-input-body{max-height:80px;padding:16px}.dice-notation-input{width:220px;padding:8px 12px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text-primary);font-size:16px;font-family:Cascadia Code,Fira Code,monospace;outline:none;transition:border-color .2s}.dice-notation-input::placeholder{color:var(--text-secondary);opacity:.6;font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:13px}.dice-notation-input:focus{border-color:var(--accent)}.dice-roll-btn{padding:8px 20px;background:var(--accent);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.dice-roll-btn:hover{background:#7c6cf7;box-shadow:0 0 12px var(--accent-glow)}.dice-input-handle{width:64px;height:28px;background:var(--bg-panel);border:1px solid rgba(108,92,231,.3);border-top:none;border-radius:0 0 10px 10px;display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;pointer-events:auto;touch-action:none;transition:background .2s}.dice-input-handle:hover{background:#6c5ce726}.dice-input-handle-label{display:none}.dice-input-handle-icon{color:var(--text-secondary);font-size:14px;line-height:1;transition:transform .3s ease}.dice-input-panel.open .dice-input-handle-icon{transform:rotate(180deg)}@media(max-width:767px){.dice-input-handle{width:auto;min-width:130px;height:36px;padding:0 16px;background:#6c5ce733;border:1px solid rgba(108,92,231,.5);border-top:none;border-radius:0 0 12px 12px;box-shadow:0 4px 12px #6c5ce733;animation:handle-nudge 2s ease 1s 3}.dice-input-panel.open .dice-input-handle{animation:none}.dice-input-handle-label{display:inline;font-size:13px;font-weight:600;color:var(--accent);letter-spacing:.3px}.dice-input-handle-icon{color:var(--accent);font-size:12px}}@keyframes handle-nudge{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}@media(min-width:768px){.dice-input-panel{top:auto;bottom:56px;pointer-events:auto}.dice-input-body{max-height:80px;padding:10px 16px;border-radius:12px;border:1px solid rgba(108,92,231,.3);background:#1a1a2ed9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 -2px 20px #0006}.dice-input-panel.open .dice-input-body{max-height:80px;padding:10px 16px}.dice-input-handle{display:none}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.dice-notation-input.shake{animation:shake .4s ease;border-color:var(--danger)}.view-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10;background:var(--bg-primary);overflow-y:auto;padding-top:48px}.view-container.hidden{display:none}.view-hidden{display:none!important}.main-nav{position:fixed;top:0;left:0;right:0;height:44px;background:var(--bg-secondary);border-bottom:1px solid rgba(108,92,231,.3);display:flex;align-items:center;padding:0 16px;gap:8px;z-index:150;font-size:14px}.main-nav.hidden{display:none}.nav-link{color:var(--text-secondary);text-decoration:none;padding:6px 12px;border-radius:6px;transition:all .2s;font-weight:500}.nav-link:hover{color:var(--text-primary);background:#ffffff0f}.nav-link.active{color:var(--text-primary);background:#6c5ce733}.nav-spacer{flex:1}.nav-user{color:var(--text-secondary);font-size:13px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-auth-btn{background:none;border:1px solid rgba(108,92,231,.4);color:var(--accent);padding:4px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.nav-auth-btn:hover{background:#6c5ce726;border-color:var(--accent)}.auth-view{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 44px)}.auth-card{width:360px;background:var(--bg-panel);border:1px solid rgba(108,92,231,.3);border-radius:16px;padding:32px;box-shadow:0 16px 64px #00000080}.auth-card h2{font-size:22px;font-weight:700;margin-bottom:24px;text-align:center;color:var(--text-primary)}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-form input{padding:10px 14px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text-primary);font-size:15px;outline:none;transition:border-color .2s}.auth-form input::placeholder{color:var(--text-secondary);opacity:.6}.auth-form input:focus{border-color:var(--accent)}.auth-submit{padding:10px;background:var(--accent);border:none;border-radius:8px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:4px}.auth-submit:hover:not(:disabled){background:#7c6cf7;box-shadow:0 0 16px var(--accent-glow)}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-error{color:var(--danger);font-size:13px;min-height:18px;text-align:center}.auth-switch{text-align:center;margin-top:16px;color:var(--text-secondary);font-size:13px}.auth-switch a{color:var(--accent);text-decoration:none}.auth-switch a:hover{text-decoration:underline}.marketplace-view{max-width:1000px;margin:0 auto;padding:24px 20px}.marketplace-header{margin-bottom:24px}.marketplace-header h2{font-size:22px;font-weight:700;margin-bottom:16px;color:var(--text-primary)}.marketplace-controls{display:flex;gap:12px}.marketplace-search{flex:1;padding:8px 14px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s}.marketplace-search::placeholder{color:var(--text-secondary);opacity:.6}.marketplace-search:focus{border-color:var(--accent)}.marketplace-sort{padding:8px 12px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text-primary);font-size:14px;outline:none;cursor:pointer}.marketplace-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.marketplace-empty{grid-column:1 / -1;text-align:center;color:var(--text-secondary);padding:48px 0;font-size:15px}.marketplace-card{background:var(--bg-panel);border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s}.marketplace-card:hover{border-color:#6c5ce766;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.marketplace-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.marketplace-card-info{padding:10px 12px}.marketplace-card-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.marketplace-card-meta{font-size:12px;color:var(--text-secondary)}.marketplace-card-stats{font-size:11px;color:var(--text-secondary);opacity:.7;margin-top:2px}.marketplace-card-actions{display:flex;gap:6px;padding:0 12px 10px}.marketplace-use-btn{flex:1;padding:6px;background:var(--accent);border:none;border-radius:6px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.marketplace-use-btn:hover:not(:disabled){background:#7c6cf7}.marketplace-use-btn:disabled{opacity:.5;cursor:not-allowed}.marketplace-use-btn.success{background:var(--success)}.marketplace-report-btn{padding:6px 10px;background:none;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-secondary);font-size:11px;cursor:pointer;transition:all .2s}.marketplace-report-btn:hover{border-color:var(--danger);color:var(--danger)}.marketplace-pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding:16px 0}.marketplace-pagination button{padding:6px 16px;background:var(--bg-panel);border:1px solid rgba(108,92,231,.3);border-radius:6px;color:var(--text-primary);font-size:13px;cursor:pointer;transition:all .2s}.marketplace-pagination button:hover:not(:disabled){background:#6c5ce726}.marketplace-pagination button:disabled{opacity:.3;cursor:not-allowed}.marketplace-pagination span{color:var(--text-secondary);font-size:13px}.privacy-page{max-width:700px;margin:0 auto;padding:60px 24px;color:var(--text-secondary);line-height:1.7}.privacy-page h1{font-size:1.8rem;color:var(--text-primary);margin-bottom:.25rem}.privacy-page .privacy-updated{font-size:.85rem;color:var(--text-muted, #666);margin-bottom:2rem}.privacy-page h2{font-size:1.1rem;color:var(--text-primary);margin-top:1.5rem;margin-bottom:.5rem}.privacy-page p{margin-bottom:.75rem}.privacy-back{display:inline-block;margin-top:2rem;color:var(--accent);text-decoration:none;font-size:.9rem}.privacy-back:hover{text-decoration:underline}@media(max-width:480px){.nav-user{display:none}.marketplace-grid{grid-template-columns:repeat(2,1fr);gap:10px}.auth-card{width:90%;padding:24px}}.account-settings-view{max-width:500px;margin:0 auto;padding:24px 20px}.account-settings-view h2{font-size:22px;font-weight:700;margin-bottom:24px;color:var(--text-primary)}.account-section{background:var(--bg-panel);border:1px solid rgba(108,92,231,.2);border-radius:12px;padding:20px;margin-bottom:16px}.account-section h3{font-size:14px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.account-current-value{font-size:13px;color:var(--text-secondary);margin-bottom:10px}.account-form{display:flex;flex-direction:column;gap:10px}.account-form input{padding:10px 14px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text-primary);font-size:15px;outline:none;transition:border-color .2s}.account-form input::placeholder{color:var(--text-secondary);opacity:.6}.account-form input:focus{border-color:var(--accent)}.account-save-btn{padding:10px;background:var(--accent);border:none;border-radius:8px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:2px}.account-save-btn:hover:not(:disabled){background:#7c6cf7;box-shadow:0 0 16px var(--accent-glow)}.account-save-btn:disabled{opacity:.5;cursor:not-allowed}.account-status{font-size:13px;min-height:18px;text-align:center}.account-status.success{color:var(--success)}.account-status.error{color:var(--danger)}@media(max-width:480px){.account-settings-view{padding:16px 12px}.account-section{padding:16px}}
