:root{--primary-color: #8b5cf6;--primary-dark: #7c3aed;--secondary-color: #1e1b4b;--accent-color: #f59e0b;--bg-dark: #0f0a1f;--bg-card: #1a1425;--text-primary: #f8fafc;--text-secondary: #94a3b8;--border-color: #2d2440;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary)}.card-header{background:#8b5cf61a;border-bottom:1px solid var(--border-color);font-weight:600}.btn-primary{background:var(--primary-color);border-color:var(--primary-color)}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.btn-outline-primary{color:var(--primary-color);border-color:var(--primary-color)}.btn-outline-primary:hover{background:var(--primary-color);color:#fff}.form-control,.form-select{background:var(--bg-dark);border:1px solid var(--border-color);color:var(--text-primary)}.form-control:focus,.form-select:focus{background:var(--bg-dark);border-color:var(--primary-color);color:var(--text-primary);box-shadow:0 0 0 .25rem #8b5cf640}.form-control::placeholder{color:var(--text-secondary)}.navbar{background:var(--bg-card)!important;border-bottom:1px solid var(--border-color)}.navbar-brand{font-weight:700;color:var(--primary-color)!important}.nav-link{color:var(--text-secondary)!important}.nav-link:hover,.nav-link.active{color:var(--primary-color)!important}.table{color:var(--text-primary)}.table-dark{--bs-table-bg: var(--bg-card);--bs-table-border-color: var(--border-color)}.badge{font-weight:500}.badge-primary{background:var(--primary-color)}.badge-secondary{background:var(--border-color)}.modal-content{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary)}.modal-header{border-bottom:1px solid var(--border-color)}.modal-footer{border-top:1px solid var(--border-color)}.btn-close{filter:invert(1)}.alert-primary{background:#8b5cf61a;border-color:var(--primary-color);color:var(--primary-color)}.progress{background:var(--bg-dark)}.progress-bar{background:var(--primary-color)}.dropdown-menu{background:var(--bg-card);border:1px solid var(--border-color)}.dropdown-item{color:var(--text-primary)}.dropdown-item:hover{background:var(--bg-dark);color:var(--primary-color)}.tooltip-inner{background:var(--bg-card);border:1px solid var(--border-color)}.bs-tooltip-top .tooltip-arrow:before{border-top-color:var(--border-color)}.list-group-item{background:var(--bg-card);border-color:var(--border-color);color:var(--text-primary)}.list-group-item:hover{background:var(--bg-dark)}.page-link{background:var(--bg-card);border-color:var(--border-color);color:var(--text-primary)}.page-link:hover{background:var(--bg-dark);color:var(--primary-color)}.page-item.active .page-link{background:var(--primary-color);border-color:var(--primary-color)}.game-room{display:grid;grid-template-columns:280px 1fr 300px;gap:1rem;height:calc(100vh - 56px);padding:1rem}.room-sidebar,.room-main{display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.room-chat{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-input-area{border-top:1px solid var(--border-color);padding:1rem}.message{padding:.75rem 1rem;border-radius:8px;max-width:85%}.message.user{background:var(--primary-color);align-self:flex-end}.message.other{background:var(--bg-dark);align-self:flex-start}.message.gm{background:#f59e0b26;border:1px solid var(--accent-color);align-self:center;max-width:95%}.message.system{background:transparent;color:var(--text-secondary);font-style:italic;align-self:center;text-align:center}.character-sheet{padding:1rem}.stat-block{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem}.stat-item{text-align:center;padding:.5rem;background:var(--bg-dark);border-radius:8px}.stat-mod{font-size:1.25rem;font-weight:700;color:var(--primary-color)}.stat-name{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.dice-tray{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;padding:1rem}.dice-btn{width:50px;height:50px;border-radius:8px;border:2px solid var(--border-color);background:var(--bg-dark);color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .2s}.dice-btn:hover{border-color:var(--primary-color);background:var(--primary-color);transform:translateY(-2px)}.dice-result{text-align:center;padding:.5rem;margin-top:.5rem;background:var(--bg-dark);border-radius:8px;animation:rollIn .3s ease-out}@keyframes rollIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.voice-indicator{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--danger-color);border-radius:20px;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.loading-spinner{display:inline-block;width:2rem;height:2rem;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.landing-page{min-height:100vh;background:linear-gradient(135deg,var(--bg-dark) 0%,#1a1025 100%);overflow-x:hidden}.hero-section{position:relative;min-height:100vh;display:flex;align-items:center;padding:100px 0 60px;overflow:hidden}.hero-bg-effects{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.floating-dice{position:absolute;opacity:.1;animation:float 20s infinite ease-in-out;font-size:3rem;color:var(--primary-color)}.floating-dice.d20{top:10%;left:10%;animation-delay:0s}.floating-dice.d12{top:20%;right:15%;animation-delay:-5s}.floating-dice.d8{bottom:30%;left:20%;animation-delay:-10s}.floating-dice.d6{bottom:10%;right:10%;animation-delay:-15s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-30px) rotate(180deg)}}.hero-content{position:relative;z-index:1}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.text-gradient{background:linear-gradient(135deg,var(--primary-color),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.hero-buttons{display:flex;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}.hero-stats{display:flex;gap:3rem;flex-wrap:wrap}.stat-item{text-align:center}.stat-value{font-size:2.5rem;font-weight:700;color:var(--primary-color);margin-bottom:.25rem}.hero-visual{position:relative;height:500px}.hero-image-container{position:relative;height:100%;display:flex;justify-content:center;align-items:center}.hero-dice-roll{position:relative;width:200px;height:200px;display:flex;justify-content:center;align-items:center;animation:pulse-glow 3s infinite ease-in-out}.dice{width:150px;height:150px;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);display:flex;justify-content:center;align-items:center;font-size:3rem;font-weight:700;color:#fff;animation:rotate-dice 10s infinite linear}.dice.d20{clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%)}@keyframes rotate-dice{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dice-aura{position:absolute;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.3) 0%,transparent 70%);animation:aura-pulse 2s infinite ease-in-out}@keyframes aura-pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.2);opacity:.8}}@keyframes pulse-glow{0%,to{filter:drop-shadow(0 0 20px rgba(139,92,246,.5))}50%{filter:drop-shadow(0 0 40px rgba(139,92,246,.8))}}.floating-cards{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;justify-content:center;align-items:center;gap:1rem}.floating-cards .card{position:absolute;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;text-align:center;animation:float-card 6s infinite ease-in-out;box-shadow:0 10px 30px #0000004d}.character-card{top:10%;left:10%;animation-delay:0s}.campaign-card{top:15%;right:10%;animation-delay:-2s}.room-card{bottom:15%;left:20%;animation-delay:-4s}@keyframes float-card{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.card-icon{font-size:2.5rem;margin-bottom:.5rem}.card-label{color:var(--text-secondary);font-size:.875rem;font-weight:600}.features-section{padding:100px 0;background:var(--bg-dark)}.section-header{margin-bottom:60px}.section-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.section-subtitle{font-size:1.125rem;color:var(--text-secondary)}.feature-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:2rem;height:100%;transition:all .3s ease}.feature-card:hover{transform:translateY(-5px);border-color:var(--primary-color);box-shadow:0 10px 40px #8b5cf633}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-title{font-size:1.25rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.feature-description{color:var(--text-secondary);line-height:1.6}.steps-section{padding:100px 0;background:linear-gradient(180deg,var(--bg-dark) 0%,#1a1025 100%)}.steps-timeline{display:flex;flex-direction:column;gap:2rem;max-width:800px;margin:0 auto}.step-item{display:flex;align-items:flex-start;gap:1.5rem;position:relative}.step-number{width:60px;height:60px;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;flex-shrink:0;box-shadow:0 5px 20px #8b5cf666}.step-content{flex:1}.step-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.step-description{color:var(--text-secondary);line-height:1.6}.step-connector{position:absolute;left:30px;top:70px;width:2px;height:calc(100% - 20px);background:linear-gradient(180deg,var(--primary-color),transparent)}.cta-section{padding:100px 0;background:var(--bg-dark)}.cta-box{background:linear-gradient(135deg,#8b5cf61a,#7c3aed1a);border:1px solid var(--primary-color);border-radius:24px;padding:4rem 2rem;text-align:center}.cta-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.cta-subtitle{font-size:1.125rem;color:var(--text-secondary);margin-bottom:2rem}.landing-footer{padding:40px 0;border-top:1px solid var(--border-color);background:var(--bg-card)}.footer-brand{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--primary-color);margin-bottom:.5rem}.footer-text{color:var(--text-secondary);font-size:.875rem}@media (max-width: 992px){.hero-title{font-size:2.5rem}.hero-visual{height:400px;margin-top:3rem}.hero-stats{gap:2rem}.steps-timeline{flex-direction:column}.step-connector{display:none}}@media (max-width: 768px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.hero-buttons{flex-direction:column}.section-title{font-size:2rem}.cta-title{font-size:1.75rem}}@media (max-width: 1200px){.game-room{grid-template-columns:1fr;height:auto}.room-sidebar,.room-chat{max-height:400px}}.dashboard-page{min-height:calc(100vh - 56px);background:linear-gradient(135deg,var(--bg-dark) 0%,#1a1025 100%);padding-bottom:60px}.dashboard-welcome{padding:60px 0 40px}.welcome-box{background:linear-gradient(135deg,#8b5cf626,#7c3aed1a);border:1px solid var(--primary-color);border-radius:24px;padding:3rem;display:flex;justify-content:space-between;align-items:center;gap:2rem}.welcome-content{flex:1}.welcome-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.welcome-subtitle{font-size:1.125rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.welcome-actions{display:flex;gap:1rem;flex-wrap:wrap}.welcome-avatar{flex-shrink:0}.avatar-circle{width:120px;height:120px;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:4rem;color:#fff;box-shadow:0 10px 40px #8b5cf666}.dashboard-stats{padding:40px 0}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease}.stat-card:hover{transform:translateY(-3px);border-color:var(--primary-color);box-shadow:0 10px 30px #8b5cf633}.stat-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.stat-icon.bg-primary{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark))}.stat-icon.bg-success{background:linear-gradient(135deg,var(--success-color),#059669)}.stat-icon.bg-warning{background:linear-gradient(135deg,var(--warning-color),#d97706)}.stat-icon.bg-info{background:linear-gradient(135deg,#06b6d4,#0891b2)}.stat-content{flex:1}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:.25rem}.stat-label{color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.dashboard-sections{padding:20px 0}.dashboard-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;transition:all .3s ease}.dashboard-card:hover{border-color:var(--border-color);box-shadow:0 10px 40px #0000004d}.card-header-custom{background:#8b5cf61a;border-bottom:1px solid var(--border-color);padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.card-header-custom h3{font-size:1.25rem;font-weight:600;margin:0;display:flex;align-items:center;gap:.5rem}.header-actions{display:flex;gap:.5rem}.card-body-custom{padding:1.5rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state i{font-size:4rem;opacity:.3;margin-bottom:1rem;display:block}.empty-state p{margin-bottom:1.5rem;font-size:1rem}.list-custom{display:flex;flex-direction:column;gap:.75rem}.list-item-custom{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-dark);border-radius:12px;text-decoration:none;color:var(--text-primary);transition:all .2s ease;border:1px solid transparent}.list-item-custom:hover{background:var(--bg-dark);border-color:var(--primary-color);transform:translate(5px)}.list-item-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#fff;flex-shrink:0}.list-item-icon.bg-primary{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark))}.list-item-icon.bg-success{background:linear-gradient(135deg,var(--success-color),#059669)}.list-item-content{flex:1}.list-item-title{font-weight:600;margin-bottom:.25rem}.list-item-subtitle{font-size:.875rem;color:var(--text-secondary)}.list-item-arrow{color:var(--text-secondary);opacity:.5}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.character-card-mini{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-dark);border:1px solid var(--border-color);border-radius:12px;text-decoration:none;color:var(--text-primary);transition:all .2s ease}.character-card-mini:hover{border-color:var(--primary-color);transform:translateY(-3px);box-shadow:0 5px 20px #8b5cf633}.char-avatar{width:50px;height:50px;border-radius:50%;overflow:hidden;background:var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--primary-color);flex-shrink:0}.char-avatar img{width:100%;height:100%;object-fit:cover}.char-info{flex:1}.char-name{font-weight:600;margin-bottom:.25rem}.char-details{font-size:.875rem;color:var(--text-secondary)}.char-stats{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem}.char-stat{display:flex;align-items:center;gap:.25rem;color:var(--text-secondary)}.char-stat i{color:var(--danger-color)}@media (max-width: 992px){.welcome-box{flex-direction:column;text-align:center}.welcome-title{font-size:2rem}.welcome-actions{justify-content:center}.welcome-avatar{display:none}}@media (max-width: 768px){.welcome-box{padding:2rem 1.5rem}.welcome-title{font-size:1.5rem}.welcome-subtitle{font-size:1rem}.stat-card{padding:1rem}.stat-icon{width:50px;height:50px;font-size:1.25rem}.stat-value{font-size:1.5rem}.characters-grid{grid-template-columns:1fr}}.create-room-page{min-height:calc(100vh - 56px);background:linear-gradient(135deg,var(--bg-dark) 0%,#1a1025 100%);padding-bottom:60px}.page-header{text-align:center;margin-bottom:2rem}.page-title{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;gap:.75rem}.page-subtitle{color:var(--text-secondary);font-size:1.125rem}.campaign-type-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.type-option{background:var(--bg-card);border:2px solid var(--border-color);border-radius:12px;padding:1.25rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:flex-start;gap:1rem;position:relative}.type-option:hover{border-color:var(--primary-color);transform:translateY(-2px)}.type-option.active{border-color:var(--primary-color);background:#8b5cf61a;box-shadow:0 5px 20px #8b5cf64d}.option-icon{width:50px;height:50px;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.option-content{flex:1}.option-title{font-weight:600;margin-bottom:.25rem}.option-description{font-size:.875rem;color:var(--text-secondary);line-height:1.4}.option-check{color:var(--primary-color);font-size:1.5rem;flex-shrink:0}.info-box{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;display:flex;gap:1rem}.info-icon{width:50px;height:50px;background:linear-gradient(135deg,var(--info-color, #06b6d4),#0891b2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.info-content h5{font-weight:600;margin-bottom:.75rem}.info-list{margin:0;padding-left:1.25rem;color:var(--text-secondary)}.info-list li{margin-bottom:.5rem;line-height:1.5}@media (max-width: 768px){.page-title{font-size:1.75rem;flex-direction:column;text-align:center}.campaign-type-selector{grid-template-columns:1fr}.info-box{flex-direction:column;text-align:center}.info-icon{margin:0 auto}}
