@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,html.theme-dark{--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;--surface:var(--bg-surface);--surface-elevated:var(--bg-elevated);--background:var(--bg-deep)}html.theme-light{--bg-deep:#f5f1e8;--bg-base:#fff;--bg-surface:#fff;--bg-elevated:#f0ebdc;--border:#b8a878;--border-bright:#8a7642;--text-primary:#1a1408;--text-secondary:#3d2f15;--text-muted:#6b5a3d;--gold:#8a6a1c;--gold-dim:#8a6a1c1f;--gold-glow:#8a6a1c4d;--red-dim:#b428282e;--purple:#4a2880;--purple-dim:#4a28802e;--surface:var(--bg-surface);--surface-elevated:var(--bg-elevated);--background:var(--bg-deep)}*{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;transition:background .25s,color .25s}textarea{field-sizing:content;resize:none;min-height:2.6em;overflow:hidden}.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}.dm-cockpit{grid-template-columns:1fr 290px;align-items:start;gap:14px;padding-bottom:80px;display:grid}.dm-cockpit-title{font-family:var(--font-display);color:var(--gold);letter-spacing:1px;border-bottom:1px solid var(--border);align-items:baseline;gap:12px;margin-bottom:14px;padding-bottom:10px;font-size:22px;display:flex}.dm-cockpit-subtitle{color:var(--text-muted);letter-spacing:0;font-size:13px;font-style:italic}.dm-col-side{max-height:calc(100vh - 80px);position:sticky;top:0;overflow-y:auto}.dm-col-main{min-width:0}.dm-sidebar{flex-direction:column;gap:0;display:flex}.dm-sidebar-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:10px;padding-bottom:0;display:flex}.dm-sidebar-tab{border:1px solid var(--border);color:var(--text-secondary);font-family:var(--font-display);letter-spacing:.5px;cursor:pointer;border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:0 0;border-bottom:none;flex:1;padding:8px 10px;font-size:13px;transition:all .15s}.dm-sidebar-tab:hover{color:var(--gold);border-color:var(--gold)}.dm-sidebar-tab.active{background:var(--surface);color:var(--gold);border-color:var(--gold)}.dm-sidebar-body{flex:1}.dm-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;display:grid}@media (width<=1500px){.dm-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=1100px){.dm-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.dm-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:6px;min-width:0;padding:8px;transition:border-color .3s,box-shadow .3s;display:flex}.dm-card-critical{border-color:#c44;box-shadow:inset 0 0 0 1px #c44}.dm-card-hl{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold) inset, 0 0 18px #c9a84c59;animation:1.6s ease-out dmCardPulse}@keyframes dmCardPulse{0%{box-shadow:0 0 0 2px var(--gold) inset, 0 0 28px #c9a84cb3}to{box-shadow:0 0 0 1px var(--gold) inset, 0 0 18px #c9a84c59}}.dm-card-head{align-items:center;gap:10px;display:flex}.dm-card-portrait{background:var(--surface-elevated);border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex;overflow:hidden}.dm-card-portrait img{object-fit:cover;width:100%;height:100%}.dm-card-id{flex:1;min-width:0}.dm-card-name{font-family:var(--font-display);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;overflow:hidden}.dm-card-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.dm-card-presence{color:var(--text-muted);margin-top:1px;font-size:10px}.dm-card-warnings{flex-wrap:wrap;gap:4px;display:flex}.dm-warn-badge{color:#ff7878;letter-spacing:.5px;background:#c444442e;border:1px solid #c4444466;border-radius:3px;padding:2px 6px;font-size:10px}.dm-hp-row{gap:6px;display:flex}.dm-hp-block{flex:1}.dm-quickstats{grid-template-columns:repeat(4,1fr);gap:3px;display:grid}.dm-stat{background:var(--surface-elevated);border-radius:var(--radius-sm);text-align:center;border:1px solid var(--border);min-width:0;padding:3px 4px}.dm-stat-lbl{color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;font-size:8px}.dm-stat-input{width:100%;font-family:var(--mono);color:var(--gold);text-align:center;background:0 0;border:none;outline:none;min-width:0;padding:0;font-size:13px}.dm-stat-readout{font-family:var(--mono);color:var(--gold);font-size:13px}.dm-attr-row{grid-template-columns:repeat(6,1fr);gap:2px;display:grid}.dm-attr{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;min-width:0;padding:2px 1px}.dm-attr-lbl{color:var(--text-muted);letter-spacing:.3px;font-size:7px}.dm-attr-val{font-family:var(--mono);color:var(--text-primary);font-size:11px}.dm-attr-mod{font-family:var(--mono);color:var(--gold);font-size:10px}.dm-gold-row{gap:6px;display:flex}.dm-expand-btn{width:100%;margin-top:4px;padding:5px 10px;font-size:12px}.dm-card-full{border-top:1px dashed var(--border);margin-top:6px;padding-top:8px}.dm-hp-block,.dm-gold-cell,.dm-stat{position:relative}.dm-field-hl{border-radius:var(--radius-sm);box-shadow:0 0 0 2px var(--gold), 0 0 22px 4px #c9a84cbf;background:#c9a84c2e;transition:box-shadow .3s,background .3s}.dm-field-glow{border-radius:var(--radius);pointer-events:none;z-index:1;box-shadow:0 0 0 3px var(--gold), 0 0 32px 12px #c9a84c, inset 0 0 14px 2px #c9a84c80;background:#c9a84c38;animation:6s ease-out forwards dmFieldGlowFade;position:absolute;inset:-5px}@keyframes dmFieldGlowFade{0%{opacity:1;transform:scale(1.06)}6%{opacity:1;transform:scale(1)}70%{opacity:.85}to{opacity:0;transform:scale(1)}}.init-tracker{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px}.init-tracker-head{font-family:var(--font-display);color:var(--gold);letter-spacing:1px;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;font-size:14px;display:flex}.init-btn{min-width:0!important;padding:2px 8px!important;font-size:12px!important}.init-list{flex-direction:column;gap:4px;display:flex}.init-empty{color:var(--text-muted);text-align:center;padding:16px 0;font-size:12px;font-style:italic}.init-row{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;padding:6px 8px;transition:all .15s;display:flex}.init-row:hover{border-color:var(--gold)}.init-row-active{background:#c9a84c1a;box-shadow:0 0 8px #c9a84c4d;border-color:var(--gold)!important}.init-row-monster{border-left:3px solid #c44}.init-val-cell{flex-shrink:0;width:38px}.init-val{text-align:center;width:34px;font-family:var(--mono);color:var(--gold);font-size:16px;font-weight:700}.init-val-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:36px;color:var(--gold);font-family:var(--mono);text-align:center;background:0 0;padding:2px 0;font-size:14px;font-weight:700}.init-val-input:focus{border-color:var(--gold);outline:none}.init-info{flex:1;min-width:0}.init-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.init-sub{color:var(--text-muted);font-size:10px}.init-monster-edit{align-items:center;gap:4px;display:flex}.init-mini-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:40px;color:var(--text-primary);text-align:center;background:0 0;padding:2px 4px;font-size:11px}.init-init-input{flex-shrink:0;width:50px}.init-add-form{gap:4px;margin-top:6px;display:flex}.init-add-btn{padding:4px 8px;font-size:12px}.init-quickspawn{border-top:1px dashed var(--border);margin-top:12px;padding-top:10px}.init-quickspawn-title{color:var(--text-muted);letter-spacing:.6px;text-transform:uppercase;margin-bottom:6px;font-size:10px}.init-quickspawn-list{flex-direction:column;gap:4px;display:flex}.init-quickspawn-chip{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;color:var(--text-secondary);align-items:center;gap:6px;padding:5px 8px;transition:all .12s;display:flex}.init-quickspawn-chip:hover{border-color:var(--gold);background:#c9a84c14}.qs-name{color:var(--text-primary);flex:1;font-size:12px}.qs-stats{color:var(--text-muted);font-size:10px;font-family:var(--mono);gap:4px;display:flex}.qs-plus{color:var(--gold);text-align:center;width:16px;font-size:16px;font-weight:700;line-height:1}.bestiary{flex-direction:column;display:flex}.beast-list{flex-direction:column;gap:6px;display:flex}.beast-row{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);gap:6px;padding:6px 8px;transition:border-color .15s;display:flex}.beast-row:hover{border-color:var(--gold)}.beast-row-main{cursor:pointer;flex:1;min-width:0}.beast-name{color:var(--text-primary);font-size:13px;font-weight:600}.beast-stats{color:var(--gold);font-size:11px;font-family:var(--mono);gap:8px;margin-top:2px;display:flex}.beast-notes-preview{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:3px;font-size:10px;display:-webkit-box;overflow:hidden}.beast-spawn-btn{align-self:stretch;min-width:30px;font-weight:700;padding:0 8px!important;font-size:18px!important}.beast-row-editing{border-color:var(--gold);flex-direction:column;gap:6px}.beast-name-input{font-size:14px}.beast-stats-edit{gap:6px;display:flex}.beast-stats-edit label{color:var(--text-muted);flex-direction:column;flex:1;gap:2px;font-size:10px;display:flex}.beast-notes{font-size:12px}.beast-row-actions{align-items:center;gap:4px;display:flex}.dm-feed-head{font-family:var(--font-display);color:var(--gold);letter-spacing:1px;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;font-size:14px;display:flex}.dm-feed-list{flex-direction:column;gap:6px;display:flex}.dm-feed-card{background:var(--surface);border-left:3px solid var(--text-muted);border-radius:var(--radius-sm);padding:6px 8px;font-size:12px}.dm-feed-line1{align-items:center;gap:6px;display:flex}.dm-feed-icon{font-size:14px}.dm-feed-name{color:var(--gold);flex:1;font-size:11px}.dm-feed-time{color:var(--text-muted);font-size:10px;font-family:var(--mono)}.dm-feed-msg{color:var(--text-secondary);margin-top:2px;font-size:11px;line-height:1.3}html.dm-mode .bottom-nav{background:var(--surface);border-top:1px solid var(--border)}@media (width<=1100px){.dm-cockpit{grid-template-columns:1fr}.dm-col-side{max-height:none;position:static}}.dm-fullsheet{padding-bottom:100px;animation:.25s ease-out fadeUp}.dm-fullsheet-head{border-bottom:1px solid var(--border);background:var(--background);z-index:10;justify-content:space-between;align-items:center;margin-bottom:16px;padding-top:4px;padding-bottom:12px;display:flex;position:sticky;top:0}.dm-fullsheet-title{align-items:center;gap:14px;display:flex}.dm-fullsheet-portrait{background:var(--surface-elevated);border:1px solid var(--gold);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:26px;display:flex;overflow:hidden}.dm-fullsheet-portrait img{object-fit:cover;width:100%;height:100%}.dm-fullsheet-name{font-family:var(--font-display);color:var(--gold);letter-spacing:1px;font-size:26px}.dm-fullsheet-sub{color:var(--text-muted);margin-top:2px;font-size:13px}.dm-fullsheet-close{border-color:var(--gold);color:var(--gold);padding:8px 16px;font-size:14px}.dm-fullsheet-close:hover{background:#c9a84c1a}.dm-fullsheet-body{max-width:1100px;margin:0 auto}
