*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#1c1810;--bg-surface:#221e16;--bg-card:#2a241a;--bg-raised:#322c20;--bg-nav:#13100a;--amber-faint:#c8761417;--amber-glow:#c8761440;--amber-dim:#5e3808;--amber:#c87820;--amber-mid:#d88c30;--amber-bright:#eca84a;--amber-text:#f0b860;--gold-faint:#9a702017;--gold-glow:#9a702038;--gold-dim:#58401a;--gold:#9a7020;--gold-mid:#b08838;--gold-bright:#c89848;--gold-on-dark:#c89848;--cat-free:#2d8a84;--cat-patron:#9a7020;--cat-danger:#8b2222;--cat-soon:#3a3028;--crimson-dim:#4a1515;--crimson:#8b2222;--crimson-mid:#a82828;--crimson-glow:#8b22222e;--forest-dim:#1a3a28;--forest-mid:#2a7a50;--text-bright:#f5eedc;--text-body:#d4be98;--text-muted:#b09878;--text-dim:#887060;--border-faint:#2a2418;--border-base:#3c3426;--border-mid:#4e4232;--border-amber:#6a4010;--border-teal:#1a5050;--border-gold:#58401a;--shadow-sm:0 1px 3px #0006;--shadow-md:0 3px 14px #00000080, 0 1px 4px #0000004d;--shadow-lg:0 6px 28px #0009, 0 2px 8px #0006;--shadow-amber:0 0 18px #c876142e;--shadow-teal:0 0 18px #2d8a822e;--font-display:"Cinzel", "Palatino Linotype", serif;--font-body:"Crimson Pro", "Georgia", serif;--font-ui:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--ease:cubic-bezier(.4, 0, .2, 1);--dur:.18s;--accent:#c87820;--accent-hover:#d88c30;--accent-glow:#c8761440;--border:#302a1c;--bg-primary:#1c1810;--bg-secondary:#221e16;--text-primary:#f5eedc;--text-secondary:#b09878;--shadow-card:0 1px 3px #0006;--teal-faint:#2d8a8217;--teal-on-dark:#5cc8be;--teal-text:#5cc8be}html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--border-mid) transparent}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--border-amber)}a{color:var(--amber-text)}a:visited{color:var(--text-muted)}body{background-color:var(--bg-base);color:var(--text-body);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:16px;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}.ui-btn--icon-only{gap:0;padding:.45rem;line-height:1}.ui-btn--icon-only.btn-sm{padding:.3rem}.btn-reset{cursor:pointer;color:inherit;background:0 0;border:none;justify-content:center;align-items:center;margin:0;padding:0;line-height:1;display:inline-flex}.ui-field{flex-direction:column;gap:0;display:flex}.ui-field-label{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.4rem;font-size:.75rem;display:block}.ui-field-hint{color:var(--text-dim);font-size:.78rem;font-family:var(--font-ui);margin-top:.3rem;line-height:1.45}.ui-field-error{color:var(--crimson-mid);font-size:.78rem;font-family:var(--font-ui);margin-top:.3rem}.field-input--error,.field-textarea--error,.field-select--error{border-color:var(--crimson-mid)}.field-input--error:focus,.field-textarea--error:focus,.field-select--error:focus{border-color:var(--crimson-mid);box-shadow:0 0 0 3px #8b22222e}.ui-checkbox{cursor:pointer;font-family:var(--font-ui);color:var(--text-body);-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.9rem;display:inline-flex}.ui-checkbox input[type=checkbox]{appearance:none;border:1.5px solid var(--border-mid);background:var(--bg-surface);cursor:pointer;width:15px;height:15px;transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease);vertical-align:middle;flex-shrink:0;position:relative}.ui-checkbox input[type=checkbox]:checked{background:var(--amber);border-color:var(--amber);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'%3E%3Cpath d='M2 5l2.5 2.5L8 3' stroke='%231a1208' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-size:100% 100%}.ui-checkbox input[type=checkbox]:focus-visible{outline:1.5px solid var(--amber);outline-offset:2px}.ui-checkbox input[type=checkbox]:disabled{opacity:.4;cursor:not-allowed}.ui-checkbox--disabled{opacity:.5;cursor:not-allowed}.ui-radio-group{flex-direction:column;gap:.5rem;display:flex}.ui-radio-group--row{flex-flow:wrap;gap:.75rem}.ui-radio-item{cursor:pointer;font-family:var(--font-ui);color:var(--text-body);-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.9rem;display:inline-flex}.ui-radio-item input[type=radio]{accent-color:var(--amber);cursor:pointer;flex-shrink:0;width:15px;height:15px}.ui-radio-item input[type=radio]:disabled{opacity:.4;cursor:not-allowed}.ui-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.55rem;display:inline-flex}.ui-toggle-track{background:var(--bg-surface);border:1.5px solid var(--border-mid);width:34px;height:18px;transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease);border-radius:999px;flex-shrink:0;position:relative}.ui-toggle-track--checked{background:var(--amber);border-color:var(--amber-bright)}.ui-toggle-thumb{background:var(--text-dim);width:10px;height:10px;transition:transform var(--dur) var(--ease), background var(--dur) var(--ease);border-radius:50%;position:absolute;top:2px;left:2px}.ui-toggle-track--checked .ui-toggle-thumb{background:#1a0e04;transform:translate(16px)}.ui-toggle-label{font-family:var(--font-ui);color:var(--text-body);font-size:.9rem}.ui-toggle--disabled{opacity:.45;cursor:not-allowed}.ui-slider{flex-direction:column;gap:.35rem;display:flex}.ui-slider-row{align-items:center;gap:.75rem;display:flex}.ui-slider-input{accent-color:var(--amber);cursor:pointer;background:var(--border-mid);appearance:none;border-radius:2px;outline:none;flex:1;height:4px}.ui-slider-input::-webkit-slider-thumb{-webkit-appearance:none;background:var(--amber);border:2px solid var(--amber-bright);cursor:pointer;width:14px;height:14px;box-shadow:0 0 4px var(--amber-glow);border-radius:50%}.ui-slider-input::-moz-range-thumb{background:var(--amber);border:2px solid var(--amber-bright);cursor:pointer;border-radius:50%;width:14px;height:14px}.ui-slider-input:focus-visible{outline:2px solid var(--amber);outline-offset:2px}.ui-slider-value{font-family:var(--font-mono);color:var(--amber-text);text-align:right;min-width:2.5rem;font-size:.82rem}.ui-spinbox{border:1px solid var(--border-mid);background:var(--bg-surface);transition:border-color var(--dur) var(--ease);border-radius:6px;align-items:stretch;display:inline-flex;overflow:hidden}.ui-spinbox:focus-within{border-color:var(--amber);box-shadow:0 0 0 3px #c8761421}.ui-spinbox-btn{background:var(--bg-raised);color:var(--text-muted);cursor:pointer;transition:color var(--dur), background var(--dur);-webkit-user-select:none;user-select:none;border:none;flex-shrink:0;padding:.35rem .6rem;font-size:1rem;line-height:1}.ui-spinbox-btn:hover:not(:disabled){color:var(--amber-text);background:var(--amber-faint)}.ui-spinbox-btn:disabled{opacity:.3;cursor:not-allowed}.ui-spinbox-input{color:var(--text-bright);font-family:var(--font-mono);text-align:center;-moz-appearance:textfield;background:0 0;border:none;outline:none;width:3.5rem;padding:.35rem .4rem;font-size:.95rem}.ui-spinbox-input::-webkit-outer-spin-button{-webkit-appearance:none}.ui-spinbox-input::-webkit-inner-spin-button{-webkit-appearance:none}.ui-search{align-items:center;display:flex;position:relative}.ui-search-icon{color:var(--text-dim);pointer-events:none;align-items:center;font-size:1rem;line-height:1;display:flex;position:absolute;left:.7rem}.ui-search .field-input{padding-left:2.1rem}.ui-search--clearable .field-input{padding-right:2.1rem}.ui-search-clear{color:var(--text-dim);cursor:pointer;transition:color var(--dur);background:0 0;border:none;align-items:center;padding:.2rem;font-size:1rem;line-height:1;display:flex;position:absolute;right:.5rem}.ui-search-clear:hover{color:var(--text-muted)}.ui-autocomplete{position:relative}.ui-autocomplete-dropdown{background:var(--bg-card);border:1px solid var(--border-mid);z-index:100;border-radius:6px;max-height:220px;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto;box-shadow:0 4px 16px #0006}.ui-autocomplete-item{font-family:var(--font-ui);color:var(--text-body);cursor:pointer;transition:background var(--dur), color var(--dur);padding:.5rem .85rem;font-size:.9rem}.ui-autocomplete-item:hover,.ui-autocomplete-item--active{background:var(--amber-faint);color:var(--amber-text)}.ui-autocomplete-empty{color:var(--text-dim);font-size:.85rem;font-family:var(--font-ui);padding:.6rem .85rem}.ui-combobox{position:relative}.ui-combobox-trigger{background:var(--bg-surface);border:1px solid var(--border-mid);width:100%;color:var(--text-bright);font-family:var(--font-ui);cursor:pointer;text-align:left;transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);border-radius:6px;justify-content:space-between;align-items:center;gap:.5rem;padding:.55rem .85rem;font-size:.95rem;display:flex}.ui-combobox-trigger:focus,.ui-combobox-trigger--open{border-color:var(--amber);outline:none;box-shadow:0 0 0 3px #c8761421}.ui-combobox-trigger-value{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.ui-combobox-trigger-value--placeholder{color:var(--text-dim)}.ui-combobox-chevron{color:var(--text-dim);transition:transform var(--dur) var(--ease);flex-shrink:0;font-size:1.1rem}.ui-combobox-trigger--open .ui-combobox-chevron{transform:rotate(180deg)}.ui-combobox-dropdown{background:var(--bg-card);border:1px solid var(--border-mid);z-index:100;border-radius:6px;max-height:260px;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto;box-shadow:0 4px 16px #0006}.ui-combobox-search{border-bottom:1px solid var(--border-base);padding:.4rem .6rem}.ui-combobox-search .field-input{padding:.35rem .65rem;font-size:.875rem}.ui-combobox-option{font-family:var(--font-ui);color:var(--text-body);cursor:pointer;transition:background var(--dur), color var(--dur);padding:.5rem .85rem;font-size:.9rem}.ui-combobox-option:hover,.ui-combobox-option--focused{background:var(--amber-faint);color:var(--amber-text)}.ui-combobox-option--selected{color:var(--amber-text);font-weight:500}.ui-combobox-empty{color:var(--text-dim);padding:.6rem .85rem;font-size:.85rem}.ui-multiselect{position:relative}.ui-multiselect-trigger{background:var(--bg-surface);border:1px solid var(--border-mid);width:100%;color:var(--text-bright);font-family:var(--font-ui);cursor:pointer;text-align:left;transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);border-radius:6px;align-items:center;gap:.4rem;padding:.45rem .75rem;font-size:.9rem;display:flex}.ui-multiselect-trigger:focus,.ui-multiselect-trigger--open{border-color:var(--amber);outline:none;box-shadow:0 0 0 3px #c8761421}.ui-multiselect-trigger--active{border-color:var(--border-amber);color:var(--amber-text)}.ui-multiselect-icon{color:var(--text-dim);flex-shrink:0;font-size:1rem}.ui-multiselect-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.ui-multiselect-chevron{color:var(--text-dim);flex-shrink:0;font-size:1.1rem}.ui-multiselect-dropdown{background:var(--bg-card);border:1px solid var(--border-mid);z-index:100;border-radius:6px;max-height:260px;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto;box-shadow:0 4px 16px #0006}.ui-multiselect-clear{border:none;border-bottom:1px solid var(--border-base);color:var(--text-muted);font-size:.82rem;font-family:var(--font-ui);cursor:pointer;text-align:left;width:100%;transition:color var(--dur);background:0 0;align-items:center;gap:.35rem;padding:.4rem .75rem;display:flex}.ui-multiselect-clear:hover{color:var(--crimson-mid)}.ui-multiselect-item{cursor:pointer;font-family:var(--font-ui);color:var(--text-body);transition:background var(--dur);-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;padding:.45rem .75rem;font-size:.9rem;display:flex}.ui-multiselect-item:hover{background:var(--amber-faint)}.ui-multiselect-item input[type=checkbox]{accent-color:var(--amber);cursor:pointer;flex-shrink:0;width:13px;height:13px}.ui-tag{border:1px solid var(--border-mid);font-family:var(--font-ui);color:var(--text-muted);white-space:nowrap;background:0 0;border-radius:999px;align-items:center;gap:.3rem;padding:.2rem .65rem;font-size:.75rem;font-weight:500;line-height:1.4;display:inline-flex}.ui-tag--amber{border-color:var(--border-amber);color:var(--amber-text);background:var(--amber-faint)}.ui-tag--gold{border-color:var(--cat-patron);color:var(--gold-on-dark);background:#9a702014}.ui-tag--crimson{border-color:var(--crimson-dim);color:var(--crimson-mid);background:#8b222214}.ui-tag--teal{border-color:var(--teal-dim,#1a5a5a);color:var(--teal,#3ab8b8);background:#3ab8b812}.ui-tag--forest{border-color:var(--forest-dim);color:var(--forest-mid);background:#2a7a5014}.ui-tag--dim{border-color:var(--border-base);color:var(--text-dim);background:0 0}.ui-tag-remove{color:inherit;cursor:pointer;opacity:.7;transition:opacity var(--dur);background:0 0;border:none;align-items:center;margin-left:.1rem;padding:0;font-size:.9rem;line-height:1;display:inline-flex}.ui-tag-remove:hover{opacity:1}.ui-badge{font-family:var(--font-ui);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;background:var(--bg-raised);border:1px solid var(--border-mid);color:var(--text-muted);border-radius:999px;padding:.1rem .45rem;font-size:.65rem;font-weight:600;line-height:1.5;display:inline-block}.ui-badge--amber{background:var(--amber-faint);border-color:var(--border-amber);color:var(--amber-text)}.ui-badge--gold{border-color:var(--cat-patron);color:var(--gold-on-dark);background:#9a702026}.ui-badge--crimson{border-color:var(--crimson-dim);color:var(--crimson-mid);background:#8b222226}.ui-badge--teal{border-color:var(--teal-dim,#1a5a5a);color:var(--teal,#3ab8b8);background:#3ab8b81a}.ui-badge--forest{border-color:var(--forest-dim);color:var(--forest-mid);background:#2a7a501a}.ui-tab-bar{border-bottom:1px solid var(--border-mid);gap:0;display:flex}.ui-tab-btn{color:var(--text-muted);cursor:pointer;font-family:var(--font-ui);transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.6rem 1rem;font-size:.875rem;font-weight:500}.ui-tab-btn:hover{color:var(--text-body)}.ui-tab-btn--active{color:var(--amber-text);border-bottom-color:var(--amber);font-weight:600}.ui-tab-btn:disabled{opacity:.35;cursor:not-allowed}.ui-scroll-area{overflow-y:auto}@keyframes ui-spin{to{transform:rotate(360deg)}}.ui-spinner{border:2px solid var(--border-mid);border-top-color:var(--amber);border-radius:50%;flex-shrink:0;animation:.7s linear infinite ui-spin;display:inline-block}.ui-spinner--sm{width:14px;height:14px}.ui-spinner--md{width:22px;height:22px}.ui-spinner--lg{border-width:3px;width:36px;height:36px}.ui-spinner-wrap{color:var(--text-muted);font-size:.875rem;font-family:var(--font-ui);justify-content:center;align-items:center;gap:.6rem;padding:1.5rem;display:flex}@keyframes ui-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.ui-skeleton{background:linear-gradient(90deg, var(--bg-raised) 25%, var(--bg-card) 50%, var(--bg-raised) 75%);background-size:800px 100%;animation:1.4s ease-in-out infinite ui-shimmer;display:block}.ui-skeleton--text{border-radius:2px;height:.9rem;margin-bottom:.4rem}.ui-skeleton--text:last-child{width:70%}.ui-skeleton--card{height:120px}.ui-skeleton-lines{flex-direction:column;display:flex}.ui-empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.6rem;padding:3rem 2rem;display:flex}.ui-empty-state--fill{flex:1;min-height:200px}.ui-empty-state-icon{opacity:.6;font-size:2.25rem;line-height:1}.ui-empty-state-message{font-family:var(--font-ui);color:var(--text-muted);margin:0;font-size:.9rem}.ui-empty-state-action{margin-top:.4rem}.ui-link{color:var(--amber-text);transition:color var(--dur) var(--ease);cursor:pointer;text-decoration:none}.ui-link:hover{color:var(--amber-bright);text-decoration:underline}.ui-link--muted{color:var(--text-muted)}.ui-link--muted:hover{color:var(--amber-text);text-decoration:none}.ui-page{flex-direction:column;height:100vh;display:flex;overflow:hidden}.ui-page-content{flex:1;overflow-y:auto}.ui-page-inner{width:100%;max-width:1100px;margin:0 auto;padding:2.5rem 1.5rem}.ui-page-inner--wide{max-width:none;padding:1.5rem}.blog-card{background:var(--bg-card);border:1px solid var(--border-base);color:inherit;transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);border-radius:0;flex-direction:column;text-decoration:none;display:flex;position:relative;overflow:hidden}.blog-card:hover{background:var(--bg-raised);border-color:var(--amber-mid);box-shadow:0 0 22px var(--amber-glow), var(--shadow-md);transform:translateY(-1px)}.blog-card--featured{border-top:3px solid var(--amber)}.blog-card:before,.blog-card:after{content:"";border-color:var(--border-gold);opacity:.4;pointer-events:none;width:10px;height:10px;transition:opacity var(--dur) var(--ease), border-color var(--dur) var(--ease);z-index:1;border-style:solid;position:absolute}.blog-card:before{border-width:1px 0 0 1px;top:6px;left:6px}.blog-card:after{border-width:0 1px 1px 0;bottom:6px;right:6px}.blog-card:hover:before,.blog-card:hover:after{opacity:1;border-color:var(--amber-mid)}.blog-card__cover{aspect-ratio:16/9;background:var(--bg-raised);border-bottom:1px solid var(--border-base);justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.blog-card--no-cover .blog-card__cover{aspect-ratio:unset;height:52px}.blog-card__cover img{object-fit:cover;width:100%;height:100%;display:block}.blog-card__cover-glyph{color:var(--border-mid);-webkit-user-select:none;user-select:none;font-size:1.6rem}.blog-card__body{flex-direction:column;flex:1;gap:.4rem;padding:.9rem 1rem;display:flex}.blog-card__tags{flex-wrap:wrap;gap:.3rem;display:flex}.blog-card__tag{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.06em;color:var(--amber);background:color-mix(in srgb, var(--amber) 12%, transparent);border:1px solid color-mix(in srgb, var(--amber) 30%, transparent);border-radius:999px;padding:.1em .55em;font-size:.64rem;font-weight:600}.blog-card__title{font-family:var(--font-display);color:var(--text-bright);margin:0;font-size:.92rem;font-weight:600;line-height:1.3}.blog-card__excerpt{color:var(--text-muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;margin:0;font-size:.88rem;line-height:1.5;display:-webkit-box;overflow:hidden}.blog-card__meta{font-family:var(--font-ui);color:var(--text-dim);margin-top:auto;font-size:.72rem}.blog-carousel{margin-top:3rem}.blog-carousel__track{background:var(--border-base);border:1px solid var(--border-base);scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;gap:1px;display:flex;overflow-x:auto}.blog-carousel__track::-webkit-scrollbar{display:none}.blog-carousel__track .blog-card{scroll-snap-align:start;border:none;flex-shrink:0;width:260px}.blog-carousel__skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, var(--bg-raised) 50%, var(--bg-card) 75%);background-size:200% 100%;flex-shrink:0;width:260px;height:240px;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.blog-carousel__footer{justify-content:flex-end;padding:.5rem 0;display:flex}.blog-carousel__view-all{font-family:var(--font-ui);color:var(--amber-text);letter-spacing:.03em;font-size:.8rem;text-decoration:none}.blog-carousel__view-all:hover{color:var(--amber-bright);text-decoration:underline}.wg-page{flex-direction:column;gap:2rem;max-width:1040px;margin:2rem auto;padding:0 2rem 4rem;display:flex}.wg-header h1{font-family:var(--font-display);color:var(--gold-on-dark);letter-spacing:.05em;margin-bottom:.4rem;font-size:2rem}.wg-header p{color:var(--text-muted);font-size:.95rem}.wg-layout{grid-template-columns:340px 1fr;align-items:start;gap:2rem;display:grid}@media (width<=700px){.wg-layout{grid-template-columns:1fr}}.wg-config{flex-direction:column;gap:1.5rem;display:flex}.wg-section{flex-direction:column;gap:.6rem;display:flex}.wg-section-label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);border-bottom:1px solid var(--border-base);padding-bottom:.4rem;font-size:.72rem}.wg-hint{color:var(--text-dim);font-size:.82rem;line-height:1.5}.wg-hint code{font-family:var(--font-mono);background:var(--bg-raised);color:var(--amber-text);padding:.1em .35em;font-size:.88em}.wg-input{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-bright);font-size:.95rem;font-family:var(--font-mono);width:100%;transition:border-color var(--dur), box-shadow var(--dur);border-radius:0;outline:none;padding:.5rem .75rem}.wg-input:focus{border-color:var(--amber);box-shadow:0 0 0 3px #c8761421}.wg-input::placeholder{color:var(--text-dim);font-family:var(--font-ui)}.wg-formula-input{letter-spacing:.06em;font-size:1.1rem}.wg-letter-input{text-align:center;text-transform:uppercase;width:52px;font-size:1rem;font-family:var(--font-display)}.wg-count-input{text-align:center;width:68px}.wg-groups{flex-wrap:wrap;gap:.5rem;display:flex}.wg-group{background:var(--bg-card);border:1px solid var(--border-mid);border-left:3px solid var(--amber);flex-direction:column;flex:1;gap:.4rem;min-width:130px;padding:.6rem .75rem;display:flex}.wg-group--error{border-left-color:var(--crimson)}.wg-group-header{justify-content:space-between;align-items:center;display:flex}.wg-group-letter{font-family:var(--font-display);color:var(--amber-text);letter-spacing:.05em;font-size:1rem;font-weight:700}.wg-group--error .wg-group-letter{color:var(--crimson-mid)}.wg-remove-btn{color:var(--text-dim);cursor:pointer;transition:color var(--dur);background:0 0;border:none;padding:0 .1rem;font-size:1.1rem;line-height:1}.wg-remove-btn:hover{color:var(--crimson-mid)}.wg-add-group{align-items:center;gap:.5rem;display:flex}.wg-generate-section{border-top:1px solid var(--border-base);padding-top:1rem}.wg-generate-row{align-items:center;gap:.75rem;display:flex}.wg-count-field{align-items:center;gap:.4rem;display:flex}.wg-count-label{color:var(--text-muted);font-size:.85rem}.wg-perms{color:var(--text-dim);font-size:.82rem}.wg-error{color:var(--crimson-mid);font-size:.875rem}.wg-results-panel{flex-direction:column;gap:.75rem;display:flex}.wg-results-header{border-bottom:1px solid var(--border-base);align-items:baseline;gap:.75rem;padding-bottom:.5rem;display:flex}.wg-results-count{font-family:var(--font-display);color:var(--gold-on-dark);letter-spacing:.05em;text-transform:uppercase;font-size:.85rem}.wg-results-note{color:var(--text-dim);font-size:.78rem}.wg-results-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.35rem;display:grid}.wg-results-grid span{background:var(--bg-surface);border:1px solid var(--border-mid);text-align:center;font-family:var(--font-body);color:var(--text-bright);overflow-wrap:break-word;min-width:0;padding:.3rem .5rem;font-size:1rem}.wg-attribution{color:var(--text-dim);font-size:.82rem}.wg-attribution a{color:var(--amber-text)}.listener-banner{background:var(--bg-card);border:1px solid var(--amber);color:var(--text-muted);align-items:center;gap:.75rem;margin-bottom:1.25rem;padding:.6rem 1rem;font-size:.88rem;display:flex}.listener-banner .material-symbols-rounded{color:var(--amber);flex-shrink:0;font-size:1.1rem}.listener-banner span strong{color:var(--text-bright);letter-spacing:.05em}.listener-start-btn{border:1px solid var(--amber);background:var(--amber-faint);color:var(--text-bright);cursor:pointer;transition:all var(--dur);border-radius:999px;align-items:center;gap:.3rem;margin-left:auto;padding:.3rem .85rem;font-size:.82rem;display:flex}.listener-start-btn .material-symbols-rounded{font-size:.95rem}.listener-start-btn:hover{background:var(--amber);color:#1a0e04}.listener-solo-btn{border:1px solid var(--border-mid);color:var(--text-muted);cursor:pointer;transition:all var(--dur);background:0 0;border-radius:999px;align-items:center;gap:.3rem;padding:.3rem .85rem;font-size:.82rem;display:flex}.listener-solo-btn .material-symbols-rounded{color:inherit;font-size:.95rem}.listener-solo-btn:hover{border-color:var(--border-amber);color:var(--text-body)}.main-content:has(.music-player){max-width:100%;padding:0;overflow:hidden}body:has(.music-player) .footer{display:none}.music-player{flex-direction:column;height:100%;display:flex;overflow:hidden}.music-player-body{flex:1;align-items:stretch;gap:2rem;min-height:0;padding:1.5rem;display:flex;overflow:hidden}.music-left-col{flex-direction:column;flex-shrink:0;gap:1.5rem;width:400px;min-height:0;display:flex;overflow-y:auto}.music-library{flex-direction:column;min-height:0;display:flex}.tag-combobox{margin-bottom:.5rem;position:relative}.tag-combobox-trigger{background:var(--bg-surface);border:1px solid var(--border-mid);width:100%;color:var(--text-muted);cursor:pointer;text-align:left;transition:border-color var(--dur), color var(--dur);border-radius:0;align-items:center;gap:.4rem;padding:.4rem .6rem;font-size:.85rem;display:flex}.tag-combobox-trigger:hover{border-color:var(--border-amber);color:var(--text-body)}.tag-combobox-trigger.active{border-color:var(--amber);color:var(--amber-text)}.tag-combobox-icon{flex-shrink:0;font-size:.95rem}.tag-combobox-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.tag-combobox-chevron{flex-shrink:0;font-size:1rem}.tag-combobox-dropdown{z-index:100;background:var(--bg-raised);border:1px solid var(--border-amber);border-top:none;flex-direction:column;max-height:220px;display:flex;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.tag-combobox-clear{text-align:left;border:none;border-bottom:1px solid var(--border-base);color:var(--amber-text);cursor:pointer;transition:background var(--dur);background:0 0;align-items:center;gap:.3rem;padding:.35rem .6rem;font-size:.78rem;display:flex}.tag-combobox-clear .material-symbols-rounded{font-size:.85rem}.tag-combobox-clear:hover{background:var(--amber-faint)}.tag-combobox-item{cursor:pointer;color:var(--text-body);transition:background var(--dur);align-items:center;gap:.5rem;padding:.35rem .6rem;font-size:.85rem;display:flex}.tag-combobox-item:hover{background:var(--bg-card)}.tag-combobox-item.checked{color:var(--amber-text)}.tag-combobox-item input[type=checkbox]{accent-color:var(--amber);flex-shrink:0}.music-search-toggle{border:1px solid var(--border-mid);color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all var(--dur);background:0 0;border-radius:999px;align-items:center;gap:.3rem;padding:.25rem .65rem .25rem .45rem;font-size:.8rem;display:flex}.music-search-toggle:hover{border-color:var(--border-amber);color:var(--text-body)}.music-search-toggle.active{background:var(--amber-faint);border-color:var(--amber);color:var(--amber-text)}.music-toggle-icon{font-size:1rem;line-height:1}.music-search-row{align-items:center;gap:.4rem;margin-bottom:.75rem;display:flex}.music-search-row .music-search{margin-bottom:0}.music-search{background:var(--bg-surface);width:100%;color:var(--text-bright);border:1px solid var(--border-mid);border-radius:0;flex:1;margin-bottom:.75rem;padding:.4rem .75rem;font-size:.88rem}.music-search::placeholder{color:var(--text-dim)}.music-search:focus{border-color:var(--amber);outline:none;box-shadow:0 0 0 3px #c8761421}.music-song-list-panel{border:1px solid var(--border-base);overflow:hidden}.music-song-list>li+li .music-album-heading{border-top:2px solid var(--border-mid)}.music-album-heading{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--bg-nav);border-bottom:1px solid var(--border-base);padding:.55rem .75rem .3rem;font-size:.72rem}.music-song-list{margin:0;padding:0;list-style:none}.music-song-item{border-bottom:1px solid var(--border-faint);background:var(--bg-surface);cursor:pointer;transition:background var(--dur), border-left-color var(--dur);border-left:2px solid #0000;align-items:center;padding:.55rem .75rem;display:flex}.music-song-item:last-child{border-bottom:none}.music-song-item:after{content:"chevron_right";color:#0000;text-align:center;flex-shrink:0;width:1rem;margin-left:auto;padding-left:.25rem;font-family:Material Symbols Rounded;font-size:1rem}.music-song-item:hover{background:var(--bg-card);border-left-color:var(--border-amber)}.music-song-item:hover:after{color:var(--text-dim)}.music-song-item.active{background:var(--bg-raised);border-left-color:var(--amber)}.music-song-item.active:after{content:"music_note";color:var(--amber)}.music-song-item .song-title{color:var(--text-bright);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.92rem;overflow:hidden}.music-song-item.active .song-title{color:var(--amber-text)}.music-song-item.locked{opacity:.55}.music-song-item.locked .song-title{color:var(--text-muted)}.song-lock-icon{color:var(--text-dim);flex-shrink:0;margin-right:.3rem;font-size:.85rem}.audio-bar-lock-icon{color:var(--text-dim);flex-shrink:0;font-size:1.3rem}.music-song-item .song-album{color:var(--text-muted);margin-top:.1rem;font-size:.78rem}.music-song-item .song-lyric-match{color:var(--amber-text);white-space:nowrap;text-overflow:ellipsis;cursor:pointer;margin-top:.2rem;font-size:.78rem;font-style:italic;overflow:hidden}.music-song-item .song-lyric-match:hover{text-decoration:underline}.song-locked-notice{background:var(--bg-card);border:1px solid var(--border-mid);border-left:3px solid var(--gold-dim);color:var(--text-muted);flex-shrink:0;align-items:center;gap:.5rem;padding:.55rem .75rem;font-size:.85rem;display:flex}.song-locked-notice .material-symbols-rounded{color:var(--text-dim);flex-shrink:0;font-size:1rem}.song-locked-notice a,.song-locked-signin{color:var(--amber-text);cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0;font-family:inherit;text-decoration:none}.song-locked-notice a:hover,.song-locked-signin:hover{text-decoration:underline}.now-playing{flex-direction:column;flex:1;gap:1rem;min-width:0;min-height:0;display:flex;overflow:hidden}.audio-bar{z-index:100;background:var(--bg-nav);border-top:1px solid var(--border-mid);grid-template-columns:1fr 2fr 1fr;align-items:center;gap:1.5rem;height:64px;padding:0 1.5rem;display:grid;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 24px #00000080}.audio-bar-info{align-items:center;gap:.75rem;min-width:0;display:flex}.audio-bar-art{object-fit:cover;border:1px solid var(--border-mid);flex-shrink:0;width:52px;height:52px}.audio-bar-art--empty{background:var(--bg-card);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.audio-bar-art--empty .material-symbols-rounded{font-size:1.5rem}.audio-bar-meta{min-width:0}.audio-bar-title{color:var(--text-bright);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;overflow:hidden}.audio-bar-artist{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.audio-bar-center{flex-direction:row;align-items:center;gap:.75rem;display:flex}.audio-bar-scrubber{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.audio-bar-scrubber .scrubber{flex:1}.audio-bar-time{color:var(--text-dim);font-size:.7rem;font-family:var(--font-mono);white-space:nowrap;flex-shrink:0}.audio-bar-right{justify-content:flex-end;align-items:center;display:flex}.scrubber{width:100%;accent-color:var(--amber);cursor:pointer}.scrubber:disabled{cursor:default;opacity:.5}.time-display{color:var(--text-muted);justify-content:space-between;margin-top:.2rem;margin-bottom:.75rem;font-size:.78rem;display:flex}.playback-controls{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.play-btn{background:var(--amber);color:#1a0e04;cursor:pointer;width:2.5rem;height:2.5rem;transition:filter var(--dur), transform .1s;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.play-btn:hover:not(:disabled){filter:brightness(1.12);transform:scale(1.07)}.play-btn:disabled{opacity:.4;cursor:default;transform:none}.play-btn .material-symbols-rounded{font-size:1.4rem;line-height:1}.volume-control{align-items:center;gap:.4rem;display:flex}.volume-icon-btn{cursor:pointer;color:var(--text-muted);transition:color var(--dur);background:0 0;border:none;align-items:center;padding:0;display:flex}.volume-icon-btn:hover{color:var(--text-body)}.volume-icon{font-size:1.1rem}.volume-slider{width:80px;accent-color:var(--amber)}.lyrics-section{flex-direction:column;flex:1;gap:.5rem;min-height:0;display:flex}.lyric-editor-link{color:var(--text-muted);border:1px solid var(--border-base);background:var(--bg-card);transition:color var(--dur), border-color var(--dur);border-radius:999px;align-self:flex-start;align-items:center;gap:.3rem;padding:.25rem .6rem .25rem .4rem;font-size:.78rem;text-decoration:none;display:inline-flex}.lyric-editor-link .material-symbols-rounded{font-size:.9rem}.lyric-editor-link:hover{color:var(--amber-text);border-color:var(--border-amber)}.lyrics-scroll-wrap{flex:1;min-height:0;position:relative}.lyrics-scroll-wrap:before,.lyrics-scroll-wrap:after{content:"";pointer-events:none;z-index:1;opacity:0;height:48px;transition:opacity .2s;position:absolute;left:0;right:0}.lyrics-scroll-wrap:before{background:linear-gradient(to bottom, var(--bg-base), transparent);top:0}.lyrics-scroll-wrap:after{background:linear-gradient(to top, var(--bg-base), transparent);bottom:0}.lyrics-scroll-wrap.fade-top:before,.lyrics-scroll-wrap.fade-bottom:after{opacity:1}.lyrics-panel{overscroll-behavior:contain;height:100%;padding:0 .25rem;overflow-y:auto}.lyric-line{min-height:1.2em;transition:color var(--dur);color:var(--text-body);margin:.3rem 0}.lyric-line.past{color:var(--text-muted)}.lyric-line.active{color:var(--amber-text);font-weight:700}.session-panel{background:var(--bg-card);border:1px solid var(--border-mid);padding:1rem}.session-panel-header{color:var(--text-muted);align-items:center;gap:.4rem;margin-bottom:.75rem;display:flex}.session-panel-header .material-symbols-rounded{font-size:1rem}.session-panel-title{text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}.session-status{color:var(--text-muted);align-items:center;gap:.4rem;font-size:.88rem;display:flex}.session-spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.session-start-btn{border:1px solid var(--amber);background:var(--amber-faint);color:var(--text-bright);cursor:pointer;transition:all var(--dur);border-radius:999px;align-items:center;gap:.4rem;padding:.45rem 1rem;font-size:.9rem;display:flex}.session-start-btn .material-symbols-rounded{font-size:1rem}.session-start-btn:hover{background:var(--amber);color:#1a0e04}.session-active{flex-direction:column;gap:.6rem;display:flex}.session-code-row{align-items:center;gap:.75rem;display:flex}.session-code{font-family:var(--font-mono);letter-spacing:.15em;color:var(--text-bright);background:var(--bg-surface);border:1px solid var(--border-mid);padding:.25rem .6rem;font-size:1.1rem}.session-copy-btn{border:1px solid var(--border-mid);color:var(--text-muted);cursor:pointer;transition:all var(--dur);background:0 0;border-radius:999px;align-items:center;gap:.3rem;padding:.3rem .85rem;font-size:.82rem;display:flex}.session-copy-btn .material-symbols-rounded{font-size:.95rem}.session-copy-btn:hover{border-color:var(--border-amber);color:var(--text-body)}.session-listeners{color:var(--text-muted);align-items:center;gap:.35rem;font-size:.85rem;display:flex}.session-listeners .material-symbols-rounded{font-size:1rem}.soundboard-heading{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.75rem;font-size:.72rem}.sfx-category{margin-bottom:1rem}.sfx-category-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.4rem;font-size:.72rem}.sfx-buttons{flex-wrap:wrap;gap:.4rem;display:flex}.sfx-button{border:1px solid var(--border-mid);background:var(--bg-card);min-width:72px;color:var(--text-body);cursor:pointer;transition:border-color var(--dur), color var(--dur), background var(--dur);border-radius:0;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;padding:.55rem .85rem;font-size:.82rem;display:flex}.sfx-button:hover{border-color:var(--amber);background:var(--amber-faint);color:var(--amber-text)}.sfx-button:active{background:var(--amber-glow)}.sfx-button-icon{font-size:1.3rem;line-height:1}.sfx-button-label{line-height:1}.music-library-admin{background:var(--bg-card);border:1px solid var(--border-amber);border-left:3px solid var(--amber-dim);justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.4rem .6rem;display:flex}.music-library-admin-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);white-space:nowrap;align-items:center;gap:.3rem;font-size:.72rem;display:flex}.music-library-admin-label .material-symbols-rounded{color:var(--amber-dim);font-size:.95rem}.music-library-admin-actions{gap:.4rem;display:flex}.lyric-editor{max-width:740px;margin:2rem auto;padding:0 2rem 4rem}.lyric-editor-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.lyric-editor-header h1{font-family:var(--font-display);color:var(--gold-on-dark);letter-spacing:.05em;margin:0}.lyric-editor-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.lyric-editor-actions--bottom{border-top:1px solid var(--border-base);margin-top:1.25rem;padding-top:1rem}.lyric-editor-section{margin-bottom:1.5rem}.lyric-editor-label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem;display:block}.lyric-editor-select{background:var(--bg-surface);color:var(--text-bright);border:1px solid var(--border-mid);cursor:pointer;min-width:280px;transition:border-color var(--dur), box-shadow var(--dur);border-radius:0;outline:none;padding:.5rem .75rem;font-size:.95rem}.lyric-editor-select:focus{border-color:var(--amber);box-shadow:0 0 0 3px #c8761421}.lyric-editor-scrubber{width:100%;accent-color:var(--amber);cursor:pointer}.lyric-editor-time-row{color:var(--text-muted);justify-content:space-between;align-items:center;margin-top:.35rem;font-size:.8rem;display:flex}.lyric-editor-textarea{background:var(--bg-surface);width:100%;color:var(--text-bright);border:1px solid var(--border-mid);resize:vertical;box-sizing:border-box;transition:border-color var(--dur), box-shadow var(--dur);border-radius:0;outline:none;padding:.75rem;font-family:inherit;font-size:.95rem}.lyric-editor-textarea::placeholder{color:var(--text-dim)}.lyric-editor-textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px #c8761421}.lyric-editor-hint{color:var(--text-muted);margin-bottom:.75rem;font-size:.85rem}.lyric-stamp-list{flex-direction:column;gap:2px;display:flex}.lyric-stamp-line{cursor:pointer;transition:background var(--dur);border:1px solid #0000;align-items:center;gap:1rem;padding:.4rem .6rem;display:flex}.lyric-stamp-line:hover{background:var(--bg-card);border-color:var(--border-base)}.lyric-stamp-line--stamped{background:var(--bg-card)}.lyric-stamp-time{font-variant-numeric:tabular-nums;min-width:52px;color:var(--border-mid);font-size:.75rem}.lyric-stamp-line--stamped .lyric-stamp-time{color:var(--amber-text)}.lyric-stamp-text{color:var(--text-body);font-size:.95rem}.lyric-stamp-text--blank{color:var(--text-muted);font-style:italic}.lyric-save-status{font-size:.85rem}.lyric-save-status--ok{color:var(--amber-text)}.lyric-save-status--err{color:var(--crimson-mid)}.plans-page{text-align:center;max-width:960px;margin:2rem auto;padding:1rem 2rem}.plans-header h1{font-family:var(--font-display);color:var(--gold-on-dark);letter-spacing:.05em;margin-bottom:.5rem;font-size:2rem}.plans-header p{color:var(--text-muted);margin-bottom:2.5rem}.plans-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:start;gap:1px;padding-top:1rem;display:grid}.plan-card{background:var(--bg-card);border-top:3px solid var(--border-mid);text-align:left;border-radius:0;flex-direction:column;gap:1rem;padding:2rem 1.5rem;display:flex;position:relative}.plan-card--featured{border-top-color:var(--amber);box-shadow:inset 0 0 0 1px var(--border-amber)}.plan-card--featured:before,.plan-card--featured:after{content:"";border-color:var(--amber-mid);opacity:.6;pointer-events:none;border-style:solid;width:10px;height:10px;position:absolute}.plan-card--featured:before{border-width:1px 0 0 1px;top:6px;left:6px}.plan-card--featured:after{border-width:0 1px 1px 0;bottom:6px;right:6px}.plan-card--current{border-top-color:var(--gold)}.plan-badge{background:var(--amber-bright);color:#1a0e04;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap;border-radius:999px;padding:.25rem .9rem;font-size:.72rem;font-weight:700;position:absolute;top:-.8rem;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0006}.plan-badge--current{background:var(--text-bright);color:#1a0e04}.plan-name{font-family:var(--font-display);letter-spacing:.05em;color:var(--text-bright);font-size:1.1rem;font-weight:600}.plan-price-amount{font-family:var(--font-display);color:var(--gold-on-dark);font-size:2rem;font-weight:700}.plan-price-period{color:var(--text-muted);font-size:.85rem}.plan-description{color:var(--text-muted);margin:0;font-size:.9rem}.plan-features{flex-direction:column;flex:1;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.plan-features li{color:var(--text-body);font-size:.9rem}.plan-features li:before{content:"✦ ";color:var(--amber);font-size:.7rem}.plan-cta{margin-top:.5rem}.plan-cta .btn-primary{text-align:center;width:100%;padding:.6rem 1rem;text-decoration:none;display:block}.plan-current-label{text-align:center;color:var(--gold-on-dark);border:1px solid var(--gold-dim);padding:.6rem;font-size:.85rem;display:block}.plans-contact{color:var(--text-muted);margin-top:2.5rem;font-size:.9rem}.plans-contact a{color:var(--amber-text)}.plans-current-banner{background:var(--bg-card);border:1px solid var(--border-mid);color:var(--text-muted);align-items:center;gap:.5rem;margin-top:.5rem;margin-bottom:3rem;padding:.6rem 1.25rem;font-size:.9rem;display:inline-flex}.plans-current-banner strong{color:var(--gold-on-dark)}.admin-page{max-width:900px;margin:2rem auto;padding:1rem 2rem}.admin-page h1{font-family:var(--font-display);color:var(--gold-on-dark);letter-spacing:.05em;margin-bottom:.25rem}.admin-count{color:var(--text-muted);margin-bottom:1.5rem;font-size:.85rem}.admin-status{text-align:center;color:var(--text-muted);margin-top:4rem}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th{text-align:left;border-bottom:1px solid var(--border-mid);color:var(--text-muted);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;padding:.6rem .75rem;font-size:.7rem;font-weight:600}.admin-table td{border-bottom:1px solid var(--border-base);color:var(--text-body);padding:.6rem .75rem}.admin-table tr:hover td{background:#c876140a}.admin-tier-select{background:var(--bg-surface);color:var(--text-bright);border:1px solid var(--border-mid);cursor:pointer;transition:border-color var(--dur);border-radius:0;outline:none;padding:.25rem .5rem;font-size:.85rem}.admin-tier-select:focus{border-color:var(--amber)}.admin-tier-select:disabled{opacity:.5}.admin-header-row{justify-content:space-between;align-items:center;margin-bottom:.25rem;display:flex}.admin-upload{max-width:800px;margin:2rem auto;padding:0 2rem 4rem}.admin-upload-header{margin-bottom:2rem}.admin-upload-header h1{font-family:var(--font-display);color:var(--gold-on-dark);letter-spacing:.05em;margin:0}.admin-upload-form{flex-direction:column;gap:1.25rem;display:flex}.upload-row{flex-wrap:wrap;gap:1rem;display:flex}.upload-field{flex-direction:column;gap:.4rem;display:flex}.upload-field--grow{flex:1;min-width:180px}.upload-field label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.75rem}.upload-hint{font-family:var(--font-ui);text-transform:none;letter-spacing:0;opacity:.7;font-size:.75rem}.upload-input,.upload-select,.upload-textarea{background:var(--bg-surface);color:var(--text-bright);border:1px solid var(--border-mid);box-sizing:border-box;width:100%;transition:border-color var(--dur), box-shadow var(--dur);border-radius:0;outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.9rem}.upload-input:focus,.upload-select:focus,.upload-textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px #c8761421}.upload-input::placeholder,.upload-textarea::placeholder{color:var(--text-dim)}.upload-input--mono{font-family:var(--font-mono);font-size:.85rem}.upload-input:disabled,.upload-select:disabled,.upload-textarea:disabled{opacity:.5;cursor:not-allowed}.upload-textarea{resize:vertical}.upload-file-input{color:var(--text-muted);cursor:pointer;font-size:.85rem}.upload-file-input:disabled{opacity:.5;cursor:not-allowed}.upload-footer{border-top:1px solid var(--border-base);justify-content:flex-end;align-items:center;gap:1rem;padding-top:.5rem;display:flex}.upload-status{color:var(--text-muted);font-size:.85rem}.upload-status--done{color:var(--amber-text)}.upload-status--error{color:var(--crimson-mid)}.admin-sfx{max-width:860px;margin:2rem auto;padding:0 2rem 4rem}.admin-sfx h1{font-family:var(--font-display);color:var(--gold-on-dark);letter-spacing:.05em;margin-bottom:1.5rem}.admin-sfx-section{background:var(--bg-card);border:1px solid var(--border-mid);border-radius:0;margin-bottom:1.5rem;padding:1.5rem}.admin-sfx-section h2{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;color:var(--amber-text);margin:0 0 1.25rem;font-size:.75rem}.sfx-upload-form{flex-direction:column;gap:1rem;display:flex}.sfx-upload-row{flex-wrap:wrap;gap:1rem;display:flex}.sfx-upload-field{flex-direction:column;gap:.4rem;min-width:160px;display:flex}.sfx-upload-field--grow{flex:1}.sfx-upload-field label{color:var(--text-muted);font-size:.8rem}.sfx-upload-footer{justify-content:flex-end;align-items:center;gap:1rem;display:flex}.admin-sfx-category{margin-bottom:1.25rem}.admin-sfx-category-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.5rem;font-size:.72rem}.admin-sfx-row{border-bottom:1px solid var(--border-base);flex-wrap:wrap;align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.admin-sfx-label{min-width:120px;color:var(--text-body);flex:1;font-size:.9rem}.admin-sfx-preview{min-width:160px;height:28px;accent-color:var(--amber);flex:2}.btn-danger.btn-sm{padding:.25rem .6rem;font-size:.8rem}.admin-vtt-wrap{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 4rem}.admin-vtt-title{font-family:var(--font-display);color:var(--amber-text);margin-bottom:2rem;font-size:1.6rem}.admin-vtt-layout{grid-template-columns:480px 1fr;align-items:start;gap:2.5rem;display:grid}@media (width<=900px){.admin-vtt-layout{grid-template-columns:1fr}}.admin-vtt-form{background:var(--bg-card);border:1px solid var(--border-base);flex-direction:column;gap:1.1rem;padding:1.5rem;display:flex}.admin-vtt-label{font-family:var(--font-ui);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;flex-direction:column;gap:.4rem;font-size:.8rem;display:flex}.admin-vtt-input,.admin-vtt-select{background:var(--bg-surface);border:1px solid var(--border-base);color:var(--text-bright);font-family:var(--font-ui);border-radius:0;outline:none;width:100%;padding:.5rem .7rem;font-size:.9rem}.admin-vtt-input:focus,.admin-vtt-select:focus{border-color:var(--amber)}.admin-vtt-file{color:var(--text-muted);font-size:.82rem}.admin-vtt-hint{color:var(--text-dim);text-transform:none;letter-spacing:0;font-size:.75rem;font-style:italic}.admin-vtt-color-row{align-items:center;gap:.7rem;display:flex}.admin-vtt-color{border:1px solid var(--border-base);cursor:pointer;background:0 0;width:2.5rem;height:2rem;padding:0}.admin-vtt-glsl{background:var(--bg-surface);border:1px solid var(--border-base);color:var(--text-body);font-family:var(--font-mono);resize:vertical;border-radius:0;outline:none;width:100%;padding:.6rem .8rem;font-size:.78rem;line-height:1.5}.admin-vtt-glsl:focus{border-color:var(--amber)}.vtt-anim-states{flex-direction:column;gap:.4rem;margin-top:.2rem;display:flex}.vtt-anim-row{align-items:center;gap:.4rem;display:flex}.vtt-anim-input{background:var(--bg-surface);border:1px solid var(--border-base);color:var(--text-bright);font-family:var(--font-ui);outline:none;flex:1;padding:.35rem .5rem;font-size:.85rem}.vtt-anim-index{background:var(--bg-surface);border:1px solid var(--border-base);width:4rem;color:var(--text-bright);font-family:var(--font-mono);text-align:center;outline:none;padding:.35rem .5rem;font-size:.85rem}.vtt-anim-remove{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0 .3rem;font-size:1.1rem;line-height:1}.vtt-anim-remove:hover{color:var(--text-bright)}.vtt-anim-add{border:1px dashed var(--border-mid);color:var(--amber);font-family:var(--font-ui);cursor:pointer;letter-spacing:.04em;background:0 0;align-self:flex-start;padding:.3rem .7rem;font-size:.78rem}.vtt-anim-add:hover{border-color:var(--amber)}.vtt-tag-input{background:var(--bg-surface);border:1px solid var(--border-base);flex-wrap:wrap;align-items:center;gap:.35rem;min-height:2.2rem;padding:.4rem .6rem;display:flex}.vtt-tag-input:focus-within{border-color:var(--amber)}.vtt-tag-input input{color:var(--text-bright);font-family:var(--font-ui);background:0 0;border:none;outline:none;flex:1;min-width:8rem;font-size:.85rem}.vtt-tag-pill{background:var(--bg-raised);border:1px solid var(--border-mid);color:var(--amber-text);font-size:.75rem;font-family:var(--font-ui);border-radius:999px;align-items:center;gap:.3rem;padding:.15rem .5rem;display:flex}.vtt-tag-pill button{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0;font-size:.9rem;line-height:1}.vtt-tag-pill button:hover{color:var(--text-bright)}.admin-vtt-status{font-family:var(--font-ui);margin:0;font-size:.85rem}.admin-vtt-status.is-ok{color:#6dbf6d}.admin-vtt-status.is-error{color:#e05555}.admin-vtt-form-actions{justify-content:flex-end;gap:.6rem;display:flex}.admin-vtt-right{flex-direction:column;display:flex}.admin-vtt-preview{background:var(--bg-surface);border:1px solid var(--border-base);justify-content:center;align-items:center;height:280px;margin-top:.5rem;display:flex}.admin-vtt-preview-empty{color:var(--text-dim);font-family:var(--font-ui);font-size:.85rem}.admin-vtt-capture-row{align-items:center;gap:.6rem;margin-top:.5rem;display:flex}.admin-vtt-captured-thumb{object-fit:cover;border:1px solid var(--amber);width:48px;height:48px}.admin-vtt-capture-clear{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0 .2rem;font-size:1.1rem;line-height:1}.admin-vtt-capture-clear:hover{color:var(--text-bright)}.admin-vtt-list{border:1px solid var(--border-base);flex-direction:column;gap:0;margin-top:.5rem;display:flex}.admin-vtt-empty{color:var(--text-dim);font-family:var(--font-ui);padding:1rem;font-size:.85rem}.admin-vtt-row{border-bottom:1px solid var(--border-base);background:var(--bg-card);align-items:center;gap:.8rem;padding:.6rem .8rem;display:flex}.admin-vtt-row:last-child{border-bottom:none}.admin-vtt-row:hover{background:var(--bg-raised)}.admin-vtt-thumb{object-fit:cover;border:1px solid var(--border-base);flex-shrink:0;width:48px;height:48px}.admin-vtt-thumb-placeholder{background:var(--bg-surface);border:1px solid var(--border-base);flex-shrink:0;width:48px;height:48px}.admin-vtt-row-info{flex-direction:column;flex:1;gap:.1rem;display:flex}.admin-vtt-row-name{color:var(--text-bright);font-family:var(--font-ui);font-size:.9rem}.admin-vtt-row-type{color:var(--amber);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}.admin-vtt-row-tags{color:var(--text-dim);font-size:.78rem;font-family:var(--font-ui)}.admin-vtt-row-actions{gap:.3rem;display:flex}.admin-vtt-collision{margin-top:.4rem}.admin-vtt-collision-toggle{font-family:var(--font-ui);color:var(--text-body);cursor:pointer;align-items:center;gap:.5rem;font-size:.82rem;display:flex}.admin-vtt-collision-toggle input{accent-color:var(--amber);cursor:pointer}.admin-vtt-collision-fields{grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.6rem;display:grid}.admin-vtt-collision-field{font-family:var(--font-ui);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;flex-direction:column;gap:.2rem;font-size:.74rem;display:flex}.admin-vtt-collision-field .admin-vtt-input{padding:.25rem .45rem;font-size:.82rem}body:has(.vtt-page) .navbar{display:none!important}body:has(.vtt-page) footer{display:none!important}body:has(.vtt-page) .beta-banner{display:none!important}body:has(.vtt-page) .cookie-banner{display:none!important}body:has(.vtt-page) html{height:100%!important;margin:0!important;padding:0!important;overflow:hidden!important}body:has(.vtt-page){height:100%!important;margin:0!important;padding:0!important;overflow:hidden!important}body:has(.vtt-page) #root{height:100%!important;margin:0!important;padding:0!important;overflow:hidden!important}body:has(.vtt-page) .app{height:100%!important;margin:0!important;padding:0!important;overflow:hidden!important}body:has(.vtt-page) .main-content{height:100%!important;margin:0!important;padding:0!important;overflow:hidden!important}.vtt-page{background:var(--bg-base);z-index:10;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.vtt-gate{color:var(--text-muted);font-family:var(--font-ui);justify-content:center;align-items:center;gap:1.2rem;font-size:.95rem}.vtt-canvas-wrap{z-index:0;position:absolute;inset:0}.vtt-canvas-wrap canvas{display:block;width:100%!important;height:100%!important}.vtt-loading{z-index:5;background:#1c1810d9;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.vtt-loading-inner{color:var(--text-muted);font-family:var(--font-ui);flex-direction:column;align-items:center;gap:.8rem;font-size:.88rem;display:flex}.vtt-loading-spinner{border:2px solid var(--border-mid);border-top-color:var(--amber);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite vtt-spin}@keyframes vtt-spin{to{transform:rotate(360deg)}}.vtt-lobby{background:var(--bg-base);flex:1;justify-content:center;align-items:center;display:flex}.vtt-lobby-inner{text-align:center;flex-direction:column;align-items:center;gap:1rem;max-width:420px;padding:3rem 2rem;display:flex}.vtt-lobby-title{font-family:var(--font-display);color:var(--text-bright);margin:0;font-size:1.8rem}.vtt-lobby-msg{color:var(--text-body);font-family:var(--font-body);margin:0;font-size:1.05rem}.vtt-lobby-sub{color:var(--text-dim);font-family:var(--font-ui);margin:0;font-size:.82rem}.vtt-lobby-pulse{align-items:center;gap:.4rem;margin:.4rem 0;display:flex}.vtt-lobby-pulse span{background:var(--amber);border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite vtt-pulse}.vtt-lobby-pulse span:nth-child(2){animation-delay:.2s}.vtt-lobby-pulse span:nth-child(3){animation-delay:.4s}@keyframes vtt-pulse{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.vtt-hud{pointer-events:none;z-index:20;position:absolute;inset:0}.vtt-toolbar,.vtt-gizmo-toolbar,.vtt-hierarchy,.vtt-inspector,.vtt-light-panel,.vtt-render-panel,.vtt-presence,.vtt-modal-backdrop{pointer-events:all}.vtt-toolbar{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-bottom:1px solid var(--border-base);scrollbar-width:none;background:#13100ae0;align-items:center;gap:.4rem;height:44px;padding:0 .8rem;display:flex;position:absolute;top:0;left:0;right:0;overflow-x:auto}.vtt-toolbar::-webkit-scrollbar{display:none}.vtt-toolbar-sep{background:var(--border-mid);flex-shrink:0;width:1px;height:18px;margin:0 .2rem}.vtt-toolbar-label{color:var(--text-muted);font-family:var(--font-ui);white-space:nowrap;flex-shrink:0;font-size:.78rem}.vtt-btn{background:var(--bg-raised);border:1px solid var(--border-mid);color:var(--text-body);font-family:var(--font-ui);cursor:pointer;white-space:nowrap;border-radius:999px;flex-shrink:0;padding:.25rem .65rem;font-size:.78rem;transition:background .15s,color .15s}.vtt-btn:hover{background:var(--bg-nav);color:var(--text-bright);border-color:var(--amber)}.vtt-btn-back{border-color:#0000}.vtt-btn-danger{color:#e05555;border-color:#6b2020}.vtt-btn-danger:hover{color:#f08080;background:#3a1515;border-color:#e05555}.vtt-toggle-group{border:1px solid var(--border-mid);border-radius:999px;flex-shrink:0;display:flex;overflow:hidden}.vtt-toggle{color:var(--text-muted);font-family:var(--font-ui);cursor:pointer;background:0 0;border:none;padding:.2rem .55rem;font-size:.75rem;transition:background .12s,color .12s}.vtt-toggle:hover{color:var(--text-bright)}.vtt-toggle.is-active{background:var(--amber);color:var(--bg-base);font-weight:600}.vtt-toolbar-grid{color:var(--text-muted);font-family:var(--font-ui);flex-shrink:0;align-items:center;gap:.3rem;font-size:.76rem;display:flex}.vtt-grid-input{background:var(--bg-surface);border:1px solid var(--border-base);width:3.5rem;color:var(--text-bright);font-family:var(--font-mono);text-align:center;border-radius:0;outline:none;padding:.15rem .4rem;font-size:.78rem}.vtt-grid-input:focus{border-color:var(--amber)}.vtt-toolbar-snap{color:var(--text-muted);font-family:var(--font-ui);cursor:pointer;flex-shrink:0;align-items:center;gap:.3rem;font-size:.76rem;display:flex}.vtt-toolbar-snap input{accent-color:var(--amber);cursor:pointer}.vtt-inspector{border:1px solid var(--border-mid);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#13100aeb;flex-direction:column;gap:.7rem;width:220px;padding:.9rem;display:flex;position:absolute;top:56px;right:12px}.vtt-inspector-header{flex-direction:column;gap:.15rem;display:flex}.vtt-inspector-name{color:var(--text-bright);font-family:var(--font-display);font-size:.95rem}.vtt-inspector-type{color:var(--amber);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem}.vtt-inspector-owner{color:var(--text-muted);font-family:var(--font-ui);margin:0;font-size:.78rem}.vtt-inspector-label{color:var(--text-muted);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.05em;flex-direction:column;gap:.3rem;font-size:.76rem;display:flex}.vtt-color-pick{border:1px solid var(--border-base);cursor:pointer;background:0 0;width:100%;height:2rem;padding:0}.vtt-state-select{background:var(--bg-surface);border:1px solid var(--border-base);color:var(--text-bright);font-family:var(--font-ui);border-radius:0;outline:none;padding:.3rem .5rem;font-size:.85rem}.vtt-state-select:focus{border-color:var(--amber)}.vtt-presence{border:1px solid var(--border-base);background:#13100acc;border-radius:999px;gap:.4rem;padding:.3rem .6rem;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.vtt-presence-chip{background:var(--bg-raised);border:1px solid var(--border-mid);width:28px;height:28px;color:var(--amber-text);font-family:var(--font-ui);cursor:default;border-radius:50%;justify-content:center;align-items:center;font-size:.78rem;font-weight:600;display:flex}.vtt-light-panel{border:1px solid var(--border-mid);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#13100aeb;flex-direction:column;gap:.65rem;width:260px;padding:.75rem .9rem;display:flex;position:absolute;top:56px;left:12px}.vtt-light-panel-header{color:var(--text-bright);font-family:var(--font-ui);letter-spacing:.04em;border-bottom:1px solid var(--border-base);justify-content:space-between;align-items:center;padding-bottom:.35rem;font-size:.82rem;font-weight:600;display:flex}.vtt-light-row{align-items:center;gap:.5rem;display:flex}.vtt-light-label{color:var(--text-muted);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;width:58px;font-size:.74rem}.vtt-light-slider{accent-color:var(--amber);cursor:pointer;flex:1;height:3px}.vtt-light-val{color:var(--amber-text);font-family:var(--font-mono);text-align:right;flex-shrink:0;width:36px;font-size:.72rem}.vtt-light-color{border:1px solid var(--border-base);cursor:pointer;background:0 0;flex-shrink:0;width:40px;height:28px;padding:0}.vtt-light-section{color:var(--amber);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.1em;border-top:1px solid var(--border-base);margin:.2rem 0 0;padding-top:.5rem;font-size:.68rem;font-weight:600}.vtt-light-select{background:var(--bg-surface);border:1px solid var(--border-base);color:var(--text-bright);font-family:var(--font-ui);cursor:pointer;border-radius:0;outline:none;flex:1;padding:.2rem .4rem;font-size:.78rem}.vtt-light-select:focus{border-color:var(--amber)}.vtt-btn-active{background:var(--bg-nav);border-color:var(--amber);color:var(--amber-text)}.vtt-measure-label{border:1px solid var(--amber);color:var(--amber-text);font-family:var(--font-ui);white-space:nowrap;pointer-events:none;background:#13100ae6;border-radius:999px;padding:.2rem .5rem;font-size:.75rem}.vtt-modal-backdrop{z-index:50;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.vtt-modal{background:var(--bg-card);border:1px solid var(--border-mid);flex-direction:column;width:480px;max-height:70vh;display:flex}.vtt-modal-header{border-bottom:1px solid var(--border-base);justify-content:space-between;align-items:center;padding:.7rem 1rem;display:flex}.vtt-modal-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0 .3rem;font-size:1.3rem;line-height:1}.vtt-modal-close:hover{color:var(--text-bright)}.vtt-modal-search{background:var(--bg-surface);border:1px solid var(--border-base);color:var(--text-bright);font-family:var(--font-ui);border-radius:0;outline:none;margin:.6rem;padding:.4rem .7rem;font-size:.88rem}.vtt-modal-search:focus{border-color:var(--amber)}.vtt-modal-list{flex:1;padding:0 .4rem .4rem;overflow-y:auto}.vtt-modal-empty{color:var(--text-dim);font-family:var(--font-ui);text-align:center;padding:1rem;font-size:.85rem}.vtt-modal-row{border:none;border-bottom:1px solid var(--border-base);width:100%;color:var(--text-body);font-family:var(--font-ui);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:.7rem;padding:.55rem .6rem;transition:background .12s;display:flex}.vtt-modal-row:hover{background:var(--bg-raised)}.vtt-modal-row:last-child{border-bottom:none}.vtt-modal-thumb{object-fit:cover;border:1px solid var(--border-base);flex-shrink:0;width:40px;height:40px}.vtt-modal-thumb-ph{background:var(--bg-surface);border:1px solid var(--border-base);flex-shrink:0;width:40px;height:40px}.vtt-modal-row-name{color:var(--text-bright);flex:1;font-size:.88rem}.vtt-modal-row-type{color:var(--amber);text-transform:uppercase;letter-spacing:.07em;font-size:.7rem}.vtt-mode-toggle{border:1px solid var(--border-mid);font-family:var(--font-ui);cursor:pointer;border-radius:999px;flex-shrink:0;padding:.25rem .75rem;font-size:.78rem;transition:background .15s,border-color .15s,color .15s}.vtt-mode-toggle.is-play{background:var(--bg-raised);color:var(--text-body)}.vtt-mode-toggle.is-play:hover{background:var(--bg-nav);color:var(--text-bright);border-color:var(--amber)}.vtt-mode-toggle.is-edit{background:var(--amber);border-color:var(--amber-bright);color:var(--bg-base);font-weight:600}.vtt-mode-toggle.is-edit:hover{background:var(--amber-bright)}.vtt-gizmo-toolbar{border-bottom:1px solid var(--border-base);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#13100ad1;align-items:center;gap:.4rem;height:36px;padding:0 .8rem;display:flex;position:absolute;top:44px;left:0;right:0}.vtt-gizmo-shortcuts{color:var(--text-dim);font-family:var(--font-mono);letter-spacing:.1em;margin-left:auto;font-size:.68rem}.vtt-hierarchy{border-right:1px solid var(--border-base);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);scrollbar-width:thin;scrollbar-color:var(--border-mid) transparent;background:#13100ae0;width:200px;position:absolute;top:52px;bottom:0;left:0;overflow-y:auto}.vtt-hud.is-edit .vtt-hierarchy{top:88px}.vtt-hierarchy-group{border-bottom:1px solid var(--border-base)}.vtt-hierarchy-group-header{cursor:pointer;width:100%;color:var(--text-muted);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.08em;text-align:left;background:0 0;border:none;align-items:center;gap:.4rem;padding:.42rem .6rem;font-size:.71rem;font-weight:600;transition:background .1s;display:flex}.vtt-hierarchy-group-header:hover{background:var(--bg-raised);color:var(--text-bright)}.vtt-hierarchy-chevron{color:var(--text-dim);font-size:.65rem}.vtt-hierarchy-group-icon{font-size:.75rem}.vtt-hierarchy-group-label{flex:1}.vtt-hierarchy-group-count{background:var(--bg-surface);color:var(--text-dim);border:1px solid var(--border-base);border-radius:999px;padding:.05rem .35rem;font-size:.63rem}.vtt-hierarchy-rows{padding:0}.vtt-hierarchy-empty{color:var(--text-dim);font-family:var(--font-ui);padding:.3rem .9rem;font-size:.72rem;font-style:italic}.vtt-hierarchy-row{cursor:pointer;font-family:var(--font-ui);color:var(--text-body);-webkit-user-select:none;user-select:none;border-left:2px solid #0000;align-items:center;gap:.35rem;padding:.32rem .6rem .32rem 1.2rem;font-size:.78rem;transition:background .1s,border-color .1s;display:flex}.vtt-hierarchy-row:hover{background:var(--bg-raised)}.vtt-hierarchy-row.is-selected{border-left-color:var(--amber);color:var(--text-bright);background:#c878201a}.vtt-hierarchy-row.is-hidden{opacity:.45}.vtt-hierarchy-row.is-locked{color:var(--text-dim)}.vtt-hierarchy-row-icon{color:var(--text-dim);flex-shrink:0;font-size:.7rem}.vtt-hierarchy-row-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.vtt-hierarchy-lock{color:var(--text-dim);flex-shrink:0;font-size:.7rem}.vtt-hierarchy-eye{cursor:pointer;color:var(--text-dim);opacity:0;background:0 0;border:none;flex-shrink:0;padding:.1rem .2rem;font-size:.72rem;transition:opacity .1s,color .1s}.vtt-hierarchy-row:hover .vtt-hierarchy-eye{opacity:1}.vtt-hierarchy-eye:hover{color:var(--amber-text)}.vtt-hierarchy-eye.is-hidden{opacity:1;color:var(--text-dim)}.vtt-hud.is-edit .vtt-inspector{top:96px}.vtt-inspector-transform{border-top:1px solid var(--border-base);border-bottom:1px solid var(--border-base);flex-direction:column;gap:.25rem;padding:.45rem 0;display:flex}.vtt-inspector-transform-row{font-family:var(--font-mono);align-items:center;gap:.35rem;font-size:.7rem;display:flex}.vtt-inspector-transform-label{width:24px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;font-size:.65rem}.vtt-inspector-transform-axis{flex:1}.vtt-inspector-light{border-top:1px solid var(--border-base);flex-direction:column;gap:.5rem;padding-top:.3rem;display:flex}.vtt-btn-ghost{border-color:var(--border-base);color:var(--text-muted);background:0 0}.vtt-btn-ghost:hover{background:var(--bg-raised);color:var(--text-bright);border-color:var(--border-mid)}.vtt-btn-sm{padding:.18rem .5rem;font-size:.72rem}.vtt-color-row{align-items:center;gap:.5rem;display:flex}.vtt-render-panel{border:1px solid var(--border-mid);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#13100aeb;flex-direction:column;gap:.65rem;width:260px;padding:.75rem .9rem;display:flex;position:absolute;top:52px;right:12px}.vtt-hud.is-edit .vtt-render-panel{top:88px}.vtt-render-presets{flex-wrap:wrap;gap:.4rem;display:flex}.vtt-upload-form{flex-direction:column;gap:.5rem;max-height:55vh;padding:0 12px;display:flex;overflow-y:auto}.vtt-upload-status{color:var(--amber-text);font-family:var(--font-ui);margin:0;font-size:.8rem}.blog-page__header{margin-bottom:2rem}.blog-page__admin-link{font-family:var(--font-ui);color:var(--amber-text);margin-top:.5rem;font-size:.8rem;text-decoration:none;display:inline-block}.blog-page__admin-link:hover{color:var(--amber-bright);text-decoration:underline}.blog-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.blog-page__skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, var(--bg-raised) 50%, var(--bg-card) 75%);background-size:200% 100%;height:280px;animation:1.4s infinite blog-shimmer}@keyframes blog-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.blog-status{color:var(--text-muted);padding:2rem 0;font-size:.95rem}.blog-status--error{color:var(--cat-danger,#e05050)}.blog-post-page{max-width:760px}.blog-post__back,.blog-post__edit-link{font-family:var(--font-ui);color:var(--amber-text);margin-bottom:1.5rem;font-size:.8rem;text-decoration:none;display:inline-block}.blog-post__back:hover,.blog-post__edit-link:hover{color:var(--amber-bright);text-decoration:underline}.blog-post__edit-link{float:right;margin-bottom:0}.blog-post__cover-wrap{border:1px solid var(--border-base);margin-bottom:1.5rem;overflow:hidden}.blog-post__cover{object-fit:cover;width:100%;max-height:420px;display:block}.blog-post__header{clear:both;margin-bottom:2.5rem}.blog-post__meta{flex-wrap:wrap;align-items:center;gap:.4rem;margin-bottom:.75rem;display:flex}.blog-post__date{font-family:var(--font-ui);color:var(--text-dim);font-size:.76rem}.blog-post__title{font-family:var(--font-display);color:var(--amber-text);margin:0 0 .6rem;font-size:2rem;line-height:1.2}.blog-post__excerpt{color:var(--text-muted);margin:0;font-size:1.1rem;font-style:italic;line-height:1.6}.blog-post__footer{border-top:1px solid var(--border-base);margin-top:3rem;padding-top:1.5rem}.blog-post-status{color:var(--text-muted);padding:2rem 0}.blog-post-status--error{color:var(--cat-danger,#e05050)}.prose{font-family:var(--font-body);color:var(--text-body);font-size:1.05rem;line-height:1.75}.prose h1,.prose h2,.prose h3,.prose h4{font-family:var(--font-display);color:var(--amber-text);margin:1.5em 0 .5em;line-height:1.2}.prose h1{font-size:1.7rem}.prose h2{font-size:1.35rem}.prose h3{font-size:1.1rem}.prose h4{text-transform:uppercase;letter-spacing:.06em;font-size:.95rem}.prose p{margin:0 0 1em}.prose a{color:var(--amber-text);text-decoration:underline}.prose a:hover{color:var(--amber-bright)}.prose strong{color:var(--text-bright)}.prose em{font-style:italic}.prose blockquote{border-left:3px solid var(--amber);color:var(--text-muted);background:color-mix(in srgb, var(--amber) 5%, transparent);margin:1.25em 0;padding:.5em 1.25em;font-style:italic}.prose blockquote p{margin:0}.prose code{background:var(--bg-nav);color:var(--amber-bright);font-family:var(--font-mono);border-radius:2px;padding:.1em .35em;font-size:.88em}.prose pre{background:var(--bg-nav);border:1px solid var(--border-base);margin:1.25em 0;padding:1rem 1.25rem;overflow-x:auto}.prose pre code{background:0 0;border-radius:0;padding:0}.prose ul,.prose ol{margin:0 0 1em;padding-left:1.75em}.prose li{margin-bottom:.3em}.prose img{border:1px solid var(--border-base);max-width:100%;height:auto;margin:1.25em 0;display:block}.prose iframe,.prose .youtube-wrapper{aspect-ratio:16/9;border:none;width:100%;margin:1.25em 0;display:block}.prose hr{border:none;border-top:1px solid var(--border-mid);margin:2em 0}.admin-blog__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.admin-blog__actions{align-items:center;gap:1rem;padding-top:.25rem;display:flex}.admin-blog__view-link{font-family:var(--font-ui);color:var(--amber-text);font-size:.8rem;text-decoration:none}.admin-blog__view-link:hover{color:var(--amber-bright);text-decoration:underline}.admin-blog__status{color:var(--text-muted);padding:.5rem 0;font-size:.9rem}.admin-blog__status--error{color:var(--cat-danger,#e05050)}.admin-blog__table-wrap{border:1px solid var(--border-base);overflow-x:auto}.admin-blog__table{border-collapse:collapse;width:100%;font-size:.88rem;font-family:var(--font-ui)}.admin-blog__table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);border-bottom:1px solid var(--border-mid);background:var(--bg-raised);white-space:nowrap;padding:.6rem .75rem;font-size:.72rem}.admin-blog__table td{border-bottom:1px solid var(--border-base);color:var(--text-body);vertical-align:middle;padding:.6rem .75rem}.admin-blog__table tr:last-child td{border-bottom:none}.admin-blog__table tr:hover td{background:var(--bg-raised)}.admin-blog__title-cell{text-overflow:ellipsis;white-space:nowrap;max-width:280px;font-weight:600;overflow:hidden;color:var(--text-bright)!important}.admin-blog__slug-cell{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden;font-family:var(--font-mono)!important;color:var(--text-dim)!important;font-size:.78rem!important}.admin-blog__date-cell{white-space:nowrap;color:var(--text-dim)!important;font-size:.8rem!important}.admin-blog__toggle{background:var(--bg-nav);border:1px solid var(--border-base);color:var(--text-dim);font-family:var(--font-ui);cursor:pointer;transition:background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);border-radius:999px;padding:.2rem .6rem;font-size:.75rem}.admin-blog__toggle--on{background:color-mix(in srgb, var(--amber) 15%, transparent);border-color:var(--amber);color:var(--amber-text)}.admin-blog__actions-cell{align-items:center;gap:.6rem;display:flex}.admin-blog__edit-link{color:var(--amber-text);font-size:.8rem;text-decoration:none}.admin-blog__edit-link:hover{text-decoration:underline}.admin-blog__delete-btn{color:var(--cat-danger,#e05050);font-family:var(--font-ui);cursor:pointer;background:0 0;border:none;padding:0;font-size:.8rem}.admin-blog__delete-btn:hover{text-decoration:underline}.rich-editor{border:1px solid var(--border-mid);background:var(--bg-surface);flex-direction:column;display:flex}.rich-editor__toolbar{border-bottom:1px solid var(--border-mid);background:var(--bg-raised);z-index:10;flex-wrap:wrap;gap:2px;padding:.4rem .5rem;display:flex;position:sticky;top:0}.rich-editor__toolbar-group{border-right:1px solid var(--border-base);gap:1px;margin-right:.25rem;padding-right:.5rem;display:flex}.rich-editor__toolbar-group:last-child{border-right:none;margin-right:0;padding-right:0}.rich-editor__btn{color:var(--text-muted);font-family:var(--font-ui);cursor:pointer;text-align:center;min-width:28px;transition:background var(--dur) var(--ease), color var(--dur) var(--ease);background:0 0;border:none;border-radius:0;padding:.2rem .45rem;font-size:.78rem;font-weight:600;line-height:1.4}.rich-editor__btn:hover:not(:disabled){background:var(--bg-nav);color:var(--text-bright)}.rich-editor__btn--active{background:var(--amber);color:var(--bg-base)}.rich-editor__btn--active:hover{background:var(--amber-mid);color:var(--bg-base)}.rich-editor__btn:disabled{opacity:.35;cursor:default}.rich-editor__content{flex:1}.rich-editor__content .ProseMirror{min-height:420px;font-family:var(--font-body);color:var(--text-body);outline:none;padding:1.25rem 1.5rem;font-size:1.05rem;line-height:1.7}.rich-editor__content .ProseMirror:focus{box-shadow:inset 0 0 0 1px var(--border-amber)}.rich-editor__content .ProseMirror .is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-dim);pointer-events:none;height:0;font-style:italic}.rich-editor__content .ProseMirror h1,.rich-editor__content .ProseMirror h2,.rich-editor__content .ProseMirror h3{font-family:var(--font-display);color:var(--amber-text);margin:1.25em 0 .4em;line-height:1.2}.rich-editor__content .ProseMirror h1{font-size:1.6rem}.rich-editor__content .ProseMirror h2{font-size:1.3rem}.rich-editor__content .ProseMirror h3{font-size:1.1rem}.rich-editor__content .ProseMirror p{margin:0 0 .75em}.rich-editor__content .ProseMirror a{color:var(--amber-text);text-decoration:underline}.rich-editor__content .ProseMirror blockquote{border-left:3px solid var(--amber);color:var(--text-muted);margin:1em 0;padding:.4em 1em;font-style:italic}.rich-editor__content .ProseMirror code{background:var(--bg-nav);color:var(--amber-bright);font-family:var(--font-mono);border-radius:2px;padding:.1em .35em;font-size:.88em}.rich-editor__content .ProseMirror pre{background:var(--bg-nav);border:1px solid var(--border-base);margin:1em 0;padding:.9rem 1rem;overflow-x:auto}.rich-editor__content .ProseMirror pre code{background:0 0;padding:0}.rich-editor__content .ProseMirror ul,.rich-editor__content .ProseMirror ol{margin:0 0 .75em;padding-left:1.5em}.rich-editor__content .ProseMirror li{margin-bottom:.2em}.rich-editor__content .ProseMirror img{border:1px solid var(--border-base);max-width:100%;height:auto;margin:1em 0;display:block}.rich-editor__content .ProseMirror .youtube-wrapper,.rich-editor__content .ProseMirror iframe{aspect-ratio:16/9;border:none;width:100%;margin:1em 0;display:block}.admin-blog-editor{max-width:900px}.admin-blog-editor__top{margin-bottom:2rem}.admin-blog-editor__status{color:var(--text-muted);padding:1rem 0}.admin-blog-editor__form{flex-direction:column;gap:1.25rem;display:flex}.admin-blog-editor__row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=600px){.admin-blog-editor__row{grid-template-columns:1fr}}.admin-blog-editor__label{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);flex-direction:column;gap:.35rem;font-size:.78rem;font-weight:600;display:flex}.admin-blog-editor__label-text{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:.35rem;font-size:.78rem;font-weight:600;display:block}.admin-blog-editor__hint{text-transform:none;letter-spacing:0;color:var(--text-dim);font-size:.72rem;font-weight:400}.admin-blog-editor__input,.admin-blog-editor__textarea{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-body);font-family:var(--font-ui);box-sizing:border-box;width:100%;transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);border-radius:0;padding:.5rem .75rem;font-size:.9rem}.admin-blog-editor__input:focus,.admin-blog-editor__textarea:focus{border-color:var(--border-amber);box-shadow:0 0 0 1px var(--border-amber);outline:none}.admin-blog-editor__input--mono{font-family:var(--font-mono);font-size:.82rem}.admin-blog-editor__textarea{resize:vertical;line-height:1.5}.admin-blog-editor__file-input{font-family:var(--font-ui);color:var(--text-muted);margin-top:.1rem;font-size:.82rem}.admin-blog-editor__cover-row{flex-direction:column;gap:.75rem;display:flex}.admin-blog-editor__cover-preview{align-items:flex-start;gap:.75rem;display:flex}.admin-blog-editor__cover-preview img{object-fit:cover;border:1px solid var(--border-base);max-width:220px;max-height:120px;display:block}.admin-blog-editor__cover-remove{color:var(--cat-danger,#e05050);font-family:var(--font-ui);cursor:pointer;background:0 0;border:none;align-self:flex-end;padding:0;font-size:.78rem}.admin-blog-editor__cover-remove:hover{text-decoration:underline}.admin-blog-editor__checks{gap:1.5rem;display:flex}.admin-blog-editor__check{font-family:var(--font-ui);color:var(--text-body);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;font-size:.88rem;display:flex}.admin-blog-editor__check input[type=checkbox]{accent-color:var(--amber);cursor:pointer;width:15px;height:15px}.admin-blog-editor__editor-wrap{flex-direction:column;gap:.35rem;display:flex}.admin-blog-editor__save-bar{border-top:1px solid var(--border-base);flex-wrap:wrap;align-items:center;gap:1rem;padding-top:.5rem;display:flex}.admin-blog-editor__error{color:var(--cat-danger,#e05050);font-family:var(--font-ui);flex:1;font-size:.85rem}.admin-blog-editor__step{color:var(--text-muted);font-family:var(--font-ui);flex:1;font-size:.82rem}.admin-blog-editor__save-btn{margin-left:auto}.account-page{max-width:640px;margin:2rem auto;padding:1rem 2rem}.account-page h1{font-family:var(--font-display);color:var(--gold-on-dark);letter-spacing:.05em;margin-bottom:1.5rem}.account-section{background:var(--bg-card);border:1px solid var(--border-mid);border-radius:0;margin-bottom:1.5rem;padding:1.5rem}.account-section h2{font-family:var(--font-display);color:var(--amber-text);text-transform:uppercase;letter-spacing:.08em;margin:0 0 1.25rem;font-size:.75rem}.account-field{flex-direction:column;gap:.3rem;margin-bottom:1rem;display:flex}.account-field label{color:var(--text-muted);font-size:.8rem}.account-value{color:var(--text-bright);font-size:.95rem}.account-name-form{margin-top:.5rem}.account-name-row{gap:.5rem;display:flex}.account-input{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-bright);transition:border-color var(--dur), box-shadow var(--dur);border-radius:0;outline:none;flex:1;padding:.45rem .75rem;font-size:.9rem}.account-input:focus{border-color:var(--amber);box-shadow:0 0 0 3px #c8761421}.account-input::placeholder{color:var(--text-dim)}.account-feedback{color:var(--amber-text);margin-top:.25rem;font-size:.8rem}.account-plan-name{color:var(--text-bright);align-items:center;gap:.75rem;margin-bottom:.75rem;font-size:1.1rem;font-weight:600;display:flex}.account-plan-features{flex-direction:column;gap:.35rem;margin:0 0 1rem;padding:0;list-style:none;display:flex}.account-plan-features li{color:var(--text-muted);font-size:.85rem}.account-plan-features li:before{content:"✦ ";color:var(--amber);font-size:.65rem}.account-upgrade-btn{text-align:center;text-decoration:none;display:inline-block}.account-danger{border-color:var(--crimson-dim)}.account-danger h2{color:var(--crimson-mid)}.account-danger p{color:var(--text-muted);margin-bottom:1rem;font-size:.9rem}.account-delete-confirm{flex-direction:column;gap:.5rem;display:flex}.account-delete-confirm label{color:var(--text-muted);font-size:.85rem}.account-input--danger{border-color:var(--crimson-dim)}.account-input--danger:focus{border-color:var(--crimson-mid);box-shadow:0 0 0 3px var(--crimson-glow)}.campaigns-toolbar{border-bottom:1px solid var(--border-base);flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 1.5rem;display:flex}.campaigns-toolbar-right{align-items:center;gap:1rem;display:flex}.campaigns-limit-note{color:var(--text-dim);font-size:.8rem}.campaigns-limit-note a{color:var(--amber-text);text-decoration:underline}.campaign-create-form{border-bottom:1px solid var(--border-base);background:var(--bg-surface);flex-shrink:0;padding:1.25rem 1.5rem}.campaign-create-form-fields{grid-template-columns:1fr 1fr 1fr;gap:1rem;margin-bottom:.75rem;display:grid}.campaign-form-error{color:var(--crimson-mid);margin:0 0 .6rem;font-size:.875rem}.campaign-create-form-actions{gap:.75rem;display:flex}.campaigns-body{flex:1;min-height:0;display:flex;overflow:hidden}.campaigns-left{border-right:1px solid var(--border-base);flex-shrink:0;width:300px;overflow-y:auto}.campaigns-right{flex:1;padding:1.5rem;overflow-y:auto}.campaigns-empty-state{height:100%;color:var(--text-muted);font-family:var(--font-body);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;font-size:1.05rem;display:flex}.campaigns-empty-state p:first-child{font-size:2.5rem}.campaign-library{flex-direction:column;padding:.75rem 0;display:flex}.campaign-search-row{padding:0 .75rem .5rem}.campaign-list{margin:0;padding:0;list-style:none}.campaign-list-empty{color:var(--text-dim);padding:1rem;font-size:.875rem}.campaign-item{cursor:pointer;transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease);border-left:2px solid #0000;align-items:center;padding:.6rem 1rem;display:flex}.campaign-item:hover{background:var(--bg-raised)}.campaign-item.active{background:var(--amber-faint);border-left-color:var(--amber)}.campaign-item-name{font-family:var(--font-body);color:var(--text-body);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:1rem;overflow:hidden}.campaign-item.active .campaign-item-name{color:var(--text-bright)}.campaign-panel{max-width:680px}.campaign-panel-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.campaign-panel-title{font-family:var(--font-display);letter-spacing:.04em;color:var(--text-bright);margin:0;font-size:1.6rem;font-weight:600}.campaign-panel-name-input{font-family:var(--font-display);flex:1;font-size:1.3rem}.campaign-panel-actions{flex-shrink:0;gap:.5rem;margin-top:.25rem;display:flex}.campaign-panel-section{margin-bottom:1.25rem}.campaign-panel-notes{font-family:var(--font-body);color:var(--text-body);white-space:pre-wrap;margin:0;font-size:1rem;line-height:1.6}.campaign-panel-empty{color:var(--text-dim);font-size:.9rem;font-style:italic}.campaign-panel-member-count{font-family:var(--font-body);color:var(--text-body);margin:0;font-size:1rem}.campaign-invite-row{background:var(--bg-surface);border:1px solid var(--border-mid);align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.campaign-invite-code{font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.8rem;overflow:hidden}.campaign-panel-edit-actions{gap:.75rem;margin-bottom:1.5rem;display:flex}.campaign-roster{border-collapse:collapse;width:100%;font-size:.875rem}.campaign-roster th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);border-bottom:1px solid var(--border-base);padding:.3rem .5rem;font-size:.7rem}.campaign-roster td{color:var(--text-body);border-bottom:1px solid var(--border-base);padding:.45rem .5rem}.campaign-roster tr:last-child td{border-bottom:none}.campaign-panel-danger{border-top:1px solid var(--border-base);margin-top:2rem;padding-top:1.25rem}.campaign-delete-confirm{color:var(--text-muted);flex-direction:column;gap:.75rem;font-size:.9rem;display:flex}.campaign-delete-confirm-actions{gap:.75rem;display:flex}.char-wizard{flex-direction:column;display:flex}.char-wizard-steps{border-bottom:1px solid var(--border-base);flex-shrink:0;gap:0;display:flex}.char-wizard-step{color:var(--text-dim);transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease);border-bottom:2px solid #0000;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.85rem;display:flex}.char-wizard-step.active{color:var(--amber-text);border-bottom-color:var(--amber)}.char-wizard-step.done{color:var(--text-muted)}.char-wizard-step-num{background:var(--bg-raised);border-radius:50%;justify-content:center;align-items:center;width:1.4rem;height:1.4rem;font-size:.75rem;font-weight:600;display:flex}.char-wizard-step.active .char-wizard-step-num{background:var(--amber);color:#000}.char-wizard-step.done .char-wizard-step-num{background:var(--border-mid)}.char-wizard-body{padding:1.5rem}.char-wizard-section{flex-direction:column;gap:1rem;display:flex}.char-wizard-footer{border-top:1px solid var(--border-base);flex-shrink:0;justify-content:space-between;align-items:center;padding:.85rem 1.5rem;display:flex}.char-form-row-3{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.char-form-row-4{grid-template-columns:repeat(4,1fr);gap:.75rem;display:grid}.char-form-field{flex-direction:column;gap:.25rem;display:flex}.char-form-checkbox-row{align-items:center;gap:1rem;display:flex}.char-form-checkbox{color:var(--text-body);cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.char-form-hint{color:var(--text-dim);margin:0;font-size:.875rem}.char-ability-grid{grid-template-columns:repeat(6,1fr);gap:.75rem;display:grid}.char-ability-card{background:var(--bg-surface);border:1px solid var(--border-base);flex-direction:column;align-items:center;gap:.35rem;padding:.75rem .5rem;display:flex}.char-ability-label{letter-spacing:.08em;color:var(--text-dim);font-size:.75rem;font-weight:700}.char-ability-input{text-align:center;width:100%;font-size:1.1rem;font-weight:700}.char-ability-mod{color:var(--amber-text);font-size:1rem;font-weight:600}.char-save-toggle{color:var(--text-dim);cursor:pointer;white-space:nowrap;align-items:center;gap:.3rem;font-size:.75rem;display:flex}.char-spell-derived{color:var(--text-body);gap:1.5rem;padding:.5rem 0;font-size:.9rem;display:flex}.char-slots-grid{grid-template-columns:repeat(9,1fr);gap:.5rem;display:grid}.char-slot-field{flex-direction:column;align-items:center;gap:.25rem;display:flex}.char-slot-field .field-label{font-size:.7rem}.char-slot-field .field-input{text-align:center;width:100%}.char-action-list{flex-direction:column;gap:.4rem;margin-bottom:1rem;display:flex}.char-action-row{background:var(--bg-surface);border:1px solid var(--border-base);align-items:center;gap:.75rem;padding:.4rem .75rem;font-size:.875rem;display:flex}.char-action-kind{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);background:var(--bg-raised);white-space:nowrap;border-radius:2px;padding:.1rem .4rem;font-size:.7rem}.char-action-name{color:var(--text-body);flex:none;font-weight:600}.char-action-slot{color:var(--text-dim);white-space:nowrap;font-size:.75rem}.char-action-detail{color:var(--text-muted);flex:1;font-size:.8rem}.char-add-action{background:var(--bg-surface);border:1px solid var(--border-base);flex-direction:column;gap:.75rem;margin-bottom:1.5rem;padding:1rem;display:flex}.char-items-section{flex-direction:column;gap:.5rem;display:flex}.char-section-header{letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);border-bottom:1px solid var(--border-base);justify-content:space-between;align-items:center;margin-bottom:.25rem;padding-bottom:.4rem;font-size:.75rem;font-weight:700;display:flex}.char-item-row{background:var(--bg-surface);border:1px solid var(--border-base);align-items:flex-end;gap:.75rem;padding:.5rem .75rem;display:flex}.char-panel{flex-direction:column;gap:1.25rem;max-width:760px;display:flex}.char-panel-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.char-panel-name{font-family:var(--font-display);letter-spacing:.04em;color:var(--text-bright);margin:0 0 .25rem;font-size:1.7rem;font-weight:600}.char-panel-subtitle{color:var(--text-dim);margin:0;font-size:.9rem}.char-panel-campaign{color:var(--amber-text)}.char-panel-actions{flex-shrink:0;gap:.5rem;display:flex}.char-stat-row{flex-wrap:wrap;gap:.75rem;display:flex}.char-stat-box{background:var(--bg-surface);border:1px solid var(--border-base);flex-direction:column;align-items:center;min-width:70px;padding:.6rem 1rem;display:flex}.char-stat-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);margin-bottom:.2rem;font-size:.7rem}.char-stat-value{color:var(--text-bright);font-size:1.3rem;font-weight:700;line-height:1}.char-stat-temp{color:var(--amber-text);margin-left:.15rem;font-size:.85rem}.char-stat-sub{color:var(--text-dim);font-size:.75rem;font-weight:400}.char-abilities-row{gap:.5rem;display:flex}.char-ability-display{background:var(--bg-surface);border:1px solid var(--border-base);flex-direction:column;flex:1;align-items:center;gap:.2rem;padding:.6rem .25rem;display:flex}.char-ability-score{color:var(--text-bright);font-size:1.25rem;font-weight:700}.char-save-display{color:var(--text-dim);font-size:.7rem}.char-save-display.proficient{color:var(--amber-text);font-weight:600}.char-slots-display{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.char-slot-pip{background:var(--bg-raised);border:1px solid var(--border-base);flex-direction:column;align-items:center;padding:.3rem .6rem;font-size:.8rem;display:flex}.char-slot-level{color:var(--text-dim);font-size:.7rem}.char-slot-count{color:var(--text-bright);font-weight:700}.char-panel-section{flex-direction:column;gap:.5rem;display:flex}.char-action-table{border-collapse:collapse;width:100%;font-size:.875rem}.char-action-table th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);border-bottom:1px solid var(--border-base);padding:.3rem .5rem;font-size:.7rem}.char-action-table td{color:var(--text-body);border-bottom:1px solid var(--border-base);padding:.4rem .5rem}.char-action-table tr:last-child td{border-bottom:none}.character-library{flex-direction:column;padding:.75rem 0;display:flex}.character-group-label{text-transform:uppercase;letter-spacing:.09em;color:var(--text-dim);padding:.5rem 1rem .25rem;font-size:.7rem;font-weight:700}.character-item{cursor:pointer;transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease);border-left:2px solid #0000;flex-direction:column;padding:.55rem 1rem;display:flex}.character-item:hover{background:var(--bg-raised)}.character-item.active{background:var(--amber-faint);border-left-color:var(--amber)}.character-item-name{font-family:var(--font-body);color:var(--text-body);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;overflow:hidden}.character-item.active .character-item-name{color:var(--text-bright)}.character-item-meta{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:.4rem;font-size:.75rem;display:flex;overflow:hidden}.character-item-badge{text-transform:uppercase;letter-spacing:.06em;background:var(--amber-faint);color:var(--amber-text);border-radius:2px;padding:.1rem .35rem;font-size:.65rem}.monster-library-meta{color:var(--text-dim);font-size:.75rem;font-family:var(--font-body);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.monster-panel{max-width:600px}.monster-builtin-badge{text-transform:uppercase;letter-spacing:.06em;color:var(--amber-text);background:var(--amber-faint);border:1px solid var(--amber);align-self:center;padding:.15rem .5rem;font-size:.7rem}.stat-block{background:var(--bg-surface);border:1px solid var(--amber);font-family:var(--font-body);padding:1.25rem 1.5rem}.stat-block-header{margin-bottom:.5rem}.stat-block-name{font-family:var(--font-display);color:var(--text-bright);letter-spacing:.03em;margin:0 0 .15rem;font-size:1.4rem;font-weight:600}.stat-block-meta{color:var(--text-dim);margin:0;font-size:.875rem;font-style:italic}.stat-block-divider{background:var(--amber);opacity:.35;height:2px;margin:.75rem 0}.stat-block-core{color:var(--text-body);flex-direction:column;gap:.2rem;font-size:.9rem;display:flex}.stat-block-core p{margin:0}.stat-block-label{color:var(--text-muted);font-weight:700}.stat-block-abilities{text-align:center;grid-template-columns:repeat(6,1fr);gap:.25rem;display:grid}.stat-block-ability{flex-direction:column;align-items:center;gap:.1rem;display:flex}.stat-block-ability-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);font-size:.65rem;font-weight:700}.stat-block-ability-score{color:var(--text-bright);font-size:.95rem;font-weight:600}.stat-block-ability-mod{color:var(--text-body);font-size:.8rem}.stat-block-section-header{font-family:var(--font-display);letter-spacing:.04em;color:var(--amber-text);border-bottom:1px solid var(--amber);margin:.75rem 0 .5rem;padding-bottom:.2rem;font-size:1.05rem;font-weight:600}.stat-block-entries{flex-direction:column;gap:.5rem;display:flex}.stat-block-entry{color:var(--text-body);margin:0;font-size:.875rem;line-height:1.55}.monster-form{flex-direction:column;gap:0;max-width:680px;display:flex}.monster-form-section{border-bottom:1px solid var(--border-base);margin-bottom:1.25rem;padding-bottom:1.25rem}.monster-form-section:last-of-type{border-bottom:none}.monster-ability-card{padding-bottom:.5rem}.monster-text-entry{background:var(--bg-raised);border:1px solid var(--border-base);margin-bottom:.5rem;padding:.6rem .75rem}.monster-text-entry-header{justify-content:space-between;align-items:center;margin-bottom:.2rem;display:flex}.monster-text-entry-name{color:var(--text-muted);font-size:.875rem}.monster-text-entry-desc{color:var(--text-dim);white-space:pre-wrap;margin:0;font-size:.825rem;line-height:1.45}.monster-add-entry{background:var(--bg-raised);border:1px solid var(--border-base);flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.sim-page{flex-direction:column;gap:0;display:flex}.sim-topbar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;padding-bottom:12px;display:flex}.sim-title{color:var(--accent);white-space:nowrap;margin-right:8px;font-size:1.1rem;font-weight:700}.sim-tabs{gap:2px;display:flex}.sim-tab-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:6px 14px;font-family:inherit;font-size:.9rem;transition:color .15s,border-color .15s}.sim-tab-btn:hover{color:var(--text-primary)}.sim-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.sim-topbar-right{align-items:center;gap:10px;margin-left:auto;display:flex}.sim-scenario-label{color:var(--text-secondary);align-items:center;gap:6px;font-size:.8rem;display:flex}.sim-scenario-input{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;width:70px;padding:4px 8px;font-family:inherit;font-size:.85rem;transition:border-color .15s}.sim-scenario-input:focus{border-color:var(--accent);outline:none}.sim-guide-link{border:1px solid var(--border-mid);width:26px;height:26px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;text-decoration:none;transition:color .15s,border-color .15s;display:inline-flex}.sim-guide-link:hover{color:var(--amber-text);border-color:var(--amber)}.sim-run-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:6px 18px;font-family:inherit;font-size:.85rem;font-weight:600;transition:background .15s,box-shadow .15s}.sim-run-btn:hover{background:var(--accent-hover);box-shadow:0 0 12px var(--accent-glow)}.sim-layout{border:1px solid var(--border);border-top:none;border-radius:0 0 8px 8px;grid-template-columns:200px 240px 1fr;height:65vh;min-height:500px;display:grid;overflow:hidden}.sim-col{border-right:1px solid var(--border);flex-direction:column;gap:10px;padding:12px;display:flex;overflow-y:auto}.sim-col:last-child{border-right:none}.sim-col--editor{background:var(--bg-secondary)}.sim-col-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding-bottom:8px;display:flex}.sim-col-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-size:.7rem;font-weight:700}.sim-icon-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;text-align:center;border-radius:5px;width:22px;height:22px;font-size:1rem;line-height:20px;transition:background .15s}.sim-icon-btn:hover{background:var(--border)}.sim-list{flex-direction:column;gap:5px;display:flex}.sim-list-item{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:6px;align-items:center;gap:7px;padding:6px 9px;transition:border-color .1s;display:flex}.sim-list-item:hover{border-color:var(--accent)}.sim-list-item.selected{border-color:var(--accent);background:#7c3aed1a}.sim-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.sim-list-label{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.875rem;font-weight:500;overflow:hidden}.sim-list-body{flex:1;min-width:0}.sim-list-body .sim-list-label{display:block}.sim-list-meta{color:var(--text-secondary);font-size:.7rem}.sim-remove-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:1px 4px;font-size:1rem;line-height:1;transition:background .1s,color .1s}.sim-remove-btn:hover{color:#e06c75;background:#e06c7526}.sim-card{background:var(--bg-card);border:1px solid var(--border);border-radius:7px;flex-direction:column;flex-shrink:0;gap:9px;padding:11px;display:flex}.sim-card-title{color:var(--text-primary);flex-wrap:wrap;align-items:center;gap:.75rem;font-size:.8rem;font-weight:700;display:flex}.sim-field{flex-direction:column;gap:4px;display:flex}.sim-field label{color:var(--text-secondary);letter-spacing:.06em;text-transform:uppercase;font-size:.7rem;font-weight:600}.sim-field input[type=text],.sim-field input[type=number],.sim-field select{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:5px;width:100%;padding:5px 8px;font-family:inherit;font-size:.85rem;transition:border-color .15s}.sim-field input:focus,.sim-field select:focus{border-color:var(--accent);outline:none}.sim-row-fields{grid-template-columns:1fr 1fr;gap:8px;display:grid}.sim-color-row{align-items:center;gap:7px;display:flex}.sim-color-row input[type=color]{background:var(--bg-primary);border:1px solid var(--border);cursor:pointer;border-radius:5px;flex-shrink:0;width:36px;height:30px;padding:2px}.sim-color-row input[type=text]{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:5px;flex:1;padding:5px 8px;font-family:monospace;font-size:.85rem;transition:border-color .15s}.sim-color-row input[type=text]:focus{border-color:var(--accent);outline:none}.sim-empty{color:var(--text-secondary);text-align:center;padding:8px 4px;font-size:.8rem}.sim-empty-editor{color:var(--text-secondary);flex:1;justify-content:center;align-items:center;font-size:.85rem;display:flex}.sim-results-top-bar{justify-content:flex-end;padding-bottom:4px;display:flex}.sim-export-panel{background:var(--bg-raised);border:1px solid var(--border-mid);z-index:20;flex-direction:column;gap:6px;min-width:200px;padding:10px 12px;display:flex;position:absolute;top:calc(100% + 4px);right:0}.sim-export-option{cursor:pointer;color:var(--text-body);align-items:center;gap:7px;font-size:.82rem;display:flex}.sim-results{border:1px solid var(--border);border-top:none;border-radius:0 0 8px 8px;flex-direction:column;gap:12px;padding:14px;display:flex}.sim-results-top{grid-template-columns:1fr 1fr;gap:12px;display:grid}.sim-win-row{align-items:center;gap:8px;margin-top:6px;display:flex}.sim-win-label{white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;align-items:center;gap:6px;width:110px;font-size:.82rem;display:flex;overflow:hidden}.sim-win-bar-track{background:var(--bg-primary);border-radius:6px;flex:1;height:11px;overflow:hidden}.sim-win-bar-fill{border-radius:6px;height:100%;transition:width .4s}.sim-win-count{color:var(--text-secondary);text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;width:52px;font-size:.75rem}.sim-stat-note{color:var(--text-muted);border-top:1px solid var(--border-base);margin:4px 0 0;padding-top:6px;font-size:.72rem;line-height:1.55}.sim-stat-note strong{color:var(--text-body);font-weight:600}.sim-stats-table{border-collapse:collapse;width:100%;margin-top:4px}.sim-stats-key{text-transform:capitalize;color:var(--text-secondary);padding:4px 0;font-size:.8rem}.sim-stats-val{text-align:right;font-variant-numeric:tabular-nums;color:var(--text-primary);font-size:.85rem;font-weight:600}.sim-scenario-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:4px;display:flex}.sim-scenario-slider{min-width:80px;accent-color:var(--accent);cursor:pointer;flex:1}.sim-scenario-meta{color:var(--text-secondary);margin-top:4px;font-size:.82rem;display:block}.sim-scenario-rounds{font-size:.78rem}.sim-hp-chart{width:100%;display:block}.sim-demo-banner{background:color-mix(in srgb, var(--amber) 10%, var(--bg-card));border:1px solid var(--border-amber,var(--border));color:var(--amber-text,var(--text-body));text-align:center;border-top:none;padding:7px 14px;font-size:.8rem}.sim-campaign-bar{background:var(--bg-surface,var(--bg-card));border:1px solid var(--border);border-top:none;align-items:center;gap:12px;padding:7px 14px;display:flex}.sim-campaign-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted,var(--text-secondary));align-items:center;gap:8px;font-size:.75rem;font-weight:600;display:flex}.sim-campaign-select{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:5px;min-width:220px;padding:4px 8px;font-family:inherit;font-size:.85rem;transition:border-color .15s}.sim-campaign-select:focus{border-color:var(--accent);outline:none}.sim-entity-section{border:1px solid var(--border);background:var(--bg-card);border-radius:5px;flex-shrink:0;overflow:hidden}.sim-entity-section-title{cursor:pointer;letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary);-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:6px 9px;font-size:.7rem;font-weight:700;list-style:none;display:flex}.sim-entity-section-title:hover{color:var(--text-primary)}.sim-entity-section[open]>.sim-entity-section-title{border-bottom:1px solid var(--border)}.sim-entity-list{flex-direction:column;gap:3px;max-height:160px;padding:5px;display:flex;overflow-y:auto}.sim-entity-item{background:var(--bg-raised,var(--bg-card));border:1px solid var(--border);border-radius:4px;align-items:center;gap:6px;padding:4px 6px;display:flex}.sim-entity-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sim-entity-name{color:var(--text-bright,var(--text-primary));text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;font-weight:500;overflow:hidden}.sim-entity-meta{color:var(--text-muted,var(--text-secondary));font-size:.68rem}.sim-entity-add-btn{background:var(--bg-surface,var(--bg-card));border:1px solid var(--border);color:var(--accent);cursor:pointer;text-align:center;border-radius:4px;flex-shrink:0;width:20px;height:20px;padding:0;font-size:1rem;font-weight:700;line-height:18px;transition:background .12s,border-color .12s}.sim-entity-add-btn:hover{background:var(--border);border-color:var(--accent)}.sim-pending-editor{background:var(--bg-card);border:1px solid var(--border-amber,var(--accent));border-radius:7px;flex-direction:column;flex-shrink:0;gap:10px;padding:12px;display:flex}.sim-pending-header{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding-bottom:8px;display:flex}.sim-pending-name{color:var(--text-bright,var(--text-primary));font-size:.9rem;font-weight:700}.sim-pending-footer{justify-content:flex-end;gap:8px;padding-top:4px;display:flex}.sim-pending-hp-input{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:5px;width:80px;margin-top:4px;padding:4px 8px;font-family:inherit;font-size:.85rem;transition:border-color .15s}.sim-pending-hp-input:focus{border-color:var(--accent);outline:none}.sim-hp-mode-group{flex-direction:column;gap:4px;margin-top:2px;display:flex}.sim-hp-mode-option{color:var(--text-body,var(--text-primary));cursor:pointer;align-items:center;gap:6px;font-size:.8rem;display:flex}.sim-ac-override-toggle{color:var(--text-body,var(--text-primary));cursor:pointer;letter-spacing:.06em;text-transform:uppercase;align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:flex}.sim-source-badge{border:1px solid var(--border-amber,var(--accent));color:var(--amber-text,var(--accent));letter-spacing:.05em;white-space:nowrap;background:0 0;border-radius:999px;padding:2px 8px;font-size:.68rem;font-weight:600}.sim-source-info{align-items:center;gap:8px;padding:2px 0 6px;display:flex}.sim-action-summary-list{flex-direction:column;gap:4px;display:flex}.sim-action-summary-row{align-items:baseline;gap:5px;font-size:.78rem;line-height:1.4;display:flex}.sim-action-summary-kind{background:var(--bg-raised,var(--bg-surface,#322c20));color:var(--text-muted,var(--text-secondary));letter-spacing:.05em;text-transform:uppercase;border-radius:3px;flex-shrink:0;padding:1px 5px;font-size:.65rem;font-weight:700}.sim-action-summary-name{color:var(--text-bright,var(--text-primary));flex-shrink:0;font-weight:600}.sim-action-summary-detail{color:var(--text-muted,var(--text-secondary));text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.char-action-uses{color:var(--amber-text,var(--accent));border:1px solid var(--border-amber,var(--accent));white-space:nowrap;border-radius:999px;padding:1px 6px;font-size:.68rem}.sim-page input[type=checkbox]{appearance:none;border:1.5px solid var(--border-mid);background:var(--bg-surface);cursor:pointer;width:15px;height:15px;transition:border-color var(--dur,.15s) var(--ease,ease), background var(--dur,.15s) var(--ease,ease);vertical-align:middle;flex-shrink:0;position:relative}.sim-page input[type=checkbox]:checked{background:var(--amber);border-color:var(--amber);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'%3E%3Cpath d='M2 5l2.5 2.5L8 3' stroke='%231a1208' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-size:100% 100%}.sim-page input[type=checkbox]:focus-visible{outline:1.5px solid var(--amber);outline-offset:2px}.sim-hp-mode-option input[type=radio],.sim-page input[type=radio]{accent-color:var(--amber);cursor:pointer}.sim-modal-overlay{z-index:200;background:#1c1810c7;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.sim-modal-overlay--fullscreen{align-items:flex-start;padding-top:4vh}.sim-modal{background:var(--bg-card);border:1px solid var(--border-mid);flex-direction:column;gap:.75rem;width:min(480px,92vw);max-height:80vh;padding:1.25rem 1.5rem;display:flex;overflow-y:auto}.sim-modal--wide{width:min(860px,95vw);max-height:92vh}.sim-modal-header{border-bottom:1px solid var(--border-base);flex-shrink:0;justify-content:space-between;align-items:center;padding-bottom:.5rem;display:flex}.sim-modal-title{font-family:var(--font-display);color:var(--text-bright);font-size:.95rem}.sim-modal-subtitle{font-family:var(--font-ui,inherit);color:var(--text-muted);font-size:.75rem;font-weight:400}.sim-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.3rem;line-height:1;transition:color .12s}.sim-modal-close:hover{color:var(--text-bright)}.sim-faction-modal-row{align-items:center;gap:.5rem;display:flex}.sim-faction-color-input{background:var(--bg-surface);border:1px solid var(--border-mid);cursor:pointer;border-radius:3px;flex-shrink:0;width:36px;height:30px;padding:2px}.sim-faction-name-input{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-bright);flex:1;padding:5px 8px;font-family:inherit;font-size:.85rem;transition:border-color .15s}.sim-faction-name-input:focus{border-color:var(--amber);outline:none}.sim-title-group{align-items:center;gap:.75rem;display:flex}.sim-encounter-name-input{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-body);font-family:var(--font-ui,inherit);width:180px;padding:3px 8px;font-size:.82rem;transition:border-color .15s}.sim-encounter-name-input:focus{border-color:var(--amber);outline:none}.sim-encounter-name-input::placeholder{color:var(--text-dim)}.sim-saved-row{border-bottom:1px solid var(--border-base);align-items:center;gap:.5rem;padding:.5rem 0;display:flex}.sim-saved-row:last-child{border-bottom:none}.sim-saved-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sim-saved-name{color:var(--text-bright);text-overflow:ellipsis;white-space:nowrap;font-size:.88rem;font-weight:500;overflow:hidden}.sim-saved-meta{color:var(--text-muted);font-size:.72rem}.sim-entity-search{border-bottom:1px solid var(--border-base);padding:.4rem .5rem .25rem}.sim-entity-search-input{background:var(--bg-surface);border:1px solid var(--border-mid);width:100%;color:var(--text-bright);padding:.3rem .5rem;font-family:inherit;font-size:.8rem;transition:border-color .15s}.sim-entity-search-input:focus{border-color:var(--amber);outline:none}.sim-entity-search-input::placeholder{color:var(--text-dim)}.sim-win-pct{color:var(--text-dim);font-size:.7rem}.sim-stat-select{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-body);cursor:pointer;margin-left:auto;padding:2px 6px;font-family:inherit;font-size:.78rem;transition:border-color .15s}.sim-stat-select:focus{border-color:var(--amber);outline:none}.sim-entity-stats-table{border-collapse:collapse;width:100%;margin-top:6px;font-size:.78rem}.sim-entity-stats-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-mid);padding:4px 6px 6px;font-size:.72rem;font-weight:600}.sim-entity-stats-table th:not(:first-child){text-align:right}.sim-entity-stats-table td{color:var(--text-body);border-bottom:1px solid var(--border-base);font-variant-numeric:tabular-nums;padding:4px 6px}.sim-entity-stats-table td:not(:first-child){text-align:right}.sim-entity-stats-table tr:last-child td{border-bottom:none}.sim-entity-stats-table tr:hover td{background:var(--bg-raised)}.sim-entity-color-dot{vertical-align:middle;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-right:5px;display:inline-block}.guide-page{max-width:860px;margin:0 auto;padding:0}.guide-back-link{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:1.5rem;font-size:.85rem;text-decoration:none;transition:color .15s;display:inline-flex}.guide-back-link:hover{color:var(--amber-text)}.guide-hero{border:1px solid var(--border-mid);background:var(--bg-card);margin-bottom:2.5rem;padding:2rem 2rem 1.5rem}.guide-hero-title{font-family:var(--font-display);color:var(--amber-bright);margin:0 0 .5rem;font-size:1.8rem}.guide-hero-subtitle{color:var(--text-body);margin:0 0 1.25rem;font-size:1rem;line-height:1.6}.guide-toc{border-top:1px solid var(--border-base);flex-wrap:wrap;gap:6px 12px;margin:0;padding:1rem 0 0;list-style:none;display:flex}.guide-toc li a{color:var(--amber);font-size:.85rem;text-decoration:none;transition:color .15s}.guide-toc li a:hover{color:var(--amber-bright)}.guide-toc li:before{content:"→ ";color:var(--text-dim);font-size:.8rem}.guide-section{margin-bottom:3rem}.guide-section-title{font-family:var(--font-display);color:var(--amber-text);border-bottom:1px solid var(--border-mid);margin:0 0 1.25rem;padding-bottom:.5rem;font-size:1.2rem}.guide-subsection-title{font-family:var(--font-ui);color:var(--text-bright);margin:1.5rem 0 .5rem;font-size:.95rem;font-weight:700}.guide-body{color:var(--text-body);margin:0 0 .75rem;font-size:.95rem;line-height:1.7}.guide-body+.guide-body{margin-top:0}.guide-ol,.guide-ul{color:var(--text-body);margin:0 0 .75rem;padding-left:1.5rem;font-size:.95rem;line-height:1.7}.guide-ol li,.guide-ul li{margin-bottom:.25rem}.guide-callout{border-left:3px solid var(--amber);background:var(--bg-raised);color:var(--text-body);gap:10px;margin:1rem 0;padding:.75rem 1rem;font-size:.875rem;line-height:1.6;display:flex}.guide-callout--tip{border-left-color:#52b788}.guide-callout--warn{border-left-color:#e07a5f}.guide-callout-icon{flex-shrink:0;font-size:1rem}.guide-mockup{background:var(--bg-card);border:1px solid var(--border-mid);font-family:var(--font-ui);margin:1.25rem 0}.guide-mockup-caption{background:var(--bg-nav);color:var(--text-dim);letter-spacing:.05em;text-transform:uppercase;border-bottom:1px solid var(--border-base);padding:4px 10px;font-size:.7rem}.guide-mockup-body{padding:12px 14px}.mock-topbar{background:var(--bg-card);border-bottom:1px solid var(--border-base);flex-wrap:wrap;align-items:center;gap:10px;padding:8px 14px;display:flex}.mock-title{color:var(--amber);white-space:nowrap;font-size:.95rem;font-weight:700}.mock-tab-group{gap:2px;display:flex}.mock-tab{color:var(--text-muted);cursor:default;font-size:.82rem;font-family:var(--font-ui);background:0 0;border:none;border-bottom:2px solid #0000;padding:4px 12px}.mock-tab.active{color:var(--amber);border-bottom-color:var(--amber)}.mock-right{align-items:center;gap:8px;margin-left:auto;display:flex}.mock-btn-ghost{border:1px solid var(--border-mid);color:var(--text-muted);cursor:default;font-size:.78rem;font-family:var(--font-ui);background:0 0;padding:3px 10px}.mock-btn-run{background:var(--amber);color:#fff;cursor:default;font-size:.78rem;font-weight:600;font-family:var(--font-ui);border:none;padding:4px 14px}.mock-input-sm{background:var(--bg-surface);border:1px solid var(--border-base);color:var(--text-bright);width:56px;font-size:.78rem;font-family:var(--font-ui);padding:3px 6px}.mock-label-sm{color:var(--text-muted);align-items:center;gap:5px;font-size:.78rem;display:flex}.mock-three-col{border:1px solid var(--border-base);grid-template-columns:160px 200px 1fr;min-height:200px;font-size:.8rem;display:grid}.mock-col{border-right:1px solid var(--border-base);overflow:hidden}.mock-col:last-child{border-right:none}.mock-col-header{background:var(--bg-raised);border-bottom:1px solid var(--border-base);color:var(--text-muted);justify-content:space-between;align-items:center;padding:6px 10px;font-size:.75rem;font-weight:600;display:flex}.mock-col-header-btn{color:var(--text-dim);cursor:default;background:0 0;border:none;font-size:1rem;line-height:1}.mock-faction-row{border-bottom:1px solid var(--border-base);align-items:center;gap:7px;padding:7px 10px;display:flex}.mock-faction-row.selected{background:var(--bg-raised)}.mock-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.mock-faction-name{color:var(--text-body);font-size:.78rem}.mock-faction-count{color:var(--text-dim);margin-left:auto;font-size:.7rem}.mock-combatant-row{border-bottom:1px solid var(--border-base);cursor:default;align-items:center;gap:7px;padding:7px 10px;display:flex}.mock-combatant-row.selected{background:var(--bg-raised)}.mock-combatant-body{flex:1;overflow:hidden}.mock-combatant-name{color:var(--text-bright);font-size:.8rem}.mock-combatant-meta{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;font-size:.68rem;overflow:hidden}.mock-editor-pad{padding:10px 12px}.mock-card{border:1px solid var(--border-base);margin-bottom:8px}.mock-card-title{background:var(--bg-raised);color:var(--text-muted);border-bottom:1px solid var(--border-base);text-transform:uppercase;letter-spacing:.04em;padding:4px 8px;font-size:.7rem;font-weight:600}.mock-field-row{flex-wrap:wrap;gap:8px;padding:6px 8px;display:flex}.mock-field{flex-direction:column;gap:2px;display:flex}.mock-field label{color:var(--text-dim);font-size:.65rem}.mock-field input,.mock-field select{background:var(--bg-surface);border:1px solid var(--border-base);color:var(--text-bright);width:60px;font-size:.72rem;font-family:var(--font-ui);padding:2px 5px}.mock-entity-section{border-bottom:1px solid var(--border-base)}.mock-entity-header{color:var(--text-muted);background:var(--bg-surface);justify-content:space-between;align-items:center;padding:5px 10px;font-size:.72rem;display:flex}.mock-entity-row{border-bottom:1px solid var(--border-base);align-items:center;gap:6px;padding:5px 10px;display:flex}.mock-entity-info{flex:1}.mock-entity-name{color:var(--text-bright);font-size:.75rem}.mock-entity-meta{color:var(--text-dim);font-size:.65rem}.mock-entity-add{background:var(--bg-raised);border:1px solid var(--border-mid);color:var(--amber);cursor:default;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.9rem;display:flex}.mock-win-row{align-items:center;gap:8px;padding:5px 0;display:flex}.mock-win-label{width:80px;color:var(--text-body);flex-shrink:0;align-items:center;gap:6px;font-size:.78rem;display:flex}.mock-win-track{background:var(--bg-surface);border:1px solid var(--border-base);flex:1;height:8px}.mock-win-fill{height:100%}.mock-win-count{color:var(--text-bright);text-align:right;flex-shrink:0;width:70px;font-size:.78rem}.mock-win-pct{color:var(--text-muted);font-size:.72rem}.mock-stats-table{border-collapse:collapse;width:100%;font-size:.8rem}.mock-stats-table td{border-bottom:1px solid var(--border-base);padding:4px 8px}.mock-stats-key{color:var(--text-muted)}.mock-stats-val{color:var(--text-bright);text-align:right}.mock-stat-note{color:var(--text-dim);border-top:1px solid var(--border-base);margin-top:4px;padding-top:6px;font-size:.75rem;line-height:1.5}.mock-chart-area{background:var(--bg-surface);border:1px solid var(--border-base);padding:8px;position:relative;overflow:hidden}.mock-chart-svg{width:100%;height:100px;display:block}.mock-band-chart{background:var(--bg-surface);border:1px solid var(--border-base);height:110px;padding:8px;position:relative;overflow:hidden}.mock-entity-stats-table{border-collapse:collapse;width:100%;font-size:.78rem}.mock-entity-stats-table th{color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border-mid);text-transform:uppercase;letter-spacing:.04em;padding:4px 8px;font-size:.65rem;font-weight:600}.mock-entity-stats-table td{border-bottom:1px solid var(--border-base);color:var(--text-body);padding:5px 8px}.mock-entity-stats-table tr:hover td{background:var(--bg-raised)}.mock-color-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:5px;display:inline-block}.mock-scenario-header{background:var(--bg-raised);border-bottom:1px solid var(--border-base);align-items:center;gap:12px;padding:8px 12px;display:flex}.mock-scenario-label{color:var(--text-body);white-space:nowrap;font-size:.8rem}.mock-scenario-slider{appearance:none;background:linear-gradient(to right, var(--amber) 30%, var(--border-mid) 30%);border-radius:2px;outline:none;flex:1;height:4px}.mock-pending-pad{padding:10px 12px}.mock-pending-name{font-family:var(--font-display);color:var(--amber-bright);margin-bottom:8px;font-size:.9rem}.mock-radio-group{flex-wrap:wrap;gap:10px;margin-bottom:6px;display:flex}.mock-radio-label{color:var(--text-body);align-items:center;gap:4px;font-size:.72rem;display:flex}.mock-footer-row{border-top:1px solid var(--border-base);justify-content:flex-end;gap:8px;margin-top:10px;padding-top:8px;display:flex}.mock-btn-primary{background:var(--amber);color:#fff;cursor:default;font-size:.75rem;font-weight:600;font-family:var(--font-ui);border:none;padding:4px 12px}.guide-def-list{margin:.5rem 0 .75rem;padding:0}.guide-def-list dt{color:var(--text-bright);margin-top:.75rem;font-size:.9rem;font-weight:700}.guide-def-list dd{color:var(--text-body);margin:.1rem 0 0 1rem;font-size:.875rem;line-height:1.6}.guide-badge{background:var(--bg-raised);border:1px solid var(--border-mid);color:var(--amber-text);letter-spacing:.03em;vertical-align:middle;margin:0 2px;padding:1px 7px;font-size:.72rem;font-weight:600;display:inline-block}.mock-legend{flex-wrap:wrap;gap:12px;padding:6px 0 2px;display:flex}.mock-legend-item{color:var(--text-body);align-items:center;gap:5px;font-size:.72rem;display:flex}.mock-legend-line{border-radius:2px;width:20px;height:3px}.mock-legend-band{opacity:.4;width:20px;height:10px}.contact-page{max-width:560px;margin:3rem auto;padding:0 1.5rem 4rem}.contact-card{background:var(--bg-card);border:1px solid var(--border-mid);padding:2rem 2rem 2.5rem}.contact-title{font-family:var(--font-display);color:var(--amber-bright);margin:0 0 .4rem;font-size:1.8rem}.contact-subtitle{color:var(--text-muted);margin:0 0 2rem;font-size:.95rem}.contact-form{flex-direction:column;gap:1.25rem;display:flex}.contact-field{flex-direction:column;gap:.35rem;display:flex}.contact-label{font-family:var(--font-ui);color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.contact-input{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-bright);font-family:var(--font-ui);box-sizing:border-box;outline:none;width:100%;padding:.55rem .75rem;font-size:.95rem;transition:border-color .15s}.contact-input::placeholder{color:var(--text-dim)}.contact-input:focus{border-color:var(--amber)}.contact-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23887060' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2.25rem}.contact-textarea{resize:vertical;min-height:120px;font-family:var(--font-body);font-size:1rem;line-height:1.6}.contact-submit{align-self:flex-start;margin-top:.25rem}.guides-layout{align-items:flex-start;min-height:100%;display:flex}.guides-sidebar{border-right:1px solid var(--border-base);flex-shrink:0;width:220px;max-height:100vh;padding:1.5rem 0 3rem;position:sticky;top:0;overflow-y:auto}.guides-sidebar-home{color:var(--text-dim);padding:.3rem 1.25rem .9rem;font-size:.8rem;text-decoration:none;transition:color .15s;display:block}.guides-sidebar-home:hover,.guides-sidebar-home.active{color:var(--amber-text)}.guides-sidebar-group{margin-bottom:.25rem}.guides-sidebar-heading{font-family:var(--font-ui);letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin:0;padding:.75rem 1.25rem .35rem;font-size:.68rem;font-weight:700}.guides-sidebar-link{color:var(--text-muted);border-left:2px solid #0000;padding:.3rem 1.25rem;font-size:.875rem;text-decoration:none;transition:color .15s,border-color .15s,background .15s;display:block}.guides-sidebar-link:hover{color:var(--text-bright);background:var(--bg-raised)}.guides-sidebar-link.active{color:var(--amber-text);border-left-color:var(--amber);background:var(--bg-raised)}.guides-content{flex:1;min-width:0;padding:2rem 2rem 4rem}.guides-page{max-width:860px;padding:0}.guides-hero{text-align:center;margin-bottom:2rem;padding:2.5rem 1rem 2rem}.guides-hero-title{font-family:var(--font-display);color:var(--amber-bright);margin:0 0 .6rem;font-size:2rem}.guides-hero-subtitle{color:var(--text-muted);margin:0;font-size:1rem;line-height:1.6}.guides-search-wrap{margin-bottom:2.5rem}.guides-search{box-sizing:border-box;background:var(--bg-surface);border:1px solid var(--border-mid);width:100%;color:var(--text-bright);font-family:var(--font-ui);outline:none;padding:.6rem 1rem;font-size:.95rem;transition:border-color .15s}.guides-search::placeholder{color:var(--text-dim)}.guides-search:focus{border-color:var(--amber)}.guides-no-results{color:var(--text-muted);text-align:center;padding:1.5rem 0;font-size:.95rem}.guides-section{margin-bottom:2.5rem}.guides-section-heading{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);border-bottom:1px solid var(--border-base);margin:0 0 1px;padding-bottom:.5rem;font-size:.85rem}.guides-grid{background:var(--border-base);border:1px solid var(--border-base);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1px;display:grid}.guides-card{background:var(--bg-card);border-top:3px solid var(--border-mid);transition:border-top-color var(--dur) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);flex-direction:column;gap:.4rem;padding:1.25rem 1.25rem 1rem;text-decoration:none;display:flex;position:relative}.guides-card:hover{border-top-color:var(--amber);background:var(--bg-raised);box-shadow:0 0 22px var(--amber-glow), var(--shadow-md)}.guides-card:before,.guides-card:after{content:"";border-color:var(--border-gold);opacity:.4;pointer-events:none;width:10px;height:10px;transition:opacity var(--dur) var(--ease), border-color var(--dur) var(--ease);border-style:solid;position:absolute}.guides-card:before{border-width:1px 0 0 1px;top:6px;left:6px}.guides-card:after{border-width:0 1px 1px 0;bottom:6px;right:6px}.guides-card:hover:before,.guides-card:hover:after{opacity:1;border-color:var(--amber-mid)}.guides-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.guides-card-title{font-family:var(--font-display);color:var(--text-bright);margin:0;font-size:.95rem;line-height:1.3}.guides-card-badge{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.06em;background:var(--amber-bright);color:var(--bg-base);border-radius:999px;flex-shrink:0;padding:2px 7px;font-size:.65rem;font-weight:600;line-height:1.6}.guides-card-desc{color:var(--text-muted);margin:0;font-size:.85rem;line-height:1.5}.app{flex-direction:column;height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1100px;min-height:0;margin:0 auto;padding:2.5rem 1.5rem;overflow-y:auto}.navbar{background:var(--bg-nav);border-bottom:1px solid var(--border-mid);box-shadow:0 1px 0 var(--border-base), 0 2px 12px #00000080;z-index:10;flex-shrink:0;grid-template-columns:auto 1fr auto;align-items:stretch;gap:0;height:58px;padding:0 1.5rem;display:grid}.navbar-brand{font-family:var(--font-display);color:var(--gold-on-dark);letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;transition:color var(--dur) var(--ease);align-items:center;gap:.5rem;padding-right:1.5rem;font-size:1.15rem;font-weight:700;text-decoration:none;display:flex}.navbar-brand:hover{color:#e8cc60}.navbar-brand-icon{opacity:.85;object-fit:contain;width:1.4em;height:1.4em}.navbar-nav{justify-content:center;gap:0;list-style:none;display:flex}.navbar-nav a{color:var(--text-muted);font-family:var(--font-ui);letter-spacing:.02em;height:58px;transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease);border-bottom:2px solid #0000;padding:0 1rem;font-size:.875rem;font-weight:500;line-height:58px;text-decoration:none;display:block}.navbar-nav a:hover{color:var(--text-body)}.navbar-nav a.active{color:var(--amber-text);border-bottom-color:var(--amber);font-weight:600}.navbar-right{align-items:center;gap:.6rem;padding-left:1.5rem;display:flex}.navbar-admin-link{font-family:var(--font-ui);color:var(--text-muted);border:1px solid var(--border-mid);transition:color var(--dur), border-color var(--dur);border-radius:999px;padding:.3rem .75rem;font-size:.8rem;font-weight:500;text-decoration:none}.navbar-admin-link:hover{color:var(--text-body);border-color:var(--border-amber)}.navbar-admin-link.active{color:var(--amber-text);border-color:var(--amber)}.navbar-user{align-items:center;gap:.6rem;display:flex}.navbar-user-name{color:var(--text-muted);font-size:.875rem}.navbar-user-tier{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--gold-dim);color:var(--gold-on-dark);background:#9a70201f;border-radius:999px;padding:.15rem .55rem;font-size:.65rem}.navbar-account-link{color:var(--text-muted);transition:color var(--dur);font-size:.875rem;text-decoration:none}.navbar-account-link:hover{color:var(--text-body)}.navbar-signin-btn{background:linear-gradient(180deg, var(--amber-mid) 0%, var(--amber) 100%);border:1px solid var(--amber-bright);border-bottom-color:var(--amber-dim);color:#1a0e04;cursor:pointer;font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;transition:filter var(--dur), box-shadow var(--dur);box-shadow:var(--shadow-sm);border-radius:999px;padding:.35rem 1rem;font-size:.75rem;font-weight:600}.navbar-signin-btn:hover{filter:brightness(1.1);box-shadow:0 0 14px var(--amber-glow)}.navbar-signout-btn{border:1px solid var(--border-mid);color:var(--text-muted);cursor:pointer;font-family:var(--font-ui);transition:border-color var(--dur), color var(--dur);background:0 0;border-radius:999px;padding:.3rem .85rem;font-size:.8rem}.navbar-signout-btn:hover{border-color:var(--border-amber);color:var(--text-body)}.navbar-cloak-select{background:var(--bg-surface);color:var(--amber-text);border:1px solid var(--border-amber);cursor:pointer;border-radius:999px;padding:.25rem .65rem;font-size:.75rem}.page-title{font-family:var(--font-display);letter-spacing:.05em;color:var(--text-bright);margin-bottom:.3rem;font-size:1.8rem;font-weight:600;line-height:1.2}.page-subtitle{font-family:var(--font-body);color:var(--text-muted);margin-bottom:2rem;font-size:1.1rem;font-style:italic}.hero{text-align:center;padding:3rem 1.5rem 2.5rem;position:relative}.hero:before{content:"";pointer-events:none;background:radial-gradient(60% 50% at 50% 0,#a880380f 0%,#0000 70%);position:absolute;inset:0}.hero-eyebrow{font-family:var(--font-display);letter-spacing:.25em;text-transform:uppercase;color:var(--gold-on-dark);border:1px solid var(--gold-dim);background:var(--gold-faint);border-radius:999px;margin-bottom:1.25rem;padding:.25rem .9rem;font-size:.7rem;display:inline-block}.hero-title{font-family:var(--font-display);color:var(--text-bright);letter-spacing:.08em;margin-bottom:1rem;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:700;line-height:1.1}.hero-subtitle{font-family:var(--font-body);color:var(--text-muted);max-width:540px;margin:0 auto 2rem;font-size:1.25rem;font-style:italic;line-height:1.6}.ornament{color:var(--gold-dim);font-family:var(--font-display);letter-spacing:.18em;text-transform:uppercase;-webkit-user-select:none;user-select:none;align-items:center;gap:.75rem;margin:1.5rem 0;font-size:.75rem;display:flex}.ornament:before,.ornament:after{content:"";flex:1;height:1px}.ornament:before{background:linear-gradient(to right, transparent, var(--border-gold))}.ornament:after{background:linear-gradient(to left, transparent, var(--border-gold))}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.25rem;display:grid}.card{background:var(--bg-card);border:1px solid var(--border-base);transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);border-radius:8px;flex-direction:column;gap:.5rem;padding:1.4rem 1.25rem;display:flex;position:relative}.card--clickable{cursor:pointer}.card--clickable:hover{background:var(--bg-raised);border-color:var(--amber-mid);box-shadow:0 0 22px var(--amber-glow), var(--shadow-md);transform:translateY(-1px)}.bracketed{position:relative}.bracketed:before,.bracketed:after{content:"";border-color:var(--border-gold);opacity:.4;pointer-events:none;width:10px;height:10px;transition:opacity var(--dur) var(--ease), border-color var(--dur) var(--ease);border-style:solid;position:absolute}.bracketed:before{border-width:1px 0 0 1px;top:6px;left:6px}.bracketed:after{border-width:0 1px 1px 0;bottom:6px;right:6px}.bracketed:hover:before,.bracketed:hover:after{opacity:1;border-color:var(--amber-mid)}.card-icon{margin-bottom:.1rem;font-size:1.6rem;line-height:1}.card-title{font-family:var(--font-display);letter-spacing:.04em;color:var(--text-bright);font-size:.95rem;font-weight:600}.card-description{font-family:var(--font-body);color:var(--text-muted);flex:1;font-size:1rem;line-height:1.5}.card-tag{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;border:1px solid;border-radius:999px;width:fit-content;margin-top:.2rem;padding:.15rem .6rem;font-size:.68rem;display:inline-block}.card-tag--free,.card-tag{border-color:var(--cat-free);color:#5cc8be;background:#2d8a8214}.card-tag--patron{border-color:var(--cat-patron);color:var(--gold-on-dark);background:#9a702014}.card-tag--locked{border-color:var(--border-mid);color:var(--text-dim);background:0 0}.btn-primary{background:linear-gradient(180deg, var(--amber-mid) 0%, var(--amber) 100%);color:#1a0e04;border:1px solid var(--amber-bright);border-bottom-color:var(--amber-dim);cursor:pointer;font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;transition:filter var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);box-shadow:var(--shadow-sm);border-radius:6px;justify-content:center;align-items:center;gap:.4rem;padding:.5rem 1.4rem;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary:hover{filter:brightness(1.1);box-shadow:0 0 18px var(--amber-glow), var(--shadow-md);transform:translateY(-1px)}.btn-primary:active{filter:brightness(.95);transform:none}.btn-ghost{color:var(--text-muted);border:1px solid var(--border-mid);cursor:pointer;font-family:var(--font-ui);transition:border-color var(--dur) var(--ease), color var(--dur) var(--ease);background:0 0;border-radius:6px;align-items:center;gap:.4rem;padding:.45rem 1.1rem;font-size:.875rem;display:inline-flex}.btn-ghost:hover{border-color:var(--border-amber);color:var(--text-body)}.btn-danger{background:var(--crimson);color:#fff;border:1px solid var(--crimson-mid);border-bottom-color:var(--crimson-dim);cursor:pointer;font-family:var(--font-ui);transition:filter var(--dur), box-shadow var(--dur);border-radius:6px;align-items:center;gap:.4rem;padding:.5rem 1.1rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn-danger:hover:not(:disabled){filter:brightness(1.15);box-shadow:0 0 14px var(--crimson-glow)}.btn-danger:disabled{opacity:.4;cursor:not-allowed}.btn-sm{padding:.3rem .85rem;font-size:.8rem}.guide-help-link{border:1px solid var(--border-mid);width:26px;height:26px;color:var(--text-muted);font-family:var(--font-ui);flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;text-decoration:none;transition:color .15s,border-color .15s;display:inline-flex}.guide-help-link:hover{color:var(--amber-text);border-color:var(--amber)}.field-label{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.4rem;font-size:.75rem;display:block}.field-input,.field-select,.field-textarea{background:var(--bg-surface);border:1px solid var(--border-mid);width:100%;color:var(--text-bright);font-family:var(--font-ui);transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);border-radius:6px;outline:none;padding:.55rem .85rem;font-size:.95rem}.field-input:focus,.field-select:focus,.field-textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px #c8761421}.field-input::placeholder,.field-textarea::placeholder{color:var(--text-dim)}.field-input--mono{font-family:var(--font-mono);font-size:1rem}.field-textarea{resize:vertical;font-family:var(--font-ui)}.char-form-checkbox input[type=checkbox],.char-save-toggle input[type=checkbox]{appearance:none;border:1.5px solid var(--border-mid);background:var(--bg-surface);cursor:pointer;width:15px;height:15px;transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease);vertical-align:middle;flex-shrink:0;position:relative}.char-form-checkbox input[type=checkbox]:checked,.char-save-toggle input[type=checkbox]:checked{background:var(--amber);border-color:var(--amber);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'%3E%3Cpath d='M2 5l2.5 2.5L8 3' stroke='%231a1208' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-size:100% 100%}.char-form-checkbox input[type=checkbox]:focus-visible,.char-save-toggle input[type=checkbox]:focus-visible{outline:1.5px solid var(--amber);outline-offset:2px}.char-form-checkbox input[type=checkbox]:disabled{opacity:.4;cursor:not-allowed}.char-save-toggle input[type=checkbox]{width:12px;height:12px}.dice-roller{max-width:600px}.dice-roller code{font-family:var(--font-mono);background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--amber-text);border-radius:2px;padding:.1em .4em;font-size:.875em}.dice-controls{gap:.75rem;margin-bottom:1rem;display:flex}.dice-notation-input{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-bright);font-family:var(--font-mono);transition:border-color var(--dur), box-shadow var(--dur);border-radius:0;outline:none;flex:1;padding:.55rem .85rem;font-size:1.05rem}.dice-notation-input:focus{border-color:var(--amber);box-shadow:0 0 0 3px #c8761421}.dice-notation-input::placeholder{color:var(--text-dim)}.dice-btn{background:linear-gradient(180deg, var(--amber-mid) 0%, var(--amber) 100%);border:1px solid var(--amber-bright);border-bottom-color:var(--amber-dim);color:#1a0e04;cursor:pointer;font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;transition:filter var(--dur), box-shadow var(--dur);box-shadow:var(--shadow-sm);border-radius:999px;padding:.55rem 1.4rem;font-size:.875rem;font-weight:600}.dice-btn:hover{filter:brightness(1.1);box-shadow:0 0 16px var(--amber-glow), var(--shadow-md)}.dice-quick{flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem;display:flex}.dice-quick-btn{background:var(--bg-surface);border:1px solid var(--border-base);color:var(--text-muted);cursor:pointer;transition:border-color var(--dur), color var(--dur), background var(--dur);border-radius:999px;padding:.3rem .8rem;font-size:.8rem;font-weight:500}.dice-quick-btn:hover{border-color:var(--border-amber);color:var(--amber-text);background:var(--amber-faint)}.dice-quick-btn--adv{border-color:var(--forest-dim);color:var(--forest-mid)}.dice-quick-btn--adv:hover{border-color:var(--forest-mid);color:var(--forest-mid);background:#2a7a5014}.dice-quick-btn--dis{border-color:var(--crimson-dim);color:var(--crimson-mid)}.dice-quick-btn--dis:hover{border-color:var(--crimson-mid);color:var(--crimson-mid);background:#8b222214}.dice-combine-label{color:var(--text-muted);cursor:pointer;align-items:center;gap:.4rem;margin-left:auto;font-size:.8rem;display:flex}.dice-combine-label input{accent-color:var(--amber);cursor:pointer}.dice-error{color:var(--crimson-mid);margin-bottom:1rem;font-size:.875rem}.dice-result{background:var(--bg-card);border:1px solid var(--border-mid);border-left:3px solid var(--gold);transition:border-color .3s var(--ease), box-shadow .3s var(--ease);border-radius:0;padding:2rem}.dice-result--crit{box-shadow:-4px 0 32px #e8b84a59, var(--shadow-md);border-left-color:#e8b84a}.dice-result--fail{box-shadow:-4px 0 32px #e0383859, var(--shadow-md);border-left-color:#e03838}.dice-result-total{font-family:var(--font-display);color:var(--text-bright);text-align:center;letter-spacing:.02em;font-size:4.5rem;font-weight:700;line-height:1}.dice-result--crit .dice-result-total{color:#f0cc60;text-shadow:0 0 30px #f0cc608c,0 0 8px #f0cc604d}.dice-result-crit-label{text-align:center;font-family:var(--font-display);color:#e8b84a;letter-spacing:.18em;text-transform:uppercase;margin-top:.5rem;margin-bottom:1rem;font-size:.85rem;font-weight:600}.dice-breakdown{border-top:1px solid var(--border-base);flex-direction:column;gap:.6rem;margin-top:1.25rem;padding-top:1rem;display:flex}.dice-group{align-items:center;gap:.75rem;font-size:.875rem;display:flex}.dice-group-notation{color:var(--text-muted);font-family:var(--font-mono);min-width:80px}.dice-group-dice{flex-wrap:wrap;flex:1;gap:.3rem;display:flex}.die-pip{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-body);font-family:var(--font-display);text-align:center;border-radius:2px;min-width:1.9rem;padding:.2rem .4rem;font-size:.8rem;font-weight:600}.die-pip--dropped{opacity:.3;text-decoration:line-through}.die-pip--min{color:#f05050;background:#e038381a;border-color:#c02828}.die-pip--max{color:#f0cc60;background:#f0cc601a;border-color:#b08030}.dice-group-eq{color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap}.dice-group-eq--min{color:#f05050}.dice-group-eq--max{color:#f0cc60}.dice-result-total--min{color:#f05050;text-shadow:0 0 30px #f050508c,0 0 8px #f050504d}.dice-result-total--max{color:#f0cc60;text-shadow:0 0 30px #f0cc608c,0 0 8px #f0cc604d}.dice-reference{background:var(--bg-card);border:1px solid var(--border-base);flex-wrap:wrap;gap:1.5rem;margin-bottom:1.25rem;padding:.85rem 1rem;display:flex}.dice-reference-col{flex-direction:column;flex:1;gap:4px;min-width:200px;display:flex}.dice-reference-heading{font-family:var(--font-ui);color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-base);margin-bottom:4px;padding-bottom:3px;font-size:.7rem;font-weight:600}.dice-reference-row{align-items:baseline;gap:8px;font-size:.82rem;display:flex}.dice-reference-row code{font-family:var(--font-mono);color:var(--amber-text);flex-shrink:0;min-width:80px;font-size:.8rem}.dice-reference-row span{color:var(--text-muted);font-size:.78rem}.dice-reference-row--note{align-items:flex-start}.dice-reference-row--note span{line-height:1.55}.dice-reference-row--note code{min-width:unset}.dice-distribution{border-top:1px solid var(--border-base);margin-top:1.25rem;padding-top:1rem}.dist-controls{gap:.3rem;margin-bottom:.75rem;display:flex}.dist-mode-btn{border:1px solid var(--border-mid);color:var(--text-muted);cursor:pointer;transition:border-color var(--dur), color var(--dur);background:0 0;border-radius:999px;padding:.3rem .75rem;font-size:.8rem}.dist-mode-btn:hover{border-color:var(--border-amber);color:var(--text-body)}.dist-mode-btn.active{background:var(--amber-faint);border-color:var(--amber);color:var(--amber-text);font-weight:600}.dist-row-toggles{flex-wrap:wrap;gap:.3rem;margin-left:.5rem;display:flex}.dist-row-toggle{border:1px solid var(--border-mid);color:var(--text-muted);cursor:pointer;font-family:var(--font-mono);transition:border-color var(--dur), color var(--dur), opacity var(--dur);background:0 0;border-radius:999px;align-items:center;gap:.35rem;padding:.2rem .6rem;font-size:.75rem;display:flex}.dist-row-toggle[aria-pressed=true]{border-color:var(--toggle-color);color:var(--text-body)}.dist-row-toggle[aria-pressed=false]{opacity:.4}.dist-row-toggle-dot{background:var(--toggle-color);border-radius:50%;flex-shrink:0;width:7px;height:7px}.dist-empty{color:var(--text-muted);text-align:center;padding:1rem 0 .5rem;font-size:.8rem}.dist-explainer{color:var(--text-dim);margin:.4rem 0 0;font-size:.75rem;line-height:1.5}.dist-svg{width:100%;height:auto;display:block}.empty-state{text-align:center;color:var(--text-muted);padding:4rem 2rem}.empty-state p:first-child{margin-bottom:.75rem;font-size:2.5rem}.gate-locked{border:1px dashed var(--border-mid);color:var(--text-muted);text-align:center;flex-direction:column;align-items:center;gap:.5rem;padding:2rem;display:flex}.gate-lock-icon{font-size:1.5rem}.gate-wrapper{position:relative;overflow:hidden}.gate-content-blur{filter:blur(3px);opacity:.25;pointer-events:none;-webkit-user-select:none;user-select:none}.gate-overlay{border:1px dashed var(--border-amber);text-align:center;color:var(--text-bright);background:#1c1810b3;flex-direction:column;justify-content:center;align-items:center;gap:.6rem;padding:1rem;display:flex;position:absolute;inset:0}.gate-overlay-icon{font-size:1.5rem}.gate-overlay p{color:var(--text-body);margin:0;font-size:.9rem}.gate-page{text-align:center;min-height:60vh;color:var(--text-body);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem;display:flex}.gate-page-icon{font-size:3rem}.gate-page h2{font-family:var(--font-display);letter-spacing:.05em;color:var(--text-bright);margin:0;font-size:1.5rem}.gate-page p{color:var(--text-muted);margin:0}.gate-page-actions{gap:1rem;margin-top:.5rem;display:flex}.footer{color:var(--text-dim);border-top:1px solid var(--border-base);opacity:.7;flex-direction:column;align-items:center;gap:.3rem;padding:.75rem;font-size:.75rem;display:flex}.footer-legal{gap:.75rem;display:flex}.footer-legal a{color:var(--text-dim);transition:color var(--dur);text-decoration:none}.footer-legal a:hover{color:var(--amber-text)}.legal-page{max-width:800px;color:var(--text-body);margin:2rem auto;padding:2rem;line-height:1.7}.legal-page h1{font-family:var(--font-display);color:var(--gold-on-dark);letter-spacing:.05em;margin-bottom:.25rem;font-size:2rem}.legal-updated{color:var(--text-dim);margin-bottom:2rem;font-size:.85rem}.legal-page h2{font-family:var(--font-display);letter-spacing:.06em;color:var(--amber-text);margin-top:2rem;margin-bottom:.5rem;font-size:.9rem}.legal-page ul{padding-left:1.5rem}.legal-page li{margin-bottom:.4rem}.legal-page a{color:var(--amber);text-decoration:none}.legal-page a:hover{color:var(--amber-bright);text-decoration:underline}.legal-page code{font-family:var(--font-mono);color:var(--text-muted);font-size:.85em}.legal-table{border-collapse:collapse;width:100%;margin:.75rem 0;font-size:.875rem}.legal-table th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border-mid);text-transform:uppercase;letter-spacing:.04em;padding:5px 10px;font-size:.75rem;font-weight:600}.legal-table td{border-bottom:1px solid var(--border-base);color:var(--text-body);padding:6px 10px}.legal-table tr:last-child td{border-bottom:none}.legal-page section{border-bottom:1px solid var(--border-base);padding-bottom:1rem}.cookie-banner{background:var(--bg-card);border-top:1px solid var(--border-mid);z-index:1000;color:var(--text-muted);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 2rem;font-size:.9rem;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #0006}.cookie-banner p{margin:0}.cookie-banner a{color:var(--amber-text);text-decoration:underline}.beta-banner{color:var(--text-body);background:#8b22222e;border-bottom:1px solid #8b222266;align-items:center;gap:.75rem;padding:.35rem 1rem;font-size:.85rem;display:flex}.beta-banner-badge{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.08em;color:#f5d0d0;background:#8b2222;border-radius:999px;flex-shrink:0;padding:2px 8px;font-size:.65rem;font-weight:700}.beta-banner-text{flex:1;margin:0}.cloak-banner{border-bottom:1px solid var(--amber-dim);color:var(--text-body);background:#c8761414;align-items:center;gap:.75rem;padding:.4rem 1rem;font-size:.85rem;display:flex}.cloak-banner strong{color:var(--amber-text);text-transform:capitalize}.cloak-banner button{border:1px solid var(--amber-dim);color:var(--amber-text);cursor:pointer;transition:background var(--dur), color var(--dur);background:0 0;border-radius:999px;margin-left:auto;padding:.15rem .6rem;font-size:.8rem}.cloak-banner button:hover{background:var(--amber);color:#1a0e04}:is(.main-content:has(.campaigns-page),.main-content:has(.characters-page),.main-content:has(.bestiary-page)){max-width:100%;padding:0;overflow:hidden}:is(body:has(.campaigns-page) .footer,body:has(.characters-page) .footer,body:has(.bestiary-page) .footer){display:none}.campaigns-page,.characters-page,.bestiary-page{flex-direction:column;height:100%;display:flex;overflow:hidden}.scrollbar-thin{scrollbar-width:thin;scrollbar-color:var(--border-mid) transparent}.panel-box{background:var(--bg-card);border:1px solid var(--border-mid);margin-bottom:1.5rem;padding:1.5rem}.btn-reset{cursor:pointer;color:inherit;background:0 0;border:none;padding:0}.table-base{border-collapse:collapse;width:100%;font-size:.9rem}.table-base th{text-align:left;border-bottom:1px solid var(--border-mid);color:var(--text-muted);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;padding:.6rem .75rem;font-size:.7rem;font-weight:600}.table-base td{border-bottom:1px solid var(--border-base);color:var(--text-body);padding:.6rem .75rem}.modal-overlay{z-index:200;background:#1c1810c7;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay--top{align-items:flex-start;padding-top:4vh}.modal-box{background:var(--bg-card);border:1px solid var(--border-mid);flex-direction:column;gap:.75rem;width:min(480px,92vw);max-height:80vh;padding:1.25rem 1.5rem;display:flex;overflow-y:auto}.modal-box--wide{width:min(860px,95vw);max-height:92vh}.modal-header{border-bottom:1px solid var(--border-base);flex-shrink:0;justify-content:space-between;align-items:center;padding-bottom:.5rem;display:flex}.modal-title{font-family:var(--font-display);letter-spacing:.04em;color:var(--text-bright);font-size:1rem}.workspace-empty-state{height:100%;color:var(--text-muted);font-family:var(--font-body);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;font-size:1.05rem;display:flex}.workspace-empty-state p:first-child{font-size:2.5rem}.library-item{cursor:pointer;transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease);border-left:2px solid #0000;align-items:center;padding:.6rem 1rem;display:flex}.library-item:hover{background:var(--bg-raised)}.library-item.active{background:var(--amber-faint);border-left-color:var(--amber)}.library-item-name{font-family:var(--font-body);color:var(--text-body);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:1rem;overflow:hidden}.library-item.active .library-item-name{color:var(--text-bright)}
