*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:14px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;height:100vh}h1,h2,h3,h4,h5,h6{font-family:Cinzel,Georgia,serif;font-weight:600;line-height:1.3}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover);text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}#main-app{display:flex;height:100vh;background:var(--bg-primary);color:var(--text-primary)}.app-content{flex:1;overflow-y:auto;padding:1.5rem 2rem;background:var(--bg-primary)}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);height:100vh;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;overflow-y:auto}.sidebar-brand{padding:1.5rem 1.25rem 1rem;border-bottom:1px solid var(--border)}.sidebar-title{font-size:1.3rem;color:var(--accent);margin:0}.sidebar-subtitle{font-size:.75rem;color:var(--text-muted);margin-top:2px}.sidebar-calendar{padding:.75rem 1.25rem;background:var(--accent-dim);border-bottom:1px solid var(--border);font-size:.8rem;color:var(--accent);display:flex;align-items:center;gap:.5rem}.sidebar-nav{flex:1;padding:.75rem 0;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 1.25rem;background:transparent;color:var(--text-secondary);font-size:.9rem;border:none;text-align:left;transition:all var(--duration-fast) var(--ease);border-left:3px solid transparent}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-dim);color:var(--accent);border-left-color:var(--accent);font-weight:500}.nav-icon{font-size:1.1rem;width:1.5rem;text-align:center}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}.sidebar-user{font-size:.8rem;color:var(--text-muted)}.sidebar-logout{background:transparent;color:var(--text-muted);font-size:.8rem;padding:.4rem 0;text-align:left;transition:color var(--duration-fast)}.sidebar-logout:hover{color:var(--error)}.sidebar-bug-report{background:transparent;color:var(--text-muted);font-size:.8rem;padding:.4rem 0;text-align:left;transition:color var(--duration-fast);border:none;cursor:pointer}.sidebar-bug-report:hover{color:var(--accent)}.split-layout{display:flex;gap:1rem;flex:1;min-height:0;max-height:calc(100vh - 180px)}.list-panel{width:380px;min-width:320px;max-width:450px;display:flex;flex-direction:column;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden}.detail-panel-inline{flex:1;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border);overflow-y:auto;padding:1.5rem}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.view-header h1{font-size:1.5rem;color:var(--text-heading)}.view-subtitle{font-size:.85rem;color:var(--text-muted)}.view-header-left,.view-header-right{display:flex;align-items:center;gap:.75rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.dash-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem}.dash-card h3{font-size:1rem;color:var(--text-heading);margin-bottom:.75rem;font-family:Inter,sans-serif;font-weight:600}.dash-calendar-display{font-size:1.1rem;color:var(--accent);font-weight:500}.dash-town-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.75rem;max-height:200px;overflow-y:auto}.dash-town-item{display:flex;justify-content:space-between;padding:.5rem .75rem;background:var(--bg-hover);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast)}.dash-town-item:hover{background:var(--accent-dim)}.dash-town-name{font-weight:500}.dash-town-sub{color:var(--text-muted);font-size:.8rem}.dash-stats-grid{display:flex;gap:1.5rem}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.8rem;font-weight:700;color:var(--accent)}.stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.dash-actions{display:flex;flex-wrap:wrap;gap:.5rem}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1rem;margin-bottom:1.5rem}.settings-section-card:has(.hb-panel-grid){grid-column:1 / -1}.settings-section-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem}.settings-section-card h3{font-family:Inter,sans-serif;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.settings-actions{display:flex;align-items:center;gap:1rem}.homebrew-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.75rem 1.25rem}.hb-panel-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}@media(max-width:1200px){.hb-panel-grid{grid-template-columns:1fr 1fr}}@media(max-width:700px){.hb-panel-grid{grid-template-columns:1fr}}.hb-panel{border:1px solid var(--border);border-radius:8px;background:#00000026;overflow:hidden}.hb-panel-title{padding:.55rem .85rem;font-size:.85rem;font-weight:600;font-family:Inter,sans-serif;color:var(--text-main);background:#ffffff0a;border-bottom:1px solid var(--border)}.hb-panel .homebrew-grid{grid-template-columns:1fr;padding:.65rem .85rem .85rem;gap:.5rem}.settings-hint{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.view-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;text-align:center;color:var(--text-muted)}.view-empty h2{color:var(--text-secondary);margin-bottom:.5rem}.detail-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:.95rem}.muted{color:var(--text-muted)}@media(max-width:768px){.sidebar{width:var(--sidebar-collapsed);min-width:var(--sidebar-collapsed)}.nav-label,.sidebar-subtitle,.sidebar-user,.sidebar-logout,.sidebar-bug-report,.sidebar-calendar .calendar-text{display:none}.split-layout{flex-direction:column}.list-panel{width:100%;max-width:100%;max-height:40vh}}.btn-primary{background:linear-gradient(135deg,#8a5a2b,#b87333,#d4956a);color:#0d0815;border:none;padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem;transition:all var(--duration-fast) var(--ease);box-shadow:var(--shadow-sm)}.btn-primary:hover{background:linear-gradient(135deg,#b87333,#d4956a,#e8b892);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-weight:500;font-size:.85rem;transition:all var(--duration-fast) var(--ease)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-light)}.btn-danger{background:#c75b3a26;color:var(--error);border:1px solid rgba(199,91,58,.3);padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-weight:500;font-size:.85rem;transition:all var(--duration-fast) var(--ease)}.btn-danger:hover{background:#c75b3a40}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.form-group{margin-bottom:.75rem}.form-group label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:.3rem}.form-input,.form-select{width:100%;padding:.55rem .75rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;transition:border-color var(--duration-fast)}.form-input:focus,.form-select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px var(--accent-dim)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236a6a8a' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.search-box{display:flex;align-items:center;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 .75rem;gap:.5rem}.search-box input{background:none;border:none;color:var(--text-primary);padding:.5rem 0;width:160px;outline:none;font-size:.85rem}.search-icon{color:var(--text-muted);font-size:.9rem}.town-select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.9rem;min-width:180px}.town-filters{display:flex;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap;align-items:center}.filter-group{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.filter-dropdown{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);padding:.35rem 2rem .35rem .65rem;border-radius:var(--radius-sm);font-size:.8rem;min-width:140px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236a6a8a' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;cursor:pointer;transition:border-color var(--duration-fast) var(--ease)}.filter-dropdown:hover{border-color:var(--border-light)}.filter-dropdown:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px var(--accent-dim)}.list-header-row{display:grid;grid-template-columns:1.5fr 1fr .9fr .4fr .5fr .5fr .5fr;padding:.5rem .75rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border);font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.sort-col{cursor:pointer;-webkit-user-select:none;user-select:none}.sort-col:hover{color:var(--accent)}.list-body{flex:1;overflow-y:auto}.char-row{display:grid;grid-template-columns:1.5fr 1fr .9fr .4fr .5fr .5fr .5fr;padding:.5rem .75rem;border-bottom:1px solid var(--border);font-size:.85rem;cursor:pointer;transition:background var(--duration-fast);align-items:center}.char-row:hover{background:var(--bg-hover)}.char-row.active{background:var(--accent-dim);border-left:3px solid var(--accent)}.char-row.deceased{opacity:.5}.col-name{font-weight:500;color:var(--text-primary)}.col-race{font-size:.8rem}.col-class{color:var(--text-secondary);font-size:.8rem}.col-hp,.col-ac,.col-lvl,.col-align{text-align:center;font-size:.8rem}.list-footer{display:flex;justify-content:space-around;padding:.5rem;border-top:1px solid var(--border);font-size:.75rem;color:var(--text-muted);background:var(--bg-tertiary)}.intake-bar{border-top:1px solid var(--border);background:var(--bg-secondary);padding:.5rem .75rem}.intake-bar-row{display:flex;align-items:center;gap:.5rem}.intake-label{font-size:.78rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.intake-input{width:60px!important;padding:.3rem .5rem!important;font-size:.8rem!important;text-align:center}.intake-status{font-size:.78rem;margin-top:.35rem;line-height:1.4}.intake-instructions-row{margin-top:.35rem}.intake-instr-input{width:100%!important;padding:.3rem .5rem!important;font-size:.75rem!important;color:var(--text-secondary)!important;background:var(--bg-tertiary)!important;border:1px solid var(--border)!important}.intake-instr-input::placeholder{color:var(--text-muted);font-style:italic;font-size:.72rem}.intake-preview{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .65rem;margin-top:.35rem}.intake-preview-header{font-weight:600;font-size:.78rem;color:var(--success);margin-bottom:.35rem;padding-bottom:.25rem;border-bottom:1px solid var(--border)}.intake-preview-list{max-height:150px;overflow-y:auto}.intake-preview-item{font-size:.75rem;padding:.15rem 0;color:var(--text-secondary);border-bottom:1px solid rgba(255,255,255,.03)}.intake-preview-item strong{color:var(--text-primary)}.intake-preview-actions{display:flex;gap:.4rem;margin-top:.4rem;padding-top:.35rem;border-top:1px solid var(--border)}.char-detail{min-height:200px}.detail-header{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.detail-portrait{width:72px;height:72px;border-radius:var(--radius-md);object-fit:cover;border:2px solid var(--border)}.detail-identity{flex:1}.detail-name{font-size:1.3rem;color:var(--accent);margin:0}.detail-subtitle{color:var(--text-secondary);font-size:.9rem}.detail-meta{color:var(--text-muted);font-size:.8rem}.detail-actions{display:flex;gap:.4rem}.detail-stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;margin-bottom:1.25rem}.stat-box{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem;text-align:center}.stat-box .stat-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase}.stat-box .stat-value{font-size:1.1rem;font-weight:600;color:var(--accent)}.detail-abilities{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;margin-bottom:1.25rem}.ability-score{text-align:center;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .25rem}.ability-name{display:block;font-size:.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.ability-val{display:block;font-size:1.2rem;font-weight:600;color:var(--text-primary)}.ability-mod{display:block;font-size:.75rem;color:var(--accent)}.detail-section{margin-bottom:1rem}.detail-section h3{font-family:Inter,sans-serif;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.3rem}.detail-section p,.detail-history{color:var(--text-secondary);font-size:.85rem;line-height:1.5}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn var(--duration) var(--ease)}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;max-width:520px;width:90%;max-height:85vh;overflow-y:auto;position:relative;box-shadow:var(--shadow-lg);animation:slideUp var(--duration) var(--ease)}.modal-wide{max-width:800px}.modal-title{font-size:1.2rem;color:var(--text-heading);margin-bottom:1rem}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;line-height:1;transition:color var(--duration-fast)}.modal-close:hover{color:var(--error)}.import-modal-body{display:flex;flex-direction:column;gap:.75rem}.import-instructions{font-size:.82rem;color:var(--text-secondary);line-height:1.5}.import-instructions code{font-size:.75rem;background:var(--bg-tertiary);padding:.15rem .4rem;border-radius:var(--radius-sm);color:var(--accent)}.modal-textarea{width:100%;min-height:140px;padding:.75rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Inter,monospace;font-size:.82rem;line-height:1.5;resize:vertical;transition:border-color var(--duration-fast)}.modal-textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px var(--accent-dim)}.modal-error{background:#c75b3a1f;border:1px solid rgba(199,91,58,.3);color:var(--error);padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.8rem}.modal-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.25rem}.import-preview{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;max-height:280px;overflow-y:auto}.import-preview .preview-name{font-size:1.05rem;color:var(--accent);margin-bottom:.5rem;padding-bottom:.35rem;border-bottom:1px solid var(--border)}.import-preview .preview-row{display:flex;gap:.5rem;padding:.2rem 0;font-size:.82rem;line-height:1.4}.import-preview .preview-label{color:var(--text-muted);min-width:80px;font-weight:500}.import-preview .preview-row strong{color:var(--text-primary);font-weight:500}.toast-container{position:fixed;top:1rem;right:1rem;z-index:2000;display:flex;flex-direction:column;gap:.5rem}.toast{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);font-size:.85rem;color:var(--text-primary);transform:translate(120%);transition:all var(--duration) var(--ease);max-width:350px}.toast-visible{transform:translate(0)}.toast-exit{transform:translate(120%);opacity:0}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--error)}.toast-warning{border-left:3px solid var(--warning)}.toast-info{border-left:3px solid var(--info)}.toast-close{background:none;border:none;color:var(--text-muted);margin-left:auto;cursor:pointer;font-size:1.1rem}.auth-backdrop{height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0d0815,#1a0e2e,#2d1b4e)}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:400px;box-shadow:var(--shadow-lg);text-align:center}.auth-brand{font-size:1.8rem;color:var(--accent);margin-bottom:.25rem}.auth-tagline{color:var(--text-muted);font-size:.85rem;margin-bottom:1.5rem}.auth-form{display:flex;flex-direction:column;gap:.75rem}.auth-form .btn-primary{margin-top:.5rem}.auth-switch{font-size:.8rem;color:var(--text-muted)}.auth-error{background:#c75b3a26;border:1px solid rgba(199,91,58,.3);color:var(--error);padding:.5rem;border-radius:var(--radius-sm);font-size:.8rem;margin-bottom:.75rem}.auth-hint{color:var(--text-muted);font-size:.75rem;text-align:center;margin-top:-.25rem}.pw-wrapper{position:relative;display:flex;align-items:center}.pw-wrapper .form-input{flex:1;padding-right:2.5rem}.pw-toggle{position:absolute;right:.5rem;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:.25rem;line-height:1;opacity:.6;transition:opacity var(--duration-fast)}.pw-toggle:hover{opacity:1}input[type=number].form-select,input[type=number].form-input-num{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}input[type=number].form-select::-webkit-inner-spin-button,input[type=number].form-select::-webkit-outer-spin-button,input[type=number].form-input-num::-webkit-inner-spin-button,input[type=number].form-input-num::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.encounter-view{padding:1rem;max-width:1400px;margin:0 auto}.encounter-view .view-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.encounter-view .view-header h1{flex:1;margin:0;font-size:1.4rem}.encounter-view .view-header-actions{display:flex;gap:.5rem}.enc-sections{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:900px){.enc-sections{grid-template-columns:1fr}}.enc-party-section,.enc-list-section{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.enc-party-section h2,.enc-list-section h2{margin:0 0 .5rem;font-size:1.1rem}.party-member-card{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);margin-bottom:.3rem;transition:background .15s}.party-member-card:hover{background:var(--surface-2)}.party-member-info{flex:1;min-width:0}.party-member-name{font-weight:600;font-size:.85rem;display:block}.party-member-detail{font-size:.7rem;color:var(--text-muted)}.party-member-stats{display:flex;gap:.5rem;font-size:.75rem;color:var(--text-secondary)}.enc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem;margin-bottom:.5rem;cursor:pointer;transition:all .15s;border-left:3px solid var(--accent)}.enc-card:hover{background:var(--surface-2);transform:translate(2px)}.enc-card-header{display:flex;align-items:center;gap:.5rem}.enc-card-name{flex:1;font-weight:600;font-size:.9rem}.enc-card-count{font-size:.75rem;color:var(--text-muted)}.enc-card-desc{font-size:.75rem;color:var(--text-secondary);margin-top:.3rem}.enc-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.4rem;font-size:.7rem}.enc-card-actions{display:flex;gap:.3rem}.enc-status-setup{color:#aaa}.enc-status-active{color:#f55}.enc-status-completed{color:#50c878}.enc-setup-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;min-height:400px}@media(max-width:900px){.enc-setup-grid{grid-template-columns:1fr}}.enc-picker,.enc-roster{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;max-height:600px;display:flex;flex-direction:column}.enc-picker h3,.enc-roster h3{margin:0 0 .5rem;font-size:1rem}.enc-picker-controls{display:flex;gap:.5rem;margin-bottom:.5rem;align-items:center}.enc-pick-list,.enc-roster-list{overflow-y:auto;flex:1}.enc-pick-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);margin-bottom:.25rem;font-size:.8rem}.enc-pick-info{flex:1;min-width:0}.enc-pick-name{font-weight:600;display:block}.enc-pick-detail{font-size:.7rem;color:var(--text-muted)}.enc-pick-stats{display:flex;gap:.4rem;font-size:.7rem;color:var(--text-secondary)}.enc-pick-actions{display:flex;gap:.3rem;align-items:center}.enc-roster-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.enc-group{margin-bottom:.75rem;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.enc-group-header{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;background:var(--surface);font-weight:600;font-size:.8rem}.enc-group-name{flex:1;cursor:pointer}.enc-group-name[data-group-id]:hover{color:var(--accent)}.enc-group-count{font-size:.7rem;color:var(--text-muted);background:var(--surface-2);padding:.1rem .3rem;border-radius:8px}.enc-group-members{padding:.3rem}.enc-participant{padding:.35rem .5rem;margin-bottom:.2rem;border-radius:var(--radius-sm);background:var(--surface);font-size:.8rem}.enc-part-main{display:flex;align-items:center;gap:.4rem}.enc-part-icon{font-size:.9rem}.enc-part-info{flex:1;min-width:0}.enc-part-name{font-weight:600;display:block;font-size:.8rem}.enc-part-detail{font-size:.65rem;color:var(--text-muted)}.enc-part-stats{display:flex;gap:.4rem;font-size:.7rem}.enc-part-controls{display:flex;gap:.3rem;margin-top:.2rem;align-items:center;flex-wrap:wrap}.enc-part-conditions{font-size:.65rem;color:#f0ad4e}.enc-combat-grid{display:grid;grid-template-columns:220px 1fr;gap:1rem}@media(max-width:900px){.enc-combat-grid{grid-template-columns:1fr}}.enc-initiative-col{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;max-height:500px;display:flex;flex-direction:column}.enc-initiative-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.enc-initiative-header h3{margin:0;font-size:.9rem}.enc-round-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.8rem}.enc-init-list{overflow-y:auto;flex:1}.enc-init-item{display:flex;align-items:center;gap:.4rem;padding:.35rem .5rem;margin-bottom:.2rem;border-radius:var(--radius-sm);background:var(--surface);font-size:.8rem;transition:all .15s}.enc-init-item.enc-init-active{background:#f5c51826;box-shadow:0 0 8px #f5c5184d}.enc-init-item.enc-init-dead{opacity:.4;text-decoration:line-through}.enc-init-item.enc-init-inactive{opacity:.3}.enc-init-turn{width:14px;font-size:.7rem;color:var(--accent)}.enc-init-roll{font-weight:700;width:24px;text-align:center;font-size:.8rem}.enc-init-info{flex:1;min-width:0}.enc-init-name{display:block;font-weight:600;font-size:.75rem}.enc-init-hp{font-size:.65rem}.enc-init-hp.hp-dead{color:#f55}.enc-init-hp.hp-low{color:#f0ad4e}.enc-combat-zone{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem}.enc-combat-zone-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.enc-combat-zone-header h3{margin:0;font-size:.9rem}.enc-combat-area{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.enc-combat-side h4{margin:0 0 .5rem;font-size:.85rem}.enc-combat-members{display:flex;flex-direction:column;gap:.4rem}.enc-combat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem;transition:all .15s}.enc-combat-card:hover{box-shadow:var(--shadow-sm)}.enc-combat-card.enc-combat-dead{opacity:.4}.enc-ccard-header{display:flex;justify-content:space-between;margin-bottom:.3rem}.enc-ccard-header strong{font-size:.85rem}.enc-ccard-class{font-size:.7rem;color:var(--text-muted)}.enc-ccard-hp{margin-bottom:.3rem}.enc-hp-bar{height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden;margin-bottom:.2rem}.enc-hp-fill{height:100%;border-radius:3px;transition:width .3s ease}.enc-hp-text{font-size:.75rem}.enc-hp-buttons{display:inline-flex;gap:.2rem;margin-left:.5rem}.enc-ccard-stats{display:flex;gap:.5rem;font-size:.7rem;color:var(--text-secondary);margin-bottom:.3rem}.enc-ccard-weapons{display:flex;flex-wrap:wrap;gap:.2rem;margin-bottom:.3rem}.enc-ccard-conditions{font-size:.65rem;margin-bottom:.3rem}.enc-condition-tag{background:#f0ad4e33;color:#f0ad4e;padding:.1rem .3rem;border-radius:4px;margin-right:.2rem}.enc-ccard-actions{display:flex;gap:.2rem}.enc-log-panel{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;margin-top:1rem}.enc-log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.enc-log-header h3{margin:0;font-size:.9rem}.enc-combat-log{max-height:200px;overflow-y:auto;font-family:var(--font-mono);font-size:.75rem}.enc-log-entry{padding:.15rem 0;border-bottom:1px solid var(--border)}.enc-log-time{color:var(--text-muted)}.btn-xs{padding:.15rem .4rem;font-size:.7rem}.btn-success{background:#50c878;color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer}.btn-success:hover{background:#45b069}.view-party{padding:1rem;max-width:1400px;margin:0 auto}.view-party .view-header{margin-bottom:1rem}.view-party .view-header h1{margin:0;font-size:1.4rem}.party-tabs{display:flex;gap:.25rem;margin-bottom:1rem;border-bottom:2px solid var(--border);padding-bottom:0}.party-tab{background:transparent;border:none;color:var(--text-muted);font-size:.85rem;padding:.5rem 1rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.party-tab:hover{color:var(--text-primary)}.party-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.party-content{display:flex;gap:1rem;min-height:500px}.party-list-panel{flex:0 0 320px;min-width:0}.party-detail-panel{flex:1;min-width:0}@media(max-width:900px){.party-content{flex-direction:column}.party-list-panel{flex:0 0 auto}}.party-list-panel{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;display:flex;flex-direction:column;max-height:650px;overflow-y:auto}.party-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.8rem;color:var(--text-muted)}.party-member-list{flex:1;overflow-y:auto}.party-list-item{padding:.5rem .6rem;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);margin-bottom:.35rem;cursor:pointer;transition:all .15s;border-left:3px solid transparent}.party-list-item:hover{background:var(--surface-2);transform:translate(2px)}.party-list-item.selected{border-left-color:var(--accent);background:#f5c51814;box-shadow:0 0 8px #f5c51826}.party-item-main{display:flex;align-items:center;gap:.5rem}.party-item-info{flex:1;min-width:0}.party-item-name{font-weight:600;font-size:.85rem;display:block}.party-item-meta{font-size:.7rem;color:var(--text-muted)}.party-item-badges{display:flex;gap:.4rem;font-size:.7rem}.party-badge{padding:.1rem .3rem;border-radius:4px;background:var(--surface-2)}.party-badge-hp{color:#f55}.party-badge-ac{color:#4a9eff}.party-item-from{font-size:.65rem;color:var(--text-muted);margin-top:.15rem}.party-recruit-controls{margin-bottom:.5rem}.party-recruit-list{flex:1;overflow-y:auto}.party-recruit-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);margin-bottom:.25rem;font-size:.8rem}.party-recruit-item.already-in-party{opacity:.5}.party-recruit-info{flex:1;min-width:0}.party-recruit-name{font-weight:600;display:block}.party-recruit-meta{font-size:.7rem;color:var(--text-muted)}.party-in-badge{font-size:.65rem;color:#50c878;background:#50c8781a;padding:.15rem .4rem;border-radius:4px}.party-detail-panel{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;overflow-y:auto;max-height:650px}.party-detail-card{animation:fadeInUp .2s ease}.party-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.party-detail-header h2{margin:0;font-size:1.3rem}.party-detail-subtitle{font-size:.85rem;color:var(--text-secondary);margin-top:.2rem}.party-detail-town{font-size:.75rem;color:var(--text-muted);margin-top:.2rem}.party-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem;margin-bottom:1rem}.party-stat-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem;text-align:center;transition:all .15s}.party-stat-block:hover{border-color:var(--accent)}.party-stat-block.party-stat-hp{border-color:#f55}.party-stat-block.party-stat-ac{border-color:#4a9eff}.party-stat-label{display:block;font-size:.6rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;margin-bottom:.15rem}.party-stat-value{font-size:1.1rem;font-weight:700;display:block}.party-stat-mod{font-size:.7rem;color:var(--text-secondary)}.party-detail-section{margin-bottom:1rem}.party-detail-section h4{margin:0 0 .4rem;font-size:.85rem}.party-tag-list{display:flex;flex-wrap:wrap;gap:.3rem}.party-feat-tag{font-size:.7rem;padding:.15rem .5rem;background:#f5c5181a;color:var(--accent);border:1px solid rgba(245,197,24,.2);border-radius:4px}.party-gear-tag{font-size:.7rem;padding:.15rem .5rem;background:#4a9eff1a;color:#4a9eff;border:1px solid rgba(74,158,255,.2);border-radius:4px}.party-quick-stats{font-size:.8rem;color:var(--text-secondary)}.enc-pick-divider{font-size:.7rem;color:var(--text-muted);padding:.3rem .5rem;margin-top:.5rem;border-top:1px solid var(--border);text-transform:uppercase;letter-spacing:.5px}.enc-pick-added{opacity:.5}.create-char-sidebar{padding:.25rem 0}.create-char-steps{display:flex;flex-direction:column;gap:.25rem}.create-step{padding:.4rem .6rem;border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-muted);cursor:pointer;transition:all .15s;border-left:3px solid transparent}.create-step:hover{color:var(--text-primary);background:var(--surface)}.create-step.active{color:var(--accent);border-left-color:var(--accent);background:#f5c5180f;font-weight:600}.create-step.done{color:#50c878}.creator-form{animation:fadeInUp .2s ease}.creator-form h2{font-size:1.1rem;margin:0 0 .85rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.creator-grid{display:grid;grid-template-columns:1fr 1fr;gap:.65rem;margin-bottom:1rem}@media(max-width:700px){.creator-grid{grid-template-columns:1fr}}.creator-field{display:flex;flex-direction:column}.creator-field label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted);margin-bottom:.2rem}.creator-field-wide{grid-column:1 / -1}.creator-hint{font-size:.65rem;color:var(--text-muted);margin-top:.15rem;font-style:italic}.creator-preview{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;margin-bottom:1rem}.creator-preview h4{margin:0 0 .4rem;font-size:.85rem}.creator-preview-grid{display:flex;flex-wrap:wrap;gap:.5rem 1.2rem;font-size:.78rem;color:var(--text-secondary)}.creator-preview-grid strong{color:var(--text-primary)}.creator-nav{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;margin-top:.75rem;border-top:1px solid var(--border)}.creator-method-toggle{display:flex;gap:.35rem;margin-bottom:.75rem}.creator-points-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.4rem .75rem;font-size:.82rem;margin-bottom:.75rem;text-align:center}.text-danger{color:#f55!important}.text-success{color:#50c878!important}.creator-ability-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;margin-bottom:1rem}@media(max-width:800px){.creator-ability-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:500px){.creator-ability-grid{grid-template-columns:repeat(2,1fr)}}.creator-ability-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.6rem .4rem;text-align:center;transition:all .15s}.creator-ability-card:hover{border-color:var(--accent)}.creator-ability-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:.3rem}.creator-ability-controls{display:flex;align-items:center;justify-content:center;gap:.25rem;margin-bottom:.2rem}.creator-ability-input{width:38px;text-align:center;font-size:1rem;font-weight:700;padding:.2rem;border:1px solid var(--border);background:var(--surface-2);color:var(--text-primary);border-radius:4px}.creator-ability-input:focus{border-color:var(--accent);outline:none}.creator-ability-race{font-size:.65rem;color:#50c878;min-height:14px}.creator-ability-final{margin-top:.2rem;padding-top:.25rem;border-top:1px solid var(--border)}.creator-ability-total{font-size:1.2rem;font-weight:800;display:block}.creator-ability-mod{font-size:.75rem;color:var(--text-secondary)}.creator-ability-cost{font-size:.6rem;color:var(--text-muted);margin-top:.15rem}.creator-calculated{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.creator-calc-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.4rem .65rem;font-size:.78rem;display:flex;flex-direction:column;align-items:center;min-width:70px}.creator-calc-item strong{font-size:1rem;color:var(--accent)}.creator-calc-item .text-muted{font-size:.6rem}.creator-review{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:.75rem}.creator-review-header{margin-bottom:.75rem}.creator-review-header h3{margin:0;font-size:1.2rem}.creator-review-subtitle{font-size:.85rem;color:var(--text-secondary);margin-top:.15rem}.creator-review-stats{display:flex;flex-wrap:wrap;gap:.5rem 1.2rem;font-size:.8rem;color:var(--text-secondary);padding:.5rem 0;margin:.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.creator-review-stats strong{color:var(--text-primary)}.creator-review-section{font-size:.8rem;margin-top:.5rem;color:var(--text-secondary)}.creator-review-section strong{color:var(--text-primary)}.creator-review-town{font-size:.75rem;color:var(--text-muted);margin-top:.75rem;padding-top:.5rem;border-top:1px solid var(--border)}.btn-lg{padding:.5rem 1.5rem!important;font-size:.9rem!important}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cc-root{display:flex;flex-direction:column;height:100%}.cc-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:#0000004d;border-bottom:1px solid var(--border);gap:1rem}.cc-name-input{background:transparent;border:1px solid var(--border);color:var(--text);font-size:1.1rem;font-weight:700;padding:.3rem .6rem;border-radius:4px;width:220px;font-family:inherit}.cc-name-input:focus{border-color:var(--accent);outline:none}.cc-header-detail{font-size:.8rem;color:var(--text-muted);margin-left:.5rem}.cc-header-right{display:flex;gap:.5rem}.cc-header-select{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-family:inherit}.cc-tabs{display:flex;gap:2px;padding:0;background:#0003;border-bottom:2px solid var(--accent);overflow-x:auto;scrollbar-width:none}.cc-tab{background:transparent;border:none;color:var(--text-muted);padding:.5rem .8rem;font-size:.78rem;font-family:inherit;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;white-space:nowrap}.cc-tab:hover{color:var(--text);background:#f5c5180d}.cc-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:#f5c51814;font-weight:600}.cc-body{flex:1;overflow-y:auto;padding:.8rem}.cc-class-layout{display:grid;grid-template-columns:200px 1fr;gap:1rem;height:100%}.cc-class-left{display:flex;flex-direction:column;gap:.5rem}.cc-filter-row{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}.cc-checkbox{display:flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--text-muted);cursor:pointer}.cc-checkbox input[type=checkbox]{accent-color:var(--accent)}.cc-filter-hint{font-size:.7rem;color:var(--text-muted);font-style:italic}.cc-class-list{flex:1;overflow-y:auto;border:1px solid var(--border);border-radius:6px;background:#0003;max-height:400px}.cc-class-item{display:flex;justify-content:space-between;padding:.35rem .6rem;cursor:pointer;font-size:.82rem;border-bottom:1px solid rgba(255,255,255,.03);transition:background .1s}.cc-class-item:hover{background:#f5c51814}.cc-class-item.selected{background:#f5c51826;color:var(--accent);font-weight:600;border-left:3px solid var(--accent)}.cc-class-item-hd{color:var(--text-muted);font-size:.75rem}.cc-class-right{display:flex;flex-direction:column;gap:.8rem}.cc-class-info{background:#0003;border:1px solid var(--border);border-radius:6px;padding:.8rem}.cc-info-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem;font-size:.82rem}.cc-info-label{color:var(--text-muted);min-width:100px}.cc-info-value{color:var(--text);font-weight:600}.cc-info-select,.cc-level-input{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.2rem .4rem;border-radius:4px;font-size:.82rem;font-family:inherit;width:80px}.cc-race-traits{background:#00000026;border:1px solid var(--border);border-radius:6px;padding:.6rem .8rem}.cc-race-traits h4{margin:0 0 .4rem;font-size:.85rem;color:var(--accent)}.cc-traits-grid{display:flex;flex-wrap:wrap;gap:.3rem 1.2rem;font-size:.78rem;color:var(--text-muted)}.cc-class-desc{background:#f5c5180a;border:1px solid rgba(245,197,24,.2);border-radius:6px;padding:.6rem .8rem;flex:1;overflow-y:auto}.cc-class-desc h4{margin:0 0 .4rem;color:var(--accent);font-size:.9rem}.cc-class-desc p{font-size:.8rem;line-height:1.5;margin:0;color:var(--text-muted)}.cc-abilities-layout{display:flex;flex-direction:column;gap:.8rem}.cc-method-toggle{display:flex;gap:4px}.cc-method-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);padding:.3rem .8rem;font-size:.78rem;cursor:pointer;border-radius:4px;font-family:inherit;transition:all .15s}.cc-method-btn.active{background:#f5c51826;border-color:var(--accent);color:var(--accent);font-weight:600}.cc-points-bar{font-size:.82rem;color:var(--text-muted)}.cc-ability-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}.cc-ability-card{background:#0003;border:1px solid var(--border);border-radius:6px;padding:.5rem;text-align:center}.cc-ab-label{font-weight:700;font-size:.75rem;color:var(--accent);letter-spacing:1px;margin-bottom:.3rem}.cc-ab-controls{display:flex;align-items:center;justify-content:center;gap:4px}.cc-ab-btn{width:24px;height:24px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:4px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center}.cc-ab-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.cc-ab-btn:disabled{opacity:.3;cursor:not-allowed}.cc-ab-input{width:36px;text-align:center;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:4px;font-size:.9rem;font-family:inherit;padding:2px}.cc-ab-race{font-size:.7rem;color:var(--text-muted);margin-top:2px}.cc-ab-final{margin-top:4px}.cc-ab-total{font-size:1.1rem;font-weight:700;color:var(--text)}.cc-ab-mod{font-size:.75rem;color:var(--text-muted);margin-left:4px}.cc-ab-cost{font-size:.65rem;color:var(--text-muted)}.cc-stats-row{display:flex;gap:.4rem;flex-wrap:wrap}.cc-stat-box{background:#00000040;border:1px solid var(--border);border-radius:6px;padding:.4rem .6rem;text-align:center;min-width:55px}.cc-stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.cc-stat-val{font-size:1rem;font-weight:700;color:var(--text)}.cc-stat-detail{font-size:.6rem;color:var(--text-muted)}.cc-stat-hp{border-color:#ef444466}.cc-stat-hp .cc-stat-val{color:#ef4444}.cc-skills-layout{display:flex;flex-direction:column;gap:.5rem}.cc-skills-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.cc-skills-points{font-size:.85rem}.cc-skills-hint{font-size:.7rem;color:var(--text-muted);margin-left:.5rem}.cc-skills-table{border:1px solid var(--border);border-radius:6px;overflow:hidden}.cc-skill-header-row{display:grid;grid-template-columns:2fr 60px 55px 100px 60px;padding:.3rem .6rem;background:#0000004d;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border)}.cc-skill-row{display:grid;grid-template-columns:2fr 60px 55px 100px 60px;padding:.25rem .6rem;font-size:.78rem;border-bottom:1px solid rgba(255,255,255,.03);align-items:center;transition:background .1s}.cc-skill-row:hover{background:#ffffff05}.cc-skill-class{background:#f5c51805}.cc-skill-cross{opacity:.65}.cc-skill-active{background:#f5c5180d!important}.cc-skill-isclass{color:var(--accent);font-size:.7rem}.cc-skill-total{font-weight:600}.cc-skill-ranks{display:flex;align-items:center;gap:3px}.cc-sk-btn{width:20px;height:20px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:3px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;padding:0}.cc-sk-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.cc-sk-btn:disabled{opacity:.25;cursor:not-allowed}.cc-sk-val{width:20px;text-align:center;font-size:.8rem;font-weight:600}.cc-skills-footer{font-size:.7rem;color:var(--text-muted);padding:.3rem 0}.cc-feats-layout{display:flex;flex-direction:column;gap:.5rem}.cc-feats-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.cc-feats-slots{font-size:.85rem}.cc-feats-hint{font-size:.7rem;color:var(--text-muted);margin-left:.3rem}.cc-feats-selected{background:#0003;border:1px solid var(--border);border-radius:6px;padding:.5rem .8rem}.cc-feats-selected h4{margin:0 0 .3rem;font-size:.82rem;color:var(--text)}.cc-feat-tags{display:flex;flex-wrap:wrap;gap:.3rem}.cc-feat-tag{background:#f5c5181f;border:1px solid rgba(245,197,24,.3);color:var(--accent);padding:.15rem .5rem;border-radius:12px;font-size:.75rem;display:flex;align-items:center;gap:.3rem}.cc-feat-remove{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.7rem;padding:0;opacity:.6}.cc-feat-remove:hover{opacity:1}.cc-feats-table{border:1px solid var(--border);border-radius:6px;overflow:hidden;max-height:350px;overflow-y:auto}.cc-feat-header-row{display:grid;grid-template-columns:1fr 80px 1fr 40px;padding:.3rem .6rem;background:#0000004d;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1}.cc-feat-row{display:grid;grid-template-columns:1fr 80px 1fr 40px;padding:.25rem .6rem;font-size:.78rem;border-bottom:1px solid rgba(255,255,255,.03);align-items:center;transition:background .1s}.cc-feat-row:hover{background:#ffffff05}.cc-feat-unqualified{opacity:.4}.cc-feat-selected{background:#f5c51814!important}.cc-feat-prereq,.cc-feat-type{font-size:.72rem;color:var(--text-muted)}.cc-feat-check{color:var(--accent);font-weight:700}.cc-feat-add-btn{width:24px;height:24px;border:1px solid var(--accent);background:transparent;color:var(--accent);border-radius:4px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;padding:0}.cc-feat-add-btn:hover:not(:disabled){background:#f5c51826}.cc-feat-add-btn:disabled{opacity:.2;cursor:not-allowed}.cc-features-layout{display:flex;flex-direction:column;gap:1rem}.cc-features-section{background:#00000026;border:1px solid var(--border);border-radius:6px;padding:1rem}.cc-features-section h3{margin:0 0 .5rem;font-size:.95rem;color:var(--accent)}.cc-features-section p{font-size:.82rem;line-height:1.5;color:var(--text-muted);margin:0 0 .5rem}.cc-features-info{display:flex;flex-wrap:wrap;gap:.3rem 1.5rem}.cc-fi-row{font-size:.78rem;color:var(--text-muted)}.cc-review-layout{display:flex;flex-direction:column;gap:1rem}.cc-review-card{background:#00000026;border:1px solid var(--border);border-radius:8px;padding:1rem}.cc-review-header h2{margin:0;font-size:1.2rem}.cc-review-subtitle{font-size:.82rem;color:var(--text-muted);margin-top:.2rem}.cc-review-stats{display:flex;flex-wrap:wrap;gap:.5rem 1.2rem;font-size:.82rem;padding:.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:.5rem 0}.cc-review-section{margin:.4rem 0;font-size:.82rem}.cc-review-section label{display:block;margin-bottom:.2rem}.cc-review-town{margin-top:.5rem;font-size:.82rem;padding:.4rem .6rem;background:#f5c5180f;border:1px solid rgba(245,197,24,.2);border-radius:4px}.cc-review-actions{display:flex;justify-content:flex-end}.sidebar-campaign{position:relative;margin:.25rem .75rem}.campaign-selector{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffd7000f;border:1px solid rgba(255,215,0,.2);border-radius:8px;cursor:pointer;transition:all .2s}.campaign-selector:hover{background:#ffd7001f;border-color:#ffd70066}.campaign-icon{font-size:1.15rem}.campaign-info{flex:1;min-width:0;display:flex;flex-direction:column}.campaign-name{font-size:.85rem;font-weight:600;color:var(--text-primary, #eee);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.campaign-edition{font-size:.7rem;color:var(--accent, #eab308);opacity:.8}.campaign-chevron{font-size:.7rem;color:var(--text-muted, #888);transition:transform .2s}.campaign-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface-2, #1e1e3a);border:1px solid rgba(255,215,0,.25);border-radius:8px;box-shadow:0 8px 24px #00000080;z-index:100;animation:fadeSlideDown .15s ease}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.campaign-dropdown-list{max-height:200px;overflow-y:auto}.campaign-dropdown-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(255,255,255,.04)}.campaign-dropdown-item:hover{background:#ffd70014}.campaign-dropdown-item.active{background:#ffd7001f;border-left:3px solid var(--accent, #eab308)}.campaign-item-name{font-size:.82rem;color:var(--text-primary, #eee)}.campaign-item-edition{font-size:.7rem;color:var(--text-muted, #888)}.campaign-dropdown-actions{padding:.5rem .75rem;border-top:1px solid rgba(255,255,255,.06)}.campaign-dropdown-actions button{width:100%}.campaign-tier-info{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.5rem .75rem;background:#ffffff08;border-radius:6px}.tier-badge{padding:.2rem .6rem;border-radius:12px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.tier-free{background:#334155;color:#94a3b8}.tier-standard{background:#1e3a5f;color:#60a5fa}.tier-premium{background:#3b1f6e;color:#a78bfa}.tier-legendary{background:linear-gradient(135deg,#92400e,#78350f);color:#fbbf24}.tier-limit{font-size:.8rem;color:var(--text-muted, #888)}.campaign-list{display:flex;flex-direction:column;gap:.5rem}.campaign-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:.75rem 1rem;transition:border-color .2s}.campaign-card:hover{border-color:#ffffff26}.campaign-card.campaign-active{border-color:#ffd70059;background:#ffd7000a}.campaign-card-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.campaign-card-title{display:flex;align-items:center;gap:.5rem}.campaign-card-name{font-size:.95rem;font-weight:600;color:var(--text-primary, #eee)}.campaign-active-badge{font-size:.65rem;padding:.15rem .4rem;border-radius:10px;background:#ffd70033;color:var(--accent, #eab308);font-weight:600;text-transform:uppercase}.campaign-card-actions{display:flex;gap:.35rem}.campaign-card-meta{display:flex;gap:.75rem;margin-top:.4rem}.campaign-edition-badge{font-size:.72rem;padding:.1rem .5rem;border-radius:4px;background:#8b5cf626;color:#a78bfa}.campaign-town-count{font-size:.72rem;color:var(--text-muted, #888)}.campaign-card-desc{font-size:.78rem;color:var(--text-muted, #888);margin-top:.3rem;font-style:italic}.campaign-form{background:#ffffff0a;border:1px solid rgba(255,215,0,.2);border-radius:8px;padding:1rem;margin-bottom:1rem;animation:fadeSlideDown .2s ease}.campaign-form h4{margin:0 0 .75rem;color:var(--accent, #eab308);font-size:.9rem}.btn-danger{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3);padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.75rem;transition:all .15s}.btn-danger:hover{background:#ef444440;border-color:#ef444480}.bug-report-form{display:flex;flex-direction:column;gap:.75rem}.bug-report-form .required{color:var(--error, #ef4444)}.form-textarea{width:100%;padding:.55rem .75rem;background:var(--bg-input, #1a1a2e);border:1px solid var(--border, #2a2a4a);border-radius:var(--radius-sm, 6px);color:var(--text-primary, #e0e0e8);font-size:.85rem;font-family:Inter,sans-serif;line-height:1.5;resize:vertical;transition:border-color .15s}.form-textarea:focus{border-color:var(--accent, #eab308);outline:none;box-shadow:0 0 0 2px var(--accent-dim, rgba(234, 179, 8, .12))}.severity-picker{display:flex;gap:.4rem;flex-wrap:wrap}.severity-btn{display:flex;align-items:center;gap:.35rem;padding:.35rem .75rem;background:var(--bg-tertiary, #1e1e36);border:1px solid var(--border, #2a2a4a);border-radius:var(--radius-sm, 6px);color:var(--text-secondary, #a0a0b8);font-size:.8rem;cursor:pointer;transition:all .15s}.severity-btn:hover{background:var(--bg-hover, #252545);border-color:var(--border-light, #3a3a5a)}.severity-btn.active{background:var(--accent-dim, rgba(234, 179, 8, .12));border-color:var(--accent, #eab308);color:var(--text-primary, #e0e0e8);font-weight:500}.severity-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.severity-low{background:#3498db}.severity-medium{background:#f39c12}.severity-high{background:#e67e22}.severity-critical{background:#e74c3c}.bug-report-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.25rem}.bug-report-note{font-size:.75rem;color:var(--text-muted, #6a6a8a);text-align:center;margin-top:.5rem;font-style:italic}.view-srd{height:100%;display:flex;flex-direction:column}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-shrink:0}.srd-tabs{display:flex;gap:.15rem;margin-bottom:1rem;border-bottom:1px solid var(--border);padding-bottom:0;overflow-x:auto;flex-shrink:0;scrollbar-width:none}.srd-tabs::-webkit-scrollbar{display:none}.srd-tab{padding:.5rem .75rem;background:transparent;color:var(--text-secondary);font-size:.78rem;font-weight:500;border:none;border-bottom:2px solid transparent;transition:all var(--duration-fast) var(--ease);margin-bottom:-1px;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:.35rem}.srd-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.srd-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.srd-tab-icon{font-size:.9rem}.srd-tab-label{display:inline}.srd-search{max-width:250px}.srd-search-inline{margin-left:auto;flex-shrink:0;padding:.25rem 0}.srd-search-inline .form-input{width:180px;padding:.35rem .6rem;font-size:.78rem;border-radius:var(--radius-pill);background:var(--bg-secondary);border:1px solid var(--border);transition:width var(--duration-fast) var(--ease),border-color var(--duration-fast)}.srd-search-inline .form-input:focus{width:240px;border-color:var(--accent)}.srd-content{flex:1;overflow:auto;min-height:0}.srd-split{display:grid;grid-template-columns:320px 1fr;gap:1rem;height:calc(100vh - 220px);min-height:400px}.srd-list{overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary)}.srd-list-header{padding:.6rem .75rem;border-bottom:1px solid var(--border);background:var(--bg-tertiary);position:sticky;top:0;z-index:2}.srd-list-count{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.srd-list-group{padding:.4rem .75rem;font-size:.7rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-tertiary);border-bottom:1px solid var(--border);position:sticky;top:37px;z-index:1}.srd-list-item{padding:.45rem .75rem;border-bottom:1px solid var(--border);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background var(--duration-fast)}.srd-list-item:hover{background:var(--bg-hover)}.srd-list-item.selected{background:var(--accent-dim);border-left:3px solid var(--accent)}.srd-list-name{font-size:.82rem;font-weight:500;color:var(--text-primary)}.srd-list-meta{font-size:.68rem;color:var(--text-muted);text-align:right;max-width:45%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.srd-group{border-bottom:1px solid var(--border)}.srd-group-header{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;cursor:pointer;background:var(--bg-tertiary);font-weight:600;font-size:.82rem;color:var(--accent);transition:background .15s}.srd-group-header:hover{background:var(--bg-hover)}.srd-group-arrow,.srd-subgroup-arrow{font-size:.65rem;color:var(--text-muted);transition:transform .15s;width:1em;text-align:center}.srd-group-name{flex:1}.srd-group-count{font-size:.65rem;color:var(--text-muted);background:var(--bg-secondary);padding:.1rem .4rem;border-radius:8px;font-weight:500}.srd-subgroup{border-top:1px solid var(--border)}.srd-subgroup-header{display:flex;align-items:center;gap:.3rem;padding:.35rem .75rem .35rem 1.5rem;cursor:pointer;font-size:.75rem;color:var(--text-secondary);font-weight:500;transition:background .15s}.srd-subgroup-header:hover{background:var(--bg-hover)}.srd-subgroup-name{flex:1}.srd-subgroup-body .srd-list-item{padding-left:2rem}.detail-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:.75rem}.detail-tab{padding:.4rem .8rem;font-size:.78rem;font-weight:500;color:var(--text-muted);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.detail-tab:hover{color:var(--text-primary)}.detail-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.detail-tab-content{display:none}.detail-tab-content.active{display:block}.attacks-table{width:100%;font-size:.78rem;border-collapse:collapse}.attacks-table th{text-align:left;padding:.3rem .5rem;font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border);background:var(--bg-tertiary)}.attacks-table td{padding:.35rem .5rem;border-bottom:1px solid var(--border);color:var(--text-secondary)}.attacks-table tr:hover td{background:var(--bg-hover)}.atk-type-badge{font-size:.65rem;padding:.1rem .35rem;border-radius:4px;font-weight:600}.atk-type-melee{background:#e5393526;color:#ef5350}.atk-type-ranged{background:#42a5f526;color:#42a5f5}.atk-type-touch{background:#ab47bc26;color:#ab47bc}.skills-table-wrap{max-height:400px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}.skills-table{width:100%;font-size:.75rem;border-collapse:collapse}.skills-table th{text-align:left;padding:.3rem .4rem;font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border);background:var(--bg-tertiary);position:sticky;top:0;z-index:1}.skills-table td{padding:.25rem .4rem;border-bottom:1px solid var(--border);color:var(--text-secondary)}.skills-table tr{cursor:pointer;transition:background .1s}.skills-table tr:hover td{background:var(--bg-hover)}.skills-table tr.selected td{background:var(--accent-dim)}.skills-table .skill-name{font-weight:500;color:var(--text-primary)}.skills-table .skill-val{text-align:center;font-family:JetBrains Mono,monospace;font-weight:600}.skills-table .skill-positive{color:var(--success)}.skills-table .skill-negative{color:var(--error)}.skill-detail-panel{margin-top:.5rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border)}.skill-detail-panel h4{color:var(--accent);margin-bottom:.3rem;font-size:.9rem}.skill-detail-panel .skill-ability-tag{font-size:.7rem;color:var(--text-muted);margin-bottom:.5rem}.char-skills-filters{display:flex;gap:.75rem;padding:.4rem 0;margin-bottom:.5rem;border-bottom:1px solid var(--border)}.skill-radio{font-size:.75rem;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:.25rem}.skill-radio input[type=radio]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}.char-skills-split{display:flex;gap:0;height:420px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.char-skills-list{flex:0 0 55%;overflow-y:auto;border-right:1px solid var(--border)}.char-skills-list .skills-table{border:none}.char-skill-detail{flex:1;overflow-y:auto;padding:.5rem;background:var(--bg-secondary)}.srd-detail-panel{overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);padding:1.25rem}.srd-detail-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);gap:.5rem}.srd-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-muted);gap:.5rem}.srd-empty-icon{font-size:2.5rem;opacity:.5}.srd-detail-content h2{font-family:Cinzel,serif;font-size:1.3rem;color:var(--accent);margin-bottom:.75rem}.srd-detail-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}.srd-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;margin-bottom:1rem}.srd-stat{background:var(--bg-secondary);border-radius:var(--radius-sm);padding:.5rem .65rem;border:1px solid var(--border)}.srd-stat label{display:block;font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.2rem}.srd-stat span{font-size:.8rem;color:var(--text-primary);line-height:1.4}.srd-stat-wide{grid-column:span 2}.srd-description{font-size:.82rem;color:var(--text-secondary);line-height:1.65;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.srd-description p{margin-bottom:.5rem}.srd-extra{font-size:.8rem;color:var(--text-secondary);margin-top:.5rem;padding:.5rem .65rem;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border);line-height:1.5}.srd-extra strong{color:var(--accent)}.srd-feat-section{margin-bottom:.75rem}.srd-feat-section h4{font-size:.72rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.3rem;padding-bottom:.2rem;border-bottom:1px solid var(--border)}.srd-feat-section p,.srd-feat-section div{font-size:.82rem;color:var(--text-secondary);line-height:1.6}.srd-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.srd-grid-wide{grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.srd-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem;transition:border-color var(--duration-fast),transform var(--duration-fast)}.srd-card:hover{border-color:var(--border-light);transform:translateY(-1px)}.srd-card h3{font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;color:var(--text-heading);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.srd-badge{font-size:.65rem;padding:.15rem .5rem;background:var(--accent-dim);color:var(--accent);border-radius:var(--radius-pill);font-weight:500}.srd-badge-sub{background:#64c8ff26;color:#64c8ff}.srd-badge-desc{background:#c896ff26;color:#c896ff}.srd-badge-cr{background:#ff646426;color:#ff6464}.srd-detail{font-size:.8rem;color:var(--text-secondary);margin-bottom:.25rem;line-height:1.5}.srd-detail strong{color:var(--text-muted)}.srd-expand-btn{margin-top:.5rem;padding:.35rem .75rem;font-size:.72rem;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast)}.srd-expand-btn:hover{background:var(--accent);color:var(--bg-primary)}.srd-progression{margin-top:.5rem}.srd-section-title{font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;color:var(--accent);margin-top:1rem;margin-bottom:.5rem;padding-bottom:.3rem;border-bottom:1px solid var(--border)}.srd-progression-wrap{max-height:400px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}.srd-table{width:100%;border-collapse:collapse;font-size:.82rem}.srd-table-sm{font-size:.72rem}.srd-table th{text-align:left;font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:.5rem .65rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1}.srd-table td{padding:.4rem .65rem;border-bottom:1px solid var(--border);color:var(--text-secondary)}.srd-table tr:hover td{background:var(--bg-hover)}.srd-equip-layout{display:flex;gap:1rem;height:calc(100vh - 220px)}.srd-equip-cats{width:180px;overflow-y:auto;display:flex;flex-direction:column;gap:.2rem;flex-shrink:0}.srd-cat-btn{padding:.4rem .6rem;font-size:.72rem;text-align:left;background:transparent;color:var(--text-secondary);border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.srd-cat-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.srd-cat-btn.active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent);font-weight:600}.srd-equip-table{flex:1;overflow:auto;border:1px solid var(--border);border-radius:var(--radius-md)}.srd-equip-name{font-weight:500;color:var(--text-primary)!important;position:relative}.srd-tooltip-icon{font-size:.7rem;margin-left:.3rem;opacity:.5;cursor:help}.srd-equip-row{position:relative}.srd-equip-row[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.72rem;white-space:nowrap;z-index:100;box-shadow:0 4px 12px #0006;pointer-events:none;max-width:400px;white-space:normal;line-height:1.5}.srd-domain-spells{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.5rem}.srd-domain-spell{font-size:.72rem;padding:.2rem .5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary)}.srd-domain-spell strong{color:var(--accent)}.srd-loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--text-muted);font-size:.85rem}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@media(max-width:768px){.srd-split{grid-template-columns:1fr;height:auto}.srd-list{max-height:250px}.srd-equip-layout{flex-direction:column;height:auto}.srd-equip-cats{width:100%;flex-direction:row;flex-wrap:wrap}.srd-stat-wide{grid-column:span 1}.srd-tab-label{display:none}.srd-tab{padding:.5rem}}.calendar-display{font-size:1.3rem;color:var(--accent);font-weight:600;font-family:Cinzel,serif;margin-bottom:1.5rem;padding:1rem;background:var(--accent-dim);border-radius:var(--radius-md);text-align:center}.cal-month-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.5rem}.cal-month-input-row{display:flex;align-items:center;gap:.5rem}.cal-month-number{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;background:var(--accent-dim);color:var(--accent);font-weight:700;font-size:.75rem;border-radius:var(--radius-sm);flex-shrink:0}.cal-month-name{flex:1;font-size:.9rem!important;padding:.4rem .6rem!important}.view-simulation{max-width:900px}.view-simulation .dash-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem;color:var(--text-secondary)}.sim-town-info{display:flex;gap:1.5rem;align-items:center;margin-bottom:1rem;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md)}.sim-town-name{font-size:1.1rem;font-weight:600;color:var(--accent)}.sim-town-pop{font-size:.85rem;color:var(--text-secondary)}.sim-config{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1rem}.sim-config-row{display:flex;gap:1.5rem;margin-bottom:.75rem}.sim-field{margin-bottom:.75rem}.sim-field label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem}.sim-field textarea{width:100%;resize:vertical}.sim-months-group{display:flex;gap:.35rem;align-items:center;flex-wrap:wrap}.sim-month-btn{padding:.4rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all var(--duration-fast) var(--ease)}.sim-month-btn:hover{border-color:var(--accent);color:var(--text-primary)}.sim-month-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);font-weight:600}.sim-actions{display:flex;align-items:center;gap:1rem;margin-top:.5rem}.sim-status{font-size:.85rem}.sim-progress{margin-bottom:1rem}.sim-progress-bar{height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;margin-bottom:.5rem}.sim-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#d4a017);border-radius:3px;width:0%;transition:width .5s ease}.sim-progress-text{font-size:.82rem;color:var(--text-muted);text-align:center}.sim-results{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem}.sim-results-title{font-size:1.15rem;color:var(--accent);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.sim-change-list{display:flex;flex-direction:column;gap:.25rem}.sim-change-item{padding:.4rem .6rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.82rem;color:var(--text-secondary);border-left:3px solid var(--border)}.sim-change-add{border-left-color:var(--success)}.sim-change-death{border-left-color:var(--error)}.sim-change-social{border-left-color:#e91e63}.sim-reason{display:block;font-size:.75rem;color:var(--text-muted);font-style:italic;margin-top:.15rem}.sim-apply-actions{display:flex;gap:.75rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.town-settings-body{display:flex;flex-direction:column}.settings-section-title{font-size:1rem;color:var(--accent);margin-bottom:.25rem}.settings-desc{font-size:.82rem;color:var(--text-muted);margin-bottom:.75rem;line-height:1.5}.demographics-grid{display:flex;flex-direction:column;gap:.5rem}.demo-row{display:flex;align-items:center;gap:.5rem}.demo-race{width:120px;flex-shrink:0}.demo-pct-wrap{flex:1;display:flex;align-items:center;gap:.35rem}.demo-slider{flex:1;accent-color:var(--accent);height:4px}.demo-pct{width:55px;text-align:center;flex-shrink:0}.demo-pct-sign{font-size:.8rem;color:var(--text-muted)}.demo-remove{padding:.25rem .5rem;font-size:.7rem}.demo-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.5rem;border-top:1px solid var(--border)}.demo-total{font-size:.85rem;color:var(--text-secondary)}.sim-res-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:0;overflow-x:auto;scrollbar-width:none}.sim-res-tabs::-webkit-scrollbar{display:none}.sim-res-tab{padding:.55rem 1rem;font-size:.78rem;font-weight:500;color:var(--text-muted);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all .15s;display:flex;align-items:center;gap:.35rem}.sim-res-tab:hover{color:var(--text-primary);background:#ffffff08}.sim-res-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.sim-tab-badge{font-size:.65rem;font-weight:700;background:var(--accent-dim);color:var(--accent);padding:.1rem .4rem;border-radius:10px;min-width:18px;text-align:center}.sim-res-tab.active .sim-tab-badge{background:var(--accent);color:var(--bg-primary)}.sim-res-panels{padding:.75rem 0;max-height:400px;overflow-y:auto}.sim-res-panel{display:none}.sim-res-panel.active{display:block;animation:simFadeIn .2s ease}@keyframes simFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.sim-summary-text{font-size:.85rem;color:var(--text-secondary);line-height:1.7;margin-bottom:1rem}.sim-events-list{display:flex;flex-direction:column;gap:.35rem}.sim-event-card{padding:.5rem .75rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.82rem;color:var(--text-secondary);border-left:3px solid var(--accent);display:flex;align-items:flex-start;gap:.5rem}.sim-event-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:.4rem}.sim-event-month{font-size:.68rem;font-weight:700;color:var(--accent);background:var(--accent-dim);padding:.1rem .4rem;border-radius:4px;white-space:nowrap;flex-shrink:0}.sim-sub-heading{font-size:.82rem;font-weight:600;color:var(--text-secondary);margin:.75rem 0 .4rem;display:flex;align-items:center;gap:.5rem}.sim-sub-heading:first-child{margin-top:0}.sim-badge{font-size:.65rem;font-weight:700;background:#4caf5026;color:var(--success);padding:.1rem .4rem;border-radius:10px}.sim-badge-danger{background:#ef444426;color:var(--error)}.sim-rel-arrow{color:var(--accent);font-weight:600;margin:0 .15rem}.sim-rel-type{font-size:.72rem;color:#e91e63;background:#e91e631a;padding:.1rem .4rem;border-radius:4px;margin-left:.35rem}.sim-xp-val{color:var(--accent);font-weight:600;font-family:JetBrains Mono,monospace;font-size:.78rem;margin-left:.35rem}.sim-stat-field{color:var(--text-muted)}.sim-stat-old{color:var(--error);text-decoration:line-through;font-size:.78rem}.sim-stat-new{color:var(--success);font-weight:600;font-size:.78rem}.sim-role-old{color:var(--text-muted)}.sim-role-new{color:var(--accent);font-weight:600}.sim-change-xp{border-left-color:var(--accent)}.sim-change-role{border-left-color:#a78bfa}.history-dropdown-wrap{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.history-select{flex:1;font-size:.85rem;padding:.5rem .75rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer}.history-select:focus{border-color:var(--accent);outline:none}.history-count{font-size:.72rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.history-display{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.25rem;max-height:400px;overflow-y:auto}.history-display-title{font-size:.95rem;color:var(--accent);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);font-weight:600}.history-display-body{display:flex;flex-direction:column;gap:.15rem}.history-line{font-size:.82rem;color:var(--text-secondary);line-height:1.6;margin:0 0 .3rem;padding-left:.5rem;border-left:2px solid var(--border)}.sim-debug-log{margin-top:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:.75rem 1rem}.sim-debug-log h3{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem;display:flex;align-items:center}.sim-log-entries{max-height:250px;overflow-y:auto;background:#0003;border-radius:var(--radius-sm);padding:.5rem}.error{color:var(--error)}.portrait-tab-body{display:flex;gap:1.25rem;align-items:flex-start;flex-wrap:wrap}.portrait-display-col{flex:0 0 200px;min-height:160px}.portrait-preview-img{width:200px;max-height:270px;object-fit:cover;border-radius:var(--radius-md);border:2px solid var(--border);box-shadow:var(--shadow-md)}.portrait-placeholder{width:200px;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-tertiary);border:2px dashed var(--border);border-radius:var(--radius-md);text-align:center;padding:1rem}.portrait-placeholder-icon{font-size:2.5rem;margin-bottom:.5rem;opacity:.5}.portrait-placeholder p{color:var(--text-muted);font-size:.75rem;margin:0}.portrait-prompt-col{flex:1;min-width:200px}.portrait-upload-btn{display:inline-block;padding:6px 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--duration-fast) var(--ease)}.portrait-upload-btn:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.edit-portrait-section{display:flex;gap:1rem;align-items:flex-start;margin-top:.5rem}.edit-portrait-preview-wrap{flex:0 0 120px}.edit-portrait-preview{width:120px;max-height:160px;object-fit:cover;border-radius:var(--radius-sm);border:2px solid var(--border)}.edit-portrait-empty{width:120px;height:120px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:2px dashed var(--border);border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-muted);text-align:center}.edit-portrait-controls{flex:1;display:flex;flex-direction:column;gap:.4rem}.char-sheet{font-family:Inter,sans-serif;color:#d4c8a8;font-size:.78rem;line-height:1.4}.sheet-abilities::-webkit-scrollbar,.sheet-combat::-webkit-scrollbar,.sheet-attacks::-webkit-scrollbar,.sheet-skills::-webkit-scrollbar,.sheet-feats::-webkit-scrollbar,.sheet-gear::-webkit-scrollbar,.sheet-traits::-webkit-scrollbar,.sheet-history::-webkit-scrollbar{width:5px}.sheet-abilities::-webkit-scrollbar-track,.sheet-combat::-webkit-scrollbar-track,.sheet-attacks::-webkit-scrollbar-track,.sheet-skills::-webkit-scrollbar-track,.sheet-feats::-webkit-scrollbar-track,.sheet-gear::-webkit-scrollbar-track,.sheet-traits::-webkit-scrollbar-track,.sheet-history::-webkit-scrollbar-track{background:#1e18104d;border-radius:3px}.sheet-abilities::-webkit-scrollbar-thumb,.sheet-combat::-webkit-scrollbar-thumb,.sheet-attacks::-webkit-scrollbar-thumb,.sheet-skills::-webkit-scrollbar-thumb,.sheet-feats::-webkit-scrollbar-thumb,.sheet-gear::-webkit-scrollbar-thumb,.sheet-traits::-webkit-scrollbar-thumb,.sheet-history::-webkit-scrollbar-thumb{background:#5a4a2c;border-radius:3px}.sheet-abilities::-webkit-scrollbar-thumb:hover,.sheet-combat::-webkit-scrollbar-thumb:hover,.sheet-attacks::-webkit-scrollbar-thumb:hover,.sheet-skills::-webkit-scrollbar-thumb:hover,.sheet-feats::-webkit-scrollbar-thumb:hover,.sheet-gear::-webkit-scrollbar-thumb:hover,.sheet-traits::-webkit-scrollbar-thumb:hover,.sheet-history::-webkit-scrollbar-thumb:hover{background:#8b6914}.sheet-abilities,.sheet-combat,.sheet-attacks,.sheet-skills,.sheet-feats,.sheet-gear,.sheet-traits,.sheet-history{scrollbar-width:thin;scrollbar-color:#5a4a2c rgba(30,24,16,.3)}.sheet-frame{background:linear-gradient(160deg,#1a1510,#221c14 40%,#1e1812);border:3px solid #5a4a2c;border-radius:8px;box-shadow:inset 0 0 0 1px #8b6914,inset 0 0 30px #00000080,0 4px 20px #0009;position:relative;overflow:hidden}.sheet-frame:before,.sheet-frame:after{content:"◆";position:absolute;color:#c9a84c;font-size:.75rem;opacity:.6;z-index:2}.sheet-frame:before{top:4px;left:8px}.sheet-frame:after{top:4px;right:8px}.sheet-header{text-align:center;padding:.5rem 1rem .4rem;border-bottom:2px solid #5a4a2c;background:linear-gradient(180deg,#282014e6,#1a1510f2);position:relative}.sheet-edition{font-family:Cinzel,serif;font-size:.55rem;color:#8b6914;letter-spacing:2px;text-transform:uppercase;margin-bottom:.15rem;opacity:.8}.sheet-name{font-family:Cinzel,serif;font-size:1.15rem;font-weight:700;color:#c9a84c;text-shadow:0 2px 8px rgba(201,168,76,.3),0 0 30px rgba(201,168,76,.1);margin:0 0 .15rem;letter-spacing:1px}.sheet-subtitle{font-family:Cinzel,serif;font-size:.62rem;color:#a89870;letter-spacing:1.5px;text-transform:uppercase;margin:0}.sheet-deceased-badge{display:inline-block;margin-top:.4rem;padding:.15rem .6rem;background:#c8282840;border:1px solid rgba(200,40,40,.5);border-radius:3px;font-size:.65rem;color:#e57373;letter-spacing:1px;font-weight:600}.sheet-actions{position:absolute;top:.75rem;right:.75rem;display:flex;gap:.3rem}.sheet-action-btn{background:#5a4a2c66;border:1px solid #5a4a2c;border-radius:4px;padding:.25rem .45rem;font-size:.7rem;cursor:pointer;transition:all .15s;color:#d4c8a8}.sheet-action-btn:hover{background:#c9a84c33;border-color:#c9a84c}.sheet-action-del:hover{background:#c8282833;border-color:#e57373}.sheet-levelup-bar{padding:.35rem .75rem;border-bottom:1px solid rgba(255,255,255,.06)}.btn-levelup{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border:1px solid rgba(90,184,92,.4);border-radius:8px;background:linear-gradient(135deg,#3c8c3c26,#5ab85c14);color:#5cb85c;font-family:Cinzel,serif;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s;letter-spacing:.5px}.btn-levelup:hover{background:linear-gradient(135deg,#3c8c3c40,#5ab85c26);border-color:#5cb85c;transform:translateY(-1px);box-shadow:0 2px 8px #5ab85c33}.btn-levelup:active{transform:translateY(0)}.btn-levelup:disabled{opacity:.5;cursor:wait;transform:none;box-shadow:none}.levelup-icon{font-size:.9rem}.levelup-text{font-weight:700}.levelup-class{font-family:Inter,sans-serif;font-size:.6rem;font-weight:400;opacity:.6;letter-spacing:0}.levelup-summary{padding:.25rem 0}.levelup-summary-header{font-family:Cinzel,serif;font-size:1.1rem;font-weight:700;color:#5cb85c;text-align:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid rgba(90,184,92,.2)}.levelup-summary-body{font-size:.8rem;line-height:1.6;color:#fff!important}.levelup-summary-line{padding:.2rem 0 .2rem 1rem;position:relative;color:#fff!important}.levelup-summary-line:before{content:"▸";position:absolute;left:0;color:#5cb85c;font-weight:700}.sheet-body{display:grid;grid-template-columns:1.2fr .75fr 1.2fr;gap:0;min-height:300px}.sheet-col{padding:.3rem .45rem;border-right:1px solid #3a3020}.sheet-col:last-child{border-right:none}.sheet-section{margin-bottom:.3rem}.sheet-section-title{font-family:Cinzel,serif;font-size:.58rem;font-weight:700;color:#c9a84c;text-align:center;text-transform:uppercase;letter-spacing:1px;padding:.15rem 0;margin-bottom:.2rem;border-top:1px solid #5a4a2c;border-bottom:1px solid #5a4a2c;background:linear-gradient(90deg,transparent,rgba(90,74,44,.2),transparent)}.sheet-ornament{font-size:.55rem;opacity:.7}.sheet-abilities{display:flex;flex-direction:column;gap:.15rem;max-height:160px;overflow-y:auto}.sheet-ability-row{display:grid;grid-template-columns:1rem 2.2rem 1.6rem 1.8rem;align-items:center;padding:.1rem .2rem;border-radius:3px;transition:background .15s}.sheet-ability-row:hover{background:#c9a84c14}.sheet-ability-icon{font-size:.6rem;opacity:.7}.sheet-ability-name{font-weight:700;color:#c9a84c;font-size:.65rem;letter-spacing:.5px}.sheet-ability-score{font-weight:600;color:#e8dcc0;text-align:center;font-size:.75rem}.sheet-ability-mod{font-weight:600;color:#a89870;text-align:right;font-size:.68rem}.sheet-combat{display:flex;flex-direction:column;gap:.1rem;max-height:200px;overflow-y:auto}.sheet-combat-row{display:flex;align-items:center;gap:.25rem;padding:.12rem .25rem;font-size:.74rem}.sheet-combat-label{color:#a89870;font-weight:500;white-space:nowrap}.sheet-combat-val{font-weight:600;color:#e8dcc0}.sheet-hp{color:#66bb6a;font-size:.85rem}.sheet-saves-line{color:#6a6050}.sheet-saves-mods{display:flex;gap:0;padding:.1rem .25rem;justify-content:space-around;font-size:.65rem;color:#8a7a58;border-top:1px solid #3a3020;margin-top:.15rem}.sheet-attacks{display:flex;flex-direction:column;gap:.25rem;max-height:150px;overflow-y:auto}.sheet-attack-entry{padding:.25rem;border-radius:3px;background:#1e181080;border:1px solid #3a3020}.sheet-attack-name{font-weight:600;color:#c9a84c;font-size:.72rem;margin-bottom:.1rem}.sheet-attack-bonus{color:#e8dcc0;font-weight:600;font-size:.78rem}.sheet-attack-dmg{color:#e57373;font-size:.72rem}.sheet-attack-crit{color:#8a7a58;font-size:.65rem}.sheet-portrait-wrap{display:flex;flex-direction:column;align-items:center;padding:.5rem 0 .25rem;gap:.3rem}.sheet-portrait{width:100%;max-width:180px;max-height:240px;object-fit:cover;border-radius:6px;border:2px solid #5a4a2c;box-shadow:0 2px 12px #00000080,0 0 20px #c9a84c1a}.sheet-portrait-placeholder{width:140px;height:180px;display:flex;align-items:center;justify-content:center;background:#1e181099;border:2px dashed #5a4a2c;border-radius:6px;font-size:3rem;opacity:.4}.sheet-skills{display:flex;flex-direction:column;gap:.05rem;max-height:200px;overflow-y:auto}.sheet-skill-name{color:#d4c8a8;font-size:.72rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sheet-skill-val{font-weight:600;color:#c9a84c;font-size:.68rem;text-align:center}.sheet-feats{display:flex;flex-direction:column;gap:.05rem;max-height:180px;overflow-y:auto}.sheet-feat-item{color:#d4c8a8;font-size:.72rem;border-left:2px solid #5a4a2c;padding:.12rem .25rem .12rem .5rem;transition:border-color .15s}.sheet-feat-item:hover{border-left-color:#c9a84c;color:#e8dcc0}.sheet-gear{display:flex;flex-direction:column;gap:.05rem;max-height:200px;overflow-y:auto}.sheet-gear-item{display:flex;align-items:flex-start;gap:.35rem;padding:.1rem 0;font-size:.72rem;color:#d4c8a8}.sheet-gear-check{color:#c9a84c;font-size:.55rem;margin-top:.15rem;flex-shrink:0}.sheet-traits{display:flex;flex-direction:column;gap:.05rem;max-height:160px;overflow-y:auto}.sheet-trait-item{padding:.1rem .25rem;color:#b8a880;font-size:.7rem;font-style:italic}.sheet-languages{color:#d4c8a8;font-size:.75rem;padding:.15rem .25rem;line-height:1.4}.sheet-history{color:#a89870;font-size:.7rem;padding:.15rem .25rem;line-height:1.5;max-height:120px;overflow-y:auto}.sheet-empty-note{color:#6a6050;font-size:.7rem;font-style:italic;padding:.25rem;text-align:center}.sheet-skill-header{display:grid;grid-template-columns:1fr 1.8rem 1.8rem 1.8rem 1.8rem;gap:.15rem;padding:.15rem .25rem;border-bottom:1px solid #5a4a2c;margin-bottom:.15rem}.sheet-skill-hname{font-size:.6rem;font-weight:700;color:#8b6914;text-transform:uppercase;letter-spacing:.5px}.sheet-skill-hval{font-size:.55rem;font-weight:600;color:#8b6914;text-align:center;text-transform:uppercase}.sheet-skill-row{display:grid;grid-template-columns:1fr 1.8rem 1.8rem 1.8rem 1.8rem;gap:.15rem;align-items:center;padding:.12rem .25rem;border-radius:2px;transition:background .1s;cursor:default}.sheet-skill-ab{color:#6a6050;font-size:.62rem}.sheet-val-pos{color:#66bb6a!important}.sheet-val-neg{color:#e57373!important}.sheet-portrait-actions{display:flex;gap:.35rem;justify-content:center;margin-top:.4rem}.sheet-portrait-btn{display:inline-flex;align-items:center;gap:.2rem;padding:.25rem .6rem;background:#5a4a2c59;border:1px solid #5a4a2c;border-radius:4px;color:#d4c8a8;font-size:.65rem;font-weight:500;cursor:pointer;transition:all .15s}.sheet-portrait-btn:hover{background:#c9a84c33;border-color:#c9a84c;color:#c9a84c}.sheet-portrait-btn:disabled{opacity:.5;cursor:wait}.sheet-portrait-status{text-align:center;font-size:.65rem;color:#a89870;margin-top:.3rem;padding:0 .5rem}.sheet-prompt-output{width:100%;background:#14100ccc;border:1px solid #5a4a2c;border-radius:4px;color:#d4c8a8;font-size:.65rem;font-family:Inter,sans-serif;padding:.4rem;margin:.3rem 0;resize:vertical;line-height:1.4}.sheet-prompt-output:focus{outline:none;border-color:#c9a84c}.sheet-tooltip{display:none;position:fixed;z-index:10000;max-width:320px;padding:.5rem .65rem;background:linear-gradient(160deg,#1e1812,#2a2018);border:1px solid #8b6914;border-radius:6px;box-shadow:0 4px 16px #0009,0 0 8px #c9a84c26;color:#d4c8a8;font-size:.7rem;line-height:1.45;pointer-events:none}.sheet-tooltip strong{color:#c9a84c;font-size:.75rem}.sheet-tooltip em{color:#8a7a58}[data-srd-type]{cursor:help;transition:color .15s}[data-srd-type]:hover{color:#c9a84c!important}.prompt-modal-body{display:flex;flex-direction:column;gap:.75rem}.prompt-modal-status{font-size:.75rem;color:#a89870;min-height:1.2em}.prompt-modal-textarea{width:100%;background:#14100ccc;border:1px solid #5a4a2c;border-radius:6px;color:#d4c8a8;font-size:.78rem;font-family:Inter,sans-serif;padding:.6rem;resize:vertical;line-height:1.5;min-height:120px}.prompt-modal-textarea:focus{outline:none;border-color:#c9a84c;box-shadow:0 0 8px #c9a84c26}.prompt-modal-textarea:disabled{opacity:.5}.prompt-modal-actions{display:flex;gap:.5rem;justify-content:flex-end}.skill-check-body{display:flex;flex-direction:column;gap:.75rem}.skill-check-info{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap}.skill-check-label{color:#a89870;font-size:.78rem}.skill-check-mod{font-size:1.3rem;font-weight:700;color:#c9a84c;font-family:Cinzel,serif}.skill-check-breakdown{color:#6a6050;font-size:.68rem}.skill-check-extra{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.skill-check-extra label{color:#a89870;font-size:.75rem;white-space:nowrap}.skill-check-input{width:3.5rem;padding:.25rem .4rem;background:#14100ccc;border:1px solid #5a4a2c;border-radius:4px;color:#e8dcc0;font-size:.85rem;font-weight:600;text-align:center}.skill-check-input:focus{outline:none;border-color:#c9a84c}.skill-check-hint{color:#6a6050;font-size:.62rem;font-style:italic}.skill-roll-btn{font-size:.85rem;padding:.5rem 1rem;letter-spacing:.5px}.skill-roll-results{display:flex;flex-direction:column;gap:.3rem;max-height:200px;overflow-y:auto}.skill-roll-entry{display:flex;align-items:center;gap:.4rem;padding:.4rem .6rem;background:#1e181099;border:1px solid #3a3020;border-radius:5px;animation:rollIn .3s ease-out}@keyframes rollIn{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.skill-roll-die{font-size:1.2rem;font-weight:700;color:#e8dcc0;min-width:1.8rem;text-align:center;background:#5a4a2c4d;border:1px solid #5a4a2c;border-radius:4px;padding:.1rem .3rem}.skill-roll-plus,.skill-roll-eq{color:#6a6050;font-size:.8rem}.skill-roll-modifier{color:#a89870;font-size:.85rem;font-weight:600}.skill-roll-total{font-size:1.3rem;font-weight:700;color:#c9a84c;font-family:Cinzel,serif;min-width:2rem;text-align:center}.skill-roll-crit{font-size:.65rem;font-weight:700;padding:.1rem .4rem;border-radius:3px;letter-spacing:.5px;margin-left:auto;background:#4caf5040;border:1px solid rgba(76,175,80,.4);color:#66bb6a}.skill-roll-fumble{background:#e5737340;border-color:#e5737366;color:#e57373}.skill-roll-entry.nat20{border-color:#4caf5066;box-shadow:0 0 8px #4caf5026}.skill-roll-entry.nat20 .skill-roll-die{color:#66bb6a;border-color:#4caf5080}.skill-roll-entry.nat1{border-color:#e5737366;box-shadow:0 0 8px #e5737326}.skill-roll-entry.nat1 .skill-roll-die{color:#e57373;border-color:#e5737380}@media(max-width:900px){.sheet-body{grid-template-columns:1fr 1fr}.sheet-col-right{grid-column:span 2;border-top:1px solid #3a3020}}@media(max-width:600px){.sheet-body{grid-template-columns:1fr}.sheet-col{border-right:none;border-bottom:1px solid #3a3020}.sheet-col-right{grid-column:span 1}.sheet-name{font-size:1.2rem}}.view-town-stats{max-width:1100px;margin:0 auto}.stats-loading{text-align:center;padding:3rem;color:var(--text-muted);font-size:.9rem}.stats-banner{text-align:center;padding:.75rem;margin-bottom:1rem}.stats-banner h2{font-family:Cinzel,serif;font-size:1.5rem;color:var(--accent);margin:0;letter-spacing:1px}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.6rem;margin-bottom:1.25rem}.stat-card{background:#ffffff0a;border:1px solid var(--border);border-radius:10px;padding:.75rem .5rem;text-align:center;transition:all .2s}.stat-card:hover{border-color:var(--accent);background:#ffffff0f;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.stat-card-muted{opacity:.6}.stat-card-value{font-family:Cinzel,serif;font-size:1.4rem;font-weight:700;color:var(--accent);line-height:1.2}.stat-card-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.25rem}.stats-panel{background:#ffffff08;border:1px solid var(--border);border-radius:10px;padding:.75rem}.stats-panel h3{font-family:Cinzel,serif;font-size:.75rem;color:var(--accent);margin:0 0 .5rem;padding-bottom:.35rem;border-bottom:1px solid var(--border);letter-spacing:.5px}.stats-panel h4{font-size:.72rem;color:var(--text-secondary);margin:0 0 .5rem}.stats-bar-list{display:flex;flex-direction:column;gap:.3rem}.stats-bar-scrollable{max-height:220px;overflow-y:auto}.stats-bar-row{display:grid;grid-template-columns:120px 1fr 70px;align-items:center;gap:.4rem}.stats-bar-label{font-size:.7rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-bar-track{height:8px;background:#ffffff0f;border-radius:4px;overflow:hidden}.stats-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#e0c060);border-radius:4px;transition:width .6s ease-out;min-width:2px}.stats-bar-fill-class{background:linear-gradient(90deg,#6ea8fe,#3d8bfd)}.stats-bar-fill-age{background:linear-gradient(90deg,#7dd87d,#48b548)}.stats-bar-fill-role{background:linear-gradient(90deg,#c97fbf,#a855a0)}.stats-bar-value{font-size:.65rem;color:var(--text-muted);text-align:right;white-space:nowrap}.stats-buildings-section{margin-bottom:1.5rem}.stats-buildings-section>h3{font-family:Cinzel,serif;font-size:.85rem;color:var(--accent);margin:0 0 .75rem;padding-bottom:.35rem;border-bottom:1px solid var(--border)}.building-group-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin:.75rem 0 .4rem;padding-bottom:.2rem}.stats-buildings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.6rem;margin-bottom:.5rem}.stats-building-card{background:#ffffff08;border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .2s;padding:.55rem .7rem}.stats-building-card:hover{border-color:var(--accent)}.building-status-completed{border-left:3px solid var(--success)}.building-status-under_construction{border-left:3px solid var(--warning)}.building-status-damaged{border-left:3px solid #e05555}.building-status-destroyed{border-left:3px solid #666;opacity:.6}.stats-building-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.stats-building-name{font-size:.78rem;font-weight:600;color:var(--text-primary)}.stats-building-status{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.building-desc{font-size:.7rem;color:var(--text-muted);line-height:1.4;margin-bottom:.3rem}.building-progress-wrap{margin-top:.3rem}.building-progress-bar{width:100%;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden;margin-bottom:.2rem}.building-progress-fill{height:100%;background:linear-gradient(90deg,var(--warning),#d4a017);border-radius:3px;transition:width .3s ease}.building-progress-text{font-size:.6rem;color:var(--text-muted)}.stat-card-warn .stat-card-value{color:var(--warning)}.stats-empty{text-align:center;padding:1.5rem;color:var(--text-muted);font-style:italic;font-size:.8rem}@media(max-width:768px){.stats-grid,.stats-buildings-grid{grid-template-columns:1fr}.stats-bar-row{grid-template-columns:80px 1fr 55px}}.roster-tabs{display:flex;border-bottom:2px solid var(--border);background:#ffffff05}.roster-tab{flex:1;padding:.5rem .75rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--text-muted);font-size:.75rem;font-weight:600;letter-spacing:.3px;cursor:pointer;transition:all .2s;text-align:center}.roster-tab:hover{color:var(--text-primary);background:#ffffff08}.roster-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:#ffffff0a}.roster-tab-count{display:inline-block;background:#ffffff14;color:var(--text-muted);font-size:.62rem;padding:.05rem .35rem;border-radius:8px;margin-left:.3rem;min-width:1.2rem;text-align:center}.roster-tab.active .roster-tab-count{background:#c9a84c26;color:var(--accent)}.btn-danger{background:#c8323226;border:1px solid rgba(200,50,50,.4);color:#e05555;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#c832324d;border-color:#e05555}.wsim-config{padding:.5rem 0}.wsim-status-header{font-size:.85rem;color:var(--accent);font-weight:600;margin-bottom:.75rem;padding-bottom:.35rem;border-bottom:1px solid var(--border)}.wsim-town-list{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem}.wsim-town-row{display:flex;justify-content:space-between;align-items:center;padding:.35rem .5rem;border-radius:4px;font-size:.75rem;background:#ffffff05;border:1px solid transparent;transition:all .2s}.wsim-town-row.wsim-active{border-color:var(--accent);background:#c9a84c0f}.wsim-town-name{font-weight:600;color:var(--text-primary)}.wsim-town-status{font-size:.68rem;color:var(--text-muted);padding:.1rem .4rem;border-radius:3px;background:#ffffff0d}.wsim-applied{color:#5cb85c!important;background:#5cb85c1f!important}.wsim-skipped{color:var(--text-muted)!important}.wsim-error{color:#e05555!important;background:#c832321f!important}.wsim-review{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:.75rem}.wsim-review h4{font-family:Cinzel,serif;color:var(--accent);margin:0 0 .4rem;font-size:.85rem}.wsim-summary{font-size:.75rem;color:var(--text-secondary);margin:0 0 .5rem;line-height:1.5}.wsim-result-stats{display:flex;gap:1rem;font-size:.72rem;color:var(--text-muted);margin-bottom:.75rem;padding:.35rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.wsim-review-actions{display:flex;gap:.5rem}.wsim-final{text-align:center;padding:1rem}.wsim-final h3{font-family:Cinzel,serif;color:var(--accent);margin:0 0 .5rem}.wsim-final p{color:var(--text-secondary);font-size:.8rem;margin:0 0 .75rem}.wsim-current{margin-top:.5rem}.sheet-purse{display:flex;flex-direction:column;gap:.35rem;padding:.4rem .5rem;margin-bottom:.35rem;background:#c9a84c0f;border:1px solid rgba(201,168,76,.2);border-radius:6px}.purse-title{font-family:Cinzel,serif;font-size:.6rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);opacity:.7;text-align:center}.purse-coins{display:flex;gap:.25rem;justify-content:center;flex-wrap:wrap}.purse-spinner{display:flex;align-items:center;gap:0;border-radius:5px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.purse-btn{width:18px;height:22px;border:none;font-size:.65rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;padding:0;line-height:1}.purse-minus{background:#c83c3c26;color:#e05555;border-right:1px solid rgba(255,255,255,.05)}.purse-minus:hover{background:#c83c3c4d}.purse-plus{background:#3cb43c26;color:#5cb85c;border-left:1px solid rgba(255,255,255,.05)}.purse-plus:hover{background:#3cb43c4d}.purse-val{min-width:22px;text-align:center;font-size:.65rem;font-weight:700;padding:0 2px;background:#00000040;height:22px;line-height:22px}.purse-label{font-size:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:0 3px;background:#00000026;height:22px;line-height:22px}.purse-pp .purse-val,.purse-pp .purse-label{color:#e5e4e2}.purse-pp{border-color:#e5e4e240}.purse-gp .purse-val,.purse-gp .purse-label{color:#daa520}.purse-gp{border-color:#daa5204d}.purse-ep .purse-val,.purse-ep .purse-label{color:#b8b8b8}.purse-ep{border-color:#c0c0c033}.purse-sp .purse-val,.purse-sp .purse-label{color:silver}.purse-sp{border-color:#c0c0c040}.purse-cp .purse-val,.purse-cp .purse-label{color:#cd7f32}.purse-cp{border-color:#b8733340}.mayor-row{border-left:3px solid var(--accent)!important;background:#c9a84c0a!important}.mayor-badge{color:var(--accent);font-size:.8rem;margin-right:.15rem}.hp-adjuster{padding:.25rem 0}.hp-adjuster-display{display:flex;align-items:baseline;justify-content:center;gap:.25rem;margin-bottom:.5rem}.hp-current{font-family:Cinzel,serif;font-size:2.5rem;font-weight:700;color:var(--accent);line-height:1;transition:color .3s}.hp-separator,.hp-max{font-size:1.2rem;color:var(--text-muted)}.hp-adjuster-bar{width:100%;height:10px;background:#ffffff14;border-radius:5px;overflow:hidden;margin-bottom:.75rem}.hp-bar-fill{height:100%;background:var(--accent);border-radius:5px;transition:width .3s ease,background .3s ease}.hp-adjuster-buttons{display:flex;gap:.35rem;justify-content:center;margin-bottom:.75rem}.hp-btn{padding:.35rem .6rem;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--text-primary);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s}.hp-btn:hover{transform:scale(1.05)}.hp-btn-dmg{border-color:#c832324d;color:#e05555}.hp-btn-dmg:hover{background:#c8323226}.hp-btn-heal{border-color:#32b4324d;color:#5cb85c}.hp-btn-heal:hover{background:#32b43226}.hp-adjuster-custom{display:flex;gap:.35rem;align-items:center;justify-content:center;flex-wrap:wrap}.hp-btn-apply{font-size:.7rem!important;padding:.3rem .5rem!important}.roll-log-section{border-top:1px solid rgba(255,255,255,.06)}.roll-log{max-height:300px;overflow-y:auto;font-size:.65rem;font-family:Inter,sans-serif}.roll-log:empty:after{content:"Click a skill or attack to roll...";color:var(--text-muted);font-style:italic;display:block;padding:.5rem 0;opacity:.5}.roll-log-entry{display:flex;align-items:baseline;gap:.35rem;padding:.2rem .35rem;border-bottom:1px solid rgba(255,255,255,.03);animation:logSlideIn .3s ease;flex-wrap:wrap}@keyframes logSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.roll-log-time{color:var(--text-muted);opacity:.4;font-size:.55rem;min-width:50px;flex-shrink:0}.roll-log-label{font-weight:600;min-width:70px;flex-shrink:0}.roll-log-skill .roll-log-label{color:#5cb85c}.roll-log-attack .roll-log-label{color:#e05555}.roll-log-hp .roll-log-label{color:var(--accent)}.roll-log-dice{font-weight:700;color:var(--text-primary)}.roll-log-dmg{color:#e05555;font-weight:600}.roll-log-heal{color:#5cb85c;font-weight:600}.roll-crit{color:#f44;font-weight:700;text-shadow:0 0 6px rgba(255,68,68,.5)}.roll-fumble{color:#888;font-weight:700}.roll-crit-dmg{color:#f64;font-weight:600;font-style:italic}@keyframes rollFlash{0%{background:#c9a84c40}to{background:transparent}}.roll-flash{animation:rollFlash .4s ease-out}.sheet-skill-row:hover,.sheet-attack-entry:hover{background:#ffffff0a}.onboarding-screen{display:flex;align-items:center;justify-content:center;height:100%;min-height:60vh;padding:2rem}.onboarding-card{max-width:480px;width:100%;background:var(--bg-card, #1e1e3a);border:1px solid rgba(255,215,0,.2);border-radius:16px;padding:2.5rem 2rem;text-align:center;box-shadow:0 12px 40px #0006;animation:fadeSlideUp .4s ease}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.onboarding-icon{font-size:3.5rem;margin-bottom:.75rem;filter:drop-shadow(0 4px 12px rgba(255,215,0,.3))}.onboarding-title{font-family:Cinzel,serif;font-size:1.6rem;color:var(--accent, #eab308);margin-bottom:.5rem}.onboarding-subtitle{font-size:.85rem;color:var(--text-muted, #888);line-height:1.6;margin-bottom:1.5rem}.onboarding-form{text-align:left}.onboarding-form .form-group{margin-bottom:1rem}.onboarding-form label{display:block;font-size:.78rem;font-weight:600;color:var(--text-secondary, #bbb);margin-bottom:.3rem}.onboarding-submit{width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:700;margin-top:.5rem;border-radius:8px;transition:all .2s}.onboarding-submit:hover{transform:translateY(-1px);box-shadow:0 4px 16px #ffd7004d}.onboarding-submit:disabled{opacity:.6;cursor:wait;transform:none}.view-help{max-width:1000px;margin:0 auto;padding-bottom:3rem}.help-header{text-align:center;padding:1.5rem 1rem 1rem;margin-bottom:1rem;background:linear-gradient(135deg,#c9a84c14,#c9a84c05);border:1px solid rgba(201,168,76,.15);border-radius:var(--radius-lg)}.help-title{font-size:1.5rem;color:var(--accent);margin:0 0 .25rem;font-family:Cinzel,serif}.help-subtitle{font-size:.85rem;color:var(--text-muted);margin:0}.help-tabbed-layout{display:grid;grid-template-columns:200px 1fr;gap:1rem;min-height:500px}.help-tab-list{display:flex;flex-direction:column;gap:2px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:.4rem;overflow-y:auto;max-height:calc(100vh - 220px);position:sticky;top:1rem}.help-tab-btn{display:flex;align-items:center;gap:.5rem;padding:.55rem .7rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.78rem;font-weight:500;cursor:pointer;text-align:left;transition:all .15s;white-space:nowrap}.help-tab-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.help-tab-btn.active{background:var(--accent-dim);color:var(--accent);font-weight:600;border-left:3px solid var(--accent)}.help-tab-icon{font-size:.9rem;flex-shrink:0;width:20px;text-align:center}.help-tab-label{overflow:hidden;text-overflow:ellipsis}.help-tab-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem 1.5rem;overflow-y:auto;max-height:calc(100vh - 220px);animation:helpContentFade .2s ease}@keyframes helpContentFade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.help-content-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.help-content-icon{font-size:1.4rem}.help-content-title{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:0;font-family:Cinzel,serif}.help-content-body{color:var(--text-secondary);font-size:.85rem;line-height:1.65}.help-content-body h4{color:var(--accent);font-size:.95rem;margin:0 0 .5rem}.help-content-body p{margin:0 0 .5rem}.help-feature{padding:.6rem .8rem;margin-bottom:.5rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);border-left:3px solid var(--accent)}.help-feature strong{color:var(--text-primary);display:block;margin-bottom:.2rem;font-size:.82rem}.help-feature p{margin:0!important;font-size:.8rem;color:var(--text-secondary)}.help-list{margin:.3rem 0 0 1.2rem;padding:0;font-size:.8rem}.help-list li{margin-bottom:.2rem}.help-list code{background:#c9a84c1f;color:var(--accent);padding:.1rem .35rem;border-radius:3px;font-size:.75rem;font-family:JetBrains Mono,monospace}.help-steps{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.help-step{display:flex;gap:.75rem;align-items:flex-start;padding:.6rem .8rem;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.help-step-num{width:26px;height:26px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),#d4a017);color:#1a1a2e;font-weight:700;font-size:.75rem;border-radius:50%}.help-step strong{color:var(--text-primary);display:block;font-size:.82rem;margin-bottom:.15rem}.help-step p{margin:0;font-size:.78rem;color:var(--text-secondary)}.help-tip{padding:.6rem .8rem;margin-top:.5rem;background:#4caf5014;border:1px solid rgba(76,175,80,.2);border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-secondary)}.help-tip strong{color:var(--success)}.help-content-body kbd{display:inline-block;padding:.1rem .4rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:3px;font-size:.72rem;font-family:JetBrains Mono,monospace;color:var(--text-primary);box-shadow:0 1px 0 var(--border)}@media(max-width:700px){.help-tabbed-layout{grid-template-columns:1fr}.help-tab-list{flex-direction:row;flex-wrap:wrap;position:static;max-height:none;gap:3px}.help-tab-btn{padding:.4rem .5rem;font-size:.7rem}.help-tab-content{max-height:none}}.ws-town-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem}.ws-town-card{display:flex;flex-direction:column;padding:.85rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color .15s,box-shadow .15s}.ws-town-card:hover{border-color:var(--border-light);box-shadow:0 2px 12px #0003}.ws-town-check{display:flex;align-items:center;gap:.6rem;cursor:pointer;margin-bottom:.5rem}.ws-town-check input[type=checkbox]{accent-color:var(--accent);width:18px;height:18px;cursor:pointer;flex-shrink:0}.ws-town-info{display:flex;flex-direction:column}.ws-town-name{font-size:1rem;font-weight:700;color:var(--text-primary)}.ws-town-pop{font-size:.75rem;color:var(--text-muted)}.ws-town-status{font-size:.75rem;white-space:nowrap;display:flex;align-items:center;gap:.25rem;margin-top:.4rem;padding-top:.4rem;border-top:1px solid rgba(255,255,255,.05)}.sim-log-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.sim-log-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:560px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 16px 48px #00000080;animation:slideUp .25s ease}.sim-log-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.sim-log-header h3{margin:0;font-size:1rem;color:var(--accent);font-family:Cinzel,serif}.sim-log-close{background:none;border:none;color:var(--text-muted);font-size:1.3rem;cursor:pointer;line-height:1}.sim-log-close:hover{color:var(--error)}.sim-log-body{flex:1;overflow-y:auto;padding:.75rem 1.25rem;max-height:55vh}.sim-log-entry{display:flex;align-items:flex-start;gap:.6rem;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.04);animation:logSlideIn .2s ease}.sim-log-icon{font-size:.9rem;flex-shrink:0;margin-top:.1rem}.sim-log-text{font-size:.82rem;color:var(--text-secondary);line-height:1.4}.sim-log-text strong{color:var(--text-primary)}.sim-log-entry.sim-log-error .sim-log-text{color:var(--error)}.sim-log-entry.sim-log-success .sim-log-text{color:var(--success)}.sim-log-footer{padding:.75rem 1.25rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sim-log-progress{flex:1;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.sim-log-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease}.sim-log-percent{font-size:.72rem;color:var(--text-muted);min-width:35px;text-align:right}.ws-narrative-card{margin-bottom:.75rem;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm)}.ws-narrative-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.ws-narrative-town{font-size:.9rem;font-weight:600;color:var(--accent)}.ws-narrative-town:hover{text-decoration:underline}.ws-narrative-stats{font-size:.72rem;color:var(--text-muted)}.ws-narrative-body{font-size:.8rem;color:var(--text-secondary);line-height:1.6}.party-detail-panel{display:flex;flex-direction:column}.party-remove-bar{display:flex;justify-content:space-between;align-items:center;padding:.4rem .75rem;background:#4e3a7814;border-bottom:1px solid var(--border);flex-shrink:0}.party-from-town{font-size:.75rem;color:var(--text-secondary)}.cs-sheet{display:flex;flex-direction:column;height:100%;overflow:hidden;font-family:Inter,sans-serif}.cs-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:linear-gradient(135deg,#1a0e2ef2,#0d0815fa);border-bottom:2px solid #1A0E2E;flex-shrink:0}.cs-header-left{display:flex;align-items:center;gap:.75rem;min-width:0}.cs-portrait-wrap{width:52px;height:52px;flex-shrink:0;border-radius:4px;overflow:hidden;border:2px solid rgba(184,115,51,.3);background:var(--bg-tertiary)}.cs-portrait-img{width:100%;height:100%;object-fit:cover}.cs-portrait-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;opacity:.4}.cs-header-info{min-width:0}.cs-name{font-family:Cinzel,serif;font-size:1.05rem;color:var(--text-heading);margin:0;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.cs-subtitle{font-size:.65rem;font-weight:600;color:var(--text-muted);margin:.1rem 0 0;letter-spacing:.5px}.cs-deceased{font-size:.6rem;padding:.1rem .4rem;border-radius:4px;background:#8b000066;color:#f66;font-weight:700}.cs-header-right{display:flex;gap:.3rem;flex-shrink:0}.cs-action-btn{width:30px;height:30px;border-radius:4px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--text-secondary);cursor:pointer;font-size:.85rem;transition:all .15s;display:flex;align-items:center;justify-content:center}.cs-action-btn:hover{background:#b873331f;border-color:#b873334d;color:var(--accent)}.cs-action-del:hover{background:#ef444426;border-color:#ef44444d;color:#ef4444}.cs-tabs{display:flex;gap:0;flex-shrink:0;border-bottom:2px solid #1A0E2E;background:#0d0815;overflow-x:auto;scrollbar-width:none}.cs-tabs::-webkit-scrollbar{display:none}.cs-tab{padding:.45rem .85rem;font-size:.72rem;font-weight:600;color:var(--text-muted);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all .15s;text-transform:uppercase;letter-spacing:.3px}.cs-tab:hover{color:var(--text-primary);background:#ffffff08}.cs-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.cs-tab-content{flex:1;overflow-y:auto;padding:.5rem;min-height:0}.dnd-section-head{background:#1a0e2e;color:#f0e6d3;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:.2rem .4rem;margin-bottom:.3rem;border:1px solid #2D1B4E;display:flex;justify-content:space-between;align-items:center}.dnd-section-head .head-count{font-size:.55rem;font-weight:400;color:#a89bb8;letter-spacing:0;text-transform:none}.dnd-field{border:1px solid #4E3A78;background:#ffffff08;min-width:32px;min-height:24px;text-align:center;font-family:JetBrains Mono,Courier New,monospace;font-size:.78rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;justify-content:center;padding:.15rem .3rem}.dnd-field-sm{min-width:28px;min-height:20px;font-size:.68rem;padding:.1rem .2rem}.dnd-field-lg{min-width:44px;min-height:34px;font-size:1.2rem;font-weight:800}.dnd-field-label{font-size:.45rem;font-weight:600;color:#a89bb8;text-transform:uppercase;letter-spacing:.5px;text-align:center;margin-top:.05rem;line-height:1}.cs-info-bar{display:grid;grid-template-columns:2fr 1fr 1fr;gap:.4rem;margin-bottom:.3rem}.cs-info-row{display:flex;gap:.4rem;align-items:flex-end}.cs-info-field{flex:1;border-bottom:1px solid #4E3A78;padding-bottom:.15rem;display:flex;flex-direction:column;gap:.05rem}.cs-info-val{font-size:.82rem;font-weight:600;color:var(--text-primary);min-height:1.1rem;line-height:1.2}.cs-info-label{font-size:.45rem;font-weight:600;color:#6b5d7a;text-transform:uppercase;letter-spacing:.5px}.cs-phys-bar{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:.4rem;margin-bottom:.3rem}.cs-phys-field{border-bottom:1px solid #4E3A78;display:flex;flex-direction:column;padding-bottom:.15rem;gap:.05rem}.cs-page1-grid{display:grid;grid-template-columns:175px 1fr 1fr;gap:.5rem;flex:1;min-height:0;overflow:hidden}.cs-abilities-col{display:flex;flex-direction:column;gap:.15rem}.cs-ability-row{display:grid;grid-template-columns:42px 28px 28px 28px 28px;gap:.1rem;align-items:center}.cs-ability-name{font-size:.55rem;font-weight:700;color:#d4c5f9;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;line-height:1}.cs-ability-name small{display:block;font-size:.38rem;font-weight:400;color:#6b5d7a;text-transform:capitalize;line-height:1}.cs-ability-header{display:grid;grid-template-columns:42px 28px 28px 28px 28px;gap:.1rem;align-items:center;margin-bottom:.1rem}.cs-ability-header span{font-size:.38rem;font-weight:600;color:#6b5d7a;text-transform:uppercase;letter-spacing:.3px;text-align:center}.cs-combat-col{display:flex;flex-direction:column;gap:.3rem;overflow-y:auto}.cs-hp-section{display:flex;gap:.3rem;align-items:stretch}.cs-hp-total{display:flex;flex-direction:column;align-items:center;gap:.05rem}.cs-hp-boxes{display:flex;gap:.2rem;flex:1}.cs-hp-box{flex:1;display:flex;flex-direction:column;align-items:center}.cs-ac-section{display:flex;flex-direction:column;gap:.15rem}.cs-ac-main-row{display:flex;align-items:center;gap:.15rem}.cs-ac-breakdown{display:flex;flex-wrap:wrap;gap:.1rem;align-items:center}.cs-ac-plus,.cs-ac-equals{color:#6b5d7a;font-size:.65rem;font-weight:600}.cs-ac-sub-row{display:flex;gap:.5rem;margin-top:.1rem}.cs-ac-sub-item{display:flex;align-items:center;gap:.2rem}.cs-ac-sub-label{font-size:.55rem;font-weight:700;color:#a89bb8;text-transform:uppercase}.cs-init-row{display:flex;align-items:center;gap:.15rem}.cs-saves-section{display:flex;flex-direction:column;gap:.1rem}.cs-save-header{display:grid;grid-template-columns:70px 1fr 1fr 1fr 1fr 1fr 1fr;gap:.15rem;align-items:center}.cs-save-header span{font-size:.4rem;font-weight:600;color:#6b5d7a;text-transform:uppercase;text-align:center}.cs-save-row{display:grid;grid-template-columns:70px 1fr 1fr 1fr 1fr 1fr 1fr;gap:.15rem;align-items:center}.cs-save-name{font-size:.6rem;font-weight:700;color:#d4c5f9;text-transform:uppercase}.cs-save-name small{display:block;font-size:.38rem;font-weight:400;color:#6b5d7a}.cs-bab-section{display:flex;gap:.3rem;align-items:center}.cs-bab-item{display:flex;align-items:center;gap:.15rem}.cs-bab-label{font-size:.55rem;font-weight:700;color:#a89bb8;text-transform:uppercase;white-space:nowrap}.cs-grapple-row{display:flex;gap:.1rem;align-items:center}.cs-attack-block{border:1px solid #2D1B4E;margin-bottom:.2rem;cursor:pointer;transition:border-color .15s}.cs-attack-block:hover{border-color:#b873334d}.cs-atk-top{display:grid;grid-template-columns:1fr 100px 100px 80px;gap:0}.cs-atk-top>div{padding:.2rem .3rem;border-right:1px solid #2D1B4E;display:flex;flex-direction:column}.cs-atk-top>div:last-child{border-right:none}.cs-atk-bot{display:grid;grid-template-columns:80px 80px 1fr;gap:0;border-top:1px solid #2D1B4E}.cs-atk-bot>div{padding:.15rem .3rem;border-right:1px solid #2D1B4E;display:flex;flex-direction:column}.cs-atk-bot>div:last-child{border-right:none}.cs-atk-val-text{font-size:.72rem;font-weight:600;color:var(--text-primary);font-family:JetBrains Mono,monospace}.cs-atk-label-text{font-size:.38rem;font-weight:600;color:#6b5d7a;text-transform:uppercase;letter-spacing:.3px}.cs-ammo-row{font-size:.5rem;color:#6b5d7a;padding:.1rem .3rem;border-top:1px solid #1A0E2E}.cs-skills-col{display:flex;flex-direction:column;min-height:0}.cs-skills-list{flex:1;overflow-y:auto;max-height:calc(100vh - 280px)}.cs-skill-header,.cs-skill-row{display:grid;grid-template-columns:14px 1fr 30px 38px 30px 30px;gap:.1rem;padding:.12rem .15rem;font-size:.65rem;align-items:center}.cs-skill-header{font-size:.42rem;font-weight:700;color:#6b5d7a;text-transform:uppercase;border-bottom:1px solid #4E3A78;padding-bottom:.15rem;position:sticky;top:0;background:var(--bg-card);z-index:1}.cs-skill-row{cursor:pointer;border-bottom:1px solid rgba(255,255,255,.03);transition:background .1s}.cs-skill-check{width:10px;height:10px;border:1px solid #4E3A78;display:flex;align-items:center;justify-content:center;font-size:.5rem;color:var(--accent)}.cs-skill-name{color:var(--text-primary);font-weight:500;font-size:.62rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cs-skill-ab{color:#a89bb8;text-align:center;font-size:.55rem;text-transform:uppercase}.cs-skill-val{text-align:center;font-family:JetBrains Mono,monospace;color:var(--text-secondary);font-size:.65rem;border:1px solid #2D1B4E;background:#ffffff05;padding:.05rem}.cs-val-pos{color:var(--success)!important}.cs-val-neg{color:var(--error)!important}.cs-maxranks{font-size:.42rem;color:#6b5d7a;text-align:right;padding:.1rem .15rem}.cs-page2-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.4rem;flex:1;min-height:0}.cs-page2-left,.cs-page2-center,.cs-page2-right{display:flex;flex-direction:column;gap:.3rem;overflow-y:auto}.cs-prot-item{display:grid;grid-template-columns:1fr 60px 50px 1fr;gap:0;border:1px solid #2D1B4E;margin-bottom:.2rem}.cs-prot-item>div{padding:.15rem .25rem;border-right:1px solid #2D1B4E;display:flex;flex-direction:column}.cs-prot-item>div:last-child{border-right:none}.cs-poss-table{width:100%;border-collapse:collapse;font-size:.65rem}.cs-poss-table th{background:#1a0e2e;color:#d4c5f9;font-size:.5rem;font-weight:600;text-transform:uppercase;padding:.15rem .25rem;border:1px solid #2D1B4E;text-align:left}.cs-poss-table td{padding:.12rem .25rem;border:1px solid #1A0E2E;color:var(--text-secondary);font-size:.65rem}.cs-poss-table tr:hover td{background:#b8733308}.cs-load-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.15rem}.cs-load-item{display:flex;flex-direction:column;align-items:center;border:1px solid #2D1B4E;padding:.15rem}.cs-money-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.15rem}.cs-money-item{display:flex;flex-direction:column;align-items:center;border:1px solid #2D1B4E;padding:.15rem}.cs-money-label{font-size:.5rem;font-weight:700;color:#a89bb8}.cs-feats-list{display:flex;flex-direction:column}.cs-feat-item{padding:.2rem .3rem;font-size:.68rem;color:var(--text-primary);cursor:pointer;border-bottom:1px solid rgba(255,255,255,.04);transition:background .1s}.cs-feat-item:hover{background:#b873330a}.cs-traits-list{display:flex;flex-direction:column}.cs-trait-item{padding:.15rem .3rem;font-size:.65rem;color:var(--text-secondary);border-bottom:1px solid rgba(255,255,255,.03)}.cs-languages{font-size:.72rem;color:var(--text-secondary);line-height:1.5;padding:.2rem .3rem}.cs-spell-grid{display:flex;flex-direction:column;gap:0}.cs-spell-save-row{display:flex;gap:.3rem;align-items:center;padding:.2rem 0}.cs-spell-save-label{font-size:.55rem;font-weight:700;color:#a89bb8;text-transform:uppercase}.cs-block{background:#0d081599;border:1px solid #1A0E2E;border-radius:4px;padding:.5rem .6rem;margin-bottom:.35rem;transition:border-color .2s}.cs-block:hover{border-color:#b873331f}.cs-block-title{font-size:.62rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.35rem;padding-bottom:.2rem;border-bottom:1px solid #1A0E2E;display:flex;justify-content:space-between;align-items:center}.cs-block-count{font-size:.55rem;color:var(--text-muted);font-weight:500;text-transform:none;letter-spacing:0}.cs-empty{font-size:.72rem;color:var(--text-muted);font-style:italic;text-align:center;padding:.5rem;opacity:.6}.cs-muted{color:var(--text-muted);font-size:.72rem}.cs-loading{text-align:center;font-size:.75rem;color:var(--text-muted);padding:1rem}.cs-roll-log-bar{flex-shrink:0;border-top:1px solid #1A0E2E;background:#0d0815;max-height:120px}.cs-roll-log-header{display:flex;justify-content:space-between;align-items:center;padding:.25rem .5rem;font-size:.65rem;font-weight:600;color:var(--text-muted);border-bottom:1px solid #1A0E2E}.cs-roll-log-header span{font-size:.55rem;cursor:pointer;color:var(--text-muted);opacity:.6}.cs-roll-log-header span:hover{opacity:1;color:var(--accent)}.cs-roll-log{max-height:80px;overflow-y:auto;padding:.15rem .5rem;scrollbar-width:thin}.roll-log-entry{display:flex;gap:.35rem;align-items:baseline;padding:.1rem 0;font-size:.68rem;border-bottom:1px solid rgba(255,255,255,.02)}.roll-log-time{font-size:.55rem;color:#6b5d7a;font-family:JetBrains Mono,monospace;flex-shrink:0}.roll-log-label{font-weight:600;color:var(--text-secondary);margin-right:.25rem}.roll-log-dice{color:var(--accent);font-family:JetBrains Mono,monospace;font-weight:700}.roll-log-dmg{color:#c75b3a;font-family:JetBrains Mono,monospace}.roll-crit{color:#c9a84c;font-weight:700;text-shadow:0 0 6px rgba(201,168,76,.4)}.roll-fumble{color:#c75b3a;font-weight:700}.roll-flash{animation:rollFlash .4s ease}@keyframes rollFlash{0%{background:#b8733326}to{background:transparent}}.cs-paperdoll-block{background:linear-gradient(180deg,#0d081599,#b8733305)}.cs-paperdoll{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.4rem 0}.pd-row{display:flex;justify-content:center;align-items:center;gap:.3rem;width:100%}.pd-body-center{width:70px;height:110px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pd-svg{width:100%;height:100%;opacity:.8}.pd-slot{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:85px;min-height:40px;padding:.25rem .4rem;border-radius:4px;cursor:pointer;transition:all .2s ease;text-align:center;position:relative}.pd-slot.pd-wide{min-width:170px}.pd-slot.pd-small{min-width:65px}.pd-slot.pd-empty{border:1px dashed rgba(184,115,51,.12);background:#ffffff05}.pd-slot.pd-empty:hover{border-color:#b873334d;background:#b873330a}.pd-slot.pd-filled{border:1px solid rgba(184,115,51,.25);background:#b873330f}.pd-slot.pd-filled:hover{border-color:#ef44444d;background:#ef44440f}.pd-label{font-size:.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);opacity:.7;line-height:1}.pd-item{font-size:.62rem;font-weight:600;color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px;line-height:1.2}.pd-slot.pd-empty .pd-label{opacity:.4}.cs-backpack-list{max-height:220px;overflow-y:auto}.cs-backpack-item{display:flex;align-items:center;gap:.3rem;padding:.25rem .2rem;font-size:.7rem;border-bottom:1px solid rgba(255,255,255,.03);transition:background .1s}.cs-backpack-item:hover{background:#b8733308}.cs-bp-icon{font-size:.8rem;flex-shrink:0}.cs-bp-name{flex:1;color:var(--text-primary);font-weight:500}.cs-bp-equip-btn,.cs-bp-del-btn{padding:.12rem .35rem;border-radius:3px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--text-muted);cursor:pointer;font-size:.6rem;transition:all .15s;white-space:nowrap}.cs-bp-equip-btn:hover{background:#8b5cf626;border-color:#8b5cf64d;color:#a78bfa}.cs-bp-del-btn:hover{background:#ef444426;border-color:#ef44444d;color:#ef4444}.cs-purse{margin-bottom:.35rem;padding:.4rem;background:#14141966;border-radius:4px}.cs-purse-title{display:block;font-size:.55rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:.3rem}.cs-purse-coins{display:flex;gap:.3rem;flex-wrap:wrap}.cs-xp-section{margin-top:.35rem;background:#8b5cf60f;border:1px solid rgba(139,92,246,.15);border-radius:6px;overflow:hidden}.cs-xp-header{display:flex;justify-content:space-between;align-items:center;padding:.4rem .6rem;transition:background .15s}.cs-xp-header:hover{background:#8b5cf614}.cs-xp-info{display:flex;align-items:baseline;gap:.4rem}.cs-xp-label{font-size:.65rem;font-weight:600;color:var(--text-secondary)}.cs-xp-total{font-size:.85rem;font-weight:800;color:#a78bfa;font-family:JetBrains Mono,monospace}.cs-xp-next-label{font-size:.6rem;color:var(--text-muted)}.cs-xp-progress-bar{position:relative;height:6px;background:#0000004d}.cs-xp-progress-fill{height:100%;background:linear-gradient(90deg,#7c3aed,#a78bfa);border-radius:0 3px 3px 0;transition:width .4s ease}.cs-xp-progress-text{position:absolute;right:4px;top:-1px;font-size:.45rem;font-weight:700;color:#fff9;line-height:6px}.cs-xp-log-panel{border-top:1px solid rgba(139,92,246,.12)}.cs-xp-log-header{display:flex;justify-content:space-between;align-items:center;padding:.3rem .5rem;font-size:.6rem;font-weight:600;color:var(--text-muted);background:#00000026}.cs-xp-log-indicator{font-size:.55rem;color:var(--text-muted);opacity:.7}.cs-xp-log-list{max-height:200px;overflow-y:auto;scrollbar-width:thin}.cs-xp-log-empty{text-align:center;padding:.75rem;font-size:.7rem;color:var(--text-muted);font-style:italic}.cs-xp-log-table{width:100%;border-collapse:collapse;font-size:.62rem}.cs-xp-log-table thead th{padding:.2rem .35rem;text-align:left;font-size:.5rem;font-weight:700;color:#a89bb8;text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid rgba(139,92,246,.12);background:#0000001a;position:sticky;top:0}.cs-xp-log-table tbody tr{border-bottom:1px solid rgba(255,255,255,.03);transition:background .1s}.cs-xp-log-table tbody tr:hover{background:#8b5cf60a}.cs-xp-log-table td{padding:.2rem .35rem;vertical-align:middle}.xplog-date{color:var(--text-muted);white-space:nowrap;font-size:.58rem}.xplog-xp{color:#a78bfa;font-weight:700;font-family:JetBrains Mono,monospace;white-space:nowrap}.xplog-source{color:var(--text-muted);font-size:.55rem;white-space:nowrap}.xplog-reason{color:var(--text-secondary);font-size:.6rem}.cs-add-srd-bar{padding:.3rem 0}.cs-history-text{font-size:.78rem;color:var(--text-secondary);line-height:1.6;white-space:pre-wrap;padding:.5rem;background:#ffffff05;border-radius:4px;border:1px solid #1A0E2E;min-height:100px}.cs-ai-debug{opacity:.6}.hp-adjuster{display:flex;flex-direction:column;align-items:center;gap:.75rem}.hp-adjuster-display{display:flex;align-items:baseline;gap:.15rem;font-family:JetBrains Mono,monospace}.hp-current{font-size:2.5rem;font-weight:800;color:var(--accent)}.hp-separator{font-size:1.5rem;color:#6b5d7a}.hp-max{font-size:1.2rem;color:#a89bb8}.hp-adjuster-bar{width:100%;height:8px;background:#1a0e2e;border-radius:4px;overflow:hidden}.hp-bar-fill{height:100%;background:var(--accent);border-radius:4px;transition:all .3s ease}.hp-adjuster-buttons{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:center}.hp-btn{padding:.4rem .8rem;border-radius:4px;border:1px solid #2D1B4E;background:#ffffff0d;cursor:pointer;font-size:.85rem;font-weight:700;font-family:JetBrains Mono,monospace;transition:all .15s}.hp-btn-dmg{color:#ff6b6b}.hp-btn-dmg:hover{background:#ef444426;border-color:#ef44444d}.hp-btn-heal{color:#4ade80}.hp-btn-heal:hover{background:#4ade8026;border-color:#4ade804d}.hp-adjuster-custom{display:flex;gap:.35rem;align-items:center}.hp-btn-apply{padding:.35rem .7rem;font-size:.72rem}.ai-levelup-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem}.ai-levelup-spinner{width:40px;height:40px;border:3px solid #2D1B4E;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.ai-levelup-text{text-align:center;font-size:.85rem;color:var(--text-secondary)}.ai-levelup-diff{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.ai-diff-row{display:grid;grid-template-columns:80px 1fr 20px 1fr;gap:.35rem;align-items:center;padding:.25rem .35rem;border-radius:4px;font-size:.75rem}.ai-diff-row.changed{background:#b873330d}.ai-diff-label{font-weight:600;color:var(--text-muted);text-transform:uppercase;font-size:.65rem}.ai-diff-old{color:#a89bb8;font-family:JetBrains Mono,monospace;font-size:.68rem}.ai-diff-arrow{color:var(--accent);text-align:center}.ai-diff-new{color:var(--accent);font-weight:600;font-family:JetBrains Mono,monospace;font-size:.68rem}.ai-levelup-summary{padding:.5rem;background:#ffffff08;border-radius:4px;border:1px solid #1A0E2E;font-size:.75rem;color:var(--text-secondary);white-space:pre-wrap;margin-bottom:.75rem}.ai-levelup-actions{display:flex;justify-content:center;gap:.5rem}.cs-social-grid,.cs-inv-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.skill-check-body{display:flex;flex-direction:column;align-items:center;gap:.5rem}.skill-check-info{display:flex;align-items:baseline;gap:.35rem}.skill-check-label{font-size:.85rem;color:var(--text-muted)}.skill-check-mod{font-size:1.5rem;font-weight:800;color:var(--accent);font-family:JetBrains Mono,monospace}.skill-check-extra{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--text-muted)}.skill-check-input{width:60px;text-align:center}.skill-roll-btn{margin-top:.35rem}[data-edit]:hover{cursor:pointer}[data-edit]:hover .cs-block-title:after{content:" ✎";font-size:.55rem;opacity:.4}.cs-skills-col{display:flex;flex-direction:column;overflow-y:auto;min-height:0}.cs-skills-list{display:flex;flex-direction:column;font-size:.68rem}.cs-skill-header{display:grid;grid-template-columns:18px 1fr 30px 32px 28px 28px 28px;gap:.1rem;padding:.15rem 0;border-bottom:1px solid #4E3A78;font-size:.5rem;font-weight:600;color:#a89bb8;text-transform:uppercase;letter-spacing:.3px}.cs-skill-header span{text-align:center}.cs-skill-header span:nth-child(2){text-align:left}.cs-skill-row{display:grid;grid-template-columns:18px 1fr 30px 32px 28px 28px 28px;gap:.1rem;align-items:center;padding:.1rem 0;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background .1s}.cs-skill-row:hover{background:#b873330a}.cs-skill-check{text-align:center;color:var(--accent);font-size:.6rem;font-weight:700}.cs-skill-name{font-size:.62rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cs-skill-ab{text-align:center;font-size:.55rem;color:#a89bb8;text-transform:uppercase}.cs-skill-val{text-align:center;font-family:JetBrains Mono,Courier New,monospace;font-size:.62rem;font-weight:600;color:var(--text-secondary);border:1px solid #2D1B4E;background:#ffffff05;padding:.05rem;min-height:16px;display:flex;align-items:center;justify-content:center}.cs-val-pos{color:#6b6}.cs-val-neg{color:#c77}.cs-bg-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:.5rem}.cs-bg-left,.cs-bg-right{display:flex;flex-direction:column;gap:0}.cs-desc-grid{display:flex;flex-direction:column;gap:.15rem}.cs-desc-item{display:flex;gap:.5rem;align-items:baseline;padding:.2rem 0;font-size:.78rem;border-bottom:1px solid rgba(255,255,255,.04)}.cs-desc-label{font-weight:600;color:var(--text-muted);min-width:80px;text-transform:uppercase;font-size:.65rem;letter-spacing:.3px}.cs-desc-item span:last-child{color:var(--text-primary);font-weight:500}.cs-bg-text{font-size:.78rem;color:var(--text-secondary);line-height:1.5}.cs-portrait-section{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.5rem 0}.cs-bg-portrait{max-width:150px;max-height:200px;border-radius:6px;border:2px solid rgba(184,115,51,.2)}.cs-portrait-actions{display:flex;gap:.35rem}.cs-spells-placeholder{font-size:.75rem;color:var(--text-muted);text-align:center;padding:1rem}.spell-slots-table{width:100%;border-collapse:collapse;font-size:.7rem;margin-bottom:.5rem}.spell-slots-table th{background:#1a0e2e;color:#d4c5f9;font-size:.5rem;font-weight:600;text-transform:uppercase;padding:.2rem .35rem;border:1px solid #2D1B4E;text-align:center}.spell-slots-table td{padding:.15rem .35rem;border:1px solid #1A0E2E;text-align:center;color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:.68rem}.spell-slots-table tr:hover td{background:#b8733308}.spell-list-section{margin-top:.35rem}.spell-item{display:flex;justify-content:space-between;align-items:center;padding:.2rem .3rem;font-size:.68rem;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background .1s}.spell-item:hover{background:#b873330a}.spell-item .spell-name{color:var(--text-primary);font-weight:500}.spell-item .spell-meta{color:var(--text-muted);font-size:.6rem}.spell-search-bar{display:flex;gap:.25rem;margin-bottom:.35rem}.spell-search-bar input{flex:1;font-size:.72rem}.spell-search-results{max-height:200px;overflow-y:auto}.spell-level-group{margin-bottom:.35rem}.spell-level-header{font-size:.6rem;font-weight:700;color:var(--accent);text-transform:uppercase;padding:.15rem .3rem;background:#b873330d;border-bottom:1px solid #1A0E2E;margin-bottom:.1rem}.cs-social-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:768px){.cs-social-grid{grid-template-columns:1fr}}.social-rel-list{display:flex;flex-direction:column;gap:.5rem}.social-rel-card{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:#ffffff0a;border-radius:8px;border-left:3px solid var(--accent, #B87333);transition:all .2s ease;cursor:default}.social-rel-card:hover{background:#ffffff14;transform:translate(2px)}.social-rel-card .rel-icon{font-size:1.3rem;width:2rem;text-align:center;flex-shrink:0}.social-rel-card .rel-info{flex:1;min-width:0}.social-rel-card .rel-names{font-weight:600;font-size:.85rem;color:var(--text-primary, #eee);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.social-rel-card .rel-type{font-size:.72rem;color:var(--text-secondary, #999);text-transform:capitalize}.social-rel-card .rel-disposition{flex-shrink:0;width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}.rel-disposition.hostile{background:#dc354533;color:#f44;border:1px solid rgba(220,53,69,.3)}.rel-disposition.unfriendly{background:#ff980026;color:#ff9800;border:1px solid rgba(255,152,0,.2)}.rel-disposition.neutral{background:#ffffff0f;color:#888;border:1px solid rgba(255,255,255,.1)}.rel-disposition.friendly{background:#4caf5026;color:#66bb6a;border:1px solid rgba(76,175,80,.2)}.rel-disposition.close{background:#b8733326;color:#b87333;border:1px solid rgba(184,115,51,.3)}.social-rel-card[data-type=friend]{border-left-color:#66bb6a}.social-rel-card[data-type=rival]{border-left-color:#ff9800}.social-rel-card[data-type=enemy]{border-left-color:#f44}.social-rel-card[data-type=romantic]{border-left-color:#e91e63}.social-rel-card[data-type=mentor]{border-left-color:#42a5f5}.social-rel-card[data-type=student]{border-left-color:#7e57c2}.social-rel-card[data-type=ally]{border-left-color:#26a69a}.social-mem-list{display:flex;flex-direction:column;gap:.4rem;max-height:350px;overflow-y:auto}.social-mem-card{padding:.5rem .75rem;background:#ffffff08;border-radius:6px;border-left:3px solid var(--text-secondary, #666);font-size:.78rem;line-height:1.4;transition:all .2s ease}.social-mem-card:hover{background:#ffffff0f}.social-mem-card .mem-content{color:var(--text-primary, #ddd)}.social-mem-card .mem-meta{display:flex;gap:.5rem;margin-top:.25rem;font-size:.68rem;color:var(--text-secondary, #888)}.mem-sentiment-pos{border-left-color:#66bb6a}.mem-sentiment-neg{border-left-color:#ff5252}.mem-sentiment-neutral{border-left-color:#666}.mem-importance-high{border-left-width:4px}.social-faction-list{display:flex;flex-direction:column;gap:.75rem}.social-faction-card{padding:.75rem;background:#ffffff0a;border-radius:10px;border:1px solid rgba(255,255,255,.08);transition:all .2s ease}.social-faction-card:hover{background:#ffffff12;border-color:#b8733333}.faction-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.faction-icon{font-size:1.3rem}.faction-name{font-weight:700;font-size:.9rem;color:var(--text-primary, #eee);flex:1}.faction-influence{font-size:.7rem;padding:2px 8px;border-radius:10px;background:#b873331f;color:var(--accent, #B87333);font-weight:600}.faction-desc{font-size:.75rem;color:var(--text-secondary, #aaa);line-height:1.4;margin-bottom:.4rem}.faction-members-row{display:flex;flex-wrap:wrap;gap:.3rem}.faction-member-badge{font-size:.68rem;padding:2px 8px;border-radius:12px;background:#ffffff0f;color:var(--text-secondary, #bbb);border:1px solid rgba(255,255,255,.08)}.faction-member-badge.leader{background:#b873331f;color:var(--accent, #B87333);border-color:#b8733340}.social-incident-list{display:flex;flex-direction:column;gap:.5rem}.social-incident-card{padding:.6rem .75rem;background:#ffffff08;border-radius:8px;border-left:3px solid #666;transition:all .2s ease}.social-incident-card:hover{background:#ffffff0f}.social-incident-card[data-status=active]{border-left-color:#ff5252}.social-incident-card[data-status=investigating]{border-left-color:#ffab40}.social-incident-card[data-status=resolved]{border-left-color:#66bb6a}.social-incident-card[data-status=cold]{border-left-color:#90a4ae}.incident-header{display:flex;align-items:center;gap:.5rem}.incident-type-badge{font-size:.65rem;padding:1px 7px;border-radius:8px;background:#ff525226;color:#ff5252;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.incident-type-badge.murder{background:#c6282833;color:#ef5350}.incident-type-badge.theft{background:#ff980026;color:#ff9800}.incident-type-badge.mystery{background:#673ab726;color:#b39ddb}.incident-type-badge.conspiracy{background:#9c27b026;color:#ce93d8}.incident-type-badge.sabotage{background:#ff572226;color:#ff7043}.incident-summary{font-size:.8rem;color:var(--text-primary, #ddd);flex:1;line-height:1.3}.incident-severity{font-size:.65rem;color:var(--text-secondary, #888)}.incident-status-badge{font-size:.6rem;padding:1px 6px;border-radius:6px;text-transform:uppercase;font-weight:600}.incident-status-badge.active{background:#ff525226;color:#ff5252}.incident-status-badge.investigating{background:#ffab4026;color:#ffab40}.incident-status-badge.resolved{background:#66bb6a26;color:#66bb6a}.incident-status-badge.cold{background:#90a4ae1f;color:#90a4ae}.incident-clues{margin-top:.4rem;padding-left:.75rem}.clue-item{font-size:.72rem;color:var(--text-secondary, #aaa);padding:.15rem 0;display:flex;gap:.4rem;align-items:center}.clue-item .clue-icon{font-size:.85rem;color:var(--accent, #B87333)}.clue-item.found{color:#66bb6a;text-decoration:line-through;opacity:.7}.clue-item.red-herring{color:#ff9800;font-style:italic}.social-rep-list{display:flex;flex-direction:column;gap:.4rem}.social-rep-row{display:grid;grid-template-columns:1fr auto 3fr;gap:.5rem;align-items:center;padding:.4rem .6rem;font-size:.78rem;background:#ffffff08;border-radius:6px}.rep-pc-name{font-weight:600;color:var(--text-primary, #eee)}.rep-bar{width:60px;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden;position:relative}.rep-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.rep-reason{font-size:.7rem;color:var(--text-secondary, #888);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.social-add-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem}.social-add-btn{font-size:.72rem;padding:4px 10px;border-radius:6px;background:#ffffff0f;color:var(--text-secondary, #bbb);border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .2s ease}.social-add-btn:hover{background:#b873331f;color:var(--accent, #B87333);border-color:#b8733340}.town-social-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1rem;padding:1rem}.town-social-section{background:#ffffff08;border-radius:12px;border:1px solid rgba(255,255,255,.06);padding:1rem}.town-social-section-title{font-size:.85rem;font-weight:700;color:var(--text-primary, #eee);margin-bottom:.75rem;display:flex;align-items:center;gap:.4rem}.town-social-section-title .section-icon{font-size:1.1rem}.town-social-section-title .section-count{margin-left:auto;font-size:.65rem;font-weight:400;padding:2px 8px;border-radius:8px;background:#ffffff0f;color:var(--text-secondary, #888)}.social-empty{text-align:center;padding:1.5rem;color:var(--text-secondary, #666);font-size:.8rem}.social-empty-icon{font-size:2rem;margin-bottom:.5rem;opacity:.4}.modal-form{display:flex;flex-direction:column;gap:.5rem}.modal-form label{font-size:.75rem;font-weight:600;color:var(--text-secondary, #aaa);margin-top:.25rem}.modal-form .form-input,.modal-form .form-select{width:100%}@keyframes social-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.social-rel-card,.social-mem-card,.social-faction-card,.social-incident-card{animation:social-slide-in .3s ease forwards}.bld-panel{padding:1rem}.bld-summary-bar{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem;padding:.6rem 1rem;background:#ffffff0a;border-radius:10px;border:1px solid rgba(255,255,255,.06)}.bld-stat{font-size:.78rem;color:var(--text-secondary, #999)}.bld-stat strong{color:var(--text-primary, #eee)}.bld-stat-warn strong{color:#ffab40}.bld-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:.75rem;margin-bottom:1rem}.bld-card{background:#ffffff0a;border-radius:12px;border:1px solid rgba(255,255,255,.08);padding:.75rem;transition:all .25s ease;animation:bld-slide-in .3s ease forwards}.bld-card:hover{background:#ffffff12;border-color:#b8733333}.bld-card[data-status=destroyed]{opacity:.5;border-color:#ff525233}.bld-card[data-status=damaged]{border-color:#ff980040}.bld-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.bld-card-icon{font-size:1.4rem;flex-shrink:0}.bld-card-info{flex:1;min-width:0}.bld-card-name{font-weight:700;font-size:.88rem;color:var(--text-primary, #eee);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bld-card-type{font-size:.68rem;color:var(--text-secondary, #999);text-transform:capitalize}.bld-status-badge{font-size:.6rem;padding:1px 7px;border-radius:8px;text-transform:capitalize;font-weight:600;white-space:nowrap}.bld-card-actions{display:flex;gap:.2rem;opacity:0;transition:opacity .2s}.bld-card:hover .bld-card-actions{opacity:1}.bld-action-btn{background:none;border:none;cursor:pointer;font-size:.75rem;padding:2px 4px;border-radius:4px;transition:background .2s}.bld-action-btn:hover{background:#ffffff1a}.bld-card-desc{font-size:.73rem;color:var(--text-secondary, #aaa);line-height:1.4;margin-bottom:.5rem;padding-left:.3rem}.bld-progress-wrap{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.bld-progress-bar{flex:1;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.bld-progress-fill{height:100%;background:linear-gradient(90deg,#ffab40,#ff9100);border-radius:3px;transition:width .4s ease}.bld-progress-label{font-size:.65rem;color:var(--text-secondary, #888);white-space:nowrap}.bld-rooms-section{margin-top:.5rem;padding-top:.4rem;border-top:1px solid rgba(255,255,255,.06)}.bld-rooms-title,.bld-residents-title{font-size:.7rem;font-weight:600;color:var(--text-secondary, #aaa);margin-bottom:.3rem;display:flex;align-items:center;gap:.3rem}.bld-count{font-size:.6rem;padding:1px 6px;border-radius:6px;background:#ffffff0f;color:var(--text-secondary, #888);font-weight:400}.bld-rooms-list{display:flex;flex-wrap:wrap;gap:.3rem}.bld-room-chip{display:inline-flex;align-items:center;gap:.2rem;font-size:.68rem;padding:2px 8px;border-radius:10px;background:#ffffff0f;color:var(--text-secondary, #bbb);border:1px solid rgba(255,255,255,.08);transition:all .2s}.bld-room-chip:hover{background:#b873331a;border-color:#b8733333}.bld-room-name{cursor:pointer}.bld-room-del{background:none;border:none;color:var(--text-secondary, #888);cursor:pointer;font-size:.8rem;line-height:1;padding:0 1px;opacity:0;transition:opacity .2s}.bld-room-chip:hover .bld-room-del{opacity:1}.bld-room-del:hover{color:#ff5252}.bld-residents-section{margin-top:.5rem;padding-top:.4rem;border-top:1px solid rgba(255,255,255,.06)}.bld-residents-list{display:flex;flex-wrap:wrap;gap:.3rem}.bld-resident-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.68rem;padding:2px 8px;border-radius:10px;background:#66bb6a14;color:#a5d6a7;border:1px solid rgba(102,187,106,.15);transition:all .2s}.bld-resident-badge:hover{background:#66bb6a24}.bld-resident-detail{font-size:.6rem;color:var(--text-secondary, #888)}.bld-resident-remove{background:none;border:none;color:var(--text-secondary, #888);cursor:pointer;font-size:.8rem;line-height:1;padding:0 1px;opacity:0;transition:opacity .2s}.bld-resident-badge:hover .bld-resident-remove{opacity:1}.bld-resident-remove:hover{color:#ff5252}.bld-no-residents{font-size:.68rem;color:var(--text-secondary, #666);font-style:italic}.bld-card-footer{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.5rem;padding-top:.4rem;border-top:1px solid rgba(255,255,255,.06)}.bld-unassigned-section{background:#ffab400d;border:1px solid rgba(255,171,64,.12);border-radius:10px;padding:.75rem;margin-bottom:1rem}.bld-section-title{font-size:.8rem;font-weight:700;color:var(--text-primary, #eee);margin-bottom:.5rem;display:flex;align-items:center;gap:.3rem}.bld-unassigned-list{display:flex;flex-wrap:wrap;gap:.3rem}.bld-char-badge{font-size:.68rem;padding:2px 8px;border-radius:10px;background:#ffffff0f;color:var(--text-secondary, #bbb);border:1px solid rgba(255,255,255,.08);cursor:default}.bld-add-bar{display:flex;gap:.5rem;margin-top:.5rem}.bld-empty{text-align:center;padding:2rem;color:var(--text-secondary, #666);font-size:.82rem;grid-column:1 / -1}.bld-empty-icon{font-size:2.5rem;margin-bottom:.5rem;opacity:.35}@keyframes bld-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.levelup-wizard{min-height:350px;display:flex;flex-direction:column}.levelup-step{flex:1;padding:.25rem 0}.levelup-step h3{font-size:1rem;color:var(--accent, #B87333);margin:0 0 .75rem;border-bottom:1px solid rgba(184,115,51,.15);padding-bottom:.4rem}.levelup-sublabel{font-size:.75rem;color:var(--text-secondary, #aaa);font-weight:400}.levelup-current-classes{font-size:.8rem;color:var(--text-secondary);margin-bottom:1rem;padding:.5rem .75rem;background:#ffffff08;border-radius:6px;border-left:3px solid var(--accent)}.levelup-class-section{margin-bottom:1rem}.levelup-section-title{font-size:.78rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.5px}.levelup-class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem}.levelup-class-card{padding:.6rem .8rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;transition:all .2s ease}.levelup-class-card:hover{border-color:#b873334d;background:#b873330d;transform:translateY(-1px)}.levelup-class-card.selected{border-color:var(--accent);background:#b873331a;box-shadow:0 0 12px #b8733326}.levelup-class-card.new{border-style:dashed}.levelup-class-card.prestige{border-color:#9370db33}.levelup-class-card.prestige.selected{border-color:#9370db;background:#9370db1a}.levelup-class-card.ineligible{opacity:.4;cursor:not-allowed}.class-card-name{font-weight:600;font-size:.85rem;color:var(--text-primary)}.class-card-info{font-size:.68rem;color:var(--text-secondary);margin-top:.15rem}.class-card-missing{font-size:.62rem;color:#ff5252;margin-top:.2rem}.levelup-hp-display{display:flex;gap:1.5rem;align-items:center;justify-content:center;padding:1.5rem;background:#ffffff08;border-radius:12px;margin-bottom:1rem}.hp-roll-result{text-align:center}.hp-roll-result.total .hp-die{color:var(--accent);font-size:2rem}.hp-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;margin-bottom:.3rem}.hp-die{font-size:1.5rem;font-weight:700;color:var(--text-primary);min-width:40px}.levelup-hp-actions{text-align:center;margin-bottom:1rem}.levelup-hp-result{text-align:center;font-size:.9rem;color:var(--text-secondary);padding:.75rem;background:#b873330d;border-radius:8px;border:1px solid rgba(184,115,51,.15)}.levelup-hp-result strong{color:var(--accent);font-size:1.2rem;margin-left:.5rem}.levelup-skill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:.5rem .75rem;background:#ffffff08;border-radius:8px}.skill-points-remaining{font-weight:600;color:#ff9800}.skill-points-remaining.done{color:#66bb6a}.levelup-skill-list{max-height:320px;overflow-y:auto;border:1px solid rgba(255,255,255,.06);border-radius:8px}.levelup-skill-row{display:flex;align-items:center;padding:.35rem .6rem;font-size:.78rem;border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s}.levelup-skill-row:hover{background:#ffffff08}.levelup-skill-row.class-skill{background:#b8733308}.skill-name{flex:1;color:var(--text-primary)}.levelup-skill-row.class-skill .skill-name{color:var(--accent)}.skill-ranks{width:60px;text-align:center;color:var(--text-secondary);font-family:monospace}.skill-buttons{display:flex;gap:.25rem}.skill-btn{width:24px;height:24px;border-radius:4px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:var(--text-primary);cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:all .15s}.skill-btn:hover:not(:disabled){background:#b8733326;border-color:var(--accent)}.skill-btn:disabled{opacity:.25;cursor:not-allowed}.levelup-feat-section{margin-bottom:1rem;padding:.75rem;background:#ffffff08;border-radius:8px}.levelup-ability-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;margin-top:.5rem}.levelup-ability-card{padding:.5rem;text-align:center;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;transition:all .2s}.levelup-ability-card:hover{border-color:#b873334d}.levelup-ability-card.selected{border-color:var(--accent);background:#b873331a}.ability-name{font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.ability-val{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-top:.2rem}.levelup-ability-card.selected .ability-val{color:var(--accent)}.feat-benefit{font-size:.72rem;color:var(--text-secondary);margin-top:.5rem;padding:.4rem .6rem;background:#ffffff08;border-radius:4px;border-left:2px solid var(--accent)}.levelup-features-list{display:flex;flex-direction:column;gap:.3rem;margin-top:.4rem}.feature-item{font-size:.78rem;color:var(--text-primary);padding:.3rem .5rem;background:#66bb6a0f;border-radius:4px;border-left:2px solid #66bb6a}.levelup-spell-info{display:grid;grid-template-columns:auto 1fr;gap:.3rem 1rem;padding:.6rem .8rem;background:#ffffff08;border-radius:8px;font-size:.8rem}.spell-info-label{color:var(--text-secondary);font-weight:600}.spell-info-value{color:var(--text-primary)}.levelup-spell-slots{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.4rem}.spell-slot-box{text-align:center;padding:.5rem .75rem;background:#9370db14;border:1px solid rgba(147,112,219,.2);border-radius:8px;min-width:55px}.spell-slot-box.new{border-color:var(--accent);background:#b8733314;animation:pulse-gold 1.5s ease-in-out infinite}.slot-level{font-size:.65rem;color:var(--text-secondary);text-transform:uppercase}.slot-count{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.spell-slot-box.new .slot-count{color:var(--accent);font-size:.75rem}.levelup-summary{display:flex;flex-direction:column;gap:.5rem}.summary-section{display:flex;align-items:center;padding:.5rem .75rem;background:#ffffff08;border-radius:6px;border-left:3px solid rgba(184,115,51,.3)}.summary-title{font-size:.78rem;font-weight:600;color:var(--text-secondary);min-width:100px}.summary-value{font-size:.85rem;color:var(--text-primary);font-weight:500}.levelup-nav{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.06)}.levelup-progress{display:flex;gap:.4rem}.levelup-step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;background:#ffffff0f;color:var(--text-secondary);border:1px solid rgba(255,255,255,.1);transition:all .2s}.levelup-step-dot.active{background:#b8733333;color:var(--accent);border-color:var(--accent);box-shadow:0 0 8px #b8733333}.levelup-step-dot.done{background:#66bb6a26;color:#66bb6a;border-color:#66bb6a}.levelup-nav-buttons{display:flex;gap:.5rem}.spell-panel{padding:.5rem}.spell-level-group{margin-bottom:.75rem}.spell-level-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem .6rem;background:#9370db14;border-radius:6px;margin-bottom:.4rem}.spell-level-label{font-size:.78rem;font-weight:600;color:#b39ddb}.spell-slot-tracker{display:flex;gap:.25rem}.spell-slot-pip{width:14px;height:14px;border-radius:50%;border:2px solid #9370db;background:transparent;cursor:pointer;transition:all .15s}.spell-slot-pip.filled{background:#9370db}.spell-slot-pip.used{background:#ff525299;border-color:#ff5252}.spell-card{display:flex;align-items:center;padding:.35rem .6rem;border-radius:4px;font-size:.78rem;background:#ffffff08;margin-bottom:.2rem;transition:background .15s}.spell-card:hover{background:#ffffff0f}.spell-card.used{opacity:.5;text-decoration:line-through}.spell-card.domain{border-left:2px solid #B87333}.spell-card.metamagic{border-left:2px solid #9370db}.spell-name{flex:1;color:var(--text-primary)}.spell-school{font-size:.65rem;color:var(--text-secondary);margin-left:.5rem}.spell-actions{display:flex;gap:.25rem}.conditions-panel{padding:.5rem}.effect-card{display:flex;align-items:center;padding:.5rem .7rem;background:#ffffff08;border-radius:6px;margin-bottom:.35rem;border-left:3px solid rgba(255,255,255,.1);transition:all .2s}.effect-card.buff{border-left-color:#66bb6a;background:#66bb6a0a}.effect-card.debuff,.effect-card.condition{border-left-color:#ff5252;background:#ff52520a}.effect-name{flex:1;font-size:.8rem;font-weight:600;color:var(--text-primary)}.effect-duration{font-size:.7rem;color:var(--text-secondary);margin:0 .5rem}.effect-mods{font-size:.65rem;color:var(--accent);font-family:monospace}.effect-remove{cursor:pointer;color:var(--text-secondary);font-size:.8rem;margin-left:.5rem;opacity:.6;transition:opacity .15s}.effect-remove:hover{opacity:1;color:#ff5252}.encumbrance-widget{padding:.5rem .75rem;background:#ffffff08;border-radius:8px;margin-top:.5rem}.encumbrance-label{font-size:.72rem;color:var(--text-secondary);display:flex;justify-content:space-between;margin-bottom:.3rem}.encumbrance-bar{height:8px;background:#ffffff0f;border-radius:4px;overflow:hidden;position:relative}.encumbrance-fill{height:100%;border-radius:4px;transition:width .3s ease,background .3s ease}.encumbrance-fill.light{background:#66bb6a}.encumbrance-fill.medium{background:#ff9800}.encumbrance-fill.heavy{background:#ff5252}.encumbrance-fill.overloaded{background:#b71c1c}.encumbrance-tiers{display:flex;justify-content:space-between;font-size:.6rem;color:var(--text-secondary);margin-top:.2rem}.encumbrance-effects{font-size:.68rem;color:var(--text-secondary);margin-top:.3rem;padding:.3rem .5rem;background:#ffffff08;border-radius:4px}@keyframes pulse-gold{0%,to{box-shadow:0 0 4px #b873331a}50%{box-shadow:0 0 12px #b873334d}}.levelup-xp-penalty{margin-top:.75rem;padding:.6rem .8rem;background:#ff980014;border:1px solid rgba(255,152,0,.3);border-left:3px solid #ff9800;border-radius:6px;font-size:.78rem;color:#ffcc80;animation:fadeSlideIn .3s ease}.metamagic-btn{background:#9370db1f;border:1px solid rgba(147,112,219,.3);color:#b39ddb;font-size:.68rem;padding:.15rem .4rem;border-radius:4px;cursor:pointer;transition:all .2s;white-space:nowrap}.metamagic-btn:hover{background:#9370db40;border-color:#9370db;transform:scale(1.05)}.metamagic-tag{font-size:.6rem;padding:.1rem .35rem;border-radius:3px;background:#9370db26;color:#b39ddb;font-style:italic;margin-left:.3rem;white-space:nowrap}.metamagic-modal-content{padding:.5rem 0}.metamagic-combo-card{display:flex;align-items:center;justify-content:space-between;padding:.6rem .8rem;margin-bottom:.4rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:8px;cursor:pointer;transition:all .2s}.metamagic-combo-card:hover{border-color:#9370db66;background:#9370db0f;transform:translate(2px)}.metamagic-combo-card.selected{border-color:#9370db;background:#9370db1f;box-shadow:0 0 10px #9370db26}.metamagic-combo-feats{font-weight:600;font-size:.82rem;color:var(--text-primary)}.metamagic-combo-detail{font-size:.7rem;color:var(--text-secondary);margin-top:.15rem}.metamagic-combo-slot{font-size:.85rem;font-weight:700;color:#b39ddb;min-width:50px;text-align:right}.metamagic-effects-preview{margin-top:.75rem;padding:.6rem;background:#9370db0f;border:1px solid rgba(147,112,219,.15);border-radius:6px;font-size:.75rem;color:var(--text-secondary)}.metamagic-effects-preview strong{color:#b39ddb}.metamagic-known-section{margin-top:1rem;padding:.6rem .8rem;background:#9370db0a;border:1px solid rgba(147,112,219,.1);border-radius:8px}.metamagic-known-title{font-size:.72rem;font-weight:600;color:#b39ddb;text-transform:uppercase;letter-spacing:.4px;margin-bottom:.4rem}.metamagic-feat-badge{display:inline-block;padding:.2rem .5rem;margin:.15rem;border-radius:12px;font-size:.7rem;background:#9370db1f;border:1px solid rgba(147,112,219,.25);color:var(--text-primary)}.metamagic-feat-badge .meta-slot{font-size:.6rem;color:var(--text-secondary);margin-left:.3rem}.ai-levelup-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;gap:1rem}.ai-levelup-spinner{width:48px;height:48px;border:3px solid rgba(184,115,51,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.ai-levelup-text{font-size:.85rem;color:var(--text-secondary);text-align:center}.ai-levelup-diff{display:flex;flex-direction:column;gap:.4rem;max-height:400px;overflow-y:auto}.ai-diff-row{display:flex;align-items:center;padding:.45rem .7rem;background:#ffffff08;border-radius:6px;font-size:.8rem}.ai-diff-label{min-width:100px;font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase}.ai-diff-old{color:var(--text-secondary);text-decoration:line-through;opacity:.6;margin-right:.5rem}.ai-diff-arrow{color:var(--accent);margin:0 .4rem;font-weight:600}.ai-diff-new{color:var(--accent);font-weight:600}.ai-diff-row.changed{border-left:3px solid var(--accent);background:#b873330a}.ai-levelup-summary{margin-top:1rem;padding:.75rem;background:#66bb6a0f;border:1px solid rgba(102,187,106,.2);border-radius:8px;font-size:.78rem;color:var(--text-primary);white-space:pre-line}.ai-levelup-summary strong{color:#66bb6a}.ai-levelup-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.06)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.level-history-list{display:flex;flex-direction:column;gap:.3rem;max-height:200px;overflow-y:auto}.level-history-item{display:flex;align-items:center;padding:.35rem .6rem;background:#ffffff08;border-radius:4px;font-size:.75rem;border-left:2px solid rgba(184,115,51,.2)}.level-history-num{min-width:28px;font-weight:700;color:var(--accent);font-size:.8rem}.level-history-class{flex:1;color:var(--text-primary)}.level-history-detail{color:var(--text-secondary);font-size:.68rem}.cs-spell-castable{cursor:pointer;-webkit-user-select:none;user-select:none}.cs-spell-castable:hover{background:#9370db0f}.cs-spell-castable.cs-spell-used{opacity:.55}.cs-spell-castable.cs-spell-used:hover{opacity:.8;background:#66bb6a0f}.cs-spell-header{display:grid;grid-template-columns:32px 1fr 40px;gap:.3rem;padding:.3rem .5rem;font-size:.65rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:.25rem}.cs-spell-level-row{display:grid;grid-template-columns:32px 1fr 40px;gap:.3rem;padding:.3rem .5rem;align-items:center;border-radius:4px;transition:background .15s}.cs-spell-level-row:hover{background:#ffffff08}.cs-spell-level-row.cs-spell-depleted{background:#ff52520a}.cs-spell-level-row.cs-spell-unavail{opacity:.35}.cs-spell-lvl{font-weight:700;color:#b39ddb;font-size:.85rem;text-align:center}.cs-spell-pips{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.cs-spell-dc{font-size:.75rem;color:var(--text-secondary);text-align:center;font-family:monospace}.spell-pip-row{display:flex;gap:3px;flex-wrap:wrap}.spell-pip{width:12px;height:12px;border-radius:50%;display:inline-block;transition:all .2s ease;cursor:default}.spell-pip-filled{background:#9370db;border:2px solid #b39ddb;box-shadow:0 0 4px #9370db4d}.spell-pip-used{background:#ff525240;border:2px solid rgba(255,82,82,.5)}.spell-pip-count{font-size:.65rem;color:var(--text-secondary);font-family:monospace;margin-left:.25rem;white-space:nowrap}.cs-spell-depleted .spell-pip-count{color:#ff5252}.spell-pip-none{font-size:.7rem;color:var(--text-secondary);opacity:.5}@media(max-width:600px){.levelup-ability-grid{grid-template-columns:repeat(3,1fr)}.levelup-class-grid{grid-template-columns:repeat(2,1fr)}.levelup-hp-display{flex-wrap:wrap}}:root{--bg-primary: #0D0815;--bg-secondary: #1A0E2E;--bg-tertiary: #2D1B4E;--bg-card: #1A0E2E;--bg-hover: #3D2A63;--bg-input: #0D0815;--text-primary: #F0E6D3;--text-secondary: #D4C5F9;--text-muted: #6B5D7A;--text-heading: #F0E6D3;--accent: #B87333;--accent-hover: #D4956A;--accent-dim: rgba(184,115,51, .15);--accent-glow: rgba(184,115,51, .3);--success: #7A9E7E;--error: #C75B3A;--warning: #D4A843;--info: #8B7EB8;--border: #2D1B4E;--border-light: #4E3A78;--border-accent: var(--accent);--sidebar-bg: #0D0815;--sidebar-width: 240px;--sidebar-collapsed: 64px;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 12px rgba(0,0,0,.5);--shadow-lg: 0 8px 24px rgba(0,0,0,.6);--shadow-glow: 0 0 20px var(--accent-glow);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-pill: 50px;--ease: cubic-bezier(.4, 0, .2, 1);--duration-fast: .15s;--duration: .25s;--duration-slow: .4s;--race-human: #C9A84C;--race-dwarf: #8A5A2B;--race-elf: #5B8A72;--race-halfling: #D4956A;--race-gnome: #8B7EB8;--race-half-elf: #5B8A72;--race-half-orc: #8A5A2B;--race-tiefling: #C75B3A;--race-orc: #5B8A72;--race-drow: #4E3A78}
