@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Crimson+Text:ital,wght@0,400;0,600;1,400&family=JetBrains+Mono:wght@400&display=swap";:root{--bg-deep:#0a0b10;--bg-base:#0f1118;--bg-surface:#161822;--bg-elevated:#1e2030;--border:#2a2540;--border-bright:#3d3660;--text-primary:#d4c8a8;--text-secondary:#8a7e6a;--text-muted:#5a5040;--gold:#c9a84c;--gold-dim:#c9a84c1f;--gold-glow:#c9a84c40;--red-dim:#8b202033;--purple:#6b3fa0;--purple-dim:#6b3fa026;--radius:8px;--radius-sm:6px;--font-display:"Cinzel", serif;--font-body:"Crimson Text", serif;--mono:"JetBrains Mono", monospace}*{box-sizing:border-box;margin:0;padding:0}body,#root{font-family:var(--font-body);background:var(--bg-deep);color:var(--text-primary);min-height:100vh;font-size:18px}.app{max-width:var(--app-max-width,480px);zoom:var(--app-zoom,1);background:var(--bg-base);background-image:radial-gradient(at 20% 0,#6b3fa00f 0%,#0000 60%),radial-gradient(at 80% 100%,#c9a84c0a 0%,#0000 60%);flex-direction:column;min-height:100vh;margin:0 auto;display:flex;position:relative}.header{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background:linear-gradient(#0f1118fa,#0f1118eb);padding:18px 20px 14px;position:sticky;top:0}.header-row{justify-content:space-between;align-items:center;display:flex}.header h1{font-family:var(--font-display);color:var(--gold);text-shadow:0 0 20px var(--gold-glow);letter-spacing:.8px;font-size:24px;font-weight:700}.header-sub{color:var(--text-muted);font-size:13px;font-family:var(--mono);letter-spacing:.5px;margin-top:1px}.icon-btn{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;transition:all .2s;display:flex;overflow:hidden}.icon-btn:hover{border-color:var(--gold);color:var(--gold)}.icon-btn img{object-fit:cover;border-radius:var(--radius);width:100%;height:100%}.content{flex:1;padding:16px 20px 90px;overflow-y:auto}.quest-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-bottom:10px;padding:16px;transition:all .25s;position:relative;overflow:hidden}.quest-card:before{content:"";background:linear-gradient(180deg, var(--gold), var(--purple));opacity:.6;width:3px;height:100%;position:absolute;top:0;left:0}.quest-card:hover{border-color:var(--gold);transform:translateY(-1px);box-shadow:0 0 24px #c9a84c14}.quest-card:hover:before{opacity:1}.quest-date{font-family:var(--mono);color:var(--gold);text-transform:uppercase;letter-spacing:1px;margin-bottom:5px;font-size:13px}.quest-title{font-family:var(--font-display);letter-spacing:.3px;margin-bottom:3px;font-size:20px;font-weight:600}.quest-loc{color:var(--text-secondary);align-items:center;gap:5px;font-size:16px;font-style:italic;display:flex}.quest-footer{gap:8px;margin-top:10px;display:flex}.quest-badge{font-family:var(--mono);color:var(--gold);background:var(--gold-dim);border-radius:4px;align-items:center;gap:4px;padding:4px 10px;font-size:14px;display:flex}.fab{border:2px solid var(--gold);width:52px;height:52px;color:var(--bg-deep);cursor:pointer;box-shadow:0 4px 20px var(--gold-glow), inset 0 1px 2px #fff3;z-index:20;background:radial-gradient(circle at 30% 30%,#d4a84c,#8b6914);border-radius:50%;justify-content:center;align-items:center;font-size:24px;transition:all .2s;display:flex;position:fixed;bottom:70px;right:calc(50% - 210px)}.fab:hover{transform:scale(1.1)}@media (width<=520px){.fab{right:20px}}.bottom-nav{width:100%;max-width:var(--app-max-width,480px);background:var(--bg-surface);border-top:1px solid var(--border);z-index:30;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-tab{color:var(--text-muted);font-family:var(--font-display);cursor:pointer;letter-spacing:.8px;text-transform:uppercase;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:2px;padding:9px 0;font-size:13px;font-weight:600;transition:color .15s;display:flex}.nav-tab.active{color:var(--gold)}.form-group{margin-bottom:14px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:14px;font-weight:600;font-family:var(--font-display);margin-bottom:5px;display:block}.form-input,.form-textarea{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-body);outline:none;padding:10px 14px;font-size:18px;transition:border-color .15s}.form-input:focus,.form-textarea:focus{border-color:var(--gold)}.form-textarea{resize:vertical;min-height:60px}.btn{border-radius:var(--radius-sm);border:1px solid var(--border);font-family:var(--font-display);cursor:pointer;letter-spacing:.5px;justify-content:center;align-items:center;gap:6px;padding:12px 24px;font-size:16px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{border:1px solid var(--gold);color:var(--bg-deep);background:linear-gradient(135deg,#c9a84c,#8b6914)}.btn-primary:hover{box-shadow:0 2px 16px var(--gold-glow)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-bright)}.btn-danger{background:var(--red-dim);color:#c44;border-color:#0000}.btn-row{gap:8px;margin-top:16px;display:flex}.section-title{font-family:var(--font-display);color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;align-items:center;gap:8px;margin:20px 0 10px;font-size:15px;font-weight:700;display:flex}.detail-title{font-family:var(--font-display);color:var(--gold);text-shadow:0 0 30px #c9a84c26;letter-spacing:.5px;margin-bottom:6px;font-size:26px;font-weight:700}.detail-desc{color:var(--text-secondary);margin-bottom:4px;font-size:18px;font-style:italic;line-height:1.6}.detail-meta{flex-direction:column;gap:6px;margin:12px 0;display:flex}.detail-meta-item{color:var(--text-secondary);align-items:center;gap:8px;font-size:17px;display:flex}.divider{background:var(--border);height:1px;margin:16px 0}.item-row{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);align-items:center;gap:10px;margin-bottom:6px;padding:10px 12px;animation:.2s ease-out fadeUp;display:flex}.item-name{flex:1;font-size:18px}.item-assigned{background:var(--gold-dim);color:var(--gold);font-size:14px;font-family:var(--font-display);letter-spacing:.3px;border-radius:4px;padding:2px 8px}.item-claim-btn{border:1px solid var(--border);color:var(--gold);cursor:pointer;font-size:15px;font-family:var(--font-display);letter-spacing:.3px;background:0 0;border-radius:4px;padding:6px 14px}.item-claim-btn:hover{background:var(--gold-dim);border-color:var(--gold)}.add-item-row{gap:8px;margin-top:8px;display:flex}.add-item-row input{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);outline:none;flex:1;padding:8px 12px;font-size:14px}.add-item-row input:focus{border-color:var(--gold)}.char-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;padding:16px;animation:.25s ease-out fadeUp}.char-card-header{align-items:center;gap:12px;margin-bottom:12px;display:flex}.char-avatar{background:var(--purple-dim);border:2px solid var(--border-bright);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:32px;transition:border-color .2s;display:flex;overflow:hidden}.char-avatar:hover{border-color:var(--gold)}.char-avatar img{object-fit:cover;width:100%;height:100%}.char-name{font-family:var(--font-display);color:var(--gold);font-size:20px;font-weight:600}.char-player{color:var(--text-muted);font-size:15px;font-family:var(--mono)}.char-upload-zone{border:2px dashed var(--border-bright);border-radius:var(--radius-sm);text-align:center;color:var(--text-muted);cursor:pointer;font-size:18px;font-family:var(--font-display);letter-spacing:.5px;padding:32px 16px;transition:all .2s}.char-upload-zone:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}.char-photo{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;width:100%;transition:opacity .2s}.char-photo:hover{opacity:.85}.char-photo-overlay{z-index:200;cursor:pointer;background:#000000e6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.char-photo-overlay img{border-radius:var(--radius);max-width:100%;max-height:90vh}.sheet-tabs{border-radius:var(--radius-sm);border:1px solid var(--border);gap:0;margin-bottom:12px;display:flex;overflow:hidden}.sheet-tab{text-align:center;font-family:var(--font-display);letter-spacing:.5px;cursor:pointer;background:var(--bg-elevated);color:var(--text-muted);border:none;flex:1;padding:10px;font-size:14px;font-weight:600;transition:all .15s}.sheet-tab.active{background:var(--gold-dim);color:var(--gold)}.stat-grid{grid-template-columns:repeat(3,1fr);gap:6px;margin:10px 0;display:grid;overflow:hidden}.stat-box{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:8px;transition:border-color .15s}.stat-box:focus-within{border-color:var(--gold)}.stat-label{font-family:var(--font-display);color:var(--text-muted);letter-spacing:1px;margin-bottom:2px;font-size:13px;font-weight:700}.stat-value{font-family:var(--mono);color:var(--text-primary);font-size:22px;font-weight:700}.stat-box .num-val-display{background:0 0;border:none;padding:4px 2px;font-size:22px}.stat-value input{text-align:center;width:100%;color:var(--text-primary);font-family:var(--mono);background:0 0;border:none;outline:none;font-size:22px;font-weight:700}.stat-mod{font-family:var(--mono);color:var(--gold);margin-top:1px;font-size:16px}.combat-grid{grid-template-columns:repeat(4,1fr);gap:6px;margin:10px 0;display:grid;overflow:hidden}.combat-box{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:8px}.combat-box:focus-within{border-color:var(--gold)}.combat-label{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.5px;margin-bottom:2px;font-size:12px;font-weight:700}.combat-val input{text-align:center;width:100%;color:var(--gold);font-family:var(--mono);background:0 0;border:none;outline:none;font-size:18px;font-weight:700}.sheet-field{margin-bottom:10px}.sheet-field-label{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase;margin-bottom:4px;font-size:13px;font-weight:700}.sheet-field textarea{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-body);resize:vertical;outline:none;min-height:50px;padding:10px 12px;font-size:17px}.sheet-field textarea:focus{border-color:var(--gold)}.sheet-row{grid-template-columns:1fr 1fr;gap:6px;margin-bottom:8px;display:grid;overflow:hidden}.sheet-row-3{grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:8px;display:grid;overflow:hidden}.sheet-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);outline:none;width:100%;padding:10px 12px;font-size:17px}.sheet-input:focus{border-color:var(--gold)}.sheet-input-label{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.5px;margin-bottom:3px;font-size:12px}.user-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.user-btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary);font-family:var(--font-display);cursor:pointer;letter-spacing:.5px;justify-content:flex-start;align-items:center;gap:10px;padding:16px;font-size:18px;font-weight:600;transition:all .2s;display:flex}.user-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}.user-btn-avatar{background:var(--purple-dim);border:1px solid var(--border-bright);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex;overflow:hidden}.user-btn-avatar img{object-fit:cover;width:100%;height:100%}.login-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-top:16px;padding:24px;animation:.2s ease-out fadeUp}.login-title{font-family:var(--font-display);color:var(--gold);text-align:center;margin-bottom:4px;font-size:22px;font-weight:600}.login-sub{color:var(--text-muted);text-align:center;margin-bottom:16px;font-size:16px}.login-error{color:#c44;text-align:center;font-size:16px;font-family:var(--font-display);letter-spacing:.3px;margin-top:8px}.login-avatar{background:var(--purple-dim);border:2px solid var(--border-bright);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 8px;font-size:36px;display:flex;overflow:hidden}.login-avatar img{object-fit:cover;width:100%;height:100%}.empty-state{text-align:center;color:var(--text-muted);padding:50px 20px}.empty-state-icon{opacity:.4;margin-bottom:12px;font-size:56px}.empty-state-text{font-family:var(--font-display);letter-spacing:.5px;font-size:18px;line-height:1.6}.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.sheet-section{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden}.sheet-section-header{background:var(--bg-elevated);cursor:pointer;font-family:var(--font-display);color:var(--gold);letter-spacing:.5px;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 14px;font-size:14px;font-weight:700;transition:background .15s;display:flex}.sheet-section-header:hover{background:var(--gold-dim)}.sheet-section-body{padding:12px;animation:.15s ease-out fadeUp}.skills-list{flex-direction:column;gap:4px;display:flex}.skill-row{border-radius:4px;align-items:center;gap:8px;padding:5px 8px;transition:background .1s;display:flex}.skill-row:hover{background:var(--bg-elevated)}.skill-prof{cursor:pointer;align-items:center;display:flex}.skill-prof input{display:none}.skill-dot{border:2px solid var(--border-bright);border-radius:50%;width:18px;height:18px;transition:all .15s}.skill-prof input:checked+.skill-dot{background:var(--gold);border-color:var(--gold)}.skill-mod{font-family:var(--mono);color:var(--text-primary);text-align:center;min-width:32px;font-size:15px;font-weight:700}.skill-name{color:var(--text-primary);flex:1;font-size:15px}.skill-stat{font-family:var(--mono);color:var(--text-muted);font-size:11px}.spell-level-block{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px;overflow:hidden}.spell-level-header{background:var(--bg-elevated);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.spell-level-title{font-family:var(--font-display);color:var(--gold);letter-spacing:.5px;font-size:13px;font-weight:700}.spell-slots-input{align-items:center;gap:6px;display:flex}.spell-textarea{background:var(--bg-base);border:none;border-top:1px solid var(--border);width:100%;color:var(--text-primary);font-family:var(--font-body);resize:vertical;outline:none;min-height:40px;padding:8px 12px;font-size:15px}.spell-textarea:focus{background:var(--bg-surface)}.spell-entry{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;transition:border-color .15s;overflow:hidden}.spell-entry:hover{border-color:var(--border-bright)}.spell-entry-editing{background:var(--bg-elevated);padding:10px}.spell-entry-header{cursor:pointer;background:var(--bg-elevated);justify-content:space-between;align-items:center;padding:10px 12px;transition:background .15s;display:flex}.spell-entry-header:hover{background:var(--gold-dim)}.spell-entry-name{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.3px;font-size:15px;font-weight:600}.spell-expand-icon{color:var(--text-muted);font-size:11px}.spell-edit-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px;transition:all .15s}.spell-edit-btn:hover{color:var(--gold);background:var(--gold-dim)}.spell-entry-desc{color:var(--text-secondary);border-top:1px solid var(--border);background:var(--bg-base);white-space:pre-wrap;padding:10px 12px;font-size:15px;line-height:1.6;animation:.15s ease-out fadeUp}.spell-add-btn{border:1px dashed var(--border-bright);border-radius:var(--radius-sm);width:100%;color:var(--text-muted);font-family:var(--font-display);cursor:pointer;letter-spacing:.5px;background:0 0;padding:8px;font-size:13px;transition:all .15s}.spell-add-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}.mini-char-sheet{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}.mini-char-header{cursor:pointer;align-items:center;gap:10px;padding:12px 14px;transition:background .15s;display:flex}.mini-char-header:hover{background:var(--bg-elevated)}.mini-char-avatar{border:2px solid var(--border-bright);background:var(--purple-dim);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex;overflow:hidden}.mini-char-avatar img{object-fit:cover;width:100%;height:100%}.mini-char-info{flex:1}.mini-char-name{font-family:var(--font-display);color:var(--gold);font-size:16px;font-weight:700}.mini-char-stats{font-family:var(--mono);color:var(--text-muted);font-size:12px}.mini-char-hp-group{align-items:center;gap:8px;display:flex}.mini-char-hp{border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);flex-direction:column;align-items:center;padding:4px 10px;display:flex}.mini-char-hp-critical{border-color:#c44;animation:1.5s ease-in-out infinite criticalPulse}.mini-char-hp-label{font-family:var(--font-display);color:var(--text-muted);letter-spacing:1px;font-size:9px}.mini-char-hp-value{font-family:var(--mono);color:var(--gold);font-size:18px;font-weight:700}.mini-char-hp-critical .mini-char-hp-value{color:#e55}.mini-char-body{border-top:1px solid var(--border);padding:12px 14px;animation:.15s ease-out fadeUp}.party-bar{gap:4px;margin-bottom:12px;display:flex}.party-chip{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;flex:1;align-items:center;gap:2px;min-width:0;padding:6px 4px;transition:all .2s;display:flex;overflow:hidden}.party-chip-critical{border-color:#c44;animation:1.5s ease-in-out infinite criticalPulse}.party-chip-avatar{width:28px;height:28px;font-size:11px;font-family:var(--font-display);color:var(--text-muted);background:var(--purple-dim);border:1px solid var(--border-bright);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex;overflow:hidden}.party-chip-avatar img{object-fit:cover;width:100%;height:100%}.party-chip-name{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.5px;font-size:9px;font-weight:700;line-height:1}.party-chip-hp{font-family:var(--mono);color:var(--gold);font-size:12px;font-weight:700;line-height:1.2}.party-chip-hp-crit{color:#e55}.feed-quick-actions{margin-bottom:12px}.feed-list{flex-direction:column;gap:6px;display:flex}.feed-card{background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid var(--gold);border-radius:var(--radius-sm);padding:10px 12px;animation:.3s ease-out feedSlideIn}.feed-card-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.feed-card-avatar{background:var(--purple-dim);border:1px solid var(--border-bright);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;display:flex;overflow:hidden}.feed-card-avatar img{object-fit:cover;width:100%;height:100%}.feed-card-info{flex:1;justify-content:space-between;align-items:center;display:flex}.feed-card-name{font-family:var(--font-display);color:var(--gold);font-size:13px;font-weight:600}.feed-card-time{font-family:var(--mono);color:var(--text-muted);font-size:11px}.feed-card-body{color:var(--text-primary);align-items:center;gap:8px;font-size:15px;display:flex}.feed-card-icon{flex-shrink:0;font-size:18px}.feed-card-text{flex:1;line-height:1.4}.feed-card-value{font-family:var(--mono);flex-shrink:0;font-size:18px;font-weight:700}@keyframes feedSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.chat-wrap{flex-direction:column;height:100%;display:flex}.chat-input-bar{border-bottom:1px solid var(--border);background:var(--bg-surface);z-index:5;gap:8px;padding:12px 16px;display:flex;position:sticky;top:0}.chat-input{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);font-family:var(--font-body);border-radius:20px;outline:none;flex:1;padding:10px 14px;font-size:16px}.chat-input:focus{border-color:var(--gold)}.chat-notify-btn{background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;transition:all .15s;display:flex}.chat-notify-btn:hover{border-color:var(--gold)}.chat-notify-on{border-color:var(--gold);background:var(--gold-dim)}.chat-send-btn{border:1px solid var(--gold);width:44px;height:44px;color:var(--bg-deep);cursor:pointer;background:linear-gradient(135deg,#c9a84c,#8b6914);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:flex}.chat-send-btn:hover{box-shadow:0 2px 16px var(--gold-glow)}.chat-send-btn:disabled{opacity:.4;cursor:default}.chat-messages{flex-direction:column;flex:1;gap:8px;padding:12px 16px;display:flex}.chat-msg{gap:8px;max-width:85%;animation:.2s ease-out fadeUp;display:flex}.chat-msg-me{flex-direction:row-reverse;align-self:flex-end}.chat-msg-other{align-self:flex-start}.chat-msg-avatar{background:var(--purple-dim);border:1px solid var(--border-bright);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;margin-top:2px;font-size:16px;display:flex;overflow:hidden}.chat-msg-avatar img{object-fit:cover;width:100%;height:100%}.chat-msg-bubble{border-radius:16px;padding:10px 14px;line-height:1.4}.chat-msg-other .chat-msg-bubble{background:var(--bg-surface);border:1px solid var(--border);border-top-left-radius:4px}.chat-msg-me .chat-msg-bubble{background:var(--gold-dim);border:1px solid #c9a84c4d;border-top-right-radius:4px}.chat-msg-name{font-family:var(--font-display);color:var(--gold);margin-bottom:2px;font-size:12px;font-weight:700}.chat-msg-text{color:var(--text-primary);white-space:pre-wrap;word-break:break-word;font-size:16px}.chat-msg-footer{justify-content:flex-end;align-items:center;gap:8px;margin-top:4px;display:flex}.chat-msg-time{font-family:var(--mono);color:var(--text-muted);font-size:10px}.chat-msg-delete{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:12px;transition:all .15s}.chat-msg-bubble:hover .chat-msg-delete{opacity:1}.chat-msg-delete:hover{color:#c44;background:var(--red-dim)}.dice-result-display{justify-content:center;padding:20px 0;display:flex}.dice-result-big{border:3px solid var(--border-bright);background:var(--bg-surface);border-radius:16px;flex-direction:column;justify-content:center;align-items:center;width:160px;height:160px;transition:all .3s;display:flex;position:relative}.dice-result-big.dice-idle{opacity:.6;border-style:dashed}.dice-result-big.dice-spinning{animation:80ms infinite alternate diceShake;box-shadow:0 0 30px #c9a84c4d}.dice-result-big.dice-landed{animation:.4s ease-out diceLand;box-shadow:0 0 40px #c9a84c66}.dice-result-label{font-family:var(--font-display);color:var(--text-muted);letter-spacing:1px;margin-bottom:2px;font-size:14px}.dice-result-value{font-family:var(--mono);font-size:52px;font-weight:700;line-height:1}.dice-result-detail{font-family:var(--mono);color:var(--text-muted);margin-top:4px;font-size:11px}.dice-options{justify-content:center;gap:20px;margin-bottom:16px;display:flex}.dice-option{flex-direction:column;align-items:center;gap:4px;display:flex}.dice-option-label{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase;font-size:11px}.dice-stepper{border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:0;display:flex;overflow:hidden}.dice-stepper-btn{background:var(--bg-elevated);width:36px;height:36px;color:var(--gold);cursor:pointer;border:none;justify-content:center;align-items:center;font-size:20px;transition:background .15s;display:flex}.dice-stepper-btn:hover{background:var(--gold-dim)}.dice-stepper-value{text-align:center;min-width:44px;font-family:var(--mono);color:var(--text-primary);background:var(--bg-surface);height:36px;font-size:18px;font-weight:700;line-height:36px}.dice-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.dice-btn{border-radius:var(--radius);border:2px solid var(--border);background:var(--bg-surface);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:14px 8px;transition:all .2s;display:flex}.dice-btn:hover{border-color:var(--dice-color);background:color-mix(in srgb, var(--dice-color) 10%, var(--bg-surface));box-shadow:0 4px 16px color-mix(in srgb, var(--dice-color) 25%, transparent);transform:translateY(-2px)}.dice-btn:disabled{opacity:.5;pointer-events:none}.dice-btn-icon{font-size:28px}.dice-btn-label{font-family:var(--font-display);color:var(--dice-color);letter-spacing:.5px;font-size:14px;font-weight:700}.dice-history{flex-direction:column;gap:4px;display:flex}.dice-history-row{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);align-items:center;gap:8px;padding:8px 10px;animation:.2s ease-out fadeUp;display:flex}.dice-history-badge{font-family:var(--font-display);white-space:nowrap;border:1px solid;border-radius:4px;padding:2px 8px;font-size:12px;font-weight:700}.dice-history-rolls{font-family:var(--mono);color:var(--text-secondary);flex:1;font-size:13px}.dice-history-total{font-family:var(--mono);font-size:18px;font-weight:700}.dice-history-time{font-family:var(--mono);color:var(--text-muted);font-size:10px}.critical-alert-container{width:100%;max-width:var(--app-max-width,480px);z-index:100;pointer-events:none;flex-direction:column;gap:6px;padding:0 12px;display:flex;position:fixed;top:70px;left:50%;transform:translate(-50%)}.critical-alert-popup{border-radius:var(--radius);pointer-events:all;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1e0808f2;border:2px solid #c44;align-items:center;gap:10px;padding:10px 14px;animation:.4s ease-out criticalSlideIn,1.5s ease-in-out infinite criticalPulse;display:flex;box-shadow:0 4px 24px #c446}.critical-alert-photo{background:var(--purple-dim);border:2px solid #c44;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex;overflow:hidden}.critical-alert-photo img{object-fit:cover;width:100%;height:100%}.critical-alert-info{flex:1}.critical-alert-name{font-family:var(--font-display);color:var(--text-primary);font-size:15px;font-weight:700}.critical-alert-hp{font-family:var(--mono);color:#e55;font-size:18px;font-weight:700}.critical-alert-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:18px;transition:color .15s}.critical-alert-close:hover{color:var(--text-primary)}@keyframes criticalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.num-val-wrap{position:relative}.num-val-label{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.5px;margin-bottom:3px;font-size:12px}.num-val-display{text-align:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--mono);cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 6px;font-size:18px;font-weight:700;transition:all .2s}.num-val-display:hover{border-color:var(--gold);color:var(--gold)}.num-val-display:active{transform:scale(.97)}.num-flash-up{animation:.3s ease-out flashGreen}.num-flash-down{animation:.3s ease-out flashRed}.num-val-critical{color:#e55;border-color:#c44;animation:1.5s ease-in-out infinite criticalPulse;box-shadow:0 0 12px #cc44444d}.num-popup-backdrop{z-index:500;background:#0009;position:fixed;inset:0}.num-popup{z-index:501;background:var(--bg-surface);border:2px solid var(--gold);border-radius:var(--radius);min-width:280px;max-width:340px;box-shadow:0 8px 40px #00000080, 0 0 30px var(--gold-glow);padding:20px;animation:.2s ease-out popupIn;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.num-popup-label{font-family:var(--font-display);color:var(--gold);text-align:center;letter-spacing:.5px;margin-bottom:12px;font-size:14px}.num-popup-row{align-items:center;gap:6px;display:flex}.num-popup-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elevated);width:44px;height:44px;color:var(--gold);font-family:var(--mono);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;transition:all .15s;display:flex}.num-popup-btn:hover{background:var(--gold-dim);border-color:var(--gold)}.num-popup-btn:active{transform:scale(.92)}.num-popup-input{text-align:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:0;color:var(--text-primary);font-family:var(--mono);-moz-appearance:textfield;outline:none;flex:1;padding:8px 4px;font-size:28px;font-weight:700}.num-popup-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.num-popup-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.num-popup-input:focus{border-color:var(--gold);color:var(--gold)}.num-popup-done{border:1px solid var(--gold);border-radius:var(--radius-sm);width:100%;color:var(--bg-deep);font-family:var(--font-display);cursor:pointer;letter-spacing:.5px;background:linear-gradient(135deg,#c9a84c,#8b6914);margin-top:12px;padding:10px;font-size:15px;font-weight:700;transition:box-shadow .15s;display:block}.num-popup-done:hover{box-shadow:0 2px 16px var(--gold-glow)}.toast-popup{z-index:400;border:2px solid var(--gold);font-family:var(--font-display);color:var(--bg-deep);letter-spacing:.5px;box-shadow:0 4px 24px var(--gold-glow), 0 0 20px var(--gold-glow);white-space:nowrap;text-shadow:0 1px 2px #0003;background:linear-gradient(135deg,#c9a84c,#8b6914);border-radius:20px;padding:10px 24px;font-size:14px;font-weight:700;animation:.3s ease-out toastIn,.4s ease-in 3s forwards toastOut;position:fixed;top:70px;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}@keyframes popupIn{0%{opacity:0;transform:translate(-50%,-50%)scale(.9)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.char-card-critical{animation:1.5s ease-in-out infinite criticalPulse;position:relative;box-shadow:0 0 20px #cc444440;border-color:#c44!important}.critical-badge{color:#e55;font-family:var(--mono);background:#cc444426;border:1px solid #c446;border-radius:4px;align-items:center;gap:4px;margin-top:6px;padding:3px 10px;font-size:12px;font-weight:700;animation:1.5s ease-in-out infinite criticalPulse;display:inline-flex}@keyframes criticalPulse{0%,to{box-shadow:0 0 8px #c443}50%{box-shadow:0 0 24px #cc444480}}@keyframes flashGreen{0%{background:#4a9e6b4d}to{background:var(--bg-surface)}}@keyframes flashRed{0%{background:#cc44444d}to{background:var(--bg-surface)}}@keyframes diceShake{0%{transform:translate(-2px,-1px)rotate(-2deg)}to{transform:translate(2px,1px)rotate(2deg)}}@keyframes diceLand{0%{transform:scale(1.3)}50%{transform:scale(.95)}to{transform:scale(1)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
