:root{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e0e0e0;--text-primary: #1a1a1a;--text-secondary: #666666;--text-tertiary: #999999;--border-color: #d0d0d0;--accent-color: #8b4513;--accent-hover: #6b3410;--success-color: #2e7d32;--error-color: #c62828;--warning-color: #f57c00;--shadow: rgba(0, 0, 0, .1);--shadow-strong: rgba(0, 0, 0, .2)}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2a2a2a;--bg-tertiary: #3a3a3a;--text-primary: #ffffff;--text-secondary: #b0b0b0;--text-tertiary: #808080;--border-color: #404040;--accent-color: #d4a574;--accent-hover: #e4b584;--success-color: #4caf50;--error-color: #ef5350;--warning-color: #ff9800;--shadow: rgba(0, 0, 0, .3);--shadow-strong: rgba(0, 0, 0, .5)}[data-theme=warm]{--bg-primary: #fdf6e3;--bg-secondary: #eee8d5;--bg-tertiary: #e3dcc8;--text-primary: #5c4a3a;--text-secondary: #8a7a65;--text-tertiary: #a89f8f;--border-color: #d3c7b0;--accent-color: #b5651d;--accent-hover: #8b4513;--success-color: #6b8e23;--error-color: #c62828;--warning-color: #d48020;--shadow: rgba(92, 74, 58, .1);--shadow-strong: rgba(92, 74, 58, .2)}[data-theme=cool]{--bg-primary: #e8f4f8;--bg-secondary: #d6ebf2;--bg-tertiary: #c4e0eb;--text-primary: #1e3a4a;--text-secondary: #456578;--text-tertiary: #6b8fa0;--border-color: #b0d4e1;--accent-color: #2c7da0;--accent-hover: #1e5a78;--success-color: #2e7d6e;--error-color: #c62828;--warning-color: #f57c00;--shadow: rgba(30, 58, 74, .1);--shadow-strong: rgba(30, 58, 74, .2)}[data-theme=forest]{--bg-primary: #f0f4ed;--bg-secondary: #e2ead8;--bg-tertiary: #d4e0c9;--text-primary: #2c3e2f;--text-secondary: #4a6550;--text-tertiary: #698870;--border-color: #c5d9b8;--accent-color: #4a7c59;--accent-hover: #3a6347;--success-color: #6b8e23;--error-color: #c62828;--warning-color: #d48020;--shadow: rgba(44, 62, 47, .1);--shadow-strong: rgba(44, 62, 47, .2)}[data-theme=midnight]{--bg-primary: #0f1419;--bg-secondary: #1a2332;--bg-tertiary: #253145;--text-primary: #e0e6ed;--text-secondary: #a0b0c0;--text-tertiary: #708090;--border-color: #3a4a5e;--accent-color: #5b9bd5;--accent-hover: #7db3e8;--success-color: #4caf50;--error-color: #ef5350;--warning-color: #ff9800;--shadow: rgba(0, 0, 0, .4);--shadow-strong: rgba(0, 0, 0, .6)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=warm]):not([data-theme=cool]):not([data-theme=forest]){--bg-primary: #1a1a1a;--bg-secondary: #2a2a2a;--bg-tertiary: #3a3a3a;--text-primary: #ffffff;--text-secondary: #b0b0b0;--text-tertiary: #808080;--border-color: #404040;--accent-color: #d4a574;--accent-hover: #e4b584;--success-color: #4caf50;--error-color: #ef5350;--warning-color: #ff9800;--shadow: rgba(0, 0, 0, .3);--shadow-strong: rgba(0, 0, 0, .5)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background-color .3s ease,color .3s ease}#app{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{margin-bottom:.75rem;font-weight:600;line-height:1.2}body{font-size:16px}h1{font-size:1.75rem}h2{font-size:1.25rem}h3{font-size:1rem}p{margin-bottom:.75rem;font-size:.95rem}.text-sm{font-size:.8rem}.text-xs{font-size:.7rem}a{color:var(--accent-color);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-hover)}button,.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;background-color:var(--accent-color);color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}button:hover,.btn:hover{background-color:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 8px var(--shadow);color:#fff}button:active,.btn:active{transform:translateY(0)}button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{padding:.75rem 1.5rem;border-radius:8px;border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-primary);font-size:1rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;transition:all .18s ease}.btn-secondary:hover{background-color:var(--bg-tertiary);border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-1px);box-shadow:0 4px 10px var(--shadow)}.btn-secondary:active{transform:translateY(0);box-shadow:0 2px 5px var(--shadow)}.btn-secondary:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}.btn-small{padding:.5rem 1rem;font-size:.875rem}input,textarea,select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:1rem;font-family:inherit;transition:border-color .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-color)}textarea{resize:vertical;min-height:100px}.card{background-color:var(--bg-secondary);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px var(--shadow);transition:box-shadow .2s ease}.card:hover{box-shadow:0 4px 12px var(--shadow-strong)}.death-saves-container{background-color:var(--bg-secondary);border-radius:12px;padding:1.5rem;margin-top:1rem}.death-saves-container .death-save-title{color:var(--warning-color);font-weight:600;font-size:.875rem;letter-spacing:.5px;text-transform:uppercase;text-align:center;margin-bottom:1rem}.death-save-track{display:flex;flex-direction:column;align-items:center}.death-save-track .track-label{font-weight:600;text-transform:uppercase;font-size:.7rem;text-align:center;margin-bottom:.5rem}.death-save-track .track-circles{display:flex;justify-content:center;gap:.5rem}.death-save-circle{width:16px;height:16px;border-radius:50%;border:2px solid;transition:all .2s ease}.death-save-circle.success{border-color:var(--success-color)}.death-save-circle.success.filled{background-color:var(--success-color)}.death-save-circle.failure{border-color:var(--error-color)}.death-save-circle.failure.filled{background-color:var(--error-color)}nav{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1rem;position:sticky;top:0;z-index:100}nav ul{list-style:none;display:flex;gap:1.5rem;flex-wrap:wrap}nav a{color:var(--text-primary);font-weight:500}nav a:hover{color:var(--accent-color)}.container{max-width:1200px;margin:0 auto;padding:1rem}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.spinner{border:3px solid var(--bg-tertiary);border-top:3px solid var(--accent-color);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:2rem auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.message{padding:1rem;border-radius:8px;margin-bottom:1rem}.message-error{background-color:var(--error-color);color:#fff}.message-success{background-color:var(--success-color);color:#fff}.message-warning{background-color:var(--warning-color);color:#fff}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background-color:var(--bg-primary);border-radius:12px;padding:2rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px var(--shadow-strong)}.hidden{display:none!important}.text-center{text-align:center}.text-secondary{color:var(--text-secondary)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center,.align-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-wrap{flex-wrap:wrap}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.page-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-title{margin:0}.card-center{max-width:500px;margin:2rem auto}.card-padded-xl{padding:3rem}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-secondary)}.card-clickable{cursor:pointer;position:relative}.btn-icon{background:transparent;border:none;padding:.25rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.btn-icon:hover{color:var(--accent-color);transform:translateY(-1px)}.card-meta-row{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem;gap:.5rem}.meta-label{font-size:.875rem;color:var(--text-secondary)}.delete-btn{position:absolute;top:1rem;right:1rem}@media(max-width:768px){body{font-size:15px}h1{font-size:1.5rem}h2{font-size:1.15rem}h3{font-size:.95rem}.container{padding:.75rem}nav ul{gap:1rem}.modal{padding:1.5rem}}.model-card{background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:1.25rem;margin-bottom:1rem;cursor:pointer;transition:all .2s ease}.model-card:hover{border-color:var(--accent-color);box-shadow:0 4px 12px var(--shadow-strong);transform:translateY(-2px)}.model-card.selected{border-color:var(--accent-color);background-color:var(--bg-tertiary);box-shadow:0 0 0 3px #8b45131a}[data-theme=dark] .model-card.selected{box-shadow:0 0 0 3px #d4a57433}.model-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;gap:1rem}.model-name{font-size:1.1rem;font-weight:600;margin:0;color:var(--text-primary)}.model-id{font-size:.85rem;color:var(--text-tertiary);font-family:Courier New,monospace;margin-bottom:.75rem}.badge-selected{background-color:var(--accent-color);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;white-space:nowrap}.model-details{display:flex;flex-direction:column;gap:.5rem}.model-detail{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;gap:1rem}.detail-label{color:var(--text-secondary);font-weight:500;min-width:80px}.detail-value{color:var(--text-primary);text-align:right;flex:1}@media(max-width:768px){.model-card{padding:1rem}.model-name{font-size:1rem}.model-detail{flex-direction:column;align-items:flex-start;gap:.25rem}.detail-label{min-width:auto}.detail-value{text-align:left}}body,.card,.btn,.btn-secondary,input,textarea,select,nav,a,.model-card{transition-property:background-color,border-color,color,box-shadow,transform;transition-duration:.2s;transition-timing-function:ease}.game-container{display:flex;flex-direction:column;gap:1rem;padding:1rem;max-width:900px;margin:0 auto 2rem;width:100%}.game-main{display:flex;flex-direction:column;width:100%}.game-main-card{display:flex;flex-direction:column;max-height:calc(100dvh - 140px);min-height:400px}.game-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem}.game-header-left{flex:1}.game-header h2{margin:0 0 .25rem}.usage-display{flex-shrink:0}.usage-stats{display:flex;gap:1rem;align-items:center}.usage-stat{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.usage-stat-label{font-size:.75rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.usage-stat-value{font-size:.875rem;color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums}.usage-cost-stat .usage-stat-value{color:var(--accent-color)}@media(max-width:768px){.game-header{flex-direction:column;align-items:stretch}.usage-stats{justify-content:flex-end}.usage-stat-label{font-size:.7rem}.usage-stat-value{font-size:.8rem}}.messages-container{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;padding:1rem 1rem 2rem;margin-bottom:1rem;background-color:var(--bg-primary);border-radius:8px;min-height:0;max-width:100%;overscroll-behavior:contain}.game-below-chat{display:flex;flex-direction:column;gap:1rem}.rolls-title{margin-top:0}.roll-history-container{max-height:400px;overflow-y:auto}.message{margin-bottom:1rem;padding:1rem;border-radius:8px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-user{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-left:2rem;box-shadow:0 2px 8px #667eea4d}.message-assistant{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;margin-right:2rem;box-shadow:0 2px 8px #f093fb4d}[data-theme=dark] .message-assistant{background:linear-gradient(135deg,#434343,#000);color:#e0e0e0}.message-system{background-color:var(--bg-secondary);border-left:3px solid var(--accent-color);font-style:italic;text-align:center}.message-dice{background:linear-gradient(135deg,#ffeaa7,#fdcb6e);border-left:3px solid #fdcb6e;color:#2d3436}[data-theme=dark] .message-dice{background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff}.message-damage{background:linear-gradient(135deg,#ff7675,#d63031);border-left:3px solid #d63031;color:#fff;font-weight:500}.message-healing{background:linear-gradient(135deg,#55efc4,#00b894);border-left:3px solid #00b894;color:#fff;font-weight:500}.message-combat{background:linear-gradient(135deg,#fab1a0,#e17055);border-left:3px solid #e17055;color:#fff;font-weight:600}.message-system[data-msg-id*=_error]{background:linear-gradient(135deg,#ff7675,#d63031);border-left:3px solid #d63031;color:#fff;font-weight:500}.message-content{line-height:1.6}.message-content code{background-color:#0000001a;padding:.2rem .4rem;border-radius:3px;font-family:Courier New,monospace;font-size:.9em}.inline-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .5rem;border-radius:999px;font-size:.85rem;font-weight:600;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);white-space:nowrap}.inline-badge.location{background-color:#8b45130f;border-color:#8b45131f}.inline-badge.inventory{background-color:#228b220f;border-color:#228b221f}.inline-badge.roll{background-color:#2c82c90f;border-color:#2c82c91f}.inline-badge.damage{background-color:#c628280f;border-color:#c628281f}.inline-badge.heal{background-color:#4caf500f;border-color:#4caf501f}.inline-badge.gold{background-color:#c59c550f;border-color:#c59c551f}.inline-badge.combat{background-color:#ffa7260f;border-color:#ffa7261f}.inline-badge.status{background-color:#607d8b0f;border-color:#607d8b1f}.inline-badge.relationship{background-color:#5c6bc00f;border-color:#5c6bc01f}.inline-badge.action{background-color:#ffeb3b0f;border-color:#ffeb3b1f}[data-theme=dark] .inline-badge{color:var(--text-primary);background-color:#ffffff0a}[data-theme=dark] .inline-badge.location{box-shadow:0 1px #00000026 inset}.message-user .message-content code,.message-damage .message-content code,.message-healing .message-content code,.message-combat .message-content code{background-color:#fff3}.message-content em{font-style:italic}.message-content strong{font-weight:600}.dice-result{margin-top:.5rem;padding:.5rem;background-color:#0000001a;border-radius:4px;font-family:monospace}.input-container{padding-top:1rem;border-top:1px solid var(--border-color)}.message-reasoning{margin-bottom:.75rem;padding:.75rem;border-radius:6px;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2)}[data-theme=dark] .message-reasoning{background-color:#ffffff0d;border-color:#ffffff1a}.reasoning-details{width:100%}.reasoning-summary{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;color:#ffffffe6;list-style:none;-webkit-user-select:none;user-select:none;padding:.25rem 0}.reasoning-summary:hover{color:#fff}.reasoning-summary::marker{content:""}.reasoning-summary::-webkit-details-marker{display:none}.reasoning-tokens{font-size:.75rem;color:#ffffffb3;font-weight:400}.reasoning-body{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.15);max-height:200px;overflow-y:auto;font-size:.825rem;line-height:1.5;color:#fffc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.reasoning-body::-webkit-scrollbar{width:6px}.reasoning-body::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.reasoning-body::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.reasoning-body::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.message-usage{margin-top:.75rem;padding:.5rem .75rem;border-radius:4px;background-color:#0000001a;font-size:.75rem;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}[data-theme=dark] .message-usage{background-color:#ffffff0d}.usage-label{font-weight:600;color:#ffffffe6}.usage-value{color:#fffc}.usage-separator{color:#ffffff80}.usage-cost{color:#ffffffe6;font-weight:600;margin-left:auto}@media(max-width:768px){.message-usage{font-size:.7rem;padding:.4rem .6rem;gap:.4rem}}.chat-form{display:flex;gap:.5rem}.chat-input{flex:1 1 auto;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;background-color:var(--bg-secondary);color:var(--text-primary)}.form-label{display:block;margin-bottom:.5rem;font-weight:500}.card-padded-lg{padding:3rem}.btn-block{width:100%}.form-check{display:flex;align-items:flex-start;gap:1rem;cursor:pointer;padding:.5rem 0}.form-check input[type=checkbox]{margin-top:.2rem;flex-shrink:0}.form-check-label{display:block;line-height:1.5;flex:1}.character-subtitle{margin:.25rem 0 1rem}.key-stats{padding:.75rem;background-color:var(--bg-tertiary);border-radius:6px;font-size:.875rem}.progress-bar-lg{height:24px}.dice-tray{display:flex;flex-direction:column;gap:.35rem;padding:.5rem .75rem;margin-bottom:.5rem;border-radius:8px;background-color:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:0 1px 4px var(--shadow)}.dice-tray-row{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.dice-btn,.dice-quick-btn,.adv-toggle{padding:.25rem .6rem;font-size:.75rem;border-radius:6px;border:none;cursor:pointer;background-color:var(--bg-tertiary);color:var(--text-primary);box-shadow:0 1px 3px var(--shadow);white-space:nowrap}.dice-btn:hover,.dice-quick-btn:hover,.adv-toggle:hover{background-color:var(--accent-color);color:#fff;box-shadow:0 2px 6px var(--shadow-strong);transform:translateY(-1px)}.adv-toggle.active{background-color:var(--accent-color);color:#fff}@media(max-width:768px){.dice-tray{padding:.4rem .5rem;gap:.25rem}.dice-btn,.dice-quick-btn,.adv-toggle{padding:.2rem .5rem;font-size:.7rem}}.suggested-actions{display:flex;gap:.5rem;overflow-x:auto;padding:.75rem 0;margin-bottom:.75rem;scrollbar-width:thin;scrollbar-color:var(--accent-color) var(--bg-tertiary);-webkit-overflow-scrolling:touch}.suggested-actions::-webkit-scrollbar{height:6px}.suggested-actions::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.suggested-actions::-webkit-scrollbar-thumb{background:var(--accent-color);border-radius:3px}.suggested-actions::-webkit-scrollbar-thumb:hover{background:var(--accent-hover)}.action-bubble{flex-shrink:0;padding:.5rem 1rem;background:linear-gradient(135deg,var(--accent-color) 0%,var(--accent-hover) 100%);color:#fff;border:none;border-radius:20px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 6px var(--shadow)}.action-bubble:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-strong);background:linear-gradient(135deg,var(--accent-hover) 0%,var(--accent-color) 100%);color:#fff}.action-bubble:active{transform:translateY(0)}[data-theme=dark] .action-bubble{background:linear-gradient(135deg,#d4a574,#c49563);color:#1a1a1a}[data-theme=dark] .action-bubble:hover{background:linear-gradient(135deg,#e4b584,#d4a574)}@media(max-width:768px){.action-bubble{font-size:.85rem;padding:.4rem .85rem}}.stat-bar{margin-bottom:1rem}.progress-bar{width:100%;height:20px;background-color:var(--bg-tertiary);border-radius:10px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--success-color),var(--accent-color));transition:width .3s ease}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.stat-item{text-align:center;padding:.5rem;background-color:var(--bg-tertiary);border-radius:6px}.stat-label{display:block;font-size:.75rem;color:var(--text-secondary);font-weight:600}.stat-value{display:block;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.combat-indicator{padding:1rem;background-color:var(--error-color);color:#fff;border-radius:8px;text-align:center}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;background-color:var(--bg-tertiary);border-radius:12px;font-size:.75rem;font-weight:500;gap:.25rem}.location-chips{display:flex;flex-wrap:wrap;gap:.5rem}.location-chip{padding:.5rem 1rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:20px;font-size:.875rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem;white-space:nowrap}.location-chip:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-strong)}.location-chip:active{transform:translateY(0)}@media(max-width:768px){.location-chip{font-size:.8rem;padding:.4rem .85rem}}.template-card{transition:all .2s ease;cursor:pointer;border:1px solid var(--border-color)}.template-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-strong);border-color:var(--accent-color)}@media(max-width:768px){.game-container{padding:.5rem;margin-bottom:1rem;gap:.75rem}.game-main-card{max-height:calc(100vh - 100px);min-height:300px}.messages-container{min-height:200px;padding:.75rem;margin-bottom:.75rem}.message-user{margin-left:.5rem}.message-assistant{margin-right:.5rem}.game-below-chat{gap:.75rem}.game-below-chat .card{padding:1rem}.game-header{padding-bottom:.75rem;margin-bottom:.75rem}.game-header h2{font-size:1.25rem}.input-container{padding-top:.75rem}.chat-input{font-size:16px}}@media(max-width:480px){.game-container{padding:.25rem}.game-main-card{max-height:calc(100vh - 80px);padding:.75rem}.messages-container{padding:.5rem}.game-below-chat .card{padding:.75rem}}.character-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.character-header-left h3{margin:0 .25rem;font-size:1.25rem}.character-header-left .character-subtitle{margin:0;font-size:.875rem}.character-header-right{display:flex;align-items:flex-start;gap:.5rem}.status-chips{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:flex-end}.status-chip{display:inline-block;padding:.25rem .5rem;background-color:var(--secondary-color, #6c757d);color:#fff;border-radius:1rem;font-size:.75rem;font-weight:500;white-space:nowrap;border:1px solid rgba(25,255,255,.2)}.combat-indicator{background-color:#dc35451a;border:1px solid var(--error-color, #dc3545);border-radius:.5rem;padding:.75rem;margin-top:1rem;text-align:center}.spell-slots-grid{display:flex;flex-direction:column;gap:.375rem}.spell-slot-row{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.spell-slot-level{min-width:4rem;font-weight:500}.spell-slot-dots{display:flex;gap:.25rem;flex:1}.spell-slot-dot{font-size:1rem;line-height:1}.spell-slot-dot.filled{color:var(--primary-color)}.spell-slot-dot.empty{color:var(--border-color);opacity:.3}.spell-slot-count{min-width:2.5rem;text-align:right;color:var(--text-secondary)}.concentration-indicator{padding:.5rem;background:var(--warning-bg, rgba(255, 152, 0, .1));border-left:3px solid var(--warning-color, #ff9800);border-radius:4px;font-size:.875rem}.rest-controls{padding:1rem}.rest-controls .flex{display:flex}.rest-controls .gap-2{gap:.5rem}.rest-controls .flex-1{flex:1}.class-resources{font-size:.875rem}.resource-row{display:flex;justify-content:space-between;padding:.25rem 0}.inline-badge.spell{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.inline-badge.rest{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.inline-badge.xp{background:linear-gradient(135deg,#f7971e,#ffd200);color:#1a1a1a;font-weight:600}.spell-list-content{display:flex;flex-direction:column;gap:.5rem}.spell-chip{display:inline-block;padding:.25rem .5rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;font-size:.75rem;cursor:help;transition:all .2s ease}.spell-chip:hover{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.modal-container{width:100%;max-width:500px;max-height:90vh;overflow-y:auto;padding:1rem}.modal-content{background-color:var(--bg-secondary);border-radius:12px;padding:2rem;box-shadow:0 10px 25px #00000080;border:1px solid var(--border-color);animation:slideUp .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.xp-bar-container{height:6px;background-color:var(--bg-tertiary);border-radius:3px;overflow:hidden;margin-top:.5rem}.xp-bar-fill{height:100%;background:linear-gradient(90deg,gold,orange);transition:width .5s ease}.level-badge{position:absolute;bottom:-5px;right:-5px;background-color:var(--primary-color);color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;box-shadow:0 2px 4px #0000004d}.avatar-container{position:relative}
