*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #8b5cf6;--primary-dark: #7c3aed;--secondary: #f59e0b;--bg-dark: #0f0a1e;--bg-card: #1a1333;--bg-input: #251d3d;--text-primary: #ffffff;--text-secondary: #a3a3a3;--border: #3b2d5e;--success: #22c55e;--danger: #ef4444}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,var(--bg-dark) 0%,#1a0a2e 100%);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:flex;flex-direction:column}button{cursor:pointer;border:none;font-family:inherit}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}:root{--primary: #8b5cf6;--primary-dark: #7c3aed;--secondary: #f59e0b;--bg-dark: #0f0d1a;--bg-card: #1a1625;--bg-input: #252033;--text-primary: #f0f0f0;--text-secondary: #a0a0a0;--border: #2d2640;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--gold: #fbbf24;--silver: #9ca3af;--copper: #b45309;--platinum: #e5e7eb}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;max-width:600px;margin:0 auto}.app.loading{display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--text-secondary)}.header{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-dark) 100%);padding:1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;gap:.5rem}.header-icon{font-size:1.5rem}.header h1{font-size:1.25rem;background:linear-gradient(135deg,var(--gold) 0%,var(--primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-right{display:flex;align-items:center;gap:.5rem}.campaign-select{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;padding:.4rem .6rem;font-size:.85rem;max-width:150px}.logout-btn{background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:.4rem .8rem;border-radius:6px;font-size:.8rem;cursor:pointer}.logout-btn:hover{border-color:var(--danger);color:var(--danger)}.main-content{flex:1;padding:1rem;padding-bottom:80px;overflow-y:auto}.card{background:var(--bg-card);border-radius:12px;padding:1rem;margin-bottom:1rem;border:1px solid var(--border)}.card-title{font-size:1.1rem;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.error-card{background:#ef444426;border-color:var(--danger)}.error-card p{color:var(--danger);margin-bottom:.5rem}.error-text{color:var(--danger);margin-bottom:1rem;font-size:.9rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:.4rem}.form-group input,.form-group select{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:.75rem;color:var(--text-primary);font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.checkbox-row{display:flex;gap:1rem;margin-bottom:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary);cursor:pointer;margin-bottom:1rem}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary)}.btn{border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;width:100%}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--primary)}.btn-small{padding:.4rem .8rem;font-size:.8rem;width:auto}.btn-danger{background:var(--danger);color:#fff}.link-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-size:inherit}.link-btn:hover{text-decoration:underline}.nav-bar{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border);padding:.5rem;z-index:100}.nav-items{display:flex;justify-content:space-around;max-width:600px;margin:0 auto}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;background:none;border:none;color:var(--text-secondary);font-size:.7rem;padding:.5rem;cursor:pointer;transition:color .2s}.nav-item.active{color:var(--primary)}.nav-icon{font-size:1.25rem}.auth-screen{justify-content:center}.auth-container{display:flex;justify-content:center;align-items:center;padding:2rem 1rem}.auth-card{width:100%;max-width:400px}.auth-card h2{margin-bottom:1.5rem;text-align:center}.auth-switch{text-align:center;margin-top:1rem;color:var(--text-secondary);font-size:.9rem}.campaign-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.campaign-btn{text-align:left}.player-card{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(139,92,246,.05) 100%)}.player-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.player-name{font-size:1.1rem;font-weight:600}.player-info{font-size:.85rem;color:var(--text-secondary)}.player-stats{display:flex;gap:1rem;margin-bottom:1rem}.stat-box{background:var(--bg-input);border-radius:8px;padding:.5rem .75rem;text-align:center;flex:1}.stat-box label{display:block;font-size:.7rem;color:var(--text-secondary);margin-bottom:.25rem}.stat-box span{font-size:1rem;font-weight:600}.hp-control{display:flex;align-items:center;justify-content:center;gap:.5rem}.hp-control button{background:var(--border);border:none;color:var(--text-primary);width:24px;height:24px;border-radius:4px;cursor:pointer;font-weight:700}.hp-control button:hover{background:var(--primary)}.inventory-section{margin-bottom:1rem}.inventory-section label{font-size:.8rem;color:var(--text-secondary);display:block;margin-bottom:.5rem}.inventory-list{display:flex;flex-wrap:wrap;gap:.5rem}.inventory-item{background:var(--bg-input);padding:.25rem .5rem;border-radius:4px;font-size:.8rem}.player-actions{display:flex;gap:.5rem}.encounter-status{display:flex;gap:1rem;margin:1rem 0;font-size:.9rem;color:var(--text-secondary)}.encounter-actions{display:flex;gap:.5rem;flex-wrap:wrap}.encounter-actions .btn{width:auto;flex:1}.encounter-btn{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.status-badge{font-size:.75rem;padding:.2rem .5rem;border-radius:4px;background:var(--border)}.narrative{font-style:italic;color:var(--text-secondary);font-size:.9rem;margin:.5rem 0;padding:.5rem;background:var(--bg-input);border-radius:6px}.combatants-list{display:flex;flex-direction:column;gap:.5rem}.combatant-card{padding:.75rem}.combatant-card.player{border-left:3px solid var(--success)}.combatant-card.enemy{border-left:3px solid var(--danger)}.combatant-card.active-turn{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(139,92,246,.15) 100%);border:1px solid var(--primary)}.combatant-card.defeated{opacity:.5}.combatant-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.combatant-init{background:var(--bg-input);padding:.25rem .5rem;border-radius:4px;font-weight:700;min-width:32px;text-align:center}.combatant-name{flex:1;font-weight:500}.combatant-type-badge{font-size:.7rem;padding:.2rem .4rem;border-radius:4px;text-transform:uppercase}.combatant-type-badge.player{background:#10b98133;color:var(--success)}.combatant-type-badge.enemy{background:#ef444433;color:var(--danger)}.combatant-stats{display:flex;align-items:center;gap:1rem;font-size:.9rem}.hp-low{color:var(--danger)}.coins-display{display:flex;flex-wrap:wrap;gap:.75rem;margin:1rem 0}.coin{padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem}.coin.copper{background:linear-gradient(135deg,#b45309,#92400e);color:#fff}.coin.silver{background:linear-gradient(135deg,#9ca3af,#6b7280);color:#fff}.coin.gold{background:linear-gradient(135deg,#fbbf24,#d97706);color:#1a1625}.coin.platinum{background:linear-gradient(135deg,#e5e7eb,#9ca3af);color:#1a1625}.loot-section{margin:1rem 0}.loot-section label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.gems-list{display:flex;flex-wrap:wrap;gap:.5rem}.gem-item{background:linear-gradient(135deg,#8b5cf633,#ec489933);padding:.4rem .8rem;border-radius:6px;font-size:.85rem}.items-list{display:flex;flex-direction:column;gap:.5rem}.magic-item{display:flex;justify-content:space-between;align-items:center;background:var(--bg-input);padding:.5rem .75rem;border-radius:6px}.magic-item.common{border-left:3px solid #9ca3af}.magic-item.uncommon{border-left:3px solid var(--success)}.magic-item.rare{border-left:3px solid #3b82f6}.item-name{font-weight:500}.item-rarity{font-size:.75rem;color:var(--text-secondary);text-transform:capitalize}.quick-dice{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.dice-btn{width:auto;padding:.5rem 1rem;font-size:.9rem}.dice-result{text-align:center}.dice-total{font-size:4rem;font-weight:700;background:linear-gradient(135deg,var(--gold) 0%,var(--primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.5rem}.dice-breakdown{color:var(--text-secondary);font-size:1rem;margin-bottom:.5rem}.dice-purpose{color:var(--primary);font-size:.9rem;margin-bottom:1rem}.result-card{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(139,92,246,.08) 100%)}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.result-title{font-size:1.3rem;font-weight:600}.ai-badge{background:linear-gradient(135deg,var(--primary) 0%,#ec4899 100%);color:#fff;font-size:.7rem;padding:.2rem .5rem;border-radius:4px;font-weight:600}.info-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border)}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-secondary);font-size:.9rem}.info-value{font-weight:500}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.stat-item{background:var(--bg-input);border-radius:8px;padding:.75rem;text-align:center}.stat-name{font-size:.7rem;color:var(--text-secondary);margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700}.stat-mod{font-size:.85rem;color:var(--primary)}.backstory-text{font-size:.95rem;line-height:1.6;color:var(--text-secondary)}.initiative-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.initiative-row .player-name{flex:1;font-weight:500}.initiative-row .init-mod{color:var(--text-secondary);font-size:.85rem}.initiative-input{width:60px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;padding:.5rem;color:var(--text-primary);font-size:1rem;text-align:center}.modal-actions{display:flex;gap:.5rem;margin-top:1rem}.modal-actions .btn{flex:1}.text-muted{color:var(--text-secondary);font-size:.9rem}.roll-history{display:flex;flex-direction:column;gap:.5rem}.history-item{display:flex;align-items:center;gap:1rem;padding:.5rem .75rem;background:var(--bg-input);border-radius:6px}.history-total{font-size:1.25rem;font-weight:700;color:var(--primary);min-width:40px}.history-purpose{color:var(--text-secondary);font-size:.9rem}@media(min-width:600px){.app{padding:0 1rem}}
