@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#0d0f17;--bg-secondary:#151824;--bg-tertiary:#1c2033;--bg-card:#1a1d2e;--bg-card-hover:#22263a;--bg-input:#12141f;--accent-primary:#c9a84c;--accent-primary-hover:#dab94f;--accent-primary-glow:#c9a84c4d;--accent-secondary:#8b5cf6;--accent-danger:#ef4444;--accent-success:#22c55e;--accent-info:#3b82f6;--text-primary:#e8e6e3;--text-secondary:#9ca3af;--text-muted:#6b7280;--text-accent:var(--accent-primary);--border-color:#2a2d3e;--border-glow:#c9a84c33;--font-heading:"Cinzel", serif;--font-body:"Inter", -apple-system, sans-serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--shadow-glow:0 0 20px var(--accent-primary-glow);--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 20%,#8b5cf60d 0%,#0000 50%),radial-gradient(at 80% 80%,#c9a84c0a 0%,#0000 50%);width:100%;height:100%;position:fixed;top:0;left:0}#root{z-index:1;min-height:100vh;position:relative}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-primary);line-height:1.2}a{color:var(--accent-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-primary-hover)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);font-family:var(--font-body);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;border:none;padding:10px 20px;font-size:.9rem;font-weight:600;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), #b8942f);color:#0d0f17;box-shadow:0 2px 10px var(--accent-primary-glow)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 20px var(--accent-primary-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--accent-primary)}.btn-danger{color:var(--accent-danger);background:#ef444426;border:1px solid #ef44444d}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-icon{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:8px;font-size:1.2rem}.btn-icon:hover{color:var(--accent-primary);background:#c9a84c1a}.form-group{gap:var(--space-xs);margin-bottom:var(--space-md);flex-direction:column;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:500}.input,input[type=text],input[type=password],input[type=email],input[type=number],textarea,select{background:var(--bg-input);width:100%;color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:var(--font-body);transition:all var(--transition-fast);outline:none;padding:10px 14px;font-size:.9rem}.input:focus,input:focus,textarea:focus,select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}textarea{resize:vertical;min-height:80px}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-lg);transition:all var(--transition-normal)}.card:hover{border-color:var(--border-glow)}.card-glow{box-shadow:var(--shadow-glow);border-color:var(--accent-primary)}.panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.panel-header{padding:var(--space-md) var(--space-lg);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.panel-header h3{font-size:1rem;font-family:var(--font-heading);color:var(--accent-primary)}.panel-body{padding:var(--space-lg)}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:20px;align-items:center;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-dm{color:var(--accent-primary);background:linear-gradient(135deg,#c9a84c33,#c9a84c1a);border:1px solid #c9a84c4d}.badge-player{color:var(--accent-secondary);background:#8b5cf626;border:1px solid #8b5cf64d}.tabs{background:var(--bg-primary);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex;overflow-x:auto}.tab{text-align:center;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;font-size:.85rem;font-weight:500;font-family:var(--font-body);background:0 0;border:none;flex:1;padding:10px 16px}.tab:hover{color:var(--text-secondary);background:var(--bg-tertiary)}.tab.active{color:var(--accent-primary);background:var(--bg-card);box-shadow:var(--shadow-sm)}.toast-container{z-index:10000;gap:var(--space-sm);flex-direction:column;display:flex;position:fixed;top:20px;right:20px}.toast{align-items:center;gap:var(--space-sm);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-width:360px;padding:12px 20px;animation:.3s slideInRight,.3s 3.7s forwards fadeOut;display:flex}.toast-turn{border-left:3px solid var(--accent-primary)}.toast-info{border-left:3px solid var(--accent-info)}.toast-success{border-left:3px solid var(--accent-success)}.stat-grid{gap:var(--space-sm);grid-template-columns:repeat(3,1fr);display:grid}.stat-box{padding:var(--space-sm);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);text-align:center;flex-direction:column;align-items:center;display:flex}.stat-label{color:var(--accent-primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:2px;font-size:.7rem;font-weight:700}.stat-value{color:var(--text-primary);font-size:1.4rem;font-weight:700}.stat-mod{color:var(--text-secondary);font-size:.75rem}.stat-input{text-align:center;width:60px;color:var(--text-primary);background:0 0;border:none;outline:none;font-size:1.3rem;font-weight:700}.stat-input:focus{color:var(--accent-primary)}.dice-result{background:linear-gradient(135deg, var(--bg-tertiary), var(--bg-card));border:2px solid var(--accent-primary);border-radius:var(--radius-sm);width:48px;height:48px;color:var(--accent-primary);box-shadow:0 0 12px var(--accent-primary-glow);justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;display:inline-flex}.hp-bar-container{background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;width:100%;height:12px;overflow:hidden}.hp-bar{height:100%;transition:width var(--transition-normal), background var(--transition-normal);border-radius:6px}.hp-bar.hp-high{background:linear-gradient(90deg,#22c55e,#16a34a)}.hp-bar.hp-mid{background:linear-gradient(90deg,#eab308,#ca8a04)}.hp-bar.hp-low{background:linear-gradient(90deg,#ef4444,#dc2626)}.initiative-row{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex}.initiative-row.active{border:1px solid var(--accent-primary);box-shadow:0 0 15px var(--accent-primary-glow);background:#c9a84c1a}.initiative-row .turn-indicator{background:var(--text-muted);border-radius:50%;width:8px;height:8px}.initiative-row.active .turn-indicator{background:var(--accent-primary);box-shadow:0 0 8px var(--accent-primary);animation:1.5s ease-in-out infinite pulse}.session-layout{grid-template-rows:auto 1fr;grid-template-columns:1fr 360px;gap:0;height:calc(100vh - 60px);display:grid}.session-layout.chat-hidden{grid-template-columns:1fr}.session-main{padding:var(--space-md);grid-area:2/1;overflow-y:auto}.session-sidebar{border-left:1px solid var(--border-color);background:var(--bg-secondary);flex-direction:column;grid-area:1/2/-1;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes diceRoll{0%{transform:rotate(0)scale(1)}25%{transform:rotate(90deg)scale(1.2)}50%{transform:rotate(180deg)scale(1)}75%{transform:rotate(270deg)scale(1.1)}to{transform:rotate(360deg)scale(1)}}@keyframes glow{0%,to{box-shadow:0 0 5px var(--accent-primary-glow)}50%{box-shadow:0 0 20px var(--accent-primary-glow), 0 0 40px #c9a84c1a}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.95)}to{transform:scale(1)}}.animate-fade-in{animation:.3s fadeIn}.animate-slide-up{animation:.4s slideUp}.animate-bounce-in{animation:.5s bounceIn}.animate-dice-roll{animation:.6s diceRoll}.animate-glow{animation:2s ease-in-out infinite glow}@media (width<=1024px){.session-layout{grid-template-rows:auto 1fr auto;grid-template-columns:1fr}.session-sidebar{border-left:none;border-top:1px solid var(--border-color);grid-area:3/1;max-height:300px}.stat-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=640px){.stat-grid{grid-template-columns:repeat(2,1fr)}.tabs{gap:1px}.tab{padding:8px 10px;font-size:.75rem}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.text-center{text-align:center}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-muted)}.text-gold{color:var(--accent-primary)}.w-full{width:100%}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mb-md{margin-bottom:var(--space-md)}.overflow-auto{overflow:auto}
