*,*: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);min-height:0}.app-content:has(>.view-scribe){overflow:hidden;display:flex;flex-direction:column}.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;text-transform:none}.sidebar-subtitle{font-size:.75rem;color:var(--text-muted);margin-top:2px}.sidebar-usage{margin-top:.5rem}.sidebar-usage-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.3rem}.sidebar-tier-badge{display:inline-block;padding:.1rem .45rem;border-radius:10px;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.sidebar-credits-display{display:flex;align-items:center;gap:.4rem;padding:.25rem 0}.sidebar-credits-icon{font-size:1rem}.sidebar-credits-value{font-size:1.1rem;font-weight:700;font-family:Inter,sans-serif}.sidebar-credits-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}.sidebar-usage-label{font-size:.6rem;color:var(--text-muted);margin-top:.2rem}.credit-balance{font-weight:600;font-size:.85rem}.admin-form-info{padding:.5rem .75rem;background:#ffffff0d;border-radius:6px;font-size:.85rem;color:var(--text-secondary);font-weight:500}.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:.5rem 0 .75rem;display:flex;flex-direction:column;gap:0;min-height:0;overflow-y:auto}.sidebar-nav-top{border-bottom:1px solid rgba(255,255,255,.06);padding-bottom:.35rem;margin-bottom:.15rem}.sidebar-nav-group{border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-nav-group:last-child{border-bottom:none}.nav-group-toggle{display:flex;align-items:center;gap:.4rem;width:100%;padding:.45rem 1rem .45rem 1.1rem;margin:0;border:none;background:transparent;color:var(--text-muted);font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;text-align:left;cursor:pointer;transition:color var(--duration-fast),background var(--duration-fast)}.nav-group-toggle:hover{color:var(--text-secondary);background:#ffffff08}.nav-group-chevron{font-size:.55rem;width:.75rem;flex-shrink:0;opacity:.85;transition:transform var(--duration-fast) var(--ease)}.sidebar-nav-group.is-collapsed .nav-group-chevron{transform:rotate(-90deg)}.nav-group-label{flex:1}.nav-group-items{display:flex;flex-direction:column;gap:1px;padding-bottom:.35rem}.sidebar-nav-group.is-collapsed .nav-group-items{display:none}.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-item--nested{padding-left:1.65rem;font-size:.86rem}.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-main{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.dash-town-food{font-size:.72rem;opacity:.9}.dash-town-name{font-weight:500}.dash-town-sub{color:var(--text-muted);font-size:.8rem;text-align:right;max-width:48%}.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)}.btn-link{background:none;border:none;color:var(--accent);cursor:pointer;font:inherit;text-decoration:underline;padding:0}.sidebar-free-ad-slot{margin:0 .75rem .75rem;min-height:70px}.sidebar-ad-placeholder{font-size:.65rem;color:var(--text-muted);padding:.5rem;border:1px dashed var(--border);border-radius:6px;line-height:1.35}[data-tip]{position:relative}[data-tip]:after{content:attr(data-tip);position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:3000;padding:.45rem .55rem;font-size:.72rem;font-weight:400;line-height:1.35;text-align:left;white-space:normal;word-break:break-word;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 6px 20px #0000006b;pointer-events:none;opacity:0;visibility:hidden;transition:none}[data-tip]:hover,[data-tip]:focus-visible{z-index:3001}[data-tip]:hover:after,[data-tip]:focus-visible:after{opacity:1;visibility:visible}.sidebar-tier-badge[data-tip]:after{left:0;right:auto;min-width:10.5rem;max-width:14rem}@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:flex;gap:.75rem;padding:.5rem;background:transparent;border-bottom:1px solid rgba(255,255,255,.1);font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center}.list-header-row>span{padding:0 .25rem}.sort-col{cursor:pointer;-webkit-user-select:none;user-select:none}.sort-col:hover{color:var(--accent)}.list-body{flex:1;overflow-y:auto;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.list-body::-webkit-scrollbar{width:6px}.list-body::-webkit-scrollbar-track{background:transparent}.list-body::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.char-row{display:flex;align-items:center;padding:.6rem .8rem;border-radius:var(--radius-sm);margin-bottom:6px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);cursor:pointer;transition:all var(--duration-fast)}.char-row .char-icon{font-size:1.4rem;margin-right:1rem;opacity:.9;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.char-row .char-info{flex:1;display:flex;flex-direction:column;gap:.2rem}.char-row .char-name{font-weight:600;font-size:.95rem;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.char-row .char-sub{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.char-row .char-meta{text-align:right;display:flex;flex-direction:column;margin-left:1rem}.char-row .meta-lbl{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.char-row .meta-val{font-size:.9rem;font-weight:600;color:var(--text-secondary)}.char-row:nth-child(odd){background:#ffffff06}.char-row:nth-child(2n){background:#ffffff04}.char-row:hover{background:var(--bg-hover);border-color:#ffffff1a}.char-row.active{background:var(--accent-dim);border-color:var(--accent)}.char-row.deceased{opacity:.5}.col-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-race{font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-class{color:var(--text-secondary);font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-hp,.col-ac,.col-lvl,.col-age,.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)}.setup-bar{border-top:1px solid var(--border);background:var(--bg-secondary);padding:.5rem .75rem}.setup-wizard{display:flex;flex-direction:column;gap:0}.setup-tabs{display:flex;flex-wrap:wrap;gap:0;border-bottom:2px solid var(--border);margin-bottom:1rem}.setup-tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--text-muted);padding:.65rem 1rem;font-size:.82rem;font-weight:500;cursor:pointer;transition:all var(--duration-fast)}.setup-tab:hover{color:var(--text-secondary);background:var(--bg-hover)}.setup-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.setup-panel{display:none;padding:0 .25rem}.setup-panel.active{display:block;animation:fadeIn .2s ease}.setup-desc{color:var(--text-muted);font-size:.8rem;margin-bottom:1rem;line-height:1.5}.setup-row{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap;margin-bottom:.75rem}.setup-info-value{font-size:.85rem;color:var(--text-secondary);background:var(--bg-tertiary);padding:.35rem .6rem;border-radius:var(--radius-sm);border:1px solid var(--border);display:inline-block;min-width:80px}.setup-actions{display:flex;gap:.5rem;margin:.75rem 0}.setup-status{font-size:.82rem;margin-top:.35rem;line-height:1.4;min-height:1.4em}.setup-building-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.5rem;max-height:300px;overflow-y:auto;padding:.25rem}.setup-building-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .65rem;transition:border-color var(--duration-fast)}.setup-building-card:hover{border-color:var(--accent-dim)}.setup-building-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem;font-size:.82rem}.setup-building-type{font-size:.7rem;color:var(--text-muted);background:var(--bg-secondary);padding:.1rem .4rem;border-radius:var(--radius-sm);text-transform:capitalize}.setup-building-desc{font-size:.75rem;color:var(--text-muted);line-height:1.4}.setup-weather-preview{max-height:400px;overflow-y:auto}.setup-weather-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;padding:.25rem}.setup-weather-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .65rem}.setup-weather-month{font-weight:600;font-size:.85rem;color:var(--text-primary);margin-bottom:.25rem}.setup-weather-temp{font-size:.8rem;color:var(--accent);margin-bottom:.15rem}.setup-weather-pattern{font-size:.78rem;color:var(--text-secondary);margin-bottom:.25rem}.setup-weather-events{display:flex;flex-direction:column;gap:.1rem}.setup-weather-event{font-size:.7rem;color:var(--text-muted);line-height:1.3}.setup-preview-list{margin-top:.5rem}.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}.import-method-row{display:flex;align-items:center;gap:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border);margin-bottom:.25rem}.import-method-label{font-size:.82rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.import-method-select{flex:1;max-width:300px}.import-hint{font-size:.72rem;color:var(--text-muted);font-style:italic}.ai-prompt-options{display:flex;gap:1rem;flex-wrap:wrap;padding:.5rem .75rem;background:#9370db0f;border:1px solid rgba(147,112,219,.15);border-radius:var(--radius-sm)}.ai-opt-row{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--text-secondary)}.ai-opt-row label{font-weight:500;white-space:nowrap}.ai-opt-row select{font-size:.78rem;padding:.25rem .5rem}.spinner-inline{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--accent);border-radius:50%;animation:spinInline .6s linear infinite;vertical-align:middle;margin-right:.35rem}@keyframes spinInline{to{transform:rotate(360deg)}}.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-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0d0815,#1a0e2e,#2d1b4e);padding:1.25rem}.landing-screen{min-height:100vh;display:flex;align-items:stretch;background:linear-gradient(135deg,#0d0815,#1a0e2e,#2d1b4e)}.landing-sidebar{width:260px;min-width:260px;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;overflow-y:auto;position:sticky;top:0;height:100vh}.landing-sidebar-brand{padding:1.5rem 1.25rem 1rem;border-bottom:1px solid var(--border)}.landing-sidebar-title{font-family:Cinzel,serif;font-size:1.4rem;color:var(--accent);margin:0;letter-spacing:.02em}.landing-sidebar-subtitle{font-size:.75rem;color:var(--text-muted);margin:4px 0 0}.landing-sidebar-nav{flex:1;padding:.75rem 0;display:flex;flex-direction:column;gap:2px}.landing-nav-item{display:flex;align-items:center;gap:.75rem;padding:.65rem 1.25rem;background:transparent;color:var(--text-secondary);font-size:.9rem;border:none;border-left:3px solid transparent;text-align:left;cursor:pointer;transition:all var(--duration-fast) var(--ease);font-family:inherit}.landing-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.landing-nav-item.active{background:var(--accent-dim);color:var(--accent);border-left-color:var(--accent);font-weight:500}.landing-nav-icon{font-size:1.1rem;width:1.5rem;text-align:center;display:inline-block}.landing-sidebar-cta{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}.landing-sidebar-cta .btn-primary,.landing-sidebar-cta .btn-secondary{width:100%}.landing-sidebar-footer{padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--border);font-size:.75rem;color:var(--text-muted)}.landing-footer-links{display:flex;gap:.5rem;align-items:center;margin-bottom:.35rem}.landing-footer-links a{color:var(--text-secondary);text-decoration:none}.landing-footer-links a:hover{color:var(--accent);text-decoration:underline}.landing-footer-meta{margin:0;font-size:.7rem}.landing-main{flex:1;min-width:0;overflow-y:auto;height:100vh;padding:2.5rem clamp(1.25rem,4vw,3rem);display:flex;flex-direction:column}.landing-section{width:min(960px,100%);margin:0 auto;animation:landingFadeIn .25s var(--ease)}.landing-section[hidden]{display:none}@keyframes landingFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.landing-eyebrow{font-size:.72rem;letter-spacing:.14em;color:var(--accent);margin:0 0 .5rem;font-weight:700;text-transform:uppercase}.landing-title{font-family:Cinzel,serif;font-size:clamp(1.8rem,3.2vw,2.6rem);line-height:1.15;margin:0 0 .6rem;color:var(--text-heading)}.landing-section-title{font-family:Cinzel,serif;font-size:clamp(1.5rem,2.6vw,2.05rem);line-height:1.2;margin:0 0 .6rem;color:var(--text-heading)}.landing-section-lead{color:var(--text-secondary);margin:0 0 1.5rem;max-width:72ch}.landing-subtitle{color:var(--text-secondary);margin:0 0 1.25rem;max-width:72ch;font-size:1.02rem;line-height:1.55}.landing-actions{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1.5rem}.landing-actions-end{margin-top:2rem;margin-bottom:0}.landing-note{margin-top:1.5rem;padding:.75rem 1rem;background:var(--accent-dim);border-left:3px solid var(--accent);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.88rem}.landing-note strong{color:var(--accent)}.landing-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.landing-feature{border:1px solid var(--border);background:var(--bg-secondary);border-radius:var(--radius-sm);padding:.85rem .95rem;display:flex;flex-direction:column;gap:.25rem}.landing-feature strong{font-size:.88rem;color:var(--text-primary)}.landing-feature span{font-size:.78rem;color:var(--text-muted);line-height:1.45}.landing-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.landing-step{display:flex;gap:1rem;align-items:flex-start;padding:1rem 1.1rem;border:1px solid var(--border);background:var(--bg-secondary);border-radius:var(--radius-md)}.landing-step-num{flex:0 0 auto;width:2.4rem;height:2.4rem;border-radius:50%;background:var(--accent);color:var(--bg-primary);font-weight:700;font-size:1.1rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-glow)}.landing-step-body h3{margin:0 0 .3rem;font-size:1.05rem;color:var(--text-heading)}.landing-step-body p{margin:0;color:var(--text-secondary);line-height:1.5;font-size:.92rem}.landing-feature-deep-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.85rem}.landing-feature-card{border:1px solid var(--border);background:var(--bg-secondary);border-radius:var(--radius-md);padding:1rem 1.1rem;transition:border-color var(--duration-fast) var(--ease),transform var(--duration-fast) var(--ease)}.landing-feature-card:hover{border-color:var(--border-light);transform:translateY(-1px)}.landing-feature-card h3{margin:0 0 .4rem;font-size:.98rem;color:var(--text-heading)}.landing-feature-card p{margin:0;font-size:.85rem;color:var(--text-secondary);line-height:1.5}.landing-editions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.landing-edition{display:flex;flex-direction:column;gap:.25rem;padding:.9rem 1rem;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-secondary)}.landing-edition.full{border-color:var(--accent);background:var(--accent-dim)}.landing-edition-name{font-family:Cinzel,serif;font-size:1.1rem;color:var(--text-heading)}.landing-edition-status{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--text-muted)}.landing-edition.full .landing-edition-status{color:var(--accent)}.landing-edition.partial .landing-edition-status{color:var(--warning)}.landing-edition small{font-size:.78rem;color:var(--text-muted)}.landing-preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.85rem}.landing-preview-card{border:1px dashed var(--border-light);background:var(--bg-secondary);border-radius:var(--radius-md);padding:1rem;display:flex;flex-direction:column;gap:.4rem}.landing-preview-thumb{width:100%;aspect-ratio:16 / 9;border-radius:var(--radius-sm);background:linear-gradient(135deg,#b8733314,#2d1b4e80),var(--bg-primary);display:flex;align-items:center;justify-content:center;font-size:2.4rem;color:var(--accent);border:1px solid var(--border);margin-bottom:.35rem}.landing-preview-card h3{margin:0;font-size:.95rem;color:var(--text-heading)}.landing-preview-card p{margin:0;font-size:.82rem;color:var(--text-muted);line-height:1.45}.landing-quote{margin:0 0 1.25rem;padding:1rem 1.25rem;border-left:3px solid var(--accent);background:var(--bg-secondary);border-radius:0 var(--radius-md) var(--radius-md) 0;font-family:Cinzel,serif;font-style:italic;font-size:1.1rem;color:var(--text-heading)}.landing-bullets{margin:0;padding-left:1.2rem;color:var(--text-secondary);line-height:1.6}.landing-bullets li+li{margin-top:.4rem}.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}@media(max-width:860px){.landing-screen{flex-direction:column}.landing-sidebar{width:100%;min-width:0;height:auto;position:static;border-right:none;border-bottom:1px solid var(--border)}.landing-sidebar-brand{padding:1rem 1.25rem .75rem}.landing-sidebar-nav{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;gap:0;padding:.25rem .5rem;border-top:1px solid var(--border);scrollbar-width:thin}.landing-nav-item{flex:0 0 auto;padding:.55rem .85rem;border-left:none;border-bottom:3px solid transparent;white-space:nowrap}.landing-nav-item.active{border-left-color:transparent;border-bottom-color:var(--accent)}.landing-sidebar-cta{flex-direction:row;padding:.75rem 1.25rem;border-top:1px solid var(--border)}.landing-sidebar-cta .btn-primary,.landing-sidebar-cta .btn-secondary{flex:1}.landing-sidebar-footer{display:none}.landing-main{height:auto;padding:1.5rem 1.25rem 2rem}}@media(max-width:540px){.landing-actions .btn-primary,.landing-actions .btn-secondary{width:100%}.landing-step{flex-direction:column;gap:.6rem}}.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 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}.enc-combat-zone-actions{display:flex;gap:.3rem;align-items:center}.enc-hp-minus,.enc-hp-plus{min-width:26px;text-align:center;font-weight:700;font-family:var(--font-mono)}.enc-cr-panel{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;margin-top:1rem}.enc-cr-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.enc-cr-header h3{margin:0;font-size:.9rem}.enc-cr-body{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:700px){.enc-cr-body{grid-template-columns:1fr}}.enc-cr-add-row{display:flex;gap:.3rem;align-items:center;margin-bottom:.5rem}.enc-cr-select{flex:1;font-size:.75rem!important;padding:.25rem .35rem!important}.enc-cr-count{width:50px!important;text-align:center;font-size:.75rem!important;padding:.25rem .2rem!important}.enc-cr-list{max-height:180px;overflow-y:auto}.enc-cr-entry{display:flex;align-items:center;gap:.4rem;padding:.25rem .4rem;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);margin-bottom:.2rem;font-size:.75rem}.enc-cr-entry-label{flex:1;font-weight:600}.enc-cr-entry-xp{color:var(--accent);font-family:var(--font-mono);font-weight:700}.enc-cr-empty{text-align:center;padding:.75rem;font-size:.75rem;color:var(--text-muted);font-style:italic}.enc-cr-summary{display:flex;flex-direction:column;gap:.5rem;justify-content:center}.enc-cr-total,.enc-cr-per-member{display:flex;align-items:baseline;gap:.4rem;font-size:.8rem}.enc-cr-total strong,.enc-cr-per-member strong{font-size:1.1rem;color:var(--accent);font-family:var(--font-mono)}.enc-cr-party-count{font-size:.65rem;color:var(--text-muted)}#enc-award-xp-btn{margin-top:.5rem;font-size:.85rem;padding:.5rem 1rem}#enc-award-xp-btn:disabled{opacity:.4;cursor:not-allowed}.enc-cr-auto-label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.3rem}.enc-cr-manual-section{margin-top:.75rem;padding-top:.5rem;border-top:1px solid var(--border)}.enc-cr-manual-label{font-size:.65rem;color:var(--text-muted);margin-bottom:.3rem}.enc-party-picker{display:flex;flex-direction:column;gap:.3rem}.enc-party-pick-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all .15s;font-size:.8rem}.enc-party-pick-item:hover{background:var(--surface-2);border-color:var(--accent)}.enc-party-pick-name{font-weight:600;flex:1}.enc-party-pick-detail{font-size:.7rem;color:var(--text-muted)}.enc-party-pick-stats{font-size:.7rem;color:var(--text-secondary)}.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}.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)}.cc-root{display:flex;flex-direction:column;height:100%;background:#1a0a0a;color:#e8dcc8;font-family:inherit}.cc-title-bar{text-align:center;padding:.6rem;font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;background:linear-gradient(180deg,#2a1010,#1a0808);border-bottom:1px solid #4a2020;color:#e8dcc8;font-variant:small-caps}.cc-summary-bar{display:flex;flex-wrap:wrap;gap:2px;padding:4px 6px;background:#0e0606;border-bottom:1px solid #3a1818}.cc-sum-item{flex:1;min-width:70px;background:#1a0e0e;border:1px solid #3a1818;padding:3px 6px;text-align:center}.cc-sum-lbl{display:block;font-size:.55rem;text-transform:uppercase;letter-spacing:1px;color:#876;font-weight:600}.cc-sum-val{display:block;font-size:.78rem;font-weight:700;color:#d4c4a0}.cc-sum-done .cc-sum-val{color:#50c878}.cc-three-col{display:grid;grid-template-columns:180px 1fr 1fr;flex:1;overflow:hidden}.cc-nav-col{display:flex;flex-direction:column;gap:6px;padding:10px 8px;background:#120808;border-right:1px solid #3a1818;overflow-y:auto}.cc-nav-btn{background:linear-gradient(180deg,#6b1a1a,#3a0e0e);border:2px solid #8b3030;border-radius:8px;color:#e8dcc8;font-size:.82rem;font-weight:700;padding:10px 12px;cursor:pointer;text-transform:uppercase;letter-spacing:1px;font-variant:small-caps;font-family:inherit;transition:all .15s;box-shadow:inset 0 1px #ff969626,inset 0 -2px 4px #0006;text-shadow:0 1px 2px rgba(0,0,0,.6)}.cc-nav-btn:hover{background:linear-gradient(180deg,#8b2a2a,#5a1818);border-color:#b04040}.cc-nav-btn.active{background:linear-gradient(180deg,#a03030,#6b1a1a);border-color:#cc5050;box-shadow:inset 0 1px #ffb4b433,0 0 8px #c83c3c4d}.cc-nav-spacer{flex:1}.cc-nav-cancel{background:linear-gradient(180deg,#2a3a5a,#1a2540);border-color:#4a5a7a}.cc-nav-cancel:hover{background:linear-gradient(180deg,#3a4a6a,#2a3550)}.cc-nav-play{background:linear-gradient(180deg,#4a3020,#2a1a10);border-color:#7a5030}.cc-nav-play:hover{background:linear-gradient(180deg,#5a4030,#3a2a20)}.cc-nav-play:disabled{opacity:.4;cursor:not-allowed}.cc-select-col{padding:.8rem;overflow-y:auto;background:#1e0e0e;border-right:1px solid #3a1818}.cc-sec-title{margin:0 0 .6rem;font-size:.95rem;color:#d4a060;font-variant:small-caps;letter-spacing:1px;border-bottom:1px solid #3a1818;padding-bottom:.4rem}.cc-sel-list{display:flex;flex-direction:column;gap:4px}.cc-sel-item{background:linear-gradient(180deg,#5a1818,#3a0e0e);border:2px solid #7a2828;border-radius:6px;color:#e8dcc8;padding:8px 12px;font-size:.82rem;font-family:inherit;cursor:pointer;text-align:left;display:flex;justify-content:space-between;align-items:center;transition:all .12s;box-shadow:inset 0 1px #ff78781a}.cc-sel-item:hover{background:linear-gradient(180deg,#7a2828,#5a1818);border-color:#a04040}.cc-sel-item.selected{background:linear-gradient(180deg,#a03030,#6b1a1a);border-color:#cc5050;box-shadow:inset 0 1px #ffb4b433,0 0 6px #c83c3c40}.cc-sel-sub{font-size:.72rem;color:#a88}.cc-sel-empty{padding:2rem 1rem;text-align:center;color:#876}.cc-sel-info{padding:.8rem;color:#a98;font-size:.82rem;line-height:1.5}.cc-detail-col{padding:.8rem;overflow-y:auto;background:#160a0a}.cc-det-title{margin:0 0 .6rem;font-size:.95rem;color:#d4a060;font-variant:small-caps;letter-spacing:1px;border-bottom:1px solid #3a1818;padding-bottom:.4rem}.cc-det-body{font-size:.82rem;line-height:1.5}.cc-det-body p{color:#a98;margin:0 0 .6rem}.cc-det-row{display:flex;justify-content:space-between;padding:.25rem 0;border-bottom:1px solid rgba(60,30,30,.4);font-size:.82rem}.cc-det-row span{color:#876}.cc-det-row strong{color:#d4c4a0}.cc-det-field{margin:.8rem 0}.cc-det-field label{display:block;font-size:.75rem;color:#876;margin-bottom:.25rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.cc-det-input{width:100%;background:#1a0e0e;border:1px solid #4a2020;color:#e8dcc8;padding:.4rem .6rem;border-radius:4px;font-size:.85rem;font-family:inherit}.cc-det-input:focus{border-color:#cc5050;outline:none}textarea.cc-det-input{resize:vertical}.cc-det-desc{margin:.8rem 0;background:#501e1e26;border:1px solid #3a1818;border-radius:6px;padding:.6rem}.cc-det-desc h4{margin:0 0 .3rem;font-size:.82rem;color:#d4a060}.cc-det-desc p{font-size:.78rem;margin:0;color:#987;line-height:1.5}.cc-filter-row{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center;margin-bottom:.5rem}.cc-checkbox{display:flex;align-items:center;gap:.3rem;font-size:.78rem;color:#876;cursor:pointer}.cc-checkbox input[type=checkbox]{accent-color:#cc5050}.cc-method-toggle{display:flex;gap:4px;margin-bottom:.5rem}.cc-method-btn{background:#2a1010;border:1px solid #4a2020;color:#876;padding:.3rem .8rem;font-size:.78rem;cursor:pointer;border-radius:4px;font-family:inherit;transition:all .15s}.cc-method-btn.active{background:#c83c3c26;border-color:#cc5050;color:#cc5050;font-weight:600}.cc-points-bar{font-size:.82rem;color:#876;margin-bottom:.5rem}.cc-ability-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.cc-ability-card{background:#0000004d;border:1px solid #3a1818;border-radius:6px;padding:.5rem;text-align:center}.cc-ab-label{font-weight:700;font-size:.75rem;color:#cc5050;letter-spacing:1px;margin-bottom:.3rem}.cc-ab-btn{width:24px;height:24px;border:1px solid #4a2020;background:#2a1010;color:#e8dcc8;border-radius:4px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center}.cc-ab-btn:hover:not(:disabled){border-color:#cc5050;color:#cc5050}.cc-ab-input{width:36px;text-align:center;background:#1a0e0e;border:1px solid #4a2020;color:#e8dcc8;border-radius:4px;font-size:.9rem;font-family:inherit;padding:2px}.cc-ab-race{font-size:.7rem;color:#876;margin-top:2px}.cc-ab-total{font-size:1.1rem;font-weight:700;color:#e8dcc8}.cc-ab-mod{font-size:.75rem;color:#876;margin-left:4px}.cc-ab-cost{font-size:.65rem;color:#876}.cc-stat-box{background:#0000004d;border:1px solid #3a1818;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:#876}.cc-stat-val{font-size:1rem;font-weight:700;color:#e8dcc8}.cc-stat-detail{font-size:.6rem;color:#876}.cc-stat-hp{border-color:#c8282866}.cc-stat-hp .cc-stat-val{color:#c33}.cc-skills-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.cc-skills-hint{font-size:.7rem;color:#876;margin-left:.5rem}.cc-skills-table{border:1px solid #3a1818;border-radius:6px;overflow:hidden;max-height:400px;overflow-y:auto}.cc-skill-header-row{display:grid;grid-template-columns:2fr 50px 40px 90px 50px;padding:.3rem .6rem;background:#0000004d;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#876;border-bottom:1px solid #3a1818;position:sticky;top:0;z-index:1}.cc-skill-row{display:grid;grid-template-columns:2fr 50px 40px 90px 50px;padding:.25rem .6rem;font-size:.78rem;border-bottom:1px solid rgba(60,30,30,.3);align-items:center;transition:background .1s}.cc-skill-row:hover{background:#c83c3c0d}.cc-skill-class{background:#c83c3c05}.cc-skill-active{background:#c83c3c14!important}.cc-skill-isclass{color:#cc5050;font-size:.7rem}.cc-sk-btn{width:20px;height:20px;border:1px solid #4a2020;background:#2a1010;color:#e8dcc8;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:#cc5050;color:#cc5050}.cc-feats-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.cc-feat-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.5rem}.cc-feat-tag{background:#c83c3c1f;border:1px solid rgba(200,60,60,.3);color:#cc5050;padding:.15rem .5rem;border-radius:12px;font-size:.75rem;display:flex;align-items:center;gap:.3rem}.cc-feat-remove{background:none;border:none;color:#cc5050;cursor:pointer;font-size:.7rem;padding:0;opacity:.6}.cc-feats-table{border:1px solid #3a1818;border-radius:6px;overflow:hidden;max-height:350px;overflow-y:auto}.cc-feat-header-row{display:grid;grid-template-columns:1fr 80px 40px;padding:.3rem .6rem;background:#0000004d;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#876;border-bottom:1px solid #3a1818;position:sticky;top:0;z-index:1}.cc-feat-row{display:grid;grid-template-columns:1fr 80px 40px;padding:.25rem .6rem;font-size:.78rem;border-bottom:1px solid rgba(60,30,30,.3);align-items:center;transition:background .1s;cursor:pointer}.cc-feat-row:hover{background:#c83c3c0d}.cc-feat-selected{background:#c83c3c14!important}.cc-feat-type{font-size:.72rem;color:#876}.cc-feat-check{color:#cc5050;font-weight:700}.cc-feat-add-btn{width:24px;height:24px;border:1px solid #cc5050;background:transparent;color:#cc5050;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:#c83c3c26}.text-danger{color:#f55!important}.text-success{color:#50c878!important}.text-muted{color:#876}.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-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-apprentice{background:linear-gradient(135deg,#0e7490,#155e75);color:#67e8f9}.tier-adventurer{background:linear-gradient(135deg,#065f46,#064e3b);color:#6ee7b7}.tier-guild_master{background:linear-gradient(135deg,#4c1d95,#3b0764);color:#c4b5fd}.tier-world_builder{background:linear-gradient(135deg,#92400e,#78350f);color:#fbbf24}.tier-limit{font-size:.8rem;color:var(--text-muted, #888)}.tier-catalog-details{margin-top:1rem;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:#00000026;padding:.5rem .75rem .75rem}.tier-catalog-summary{cursor:pointer;font-size:.85rem;font-weight:600;color:var(--text-secondary, #cbd5e1);list-style-position:outside}.tier-catalog-note{font-size:.72rem;color:var(--text-muted, #94a3b8);margin:.5rem 0 .65rem;line-height:1.45}.tier-catalog-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.tier-catalog-table{width:100%;border-collapse:collapse;font-size:.75rem}.tier-catalog-table th,.tier-catalog-table td{padding:.35rem .5rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.06)}.tier-catalog-table th{color:var(--text-muted, #94a3b8);font-weight:600;white-space:nowrap}.tier-catalog-tier .tier-badge{font-size:.65rem}.tier-catalog-row-current{background:#6366f11f}.tier-catalog-row-current td{border-bottom-color:#6366f133}.tier-includes-wrap{margin-top:.75rem;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:#0000001f;padding:.5rem .75rem .75rem}.tier-includes-stack{display:flex;flex-direction:column;gap:.35rem}.tier-includes-one{border-radius:6px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;padding:.15rem .5rem}.tier-includes-one-current{border-color:#6366f159;background:#6366f114}.tier-includes-summary{cursor:pointer;font-size:.8rem;font-weight:600;color:var(--text-secondary, #cbd5e1);list-style-position:outside}.tier-includes-ul{margin:.35rem 0 .5rem 1.1rem;padding:0;font-size:.72rem;line-height:1.45;color:var(--text-muted, #94a3b8)}.tier-includes-ul li{margin-bottom:.25rem}.usage-meter-card{margin-top:1rem;padding:.85rem 1rem;background:#0003;border:1px solid rgba(255,255,255,.08);border-radius:8px}.usage-meter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.usage-meter-title{font-size:.82rem;font-weight:600;color:var(--text-primary, #eee)}.usage-meter-period{font-size:.7rem;color:var(--text-muted, #888);font-family:monospace}.usage-bar-container{margin-bottom:.5rem}.usage-bar-track{width:100%;height:10px;background:#ffffff0f;border-radius:5px;overflow:hidden}.usage-bar-fill{height:100%;border-radius:5px;transition:width .8s ease,background .5s ease;box-shadow:0 0 8px #0000004d}.usage-bar-fill.usage-good{box-shadow:0 0 8px #22c55e40}.usage-bar-fill.usage-moderate{box-shadow:0 0 8px #eab30840}.usage-bar-fill.usage-warning{box-shadow:0 0 8px #f59e0b59}.usage-bar-fill.usage-critical{box-shadow:0 0 12px #ef444466;animation:usage-pulse 2s ease-in-out infinite}@keyframes usage-pulse{0%,to{opacity:1}50%{opacity:.75}}.usage-bar-labels{display:flex;justify-content:space-between;align-items:center;margin-top:.35rem;font-size:.72rem}.usage-bar-used{color:var(--text-secondary, #aaa)}.usage-bar-pct{font-weight:700;font-size:.82rem}.usage-bar-limit{color:var(--text-muted, #888)}.usage-meter-details{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.25rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.04)}.usage-detail-item{font-size:.72rem;color:var(--text-muted, #888)}.usage-status.usage-good{color:#22c55e}.usage-status.usage-moderate{color:#eab308}.usage-status.usage-warning{color:#f59e0b}.usage-status.usage-critical{color:#ef4444;font-weight:600}.usage-upgrade-hint{margin-top:.5rem;padding:.4rem .65rem;background:#f5c5180f;border:1px solid rgba(245,197,24,.15);border-radius:6px;font-size:.72rem;color:var(--accent, #eab308)}.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}.enc-dice-panel{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;margin-top:1rem}.enc-dice-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.enc-dice-header h3{margin:0;font-size:.9rem}.enc-dice-body{display:flex;flex-direction:column;gap:.5rem}.enc-dice-input-row{display:flex;gap:.3rem;align-items:center}.enc-dice-input-row .form-input{flex:1;font-family:var(--font-mono);font-size:.85rem}.enc-dice-presets{display:flex;flex-wrap:wrap;gap:.25rem}.enc-dice-preset{font-family:var(--font-mono);font-weight:600;min-width:40px;text-align:center;transition:all .15s}.enc-dice-preset:hover{background:var(--accent);color:var(--bg-primary);transform:scale(1.05)}.enc-dice-history{max-height:180px;overflow-y:auto}.enc-dice-entry{display:flex;align-items:center;gap:.5rem;padding:.25rem .4rem;border-radius:var(--radius-sm);font-size:.75rem;border-bottom:1px solid var(--border);transition:all .2s}.enc-dice-entry.enc-dice-latest{background:#f5c51814;border-color:#f5c51833;animation:diceFlash .4s ease}@keyframes diceFlash{0%{background:#f5c5184d;transform:scale(1.02)}to{background:#f5c51814;transform:scale(1)}}.enc-dice-total{font-size:1.2rem;font-weight:800;font-family:var(--font-mono);color:var(--accent);min-width:36px;text-align:center}.enc-dice-detail{flex:1;color:var(--text-secondary);font-family:var(--font-mono)}.enc-dice-time{color:var(--text-muted);font-size:.65rem}.enc-ai-tools-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}@media(max-width:900px){.enc-ai-tools-row{grid-template-columns:1fr}}.enc-ai-panel{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-top:1rem}.enc-ai-tools-row .enc-ai-panel{margin-top:0}.enc-ai-panel-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;cursor:pointer;background:linear-gradient(135deg,rgba(245,197,24,.05),transparent);border-bottom:1px solid var(--border);transition:background .15s}.enc-ai-panel-header:hover{background:linear-gradient(135deg,rgba(245,197,24,.1),transparent)}.enc-ai-panel-header h3{margin:0;font-size:.85rem}.enc-ai-toggle{font-size:.7rem;color:var(--text-muted);transition:transform .2s}.enc-ai-panel-body{padding:.75rem}.enc-ai-form{display:flex;flex-direction:column;gap:.4rem}.enc-ai-form-row{display:flex;align-items:center;gap:.5rem}.enc-ai-form-row label{font-size:.75rem;font-weight:600;min-width:80px;color:var(--text-secondary)}.enc-ai-form-row .form-input{flex:1;font-size:.8rem;padding:.3rem .5rem}.enc-ai-form .btn-primary{margin-top:.5rem;align-self:flex-start;font-size:.8rem;padding:.4rem .8rem}.enc-ai-result{margin-top:.5rem}.enc-ai-loading{display:flex;align-items:center;gap:.5rem;padding:.75rem;font-size:.8rem;color:var(--text-secondary);font-style:italic}.enc-ai-error{padding:.5rem .75rem;background:#ff55551a;border:1px solid rgba(255,85,85,.3);border-radius:var(--radius-sm);color:#f55;font-size:.8rem}.enc-ai-result-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;animation:fadeInUp .3s ease}.enc-ai-result-card h4{margin:0 0 .4rem;font-size:1rem;color:var(--accent)}.enc-ai-desc{font-size:.8rem;color:var(--text-secondary);margin:0 0 .5rem;font-style:italic;line-height:1.4}.enc-ai-env{font-size:.75rem;color:var(--text-muted);margin:0 0 .5rem}.enc-ai-monsters{margin:.5rem 0}.enc-ai-monsters strong{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.enc-ai-monster-row{display:flex;align-items:center;gap:.5rem;padding:.3rem .5rem;background:var(--surface-2);border-radius:var(--radius-sm);margin-top:.2rem;font-size:.8rem}.enc-ai-monster-name{font-weight:600;flex:1}.enc-ai-monster-cr{font-family:var(--font-mono);font-weight:700;color:var(--accent);font-size:.75rem;background:#f5c5181a;padding:.1rem .4rem;border-radius:4px}.enc-ai-monster-notes{font-size:.7rem;color:var(--text-muted);font-style:italic}.enc-ai-meta-row{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;font-size:.8rem;padding-top:.4rem;border-top:1px solid var(--border)}.enc-ai-diff-badge{padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.enc-ai-diff-easy{background:#50c87826;color:#50c878}.enc-ai-diff-medium{background:#4a9eff26;color:#4a9eff}.enc-ai-diff-hard{background:#f0ad4e26;color:#f0ad4e}.enc-ai-diff-deadly{background:#ff555526;color:#f55}.enc-ai-tactics,.enc-ai-treasure-hint{font-size:.78rem;margin-top:.4rem;padding:.4rem .5rem;background:var(--surface-2);border-radius:var(--radius-sm);line-height:1.4}.enc-ai-loot-section{margin-top:.5rem}.enc-ai-loot-section strong{font-size:.75rem;display:block;margin-bottom:.2rem}.enc-ai-loot-item{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem;padding:.2rem .4rem;font-size:.78rem;border-bottom:1px solid var(--border)}.enc-ai-gp{font-family:var(--font-mono);font-weight:700;color:#f5c518;font-size:.75rem}.enc-ai-gp-total{font-family:var(--font-mono);font-weight:800;color:#f5c518;font-size:1rem}.enc-ai-item-desc{font-size:.7rem;color:var(--text-muted);font-style:italic;width:100%}.enc-ai-magic-item{background:#9370db0f;border:1px solid rgba(147,112,219,.15);border-radius:var(--radius-sm);padding:.3rem .5rem;margin-top:.2rem}.enc-ai-magic-name{font-weight:700;color:#b48eff}.enc-ai-aura{font-size:.65rem;color:#9370db;font-style:italic}.enc-ai-shopkeeper{font-size:.8rem;margin-bottom:.4rem}.enc-ai-specialty{font-size:.78rem;color:var(--accent);margin-bottom:.5rem}.enc-ai-shop-table{width:100%;border-collapse:collapse;font-size:.78rem}.enc-ai-shop-table thead th{text-align:left;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:.3rem .4rem;border-bottom:2px solid var(--border)}.enc-ai-shop-row td{padding:.3rem .4rem;border-bottom:1px solid var(--border)}.enc-ai-shop-row:hover{background:var(--surface-2)}.enc-ai-shop-name{font-weight:600}.enc-ai-shop-type{font-size:.7rem;color:var(--text-muted);text-transform:capitalize}#dm-toolbar-root{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column-reverse;align-items:flex-end;gap:.5rem}.dm-toolbar{display:flex;flex-direction:column-reverse;align-items:center;gap:.4rem}.dm-tb-fab{width:52px;height:52px;border-radius:50%;border:2px solid var(--accent);background:var(--surface);font-size:1.4rem;cursor:pointer;box-shadow:0 4px 20px #0006,0 0 12px #f5c51833;transition:all .2s;display:flex;align-items:center;justify-content:center}.dm-tb-fab:hover{transform:scale(1.1);box-shadow:0 4px 24px #00000080,0 0 20px #f5c5184d}.dm-tb-buttons{display:flex;flex-direction:column-reverse;gap:.3rem;animation:fadeInUp .2s ease}.dm-tb-btn{width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);font-size:1.1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d}.dm-tb-btn:hover{background:var(--accent);transform:scale(1.1)}.dm-tb-btn.active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 12px #f5c51866}.dm-panel{position:fixed;bottom:1.5rem;right:5.5rem;width:380px;max-height:80vh;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 40px #00000080,0 0 16px #f5c51814;overflow:hidden;animation:fadeInUp .2s ease;display:flex;flex-direction:column;z-index:9998}@media(max-width:500px){.dm-panel{width:calc(100vw - 2rem);right:1rem;bottom:5rem}}.dm-panel-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;background:linear-gradient(135deg,rgba(245,197,24,.08),transparent);border-bottom:1px solid var(--border)}.dm-panel-header h3{margin:0;font-size:.9rem}.dm-panel-close{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:.2rem .4rem;border-radius:var(--radius-sm);transition:all .15s}.dm-panel-close:hover{color:#f55;background:#ff55551a}.dm-panel-body{padding:.75rem;overflow-y:auto;flex:1}.ai-cost-modal{z-index:1100}.ai-cost-content{max-width:420px;text-align:center;padding:2rem 2rem 1.5rem;border-top:3px solid;border-image:linear-gradient(90deg,#b87333,#d4956a,gold,#d4956a,#b87333) 1}.ai-cost-icon{font-size:2.8rem;margin-bottom:.5rem;animation:aiCostPulse 2s ease-in-out infinite;filter:drop-shadow(0 0 12px rgba(255,215,0,.35))}@keyframes aiCostPulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 12px rgba(255,215,0,.35))}50%{transform:scale(1.08);filter:drop-shadow(0 0 20px rgba(255,215,0,.55))}}.ai-cost-title{font-size:1.15rem;color:var(--text-heading);margin:0 0 .35rem;font-weight:600;letter-spacing:.3px}.ai-cost-operation{color:var(--text-secondary);font-size:.85rem;margin:0 0 1.25rem;line-height:1.4}.ai-cost-amount{display:flex;flex-direction:column;align-items:center;gap:.2rem;background:linear-gradient(135deg,#b8733314,#ffd7000f);border:1px solid rgba(184,115,51,.25);border-radius:var(--radius-md);padding:1rem 1.5rem;margin:0 auto 1rem;max-width:240px}.ai-cost-value{font-size:1.8rem;font-weight:700;color:#d4956a;font-family:Inter,sans-serif;letter-spacing:-.5px;text-shadow:0 0 20px rgba(212,149,106,.2)}.ai-cost-unit{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}.ai-cost-note{font-size:.72rem;color:var(--text-muted);margin:0 0 1.25rem;line-height:1.5;opacity:.75;max-width:320px;margin-left:auto;margin-right:auto}.ai-cost-actions{display:flex;gap:.75rem;justify-content:center}.ai-cost-proceed{min-width:140px;font-weight:600}.ai-cost-proceed:disabled{opacity:.5;cursor:not-allowed;background:#ffffff14;color:var(--text-muted, #94a3b8);border-color:transparent}.ai-cost-cancel{min-width:100px}.ai-cost-balance{display:flex;justify-content:center;align-items:baseline;gap:.4rem;margin:-.4rem 0 .9rem;font-size:.8rem;font-variant-numeric:tabular-nums}.ai-cost-balance-label{color:var(--text-muted)}.ai-cost-balance-value{color:#22c55e;font-weight:600}.ai-cost-balance-low .ai-cost-balance-value{color:#ef4444}.ai-cost-warn{background:#ef444414;border:1px solid rgba(239,68,68,.35);color:#fca5a5;border-radius:8px;padding:.6rem .8rem;font-size:.8rem;line-height:1.4;margin:0 0 1rem;text-align:left}.ai-cost-warn.ai-cost-warn-soft{background:#f59e0b14;border-color:#f59e0b66;color:#fcd34d}.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-wx-grid-host{overflow-x:auto}.cal-wx-grid-title{font-size:1rem;color:var(--text);margin-bottom:.6rem;font-weight:600}.cal-wx-grid{display:grid;gap:0;min-width:760px;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:#00000029}.cal-wx-head{font-size:.75rem;font-weight:600;color:var(--text-muted);text-align:center;padding:.5rem 0;border-right:1px solid var(--border-color);background:#0000002e}.cal-wx-head:last-child{border-right:none}.cal-wx-cell{border-right:1px solid var(--border-color);border-top:1px solid var(--border-color);padding:.35rem .45rem .45rem;font-size:.72rem;background:#08081447;min-height:7.4rem;position:relative}.cal-wx-cell.cal-wx-blank{background:#04040c38;min-height:7.4rem}.cal-wx-is-today{box-shadow:inset 0 0 0 2px var(--accent);background:#c4a35a17}.cal-wx-daynum{font-weight:700;font-size:.9rem;margin-bottom:.25rem;color:var(--text)}.cal-wx-moon-inline{position:absolute;right:.35rem;top:.35rem;font-size:.85rem;opacity:.95}.cal-wx-temp{font-weight:600;color:var(--text-secondary);line-height:1.15;font-size:.82rem;margin-top:.4rem}.cal-wx-sub,.cal-wx-no-wx{font-size:.66rem;line-height:1.25;margin-top:.2rem;color:var(--text-muted)}.cal-wx-odd{font-size:.62rem;color:var(--warning, #c9a227);margin-top:.25rem;line-height:1.2;max-height:1.6rem;overflow:hidden}.cal-wx-moon{margin-top:.45rem;padding-top:.3rem;border-top:1px solid var(--border-color);font-size:.64rem;line-height:1.2}.cal-wx-moon-sym{margin-right:.25rem}.cal-wx-moon-label{display:inline;color:var(--text-muted);font-size:.6rem}.cal-months-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.cal-months-header h3{margin:0}.cal-month-count{font-size:.8rem;font-weight:400;color:var(--text-muted);margin-left:.25rem}.cal-months-controls{display:flex;gap:.35rem}.cal-months-controls button{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;line-height:1}.cal-month-list{display:flex;flex-direction:column;gap:.35rem}.cal-month-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}.cal-month-days{width:65px;flex-shrink:0;text-align:center;font-size:.85rem!important;padding:.4rem .3rem!important}.cal-days-label{font-size:.75rem;color:var(--text-muted);flex-shrink:0;min-width:28px}.view-simulation{max-width:900px}.view-simulation-with-log{max-width:none;width:100%}.sim-layout{display:flex;align-items:flex-start;gap:1rem;width:100%}.sim-main-column{flex:1;min-width:0}.sim-debug-sidebar{flex:0 0 clamp(280px,32vw,420px);width:clamp(280px,32vw,420px);position:sticky;top:.75rem;align-self:flex-start;max-height:calc(100vh - 1.5rem);display:flex;flex-direction:column}@media(max-width:960px){.sim-layout{flex-direction:column}.sim-debug-sidebar{position:relative;top:0;flex:1 1 auto;width:100%;max-height:none}}.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{flex:1;display:flex;flex-direction:column;min-height:0;margin-top:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:.65rem .75rem}.sim-debug-log-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-shrink:0;margin-bottom:.4rem}.sim-debug-log-header h3{font-size:.8rem;color:var(--text-muted);margin:0;font-weight:600}.sim-log-entries{flex:1;min-height:min(70vh,560px);max-height:min(70vh,560px);overflow-y:auto;overflow-x:auto;background:#00000038;border-radius:var(--radius-sm);padding:.5rem .6rem;font-size:.8rem;line-height:1.35}.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:minmax(220px,260px) 1fr;gap:1rem;min-height:500px}.help-tab-list{display:flex;flex-direction:column;gap:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:.35rem .4rem .5rem;overflow-y:auto;max-height:calc(100vh - 220px);position:sticky;top:1rem}.help-nav-group{border-bottom:1px solid var(--border)}.help-nav-group:last-child{border-bottom:none}.help-group-toggle{display:flex;align-items:center;gap:.35rem;width:100%;padding:.4rem .45rem;margin:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:.65rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;text-align:left;cursor:pointer;transition:background .15s,color .15s}.help-group-toggle:hover{color:var(--text-secondary);background:var(--bg-hover)}.help-group-chevron{font-size:.5rem;width:.7rem;flex-shrink:0;opacity:.85;transition:transform .15s ease}.help-nav-group.is-collapsed .help-group-chevron{transform:rotate(-90deg)}.help-group-label{flex:1}.help-group-topics{display:flex;flex-direction:column;gap:2px;padding:0 0 .35rem .15rem}.help-nav-group.is-collapsed .help-group-topics{display:none}.help-group-topics .help-tab-btn{padding-left:.5rem}.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-incomplete{padding:.6rem .8rem;margin:.5rem 0;background:#f59e0b12;border:1px solid rgba(245,158,11,.28);border-left:3px solid var(--warning, #f59e0b);border-radius:var(--radius-sm);font-size:.78rem;color:var(--text-secondary)}.help-incomplete-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--warning, #f59e0b);margin:0 0 .35rem}.help-incomplete p{margin:0 0 .35rem}.help-incomplete p:last-child{margin-bottom:0}.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:column;position:static;max-height:min(42vh,320px);gap:0}.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}.view-subscription{max-width:1200px;margin:0 auto;padding:0 .5rem 2rem}.subscription-header{align-items:flex-start;gap:1rem;flex-wrap:wrap}.subscription-header h1{margin:0 0 .35rem}.subscription-lead{margin:0;max-width:52rem;font-size:.85rem;color:var(--text-secondary);line-height:1.5}.subscription-header-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;flex-shrink:0}.subscription-body{margin-top:.5rem}.subscription-section{margin-bottom:2rem}.subscription-section h2{font-size:1rem;margin:0 0 .75rem;color:var(--text-primary)}.subscription-you{font-size:.85rem;margin:0 0 1rem;color:var(--text-secondary)}.subscription-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.subscription-card{background:var(--bg-secondary, rgba(0, 0, 0, .25));border:1px solid var(--border);border-radius:var(--radius-md, 10px);padding:1rem 1rem 1.1rem;display:flex;flex-direction:column;min-height:0}.subscription-card-current{border-color:#6366f18c}.subscription-card-head{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.35rem}.subscription-current-pill{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.15rem .45rem;border-radius:999px;background:#6366f140;color:#c4b5fd}.subscription-card-price{font-size:1.35rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem}.subscription-card-specs{margin:0 0 .75rem;display:grid;gap:.35rem;font-size:.75rem}.subscription-card-specs>div{display:flex;justify-content:space-between;gap:.5rem;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:.25rem}.subscription-card-specs dt{margin:0;color:var(--text-muted);font-weight:500}.subscription-card-specs dd{margin:0;color:var(--text-secondary);text-align:right}.subscription-includes-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 .35rem}.subscription-includes-list{margin:0;padding-left:1.1rem;font-size:.72rem;line-height:1.45;color:var(--text-secondary);flex:1}.subscription-includes-list li{margin-bottom:.3rem}.subscription-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}.subscription-compare-table{width:100%;border-collapse:collapse;font-size:.78rem}.subscription-compare-table th,.subscription-compare-table td{padding:.45rem .6rem;text-align:left;border-bottom:1px solid var(--border)}.subscription-compare-table th{background:#0003;color:var(--text-muted);font-weight:600;white-space:nowrap}.subscription-compare-table tbody tr:hover{background:#ffffff08}.subscription-foot{font-size:.78rem;line-height:1.55;max-width:48rem}.subscription-foot p{margin:0 0 .5rem}.subscription-error{color:var(--error)}.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-portrait-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;border-radius:4px}.cs-portrait-overlay span{font-size:1.2rem;filter:drop-shadow(0 1px 3px rgba(0,0,0,.5))}.cs-portrait-wrap:hover .cs-portrait-overlay{opacity:1}.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}.ccard{display:flex;flex-direction:column;gap:0}.ccard-header{display:flex;gap:1rem;padding:.75rem;background:linear-gradient(135deg,#0f0a19f2,#190f28e6);border-radius:10px 10px 0 0;border:1px solid rgba(184,115,51,.2);border-bottom:none}.ccard-header-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.ccard-name{font-family:Cinzel,serif;font-size:1.5rem;font-weight:700;color:#f0e6d3;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.6);text-transform:uppercase;letter-spacing:1px;line-height:1.15}.ccard-class{font-size:.8rem;color:#a89bb8;font-weight:500}.ccard-meta-row{display:flex;gap:1rem;font-size:.75rem;color:#9a8daa;margin-top:.15rem}.ccard-meta-lbl{font-weight:700;color:#d4af37;margin-right:.2rem}.ccard-deity{font-size:.8rem;color:#c8b8e0;font-style:italic}.ccard-xp-row{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.ccard-xp-lbl{font-size:.65rem;font-weight:700;color:#a89bb8;text-transform:uppercase}.ccard-xp-track{flex:1;height:5px;background:#ffffff14;border-radius:3px;overflow:hidden}.ccard-xp-fill{height:100%;background:linear-gradient(90deg,#2d7d32,#4caf50);border-radius:3px;transition:width .5s}.ccard-portrait{width:120px;height:140px;flex-shrink:0;border-radius:8px;overflow:hidden;border:2px solid rgba(184,115,51,.35);background:#0006;box-shadow:0 4px 16px #00000080}.ccard-portrait-img{width:100%;height:100%;object-fit:cover}.ccard-portrait-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;opacity:.25;color:#d4af37}.ccard-divider{text-align:center;font-size:.9rem;color:#b8733366;padding:.15rem 0;background:linear-gradient(90deg,transparent,rgba(184,115,51,.1),transparent);border-left:1px solid rgba(184,115,51,.2);border-right:1px solid rgba(184,115,51,.2);letter-spacing:8px}.ccard-body{display:grid;grid-template-columns:110px 1fr 280px;gap:.75rem;padding:.75rem;background:linear-gradient(180deg,#0f0a19f2,#0a0612fa);border:1px solid rgba(184,115,51,.2);border-top:none;border-radius:0 0 10px 10px}.ccard-col-left{display:flex;flex-direction:column;gap:1rem}.ccard-col-skills{display:flex;flex-direction:column;gap:.3rem;border-left:1px solid rgba(184,115,51,.1);padding-left:.75rem}.ccard-skills-scroll{overflow-y:auto;max-height:calc(100vh - 380px);scrollbar-width:thin;scrollbar-color:rgba(184,115,51,.2) transparent}.ccard-ab-grid{display:grid;grid-template-columns:1fr;gap:.3rem}.ccard-ab{display:flex;flex-direction:row;align-items:center;gap:.4rem;padding:.3rem .4rem;background:linear-gradient(180deg,#191226e6,#120c1ef2);border:1px solid rgba(184,115,51,.2);border-radius:8px;box-shadow:inset 0 2px 6px #0000004d;transition:border-color .2s}.ccard-ab:hover{border-color:#b8733380}.ccard-ab-label{font-size:.6rem;font-weight:800;color:#d4af37;text-transform:uppercase;letter-spacing:.5px;width:28px;flex-shrink:0}.ccard-ab-score{font-size:1.1rem;font-family:Cinzel,serif;font-weight:700;color:#fff;line-height:1;text-shadow:0 1px 2px rgba(0,0,0,.5);width:28px;text-align:center}.ccard-ab-mod{font-size:.65rem;font-weight:700;color:#c8b8e0;background:#b873331f;border:1px solid rgba(184,115,51,.25);padding:.05rem .35rem;border-radius:20px;font-family:JetBrains Mono,monospace}.ccard-ab-pos .ccard-ab-mod{color:#81c784}.ccard-col-right{display:flex;flex-direction:column;gap:.6rem;overflow-y:auto}.ccard-section{display:flex;flex-direction:column;gap:.3rem}.ccard-section-title{font-family:Cinzel,serif;font-size:.8rem;font-weight:700;color:#d4af37;margin:0;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid rgba(184,115,51,.15);padding-bottom:.2rem}.ccard-stat-boxes{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}.ccard-stat-box{display:flex;flex-direction:column;align-items:center;padding:.4rem .25rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:8px;transition:all .2s}.ccard-stat-box:hover{background:#b873330f;border-color:#b8733340}.ccard-stat-lbl{font-size:.6rem;font-weight:700;color:#a89bb8;text-transform:uppercase;letter-spacing:.5px}.ccard-stat-val{font-size:1.2rem;font-family:Cinzel,serif;font-weight:700;color:#fff}.ccard-ac-detail{font-size:.65rem;color:#8a7da0;line-height:1.4;text-align:right}.ccard-speed{font-size:.75rem;color:#9a8daa;text-align:right}.ccard-speed strong{color:#c8b8e0}.ccard-save-boxes{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}.ccard-save-box{display:flex;flex-direction:column;align-items:center;padding:.35rem;background:#00000040;border:1px solid rgba(255,255,255,.05);border-radius:6px}.ccard-save-lbl{font-size:.55rem;font-weight:700;color:#a89bb8;text-transform:uppercase}.ccard-save-val{font-size:1rem;font-family:Cinzel,serif;font-weight:700;color:#fff}.ccard-list{display:flex;flex-direction:column;gap:.15rem}.ccard-list-item{display:flex;align-items:center;gap:.4rem;padding:.2rem .3rem;border-radius:4px;cursor:pointer;transition:background .15s;font-size:.78rem}.ccard-list-item:hover{background:#b873330f}.ccard-list-icon{font-size:.7rem;flex-shrink:0;width:1rem;text-align:center;opacity:.7}.ccard-list-name{flex:1;color:#d4c5f9;min-width:0;line-height:1.25}.ccard-skill-base{display:block}.ccard-skill-sub{display:block;font-size:.68rem;color:#9a8daa;margin-top:-.05rem}.ccard-list-val{font-family:JetBrains Mono,monospace;font-weight:700;color:#fff;font-size:.75rem;flex-shrink:0;min-width:32px;text-align:right}.ccard-empty{font-size:.75rem;color:#6b5d7a;font-style:italic;padding:.2rem 0}.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-bp-sell-btn{padding:.12rem .35rem;border-radius:3px;border:1px solid hsla(40,70%,50%,.3);background:#cf91171f;color:#f2bf5a;cursor:pointer;font-size:.6rem;transition:all .15s;white-space:nowrap}.cs-bp-sell-btn:hover{background:#e6a21933;border-color:#dda73c80;color:#f7c96e}.cs-bp-actions{display:flex;gap:.2rem;align-items:center;flex-shrink:0;margin-left:auto}.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}.ft-container{display:flex;flex-direction:row;align-items:center;gap:0;padding:1.5rem 1rem;min-height:300px;overflow-x:auto;overflow-y:visible;scroll-behavior:smooth}.ft-generation{display:flex;flex-direction:column;align-items:center;gap:.5rem;position:relative;flex-shrink:0}.ft-gen-label{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#a89bb8;padding:.2rem .8rem;background:#4e3a7840;border-radius:10px;border:1px solid rgba(78,58,120,.3);white-space:nowrap}.ft-gen-label-sm{font-size:.5rem;padding:.15rem .5rem;margin-bottom:.25rem}.ft-gen-row{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem}.ft-root-row{gap:.5rem}.ft-couple-group{display:flex;flex-direction:column;gap:.4rem;align-items:center;padding:.25rem;border:1px dashed rgba(78,58,120,.2);border-radius:8px;background:#4e3a780f}.ft-siblings-group{display:flex;flex-direction:column;align-items:center;gap:.35rem}.ft-siblings-group>.ft-person{transform:scale(.9)}.ft-connector{display:flex;align-items:center;justify-content:center;flex-shrink:0}.ft-connector-horizontal{width:32px;height:2px;background:linear-gradient(to right,#b8733326,#b8733380,#b8733326);border-radius:1px}.ft-connector-vertical{width:2px;height:16px;background:linear-gradient(to bottom,#b8733380,#b8733326);border-radius:1px;flex-shrink:0}.ft-connector-heart{width:auto;height:auto;background:none;font-size:.9rem;padding:.15rem 0;animation:heartbeat 2s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.ft-person{position:relative;display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.6rem .5rem .45rem;background:linear-gradient(135deg,#1a0e2ee6,#2d1b4eb3);border:1px solid rgba(78,58,120,.35);border-radius:10px;min-width:100px;max-width:130px;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000004d}.ft-person:hover{border-color:#b8733380;box-shadow:0 4px 16px #b8733326;transform:translateY(-2px)}.ft-person[data-ft-nav]:hover{border-color:#b8733399}.ft-person.ft-root{border-color:#b8733399;background:linear-gradient(135deg,#2e1e0fe6,#4e361b80);box-shadow:0 0 20px #b8733326,0 4px 12px #0000004d,inset 0 1px #b8733326;min-width:120px;max-width:150px;padding:.75rem .6rem .55rem}.ft-person.ft-root:before{content:"⭐";position:absolute;top:-8px;right:-4px;font-size:.7rem;filter:drop-shadow(0 1px 3px rgba(184,115,51,.5))}.ft-person.ft-root .ft-name{color:#f4bd71;font-size:.75rem}.ft-person.ft-deceased{opacity:.6;filter:grayscale(40%)}.ft-person.ft-deceased:hover{opacity:.85}.ft-portrait-wrap{width:48px;height:48px;border-radius:50%;overflow:hidden;border:2px solid rgba(78,58,120,.5);background:#0000004d;flex-shrink:0}.ft-root .ft-portrait-wrap{width:56px;height:56px;border-color:#b8733373}.ft-portrait{width:100%;height:100%;object-fit:cover}.ft-portrait-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;background:linear-gradient(135deg,#4e3a784d,#2d1b4e80)}.ft-name{font-size:.7rem;font-weight:700;color:var(--text-primary);text-align:center;line-height:1.2;word-break:break-word}.ft-meta{font-size:.56rem;color:#a89bb8;text-align:center;line-height:1.2}.ft-age{font-size:.5rem;color:var(--text-muted)}.ft-status{font-size:.5rem;color:#c44;font-weight:600}.ft-delete-btn{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;border:1px solid rgba(239,68,68,.2);background:#ef44441a;color:#ef444480;font-size:.55rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .15s;padding:0;line-height:1}.ft-person:hover .ft-delete-btn{opacity:1}.ft-delete-btn:hover{background:#ef44444d;border-color:#ef444480;color:#ef4444}.ft-actions{display:flex;justify-content:center;padding:1rem 0 .5rem}.ft-add-btn{display:flex;align-items:center;gap:.3rem;padding:.5rem 1.2rem;font-size:.78rem;font-weight:600;border-radius:8px;transition:all .2s}.ft-add-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #b8733340}.ft-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem;text-align:center}.ft-empty-icon{font-size:3rem;opacity:.3;animation:treeSway 4s ease-in-out infinite}@keyframes treeSway{0%,to{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}.ft-empty-title{font-size:1rem;font-weight:700;color:var(--text-primary)}.ft-empty-text{font-size:.78rem;color:var(--text-muted);max-width:320px;line-height:1.5}@media(max-width:600px){.ft-container{padding:1rem .5rem}.ft-gen-row{gap:.4rem}.ft-person{min-width:85px;max-width:110px;padding:.4rem .35rem .35rem}.ft-portrait-wrap{width:38px;height:38px}.ft-root .ft-portrait-wrap{width:46px;height:46px}.ft-name{font-size:.6rem}.ft-connector-horizontal{width:20px}}.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}}.spell-pip-domain,.spell-pip-domain-used{width:14px;height:14px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.5rem;font-weight:700;line-height:1;transition:all .2s ease;margin-left:2px}.spell-pip-domain{background:#b8733340;border:2px solid #B87333;color:#b87333}.spell-pip-domain-used{background:#ff525266;border:2px solid #ff5252;color:#ff5252}.domain-slot-label{color:#b87333;font-weight:700;font-size:.65rem}.domain-section{margin-top:.75rem;padding:.6rem .75rem;background:#b873330a;border:1px solid rgba(184,115,51,.12);border-radius:8px}.domain-section-title{font-size:.78rem;font-weight:600;color:#b87333;margin-bottom:.4rem}.domain-section-title .cs-block-count{font-weight:400;color:var(--text-secondary)}.domain-power-card{padding:.4rem .6rem;margin-bottom:.3rem;background:#ffffff08;border-radius:6px;border-left:2px solid #B87333}.domain-power-name{font-size:.78rem;font-weight:600;color:var(--text-primary);margin-bottom:.15rem}.domain-power-desc{font-size:.68rem;color:var(--text-secondary);line-height:1.35}.domain-picker{padding:.3rem 0}.domain-picker-help{font-size:.72rem;color:var(--text-secondary);margin-bottom:.4rem}.domain-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.2rem;margin-bottom:.5rem;max-height:200px;overflow-y:auto}.domain-pick-option{display:flex;align-items:center;gap:.3rem;padding:.2rem .4rem;font-size:.72rem;color:var(--text-primary);border-radius:4px;cursor:pointer;transition:background .15s}.domain-pick-option:hover{background:#b8733314}.domain-pick-option input:checked+span,.domain-pick-option:has(input:checked){color:#b87333;font-weight:600}.domain-spells-list{margin-top:.5rem}.domain-spell-level{display:flex;align-items:flex-start;gap:.3rem;padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,.04);flex-wrap:wrap}.domain-spell-lvl{min-width:20px;font-weight:700;font-size:.75rem;color:#b87333;text-align:center;padding-top:.15rem}.domain-spell-entry{display:inline-flex;align-items:center;gap:.2rem;padding:.15rem .4rem;margin:.1rem;background:#ffffff08;border-radius:4px;font-size:.7rem;border:1px solid rgba(255,255,255,.06);transition:all .15s}.domain-spell-entry:hover{background:#b8733314;border-color:#b8733333}.domain-spell-entry.prepared{border-color:#66bb6a4d;background:#66bb6a0d}.domain-spell-name{color:var(--text-primary);font-weight:500}.domain-spell-src{font-size:.6rem;color:var(--text-secondary);font-style:italic}.domain-prepare-btn{padding:.1rem .25rem!important;font-size:.6rem!important;cursor:pointer;background:#b873331f;border:1px solid rgba(184,115,51,.3);color:#b87333;border-radius:3px;transition:all .2s}.domain-prepare-btn:hover{background:#b8733340;transform:scale(1.1)}.cs-spell-badge{font-size:.6rem;color:#66bb6a;font-weight:700}.spontaneous-section{margin-top:.75rem;padding:.6rem .75rem;background:#66bb6a0a;border:1px solid rgba(102,187,106,.12);border-radius:8px}.spontaneous-title{font-size:.78rem;font-weight:600;color:#66bb6a;margin-bottom:.3rem}.spontaneous-help{font-size:.68rem;color:var(--text-secondary);margin-bottom:.4rem;font-style:italic}.spontaneous-list{display:flex;flex-direction:column;gap:.2rem}.spontaneous-spell{display:flex;align-items:center;gap:.4rem;padding:.2rem .4rem;border-radius:4px;font-size:.72rem;transition:background .15s}.spontaneous-spell:hover{background:#66bb6a0f}.spontaneous-lvl{min-width:18px;font-weight:700;color:#66bb6a;text-align:center;font-size:.75rem}.spontaneous-name{color:var(--text-primary)}.metamagic-prepare-btn{margin-left:.2rem}.cs-spell-prepare-btn{font-size:.6rem;padding:.1rem .3rem;cursor:pointer}.cs-spell-search-item{display:flex;align-items:center;gap:.3rem}.cs-spell-meta-add-btn{font-size:.7rem;padding:.15rem .35rem;min-width:unset;border-radius:4px}.cs-spell-metamagic{border-left:3px solid hsl(275,60%,55%)}.cs-spell-metamagic .metamagic-tag{margin-left:.3rem}.srd-eq-actions{display:flex;gap:.3rem;align-items:center;flex-shrink:0}.srd-eq-buy{background:linear-gradient(135deg,#cf911740,#8f6b2433);border:1px solid hsla(40,70%,50%,.4);color:#f2bf5a;font-size:.7rem;padding:.2rem .5rem;border-radius:4px;cursor:pointer;transition:all .15s ease;white-space:nowrap}.srd-eq-buy:hover{background:linear-gradient(135deg,#e6a21959,#a37a294d);border-color:#dda73c99;transform:translateY(-1px);box-shadow:0 2px 6px #a37a2933}.srd-eq-buy:disabled,.srd-eq-buy.srd-eq-bought{background:#26592626;border-color:#3d8f3d4d;color:#6c6;cursor:default;transform:none;box-shadow:none}.srd-eq-buy.srd-eq-cant-afford{background:#4d4d4d1f;border-color:#6663;color:#8c8c8c99;cursor:not-allowed;opacity:.5}.srd-eq-row{display:flex;align-items:center;gap:.4rem}.srd-eq-row>span{flex-shrink:0}.srd-eq-name{flex:1;min-width:0}.cc-homebrew-badge{display:inline-block;font-size:.6rem;padding:.1rem .35rem;border-radius:3px;background:linear-gradient(135deg,#e6b31933,#9d26d933);color:#f6ce55;border:1px solid hsla(45,80%,50%,.3);font-weight:600;letter-spacing:.3px;vertical-align:middle;margin-left:.25rem}.cc-feat-mods{display:inline-flex;gap:.2rem;margin-left:.4rem;vertical-align:middle;flex-wrap:wrap}.cc-mod-badge{display:inline-block;font-size:.58rem;font-weight:700;padding:.08rem .3rem;border-radius:3px;letter-spacing:.2px;vertical-align:middle;background:#66bb6a1f;color:#81c784;border:1px solid rgba(102,187,106,.25)}.cc-mod-ability{background:#64b5f61f;color:#90caf9;border-color:#64b5f640}.cc-mod-save{background:#ffb74d1f;color:#ffcc80;border-color:#ffb74d40}.cc-mod-skill{background:#81c7841f;color:#a5d6a7;border-color:#81c78440}.cc-mod-ac{background:#9575cd1f;color:#b39ddb;border-color:#9575cd40}.cc-mod-hp{background:#ef53501f;color:#ef9a9a;border-color:#ef535040}.cc-mod-init{background:#4dd0e11f;color:#80deea;border-color:#4dd0e140}.cc-mod-atk{background:#ff8a651f;color:#ffab91;border-color:#ff8a6540}.cc-mod-dmg{background:#ff52521f;color:#ff8a80;border-color:#ff525240}.cc-mod-spd{background:#81d4fa1f;color:#b3e5fc;border-color:#81d4fa40}: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}.admin-dashboard{padding:1.5rem;max-width:1400px;margin:0 auto}.admin-header{margin-bottom:1.5rem}.admin-title{font-size:1.75rem;font-weight:700;color:var(--gold-primary);margin:0 0 .25rem}.admin-subtitle{color:var(--text-muted);font-size:.9rem;margin:0}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:1px solid var(--border-subtle);padding-bottom:.5rem;flex-wrap:wrap}.admin-tab{background:transparent;border:1px solid transparent;color:var(--text-muted);padding:.5rem 1rem;border-radius:6px 6px 0 0;cursor:pointer;font-size:.85rem;transition:all .2s}.admin-tab:hover{color:var(--text-primary);background:#ffffff08}.admin-tab.active{color:var(--gold-primary);border-color:var(--border-subtle);border-bottom-color:var(--bg-primary);background:var(--bg-secondary)}.admin-breadcrumb{margin-bottom:1rem}.breadcrumb-trail{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;font-size:.85rem;padding:.5rem .75rem;background:#ffffff05;border:1px solid var(--border-subtle);border-radius:8px}.breadcrumb-item{background:transparent;border:none;color:var(--gold-primary);cursor:pointer;padding:.2rem .5rem;border-radius:4px;transition:all .2s;font-size:.85rem}.breadcrumb-item:hover{background:#f5c5181a}.breadcrumb-current{color:var(--text-primary);font-weight:600;cursor:default}.breadcrumb-current:hover{background:transparent}.breadcrumb-sep{color:var(--text-muted);font-size:.75rem}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.admin-stat-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:10px;padding:1.25rem;text-align:center;transition:all .3s}.admin-stat-card:hover{border-color:var(--gold-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.stat-icon{font-size:1.75rem;margin-bottom:.5rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.admin-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.admin-section-header h2{margin:0;font-size:1.25rem;color:var(--gold-primary)}.admin-table-wrap{overflow-x:auto;margin-bottom:1rem}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th{text-align:left;padding:.6rem .75rem;border-bottom:2px solid var(--border-subtle);color:var(--gold-primary);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;position:sticky;top:0;background:var(--bg-primary);z-index:1}.admin-table td{padding:.55rem .75rem;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text-primary)}.admin-table tr:hover td{background:#ffffff05}.admin-table.compact th,.admin-table.compact td{padding:.4rem .6rem;font-size:.8rem}.cell-id{color:var(--text-muted);font-size:.75rem;font-family:monospace}.cell-truncate{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.row-equipped td{background:#f5c5180a!important}.clickable{cursor:pointer;color:var(--gold-primary)!important;font-weight:600;transition:all .2s}.clickable:hover{text-decoration:underline;color:#f5d76e!important}.member-name{font-weight:600;color:var(--gold-primary)}.member-email{color:var(--text-muted);font-size:.8rem}.admin-inline-select{background:var(--bg-primary);border:1px solid var(--border-subtle);color:var(--text-primary);padding:.2rem .4rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:border-color .2s}.admin-inline-select:hover,.admin-inline-select:focus{border-color:var(--gold-primary);outline:none}.admin-inline-input{background:var(--bg-primary);border:1px solid var(--border-subtle);color:var(--text-primary);padding:.35rem .5rem;border-radius:4px;font-size:.85rem;width:100%;min-width:150px;transition:border-color .2s}.admin-discord-id-input{width:10.5rem;min-width:0;max-width:100%}.admin-inline-input:focus{border-color:var(--gold-primary);outline:none}.status-badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-alive{background:#2ecc7126;color:#2ecc71}.status-dead{background:#e74c3c26;color:#e74c3c}.status-missing{background:#f1c40f26;color:#f1c40f}.status-departed{background:#9b59b626;color:#9b59b6}.status-unconscious{background:#e67e2226;color:#e67e22}.tier-badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tier-free{background:#6464644d;color:#aaa}.tier-apprentice{background:#67e8f926;color:#67e8f9}.tier-adventurer{background:#6ee7b726;color:#6ee7b7}.tier-guild_master{background:#c4b5fd26;color:#c4b5fd}.tier-world_builder{background:#f5c51826;color:var(--gold-primary)}.admin-usage-bar{position:relative;width:70px;height:16px;background:#ffffff0f;border-radius:3px;overflow:hidden}.admin-usage-fill{height:100%;border-radius:3px;transition:width .5s ease}.admin-usage-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#fff;text-shadow:0 0 3px rgba(0,0,0,.6)}.admin-btn{background:var(--bg-secondary);border:1px solid var(--border-subtle);color:var(--text-primary);padding:.4rem .75rem;border-radius:6px;cursor:pointer;font-size:.8rem;transition:all .2s;white-space:nowrap}.admin-btn:hover{border-color:var(--gold-primary);background:#f5c5180d}.admin-btn-small{padding:.2rem .5rem;font-size:.75rem}.admin-btn-primary{background:#f5c51826;border-color:var(--gold-primary);color:var(--gold-primary)}.admin-btn-primary:hover{background:#f5c51840}.admin-btn-danger{color:#e74c3c;border-color:#e74c3c4d}.admin-btn-danger:hover{background:#e74c3c1a;border-color:#e74c3c}.admin-drill-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.admin-drill-header h2{margin:0;font-size:1.4rem;color:var(--text-primary)}.admin-drill-count{font-size:.85rem;color:var(--text-muted);padding:.2rem .6rem;background:#ffffff08;border-radius:4px}.admin-drill-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-subtle)}.admin-drill-section:last-child{border-bottom:none}.admin-drill-section h3{font-size:1rem;color:var(--gold-primary);margin:0 0 .75rem;font-weight:600}.admin-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.admin-data-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:10px;padding:1rem;transition:all .3s}.admin-data-card:hover{border-color:#f5c5184d;box-shadow:0 2px 8px #0003}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.card-title{font-weight:600;font-size:1rem}.card-badge{padding:.15rem .5rem;border-radius:4px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge-active{background:#2ecc7126;color:#2ecc71}.badge-inactive{background:#64646433;color:#888}.card-meta{display:flex;gap:.75rem;font-size:.8rem;color:var(--text-muted);margin-bottom:.5rem}.card-desc{font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem;line-height:1.4}.card-actions{display:flex;gap:.5rem;margin-top:.5rem}.admin-kv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.admin-kv-grid.char-stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.kv-row{display:flex;gap:.5rem;padding:.35rem .5rem;background:#ffffff05;border-radius:4px;align-items:baseline}.kv-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;min-width:60px;flex-shrink:0}.kv-value{font-size:.85rem;color:var(--text-primary);word-break:break-word}.admin-ability-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.75rem}.ability-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:8px;padding:.75rem;text-align:center}.ability-label{font-size:.7rem;color:var(--gold-primary);font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:.25rem}.ability-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2}.ability-mod{font-size:.85rem;color:var(--text-muted);margin-top:.1rem}.admin-text-block{background:#ffffff05;border:1px solid var(--border-subtle);border-radius:6px;padding:.75rem;margin-top:.5rem;font-size:.8rem}.admin-text-block pre{margin:.25rem 0 0;white-space:pre-wrap;word-break:break-word;color:var(--text-secondary);font-size:.8rem;font-family:inherit;max-height:200px;overflow-y:auto}.admin-text-block strong{color:var(--text-primary);font-size:.8rem}.admin-portrait{max-width:200px;border-radius:8px;border:2px solid var(--border-subtle)}.admin-history-list{display:flex;flex-direction:column;gap:.5rem}.admin-history-entry{background:#ffffff05;border:1px solid var(--border-subtle);border-radius:6px;padding:.75rem}.history-heading{font-weight:600;color:var(--gold-primary);font-size:.85rem;margin-bottom:.25rem}.history-content{font-size:.8rem;color:var(--text-secondary);line-height:1.4}.xp-value{color:#2ecc71;font-weight:600}.admin-empty-inline{color:var(--text-muted);font-style:italic;font-size:.85rem;padding:.5rem 0}.usage-month-block{margin-bottom:1.5rem}.usage-month-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.usage-month-header h3{margin:0;font-size:1rem;color:var(--text-primary)}.usage-month-total{font-size:.8rem;color:var(--text-muted)}.setting-key{font-family:monospace;color:var(--gold-primary);font-weight:600}.admin-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;text-align:center;padding:3rem;color:var(--text-muted);font-style:italic}.admin-spinner{width:20px;height:20px;border:2px solid var(--border-subtle);border-top-color:var(--gold-primary);border-radius:50%;animation:admin-spin .8s linear infinite}@keyframes admin-spin{to{transform:rotate(360deg)}}.admin-empty{text-align:center;padding:3rem;color:var(--text-muted)}.admin-error{text-align:center;padding:2rem;color:#e74c3c;background:#e74c3c1a;border-radius:8px;border:1px solid rgba(231,76,60,.2)}.flash-success{animation:flash-green .6s ease}@keyframes flash-green{0%{box-shadow:0 0 #2ecc7180}50%{box-shadow:0 0 0 4px #2ecc714d}to{box-shadow:none}}.admin-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.admin-modal{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:12px;width:90%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-subtle)}.admin-modal-header h3{margin:0;color:var(--gold-primary);font-size:1.1rem}.admin-modal-close{background:transparent;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s}.admin-modal-close:hover{color:#e74c3c;background:#e74c3c1a}.admin-modal-body{padding:1.25rem;overflow-y:auto;flex:1}.admin-form-group{margin-bottom:1rem}.admin-form-group label{display:block;font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.35rem;font-weight:600}.admin-form-input{width:100%;padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-primary);font-size:.9rem;transition:border-color .2s;box-sizing:border-box}.admin-form-input:focus{border-color:var(--gold-primary);outline:none;box-shadow:0 0 0 2px #f5c5181a}textarea.admin-form-input{resize:vertical;font-family:inherit}select.admin-form-input{cursor:pointer}.admin-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid var(--border-subtle)}.sidebar.admin-mode .sidebar-brand{border-bottom-color:#e74c3c4d}.sidebar.admin-mode .sidebar-title:after{content:" Admin";font-size:.6em;color:#e74c3c;font-weight:400}.admin-credit-cell{display:flex;align-items:center;gap:.4rem}.admin-form-info{color:var(--text-muted);font-size:.85rem;padding:.35rem 0}.metrics-toolbar{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.metrics-toolbar-live{flex-wrap:wrap;justify-content:space-between}.metrics-toolbar-live--compact{margin-top:1rem}.metrics-live-badge{margin-left:auto;font-size:.8rem;color:var(--text-muted);white-space:nowrap}.metrics-live-badge--error{color:#f87171}.metrics-grid-overview{margin-top:.5rem}.metrics-label{color:var(--text-muted);font-size:.85rem}.metrics-window-btn{padding:.35rem .8rem;border:1px solid var(--border);background:transparent;color:var(--text);border-radius:6px;cursor:pointer;font-size:.85rem}.metrics-window-btn.active{background:var(--accent, #60a5fa);color:#fff;border-color:var(--accent, #60a5fa)}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.metric-card{background:var(--surface, #1e293b);border:1px solid var(--border, #334155);border-radius:10px;padding:1rem;overflow:hidden}.metric-card-wide{grid-column:span 2}.metric-title{font-weight:600;margin-bottom:.75rem;color:var(--text);font-size:.95rem}.metric-empty{color:var(--text-muted);font-style:italic;font-size:.85rem;padding:.5rem 0}.metric-spark{width:100%;height:auto;max-height:240px;display:block}.metric-gridline{stroke:#ffffff14;stroke-width:1;shape-rendering:crispEdges}.metric-axis-label{fill:var(--text-muted, #94a3b8);font-size:10px;font-family:inherit;font-variant-numeric:tabular-nums}.metric-axis-y{text-anchor:end;dominant-baseline:middle}.metric-axis-x{text-anchor:middle}.metric-point-label{fill:var(--text, #e2e8f0);font-weight:600;font-size:10px}.metric-spark-meta{display:flex;justify-content:space-between;margin-top:.35rem;color:var(--text-muted);font-size:.75rem;font-variant-numeric:tabular-nums}.tier-list{display:flex;flex-direction:column;gap:.35rem}.tier-row{display:grid;grid-template-columns:110px 1fr 110px;align-items:center;gap:.5rem;font-size:.85rem}.tier-label{text-transform:capitalize;color:var(--text-muted)}.tier-bar-track{height:12px;background:#ffffff0d;border-radius:6px;overflow:hidden}.tier-bar-fill{height:100%}.tier-count{text-align:right;font-variant-numeric:tabular-nums}.tier-pct{color:var(--text-muted);font-size:.75rem}.funnel{display:flex;flex-direction:column;gap:.5rem}.funnel-step{position:relative;background:#ffffff0a;border-radius:6px;overflow:hidden;height:36px;display:flex;align-items:center}.funnel-step-bar{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,#60a5fa66,#60a5fa26);transition:width .3s ease}.funnel-step-text{position:relative;padding:0 .75rem;font-size:.85rem}.funnel-pct{color:var(--text-muted);font-size:.75rem;margin-left:.5rem}.metric-table{width:100%;border-collapse:collapse;font-size:.85rem}.metric-table th,.metric-table td{padding:.4rem .5rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.05)}.metric-table th{color:var(--text-muted);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.metric-table td code{background:#ffffff0d;padding:1px 6px;border-radius:4px;font-size:.8rem}.cohort-table .cohort-cell{text-align:center;font-variant-numeric:tabular-nums}.cohort-table .cohort-cell.empty{color:var(--text-muted);background:transparent!important}.cohort-pct{color:#fff9;font-size:.7rem}.cohort-week{font-variant-numeric:tabular-nums;color:var(--text-muted)}@media(max-width:900px){.metrics-grid{grid-template-columns:1fr}.metric-card-wide{grid-column:span 1}}@media(max-width:768px){.admin-ability-grid{grid-template-columns:repeat(3,1fr)}.admin-kv-grid,.admin-card-grid{grid-template-columns:1fr}.admin-drill-header{flex-direction:column;align-items:flex-start}}.view-homebrew{padding:1.5rem;max-width:1000px;margin:0 auto}.view-homebrew .view-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.85rem}.homebrew-tabs{display:flex;gap:.4rem;border-bottom:2px solid var(--border);padding-bottom:0;margin-bottom:1.25rem;overflow-x:auto}.hb-tab{display:flex;align-items:center;gap:.4rem;padding:.6rem 1rem;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:.8rem;font-weight:600;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s;white-space:nowrap}.hb-tab:hover{color:var(--text-primary);background:var(--bg-hover, rgba(255,255,255,.03))}.hb-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.hb-tab-icon{font-size:1rem}.hb-tab-count{background:var(--bg-tertiary, #1a1a2e);color:var(--text-secondary);font-size:.65rem;padding:.1rem .4rem;border-radius:9999px;min-width:1.2rem;text-align:center}.hb-tab.active .hb-tab-count{background:var(--accent);color:var(--bg-primary, #0d0d1a)}.hb-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.hb-list-header h3{margin:0;font-size:1rem}.hb-count{color:var(--text-muted);font-weight:400}.hb-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.hb-empty-icon{font-size:3rem;display:block;margin-bottom:.75rem;opacity:.3}.hb-list{display:flex;flex-direction:column;gap:.6rem}.hb-item-card{background:var(--bg-secondary, #161625);border:1px solid var(--border);border-radius:var(--radius-sm, 6px);padding:.75rem 1rem;transition:border-color .2s,box-shadow .2s}.hb-item-card:hover{border-color:var(--accent);box-shadow:0 0 12px #f5c51814}.hb-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.35rem}.hb-item-name{font-weight:700;font-size:.9rem}.hb-badge{background:linear-gradient(135deg,#9c27b0,#673ab7);color:#fff;font-size:.6rem;font-weight:700;padding:.15rem .5rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.5px}.hb-item-details{font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem;line-height:1.5}.hb-item-details em{color:var(--text-tertiary, var(--text-secondary));font-style:italic}.hb-item-actions{display:flex;gap:.35rem;justify-content:flex-end}.hb-form-card{background:var(--bg-tertiary, #1a1a2e);border:2px solid var(--accent);border-radius:var(--radius-sm, 6px);padding:1.25rem;margin-bottom:1rem;animation:hb-form-enter .2s ease-out}@keyframes hb-form-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.hb-form-card h4{margin:0 0 1rem;color:var(--accent);font-size:.95rem}.hb-form-fields{display:flex;flex-direction:column;gap:.6rem}.hb-form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.6rem}.hb-form-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border)}.hb-modifiers-section{background:#9c27b00f;border:1px solid rgba(156,39,176,.2);border-radius:var(--radius-sm, 6px);padding:.75rem 1rem}.hb-modifiers-section>label{font-weight:700;font-size:.85rem;margin-bottom:.25rem}.hb-mod-hint{font-size:.7rem;color:var(--text-muted);margin:.15rem 0 .6rem}.hb-auto-label{font-weight:400;font-size:.7rem;color:var(--text-muted)}.hb-mod-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.6rem}.hb-mod-row{display:flex;align-items:center;gap:.4rem;background:var(--bg-secondary, #161625);border:1px solid var(--border);border-radius:var(--radius-sm, 6px);padding:.4rem .5rem;animation:hb-form-enter .15s ease-out}.hb-mod-row .hb-mod-type{flex:0 0 130px;font-size:.75rem;padding:.3rem .4rem}.hb-mod-row .hb-mod-target{flex:0 0 110px;font-size:.75rem;padding:.3rem .4rem}.hb-mod-row .hb-mod-no-target{flex:0 0 110px}.hb-mod-value-wrap{display:flex;align-items:center;gap:.2rem;flex:0 0 90px}.hb-mod-value-wrap .hb-mod-sign{flex:0 0 38px;font-size:.8rem;padding:.3rem .2rem;text-align:center}.hb-mod-value-wrap .hb-mod-val{flex:1;min-width:40px;font-size:.8rem;padding:.3rem .4rem;text-align:center}.hb-mod-remove{flex:0 0 28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;font-size:.75rem;line-height:1;border-radius:4px}#hb-mod-add{width:auto;font-size:.75rem}.view-content-library{padding:1.5rem;max-width:1000px;margin:0 auto}.view-content-library .view-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.85rem}.cl-dropzone{border:2px dashed var(--border);border-radius:var(--radius-sm, 6px);padding:2rem;text-align:center;cursor:pointer;transition:all .3s;background:var(--bg-secondary, #161625)}.cl-dropzone:hover,.cl-dropzone.dragover{border-color:var(--accent);background:#f5c51808;box-shadow:0 0 20px #f5c5180f}.cl-dropzone-icon{font-size:2.5rem;display:block;margin-bottom:.5rem;opacity:.6}.cl-dropzone-text{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.cl-dropzone-hint{font-size:.7rem;color:var(--text-muted)}.cl-upload-options{background:var(--bg-tertiary, #1a1a2e);border:1px solid var(--border);border-radius:var(--radius-sm, 6px);padding:1rem;margin-top:.75rem;display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap;animation:hb-form-enter .2s ease-out}.cl-upload-options .form-group{flex:1;min-width:150px}.cl-upload-actions{display:flex;gap:.5rem;align-items:flex-end}.cl-upload-progress{margin-top:.5rem;width:100%}.cl-progress-bar{height:4px;background:var(--bg-secondary, #161625);border-radius:2px;overflow:hidden}.cl-progress-fill{height:100%;background:var(--accent);width:0%;transition:width .3s}.cl-storage-info{margin:1rem 0}.cl-storage-label{display:flex;justify-content:space-between;font-size:.72rem;color:var(--text-secondary);margin-bottom:.35rem}.cl-storage-bar{height:6px;background:var(--bg-tertiary, #1a1a2e);border-radius:3px;overflow:hidden}.cl-storage-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s}.cl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.cl-file-card{background:var(--bg-secondary, #161625);border:1px solid var(--border);border-radius:var(--radius-sm, 6px);overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .15s}.cl-file-card:hover{border-color:var(--accent);box-shadow:0 4px 16px #0000004d;transform:translateY(-2px)}.cl-file-preview{height:120px;background:var(--bg-tertiary, #1a1a2e);display:flex;align-items:center;justify-content:center;overflow:hidden}.cl-file-thumb{width:100%;height:100%;object-fit:cover}.cl-file-icon{font-size:2.5rem;opacity:.4}.cl-file-info{padding:.6rem .75rem}.cl-file-name{font-weight:700;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.cl-file-meta{display:flex;gap:.5rem;font-size:.65rem;color:var(--text-muted);align-items:center}.cl-file-type-badge{background:var(--bg-tertiary, #1a1a2e);padding:.1rem .35rem;border-radius:3px;font-size:.6rem}.cl-file-desc{font-size:.7rem;color:var(--text-secondary);margin-top:.3rem;line-height:1.3}.cl-file-actions{display:flex;gap:.3rem;padding:.5rem .75rem;border-top:1px solid var(--border);justify-content:flex-end}.cl-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.cl-empty-icon{font-size:3rem;display:block;margin-bottom:.75rem;opacity:.3}@media(max-width:768px){.homebrew-tabs{flex-wrap:nowrap}.hb-tab{padding:.5rem .6rem;font-size:.7rem}.hb-tab-label{display:none}.hb-form-row{grid-template-columns:1fr}.cl-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.cl-upload-options{flex-direction:column;align-items:stretch}}.view-scribe{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;max-width:1400px;width:100%;margin:0 auto;padding:1rem 0 0;color:var(--text-color)}.scribe-header{flex-shrink:0;margin-bottom:1rem}.scribe-tabs{flex-shrink:0;display:flex;gap:1rem;margin-bottom:1rem;border-bottom:1px solid var(--border-color);padding-bottom:1rem;overflow-x:auto}.scribe-tab{background:none;border:none;color:var(--text-color);font-size:1.1rem;cursor:pointer;padding:.75rem 1.25rem;border-radius:var(--radius-md);transition:background .2s,color .2s;white-space:nowrap;display:flex;align-items:center;gap:.5rem}.scribe-tab:hover{background:#ffffff0d}.scribe-tab.active{background:var(--primary-color);color:#fff}.scribe-workspace{display:flex;gap:2rem;flex:1;min-height:0;overflow:hidden}.scribe-controls{flex:0 0 380px;min-height:0;max-height:100%;background:var(--bg-card);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto}.scribe-output{flex:1;min-height:0;display:flex;flex-direction:column;background:var(--bg-card);padding:1.25rem 1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:inset 0 0 20px #0003;font-family:var(--font-serif, serif);overflow:hidden}.scribe-roster-actions{flex-shrink:0;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding-bottom:.75rem;margin-bottom:.75rem;border-bottom:1px solid var(--border-color);font-family:var(--font-body, "Inter", sans-serif);font-size:.9rem}.scribe-roster-actions .btn-secondary{white-space:nowrap}.scribe-output-scroll{flex:1;min-height:0;overflow-y:auto;padding-right:.25rem}.scribe-output-content{white-space:pre-wrap;line-height:1.8;font-size:1.1rem}.scribe-output-content h2{color:var(--primary-color);margin-top:1.5rem;margin-bottom:1rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.scribe-output-content h3{color:var(--text-color);margin-top:1.2rem;margin-bottom:.8rem}.scribe-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:12rem;padding:2rem;color:var(--primary-color)}.scribe-loading-icon{font-size:3rem;animation:scribe-float 2s ease-in-out infinite;margin-bottom:1rem}@keyframes scribe-float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-15px) rotate(10deg)}}.scribe-library-panel{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border-color);flex-shrink:0}.scribe-library-heading{font-family:var(--font-display, "Cinzel", serif);font-size:1rem;margin:0 0 .35rem;color:var(--text-color)}.scribe-library-help{font-size:.85rem;margin:0 0 .75rem;line-height:1.45}.scribe-library-list{margin-top:.75rem;max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.scribe-library-empty{font-size:.85rem;margin:0;line-height:1.45}.scribe-library-row{display:flex;flex-direction:column;gap:.15rem;padding:.45rem .55rem;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:#00000026}.scribe-library-open{display:block;width:100%;text-align:left;background:none;border:none;color:var(--accent, var(--primary-color));font-weight:600;font-size:.9rem;cursor:pointer;padding:0;font-family:inherit}.scribe-library-open:hover{text-decoration:underline}.scribe-library-meta{font-size:.72rem;line-height:1.3}.scribe-library-view-bar{flex-shrink:0;padding-bottom:.75rem;margin-bottom:.75rem;border-bottom:1px solid var(--border-color);font-family:var(--font-body, "Inter", sans-serif)}.scribe-library-view-bar-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.65rem}.scribe-library-view-title{font-weight:600;color:var(--accent, var(--primary-color));font-size:.95rem}.scribe-library-view-actions{display:flex;flex-wrap:wrap;gap:.5rem}.scribe-markdown-editor{width:100%;min-height:280px;resize:vertical;font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:.88rem;line-height:1.45}@media(max-width:900px){.scribe-workspace{flex-direction:column;overflow-y:auto}.scribe-controls{flex:none;width:100%;max-height:45vh}.scribe-output{flex:1;min-height:40vh}}@media(max-width:1024px){.view-header{flex-direction:column;align-items:flex-start;gap:.5rem}.view-header .view-header-right{width:100%;display:flex;flex-wrap:wrap;gap:.4rem}}@media(max-width:860px){.sidebar{width:88px;min-width:88px}.sidebar .sidebar-title,.sidebar .sidebar-subtitle,.sidebar .nav-label,.sidebar .sidebar-calendar,.sidebar .sidebar-user,.sidebar .sidebar-usage{display:none}.sidebar .nav-item{justify-content:center;padding:.55rem .35rem}.sidebar .nav-icon{font-size:1rem}}@media(max-width:720px){.dash-card,.settings-section-card,.sim-card{padding:.75rem!important}.form-row,.sim-config-row{flex-direction:column;align-items:stretch}.form-row>*,.sim-config-row>*{width:100%;min-width:0!important;max-width:100%!important}.btn-primary,.btn-secondary,.btn-danger{width:100%}.srd-table{font-size:.78rem}}
