@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&family=IM+Fell+English:ital@0;1&family=Inter:wght@300;400;500;600&display=swap";:root{--obsidian-900:#06070a;--obsidian-800:#0a0b0f;--obsidian-700:#10121a;--obsidian-600:#161922;--obsidian-500:#1e222e;--obsidian-400:#252a38;--obsidian-300:#2e3446;--ember-gold:#c9a84c;--ember-gold-light:#e2c97e;--ember-gold-dim:#8a6e2f;--ember-glow:#c9a84c26;--blood-red:#8b1a1a;--blood-red-light:#b23030;--danger-glow:#8b1a1a33;--magic-purple:#7b2ff7;--magic-purple-light:#a855f7;--magic-purple-dim:#4a1a8a;--magic-glow:#7b2ff733;--arcane-blue:#1e6fff;--arcane-blue-light:#60a5fa;--movement-glow:#1e6fff40;--healing-green:#22c55e;--healing-glow:#22c55e33;--parchment:#e8dcc8;--parchment-dim:#b0a08a;--parchment-faint:#e8dcc80f;--white:#f8f8f0;--grey-400:#6b7280;--grey-600:#374151;--bg-primary:var(--obsidian-800);--bg-secondary:var(--obsidian-700);--bg-tertiary:var(--obsidian-600);--bg-panel:var(--obsidian-500);--bg-card:var(--obsidian-400);--bg-hover:var(--obsidian-300);--text-primary:var(--parchment);--text-secondary:var(--parchment-dim);--text-heading:var(--ember-gold);--text-accent:var(--ember-gold-light);--border-subtle:#c9a84c1f;--border-dim:#c9a84c40;--border-bright:#c9a84c80;--font-display:"Cinzel", serif;--font-lore:"IM Fell English", serif;--font-body:"Inter", sans-serif;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-ember:0 0 20px #c9a84c26, 0 4px 24px #0009;--shadow-magic:0 0 20px #7b2ff740, 0 4px 24px #0009;--shadow-panel:0 8px 32px #00000080, inset 0 1px 0 #c9a84c14;--transition-fast:.15s ease;--transition-smooth:.28s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}h1,h2,h3{font-family:var(--font-display);color:var(--text-heading);letter-spacing:.04em;line-height:1.2}h1{font-size:2.8rem;font-weight:700}h2{font-size:1.8rem;font-weight:600}h3{font-size:1.2rem;font-weight:500}p{color:var(--text-secondary);line-height:1.65}.lore-text{font-family:var(--font-lore);color:var(--parchment-dim);font-style:italic;line-height:1.8}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.w-full{width:100%}.h-full{height:100%}.relative{position:relative}.absolute{position:absolute}.overflow-hidden{overflow:hidden}.panel{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-panel)}.panel-header{border-bottom:1px solid var(--border-subtle);font-family:var(--font-display);color:var(--ember-gold);letter-spacing:.08em;text-transform:uppercase;padding:12px 16px;font-size:.85rem;font-weight:600}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:16px}.card:hover{border-color:var(--border-dim);box-shadow:var(--shadow-ember)}.btn{border-radius:var(--radius-md);font-family:var(--font-display);letter-spacing:.06em;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--ember-gold-dim), var(--ember-gold));color:var(--obsidian-900);box-shadow:0 2px 12px #c9a84c4d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--ember-gold), var(--ember-gold-light));transform:translateY(-1px);box-shadow:0 4px 20px #c9a84c80}.btn-secondary{color:var(--ember-gold);border:1px solid var(--border-dim);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--ember-glow);border-color:var(--border-bright)}.btn-danger{background:var(--blood-red);color:var(--white);box-shadow:0 2px 12px var(--danger-glow)}.btn-danger:hover:not(:disabled){background:var(--blood-red-light);box-shadow:0 4px 20px #8b1a1a66}.btn-magic{background:linear-gradient(135deg, var(--magic-purple-dim), var(--magic-purple));color:var(--white);box-shadow:0 2px 12px var(--magic-glow)}.btn-magic:hover:not(:disabled){background:linear-gradient(135deg, var(--magic-purple), var(--magic-purple-light));transform:translateY(-1px);box-shadow:0 4px 20px #7b2ff766}.btn-sm{padding:6px 12px;font-size:.75rem}.btn-icon{aspect-ratio:1;border-radius:var(--radius-sm);padding:8px}.input{background:var(--obsidian-700);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:10px 14px;font-size:.95rem}.input::placeholder{color:var(--parchment-dim);opacity:.5}.input:focus{border-color:var(--ember-gold);box-shadow:0 0 0 3px var(--ember-glow)}.input-label{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--ember-gold);margin-bottom:6px;font-size:.75rem;font-weight:600;display:block}.badge{letter-spacing:.05em;text-transform:uppercase;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-flex}.badge-gold{background:var(--ember-glow);color:var(--ember-gold);border:1px solid var(--border-dim)}.badge-magic{background:var(--magic-glow);color:var(--magic-purple-light);border:1px solid #7b2ff74d}.badge-danger{background:var(--danger-glow);color:var(--blood-red-light);border:1px solid #8b1a1a4d}.badge-heal{background:var(--healing-glow);color:var(--healing-green);border:1px solid #22c55e4d}.hp-bar{background:var(--obsidian-600);border-radius:3px;width:100%;height:6px;overflow:hidden}.hp-bar-fill{background:linear-gradient(90deg, var(--healing-green), #4ade80);border-radius:3px;height:100%;transition:width .5s}.hp-bar-fill.critical{background:linear-gradient(90deg, var(--blood-red), var(--blood-red-light))}.hp-bar-fill.low{background:linear-gradient(90deg,#ea580c,#f97316)}.divider{background:linear-gradient(90deg, transparent, var(--border-dim), transparent);height:1px;margin:16px 0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--obsidian-700)}::-webkit-scrollbar-thumb{background:var(--obsidian-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--ember-gold-dim)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulseGlow{0%,to{opacity:.6;box-shadow:0 0 8px #c9a84c4d}50%{opacity:1;box-shadow:0 0 16px #c9a84c99}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes diceRoll{0%{transform:rotate(0)scale(1)}25%{transform:rotate(90deg)scale(1.2)}50%{transform:rotate(180deg)scale(.9)}75%{transform:rotate(270deg)scale(1.1)}to{transform:rotate(360deg)scale(1)}}@keyframes floatUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-40px)}}.animate-fade-in{animation:.3s forwards fadeIn}.animate-pulse-glow{animation:2s ease-in-out infinite pulseGlow}.animate-spin{animation:1s linear infinite spin}.text-gold{color:var(--ember-gold)}.text-magic{color:var(--magic-purple-light)}.text-danger{color:var(--blood-red-light)}.text-heal{color:var(--healing-green)}.text-muted{color:var(--text-secondary)}.text-center{text-align:center}.font-display{font-family:var(--font-display)}.font-lore{font-family:var(--font-lore)}.uppercase{text-transform:uppercase}.tracking-wide{letter-spacing:.08em}.login-page{background:var(--obsidian-900);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg{pointer-events:none;position:absolute;inset:0}.bg-ember-1,.bg-ember-2,.bg-ember-3{filter:blur(80px);border-radius:50%;animation:8s ease-in-out infinite floatEmber;position:absolute}.bg-ember-1{background:radial-gradient(circle,#c9a84c14,#0000);width:400px;height:400px;animation-delay:0s;top:-100px;left:-100px}.bg-ember-2{background:radial-gradient(circle,#7b2ff70f,#0000);width:300px;height:300px;animation-delay:-3s;bottom:-80px;right:-80px}.bg-ember-3{background:radial-gradient(circle,#8b1a1a0d,#0000);width:200px;height:200px;animation-delay:-6s;top:50%;left:60%}@keyframes floatEmber{0%,to{transform:translate(0)scale(1)}33%{transform:translate(20px,-30px)scale(1.05)}66%{transform:translate(-15px,20px)scale(.95)}}.login-container{z-index:1;flex-direction:column;align-items:center;gap:24px;width:100%;max-width:440px;padding:24px;display:flex;position:relative}.login-header{text-align:center}.login-rune{filter:drop-shadow(0 0 16px var(--ember-gold));margin-bottom:8px;font-size:3rem;animation:3s ease-in-out infinite pulseGlow}.login-title{text-shadow:0 0 30px #c9a84c4d;margin-bottom:4px;font-size:3.2rem}.login-subtitle{color:var(--ember-gold-light);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;font-size:1rem}.login-tagline{color:var(--parchment-dim);font-size:.85rem}.login-card{width:100%;overflow:hidden}.login-tabs{border-bottom:1px solid var(--border-subtle);display:flex}.login-tab{font-family:var(--font-display);letter-spacing:.06em;color:var(--parchment-dim);cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase;background:0 0;border:none;flex:1;padding:14px;font-size:.82rem;font-weight:600}.login-tab:hover{color:var(--parchment)}.login-tab.active{color:var(--ember-gold);border-bottom:2px solid var(--ember-gold);background:var(--ember-glow)}.login-form{flex-direction:column;gap:16px;padding:24px;display:flex}.form-field{flex-direction:column;gap:6px;display:flex}.login-error{background:var(--danger-glow);color:var(--blood-red-light);border-radius:var(--radius-md);border:1px solid #8b1a1a66;padding:10px 14px;font-size:.875rem}.login-divider{color:var(--parchment-dim);align-items:center;gap:12px;padding:0 24px;font-size:.8rem;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border-subtle);flex:1;height:1px}.login-card .btn-secondary{margin:0 24px 24px}.login-footer{text-align:center;opacity:.6;font-size:.85rem}.lobby-page{background:var(--obsidian-800);flex-direction:column;min-height:100vh;display:flex}.lobby-header{background:var(--obsidian-900);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.lobby-brand{color:var(--ember-gold);align-items:center;gap:10px;font-size:1.3rem;display:flex}.lobby-brand-rune{filter:drop-shadow(0 0 8px var(--ember-gold));font-size:1.6rem}.lobby-user{align-items:center;gap:10px;display:flex}.lobby-content{flex:1;grid-template-columns:360px 1fr;gap:24px;width:100%;max-width:1200px;margin:0 auto;padding:32px;display:grid}.lobby-create{height:fit-content}.lobby-create-body{flex-direction:column;padding:20px;display:flex}.lobby-error{background:var(--danger-glow);color:var(--blood-red-light);border-radius:var(--radius-md);border:1px solid #8b1a1a66;margin-top:8px;padding:10px 14px;font-size:.875rem}.lobby-sessions{flex-direction:column;gap:16px;display:flex}.lobby-sessions-title{margin-bottom:4px;font-size:1.4rem}.lobby-empty{text-align:center;padding:40px}.sessions-list{flex-direction:column;gap:12px;display:flex}.session-card{flex-direction:column;gap:10px;display:flex}.session-card-header{justify-content:space-between;align-items:flex-start;display:flex}.session-name{color:var(--parchment);margin-bottom:2px;font-size:1.1rem}.session-location{font-size:.8rem}.session-meta{justify-content:space-between;align-items:center;display:flex}.session-lore{opacity:.7;font-size:.82rem;line-height:1.5}.lobby-sessions-title{margin:0;font-size:1.4rem}.lobby-sessions-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.session-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.session-delete-confirm{background:#8b1a1a1f;border:1px solid #8b1a1a4d;border-radius:6px;align-items:center;gap:6px;padding:4px 8px;display:flex}.session-archived{opacity:.55;border-style:dashed!important}.session-deleting{opacity:.3;pointer-events:none}.lobby-char-btn{cursor:pointer;font-size:.75rem;font-family:var(--font-display,"Cinzel Decorative", serif);color:var(--parchment,#e8dcc8);letter-spacing:.04em;border-radius:999px;padding:4px 10px;transition:box-shadow .2s}.lobby-char-btn:hover{box-shadow:0 0 12px #a855f780}.lobby-error button{color:inherit;cursor:pointer;background:0 0;border:none;margin-left:8px;padding:0;font-size:1.1rem}.cc-page{background:var(--obsidian-800);flex-direction:column;min-height:100vh;display:flex}.cc-header{background:var(--obsidian-900);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.cc-title{font-size:1.3rem}.cc-layout{flex:1;grid-template-columns:1fr 380px;gap:20px;height:calc(100vh - 60px);padding:20px;display:grid}.cc-chat{flex-direction:column;display:flex;overflow:hidden}.cc-messages{flex-direction:column;flex:1;gap:16px;padding:16px;display:flex;overflow-y:auto}.cc-message{gap:10px;animation:.25s fadeIn;display:flex}.cc-message.user{flex-direction:row-reverse}.cc-avatar{background:linear-gradient(135deg, var(--magic-purple-dim), var(--magic-purple));width:36px;height:36px;box-shadow:var(--shadow-magic);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.cc-bubble{border-radius:var(--radius-lg);max-width:80%;padding:12px 16px;line-height:1.6}.cc-message.model .cc-bubble{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:0 var(--radius-lg) var(--radius-lg) var(--radius-lg)}.cc-message.user .cc-bubble{background:var(--magic-purple-dim);border-radius:var(--radius-lg) 0 var(--radius-lg) var(--radius-lg);color:var(--parchment);border:1px solid #7b2ff74d}.cc-bubble p{margin:4px 0;font-size:.9rem}.cc-bubble p+p{margin-top:8px}.cc-bubble strong{color:var(--ember-gold)}.cc-typing{align-items:center;gap:5px;padding:16px;display:flex}.cc-typing span{background:var(--ember-gold-dim);border-radius:50%;width:7px;height:7px;animation:1.2s infinite typingBounce}.cc-typing span:nth-child(2){animation-delay:.2s}.cc-typing span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.cc-input-row{border-top:1px solid var(--border-subtle);gap:8px;padding:12px 16px;display:flex}.cc-textarea{resize:none;font-family:var(--font-body);flex:1;min-height:44px}.cc-preview{flex-direction:column;display:flex;overflow-y:auto}.cc-preview-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:32px;display:flex}.cc-empty-rune{opacity:.3;font-size:4rem}.cc-sheet{flex-direction:column;gap:12px;padding:16px;display:flex}.cc-sheet-header{text-align:center}.cc-char-name{margin-bottom:4px;font-size:1.4rem}.cc-char-subtitle{font-size:.82rem}.cc-stats-grid{grid-template-columns:repeat(6,1fr);gap:6px;display:grid}.cc-stat{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);flex-direction:column;align-items:center;gap:2px;padding:8px 4px;display:flex}.cc-stat-label{font-size:.6rem;font-family:var(--font-display);color:var(--ember-gold);text-transform:uppercase;letter-spacing:.05em}.cc-stat-value{color:var(--parchment);font-size:1.2rem;font-weight:700}.cc-stat-mod{font-size:.7rem}.cc-sheet-meta{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.cc-meta-item{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);flex-direction:column;align-items:center;gap:2px;padding:8px;font-size:.85rem;display:flex}.cc-section{flex-direction:column;gap:4px;display:flex}.cc-section-title{font-family:var(--font-display);color:var(--ember-gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;font-size:.75rem;font-weight:700}.cc-item{background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:4px 8px;font-size:.82rem}.cl-page{background:var(--obsidian-900,#0e0f13);flex-direction:column;min-height:100vh;display:flex}.cl-header{background:var(--obsidian-900,#0e0f13);border-bottom:1px solid #c9a84c33;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.cl-header-center{align-items:center;gap:10px;display:flex}.cl-rune{filter:drop-shadow(0 0 8px #c9a84c80);font-size:1.4rem}.cl-title{color:var(--color-gold,#c9a84c);letter-spacing:.06em;margin:0;font-size:1.25rem}.cl-error{color:#ef4444;background:#8b1a1a33;border-bottom:1px solid #8b1a1a66;justify-content:space-between;align-items:center;padding:10px 24px;font-size:.875rem;display:flex}.cl-error button{color:inherit;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.1rem}.cl-body{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:24px}.cl-active-banner{background:#c9a84c12;border:1px solid #c9a84c40;border-radius:8px;align-items:center;gap:10px;margin-bottom:20px;padding:10px 16px;display:flex}.cl-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:50vh;display:flex}.cl-empty-rune{opacity:.4;margin-bottom:8px;font-size:4rem}.cl-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;display:grid}.cl-card{background:#ffffff05;border:1px solid #ffffff12;border-radius:12px;gap:16px;padding:20px;transition:border-color .2s,box-shadow .2s,opacity .3s;display:flex;position:relative;overflow:hidden}.cl-card:before{content:"";pointer-events:none;background:linear-gradient(135deg,#c9a84c08 0%,#0000 60%);position:absolute;inset:0}.cl-card:hover{border-color:#c9a84c4d;box-shadow:0 4px 24px #0006}.cl-card-active{background:#c9a84c0a;border-color:#c9a84c80;box-shadow:0 0 24px #c9a84c1f,inset 0 0 0 1px #c9a84c26}.cl-card-deleting{opacity:.4;pointer-events:none}.cl-portrait{background:#c9a84c14;border:1px solid #c9a84c33;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;display:flex;position:relative}.cl-portrait-icon{font-size:2rem;line-height:1}.cl-active-ring{border:2px solid var(--color-gold,#c9a84c);pointer-events:none;border-radius:14px;animation:2.5s ease-in-out infinite pulseGlow;position:absolute;inset:-3px}.cl-card-body{flex-direction:column;flex:1;gap:10px;min-width:0;display:flex}.cl-card-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.cl-char-name{color:var(--color-text,#e8dcc8);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1rem;overflow:hidden}.cl-char-subtitle{margin:2px 0 0;font-size:.75rem}.cl-active-badge{flex-shrink:0;font-size:.65rem}.cl-vitals{gap:12px;display:flex}.cl-vital{flex-direction:column;align-items:center;gap:1px;display:flex}.cl-vital-label{text-transform:uppercase;letter-spacing:.08em;font-size:.62rem}.cl-vital-value{font-size:.9rem;font-weight:600}.cl-stats{flex-wrap:wrap;gap:8px;display:flex}.cl-stat{background:#ffffff08;border:1px solid #ffffff0f;border-radius:6px;flex-direction:column;align-items:center;gap:1px;min-width:36px;padding:4px 6px;display:flex}.cl-stat-lbl{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted,#888);font-size:.58rem}.cl-stat-val{font-size:.82rem;font-weight:600}.cl-stat-mod{font-size:.65rem}.cl-backstory{opacity:.7;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.72rem;line-height:1.5;display:-webkit-box;overflow:hidden}.cl-actions{align-items:center;gap:8px;margin-top:4px;display:flex}.cl-currently-active{flex:1;font-size:.75rem}.cl-delete-confirm{background:#8b1a1a1f;border:1px solid #8b1a1a59;border-radius:8px;margin-top:4px;padding:10px}.cl-delete-warning{color:#ef4444;margin:0 0 8px;font-size:.78rem}.cl-delete-actions{gap:8px;display:flex}.initiative-tracker{flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow:hidden}.initiative-empty{text-align:center;padding:24px}.initiative-list{flex-direction:column;flex:1;display:flex;overflow-y:auto}.initiative-entry{border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast);align-items:center;gap:8px;padding:10px 12px;display:flex;position:relative}.initiative-entry:last-child{border-bottom:none}.initiative-entry:hover{background:var(--bg-hover)}.initiative-entry.active{background:var(--ember-glow);border-left:3px solid var(--ember-gold)}.initiative-entry.dead{opacity:.4}.initiative-entry.enemy .entity-name{color:var(--blood-red-light)}.initiative-entry.ally .entity-name,.initiative-entry.player .entity-name{color:var(--arcane-blue-light)}.turn-indicator{text-align:center;width:20px;color:var(--parchment-dim);flex-shrink:0;font-size:.75rem}.initiative-entry.active .turn-indicator{color:var(--ember-gold);font-size:.8rem}.entity-avatar{background:var(--obsidian-600);border:1px solid var(--border-subtle);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex;position:relative;overflow:hidden}.entity-avatar img{object-fit:cover;width:100%;height:100%}.dead-overlay{color:var(--blood-red-light);background:#0009;justify-content:center;align-items:center;font-size:.9rem;display:flex;position:absolute;inset:0}.entity-info{flex:1;min-width:0}.entity-name-row{align-items:baseline;gap:6px;margin-bottom:4px;display:flex}.entity-name{font-family:var(--font-display);color:var(--parchment);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;font-weight:600;overflow:hidden}.entity-ac{color:var(--parchment-dim);white-space:nowrap;font-size:.65rem}.entity-hp-wrap{align-items:center;gap:6px;display:flex}.entity-hp-text{color:var(--parchment-dim);white-space:nowrap;font-size:.65rem}.entity-conditions{gap:3px;margin-top:3px;display:flex}.condition-badge{cursor:help;font-size:.75rem}.entity-init-roll{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.init-roll-value{font-family:var(--font-display);color:var(--ember-gold);font-size:1rem;font-weight:700}.vtt-grid-container{background:var(--obsidian-900);border-radius:var(--radius-md);cursor:default;width:100%;height:100%;overflow:hidden}.vtt-grid-container canvas{display:block}.dm-chat{flex-direction:column;height:100%;display:flex;overflow:hidden}.dm-chat-header{justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.dm-oracle-indicator{align-items:center;gap:8px;font-size:.78rem;display:flex}.oracle-dot{background:var(--healing-green);width:8px;height:8px;box-shadow:0 0 6px var(--healing-green);border-radius:50%}.oracle-dot.thinking{background:var(--ember-gold);box-shadow:0 0 6px var(--ember-gold);animation:.8s ease-in-out infinite pulseGlow}.dm-quick-actions{border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;gap:6px;padding:8px 12px;display:flex}.dm-messages{flex-direction:column;flex:1;gap:12px;padding:12px;display:flex;overflow-y:auto}.dm-message{gap:8px;display:flex}.dm-message.user{flex-direction:row-reverse}.dm-avatar{background:linear-gradient(135deg, #3b1a6b, var(--magic-purple));width:32px;height:32px;box-shadow:var(--shadow-magic);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;display:flex}.dm-bubble{border-radius:var(--radius-lg);max-width:85%;padding:10px 14px;line-height:1.65}.dm-message.model .dm-bubble{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:0 var(--radius-lg) var(--radius-lg) var(--radius-lg)}.dm-message.user .dm-bubble{background:var(--obsidian-400);border:1px solid var(--border-subtle);border-radius:var(--radius-lg) 0 var(--radius-lg) var(--radius-lg)}.dm-bubble p{margin:3px 0;font-size:.875rem}.dm-bubble p+p{margin-top:6px}.dm-bubble strong{color:var(--ember-gold)}.dm-bubble em{color:var(--parchment-dim);font-style:italic}.dm-bubble code{background:var(--bg-tertiary);border-radius:3px;padding:1px 5px;font-size:.8rem}.stats-bubble{border-color:var(--border-dim)!important;background:var(--bg-card)!important}.stats-bubble strong{color:var(--healing-green)!important}.dm-thinking{align-items:center;gap:10px;display:flex}.thinking-text{opacity:.7;font-size:.82rem}.thinking-dots{gap:4px;display:flex}.thinking-dots span{background:var(--magic-purple-light);border-radius:50%;width:6px;height:6px;animation:1s infinite typingBounce}.thinking-dots span:nth-child(2){animation-delay:.15s}.thinking-dots span:nth-child(3){animation-delay:.3s}.dm-image-wrap{margin-top:10px}.dm-image{border-radius:var(--radius-md);border:1px solid var(--border-subtle);width:100%;box-shadow:var(--shadow-panel)}.dm-image-caption{text-align:center;opacity:.7;margin-top:4px;font-size:.75rem}.dm-image-generating{color:var(--magic-purple-light);align-items:center;gap:8px;padding:12px;font-size:.82rem;display:flex}.dm-input-area{border-top:1px solid var(--border-subtle);flex-direction:column;gap:6px;padding:10px 12px;display:flex}.dm-input-hint{padding:0 2px}.dm-input-row{align-items:flex-end;gap:8px;display:flex}.dm-textarea{resize:none;font-family:var(--font-body);flex:1}.fc-badge{cursor:pointer;white-space:nowrap;background:#c9a84c14;border:1px solid #c9a84c40;border-radius:8px;align-items:center;gap:6px;padding:4px 10px;transition:background .2s,border-color .2s;display:flex}.fc-badge:hover{background:#c9a84c26;border-color:#c9a84c80}.fc-icon{font-size:1rem}.fc-date-short{color:var(--color-gold,#c9a84c);letter-spacing:.03em;font-family:Cinzel,serif;font-size:.78rem}.fc-host-hint{color:#c9a84c99;font-size:.7rem}.fc-modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000b3;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.fc-modal{background:var(--color-surface,#1a1c22);border:1px solid #c9a84c59;border-radius:12px;width:90%;max-width:560px;max-height:90vh;padding:28px 32px;animation:.2s slideUp;overflow-y:auto;box-shadow:0 20px 60px #000c,0 0 40px #c9a84c14}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fc-modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.fc-modal-title{margin:0;font-size:1.1rem}.fc-close{color:var(--color-text-muted,#888);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.5rem;line-height:1;transition:color .2s}.fc-close:hover{color:var(--color-gold,#c9a84c)}.fc-current-date{text-align:center;background:#c9a84c0f;border:1px solid #c9a84c33;border-radius:8px;flex-direction:column;align-items:center;gap:4px;margin-bottom:24px;padding:16px;display:flex}.fc-date-label{text-transform:uppercase;letter-spacing:.1em;font-size:.72rem}.fc-date-full{font-family:Cinzel,serif;font-size:1.25rem}.fc-month-alias{font-size:.78rem}.fc-festival-banner{background:#a855f71a;border:1px solid #a855f74d;border-radius:8px;align-items:center;gap:14px;margin-bottom:20px;padding:14px 18px;display:flex}.fc-festival-icon{font-size:1.8rem}.fc-month-grid-wrap{margin-bottom:20px}.fc-month-name{text-align:center;color:var(--color-gold,#c9a84c);letter-spacing:.08em;margin-bottom:10px;font-size:.9rem}.fc-month-grid{grid-template-columns:repeat(10,1fr);gap:3px;display:grid}.fc-grid-header{text-align:center;color:var(--color-text-muted,#888);text-transform:uppercase;padding:3px 0;font-size:.6rem}.fc-grid-day{text-align:center;color:var(--color-text,#e8dcc8);background:#ffffff08;border:1px solid #0000;border-radius:4px;padding:6px 2px;font-size:.78rem;transition:background .15s}.fc-grid-day.today{color:var(--color-gold,#c9a84c);background:#c9a84c33;border-color:#c9a84c99;font-weight:700}.fc-legend{margin-bottom:20px}.fc-legend-grid{grid-template-columns:1fr 1fr;gap:6px;margin-top:10px;display:grid}.fc-legend-month,.fc-legend-festival{background:#ffffff08;border:1px solid #ffffff0f;border-radius:6px;flex-direction:column;padding:6px 10px;font-size:.78rem;display:flex}.fc-legend-month.current{background:#c9a84c1a;border-color:#c9a84c4d}.fc-legend-festival{background:#a855f712;border-color:#a855f733}.fc-controls{background:#1e6fff0f;border:1px solid #1e6fff33;border-radius:8px;flex-direction:column;gap:10px;margin-bottom:16px;padding:16px;display:flex}.fc-controls-label{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem}.fc-controls-btns{flex-wrap:wrap;gap:8px;display:flex}.fc-footer{text-align:center;margin:0;font-size:.7rem}.encounter-panel{background:var(--color-surface,#1a1c22);z-index:150;border-left:1px solid #c9a84c40;flex-direction:column;width:340px;height:100vh;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:0;overflow:hidden;transform:translate(100%);box-shadow:-8px 0 32px #0009}.encounter-panel.open{transform:translate(0)}.ep-header{background:#c9a84c0a;border-bottom:1px solid #c9a84c33;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.ep-title{letter-spacing:.05em;margin:0;font-size:1rem}.ep-close{color:var(--color-text-muted,#888);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.5rem;line-height:1;transition:color .2s}.ep-close:hover{color:var(--color-gold,#c9a84c)}.ep-empty{text-align:center;flex:1;justify-content:center;align-items:center;padding:32px;display:flex}.ep-list{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.ep-list::-webkit-scrollbar{width:4px}.ep-list::-webkit-scrollbar-track{background:0 0}.ep-list::-webkit-scrollbar-thumb{background:#c9a84c33;border-radius:2px}.ep-card{background:#ffffff05;border:1px solid #ffffff14;border-radius:8px;transition:border-color .2s;overflow:hidden}.ep-card.active{background:#8b1a1a0d;border-color:#8b1a1a80}.ep-card.expanded{border-color:#c9a84c4d}.ep-card-header{cursor:pointer;padding:12px 14px;transition:background .15s}.ep-card-header:hover{background:#ffffff08}.ep-card-meta{align-items:center;gap:8px;margin-bottom:6px;display:flex}.ep-status{padding:2px 7px;font-size:.65rem}.ep-date{font-family:Cinzel,serif;font-size:.7rem}.ep-card-title-row{justify-content:space-between;align-items:center;display:flex}.ep-card-name{color:var(--color-text,#e8dcc8);font-size:.88rem}.ep-expand-icon{color:var(--color-text-muted,#888);font-size:.7rem}.ep-enemies{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.ep-enemy-tag{background:#8b1a1a33;border:1px solid #8b1a1a4d;border-radius:20px;padding:2px 7px;font-size:.65rem}.ep-card-stats{gap:12px;margin-top:8px;display:flex}.ep-stat{color:var(--color-text-muted,#888);font-size:.68rem}.ep-card-body{border-top:1px solid #ffffff0f;flex-direction:column;gap:16px;padding:12px 14px;display:flex}.ep-loading{text-align:center;padding:12px;font-size:.8rem}.ep-section-label{text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;font-size:.68rem}.ep-image-gallery{grid-template-columns:1fr 1fr;gap:6px;display:grid}.ep-image-thumb{border:1px solid #c9a84c33;border-radius:6px;position:relative;overflow:hidden}.ep-image-thumb img{object-fit:cover;width:100%;height:80px;display:block}.ep-image-caption{color:#e8dcc8;white-space:nowrap;text-overflow:ellipsis;background:#000000b3;padding:3px 6px;font-size:.6rem;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.ep-log-timeline{flex-direction:column;gap:6px;max-height:240px;display:flex;overflow-y:auto}.ep-log-timeline::-webkit-scrollbar{width:3px}.ep-log-timeline::-webkit-scrollbar-thumb{background:#c9a84c33}.ep-log-entry{background:#ffffff05;border:1px solid #ffffff0d;border-radius:6px;align-items:flex-start;gap:8px;padding:6px 8px;display:flex}.ep-log-icon{flex-shrink:0;margin-top:2px;font-size:.75rem}.ep-log-text{color:var(--color-text,#e8dcc8);opacity:.85;margin:0;font-size:.72rem;line-height:1.5}.ep-log-narrative{border-color:#a855f726}.ep-log-action{border-color:#8b1a1a33}.ep-log-event{border-color:#c9a84c26}.ep-empty-body{text-align:center;margin:0;font-size:.78rem}.wm-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#000000d1;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.wm-modal{background:linear-gradient(160deg,#16202e 0%,#0f1720 100%);border:1px solid #b48c3c59;border-radius:1rem;flex-direction:column;width:min(95vw,1100px);max-height:88vh;display:flex;overflow:hidden;box-shadow:0 0 0 1px #ffc35014,0 32px 80px #000000b3,0 0 60px #8c641e1f}.wm-header{background:#ffc3500a;border-bottom:1px solid #b48c3c33;flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.wm-header-text{flex-direction:column;gap:.2rem;display:flex}.wm-title{font-family:var(--font-display,"Cinzel", serif);color:var(--color-gold,#f0c040);letter-spacing:.05em;font-size:1.25rem;font-weight:700}.wm-subtitle{color:var(--color-muted,#8a95a5);font-size:.78rem}.wm-close{flex-shrink:0}.wm-body{flex:1;min-height:0;display:flex;overflow:hidden}.wm-map-panel{background:#0a0f17;border-right:1px solid #b48c3c26;flex:60%;justify-content:center;align-items:center;min-width:0;display:flex;overflow:hidden}.wm-map-wrapper{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.wm-map-image{object-fit:contain;width:100%;height:100%;display:block}.wm-location-pin{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:none;background:#000000b3;border:1px solid #ef444499;border-radius:999px;align-items:center;gap:.5rem;padding:.35rem .9rem .35rem .5rem;display:flex;position:absolute;bottom:1rem;left:1rem;box-shadow:0 0 12px #ef444440}.wm-pin-dot{background:#ef4444;border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:1.6s ease-in-out infinite wm-ping;box-shadow:0 0 #ef444499}@keyframes wm-ping{0%{box-shadow:0 0 #ef444499}70%{box-shadow:0 0 0 8px #ef444400}to{box-shadow:0 0 #ef444400}}.wm-pin-label{color:#fff;white-space:nowrap;font-size:.8rem;font-weight:600}.wm-map-placeholder{opacity:.5;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem;display:flex}.wm-placeholder-icon{filter:grayscale();font-size:4rem}.wm-pin-marker{pointer-events:none;z-index:10;flex-direction:column;align-items:center;gap:2px;display:flex;position:absolute;transform:translate(-50%,-50%)}.wm-pin-circle{border:2px solid #ffffffe6;border-radius:50%;width:12px;height:12px}.wm-pin-here .wm-pin-circle{background:#ef4444;border-color:#fff;animation:1.6s ease-in-out infinite wm-ping;box-shadow:0 0 #ef444499}.wm-pin-other .wm-pin-circle{background:#ffffff40;border-color:#fff9}.wm-pin-name{color:#fff;text-shadow:0 1px 3px #000000e6,0 0 6px #000c;white-space:nowrap;background:#0000008c;border-radius:3px;padding:1px 4px;font-size:.6rem;font-weight:700}.wm-pin-here .wm-pin-name{color:#fca5a5;background:#000000b3}.wm-legend-panel{background:#ffffff04;flex-direction:column;flex:0 0 300px;display:flex;overflow:hidden}.wm-legend-header{color:var(--color-gold,#f0c040);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid #b48c3c1f;flex-shrink:0;padding:1rem 1.25rem .5rem;font-size:1rem}.wm-legend-scroll{scrollbar-width:thin;scrollbar-color:#b48c3c4d transparent;flex-direction:column;flex:1;gap:.25rem;padding:.75rem 1.25rem;display:flex;overflow-y:auto}.wm-legend-section{margin-bottom:1rem}.wm-legend-title{text-transform:uppercase;letter-spacing:.12em;color:var(--color-muted,#8a95a5);border-bottom:1px solid #ffffff0f;margin-bottom:.5rem;padding-bottom:.25rem;font-size:.7rem;font-weight:700}.wm-legend-entry{cursor:default;border-radius:.4rem;align-items:flex-start;gap:.6rem;padding:.45rem .6rem;transition:background .15s;display:flex}.wm-legend-entry:hover{background:#ffffff0a}.wm-legend-entry.wm-current{background:#ffd70014;border:1px solid #ffd70040}.wm-legend-icon{flex-shrink:0;font-size:1rem;line-height:1.25}.wm-legend-text{flex-direction:column;gap:.15rem;min-width:0;display:flex}.wm-legend-name{color:var(--color-text,#e2e8f0);flex-wrap:wrap;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;display:flex}.wm-here-badge{letter-spacing:.08em;color:#0a0f17;background:var(--color-gold,#f0c040);text-transform:uppercase;border-radius:.25rem;padding:.05rem .35rem;font-size:.58rem;font-weight:800}.wm-legend-desc{color:var(--color-muted,#8a95a5);font-size:.72rem;font-style:italic;line-height:1.4}.wm-empty{text-align:center;opacity:.5;padding:2rem 1rem}@media (width<=700px){.wm-body{flex-direction:column}.wm-map-panel{border-bottom:1px solid #b48c3c26;border-right:none;flex:0 0 45vh}.wm-legend-panel{flex:none;max-height:35vh}}.game-page{background:var(--obsidian-900);flex-direction:column;height:100vh;display:flex;overflow:hidden}.game-header{background:var(--obsidian-900);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:54px;padding:10px 16px;display:flex}.game-header-left,.game-header-right{align-items:center;gap:10px;min-width:200px;display:flex}.game-header-right{justify-content:flex-end}.game-header-center{align-items:center;gap:8px;display:flex}.game-world-info{flex-direction:column;gap:1px;display:flex}.phase-badge{letter-spacing:.1em;font-size:.75rem}.player-status{align-items:center;gap:6px;display:flex}.combat-controls{gap:6px;display:flex}.game-error{background:var(--danger-glow);color:var(--blood-red-light);border-bottom:1px solid #8b1a1a66;justify-content:space-between;align-items:center;padding:8px 16px;font-size:.875rem;display:flex}.game-error button{color:inherit;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.1rem}.encounter-active-bar{background:#8b1a1a1f;border-bottom:1px solid #8b1a1a4d;flex-shrink:0;align-items:center;gap:10px;padding:5px 16px;animation:.3s fadeIn;display:flex}.encounter-active-name{color:var(--blood-red-light,#ef4444);letter-spacing:.04em;font-size:.8rem}.game-layout{flex:1;gap:12px;height:calc(100vh - 54px);padding:12px;display:flex;overflow:hidden}.game-center{flex-direction:column;flex:1;gap:12px;min-width:0;display:flex;overflow:hidden}.game-map-area{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);flex:1;min-height:0;position:relative;overflow:hidden}.turn-banner{z-index:10;background:linear-gradient(135deg, var(--healing-green), #4ade80);color:var(--obsidian-900);font-family:var(--font-display);letter-spacing:.06em;pointer-events:none;border-radius:999px;padding:6px 16px;font-size:.78rem;font-weight:700;animation:2s ease-in-out infinite pulseGlow;position:absolute;top:10px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #22c55e66}.turn-banner.waiting{background:linear-gradient(135deg, var(--obsidian-400), var(--obsidian-300));color:var(--parchment-dim);box-shadow:none;animation:none}.game-chat-area{flex-shrink:0;height:320px}
