@import"https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700&family=Cinzel:wght@400;600;700&family=IM+Fell+DW+Pica:ital@0;1&family=Courier+Prime:ital,wght@0,400;0,700;1,400&display=swap";.login-root{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;overflow:hidden;background:var(--color-void)}.login-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;filter:brightness(.55) saturate(.8);z-index:0}.login-card{position:relative;z-index:10;width:100%;max-width:440px;margin:1rem;padding:2.25rem 2.25rem 1.75rem;background:#060a0ed1;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(13,115,119,.25);border-radius:16px;box-shadow:0 0 60px #0d737714,0 12px 40px #000000e6,inset 0 1px #b8860b14}.login-header{text-align:center;margin-bottom:1.75rem}.login-eye{width:68px;height:68px;object-fit:contain;border-radius:50%;filter:drop-shadow(0 0 14px var(--color-teal-glow));animation:eye-pulse 5s ease-in-out infinite;margin:0 auto .75rem;display:block}@keyframes eye-pulse{0%,to{filter:drop-shadow(0 0 6px var(--color-teal-dim))}50%{filter:drop-shadow(0 0 24px var(--color-teal-glow))}}.login-title{font-family:var(--font-title);font-size:1.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:linear-gradient(135deg,var(--color-parchment),var(--color-teal-bright) 80%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{font-family:var(--font-body);color:var(--color-text-dim);font-style:italic;font-size:.95rem;margin-top:.2rem}.login-tabs{display:flex;background:#0006;border-radius:10px;padding:3px;margin-bottom:1.5rem;border:1px solid var(--color-border)}.login-tab{flex:1;padding:.5rem;border:none;border-radius:8px;background:transparent;color:var(--color-text-dim);font-family:var(--font-ui);font-weight:500;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:all var(--transition-base)}.login-tab.active{background:#0d73772e;color:var(--color-teal-bright);box-shadow:0 0 12px #0d737726}.login-tab:hover:not(.active){color:var(--color-text)}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form input{background:#03050799;border:1px solid var(--color-border);font-family:var(--font-body);font-size:1.05rem}.login-form input:focus{border-color:var(--color-teal);box-shadow:0 0 0 2px var(--color-teal-dim)}.login-form label{font-family:var(--font-ui);font-weight:500;font-size:.75rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.1em}.role-toggle{display:flex;gap:.5rem}.role-btn{flex:1;padding:.5rem;border:1px solid var(--color-border);border-radius:8px;background:#0000004d;color:var(--color-text-dim);font-family:var(--font-ui);font-weight:500;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:all var(--transition-fast)}.role-btn.active{border-color:var(--color-teal);background:var(--color-teal-dim);color:var(--color-teal-bright)}.role-btn:hover:not(.active){border-color:var(--color-border-bright);color:var(--color-text)}.login-form .btn-primary{background:linear-gradient(135deg,#064d51,#0d7377);border-color:var(--color-teal);box-shadow:var(--shadow-teal);font-family:var(--font-ui);font-weight:600;font-size:.9rem;letter-spacing:.06em;text-transform:uppercase;padding:.7rem 1.5rem}.login-form .btn-primary:hover{background:linear-gradient(135deg,#0d7377,#14a3a8);filter:brightness(1.1)}.login-error{color:var(--color-fail);font-family:var(--font-ui);font-size:.85rem;padding:.5rem .75rem;background:#f8717114;border:1px solid rgba(248,113,113,.25);border-radius:8px}.login-info{color:var(--color-teal-bright);font-family:var(--font-ui);font-size:.85rem;padding:.5rem .75rem;background:#10b98114;border:1px solid rgba(16,185,129,.22);border-radius:8px}.login-inline-link{margin-top:.45rem;align-self:flex-start;padding:0;border:0;background:transparent;color:var(--color-gold);font-size:.8rem;cursor:pointer}.login-inline-link:hover{color:var(--color-gold-bright)}.login-divider{display:flex;align-items:center;gap:.75rem;margin:.75rem 0;color:var(--color-text-dim);font-family:var(--font-ui);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-quick-actions{display:flex;flex-direction:column;gap:.5rem}.login-helper-panel{margin-top:1rem;margin-bottom:.5rem;padding:1rem;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#00000047}.login-helper-panel h3{margin:0 0 .35rem;color:var(--color-text-bright);font-size:1rem}.login-helper-panel p{margin:0 0 .8rem;color:var(--color-text-dim);line-height:1.55;font-size:.85rem}.login-helper-panel input{width:100%;background:#03050799;border:1px solid var(--color-border);font-family:var(--font-body)}.login-helper-actions{display:flex;gap:.65rem;margin-top:.8rem}.btn-quick{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.6rem 1rem;border:1px solid var(--color-border);border-radius:8px;background:#00000040;color:var(--color-text-dim);font-family:var(--font-ui);font-weight:400;font-size:.82rem;cursor:pointer;transition:all var(--transition-fast)}.btn-quick:hover{border-color:var(--color-gold-dim);color:var(--color-gold);background:#b8860b0f}.btn-quick-observer{border-color:var(--color-olive-dim);color:var(--color-olive)}.btn-quick-observer:hover{border-color:var(--color-olive);color:var(--color-olive-bright);background:var(--color-olive-dim)}.session-code-group{display:flex;gap:.5rem}.session-code-group input{flex:1;font-family:var(--font-mono);font-size:.95rem;letter-spacing:.15em;text-align:center;text-transform:uppercase}.session-code-group .btn-primary{flex-shrink:0;padding:.55rem 1rem;font-size:.8rem}@media (prefers-reduced-motion: reduce){.login-eye{animation:none;filter:drop-shadow(0 0 10px var(--color-teal-dim))}.login-video{filter:brightness(.4) saturate(.6)}}@media (max-width: 480px){.login-card{margin:.75rem;padding:1.5rem}.login-title{font-size:1.5rem}.login-helper-actions,.session-code-group{flex-direction:column}}.char-builder{display:flex;flex-direction:column;gap:1rem;color:var(--color-text)}.cb-stepper{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.cb-step-chip{display:flex;align-items:center;gap:.75rem;padding:.82rem .9rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text);text-align:left;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease}.cb-step-chip:hover:not(:disabled){transform:translateY(-1px);border-color:#10b9813d}.cb-step-chip:disabled{cursor:not-allowed;opacity:.72}.cb-step-chip.is-active{border-color:#d4af3747;background:#d4af3714}.cb-step-chip.is-complete .cb-step-badge{color:#8af2c1;border-color:#10b98142}.cb-step-chip.is-locked .cb-step-badge{color:var(--color-text-dim)}.cb-step-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:var(--color-gold-bright);flex:0 0 auto}.cb-step-copy{display:flex;flex-direction:column;gap:.18rem;min-width:0}.cb-step-copy strong{color:var(--color-text-bright);font-size:.82rem}.cb-step-copy small,.cb-step-counter{color:var(--color-text-dim);font-size:.74rem;line-height:1.45}.cb-progress-panel{display:grid;gap:.8rem;padding:1rem 1.1rem;border:1px solid rgba(212,175,55,.16);border-radius:20px;background:linear-gradient(135deg,rgba(212,175,55,.08),transparent 46%),#ffffff09}.cb-progress-main{display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,260px);gap:1rem;align-items:center}.cb-progress-copy{display:grid;gap:.25rem}.cb-progress-copy span,.cb-next-action strong,.cb-blocker-list span{font-family:var(--font-title);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.cb-progress-copy span{color:var(--color-gold)}.cb-progress-copy strong{color:var(--color-text-bright);font-size:1rem}.cb-progress-copy p{max-width:78ch;margin:0;color:var(--color-text-dim);line-height:1.55}.cb-progress-meter{display:grid;gap:.42rem}.cb-progress-meter span{justify-self:end;color:var(--color-text-bright);font-family:var(--font-mono);font-size:.8rem}.cb-progress-track{height:8px;overflow:hidden;border-radius:999px;background:#ffffff14}.cb-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--color-gold),var(--color-success));transition:width .18s ease}.cb-next-action{display:flex;flex-wrap:wrap;gap:.45rem .8rem;align-items:center;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.07)}.cb-next-action strong{color:var(--color-gold-bright)}.cb-next-action span{color:var(--color-text);line-height:1.45}.cb-blocker-list{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center}.cb-blocker-list small,.cb-blocker-list span{font-family:var(--font-title);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.cb-blocker-list small{color:var(--color-text-dim)}.cb-blocker-list span{padding:.35rem .52rem;border:1px solid rgba(239,68,68,.24);border-radius:999px;background:#ef444414;color:#ffb7b7}.cb-help{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-left:.3rem;padding:0;border:0;border-radius:999px;background:transparent;color:var(--color-gold-bright);cursor:pointer;vertical-align:middle;transition:background .14s ease,color .14s ease,box-shadow .14s ease}.cb-help:hover,.cb-help:focus-visible,.cb-help.is-open{background:#d4af371f;box-shadow:0 0 0 2px #d4af3738;color:#ffe38a;outline:none}.cb-help-popover-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:260;display:grid;place-items:center;padding:1rem;background:#0000003d}.cb-help-popover{display:grid;gap:.65rem;width:min(360px,calc(100vw - 2rem));padding:.9rem;border:1px solid rgba(212,175,55,.26);border-radius:12px;background:#081014fa;box-shadow:0 22px 46px #00000061;color:var(--color-text)}.cb-help-popover strong{color:var(--color-gold-bright);font-family:var(--font-title);letter-spacing:.04em;text-transform:uppercase}.cb-help-popover span{color:var(--color-text);font-size:.88rem;line-height:1.5}.cb-help-popover .btn{justify-self:end}.cb-step-stack{display:flex;flex-direction:column;gap:.9rem}.cb-step-subpanel{display:flex;flex-direction:column;gap:.8rem;padding:.82rem .9rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.cb-layout--single{grid-template-columns:1fr}.cb-impact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.65rem}.cb-impact-card{display:flex;flex-direction:column;gap:.2rem;padding:.75rem .8rem;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#d4af370f}.cb-impact-card span,.cb-impact-card small{color:var(--color-text-dim)}.cb-impact-card strong{color:var(--color-text-bright);font-family:var(--font-title)}.cb-help-row{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:.8rem}.cb-help-chip{display:inline-flex;align-items:center;gap:.32rem;padding:.38rem .58rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text-dim);font-size:.74rem}.cb-module-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.char-builder--dialog{min-width:min(1100px,92vw)}.cb-head,.cb-panel,.cb-feedback,.cb-footer{border:1px solid rgba(255,255,255,.08);border-radius:24px;background:radial-gradient(circle at top right,rgba(212,175,55,.08),transparent 28%),linear-gradient(180deg,#0b171cf2,#071015f5);box-shadow:inset 0 1px #ffffff0a}.cb-head,.cb-footer,.cb-panel{padding:1.1rem 1.2rem}.cb-kicker,.cb-panel-note,.cb-mini-title,.cb-field span,.cb-summary-grid span,.cb-combat-label,.cb-attr-driver{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title)}.cb-kicker{color:var(--color-gold)}.cb-title{margin:.2rem 0 0;font-size:1.35rem;color:var(--color-text-bright);font-family:var(--font-title)}.cb-subtitle{margin:.55rem 0 0;max-width:62ch;color:var(--color-text-dim);line-height:1.6}.cb-layout{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:1rem;align-items:start}.cb-layout.cb-layout--single{grid-template-columns:1fr}.cb-stack,.cb-sidebar,.cb-occupation-summary,.cb-skill-entry-list{display:flex;flex-direction:column;gap:1rem}.cb-panel-head{display:flex;align-items:end;justify-content:space-between;gap:.8rem;margin-bottom:.9rem}.cb-panel-title{display:inline-flex;align-items:center;gap:.45rem;color:var(--color-gold-bright);font-family:var(--font-title);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase}.cb-panel-note,.cb-field span,.cb-summary-grid span,.cb-combat-label{color:var(--color-text-dim)}.cb-form-grid,.cb-summary-grid,.cb-attrs-grid{display:grid;gap:.75rem}.cb-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cb-field{display:flex;flex-direction:column;gap:.45rem;position:relative}.cb-field--wide{grid-column:1 / -1}.cb-field input,.cb-field select,.cb-field textarea,.cb-search input{width:100%;min-width:0;padding:.82rem .92rem;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#ffffff09;color:var(--color-text-bright);outline:none}.cb-field input:focus,.cb-field select:focus,.cb-field textarea:focus,.cb-search input:focus{border-color:#d4af3747;box-shadow:0 0 0 1px #d4af3724}.cb-field textarea{min-height:92px;resize:vertical;line-height:1.5}.cb-required-label{margin-left:.35rem;padding:.12rem .35rem;border-radius:999px;border:1px solid rgba(239,68,68,.28);color:#ffb7b7;font-size:.58rem;letter-spacing:.08em;text-transform:uppercase}.cb-concept-guide,.cb-rule-guide,.cb-derived-guide,.cb-warning-list,.cb-checklist{display:grid;gap:.7rem}.cb-concept-guide{margin-top:.9rem;padding:.9rem;border-radius:18px;border:1px solid rgba(212,175,55,.14);background:#d4af370b}.cb-concept-guide p,.cb-summary-text{margin:.35rem 0 0;color:var(--color-text-dim);line-height:1.55}.cb-prompt-grid{display:flex;flex-wrap:wrap;gap:.45rem}.cb-prompt-grid span{padding:.42rem .58rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff09;color:var(--color-text-dim);font-size:.74rem}.cb-concept-guide strong{color:var(--color-text-bright)}.cb-rule-guide{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:.8rem}.cb-rule-card,.cb-age-note,.cb-derived-formula,.cb-check-item{border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.cb-rule-card{display:grid;gap:.3rem;padding:.78rem .82rem}.cb-rule-card strong,.cb-age-note strong,.cb-derived-formula strong,.cb-check-item strong{color:var(--color-text-bright)}.cb-rule-card span,.cb-age-note span,.cb-derived-formula small{color:var(--color-text-dim);line-height:1.45;font-size:.76rem}.cb-age-note{display:flex;flex-wrap:wrap;gap:.45rem .8rem;align-items:center;margin-bottom:.8rem;padding:.78rem .85rem}.cb-age-note.is-active{border-color:#d4af373d;background:#d4af370f}.cb-derived-guide{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.cb-derived-formula{display:grid;gap:.2rem;padding:.68rem .72rem}.cb-derived-formula span,.cb-check-item span{color:var(--color-text-dim);font-family:var(--font-title);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase}.cb-warning-list{margin-bottom:.85rem}.cb-warning-list span{padding:.72rem .8rem;border-radius:14px;border:1px solid rgba(239,68,68,.24);background:#ef444414;color:#ffb7b7;line-height:1.45}.cb-check-item{display:grid;grid-template-columns:82px minmax(0,1fr);gap:.65rem;align-items:center;padding:.68rem .74rem}.cb-check-item.is-done{border-color:#10b98133;background:#10b9810f}.cb-check-item.is-done span{color:#8af2c1}.cb-choice-picker{position:relative;min-width:0}.cb-choice-trigger{display:flex;align-items:center;justify-content:space-between;gap:.75rem;width:100%;min-height:42px;padding:.72rem .85rem;border:1px solid rgba(255,255,255,.09);border-radius:8px;background:#ffffff09;color:var(--color-text-bright);font-family:var(--font-ui);font-size:.78rem;text-align:left;cursor:pointer}.cb-choice-trigger:focus-visible,.cb-choice-picker.is-open .cb-choice-trigger{border-color:#d4af3761;box-shadow:0 0 0 2px #d4af371a;outline:none}.cb-choice-trigger:disabled{color:var(--color-text-dim);cursor:wait}.cb-choice-trigger svg{flex-shrink:0;transition:transform var(--transition-fast)}.cb-choice-picker.is-open .cb-choice-trigger svg{transform:rotate(180deg)}.cb-choice-menu{position:absolute;z-index:40;top:calc(100% + .35rem);right:0;left:0;display:flex;flex-direction:column;gap:.2rem;max-height:260px;overflow-y:auto;padding:.35rem;border:1px solid rgba(212,175,55,.28);border-radius:8px;background:#091317;box-shadow:0 18px 36px #0000007a}.cb-choice-option{display:flex;flex-direction:column;gap:.16rem;width:100%;padding:.62rem .7rem;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--color-text);text-align:left;cursor:pointer}.cb-choice-option:hover,.cb-choice-option:focus-visible{border-color:#ffffff1a;background:#ffffff0e;outline:none}.cb-choice-option.is-selected{border-color:#d4af3742;background:#d4af371a}.cb-choice-option strong{color:var(--color-text-bright);font-size:.75rem}.cb-choice-option small{color:var(--color-text-dim);font-size:.64rem;line-height:1.35}.cb-choice-tags{display:flex;flex-wrap:wrap;gap:.25rem}.cb-choice-tags small{padding:.18rem .38rem;border-radius:999px;border:1px solid rgba(13,148,136,.22);color:#8bd8d1;font-size:.58rem;line-height:1.2}.cb-input-modes{display:grid;gap:.7rem}.cb-input-modes{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:.7rem}.cb-auto-roll-summary{display:grid;gap:.3rem;margin-bottom:.75rem;padding:.85rem .95rem;border:1px solid rgba(13,148,136,.24);border-radius:18px;background:#0d948814}.cb-auto-roll-summary strong{color:var(--color-text-bright);font-family:var(--font-title);font-size:.78rem;letter-spacing:.03em}.cb-auto-roll-summary span{color:var(--color-text-dim);font-size:.72rem;line-height:1.5}.cb-method-btn,.cb-occupation-item{display:flex;flex-direction:column;gap:.22rem;padding:.85rem .9rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text);text-align:left;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease}.cb-method-btn:hover,.cb-occupation-item:hover{transform:translateY(-1px);border-color:#10b9813d}.cb-method-btn.active,.cb-occupation-item.active{border-color:#d4af3747;background:#d4af3714}.cb-method-btn strong,.cb-occupation-item strong,.cb-summary-hero strong{color:var(--color-text-bright)}.cb-method-btn span,.cb-occupation-item span,.cb-summary-hero span{color:var(--color-text-dim);font-size:.8rem;line-height:1.45}.cb-roll-bar,.cb-combat-row,.cb-driver-row,.cb-bonus-row,.cb-footer,.cb-footer-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.cb-roll-btn{padding:.85rem 1rem;border-radius:16px;border:1px solid rgba(212,175,55,.35);background:linear-gradient(135deg,#5a3500,#8b6010);color:#f0d090;font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,filter .16s ease}.cb-roll-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 28px #0000002e}.cb-roll-btn:disabled{opacity:.6;cursor:wait}.cb-roll-note,.cb-footer-copy,.cb-placeholder{color:var(--color-text-dim);line-height:1.55}.cb-placeholder{padding:1rem;border-radius:18px;border:1px dashed rgba(255,255,255,.12)}.cb-manual-stack{display:flex;flex-direction:column;gap:.8rem}.cb-manual-copy{color:var(--color-text-dim);line-height:1.55}.cb-manual-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}.cb-manual-card{display:flex;flex-direction:column;gap:.38rem;padding:.8rem .85rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.cb-manual-card span,.cb-manual-card small{color:var(--color-text-dim)}.cb-manual-card span{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title)}.cb-manual-card input{width:100%;min-width:0;padding:.8rem .85rem;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#ffffff0b;color:var(--color-text-bright);outline:none}.cb-manual-card input:focus{border-color:#d4af3747;box-shadow:0 0 0 1px #d4af3724}.cb-attrs-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.cb-attr-card{display:flex;flex-direction:column;gap:.45rem;min-height:138px;padding:.9rem .82rem;border-radius:18px;border:1px solid color-mix(in srgb,var(--attr-color) 24%,rgba(255,255,255,.08));background:radial-gradient(circle at top left,color-mix(in srgb,var(--attr-color) 12%,transparent),transparent 42%),#ffffff08}.cb-attr-card.is-driven{box-shadow:inset 0 0 0 1px #d4af372e}.cb-attribute-insights{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.65rem}.cb-attribute-insight{display:grid;gap:.25rem;padding:.75rem .82rem;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:#ffffff08}.cb-attribute-insight--warning{border-color:#ef444442;background:#ef444414}.cb-attribute-insight--strong{border-color:#d4af3742;background:#d4af3712}.cb-attribute-insight--neutral{border-color:#0d94883d;background:#0d948812}.cb-attribute-insight strong{color:var(--color-text-bright);font-family:var(--font-title);font-size:.74rem}.cb-attribute-insight span{color:var(--color-text);font-size:.72rem;line-height:1.48}.cb-attr-head,.cb-summary-grid{display:flex;justify-content:space-between;gap:.55rem;align-items:center}.cb-attr-name{color:var(--color-text-bright);font-family:var(--font-title)}.cb-attr-driver{padding:.18rem .38rem;border-radius:999px;border:1px solid rgba(212,175,55,.18);color:var(--color-gold-bright)}.cb-attr-val{font-size:1.9rem;font-weight:900;color:var(--attr-color);font-family:var(--font-title)}.cb-attr-desc{color:var(--color-text-dim);font-size:.76rem}.cb-attr-thresholds{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:auto;color:var(--color-text-dim);font-family:var(--font-mono);font-size:.72rem}.cb-attr-thresholds span,.cb-driver-pill,.cb-bonus-pill{padding:.28rem .5rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.cb-derived-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(112px,1fr));gap:.65rem}.cb-derived-card,.cb-combat-item,.cb-summary-grid div,.cb-skill-entry,.cb-description{border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.cb-derived-card{padding:.72rem .65rem;text-align:center}.cb-derived-val,.cb-combat-val,.cb-summary-grid strong{color:var(--color-text-bright);font-family:var(--font-title)}.cb-derived-val{font-size:1.25rem}.cb-derived-name{color:var(--color-text-dim);font-size:.72rem}.cb-derived-extra{color:var(--color-gold-bright);font-size:.68rem}.cb-combat-item{flex:1 1 180px;padding:.8rem .9rem;justify-content:space-between}.cb-combat-val{font-size:1rem;color:var(--color-fail)}.cb-search{display:block}.cb-occupation-list{display:flex;flex-direction:column;gap:.55rem;max-height:320px;overflow:auto;padding-right:.2rem}.cb-summary-hero{display:flex;flex-direction:column;gap:.32rem}.cb-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.cb-summary-grid div,.cb-skill-entry,.cb-description{display:flex;flex-direction:column;gap:.28rem;padding:.75rem .82rem}.cb-mini-title{display:inline-flex;align-items:center;gap:.38rem;color:var(--color-gold-bright)}.cb-pirate-grid,.cb-pirate-summary{display:grid;gap:.75rem}.cb-pirate-grid,.cb-pirate-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.cb-pirate-block,.cb-pirate-summary-card{display:flex;flex-direction:column;gap:.6rem;padding:.82rem .9rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.cb-choice-grid{display:grid;gap:.55rem}.cb-choice-chip{display:flex;flex-direction:column;gap:.22rem;padding:.72rem .78rem;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text);text-align:left;cursor:pointer;transition:border-color .16s ease,transform .16s ease,background .16s ease}.cb-choice-chip:hover{transform:translateY(-1px);border-color:#10b9813d}.cb-choice-chip.active{border-color:#d4af3747;background:#d4af3714}.cb-choice-chip strong,.cb-pirate-summary-card strong{color:var(--color-text-bright)}.cb-choice-chip span,.cb-pirate-summary-card span{color:var(--color-text-dim);font-size:.8rem;line-height:1.45}.cb-skill-entry{gap:.22rem}.cb-skill-entry strong{color:var(--color-text-bright);font-size:.84rem}.cb-skill-entry span{color:var(--color-text-dim);font-size:.78rem;line-height:1.45}.cb-skill-entry small{color:var(--color-text);font-size:.72rem;line-height:1.45}.cb-skill-entry--choice{border-color:#d4af3729}.cb-skill-entry--free{border-color:#10b9812e}.cb-homebrew-block,.cb-skill-block{display:flex;flex-direction:column;gap:.6rem}.cb-skill-block-note{margin:0;color:var(--color-text-dim);font-size:.72rem;line-height:1.45}.cb-description{flex-direction:row;align-items:flex-start;color:var(--color-text-dim);line-height:1.6}.cb-description p,.cb-note-list p{margin:0}.cb-feedback{padding:.95rem 1.05rem;color:var(--color-text-bright)}.cb-feedback.is-error{border-color:#ef444438;background:#ef444414;color:#ffb7b7}.cb-feedback.is-info{border-color:#10b98138;background:#10b98114;color:#a8f3d0}.cb-limit-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:1rem;background:#01080cad;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.cb-limit-dialog{display:grid;gap:.75rem;width:min(440px,100%);padding:1.05rem 1.1rem;border-radius:18px;border:1px solid rgba(239,68,68,.3);background:linear-gradient(135deg,rgba(239,68,68,.14),transparent 48%),#081014fa;color:var(--color-text);box-shadow:0 22px 50px #0000006b}.cb-limit-dialog-kicker{color:#ffb7b7;font-family:var(--font-title);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase}.cb-limit-dialog h4,.cb-limit-dialog p{margin:0}.cb-limit-dialog h4{color:var(--color-text-bright);font-family:var(--font-title);font-size:1rem}.cb-limit-dialog p{color:var(--color-text);line-height:1.55}.cb-limit-dialog .btn{justify-self:end}.cb-footer{justify-content:space-between}.cb-panel--summary-final{display:none}.char-builder--step-investigator .cb-layout>.cb-stack>.cb-panel--attributes-flow,.char-builder--step-investigator .cb-sidebar,.char-builder--step-investigator .cb-panel--skills,.char-builder--step-investigator .cb-panel--summary-final{display:none}.char-builder--step-method .cb-module-switch,.char-builder--step-method .cb-layout>.cb-stack>.cb-panel--identity,.char-builder--step-method .cb-layout>.cb-stack>.cb-panel--pirate-profile,.char-builder--step-method .cb-sidebar,.char-builder--step-method .cb-panel--skills,.char-builder--step-method .cb-panel--summary-final,.char-builder--step-method .cb-panel--attributes-flow .cb-attrs-grid,.char-builder--step-method .cb-panel--attributes-flow .cb-derived-row,.char-builder--step-method .cb-panel--attributes-flow .cb-combat-row,.char-builder--step-method .cb-panel--attributes-flow .cb-roll-bar,.char-builder--step-method .cb-panel--attributes-flow .cb-manual-grid,.char-builder--step-method .cb-panel--attributes-flow .cb-attr-driver{display:none}.char-builder--step-attributes .cb-module-switch,.char-builder--step-attributes .cb-layout>.cb-stack>.cb-panel--identity,.char-builder--step-attributes .cb-layout>.cb-stack>.cb-panel--pirate-profile,.char-builder--step-attributes .cb-sidebar,.char-builder--step-attributes .cb-panel--skills,.char-builder--step-attributes .cb-panel--summary-final,.char-builder--step-attributes .cb-panel--attributes-flow .cb-input-modes,.char-builder--step-attributes .cb-panel--attributes-flow .cb-derived-row,.char-builder--step-attributes .cb-panel--attributes-flow .cb-combat-row,.char-builder--step-attributes .cb-panel--attributes-flow .cb-audit-note{display:none}.char-builder--step-derived .cb-module-switch,.char-builder--step-derived .cb-layout>.cb-stack>.cb-panel--identity,.char-builder--step-derived .cb-layout>.cb-stack>.cb-panel--pirate-profile,.char-builder--step-derived .cb-sidebar,.char-builder--step-derived .cb-panel--skills,.char-builder--step-derived .cb-panel--summary-final,.char-builder--step-derived .cb-panel--attributes-flow .cb-input-modes,.char-builder--step-derived .cb-panel--attributes-flow .cb-auto-roll-summary,.char-builder--step-derived .cb-panel--attributes-flow .cb-roll-bar,.char-builder--step-derived .cb-panel--attributes-flow .cb-manual-stack,.char-builder--step-derived .cb-panel--attributes-flow .cb-attrs-grid{display:none}.char-builder--step-occupation .cb-module-switch,.char-builder--step-occupation .cb-layout>.cb-stack>.cb-panel--identity,.char-builder--step-occupation .cb-layout>.cb-stack>.cb-panel--pirate-profile,.char-builder--step-occupation .cb-layout>.cb-stack>.cb-panel--attributes-flow,.char-builder--step-occupation .cb-panel--skills,.char-builder--step-occupation .cb-panel--summary-final{display:none}.char-builder--step-occupation .cb-layout{grid-template-columns:1fr}.char-builder--step-skills .cb-module-switch,.char-builder--step-skills .cb-layout,.char-builder--step-skills .cb-panel--summary-final,.char-builder--step-summary .cb-module-switch,.char-builder--step-summary .cb-layout,.char-builder--step-summary .cb-panel--skills{display:none}.char-builder--step-summary .cb-panel--summary-final{display:block}.cb-summary-grid--triple{grid-template-columns:repeat(3,minmax(0,1fr))}.cb-summary-hero-head,.cb-skill-name-head{display:flex;align-items:center;justify-content:space-between;gap:.55rem}.cb-inline-toggle{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .55rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text-dim);cursor:pointer}.cb-inline-toggle--micro{padding:.22rem .36rem}.cb-skill-inline-detail{display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem;padding:.65rem .72rem;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#ffffff09}.cb-skill-inline-detail p{margin:0;color:var(--color-text-dim);line-height:1.5}.cb-skill-detail-meta{display:flex;flex-wrap:wrap;gap:.45rem}.cb-skill-detail-meta span{padding:.24rem .45rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text-dim);font-size:.72rem}.cb-footer-copy{flex:1;min-width:240px}.cb-spin{animation:cb-spin 1s linear infinite}@keyframes cb-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 1120px){.cb-layout,.cb-attrs-grid{grid-template-columns:1fr}.cb-derived-row,.cb-manual-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 820px){.cb-form-grid,.cb-input-modes,.cb-summary-grid,.cb-attrs-grid,.cb-derived-row,.cb-manual-grid,.cb-rule-guide,.cb-derived-guide{grid-template-columns:1fr}.cb-head,.cb-footer{padding:1rem}.cb-panel-head,.cb-footer{flex-direction:column;align-items:stretch}}.cb-budget-grid,.cb-formula-breakdown,.cb-skill-summary-bar,.cb-skill-flags,.cb-scope-filters,.cb-skill-toolbar{display:flex;flex-wrap:wrap;gap:.65rem}.cb-budget-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.cb-budget-card,.cb-audit-note,.cb-formula-pill,.cb-skill-summary-pill{border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.cb-budget-card{display:flex;flex-direction:column;gap:.2rem;padding:.8rem .85rem}.cb-budget-card span,.cb-budget-card small,.cb-audit-note p{color:var(--color-text-dim)}.cb-budget-card strong{color:var(--color-text-bright);font-family:var(--font-title);font-size:1.05rem}.cb-formula-breakdown{align-items:stretch}.cb-formula-pill{display:flex;justify-content:space-between;gap:.75rem;padding:.55rem .75rem;min-width:150px}.cb-formula-pill span{color:var(--color-text-dim);font-size:.76rem}.cb-formula-pill strong{color:var(--color-gold-bright);font-family:var(--font-title)}.cb-audit-note{padding:.82rem .9rem}.cb-audit-note p{margin:.35rem 0 0;line-height:1.55}.cb-panel--skills{overflow:hidden}.cb-search--skills{flex:1 1 280px}.cb-skill-toolbar{justify-content:space-between;align-items:center;margin-bottom:.85rem}.cb-scope-btn{padding:.72rem .86rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text-dim);cursor:pointer;transition:border-color .16s ease,color .16s ease,background .16s ease}.cb-scope-btn.active{border-color:#d4af3747;background:#d4af3717;color:var(--color-text-bright)}.cb-skill-summary-bar{margin-bottom:.85rem}.cb-skill-summary-pill{padding:.58rem .72rem;color:var(--color-text-dim);line-height:1.45}.cb-skill-summary-pill.is-warning{border-color:#ef44443d;background:#ef444414;color:#ffb7b7}.cb-credit-required-card{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:space-between;margin-bottom:.85rem;padding:.82rem .9rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff09}.cb-credit-required-card.is-warning{border-color:#ef444447;background:#ef444414}.cb-credit-required-card.is-complete{border-color:#10b9813d;background:#10b98112}.cb-credit-required-card div{display:grid;gap:.25rem;min-width:220px}.cb-credit-required-card strong{color:var(--color-text-bright);font-family:var(--font-title);font-size:.78rem}.cb-credit-required-card span{color:var(--color-text);font-size:.72rem;line-height:1.45}.cb-skill-explainer{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;margin:0 0 .85rem}.cb-skill-explainer-card{display:grid;gap:.28rem;min-width:0;padding:.78rem .85rem;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:#ffffff08}.cb-skill-explainer-card--wide{grid-column:1 / -1;border-color:#0d948838;background:#0d948812}.cb-skill-explainer-card strong{color:var(--color-text-bright);font-family:var(--font-title);font-size:.72rem;letter-spacing:.04em;text-transform:uppercase}.cb-skill-explainer-card span{color:var(--color-text-dim);font-size:.7rem;line-height:1.48}.cb-skill-budget-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem;margin:0 0 .85rem}.cb-skill-budget-card{display:grid;gap:.18rem;min-width:0;padding:.78rem .85rem;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:#ffffff09}.cb-skill-budget-card span{color:var(--color-text-dim);font-family:var(--font-title);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.cb-skill-budget-card strong{color:var(--color-text-bright);font-family:var(--font-title);font-size:1.45rem;line-height:1}.cb-skill-budget-card small{color:var(--color-text-dim);line-height:1.4}.cb-skill-budget-card.is-open{border-color:#d4af373d;background:#d4af370f}.cb-skill-budget-card.is-open strong{color:var(--color-gold-bright)}.cb-skill-budget-card.is-complete{border-color:#10b98138;background:#10b98112}.cb-skill-budget-card.is-complete strong{color:#8af2c1}.cb-skill-table-wrap{overflow:auto;border-radius:20px;border:1px solid rgba(255,255,255,.08);background:#030b107a}.cb-skill-table{width:100%;border-collapse:collapse;min-width:820px}.cb-skill-table thead th{position:sticky;top:0;z-index:1;padding:.82rem .9rem;text-align:left;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-dim);background:#091419f0;border-bottom:1px solid rgba(255,255,255,.08)}.cb-skill-table tbody td{padding:.78rem .9rem;border-bottom:1px solid rgba(255,255,255,.06);vertical-align:middle;color:var(--color-text)}.cb-skill-row.is-eligible{background:linear-gradient(90deg,rgba(16,185,129,.05),transparent 60%)}.cb-skill-row.is-featured{background:linear-gradient(90deg,rgba(212,175,55,.08),transparent 68%)}.cb-skill-row.is-allocated{box-shadow:inset 3px 0 #d4af3780}.cb-skill-row.is-human-limit-warning{background:linear-gradient(90deg,rgba(245,158,11,.08),transparent 66%)}.cb-skill-row.is-human-limit-blocked{background:linear-gradient(90deg,rgba(239,68,68,.12),transparent 70%);box-shadow:inset 3px 0 #ef4444b8}.cb-skill-name-cell{display:flex;flex-direction:column;gap:.35rem}.cb-skill-name-cell strong{color:var(--color-text-bright)}.cb-skill-flags{gap:.4rem}.cb-flag{display:inline-flex;align-items:center;padding:.18rem .42rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);font-size:.66rem;letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-dim)}.cb-flag--occupation{border-color:#10b9813d;color:#82f3c8}.cb-flag--featured{border-color:#d4af373d;color:var(--color-gold-bright)}.cb-flag--pirate{border-color:#3b82f638;color:#98c6ff}.cb-flag--bonus{border-color:#f472b633;color:#f8b7cf}.cb-flag--warning{border-color:#ef44443d;color:#ffb7b7}.cb-flag--blocked{border-color:#ef444457;background:#ef44441f;color:#ffc0c0}.cb-flag--guardian{border-color:#d4af3757;background:#d4af371a;color:var(--color-gold-bright)}.cb-flag--tier-basic,.cb-flag--tier-competent{border-color:#10b9812e;color:#9ee7c1}.cb-flag--tier-professional{border-color:#d4af3738;color:var(--color-gold-bright)}.cb-flag--tier-specialist{border-color:#f59e0b47;color:#ffc56d}.cb-flag--tier-exceptional,.cb-flag--tier-inhuman{border-color:#ef444457;color:#ffb7b7}.cb-skill-input{width:92px;min-width:0;padding:.55rem .62rem;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:var(--color-text-bright)}.cb-skill-input:disabled{opacity:.45;cursor:not-allowed}.cb-skill-empty{color:var(--color-text-dim);text-align:center}.cb-keeper-hooks{display:grid;gap:.55rem}.cb-keeper-hooks p{margin:0;padding:.68rem .78rem;border-left:3px solid rgba(212,175,55,.42);border-radius:12px;background:#d4af370f;color:var(--color-text);line-height:1.48}@media (max-width: 1120px){.cb-budget-grid,.cb-pirate-grid,.cb-module-switch{grid-template-columns:1fr}}@media (max-width: 820px){.cb-progress-main{grid-template-columns:1fr}.cb-progress-meter span{justify-self:start}.cb-stepper,.cb-form-grid,.cb-attrs-grid,.cb-derived-row,.cb-summary-grid,.cb-summary-grid--triple,.cb-skill-explainer,.cb-skill-budget-strip,.cb-manual-grid,.cb-rule-guide,.cb-derived-guide,.cb-check-item{grid-template-columns:1fr}.cb-skill-toolbar,.cb-scope-filters{flex-direction:column;align-items:stretch}.cb-pirate-summary{grid-template-columns:1fr}}.campaign-lobby-root{min-height:100vh;background:var(--color-void);color:var(--color-text);position:relative}.campaign-lobby-builder-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:12;display:grid;place-items:center;padding:1.4rem;background:#02080ab8;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.campaign-lobby-builder-modal{width:min(1180px,100%);max-height:calc(100vh - 2.8rem);overflow:auto;padding:1rem;border-radius:28px}.campaign-lobby-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(circle at 18% 18%,rgba(16,185,129,.1),transparent 30%),radial-gradient(circle at 82% 12%,rgba(212,175,55,.12),transparent 26%),linear-gradient(180deg,#06150f,#04100b 48%,#020705)}.campaign-lobby-header,.campaign-lobby-main{position:relative;z-index:1}.campaign-lobby-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 2rem}.campaign-lobby-back,.campaign-lobby-user{display:inline-flex;align-items:center;gap:.6rem;padding:.55rem .85rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text-bright)}.campaign-lobby-back{cursor:pointer}.campaign-lobby-main{max-width:1320px;margin:0 auto;padding:1rem 2rem 3rem}.campaign-lobby-state{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;color:var(--color-text-dim)}.campaign-lobby-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr) 320px;gap:1rem;align-items:start}.campaign-lobby-hero,.campaign-lobby-sheet-panel,.campaign-lobby-sidebar{padding:1.4rem;border-radius:24px}.campaign-lobby-kicker{display:inline-flex;align-items:center;gap:.35rem;margin-bottom:.5rem;color:var(--color-gold);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;font-family:var(--font-title)}.campaign-lobby-hero h1,.campaign-lobby-section-head h2{margin:0;color:var(--color-text-bright);font-family:var(--font-title)}.campaign-lobby-hero h1{font-size:clamp(2rem,3vw,3rem)}.campaign-lobby-hero p{margin:.85rem 0 0;max-width:56ch;color:var(--color-text);line-height:1.65}.campaign-lobby-hero-meta,.campaign-lobby-selected-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.7rem;margin-top:1.2rem}.campaign-lobby-hero-meta div,.campaign-lobby-selected-grid div{display:flex;flex-direction:column;gap:.2rem;padding:.8rem .9rem;border-radius:16px;border:1px solid rgba(255,255,255,.06);background:#ffffff06}.campaign-lobby-hero-meta span,.campaign-lobby-selected-grid span,.campaign-lobby-character-meta span{color:var(--color-text-dim);font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-title)}.campaign-lobby-hero-meta strong,.campaign-lobby-selected-grid strong,.campaign-lobby-character-meta strong{color:var(--color-text-bright);font-size:.95rem}.campaign-lobby-hero-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.15rem}.campaign-lobby-warning,.campaign-lobby-selected-note{margin-top:.95rem;padding:.85rem .95rem;border-radius:16px;border:1px solid rgba(212,175,55,.18);background:#d4af3714;color:var(--color-gold-bright);line-height:1.5}.campaign-lobby-section-head{display:flex;align-items:center;justify-content:space-between;gap:.85rem;margin-bottom:1rem}.campaign-lobby-character-list{display:grid;gap:.8rem}.campaign-lobby-character-card{display:flex;flex-direction:column;gap:.9rem;padding:1rem 1.05rem;border-radius:18px;border:1px solid rgba(255,255,255,.07);background:#ffffff06;color:var(--color-text-bright);text-align:left;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease}.campaign-lobby-character-main{display:flex;flex-direction:column;gap:.9rem;padding:0;border:0;background:transparent;color:inherit;text-align:left;cursor:pointer}.campaign-lobby-character-card:hover{transform:translateY(-1px);border-color:#10b9813d}.campaign-lobby-character-card.is-active{border-color:#10b98157;background:linear-gradient(180deg,#071d18f2,#051210f2);box-shadow:inset 0 0 0 1px #10b98124}.campaign-lobby-character-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.campaign-lobby-character-head strong,.campaign-lobby-selected-head strong{display:block;margin-bottom:.2rem;font-size:1rem}.campaign-lobby-character-head span,.campaign-lobby-selected-head span{color:var(--color-text-dim);font-size:.8rem}.campaign-lobby-character-head em{display:inline-flex;width:fit-content;margin-top:.45rem;padding:.2rem .48rem;border-radius:999px;border:1px solid rgba(212,175,55,.2);background:#d4af3714;color:var(--color-gold-bright);font-size:.68rem;font-style:normal}.campaign-lobby-character-meta{display:grid;grid-template-columns:minmax(0,1.6fr) repeat(2,minmax(0,.7fr));gap:.65rem}.campaign-lobby-character-meta div{display:flex;flex-direction:column;gap:.2rem;min-width:0}.campaign-lobby-character-actions,.campaign-lobby-selected-actions,.campaign-lobby-code-actions{display:flex;flex-wrap:wrap;gap:.6rem}.campaign-lobby-empty,.campaign-lobby-sidebar-empty{display:flex;align-items:center;gap:.85rem;padding:1rem;border-radius:18px;border:1px dashed rgba(255,255,255,.12);color:var(--color-text-dim)}.campaign-lobby-empty strong{display:block;margin-bottom:.2rem;color:var(--color-text-bright)}.campaign-lobby-selected{display:flex;flex-direction:column;gap:1rem}.campaign-lobby-sidebar{min-height:100%}.campaign-lobby-invite-box{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.08)}.campaign-lobby-join-code{display:flex;flex-direction:column;gap:.4rem;padding:.95rem 1rem;border-radius:18px;border:1px solid rgba(212,175,55,.18);background:#d4af3712}.campaign-lobby-join-code span,.campaign-lobby-invite-form label{color:var(--color-text-dim);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-title)}.campaign-lobby-join-code strong{color:var(--color-gold-bright);font-family:var(--font-title);font-size:1.35rem;letter-spacing:.16em}.campaign-lobby-access-overview{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;margin-top:.9rem}.campaign-lobby-access-overview div,.campaign-lobby-member-card,.campaign-lobby-log-item{padding:.85rem .95rem;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.campaign-lobby-access-overview span,.campaign-lobby-subhead span,.campaign-lobby-member-card span,.campaign-lobby-log-item span{color:var(--color-text-dim);font-size:.72rem;letter-spacing:.06em}.campaign-lobby-access-overview strong{display:block;margin-top:.2rem;color:var(--color-text-bright);font-size:1.05rem}.campaign-lobby-invite-form{display:flex;flex-direction:column;gap:.55rem;margin-top:.9rem}.campaign-lobby-invite-input{display:flex;gap:.6rem}.campaign-lobby-invite-input input{width:100%;min-width:0;padding:.78rem .9rem;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--color-text-bright)}.campaign-lobby-invite-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.9rem}.campaign-lobby-invite-section,.campaign-lobby-member-section,.campaign-lobby-log-section{display:grid;gap:.7rem;margin-top:1rem}.campaign-lobby-subhead{display:flex;align-items:center;justify-content:space-between}.campaign-lobby-invite-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.campaign-lobby-invite-chip{padding:.4rem .7rem;border-radius:999px;border:1px solid rgba(16,185,129,.2);background:#10b98114;color:var(--color-text-bright);font-size:.78rem}.campaign-lobby-invite-empty{color:var(--color-text-dim);font-size:.84rem}.campaign-lobby-member-list,.campaign-lobby-log-list{display:grid;gap:.6rem}.campaign-lobby-member-head{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:.3rem}.campaign-lobby-member-card strong,.campaign-lobby-log-item strong{color:var(--color-text-bright)}.campaign-lobby-member-card em{display:block;margin-top:.35rem;color:var(--color-gold);font-size:.76rem;font-style:normal}.campaign-lobby-log-item{display:flex;flex-direction:column;gap:.25rem}@media (max-width: 1180px){.campaign-lobby-grid{grid-template-columns:1fr}.campaign-lobby-sidebar{order:3}}@media (max-width: 820px){.campaign-lobby-header,.campaign-lobby-main{padding-left:1rem;padding-right:1rem}.campaign-lobby-header,.campaign-lobby-section-head,.campaign-lobby-hero-actions,.campaign-lobby-character-actions,.campaign-lobby-selected-actions,.campaign-lobby-code-actions,.campaign-lobby-invite-input,.campaign-lobby-invite-row{flex-direction:column;align-items:stretch}.campaign-lobby-hero-meta,.campaign-lobby-selected-grid,.campaign-lobby-character-meta,.campaign-lobby-access-overview{grid-template-columns:1fr}}.character-library-root{min-height:100vh;position:relative;overflow-x:hidden;background:var(--color-void);color:var(--color-text)}.character-library-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(circle at 18% 12%,rgba(0,224,122,.1),transparent 34%),radial-gradient(circle at 78% 22%,rgba(201,164,74,.1),transparent 30%),linear-gradient(180deg,#061812,#03110d 48%,#020806)}.character-library-header{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 2rem;background:#030a08e0;border-bottom:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.character-library-back,.character-library-user{display:inline-flex;align-items:center;gap:.65rem}.character-library-back{border:0;background:transparent;color:var(--color-text);cursor:pointer;font:inherit}.character-library-user strong{color:var(--color-text-bright)}.character-library-main{position:relative;z-index:1;width:min(1200px,calc(100% - 2rem));margin:0 auto;padding:2rem 0 5rem;display:grid;gap:1.25rem}.character-library-hero{padding:1.5rem;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:1.25rem}.character-library-kicker{display:inline-block;color:var(--color-gold-bright);font-family:var(--font-title);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase}.character-library-hero h1,.character-library-card h2,.character-library-empty h2{margin:.35rem 0 0;color:var(--color-text-bright);font-family:var(--font-title)}.character-library-hero p,.character-library-card p,.character-library-empty p{margin:.6rem 0 0;color:var(--color-text-dim);line-height:1.6}.character-library-hero-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}.character-library-stat{min-width:6.5rem;padding:.72rem .9rem;border-radius:14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.character-library-stat span,.character-library-card-meta span{display:block;color:var(--color-text-dim);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.character-library-stat strong,.character-library-card-meta strong{color:var(--color-text-bright)}.character-library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.character-library-card{padding:1.15rem;display:grid;gap:1rem}.character-library-card-head{display:flex;justify-content:space-between;gap:1rem}.character-library-card-head svg{color:var(--color-gold-bright);flex:0 0 auto}.character-library-card-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem}.character-library-card-meta div{min-width:0;padding:.75rem;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.character-library-card-actions{display:flex;justify-content:flex-end}.character-library-state,.character-library-empty{min-height:18rem;padding:2rem;display:grid;place-items:center;text-align:center;gap:.85rem}.character-library-empty svg{color:var(--color-gold-bright)}.character-library-builder-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;padding:1.5rem;display:grid;place-items:center;background:#000000b8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.character-library-builder-modal{width:min(1120px,100%);max-height:min(92vh,980px);overflow:auto;padding:1rem}@media (max-width: 760px){.character-library-header{padding:.85rem 1rem}.character-library-main{padding-top:1rem}.character-library-hero{grid-template-columns:1fr}.character-library-hero-actions{justify-content:stretch}.character-library-hero-actions .btn,.character-library-stat{flex:1}.character-library-card-meta{grid-template-columns:1fr}}.lobby-root{min-height:100vh;background:var(--color-void);color:var(--color-text);position:relative;overflow-x:hidden}.lobby-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(circle at 20% 10%,rgba(0,224,122,.1),transparent 32%),radial-gradient(circle at 80% 20%,rgba(201,164,74,.12),transparent 28%),linear-gradient(180deg,#061812,#04110d 45%,#020906)}.lobby-bg:before,.lobby-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);background-size:120px 120px;opacity:.16}.lobby-bg:after{background-size:180px 180px;opacity:.08}.lobby-video-bg{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:brightness(.6) contrast(1.1) saturate(.8)}.lobby-bg-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#03050766,#030507e6),radial-gradient(circle at 50% 50%,transparent 20%,rgba(0,0,0,.6) 100%);z-index:1;pointer-events:none}.lobby-header{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 3rem;background:linear-gradient(180deg,rgba(3,5,7,.8) 0%,transparent 100%);z-index:100}.lobby-brand{display:flex;align-items:center;gap:1rem;transition:transform var(--transition-fast)}.lobby-brand:hover{transform:scale(1.02)}.lobby-eye{font-size:1.8rem;filter:drop-shadow(0 0 10px var(--color-gold-glow));animation:anchor-float 4s ease-in-out infinite}@keyframes anchor-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.lobby-brand-name{font-family:var(--font-title);font-size:1.8rem;font-weight:700;letter-spacing:.15em;color:var(--color-gold-bright);text-shadow:var(--glow-gold);text-transform:uppercase}.lobby-user-info{display:flex;align-items:center;gap:1.5rem}.lobby-user-info .badge{font-size:.68rem;line-height:1}.lobby-username{font-size:1rem;font-weight:500;color:var(--color-text-bright);letter-spacing:.05em}.lobby-main{position:relative;z-index:10;max-width:1300px;margin:0 auto;padding:8rem 2rem 5rem;min-height:100vh;display:flex;flex-direction:column}.lobby-title-row{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3.5rem;gap:1rem}.lobby-title-row h1{font-family:var(--font-title);font-size:3rem;color:var(--color-text-bright);text-shadow:0 4px 16px rgba(0,0,0,.9);margin:0;position:relative;display:inline-block}.lobby-title-row h1:after{content:"";position:absolute;bottom:-10px;left:0;width:60%;height:2px;background:linear-gradient(90deg,var(--color-teal-bright),transparent);box-shadow:var(--glow-teal)}.lobby-title-actions{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.lobby-join-panel{margin-bottom:2rem;padding:1.5rem;display:grid;gap:1.15rem}.lobby-join-head h3,.lobby-invitations-head h4{margin:0;color:var(--color-text-bright)}.lobby-join-head p{margin:.45rem 0 0;max-width:64ch;color:var(--color-text-dim);line-height:1.6}.lobby-join-code-form{display:grid;gap:.6rem}.lobby-join-code-form label{color:var(--color-text-dim);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title)}.lobby-join-code-row{display:flex;gap:.75rem;align-items:center}.lobby-join-code-row input{flex:1;min-width:0;padding:.92rem 1rem;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:var(--color-text-bright);text-transform:uppercase;letter-spacing:.12em;font-family:var(--font-title)}.lobby-join-code-row input:focus{outline:none;border-color:#10b9815c;box-shadow:0 0 0 3px #10b9811f}.lobby-join-error{margin:0;color:#f8a9a9;font-size:.92rem}.lobby-invitations-block{display:grid;gap:.8rem;padding-top:.4rem;border-top:1px solid rgba(255,255,255,.08)}.lobby-invitations-head{display:flex;align-items:center;justify-content:space-between;gap:1rem}.lobby-invitations-head span{min-width:1.8rem;height:1.8rem;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#d4af3724;border:1px solid rgba(212,175,55,.22);color:var(--color-gold-bright);font-family:var(--font-title);font-size:.78rem}.lobby-invitations-empty{padding:1rem 1.1rem;border-radius:16px;border:1px dashed rgba(255,255,255,.12);color:var(--color-text-dim);line-height:1.5}.lobby-invitations-list{display:grid;gap:.75rem}.lobby-invitation-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.1rem;border-radius:18px;border:1px solid rgba(16,185,129,.14);background:#ffffff08}.lobby-invitation-card strong{display:block;margin-bottom:.2rem;color:var(--color-text-bright)}.lobby-invitation-card span{display:block;color:var(--color-text-dim);line-height:1.5}.lobby-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:2.5rem}.campaign-card{position:relative;display:flex;flex-direction:column;padding:2rem;min-height:240px;transition:all var(--transition-base);cursor:default;border-radius:var(--radius-lg)}.campaign-card:hover{border-color:var(--color-teal-bright);transform:translateY(-6px) scale(1.01);box-shadow:var(--shadow-spatial),0 0 30px var(--color-teal-dim)}.campaign-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.campaign-name{font-size:1.6rem;color:var(--color-text-bright);line-height:1.2}.campaign-card:hover .campaign-name{color:var(--color-teal-bright);text-shadow:0 0 12px var(--color-teal-dim)}.campaign-desc{font-size:1.1rem;color:var(--color-text);line-height:1.6;flex-grow:1}.campaign-illusion-badge{border-radius:999px;border:1px solid rgba(201,164,74,.4);background:#c9a44a1f;color:var(--color-gold-bright);font-family:var(--font-mono);font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;padding:.26rem .52rem;white-space:nowrap}.campaign-footer{display:flex;align-items:center;justify-content:space-between;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.lobby-create-form{margin-bottom:4rem;max-width:600px;padding:2.5rem;border-radius:var(--radius-lg);animation:form-slide-down var(--transition-base) forwards}@keyframes form-slide-down{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.lobby-create-form h3{margin-bottom:2rem;color:var(--color-gold-bright);font-size:1.4rem}.lobby-create-btns{display:flex;gap:1rem;margin-top:2rem}.lobby-loading,.lobby-empty{flex-grow:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--color-text-dim);font-size:1.25rem;gap:1.5rem}.lobby-empty p{max-width:46ch;text-align:center}.lobby-create-form .btn{justify-content:center}@media (max-width: 768px){.lobby-header{position:sticky;top:0;padding:.9rem 1rem;background:linear-gradient(180deg,#030507f2,#030507cc);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lobby-brand-name{font-size:1.15rem;letter-spacing:.08em}.lobby-main{padding:1.25rem 1rem 5.5rem}.lobby-title-row{flex-direction:column;align-items:flex-start;gap:1.5rem}.lobby-title-actions,.lobby-join-code-row,.lobby-invitation-card{width:100%;flex-direction:column;align-items:stretch}.lobby-title-row h1{font-size:1.75rem}.lobby-grid{grid-template-columns:1fr;gap:1rem}.campaign-card{min-height:0;padding:1.2rem}.campaign-name{font-size:1.2rem}.campaign-desc{font-size:.95rem}.campaign-footer{flex-direction:column;align-items:stretch;gap:.7rem}.lobby-user-info{gap:.6rem}.lobby-user-info .btn{padding:.34rem .62rem;font-size:.56rem}.lobby-username{display:none}.lobby-create-form{margin-bottom:2rem;padding:1.2rem}.lobby-create-btns{flex-direction:column}}.vtt-surface-state{width:100%;height:100%;min-height:220px;display:flex;align-items:center;justify-content:center;padding:1rem}.vtt-surface-card{width:min(100%,460px);display:flex;flex-direction:column;align-items:center;gap:.85rem;padding:1.4rem 1.2rem;text-align:center;border-color:#00ff881f}.vtt-surface-crest{width:52px;height:52px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(201,164,74,.25);background:radial-gradient(circle at top,rgba(201,164,74,.14),transparent 62%),#051510d9;color:var(--color-gold-bright);box-shadow:0 0 0 1px #c9a44a14,0 12px 24px #0000004d}.vtt-surface-icon{width:22px;height:22px}.vtt-surface-title{margin:0;font-size:1rem;letter-spacing:.08em;text-transform:uppercase}.vtt-surface-message{margin:0;max-width:34ch;color:var(--color-text-dim);font-size:.92rem;line-height:1.55}.vtt-surface-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.65rem}.vtt-surface-actions .btn{min-width:148px;justify-content:center}.vtt-surface-loading .vtt-surface-crest{border-color:#00ff882e;color:var(--glow2)}.vtt-surface-error .vtt-surface-crest{border-color:#e74c3c47;color:#ff907d;background:radial-gradient(circle at top,rgba(231,76,60,.14),transparent 62%),#1c0c0beb}.vtt-surface-empty .vtt-surface-crest{border-color:#c9a44a33}.vtt-surface-spinner{width:1.2rem;height:1.2rem}@media (max-width: 780px){.vtt-surface-state{min-height:180px;padding:.75rem}.vtt-surface-card{width:100%;padding:1.1rem .95rem}.vtt-surface-actions{width:100%;flex-direction:column}.vtt-surface-actions .btn{width:100%;min-width:0}}.board-root{position:relative;width:100%;height:100%;background:var(--color-void);overflow:hidden}.board-root-stateful{background:radial-gradient(circle at top,rgba(0,255,136,.05),transparent 58%),var(--color-void)}.board-canvas{display:block;width:100%;height:100%}.board-hidden-input{display:none}.board-surface-state{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2}.board-surface-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.board-gm-controls{position:absolute;bottom:12px;left:12px;z-index:20;display:flex;align-items:center;gap:.6rem;background:#0a0a0fd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.4rem .7rem}.board-upload-btn{font-size:.82rem;padding:.3rem .7rem;cursor:pointer}.board-upload-btn.is-active{border-color:var(--color-cyan);color:var(--color-cyan);box-shadow:0 0 0 1px #06b6d433}.board-token-form{position:absolute;left:12px;bottom:64px;z-index:20;width:min(320px,calc(100% - 24px));display:grid;gap:.75rem;padding:.85rem;border:1px solid rgba(6,182,212,.28);border-radius:var(--radius-lg);background:#0a0a0feb;box-shadow:0 18px 45px #00000059;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.board-token-form label{display:grid;gap:.35rem;color:var(--color-text-muted);font-size:.76rem}.board-token-form input{width:100%;min-height:38px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#ffffff0f;color:var(--color-text-bright);padding:.45rem .6rem;font:inherit}.board-token-form input:focus{outline:2px solid rgba(6,182,212,.35);border-color:var(--color-cyan)}.board-token-actions{display:flex;justify-content:flex-end;gap:.5rem}.board-notice{position:absolute;top:12px;left:50%;z-index:30;width:min(520px,calc(100% - 24px));transform:translate(-50%);border:1px solid rgba(239,68,68,.35);border-radius:var(--radius-md);background:#280c10eb;color:var(--color-text-bright);padding:.65rem .8rem;font-size:.82rem;box-shadow:0 14px 32px #00000047}.illusion-slider-wrapper{display:flex;align-items:center;gap:.4rem}.illusion-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100px;height:4px;border-radius:2px;background:linear-gradient(90deg,var(--color-fumble),var(--color-border) 100%);outline:none;cursor:pointer}.illusion-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--color-fumble);box-shadow:0 0 8px #a855f799}.token-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:10}.token-chip{position:absolute;display:flex;flex-direction:column;align-items:center;pointer-events:all;cursor:grab;transform:translate(-50%,-50%);z-index:10;touch-action:none}.token-chip:active{cursor:grabbing}.token-chip.is-hidden-token{opacity:.5;filter:grayscale(.85)}.token-img{width:44px;height:44px;border-radius:50%;border:2px solid var(--color-cyan);box-shadow:var(--shadow-cyan);object-fit:cover}.token-placeholder{display:grid;place-items:center;width:46px;height:46px;border:2px solid var(--color-cyan);border-radius:50%;background:#06b6d424;color:var(--color-text-bright);font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.04em;box-shadow:var(--shadow-cyan)}.token-label{font-family:var(--font-mono);font-size:.62rem;color:var(--color-text-bright);background:#0a0a0fcc;padding:.05rem .3rem;border-radius:2px;margin-top:2px;white-space:nowrap}.token-actions{position:absolute;top:calc(100% + 8px);left:50%;display:flex;gap:.35rem;opacity:0;pointer-events:none;transform:translate(-50%,-4px);transition:opacity .12s ease,transform .12s ease}.token-chip:hover .token-actions,.token-chip:focus-within .token-actions{opacity:1;pointer-events:auto;transform:translate(-50%)}.token-action-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#0a0a0fe6;color:var(--color-text-bright);cursor:pointer;font-size:.66rem;padding:.22rem .42rem;white-space:nowrap}.token-action-btn:hover{border-color:var(--color-cyan);color:var(--color-cyan)}.token-action-btn.danger:hover{border-color:var(--color-fail);color:var(--color-fail)}@media (max-width: 700px){.board-gm-controls{right:10px;bottom:10px;left:10px;justify-content:space-between;gap:.45rem;padding:.4rem}.board-upload-btn{padding-inline:.55rem}.board-token-form{right:10px;bottom:62px;left:10px;width:auto}.illusion-slider{width:72px}.token-actions{opacity:1;pointer-events:auto;transform:translate(-50%)}}.chat-root{display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.4rem}.chat-msg{padding:.35rem .7rem;border-radius:var(--radius-md);background:var(--color-raised);border:1px solid var(--color-border);font-size:.9rem;line-height:1.4;word-break:break-word;display:flex;flex-direction:column;gap:.15rem}.chat-msg-mine{align-self:flex-end;background:var(--color-cyan-dim);border-color:#06b6d44d;max-width:85%}.chat-msg-whisper{background:var(--color-purple-dim);border-color:#7c3aed4d;font-style:italic}.chat-msg-roll{background:linear-gradient(135deg,var(--color-raised),var(--color-surface));border-color:var(--color-border-bright)}.chat-msg-fumble{background:linear-gradient(135deg,rgba(168,85,247,.12),var(--color-surface));border-color:var(--color-fumble);box-shadow:var(--glow-fumble)}.chat-author{font-family:var(--font-mono);font-size:.75rem;color:var(--color-cyan);display:flex;align-items:center;gap:.3rem}.chat-text,.chat-roll-info{color:var(--color-text)}.chat-roll-num{font-family:var(--font-mono);font-size:1rem}.chat-san-loss{font-size:.85rem;color:var(--color-fumble);font-style:italic}.chat-dice-row{display:flex;gap:.4rem;padding:.5rem .75rem .25rem;border-top:1px solid var(--color-border);flex-shrink:0}.chat-dice-input{flex:1;font-family:var(--font-mono);font-size:.85rem;padding:.3rem .6rem;background:var(--color-abyss);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text)}.chat-dice-input:focus{border-color:var(--color-amber);box-shadow:0 0 0 2px var(--color-amber-dim);outline:none}.chat-input-row{display:flex;gap:.4rem;padding:.25rem .75rem .75rem;flex-shrink:0}.chat-input{flex:1;padding:.4rem .7rem}.dice-roller{background:#080e12db;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:20px;color:#c9c0a0;font-family:Inter,sans-serif;display:flex;flex-direction:column;gap:16px}.dr-title{margin:0;font-size:16px;font-weight:700;color:#d4af70;font-family:Cinzel,serif;letter-spacing:.04em}.dr-intro{margin:-.35rem 0 0;color:var(--color-text-dim);font-size:.72rem;line-height:1.5}.dr-section-label{margin-bottom:-.5rem;color:var(--color-text-dim);font-size:.65rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.dr-inputs{display:flex;flex-direction:column;gap:10px}.dr-field{display:flex;flex-direction:column;gap:4px}.dr-field label{font-size:11px;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:6px}.dr-pct{font-size:14px;color:#d4af70;font-weight:700;text-transform:none;letter-spacing:0}.dr-field input[type=text],.dr-field input[type=number]{background:#ffffff0f;border:1px solid rgba(139,90,43,.25);border-radius:7px;padding:7px 10px;color:#c9c0a0;font-size:13px;outline:none;transition:border-color .2s}.dr-field input[type=text]:focus{border-color:#c8963280}.dr-field input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:5px;border-radius:3px;background:linear-gradient(90deg,#8b5e0c,#ffffff1a);cursor:pointer}.dr-field input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#d4af70;box-shadow:0 0 8px #d4af7099;cursor:pointer}.dr-thresholds{display:flex;flex-wrap:wrap;gap:.35rem .75rem;justify-content:space-between;font-size:10px;color:var(--color-text-dim);margin-top:2px}.dr-modifiers{display:flex;gap:12px}.dr-mod-group{flex:1;display:flex;flex-direction:column;gap:5px}.dr-mod-label{font-size:10px;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em}.dr-mod-btns{display:flex;gap:5px}.dr-mod-btn{flex:1;padding:5px;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--color-text-dim);font-size:12px;cursor:pointer;transition:all .2s}.dr-mod-help{margin:-.55rem 0 0;color:var(--color-text-dim);font-size:.65rem;line-height:1.45}.dr-mod-btn.active.bonus{background:#32a05026;border-color:#32c85066;color:#50c860}.dr-mod-btn.active.penalty{background:#c83c3c26;border-color:#dc505066;color:#e06060}.dr-roll-btn{padding:14px;border-radius:10px;border:1px solid rgba(212,175,112,.4);background:#8b6010b8;color:#f0d090;font-size:16px;font-weight:700;font-family:Cinzel,serif;letter-spacing:.04em;cursor:pointer;transition:all .2s}.dr-roll-btn:hover:not(:disabled){background:#b08018db;box-shadow:0 0 20px #c8963266;transform:translateY(-1px)}.dr-roll-btn:disabled{opacity:.6;cursor:not-allowed}.dr-die-spin{display:inline-block;animation:spin .6s linear infinite;font-size:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dr-result{text-align:center;padding:20px 16px;border-radius:12px;border:1px solid color-mix(in srgb,var(--result-color) 30%,transparent);background:color-mix(in srgb,var(--result-color) 6%,transparent);box-shadow:0 0 20px color-mix(in srgb,var(--result-glow) 15%,transparent);animation:popIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.dr-result-icon{font-size:28px;margin-bottom:4px}.dr-result-number{font-size:52px;font-weight:900;color:var(--result-color);text-shadow:0 0 20px var(--result-glow);font-family:Cinzel,serif;line-height:1}.dr-result-label{font-size:16px;font-weight:700;color:var(--result-color);margin:6px 0;letter-spacing:.04em}.dr-result-thresholds{display:flex;justify-content:center;gap:14px;font-size:11px;color:#6a6050;margin-top:6px}.dr-bonus-dice{font-size:11px;color:#7a7060;margin-top:6px;font-style:italic}.dr-history{border-top:1px solid rgba(139,90,43,.15);padding-top:10px}.dr-history-title{font-size:10px;color:#5a5040;text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px}.dr-history-item{display:flex;justify-content:space-between;font-size:12px;padding:3px 0;opacity:.7;border-bottom:1px solid rgba(255,255,255,.04)}.cs-root{--cs-hp-screen-shade: 0;--cs-hp-vignette-shade: 0;--cs-hp-pulse-strength: 0;--cs-hp-blur-strength: 0;--cs-hp-tunnel-tightness: 0;display:flex;flex-direction:column;height:100%;min-height:0;position:relative;isolation:isolate;background:radial-gradient(circle at top right,rgba(212,175,55,.08),transparent 26%),linear-gradient(180deg,#060f13fa,#091417f5);color:var(--color-text)}.cs-root:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:40;opacity:calc((var(--cs-hp-screen-shade) * .9) + (var(--cs-hp-vignette-shade) * .95));background:radial-gradient(circle at center,#0000 0,#0000 calc(28% - (var(--cs-hp-tunnel-tightness) * 11%)),rgba(2,4,4,calc(var(--cs-hp-screen-shade) * .4)) calc(52% - (var(--cs-hp-tunnel-tightness) * 9%)),rgba(0,0,0,calc(var(--cs-hp-vignette-shade) * .92)) calc(80% - (var(--cs-hp-tunnel-tightness) * 4%)),rgba(0,0,0,calc(var(--cs-hp-vignette-shade) + .08))),linear-gradient(180deg,rgba(5,8,10,calc(var(--cs-hp-screen-shade) * .55)),rgba(0,0,0,calc(var(--cs-hp-screen-shade) + .08)));-webkit-backdrop-filter:blur(calc(var(--cs-hp-blur-strength) * 6px)) brightness(calc(1 - (var(--cs-hp-screen-shade) * .48))) saturate(calc(1 - (var(--cs-hp-screen-shade) * .52)));backdrop-filter:blur(calc(var(--cs-hp-blur-strength) * 6px)) brightness(calc(1 - (var(--cs-hp-screen-shade) * .48))) saturate(calc(1 - (var(--cs-hp-screen-shade) * .52)));transition:opacity .26s ease,background .26s ease,backdrop-filter .26s ease}.cs-root--hp-threat:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:39;opacity:var(--cs-hp-pulse-strength);background:radial-gradient(circle at center,#78121200 18%,#7812120d 54%,#1400004d);mix-blend-mode:multiply;transition:opacity .26s ease,background .26s ease}.cs-root--session .cs-header{grid-template-columns:1fr}.cs-root--session .cs-header-rail,.cs-root--session .cs-meta-row{display:none}.cs-state{display:grid;place-items:center;gap:.8rem;height:100%;padding:2rem;text-align:center;color:var(--color-text-dim)}.cs-empty-icon{opacity:.18}.cs-header{display:grid;grid-template-columns:minmax(0,1fr);gap:1rem;padding:.9rem 1.4rem;border-bottom:1px solid rgba(255,255,255,.06);background:radial-gradient(circle at top left,rgba(212,175,55,.14),transparent 30%),linear-gradient(180deg,#040a0dfa,#040a0dc7)}.cs-header-main{display:flex;align-items:center;gap:1rem}.cs-avatar{width:56px;height:56px;border-radius:8px;overflow:hidden;display:grid;place-items:center;flex-shrink:0;color:var(--color-text-dim);border:1px solid rgba(212,175,55,.28);background:linear-gradient(160deg,#0d1c22f2,#081114f2);box-shadow:inset 0 0 0 1px #ffffff08}.cs-avatar img{width:100%;height:100%;object-fit:cover}.cs-header-copy{min-width:0;flex:1}.cs-header-kicker{margin-bottom:.45rem;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--color-gold);font-family:var(--font-title)}.cs-header-topline{display:flex;justify-content:space-between;gap:.8rem;margin-bottom:.55rem}.cs-state-pill,.cs-last-update{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title)}.cs-last-update{color:var(--color-text-dim)}.cs-state-pill{padding:.3rem .65rem;border-radius:999px;border:1px solid rgba(255,255,255,.12)}.cs-state-pill--normal{color:var(--color-success);border-color:#10b98159}.cs-state-pill--warning{color:var(--color-gold-bright);border-color:#d4af3759}.cs-state-pill--danger,.cs-state-pill--critical{color:var(--color-fail);border-color:#ef444459}.cs-name-row,.cs-occupation-row{display:flex;align-items:center;gap:.65rem}.cs-name-row{font-family:var(--font-title);font-size:clamp(1.1rem,2vw,1.6rem);color:var(--color-text-bright)}.cs-occupation-row{margin-top:.25rem;color:var(--color-text-dim)}.cs-occupation-suggestion-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.65rem}.cs-occupation-suggestion-label{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-dim);font-family:var(--font-title)}.cs-occupation-suggestion-list{display:flex;flex-wrap:wrap;gap:.45rem}.cs-occupation-suggestion{padding:.38rem .68rem;border-radius:999px;border:1px solid rgba(212,175,55,.22);background:#d4af3714;color:var(--color-gold-bright);font-size:.78rem;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease}.cs-occupation-suggestion:hover{transform:translateY(-1px);border-color:#d4af3766;background:#d4af3724}.cs-character-switcher{display:flex;flex-direction:column;gap:.55rem;margin-top:.85rem}.cs-character-switcher-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.cs-character-switcher-label,.cs-character-switcher-count{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title)}.cs-character-switcher-label{color:var(--color-text-dim)}.cs-character-switcher-count{color:var(--color-gold-bright)}.cs-character-switcher-list{display:flex;flex-wrap:wrap;gap:.5rem}.cs-character-chip{display:flex;flex-direction:column;align-items:flex-start;gap:.18rem;min-width:150px;max-width:100%;padding:.62rem .82rem;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#ffffff07;color:var(--color-text-bright);text-align:left;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}.cs-character-chip:hover{transform:translateY(-1px);border-color:#22c55e38;background:#ffffff0b}.cs-character-chip strong{font-size:.82rem;font-weight:600;color:inherit}.cs-character-chip span{font-size:.72rem;color:var(--color-text-dim)}.cs-character-chip.is-active{border-color:#10b98159;background:linear-gradient(180deg,#081b18f2,#061113f2);box-shadow:inset 0 0 0 1px #10b98129}.cs-character-chip.is-active strong,.cs-character-chip.is-active span{color:var(--color-text-bright)}.cs-character-chip--add{flex-direction:row;align-items:center;justify-content:center;min-width:0;border-style:dashed;border-color:#d4af373d;color:var(--color-gold-bright);background:#d4af370f}.cs-character-chip--add span{color:inherit;font-size:.78rem}.cs-meta-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}.cs-meta-pill{display:flex;flex-direction:column;gap:.18rem;min-width:124px;padding:.65rem .8rem;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#ffffff06}.cs-meta-pill-label{display:inline-flex;align-items:center;gap:.35rem;color:var(--color-text-dim);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title)}.cs-meta-pill strong{color:var(--color-text-bright);font-size:.95rem;font-weight:600}.cs-header-rail{display:flex;flex-direction:column;gap:.8rem}.cs-header-actions{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:.55rem;margin-top:.75rem}.cs-rail-card{display:flex;flex-direction:column;gap:.45rem;min-height:0;padding:1rem;border-radius:20px;border:1px solid rgba(212,175,55,.14);background:linear-gradient(180deg,#ffffff0d,#ffffff05);box-shadow:inset 0 1px #ffffff0a}.cs-rail-card--compact{justify-content:space-between}.cs-rail-highlight{color:var(--color-text-bright);font-size:1.05rem;font-family:var(--font-title)}.cs-rail-copy{color:var(--color-text-dim);font-size:.84rem;line-height:1.45}.cs-rail-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem}.cs-rail-metrics div{display:flex;flex-direction:column;gap:.2rem;padding:.6rem .65rem;border-radius:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.05)}.cs-rail-metrics span{font-size:.66rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim)}.cs-rail-metrics strong{color:var(--color-gold-bright);font-size:1rem;font-family:var(--font-mono)}.cs-saving-dot{width:9px;height:9px;border-radius:999px;background:var(--color-teal-bright);box-shadow:0 0 12px #22d3ee8c;animation:csPulse 1.2s infinite ease-in-out}@keyframes csPulse{0%,to{opacity:.35;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}.cs-inline-value,.cs-inline-input{min-width:0;width:100%;padding:0;border:none;background:transparent;color:inherit;font:inherit;text-align:left}.cs-inline-value{cursor:text}.cs-inline-value:hover{color:var(--color-text-bright)}.cs-inline-input{padding:.2rem .3rem;border-radius:8px;outline:none;border:1px solid rgba(34,211,238,.32);background:#081218eb}.cs-inline-placeholder{color:var(--color-text-dim);font-style:italic}.cs-meter-row{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.85rem;padding:1rem 1.4rem;border-bottom:1px solid rgba(255,255,255,.05);background:#051014c2;position:sticky;top:0;z-index:9;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.cs-meter-card{display:flex;flex-direction:column;gap:.55rem;padding:.9rem 1rem;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:linear-gradient(180deg,#ffffff0b,#ffffff05);cursor:pointer;transition:transform var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.cs-meter-card.is-active{border-color:color-mix(in srgb,var(--color-gold-bright) 38%,rgba(255,255,255,.08));background:linear-gradient(180deg,#d4af371f,#ffffff08);box-shadow:0 0 0 1px #d4af3729,inset 0 1px #ffffff0a}.cs-meter-card:hover{transform:translateY(-1px);border-color:#ffffff24;background:#ffffff0d}.cs-meter-head{display:flex;justify-content:space-between;gap:.75rem;align-items:center}.cs-meter-label{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title);color:var(--color-text-dim)}.cs-meter-label abbr{padding:.12rem .28rem;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:var(--color-text-dim);font-family:var(--font-mono);font-size:.58rem;text-decoration:none}.cs-meter-hint{color:var(--color-text-dim);font-size:.62rem;line-height:1.35;text-align:left}.cs-meter-value{font-size:.95rem;font-weight:700;font-family:var(--font-mono)}.cs-meter-track{height:7px;border-radius:999px;overflow:hidden;background:#ffffff0f}.cs-meter-fill{height:100%;border-radius:inherit;transition:width .16s ease}.cs-status-mini{display:flex;flex-direction:column;gap:.3rem;min-height:100%;padding:.85rem .95rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#ffffff0b,#ffffff05);color:var(--color-text);cursor:pointer}.cs-status-mini span,.cs-status-mini small{color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.08em}.cs-status-mini span{font-size:.67rem;font-family:var(--font-title)}.cs-status-mini small{font-size:.58rem}.cs-status-mini strong{color:var(--color-text-bright);font-size:1.05rem;font-family:var(--font-mono)}.cs-status-mini--good strong{color:var(--color-success)}.cs-status-mini--warn strong{color:var(--color-gold-bright)}.cs-status-mini--danger strong{color:var(--color-fail)}.cs-quick-adjust{display:grid;grid-template-columns:minmax(180px,260px) minmax(0,1fr);align-items:center;gap:1rem;padding:1rem 1.4rem 1.05rem;border-bottom:1px solid rgba(255,255,255,.05);background:linear-gradient(180deg,#d4af370f,#060f13f0),#060f13f0}.cs-quick-adjust-copy{display:flex;flex-direction:column;gap:.45rem}.cs-quick-adjust-summary{display:inline-flex;align-items:baseline;gap:.7rem;flex-wrap:wrap}.cs-quick-adjust-summary strong{color:var(--color-text-bright);font-family:var(--font-title);font-size:1rem}.cs-quick-adjust-summary span{color:var(--color-gold-bright);font-family:var(--font-mono);font-size:1.1rem}.cs-quick-adjust-actions{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.75rem}.cs-adjust-pill{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;min-height:58px;padding:.7rem .85rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff09;color:var(--color-text);cursor:pointer;transition:transform var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.cs-adjust-pill:hover{transform:translateY(-1px)}.cs-adjust-pill.is-negative{border-color:#ef444429;background:linear-gradient(180deg,#ef444417,#ffffff05)}.cs-adjust-pill.is-positive{border-color:#10b98133;background:linear-gradient(180deg,#10b9811a,#ffffff05)}.cs-adjust-pill.is-edit{border-color:#d4af373d;background:linear-gradient(180deg,#d4af371f,#ffffff08)}.cs-adjust-pill.is-close{gap:.35rem}.cs-adjust-pill-value{font-size:1rem;font-weight:700;font-family:var(--font-mono);color:var(--color-text-bright)}.cs-adjust-pill-label{font-size:.63rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-dim);font-family:var(--font-title)}.cs-tabs-wrap{position:sticky;top:84px;z-index:8;background:linear-gradient(180deg,#060f13fa,#060f13e0)}.cs-tabs{display:flex;gap:.6rem;padding:.9rem 1.4rem;border-bottom:1px solid rgba(255,255,255,.05);overflow-x:auto;scrollbar-width:thin}.cs-tab-context{display:flex;align-items:baseline;gap:.7rem;padding:.7rem 1.4rem;border-bottom:1px solid rgba(255,255,255,.05);background:#050f13b8}.cs-tab-context strong{color:var(--color-text-bright);font-family:var(--font-title);font-size:.75rem;letter-spacing:.04em;white-space:nowrap}.cs-tab-context span{color:var(--color-text-dim);font-size:.72rem;line-height:1.45}.cs-test-guide{display:grid;grid-template-columns:minmax(220px,.75fr) minmax(0,1.5fr);align-items:center;gap:1rem;margin:.9rem 1.4rem 0;padding:.85rem 1rem;border:1px solid rgba(13,148,136,.24);border-radius:8px;background:#0d948812}.cs-test-guide-copy{display:flex;align-items:flex-start;gap:.65rem;color:var(--color-teal-bright)}.cs-test-guide-copy div{display:flex;flex-direction:column;gap:.2rem}.cs-test-guide-copy strong{color:var(--color-text-bright);font-size:.76rem}.cs-test-guide-copy span{color:var(--color-text-dim);font-size:.68rem;line-height:1.4}.cs-test-guide-levels{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem}.cs-test-guide-levels span{display:flex;flex-direction:column;gap:.2rem;min-width:0;padding-left:.65rem;border-left:2px solid rgba(13,148,136,.34);color:var(--color-text-dim);font-size:.64rem;line-height:1.35}.cs-test-guide-levels strong{color:var(--color-text-bright);font-size:.7rem}.cs-tab{display:inline-flex;align-items:center;gap:.5rem;flex:1 0 0;justify-content:center;min-width:132px;padding:.8rem 1rem;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#ffffff0a,#ffffff05);color:var(--color-text-dim);cursor:pointer;transition:all var(--transition-fast)}.cs-tab.active{color:var(--color-gold-bright);border-color:#d4af3752;background:#d4af3714}.cs-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:1rem;min-height:0;flex:0 0 auto;align-items:start;padding:1rem 1.4rem 1.4rem}.cs-sheet-overview{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.75fr);gap:1rem}.cs-sheet-main-column,.cs-sheet-secondary-column{display:flex;flex-direction:column;gap:1rem;min-width:0}.cs-shell--paper{border-color:#d4af3733;background:#d4af3709}.cs-overview-attributes{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.55rem}.cs-overview-attribute{display:flex;flex-direction:column;gap:.55rem;min-width:0;padding:.7rem;border:1px solid color-mix(in srgb,var(--cs-accent) 26%,rgba(255,255,255,.07));border-radius:8px;background:#ffffff06}.cs-overview-attribute-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.cs-overview-attribute-head span{display:flex;flex-direction:column;gap:.12rem;min-width:0}.cs-overview-attribute-head strong{color:var(--color-text-bright);font-family:var(--font-title);font-size:.78rem}.cs-overview-attribute-head small{overflow:hidden;color:var(--color-text-dim);font-size:.62rem;text-overflow:ellipsis;white-space:nowrap}.cs-overview-attribute-head b{color:var(--cs-accent);font-family:var(--font-mono);font-size:1.25rem}.cs-overview-attribute-thresholds{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.3rem}.cs-overview-attribute-thresholds span{display:flex;flex-direction:column;color:var(--color-text-dim);font-size:.56rem;line-height:1.3}.cs-overview-attribute-thresholds strong{color:var(--color-text-bright);font-family:var(--font-mono);font-size:.68rem}.cs-overview-attribute>button{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;min-height:30px;padding:.35rem .45rem;border:1px solid rgba(255,255,255,.08);border-radius:6px;background:#ffffff06;color:var(--color-text-dim);font-size:.62rem;font-weight:600;cursor:pointer}.cs-overview-attribute>button:hover,.cs-overview-attribute>button:focus-visible{border-color:color-mix(in srgb,var(--cs-accent) 38%,rgba(255,255,255,.08));color:var(--color-text-bright);outline:none}.cs-overview-skills{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.cs-overview-skill{display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-width:0;padding:.7rem .8rem;border:1px solid rgba(255,255,255,.07);border-radius:8px;background:#ffffff06;color:var(--color-text);text-align:left;cursor:pointer}.cs-overview-skill:hover,.cs-overview-skill:focus-visible{border-color:#d4af3752;background:#d4af370f;outline:none}.cs-overview-skill span{display:flex;flex-direction:column;gap:.18rem;min-width:0}.cs-overview-skill strong{overflow:hidden;color:var(--color-text-bright);font-size:.72rem;text-overflow:ellipsis;white-space:nowrap}.cs-overview-skill small{color:var(--color-text-dim);font-size:.58rem}.cs-overview-skill b{flex-shrink:0;color:var(--color-gold-bright);font-family:var(--font-mono);font-size:.9rem}.cs-overview-rules .cs-test-guide{margin:0;grid-template-columns:1fr}.cs-overview-rules .cs-test-guide-levels{grid-template-columns:1fr}.cs-occupation-summary{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.4rem 1rem;margin-top:.75rem;padding-top:.7rem;border-top:1px solid rgba(255,255,255,.07);color:var(--color-text-dim);font-size:.66rem}.cs-occupation-summary strong{color:var(--color-text-bright)}@media (max-width: 1120px){.cs-sheet-overview{grid-template-columns:1fr}}.cs-main,.cs-sidebar{min-height:0;align-self:start}.cs-main{min-width:0}.cs-panel{display:flex;flex-direction:column;gap:1rem;min-height:0;overflow:visible}.cs-roll-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:1.5rem;background:#02080aad;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:50}.cs-roll-modal{width:min(560px,100%);max-height:min(90vh,900px);overflow:auto;padding:1rem;border-radius:24px;border:1px solid rgba(212,175,55,.18);background:linear-gradient(180deg,#091216fa,#070e12f5);box-shadow:0 24px 80px #00000073}.cs-roll-modal-head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:.9rem}.cs-shell{display:flex;flex-direction:column;gap:.95rem;padding:1rem;border-radius:22px;border:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,#ffffff09,#ffffff05),#040c0fa8;box-shadow:inset 0 1px #ffffff09}.cs-shell--accent{border-color:#d4af372e;background:radial-gradient(circle at top right,rgba(212,175,55,.08),transparent 28%),linear-gradient(180deg,#ffffff09,#ffffff05),#040c0fa8}.cs-shell--danger{border-color:#ef444429;background:radial-gradient(circle at top left,rgba(239,68,68,.08),transparent 28%),linear-gradient(180deg,#ffffff09,#ffffff05),#040c0fa8}.cs-section-header{display:flex;justify-content:space-between;gap:1rem;align-items:end}.cs-section-title{display:inline-flex;align-items:center;gap:.45rem;margin:0;font-family:var(--font-title);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-gold-bright)}.cs-section-subtitle{margin:.25rem 0 0;color:var(--color-text-dim);font-size:.86rem}.cs-dashboard-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);gap:1rem;align-items:start}.cs-dashboard-stack{display:flex;flex-direction:column;gap:1rem;min-width:0}.cs-info-matrix,.cs-resource-grid,.cs-dossier-grid,.cs-action-grid{display:grid;gap:.75rem}.cs-info-matrix,.cs-resource-grid,.cs-dossier-grid,.cs-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cs-info-card,.cs-resource-card,.cs-dossier-card,.cs-action-card,.cs-derived-pill{border:1px solid rgba(255,255,255,.06);border-radius:18px;background:#ffffff07;box-shadow:inset 0 1px #ffffff08}.cs-info-card,.cs-resource-card,.cs-dossier-card,.cs-action-card{padding:.9rem .95rem}.cs-info-card{display:flex;flex-direction:column;gap:.4rem}.cs-info-card.is-readonly{background:#ffffff05}.cs-info-edit,.cs-info-static{color:var(--color-text-bright);font-size:.98rem;font-family:var(--font-mono)}.cs-info-static{font-weight:600}.cs-resource-card{display:flex;flex-direction:column;gap:.6rem}.cs-resource-head{display:flex;justify-content:space-between;gap:.65rem;align-items:flex-start}.cs-resource-value{display:inline-flex;align-items:center;gap:.5rem;font-size:1.08rem;font-family:var(--font-mono);color:var(--color-text-bright)}.cs-resource-value strong{color:var(--color-text-bright);font-size:1.02rem}.cs-resource-inline{width:68px;min-width:68px;text-align:center}.cs-resource-foot{display:flex;flex-direction:column;gap:.22rem}.cs-resource-foot strong{font-family:var(--font-mono);font-size:.9rem}.cs-resource-foot span{color:var(--color-text-dim);font-size:.72rem;line-height:1.35}.cs-dossier-card,.cs-action-card{display:flex;flex-direction:column;gap:.45rem;border:none;font:inherit;text-align:left;color:var(--color-text);cursor:pointer;transition:transform var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.cs-dossier-card:hover,.cs-action-card:hover{transform:translateY(-1px);border-color:#d4af373d;background:#d4af370f}.cs-dossier-card.is-filled{border-color:#d4af372e}.cs-dossier-card strong,.cs-action-card strong{color:var(--color-text-bright);font-size:.84rem;line-height:1.4}.cs-dossier-card strong{font-weight:500}.cs-action-card span:last-child{color:var(--color-text-dim);font-size:.73rem;line-height:1.4}.cs-derived-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem}.cs-derived-pill{display:flex;flex-direction:column;gap:.28rem;padding:.7rem .8rem}.cs-derived-pill span{color:var(--color-text-dim);font-size:.64rem;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-title)}.cs-derived-pill strong{color:var(--color-text-bright);font-size:1rem;font-family:var(--font-mono)}.cs-field-grid,.cs-history-grid,.cs-weapon-grid,.cs-attribute-grid,.cs-stat-grid,.cs-combat-skill-grid{display:grid;gap:.85rem}.cs-field-grid,.cs-history-grid,.cs-weapon-grid,.cs-combat-skill-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cs-attribute-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.cs-attribute-grid--dense{gap:.72rem}.cs-stat-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.cs-field-card,.cs-textarea-card,.cs-stat-card,.cs-attribute-card,.cs-skill-group,.cs-weapon-card,.cs-sidebar-card,.cs-empty-card{border:1px solid rgba(255,255,255,.06);border-radius:18px;background:#ffffff08;box-shadow:inset 0 1px #ffffff08}.cs-field-card,.cs-textarea-card,.cs-stat-card,.cs-weapon-card,.cs-sidebar-card,.cs-empty-card{padding:1rem}.cs-card-eyebrow{display:inline-flex;align-items:center;gap:.35rem;margin-bottom:.55rem;font-size:.68rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-title)}.cs-split-edit{display:inline-flex;align-items:center;gap:.5rem;font-size:1rem;font-family:var(--font-mono)}.cs-stat-card{display:flex;flex-direction:column;gap:.5rem}.cs-stat-card span{color:var(--color-text-dim);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em}.cs-stat-card strong{font-size:1.15rem;color:var(--color-text-bright);font-family:var(--font-mono)}.cs-attribute-card{position:relative;overflow:visible;padding:.78rem .82rem .88rem;border-color:color-mix(in srgb,var(--cs-accent) 28%,rgba(255,255,255,.06));background:linear-gradient(180deg,color-mix(in srgb,var(--cs-accent) 10%,rgba(255,255,255,.02)),#ffffff05);transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.cs-attribute-card:before{content:"";position:absolute;inset:0 0 auto 0;height:2px;border-radius:18px 18px 0 0;background:linear-gradient(90deg,color-mix(in srgb,var(--cs-accent) 72%,transparent),transparent);opacity:.92}.cs-attribute-card--compact{min-height:116px}.cs-attribute-card:hover,.cs-attribute-card:focus-within{transform:translateY(-1px);border-color:color-mix(in srgb,var(--cs-accent) 42%,rgba(255,255,255,.08));box-shadow:inset 0 1px #ffffff0d,0 16px 28px #00000029}.cs-attribute-card--physical{background:radial-gradient(circle at top left,rgba(34,211,238,.09),transparent 44%),linear-gradient(180deg,color-mix(in srgb,var(--cs-accent) 10%,rgba(255,255,255,.02)),#ffffff05)}.cs-attribute-card--mental{background:radial-gradient(circle at top left,rgba(212,175,55,.08),transparent 42%),linear-gradient(180deg,color-mix(in srgb,var(--cs-accent) 10%,rgba(255,255,255,.02)),#ffffff05)}.cs-attribute-card--social{background:radial-gradient(circle at top left,rgba(245,197,24,.07),transparent 44%),linear-gradient(180deg,color-mix(in srgb,var(--cs-accent) 10%,rgba(255,255,255,.02)),#ffffff05)}.cs-attribute-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.6rem;margin-bottom:.5rem}.cs-attribute-ident{min-width:0;display:flex;flex-direction:column;gap:.15rem}.cs-attribute-abbr{color:var(--color-text-bright);font-size:.92rem;line-height:1;letter-spacing:.1em;text-transform:uppercase;font-family:var(--font-title)}.cs-attribute-name{color:var(--color-text-dim);font-size:.64rem;line-height:1.15}.cs-attribute-category{flex-shrink:0;padding:.2rem .42rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);color:var(--color-text-dim);font-size:.55rem;line-height:1;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title)}.cs-attribute-category--physical{border-color:#22d3ee33;color:#98f4ffeb}.cs-attribute-category--mental{border-color:#d4af373d;color:#f3d670f2}.cs-attribute-category--social{border-color:#fde0472e;color:#fadd84f0}.cs-attribute-main{margin-bottom:.65rem}.cs-attribute-value{font-family:var(--font-title);color:var(--cs-accent)}.cs-attribute-inline{font-size:1.32rem;line-height:1;font-family:var(--font-title);color:var(--cs-accent)}.cs-inline-input.cs-attribute-inline{width:90px;min-width:90px;padding:.2rem .32rem}.cs-attribute-footer{display:flex;flex-wrap:wrap;gap:.38rem}.cs-attribute-threshold-pill{display:inline-flex;align-items:baseline;gap:.32rem;padding:.25rem .42rem;border-radius:999px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;color:var(--color-text-dim);font-family:var(--font-mono);font-size:.72rem}.cs-attribute-threshold-pill small{font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;color:#ffffff80}.cs-attribute-threshold-pill strong{color:var(--color-text-bright);font-size:.78rem}.cs-attribute-roll-menu{display:grid;grid-template-columns:1fr;gap:.35rem;margin-top:.65rem}.cs-attribute-roll-btn{min-width:0;min-height:30px;padding:.35rem .45rem;border-radius:6px;border:1px solid rgba(255,255,255,.08);background:#060e12f0;color:var(--color-text-dim);font-size:.6rem;font-family:var(--font-ui);font-weight:600;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast),transform var(--transition-fast)}.cs-attribute-roll-btn:hover,.cs-attribute-roll-btn:focus-visible{color:var(--color-gold-bright);border-color:#d4af3742;background:#d4af371c;transform:translateY(-1px)}.cs-skills-toolbar{display:flex;flex-direction:column;gap:.85rem}.cs-search-box{display:flex;align-items:center;gap:.6rem;padding:.8rem .9rem;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#ffffff06;color:var(--color-text-dim)}.cs-search-box input,.cs-textarea{width:100%;border:none;outline:none;background:transparent;color:var(--color-text);font:inherit}.cs-chip-row{display:flex;flex-wrap:wrap;gap:.55rem}.cs-chip{padding:.45rem .75rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff05;color:var(--color-text-dim);cursor:pointer}.cs-chip.active{color:var(--color-gold-bright);border-color:#d4af3752;background:#d4af3714}.cs-skill-groups{display:flex;flex-direction:column;gap:.85rem}.cs-skill-group{overflow:hidden;background:#ffffff05}.cs-skill-group-head{display:flex;justify-content:space-between;align-items:center;gap:.75rem;width:100%;border:none;padding:.85rem 1rem;border-bottom:1px solid rgba(255,255,255,.05);background:#ffffff05;font:inherit;text-align:left;color:var(--color-text);cursor:pointer}.cs-skill-group-copy{display:flex;flex-direction:column;gap:.25rem;min-width:0}.cs-skill-group-title{padding:0;font-family:var(--font-title);text-transform:uppercase;letter-spacing:.08em;color:var(--color-gold)}.cs-skill-group-summary{color:var(--color-text-dim);font-size:.72rem}.cs-skill-group-toggle{display:inline-flex;align-items:center;justify-content:center;color:var(--color-text-dim)}.cs-skill-list{display:flex;flex-direction:column}.cs-skill-row{display:flex;justify-content:space-between;gap:.9rem;align-items:center;flex-wrap:wrap;padding:.9rem 1rem;border-top:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.cs-skill-row:hover,.cs-skill-row:focus-visible,.cs-skill-row.is-favorite{background:#ffffff09}.cs-skill-row:focus-visible{outline:1px solid rgba(212,175,55,.4);outline-offset:-1px}.cs-skill-copy span,.cs-sidebar-list span,.cs-weapon-head strong+span{color:var(--color-text-dim)}.cs-skill-copy{display:flex;flex-direction:column;gap:.35rem;min-width:0;flex:1}.cs-skill-title-row{display:flex;align-items:center;gap:.55rem}.cs-skill-metrics{display:flex;gap:.7rem;flex-wrap:wrap;color:var(--color-text-dim);font-size:.76rem}.cs-skill-progress{height:7px;border-radius:999px;overflow:hidden;background:#ffffff0d}.cs-skill-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#d4af37e6,#22d3eecc)}.cs-favorite-toggle{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text-dim);cursor:pointer}.cs-favorite-toggle.active{color:var(--color-gold-bright);border-color:#d4af374d;background:#d4af3714}.cs-skill-actions{display:inline-flex;align-items:center;flex-wrap:wrap;gap:.6rem;flex-shrink:0;min-width:220px;justify-content:flex-end}.cs-skill-inline-edit{width:124px;min-width:124px;padding:.4rem .5rem;border-radius:10px;text-align:center;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;font-family:var(--font-mono)}.cs-inline-input.cs-skill-inline-edit{background:#081218f5;border-color:#22d3ee52}.cs-combat-overview{display:grid;grid-template-columns:minmax(280px,.9fr) minmax(0,1.1fr);gap:.85rem;align-items:stretch}.cs-combat-focus-card{display:flex;flex-direction:column;gap:.7rem;padding:.95rem 1rem;border-radius:20px;border:1px solid rgba(239,68,68,.14);background:radial-gradient(circle at top right,rgba(212,175,55,.08),transparent 28%),linear-gradient(180deg,#ffffff09,#ffffff05)}.cs-combat-focus-card.is-live{border-color:#d4af3738}.cs-combat-focus-card .cs-card-eyebrow{margin-bottom:0}.cs-combat-focus-head,.cs-combat-focus-title-row{display:flex;justify-content:space-between;gap:.7rem;align-items:center}.cs-combat-focus-title-row{align-items:flex-start}.cs-combat-focus-title-row strong{color:var(--color-text-bright);font-size:1rem;line-height:1.3}.cs-combat-tag,.cs-weapon-kind,.cs-weapon-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.26rem .5rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title)}.cs-combat-tag--ranged,.cs-weapon-kind--ranged{border-color:#22d3ee38;color:#98f4ffeb}.cs-combat-tag--melee,.cs-weapon-kind--melee{border-color:#ef444438;color:#ff9797eb}.cs-combat-focus-metrics,.cs-weapon-summary-line{display:flex;flex-wrap:wrap;gap:.6rem;color:var(--color-text-dim);font-size:.76rem;line-height:1.45}.cs-combat-focus-actions,.cs-weapon-primary-actions,.cs-weapon-secondary-actions{display:flex;flex-wrap:wrap;gap:.5rem}.cs-combat-stat-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(112px,1fr));gap:.6rem}.cs-combat-stat-pill{display:flex;flex-direction:column;gap:.25rem;padding:.75rem .82rem;border-radius:16px;border:1px solid rgba(255,255,255,.06);background:#ffffff06}.cs-combat-stat-pill span{color:var(--color-text-dim);font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-title)}.cs-combat-stat-pill strong{color:var(--color-text-bright);font-family:var(--font-mono);font-size:.98rem}.cs-combat-stat-pill--danger{border-color:#ef444424;background:linear-gradient(180deg,#ef444412,#ffffff05)}.cs-combat-skill-card{display:flex;flex-direction:column;gap:.58rem;padding:.9rem 1rem;border-radius:18px;border:1px solid rgba(239,68,68,.16);background:linear-gradient(180deg,#ef444414,#ef444408);color:var(--color-text)}.cs-combat-skill-card-head,.cs-weapon-row{display:flex;justify-content:space-between;gap:.8rem;align-items:flex-start}.cs-combat-skill-card-head strong{color:var(--color-fail);font-family:var(--font-mono)}.cs-combat-skill-card-metrics{display:flex;gap:.6rem;flex-wrap:wrap;color:var(--color-text-dim);font-size:.74rem}.cs-combat-skill-actions{display:flex;flex-wrap:wrap;gap:.45rem}.cs-weapon-list{display:flex;flex-direction:column;gap:.85rem}.cs-weapon-card{display:flex;flex-direction:column;gap:.85rem;border-color:#ffffff14;background:linear-gradient(180deg,#ffffff09,#ffffff05),#ffffff05}.cs-weapon-card.is-equipped{border-color:#d4af373d;background:radial-gradient(circle at top right,rgba(212,175,55,.08),transparent 32%),linear-gradient(180deg,#ffffff09,#ffffff05),#ffffff05}.cs-weapon-main{min-width:0;flex:1;display:flex;flex-direction:column;gap:.38rem}.cs-weapon-main strong{color:var(--color-text-bright);font-size:.96rem}.cs-weapon-topline{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center}.cs-weapon-shell{min-width:min(100%,330px);flex:0 1 330px;display:flex;flex-direction:column;gap:.55rem;align-items:flex-end}.cs-weapon-secondary-actions{justify-content:flex-end}.cs-weapon-badge--equipped{border-color:#d4af3742;color:var(--color-gold-bright);background:#d4af3714}.cs-weapon-badge--ready{border-color:#10b9813d;color:#6ee7b7f2;background:#10b98114}.cs-weapon-badge--low{border-color:#d4af373d;color:#f3d670f2;background:#d4af3714}.cs-weapon-badge--empty{border-color:#ef44443d;color:#ff9797f2;background:#ef444414}.cs-weapon-editor{padding-top:.15rem}.cs-textarea{min-height:92px;resize:vertical;color:var(--color-text)}.cs-sidebar{display:flex;flex-direction:column;align-items:stretch;gap:.75rem;overflow:visible}.cs-sidebar-card{display:flex;flex-direction:column;align-items:stretch;gap:.65rem;position:relative;overflow:visible;padding:.8rem .85rem;height:auto;min-height:fit-content;flex:0 0 auto;align-self:stretch}.cs-sidebar-roll-card{border-color:#d4af3724;background:radial-gradient(circle at top right,rgba(16,185,129,.1),transparent 30%),#ffffff08}.cs-sidebar-list{display:flex;flex-direction:column;gap:.7rem}.cs-sidebar .cs-section-title{font-size:.74rem;margin:0 0 .65rem}.cs-sidebar-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}.cs-sidebar-summary-grid div{display:flex;flex-direction:column;gap:.18rem;padding:.6rem .65rem;border-radius:14px;border:1px solid rgba(255,255,255,.05);background:#ffffff06}.cs-sidebar-summary-grid span{color:var(--color-text-dim);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title)}.cs-sidebar-summary-grid strong{color:var(--color-text-bright);font-family:var(--font-mono);font-size:.92rem}.cs-sidebar-muted{color:var(--color-text-dim);font-size:.74rem;line-height:1.35}.cs-sidebar-list div{display:flex;justify-content:space-between;gap:.7rem;align-items:baseline}.cs-sidebar-list strong{color:var(--color-text-bright);font-family:var(--font-mono)}.cs-sidebar-notes,.cs-roll-feed{display:flex;flex-direction:column;gap:.45rem}.cs-roll-feed-item{display:flex;justify-content:space-between;gap:.8rem;align-items:flex-start;padding:.65rem .75rem;border-radius:14px;border:1px solid rgba(255,255,255,.06);background:#ffffff06}.cs-roll-feed-item strong,.cs-roll-feed-result strong{color:var(--color-text-bright)}.cs-roll-feed-item span,.cs-roll-feed-result span{display:block;color:var(--color-text-dim);font-size:.7rem}.cs-roll-feed-result{text-align:right}.cs-sidebar-notes p{margin:0;padding-left:.75rem;position:relative;color:var(--color-text-dim);line-height:1.3;font-size:.74rem}.cs-sidebar-notes p:before{content:"";position:absolute;left:0;top:.45rem;width:6px;height:6px;border-radius:999px;background:var(--color-gold-bright);box-shadow:0 0 10px #d4af3773}.cs-top-skill-list{display:flex;flex-direction:column;gap:.45rem}.cs-top-skill-item{display:flex;justify-content:space-between;gap:.8rem;align-items:center;padding:.65rem .75rem;border-radius:14px;border:1px solid rgba(255,255,255,.06);background:#ffffff07;color:var(--color-text);cursor:pointer;transition:transform var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.cs-top-skill-item:hover{transform:translateY(-1px);border-color:#d4af373d;background:#d4af3712}.cs-top-skill-item span{text-align:left;font-size:.78rem}.cs-top-skill-item strong{color:var(--color-gold-bright);font-family:var(--font-mono);font-size:.8rem}.cs-sidebar-roll-body{display:flex;flex-direction:column;gap:.65rem}.cs-sidebar-roll-highlight{display:flex;flex-direction:column;gap:.3rem;padding:.7rem .8rem;border-radius:14px;border:1px solid rgba(255,255,255,.06);background:#ffffff06}.cs-sidebar-roll-highlight strong{color:var(--color-text-bright);font-size:.84rem}.cs-sidebar-roll-highlight span{color:var(--color-text-dim);font-size:.72rem}.cs-sidebar-roll-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}@media (max-width: 1180px){.cs-header{grid-template-columns:1fr}.cs-layout{grid-template-columns:minmax(0,1fr)}.cs-dashboard-grid,.cs-derived-strip,.cs-combat-overview{grid-template-columns:1fr}.cs-attribute-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cs-sidebar{overflow:visible}}@media (max-width: 820px){.cs-meter-row,.cs-field-grid,.cs-history-grid,.cs-info-matrix,.cs-resource-grid,.cs-dossier-grid,.cs-action-grid,.cs-weapon-grid,.cs-attribute-grid,.cs-stat-grid,.cs-combat-skill-grid,.cs-derived-strip,.cs-combat-stat-strip{grid-template-columns:1fr}.cs-header,.cs-meter-row,.cs-tabs,.cs-layout,.cs-tab-context{padding-left:1rem;padding-right:1rem}.cs-tab-context{align-items:flex-start;flex-direction:column;gap:.25rem}.cs-test-guide{grid-template-columns:1fr;margin-left:1rem;margin-right:1rem}.cs-test-guide-levels{grid-template-columns:1fr}.cs-overview-attributes{grid-template-columns:repeat(2,minmax(0,1fr))}.cs-overview-skills{grid-template-columns:1fr}.cs-header{gap:.85rem}.cs-header-rail{display:none}.cs-meter-row{flex:0 0 auto;grid-template-columns:none;grid-auto-columns:minmax(150px,44vw);grid-auto-flow:column;overflow-x:auto;position:static;scrollbar-width:thin}.cs-tabs-wrap{flex:0 0 auto;top:0}.cs-tab-context{flex:0 0 auto}.cs-header-main{align-items:flex-start}.cs-header-topline,.cs-skill-row,.cs-section-header,.cs-combat-skill-card-head,.cs-weapon-row{flex-direction:column;align-items:stretch}.cs-quick-adjust{grid-template-columns:1fr}.cs-quick-adjust-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.cs-meta-pill{min-width:0}.cs-tab{flex:0 0 auto;min-width:150px}.cs-character-switcher-head{flex-direction:column;align-items:flex-start}.cs-character-switcher-list{display:grid;grid-template-columns:1fr}.cs-character-chip{min-width:0;width:100%}.cs-rail-metrics{grid-template-columns:1fr}.cs-skill-actions{justify-content:space-between;min-width:0}.cs-combat-focus-head,.cs-combat-focus-title-row{flex-wrap:wrap}.cs-combat-focus-actions,.cs-combat-skill-actions,.cs-weapon-primary-actions,.cs-weapon-secondary-actions{width:100%}.cs-weapon-shell{min-width:0;width:100%;align-items:stretch}.cs-weapon-secondary-actions{justify-content:flex-start}.cs-attribute-card{min-height:auto}.cs-attribute-footer{padding-right:0}.cs-attribute-roll-menu{position:static;margin-top:.55rem;opacity:1;pointer-events:auto;transform:none}.cs-skill-inline-edit{width:116px;min-width:116px}}.clues-panel{display:flex;flex-direction:column;gap:1rem;padding:1rem}.clues-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--color-border);padding-bottom:.5rem}.clue-add-form{display:flex;flex-direction:column;gap:.75rem}.checkbox-group{flex-direction:row!important;align-items:center;gap:.5rem}.checkbox-group input{width:auto}.clues-list{display:flex;flex-direction:column;gap:1rem}.clue-card{position:relative;padding:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);border-left:4px solid var(--color-teal);transition:all var(--transition-fast)}.clue-card.secret{border-left-color:var(--color-purple);background:#7c3aed0d}.clue-card.revealed{border-left-color:var(--color-gold);animation:reveal-pulse 1s ease-out}@keyframes reveal-pulse{0%{box-shadow:0 0 #b8860b66}to{box-shadow:0 0 0 10px #b8860b00}}.clue-category-tab{position:absolute;top:0;right:1rem;padding:.15rem .4rem;font-size:.6rem;text-transform:uppercase;font-family:var(--font-ui);font-weight:600;border-radius:0 0 4px 4px;background:var(--color-border);color:var(--color-text-dim)}.clue-category-tab[data-category=mythos]{background:var(--color-purple-dim);color:#a855f7}.clue-category-tab[data-category=mundane]{background:var(--color-teal-dim);color:var(--color-teal-bright)}.clue-category-tab[data-category=personal]{background:var(--color-gold-dim);color:var(--color-gold)}.clue-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;padding-right:4rem}.clue-title{font-family:var(--font-title);font-size:1.05rem;font-weight:700;color:var(--color-text-bright)}.clue-content{font-family:var(--font-body);font-size:.95rem;color:var(--color-text);white-space:pre-wrap;line-height:1.4}.clue-footer{margin-top:.75rem;font-size:.75rem;color:var(--color-text-dim);font-style:italic;border-top:1px dashed var(--color-border);padding-top:.4rem}.btn-xs{padding:.2rem .4rem;font-size:.7rem}.clues-loading{padding:2rem;text-align:center}.crew-panel{display:flex;flex-direction:column;gap:1rem;padding:1rem}.crew-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--color-border);padding-bottom:.5rem;margin-bottom:.5rem}.crew-add-form{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem;padding:1rem;border:1px solid var(--color-gold-dim)}.crew-list{display:flex;flex-direction:column;gap:.5rem}.crew-member-card{display:flex;justify-content:space-between;align-items:center;padding:.6rem .8rem;background:var(--color-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:transform var(--transition-fast)}.crew-member-card:hover{transform:translate(4px);border-color:var(--color-teal)}.crew-member-card.dead{opacity:.5;background:#0006;filter:grayscale(1);border-color:var(--color-fail)}.member-info{display:flex;flex-direction:column}.member-name{font-family:var(--font-title);font-size:.95rem;font-weight:600;color:var(--color-text-bright)}.member-role{font-family:var(--font-ui);font-size:.75rem;color:var(--color-gold);text-transform:uppercase;letter-spacing:.05em}.member-status-area{display:flex;align-items:center;gap:.75rem}.status-badge{padding:.15rem .4rem;border-radius:4px;font-size:.65rem;font-family:var(--font-ui);text-transform:uppercase;font-weight:600}.status-badge.active{background:#4ade8026;color:var(--color-success);border:1px solid var(--color-success)}.status-badge.wounded{background:#d9770626;color:var(--color-amber);border:1px solid var(--color-amber)}.status-badge.incapacitated{background:#f8717126;color:var(--color-fail);border:1px solid var(--color-fail)}.status-badge.dead{background:#0006;color:var(--color-text-dim);border:1px solid var(--color-text-dim)}.member-actions{display:flex;align-items:center;gap:.4rem}.status-select{padding:.2rem;font-size:.75rem;background:var(--color-void);border-color:var(--color-border);color:var(--color-text);width:auto}.btn-icon-danger{background:none;border:none;color:var(--color-fail);font-size:1.2rem;cursor:pointer;line-height:1;padding:0 .2rem;opacity:.6;transition:opacity .2rem}.btn-icon-danger:hover{opacity:1}.crew-loading,.crew-empty{padding:2rem;text-align:center}.diary-root{display:flex;flex-direction:column;height:100%;min-height:0;overflow:auto;background:radial-gradient(circle at top,rgba(201,164,74,.08),transparent 32%),linear-gradient(180deg,#051510f0,#030d08fa)}.diary-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.95rem 1.1rem;border-bottom:1px solid rgba(201,164,74,.18);background:linear-gradient(180deg,#10231cf5,#091813f0);flex-shrink:0}.diary-toolbar-copy{display:flex;flex-direction:column;gap:.3rem}.diary-kicker{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:#c9a44abf}.diary-title{display:inline-flex;align-items:center;gap:.55rem;margin:0;font-family:var(--font-serif);font-size:1.2rem;color:var(--color-parchment)}.diary-actions{display:flex;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:.6rem}.diary-view-tabs{display:flex;align-items:center;flex-wrap:wrap;gap:.45rem}.diary-view-tab{display:inline-flex;align-items:center;gap:.42rem;min-height:2.35rem;padding:.45rem .8rem;border-radius:999px;border:1px solid rgba(201,164,74,.16);background:#08130f7a;color:#f0ddb4d6;font-family:var(--font-body);font-size:.9rem;transition:border-color .2s ease,background .2s ease,color .2s ease}.diary-view-tab strong{min-width:1.55rem;padding:.1rem .4rem;border-radius:999px;background:#c9a44a1f;color:var(--color-gold-bright);font-family:var(--font-mono);font-size:.7rem;text-align:center}.diary-view-tab.is-active,.diary-view-tab:hover{border-color:#c9a44a57;background:#c9a44a1a;color:var(--color-parchment)}.diary-loading,.diary-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:.8rem;padding:2rem;text-align:center;color:var(--color-text-dim)}.diary-empty-book{flex:1;display:flex;align-items:center;justify-content:center;padding:1.5rem;min-height:0}.diary-empty-cover{width:min(100%,32rem);min-height:24rem;padding:2rem;border-radius:1.4rem;border:1px solid rgba(201,164,74,.24);box-shadow:0 28px 60px #0000007a;background:linear-gradient(145deg,#2e1b0cf5,#160e08fa),radial-gradient(circle at top,rgba(201,164,74,.12),transparent 28%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;position:relative;overflow:hidden}.diary-empty-cover:before,.diary-empty-cover:after{content:"";position:absolute;top:1rem;right:1rem;bottom:1rem;left:1rem;border-radius:1rem;border:1px solid rgba(201,164,74,.12);pointer-events:none}.diary-empty-cover:after{inset:auto 2rem 0;height:.55rem;border-radius:0 0 1rem 1rem;background:linear-gradient(90deg,#00000073,#c9a44a2e,#00000073);border:none}.diary-empty-cover h4{font-size:1.6rem;color:var(--color-parchment)}.diary-empty-cover p{max-width:25rem;color:#f0ddb4c2}.diary-empty-seal{display:inline-flex;align-items:center;justify-content:center;min-width:12rem;padding:.4rem .9rem;border-radius:999px;background:#c9a44a1f;border:1px solid rgba(201,164,74,.3);color:var(--color-gold-bright);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase}.diary-editor-book,.diary-book-wrapper{flex:1;min-height:0;display:flex;align-items:flex-start;justify-content:center;padding:1rem 1.25rem 1.75rem;overflow:auto;background:radial-gradient(circle at center,rgba(201,164,74,.1),transparent 22%),linear-gradient(180deg,#07130ff5,#030d08fa)}.diary-editor-spread,.diary-book-stage{width:min(100%,84rem)}.diary-editor-spread{display:grid;grid-template-columns:minmax(16.5rem,20rem) minmax(0,1fr);gap:1.35rem;align-items:stretch}.diary-editor-page{min-height:42rem;position:relative;border-radius:1.15rem;border:1px solid rgba(109,79,39,.42);box-shadow:0 24px 50px #00000073,inset 0 0 0 1px #fff8e41f;overflow:hidden}.diary-editor-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,rgba(120,86,42,.22),transparent 12%,transparent 88%,rgba(120,86,42,.18)),repeating-linear-gradient(180deg,transparent,transparent 1.7rem,rgba(117,87,46,.07) 1.7rem,rgba(117,87,46,.07) 1.75rem);pointer-events:none}.diary-editor-meta{padding:1.6rem;background:linear-gradient(180deg,#27170cf5,#19100afa);display:flex;flex-direction:column;gap:1rem}.diary-page-badge{display:inline-flex;align-items:center;align-self:flex-start;padding:.35rem .7rem;border-radius:999px;border:1px solid rgba(201,164,74,.24);background:#c9a44a14;color:var(--color-gold-bright);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase}.diary-book-field{display:flex;flex-direction:column;gap:.45rem}.diary-book-field>span{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#f0ddb4b8}.diary-book-input{padding:.85rem .95rem;border-radius:.85rem;border:1px solid rgba(201,164,74,.18);background:#0a12106b;color:var(--color-parchment);font-family:var(--font-serif);font-size:1rem}.diary-book-input::placeholder{color:#f0ddb452}.diary-editor-note{display:flex;align-items:flex-start;gap:.7rem;padding:.9rem 1rem;border-radius:1rem;background:#c9a44a14;border:1px solid rgba(201,164,74,.14);color:#f0ddb4cc}.diary-editor-note svg{flex-shrink:0;color:var(--color-gold-bright)}.diary-editor-note p{color:inherit}.diary-public-toggle{display:inline-flex;align-items:center;gap:.65rem;margin-top:auto;color:#f0ddb4cc;cursor:pointer}.diary-public-toggle input{width:1rem;height:1rem;accent-color:var(--color-gold-bright)}.diary-editor-buttons{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.diary-editor-buttons .btn{justify-content:center}.diary-editor-note--soft{margin-top:auto}.diary-editor-sheet{display:flex;flex-direction:column;padding:0;background:linear-gradient(180deg,#f5eacdfa,#decca4fa)}.diary-editor-sheet-head{display:flex;align-items:center;justify-content:space-between;min-height:3.4rem;padding:0 1.4rem;border-bottom:1px solid rgba(108,83,45,.18);background:linear-gradient(180deg,#fff8e7bf,#e4d2aa80);color:#4d371cd9;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}.diary-editor-sheet-actions{display:flex;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:.55rem}.diary-sheet-icon{min-height:2.15rem;padding-inline:.75rem;gap:.42rem;white-space:nowrap}.diary-sheet-icon.is-active{border-color:#c9a44a5c;background:#c9a44a1f;color:#553a18eb}.diary-book-editor-tools{display:flex;align-items:center;flex-wrap:wrap;gap:.55rem}.diary-book-section,.diary-book-tool{min-height:2.2rem;gap:.42rem;white-space:nowrap}.diary-book-section.is-active,.diary-book-tool.is-active{border-color:#c9a44a57;background:#c9a44a1a;color:var(--color-parchment)}.diary-editor-area{flex:1;min-height:0;display:flex;flex-direction:column;gap:1rem;padding:1rem;position:relative}.diary-editor-sheet .tiptap-wrapper{flex:1;border:none;border-radius:.9rem;background:#fffaee9e;box-shadow:inset 0 0 0 1px #7c5d2e1f}.diary-editor-sheet .tiptap-toolbar{padding:.55rem .7rem;background:#fff8e6d1;border-bottom:1px solid rgba(124,93,46,.12)}.diary-editor-sheet .tiptap-btn{color:#5a4223cc}.diary-editor-sheet .tiptap-btn:hover{background:#c9a44a1a;color:#372612eb}.diary-editor-sheet .tiptap-content{padding:1rem 1.2rem}.diary-editor-sheet .tiptap-content .ProseMirror{min-height:28rem;color:#372612f5;font-size:1.03rem;line-height:1.92}.diary-editor-sheet .tiptap-content .ProseMirror h2,.diary-editor-sheet .tiptap-content .ProseMirror h3,.diary-editor-sheet .tiptap-content .ProseMirror blockquote{color:#4e381aeb}.diary-textarea{flex:1;min-height:28rem;resize:none;border:none;background:#fffaee99;color:#372612f5;font-family:var(--font-body);font-size:1.03rem;line-height:1.92;padding:1rem 1.2rem;border-radius:.9rem;box-shadow:inset 0 0 0 1px #7c5d2e1f}.diary-textarea:focus{outline:none;box-shadow:inset 0 0 0 1px #7c5d2e1f,0 0 0 2px #c9a44a3d}.diary-book-stage{display:flex;flex-direction:column;align-items:center;gap:.9rem;perspective:none}.diary-book-hint{align-self:center;padding:.4rem .8rem;border-radius:999px;background:#c9a44a14;border:1px solid rgba(201,164,74,.18);color:#f0ddb4c2;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase}.diary-book-hud{width:min(100%,74rem);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.9rem}.diary-book-stats{display:inline-flex;align-items:center;padding:.45rem .8rem;border-radius:999px;background:#c9a44a14;border:1px solid rgba(201,164,74,.16);color:#f0ddb4cc;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase}.diary-page-progress{display:flex;flex-direction:column;gap:.18rem}.diary-page-progress span,.diary-page-progress strong{font-family:var(--font-mono);text-transform:uppercase}.diary-page-progress span{font-size:.64rem;letter-spacing:.22em;color:#f0ddb485}.diary-page-progress strong{font-size:.8rem;letter-spacing:.12em;color:#f0ddb4e0}.diary-book-controls{display:flex;align-items:center;gap:.6rem}.diary-book-current-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.55rem}.diary-book-control{min-width:8.8rem;justify-content:center}.diary-notebook-shell{width:min(100%,74rem);position:relative;display:flex;align-items:center;justify-content:center;min-height:48rem;padding:.75rem;border-radius:1.5rem;border:1px solid rgba(201,164,74,.12);background:linear-gradient(180deg,#0a1713eb,#050f0cf5);box-shadow:inset 0 0 0 1px #fff8e40a,0 24px 48px #00000047}.diary-notebook-shell:before{display:none}.diary-notebook-stack{display:none}.diary-notebook-stack-back{background:linear-gradient(180deg,#e9dfc4f2,#c5b28ce0);box-shadow:0 26px 44px #0006,inset 0 0 0 1px #73542d29;transform:translate3d(0,-49%,-32px) rotateX(8deg) rotateY(-3deg)}.diary-notebook-stack-front{width:min(100%,58rem);height:min(79vw,37rem);background:linear-gradient(180deg,#f7efdbf5,#dbc9a4e6);box-shadow:0 12px 24px #0000002e,inset 0 0 0 1px #73542d1f;transform:translate3d(.8rem,-50%,-9px) rotateX(7deg) rotateY(-1.5deg)}.diary-notebook-spine{display:none}.diary-notebook-spine:before{display:none}.diary-book{width:min(100%,74rem);max-width:100%;filter:drop-shadow(0 20px 38px rgba(0,0,0,.34));transform:none}.diary-book--writing{filter:drop-shadow(0 24px 42px rgba(0,0,0,.4))}.diary-page{background:linear-gradient(180deg,#faf3ddfa,#decca4fa);border:1px solid rgba(109,79,39,.34);color:#362711eb;overflow:hidden;position:relative;box-shadow:inset 0 0 0 1px #fffaf01f,0 8px 20px #00000024}.diary-writing-page{overflow:hidden}.diary-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,rgba(201,164,74,.16),transparent 28%),repeating-linear-gradient(180deg,transparent,transparent 1.65rem,rgba(124,93,46,.055) 1.65rem,rgba(124,93,46,.055) 1.71rem);pointer-events:none}.diary-page:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,rgba(86,60,24,.16),transparent 12%,transparent 88%,rgba(86,60,24,.14));pointer-events:none}.diary-page-corner{display:none}.page-left:after{background:linear-gradient(90deg,rgba(86,60,24,.2),transparent 18%,transparent 100%)}.page-right:after{background:linear-gradient(90deg,transparent 0,transparent 82%,rgba(86,60,24,.18) 100%)}.diary-page-cover{background:linear-gradient(145deg,#2d1c0efa,#140d08);color:var(--color-parchment)}.diary-page-cover:before{background:radial-gradient(circle at top,rgba(201,164,74,.18),transparent 34%),linear-gradient(180deg,rgba(255,255,255,.03),transparent)}.diary-cover-page,.diary-back-page,.diary-blank-page{position:relative;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2.5rem 2rem;text-align:center}.diary-cover-page:before,.diary-back-page:before,.diary-blank-page:before{content:"";position:absolute;top:1.2rem;right:1.2rem;bottom:1.2rem;left:1.2rem;border:1px solid rgba(201,164,74,.16);border-radius:1rem;pointer-events:none}.diary-cover-kicker{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#c9a44ae0;margin-bottom:1rem}.diary-cover-page h4,.diary-back-page span{font-size:1.7rem;color:inherit}.diary-cover-page p,.diary-back-page p{max-width:15rem;color:inherit;opacity:.78}.diary-blank-page{color:#4f381ae0;background:linear-gradient(180deg,#f6efddfa,#e2d3b2fa)}.diary-blank-page span{font-size:1.35rem;color:inherit}.diary-blank-page p{max-width:16rem;color:inherit;opacity:.76}.diary-page-back{background:linear-gradient(160deg,#e7d6b1fa,#cfbc93fa)}.diary-page-inner{position:relative;display:flex;flex-direction:column;gap:.8rem;height:100%;padding:1.55rem 1.55rem 3rem;cursor:pointer;transition:box-shadow .2s ease,background .2s ease}.diary-page-inner.is-selected{box-shadow:inset 0 0 0 2px #c9a44a47,inset 0 0 0 1px #fff8e41f;background:linear-gradient(180deg,rgba(201,164,74,.05),transparent 16%)}.diary-entry-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.diary-entry-badges,.diary-inline-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.45rem}.diary-entry-date{display:inline-flex;align-items:center;padding:.28rem .6rem;border-radius:999px;background:#7c5d2e1a;color:#604523e0;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.diary-entry-author,.diary-entry-visibility{display:inline-flex;align-items:center;gap:.35rem;padding:.28rem .6rem;border-radius:999px;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase}.diary-entry-author{background:#0f221e14;color:#533d1ee0}.diary-entry-visibility{background:#c9a44a1a;color:#714f22eb}.diary-page-title{margin:0;padding-bottom:.75rem;border-bottom:1px solid rgba(124,93,46,.16);font-family:var(--font-serif);font-size:1.38rem;color:#3d2a12f0}.diary-page-text{flex:1;overflow:auto;color:#392812f0;font-family:var(--font-body);font-size:1.03rem;line-height:1.9;padding-right:.35rem}.diary-page-text p,.diary-page-text ul,.diary-page-text ol,.diary-page-text blockquote,.diary-page-text hr{margin-bottom:.75rem}.diary-page-text h2{font-size:1.15rem;color:#4f381af0;margin-bottom:.45rem}.diary-page-text h3{font-size:1rem;color:#4f381af0;margin-bottom:.35rem}.diary-page-text ul,.diary-page-text ol{padding-left:1.3rem}.diary-page-text blockquote{padding-left:.85rem;border-left:2px solid rgba(124,93,46,.38);color:#583f1fd1;font-style:italic}.diary-writing-inner{position:relative;display:flex;flex-direction:column;gap:1rem;height:100%;padding:1.55rem}.diary-writing-inner--page{gap:.85rem;padding:0}.diary-writing-headline{margin:0;font-family:var(--font-serif);font-size:1.45rem;color:#3d2a12f0}.diary-writing-field{display:flex;flex-direction:column;gap:.45rem}.diary-writing-field>span{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#5e4423cc}.diary-writing-input{min-height:3rem;padding:.8rem .95rem;border-radius:.95rem;border:1px solid rgba(124,93,46,.18);background:#fffaeead;color:#372612f5;font-family:var(--font-serif);font-size:1rem;box-shadow:inset 0 0 0 1px #fffdf43d}.diary-writing-input:focus{outline:none;box-shadow:inset 0 0 0 1px #fffdf43d,0 0 0 2px #c9a44a38}.diary-writing-toggle{margin-top:0;color:#563e1fd6}.diary-writing-actions{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;margin-top:auto}.diary-writing-actions--center{justify-content:center;margin-top:.6rem}.diary-writing-textarea{flex:1;min-height:36rem;width:100%;resize:none;border:none;padding:1.7rem 1.65rem 1.8rem;background:linear-gradient(180deg,#faf3dd38,#decca424);color:#392812f5;font-family:var(--font-body);font-size:1.05rem;line-height:1.95;box-shadow:none}.diary-writing-textarea::placeholder{color:#62482485}.diary-writing-textarea:focus{outline:none;box-shadow:inset 0 0 0 1px #c9a44a29}.diary-writing-footnote{color:#614723b8;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:0 1.45rem 1.2rem}.diary-writing-finish{gap:1rem}.diary-page-sketch{margin-top:.35rem;padding:.75rem;border-radius:1rem;background:#7c5d2e14;border:1px solid rgba(124,93,46,.14)}.diary-page-sketch img{display:block;width:100%;max-height:16rem;object-fit:contain;border-radius:.7rem;background:#fff9ecb8}.diary-page-num{position:absolute;right:1.25rem;bottom:.9rem;color:#6b4d278c;font-family:var(--font-mono);font-size:.72rem}.diary-edit-btn{position:static;padding-inline:.7rem}.diary-editor-sketch{display:flex;flex-direction:column;gap:.8rem;padding-top:.2rem}.diary-editor-sketch-head{display:flex;flex-direction:column;gap:.2rem}.diary-editor-sketch-head span{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#4d371cd6}.diary-editor-sketch-head small{color:#594122b8;line-height:1.45}.diary-sketchpad{display:flex;flex-direction:column;gap:.65rem;padding:.8rem;border-radius:1rem;background:#fff8e59e;border:1px solid rgba(124,93,46,.14);box-shadow:inset 0 0 0 1px #fffdf447}.diary-sketch-surface{position:relative}.diary-sketch-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;color:#543c1cd1;font-size:.88rem}.diary-sketch-clear{min-height:2.2rem;padding-inline:.85rem}.diary-sketch-canvas{width:100%;height:20rem;display:block;border-radius:.9rem;border:1px dashed rgba(124,93,46,.28);background:#fff9ece6;cursor:default;touch-action:none;pointer-events:none}.diary-sketch-canvas.is-enabled{cursor:crosshair;pointer-events:auto}.diary-sketch-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.55rem;padding:1rem;border-radius:.9rem;background:#f5eed9c7;color:#5e4423db;text-align:center;pointer-events:none}.diary-sketch-overlay span{max-width:22rem;line-height:1.5}.diary-fallback{flex:1;min-height:0;display:flex;flex-direction:column;gap:.9rem;padding:1.25rem}.diary-fallback-page{flex:1;min-height:0;padding:1.6rem;border-radius:1rem;background:linear-gradient(180deg,#faf3ddfa,#decca4fa);border:1px solid rgba(109,79,39,.34);box-shadow:0 18px 38px #0000005c;overflow:auto}.diary-nav{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}@media (max-width: 900px){.diary-toolbar{flex-direction:column;align-items:stretch}.diary-actions{justify-content:flex-end}.diary-editor-spread{grid-template-columns:1fr}.diary-editor-page{min-height:30rem}.diary-notebook-shell{min-height:40rem}.diary-book,.diary-book-hud,.diary-notebook-shell{width:100%}}@media (max-width: 640px){.diary-editor-book,.diary-book-wrapper,.diary-fallback,.diary-empty-book{padding:.85rem}.diary-empty-cover{min-height:20rem;padding:1.4rem}.diary-book-hint{text-align:center;line-height:1.45}.diary-book-hud{width:100%;flex-direction:column;align-items:stretch}.diary-book-controls{width:100%;justify-content:space-between}.diary-book-current-actions{width:100%;justify-content:stretch}.diary-book-editor-tools{width:100%}.diary-book-control{min-width:0;flex:1}.diary-notebook-shell{width:100%;padding:.8rem .25rem 1rem;min-height:0}.diary-book{transform:none}.diary-writing-textarea{min-height:28rem;padding:1.25rem 1.15rem 1.4rem}.diary-editor-meta{padding:1.1rem}.diary-entry-head{align-items:flex-start;flex-direction:column}.diary-sketch-toolbar{flex-direction:column;align-items:stretch}.diary-nav{justify-content:center}}.audit-settings{display:flex;flex-direction:column;padding:1rem}.audit-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--color-border);padding-bottom:.5rem;margin-bottom:.5rem}.audit-log-list{display:flex;flex-direction:column;gap:.5rem}.audit-entry{display:flex;gap:1rem;padding:.6rem;background:var(--color-abyss);border:1px solid var(--color-border);border-radius:4px;font-family:var(--font-mono)}.audit-time{font-size:.7rem;color:var(--color-gold);min-width:70px}.audit-main{display:flex;flex-direction:column;gap:.2rem;flex:1}.audit-action{font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--color-text-bright)}.audit-details{font-size:.65rem;color:var(--color-text-dim);word-break:break-all;max-height:40px;overflow-y:auto}.audit-loading{padding:2rem;text-align:center}.encounter-builder{display:flex;flex-direction:column;gap:1rem;padding:1rem}.encounter-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--color-border);padding-bottom:.5rem}.encounter-form{display:flex;flex-direction:column;gap:.75rem;border:1px solid var(--color-fail)}.encounter-list{display:flex;flex-direction:column;gap:.75rem}.encounter-card{padding:1rem;background:var(--color-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:.5rem;transition:box-shadow var(--transition-fast)}.encounter-card:hover{box-shadow:0 0 10px #f871711a}.encounter-card.resolved{opacity:.6;background:#0000004d;border-color:var(--color-text-dim)}.enc-header{display:flex;justify-content:space-between;align-items:baseline}.enc-name{font-family:var(--font-title);font-size:1rem;font-weight:700;color:var(--color-text-bright)}.enc-cr{font-family:var(--font-mono);color:var(--color-fail);font-weight:700}.enc-meta{display:flex;gap:.5rem;align-items:center}.biome-tag{font-size:.65rem;text-transform:uppercase;background:var(--color-void);color:var(--color-teal-bright);padding:.1rem .4rem;border:1px solid var(--color-teal-dim);border-radius:4px}.resolved-badge{font-size:.65rem;color:var(--color-text-dim);text-transform:uppercase}.enc-actions{margin-top:.5rem}.encounter-loading{padding:2rem;text-align:center}.npc-library{display:flex;flex-direction:column;gap:1rem;padding:1rem}.npc-lib-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--color-border);padding-bottom:.5rem}.npc-template-form{display:flex;flex-direction:column;gap:.6rem;padding:1rem}.npc-template-list{display:flex;flex-direction:column;gap:.75rem}.npc-card{padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);border-left:5px solid var(--color-teal);transition:transform var(--transition-fast)}.npc-card:hover{transform:translate(4px);background:var(--color-raised)}.npc-card.creature{border-left-color:var(--color-fail)}.npc-card.mythos_entity{border-left-color:var(--color-purple)}.npc-card.human{border-left-color:var(--color-gold)}.npc-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.npc-name{font-family:var(--font-title);font-size:.95rem;font-weight:700;color:var(--color-text-bright)}.npc-type-tag{font-size:.6rem;text-transform:uppercase;color:var(--color-text-dim);background:var(--color-void);padding:.1rem .3rem;border-radius:4px}.npc-stats-preview{display:flex;flex-wrap:wrap;gap:.4rem;font-family:var(--font-mono);font-size:.65rem;color:var(--color-text-dim);margin-bottom:.75rem}.npc-stats-preview span{background:#0003;padding:.1rem .3rem;border-radius:2px}.npc-actions{display:flex;gap:.5rem;justify-content:flex-end}.npc-lib-loading{padding:2rem;text-align:center}.weather-panel{display:flex;flex-direction:column;gap:1rem;padding:1rem}.weather-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--color-border);padding-bottom:.5rem}.active-weather-card{display:flex;gap:1rem;padding:1rem;background:var(--color-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);border-left:6px solid var(--color-teal);position:relative;overflow:hidden}.active-weather-card.storm{border-left-color:#3b82f6;background:#3b82f60d}.active-weather-card.hurricane{border-left-color:#f43f5e;background:#f43f5e0d}.active-weather-card.supernatural{border-left-color:#a855f7;background:#a855f70d}.active-weather-card.fog{border-left-color:var(--color-text-dim);background:#7a72680d}.weather-type-icon{font-size:2rem;display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;background:var(--color-abyss);border-radius:50%;border:1px solid var(--color-border)}.weather-info{flex:1}.weather-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.weather-type-label{font-family:var(--font-title);font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-bright)}.weather-severity-badge{padding:.1rem .4rem;font-size:.6rem;font-family:var(--font-ui);text-transform:uppercase;font-weight:700;border-radius:4px;background:var(--color-gold-dim);color:var(--color-gold);border:1px solid var(--color-gold)}.weather-desc{font-family:var(--font-body);font-size:.9rem;color:var(--color-text);margin-bottom:1.5rem}.weather-effects{display:flex;flex-wrap:wrap;gap:.4rem}.effect-tag{font-family:var(--font-mono);font-size:.65rem;background:var(--color-void);padding:.1rem .35rem;border-radius:4px;border:1px solid var(--color-border);color:var(--color-teal-bright)}.weather-presets{padding:1rem;display:flex;flex-direction:column;gap:1rem}.presets-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.btn-preset{padding:.5rem;font-family:var(--font-ui);font-size:.8rem;text-transform:uppercase;background:var(--color-void);border:1px solid var(--color-border);color:var(--color-text-dim);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;gap:.4rem;transition:all var(--transition-fast)}.btn-preset:hover{border-color:var(--color-teal);color:var(--color-text-bright);background:var(--color-teal-dim)}.weather-history{display:flex;flex-direction:column;gap:.5rem}.weather-history label{font-size:.75rem;color:var(--color-text-dim)}.history-list{display:flex;flex-direction:column;gap:.25rem}.history-item{display:flex;justify-content:space-between;align-items:center;padding:.4rem .6rem;background:var(--color-abyss);border:1px solid var(--color-border);border-radius:4px;font-size:.8rem;color:var(--color-text-dim)}.history-item.active{border-color:var(--color-teal-dim);background:var(--color-teal-dim);color:var(--color-teal-bright)}.btn-text{background:none;border:none;color:var(--color-teal);font-size:.75rem;cursor:pointer;text-decoration:underline}.weather-loading,.weather-empty{padding:2rem;text-align:center}.knowledge-chat{display:flex;flex-direction:column;gap:12px;height:auto;min-height:100%;padding:18px;color:#dce9df;background:radial-gradient(circle at top right,rgba(212,175,55,.08),transparent 26%),radial-gradient(circle at left center,rgba(16,185,129,.07),transparent 28%),linear-gradient(180deg,#031112f5,#020c0efa);border-radius:24px;border:1px solid rgba(72,115,96,.28);box-shadow:inset 0 1px #ffffff0a,0 18px 50px #00000038;overflow:visible}.kc-header,.kc-summary,.kc-progress-bar-wrap,.kc-library-sidebar,.kc-viewer-shell,.kc-chat-shell{border:1px solid rgba(100,132,117,.18);background:linear-gradient(180deg,#08191cf0,#051214f5),#ffffff05;border-radius:20px;box-shadow:inset 0 1px #ffffff08}.kc-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px;flex-shrink:0}.kc-title{display:flex;align-items:flex-start;gap:14px}.kc-title-mark{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:14px;background:#d4af371a;border:1px solid rgba(212,175,55,.22);color:#f0d28f;flex-shrink:0}.kc-kicker,.kc-summary-label,.kc-viewer-chip,.kc-book-badge{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:#9eb2a5}.kc-kicker{color:#f0d28f}.kc-title h3{margin:.2rem 0 0;color:#f7f4e9;font-size:1.45rem;font-family:Cinzel,Georgia,serif}.kc-subtitle{margin:.45rem 0 0;max-width:62ch;color:#8fa398;line-height:1.6;font-size:.92rem}.kc-header-actions{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.kc-view-switch,.kc-gm-controls,.kc-chip-row,.kc-viewer-tags,.kc-viewer-actions,.kc-quick-questions,.kc-quick-bar,.kc-query-actions{display:flex;flex-wrap:wrap;gap:8px}.kc-view-btn,.kc-chip,.kc-quick-btn,.kc-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:#a9beb2;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease,color .16s ease}.kc-view-btn:hover,.kc-chip:hover,.kc-quick-btn:hover,.kc-btn:hover{transform:translateY(-1px);border-color:#10b9813d}.kc-view-btn,.kc-chip,.kc-quick-btn{padding:.5rem .82rem;font-size:.79rem}.kc-view-btn.active,.kc-chip.active{color:#f0d28f;border-color:#d4af3747;background:#d4af3714}.kc-btn{padding:.58rem .95rem;font-size:.78rem;font-weight:600}.kc-btn-primary{color:#f8e7b8;border-color:#d4af3759;background:linear-gradient(135deg,#65410aeb,#916314eb)}.kc-btn-ghost{color:#b6c9be}.kc-btn-danger{color:#f5c1c1;border-color:#ef444438;background:#ef444414}.kc-hidden-input{display:none}.kc-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:14px;flex-shrink:0}.kc-summary-card{display:flex;flex-direction:column;gap:4px;padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.06);background:#ffffff06}.kc-summary-card strong{color:#f7f4e9;font-size:1rem;font-family:Cinzel,Georgia,serif}.kc-summary-card small{color:#799186;line-height:1.45}.kc-progress-bar-wrap{padding:12px 16px;flex-shrink:0}.kc-progress-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;color:#9eb2a5;font-size:.75rem}.kc-progress-track{width:100%;height:8px;border-radius:999px;background:#ffffff0f;overflow:hidden}.kc-progress-fill{height:100%;background:linear-gradient(90deg,#0fb981,#f0d28f,#0fb981);background-size:180% 100%;animation:kc-shimmer 1.8s linear infinite;transition:width .24s ease}@keyframes kc-shimmer{0%{background-position:180% 0}to{background-position:-180% 0}}.kc-library-layout,.kc-chat-shell{min-height:0;flex:1}.kc-library-layout{display:grid;grid-template-columns:minmax(320px,.78fr) minmax(0,1.22fr);gap:12px;min-height:0}.kc-library-sidebar,.kc-viewer-shell,.kc-chat-shell{display:flex;flex-direction:column;min-height:0}.kc-library-sidebar{gap:12px;padding:14px}.kc-search{display:flex;align-items:center;gap:10px;padding:.8rem .95rem;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#ffffff09;color:#8fa398}.kc-search input,.kc-input{width:100%;min-width:0;border:none;background:transparent;color:#f7f4e9;outline:none}.kc-search input::placeholder,.kc-input::placeholder{color:#62786f}.kc-book-list,.kc-messages{min-height:0;overflow:auto;display:flex;flex-direction:column;gap:10px;padding-right:4px}.kc-book-card{display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:inherit;text-align:left;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease}.kc-book-card:hover{transform:translateY(-1px);border-color:#10b9813d}.kc-book-card.active{border-color:#d4af373d;background:#d4af3714}.kc-book-head,.kc-book-meta,.kc-viewer-head,.kc-source-header{display:flex;gap:10px;align-items:flex-start}.kc-book-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:14px;border:1px solid rgba(212,175,55,.18);background:#d4af3714;color:#f0d28f;flex-shrink:0}.kc-book-copy{min-width:0;flex:1}.kc-book-title,.kc-viewer-title{color:#f7f4e9;font-family:Cinzel,Georgia,serif}.kc-book-source,.kc-book-description,.kc-book-meta,.kc-viewer-copy,.kc-source-text,.kc-msg-text,.kc-retrieval-text{color:#9cb0a5}.kc-book-source{margin-top:2px;font-size:.76rem}.kc-book-description,.kc-viewer-copy,.kc-msg-text,.kc-retrieval-text{line-height:1.6}.kc-book-description{margin:0;font-size:.84rem}.kc-book-meta{flex-wrap:wrap;font-size:.72rem}.kc-book-meta span,.kc-book-badge,.kc-viewer-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .55rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.kc-book-badge{color:#f0d28f}.kc-book-badges{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.kc-book-badge--repo{color:#9ad5bb;border-color:#10b9813d}.kc-viewer-shell,.kc-chat-shell{padding:14px;overflow:visible}.kc-viewer-shell{gap:12px}.kc-viewer-head{justify-content:space-between}.kc-viewer-actions{justify-content:flex-end}.kc-viewer-copy{margin-top:4px;max-width:72ch}.kc-viewer-tags{justify-content:flex-start}.kc-viewer-frame{width:100%;min-height:680px;flex:1;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:#03080beb}.kc-state,.kc-query-empty{display:flex;flex-direction:column;justify-content:center;gap:10px;min-height:220px;padding:18px;border-radius:18px;border:1px dashed rgba(129,161,147,.22);background:#ffffff05;color:#90a59a;line-height:1.55}.kc-state-error{border-color:#ef44443d;color:#f2b0b0}.kc-query-empty{flex-direction:row;align-items:flex-start}.kc-query-empty-mark{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:14px;border:1px solid rgba(212,175,55,.18);background:#d4af3714;color:#f0d28f;flex-shrink:0}.kc-query-empty h4{margin:0;color:#f7f4e9;font-family:Cinzel,Georgia,serif}.kc-query-empty p{margin:6px 0 0;color:#90a59a;max-width:62ch}.kc-chat-shell{gap:12px}.kc-welcome{padding:18px 0;text-align:center}.kc-welcome p{margin:0 0 14px;color:#95a99e}.kc-msg{display:flex;gap:10px;align-items:flex-start}.kc-msg-user{flex-direction:row-reverse}.kc-avatar{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);flex-shrink:0}.kc-avatar-user{background:#d4af3714;border-color:#d4af372e}.kc-msg-body{max-width:min(88%,920px);display:flex;flex-direction:column;gap:8px}.kc-msg-text,.kc-retrieval-result,.kc-source-card,.kc-typing{padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#ffffff09}.kc-msg-user .kc-msg-text{background:#d4af3714;border-color:#d4af3724;color:#f3ebd3}.kc-msg-error .kc-msg-text{border-color:#ef44442e;color:#f2b0b0}.kc-retrieval-label,.kc-source-page,.kc-source-score,.kc-gemini-hint{font-size:.72rem;color:#7f978b}.kc-source-header{flex-wrap:wrap;margin-bottom:8px}.kc-source-book{padding:0;border:none;background:none;color:#f0d28f;cursor:pointer;font-weight:600}.kc-source-book:hover{color:#ffd988}.kc-source-score{margin-left:auto}.kc-sources{display:flex;flex-direction:column;gap:8px}.kc-sources-toggle{padding:0;border:none;background:none;color:#8ea297;cursor:pointer;text-align:left}.kc-typing{display:inline-flex;align-items:center;gap:6px;width:fit-content}.kc-typing span{width:7px;height:7px;border-radius:999px;background:#f0d28f;animation:kc-bounce 1.2s infinite ease-in-out}.kc-typing span:nth-child(2){animation-delay:.16s}.kc-typing span:nth-child(3){animation-delay:.32s}@keyframes kc-bounce{0%,80%,to{transform:scale(.7);opacity:.4}40%{transform:scale(1);opacity:1}}.kc-input-area{display:flex;gap:10px;padding:12px 14px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;flex-shrink:0}.kc-input:disabled{opacity:.55}.kc-send-btn{flex-shrink:0;padding:0 1rem;border-radius:14px;border:1px solid rgba(212,175,55,.28);background:linear-gradient(135deg,#65410aeb,#916314eb);color:#f8e7b8;cursor:pointer}.kc-send-btn:disabled{opacity:.45;cursor:not-allowed}@media (max-width: 1220px){.kc-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.kc-library-layout{grid-template-columns:1fr}.kc-book-list{max-height:340px}}@media (max-width: 880px){.knowledge-chat{padding:12px}.kc-header,.kc-viewer-head,.kc-query-empty{flex-direction:column}.kc-header-actions{width:100%;align-items:stretch}.kc-viewer-frame{min-height:520px}.kc-summary{grid-template-columns:1fr}.kc-book-badges{flex-direction:row;align-items:center;flex-wrap:wrap}}.gm-toolbar{display:flex;align-items:center;gap:.6rem;padding:.4rem .75rem;background:#f59e0b12;border:1px solid rgba(245,158,11,.2);border-radius:8px;margin-bottom:.75rem}.gm-toolbar-label{font-size:.72rem;color:#f59e0b;font-weight:600;letter-spacing:.04em;flex:1}.gm-btn-novo{background:linear-gradient(135deg,#d97706,#b45309);color:#fff;border:none;border-radius:6px;padding:5px 14px;font-size:.8rem;font-weight:600;cursor:pointer;transition:filter .15s}.gm-btn-novo:hover{filter:brightness(1.2)}.gm-item-btns{display:flex;gap:4px;margin-left:auto;opacity:0;transition:opacity .15s;flex-shrink:0}.cp-item:hover .gm-item-btns,.cp-arma-row:hover .gm-item-btns,.cp-feitico-card:hover .gm-item-btns{opacity:1}.gm-ibtn{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:5px;padding:2px 7px;font-size:.75rem;cursor:pointer;line-height:1.5;transition:background .15s}.gm-ibtn.edit:hover{background:#3b82f640;border-color:#3b82f6}.gm-ibtn.delete:hover{background:#ef444440;border-color:#ef4444}.gm-ibtn.delete.confirming{background:#ef444459;border-color:#ef4444;animation:pulse-red .5s ease infinite alternate}@keyframes pulse-red{0%{box-shadow:0 0 #ef444466}to{box-shadow:0 0 0 5px #ef444400}}.gm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gm-modal{background:#0f1625;border:1px solid rgba(245,158,11,.3);border-radius:14px;width:100%;max-width:560px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #000000b3,0 0 40px #f59e0b12;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.gm-modal-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem .75rem;border-bottom:1px solid rgba(255,255,255,.07)}.gm-modal-header h3{margin:0;font-size:1rem;color:#f59e0b;flex:1}.gm-cat-badge{font-size:.7rem;font-weight:600;color:#d97706;background:#d977061f;padding:2px 10px;border-radius:12px;border:1px solid rgba(217,119,6,.25);text-transform:uppercase;letter-spacing:.06em}.gm-close{background:none;border:none;color:#fff6;font-size:1.1rem;cursor:pointer;padding:2px 6px;border-radius:4px;transition:color .15s,background .15s}.gm-close:hover{color:#ef4444;background:#ef44441a}.gm-modal-body{flex:1;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.gm-field{display:flex;flex-direction:column;gap:4px}.gm-label{font-size:.73rem;font-weight:600;color:#ffffff8c;text-transform:uppercase;letter-spacing:.04em}.gm-req{color:#f87171;margin-left:3px}.gm-input{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:7px;color:#e2e8f0;padding:7px 10px;font-size:.85rem;width:100%;box-sizing:border-box;transition:border-color .15s;font-family:inherit}.gm-input:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 2px #f59e0b26}.gm-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.gm-textarea{resize:vertical;min-height:72px}.gm-erro{background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:7px;padding:8px 12px;color:#fca5a5;font-size:.8rem}.gm-modal-footer{display:flex;gap:.6rem;justify-content:flex-end;padding:.75rem 1.25rem 1rem;border-top:1px solid rgba(255,255,255,.07)}.gm-btn{border:none;border-radius:7px;padding:7px 18px;font-size:.85rem;font-weight:600;cursor:pointer;transition:filter .15s,opacity .15s}.gm-btn:disabled{opacity:.5;cursor:not-allowed}.gm-btn.cancel{background:#ffffff12;color:#ffffffb3}.gm-btn.cancel:hover:not(:disabled){background:#ffffff1f}.gm-btn.save{background:linear-gradient(135deg,#d97706,#b45309);color:#fff}.gm-btn.save:hover:not(:disabled){filter:brightness(1.15)}.compendio-panel{display:flex;flex-direction:column;height:100%;overflow:hidden;background:transparent}.cp-header{flex-shrink:0;padding:0 0 12px;border-bottom:1px solid var(--border)}.cp-titulo{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-family:var(--font-title);font-size:1.05rem;color:var(--glow);letter-spacing:.07em;margin-bottom:12px;text-shadow:0 0 12px rgba(0,255,136,.2)}.cp-title-icon{width:18px;height:18px;color:var(--color-gold-bright)}.cp-subtitle{font-size:.72rem;color:var(--color-text-dim);opacity:.8}.cp-gm-chip{margin-left:auto;display:inline-flex;align-items:center;gap:5px;border-radius:999px;border:1px solid rgba(245,158,11,.28);background:#f59e0b1f;color:#f7b955;font-size:.68rem;font-family:var(--font-ui);font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:4px 11px}.cp-tabs{display:flex;flex-wrap:wrap;gap:6px;padding:8px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:linear-gradient(180deg,#ffffff08,#060d1042);overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.cp-tab{position:relative;display:flex;align-items:center;gap:7px;padding:9px 12px;background:#ffffff05;border:1px solid rgba(255,255,255,.07);border-radius:9px;color:var(--color-text-dim);font-family:var(--font-ui);font-size:.68rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);letter-spacing:.08em;text-transform:uppercase;flex-shrink:0}.cp-tab:after{content:"";position:absolute;left:12px;right:12px;bottom:2px;height:2px;border-radius:999px;background:var(--color-gold);opacity:0;transform:scaleX(.45);transition:all var(--transition-fast)}.cp-tab:hover{background:#ffffff0f;border-color:#ffffff29;color:var(--color-text-bright)}.cp-tab.active{background:#d4af3717;border-color:#d4af3759;color:var(--color-gold-bright);box-shadow:inset 0 0 0 1px #d4af3724}.cp-tab.active:after{opacity:1;transform:scaleX(1)}.cp-tab:focus-visible{outline:none;box-shadow:0 0 0 2px #0d737757,0 0 0 1px #0d73778c inset}.cp-tab-icon{width:14px;height:14px;flex-shrink:0}.cp-tab-label{font-size:.68rem;white-space:nowrap}.cp-tab-description{margin:.55rem 0 0;color:var(--color-text-dim);font-size:.7rem;line-height:1.4}.cp-body{flex:1;overflow:hidden;padding:12px 0 0}.cp-split{display:flex;gap:12px;height:100%;overflow:hidden}.cp-list-col{display:flex;flex-direction:column;gap:8px;width:220px;flex-shrink:0;overflow:hidden}.cp-search{width:100%;padding:6px 10px;background:#0000004d;border:1px solid var(--border);border-radius:8px;color:var(--color-text);font-size:.82rem;font-family:var(--font-ui);outline:none;transition:border-color .15s}.cp-search:focus{border-color:var(--glow4)}.cp-search::placeholder{color:var(--color-text-dim)}.cp-global-search{display:flex;gap:.5rem;margin-bottom:.65rem}.cp-search-action{min-height:34px;padding:.45rem .85rem;border:1px solid rgba(13,148,136,.4);border-radius:7px;background:#0d948821;color:var(--color-teal-bright);font-family:var(--font-ui);font-size:.72rem;font-weight:700;cursor:pointer}.cp-search-action:disabled{border-color:#ffffff14;background:#ffffff06;color:var(--color-text-dim);cursor:not-allowed;opacity:.65}.cp-search-action:focus-visible{outline:2px solid rgba(13,148,136,.72);outline-offset:2px}.cp-search-hint{padding:.8rem;border:1px dashed rgba(255,255,255,.12);border-radius:8px;color:var(--color-text-dim);font-size:.72rem;line-height:1.5}.cp-cat-pills{display:flex;flex-wrap:wrap;gap:4px}.cp-pill{padding:3px 8px;border:1px solid rgba(255,255,255,.1);border-radius:20px;background:transparent;color:var(--color-text-dim);font-size:.72rem;font-family:var(--font-ui);cursor:pointer;transition:all .15s;text-transform:capitalize}.cp-pill:hover{border-color:var(--pill-cor, var(--glow4));color:var(--color-text)}.cp-pill.active{background:color-mix(in srgb,var(--pill-cor, var(--glow)) 15%,transparent);border-color:var(--pill-cor, var(--glow4));color:var(--pill-cor, var(--glow))}.cp-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:3px;padding-right:2px}.cp-item{display:flex;align-items:center;gap:7px;padding:7px 10px;background:#ffffff08;border:1px solid transparent;border-radius:8px;color:var(--color-text);cursor:pointer;text-align:left;transition:all .15s}.cp-item:hover{background:#ffffff0f;border-color:#ffffff14}.cp-item.active{background:color-mix(in srgb,var(--item-cor, var(--glow)) 12%,transparent);border-color:var(--item-cor, var(--glow4))}.cp-item-icon{font-size:1rem;flex-shrink:0}.cp-item-nome{font-size:.83rem;font-family:var(--font-ui);flex:1}.cp-item-sub{font-size:.7rem;color:var(--color-text-dim);font-family:var(--font-mono, monospace);flex-shrink:0}.cp-item-sub.san{color:#c06060}.cp-detail{flex:1;overflow-y:auto;padding:14px;background:#0003;border:1px solid color-mix(in srgb,var(--detail-cor, var(--glow4)) 30%,transparent);border-radius:12px;position:relative}.cp-close{position:absolute;top:8px;right:8px;background:#ffffff0d;border:1px solid var(--border);border-radius:6px;color:var(--color-text-dim);padding:2px 8px;cursor:pointer;font-size:.75rem;transition:all .15s}.cp-close:hover{color:var(--color-fail);border-color:var(--color-fail)}.cp-detail-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.cp-detail-nome{font-family:var(--font-title);font-size:1.05rem;color:var(--color-text-bright);letter-spacing:.04em}.cp-detail-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.cp-badge{padding:2px 8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:20px;font-size:.72rem;font-family:var(--font-ui);color:var(--color-text-dim)}.cp-badge.cat{border-color:var(--detail-cor, var(--glow4));color:var(--detail-cor, var(--glow))}.cp-resumo{font-size:.83rem;color:var(--color-text);line-height:1.55;margin-bottom:12px;font-family:var(--font-body);font-style:italic}.cp-mecanica,.cp-ataques{margin-bottom:10px}.cp-mec-row{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:.8rem}.cp-mec-key{color:var(--color-text-dim);font-family:var(--font-ui)}.cp-mec-val{color:var(--color-text-bright);font-family:var(--font-mono, monospace)}.cp-fonte{margin-top:10px;font-size:.75rem;color:var(--color-text-dim);font-style:italic}.cp-san-box{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#c83c3c14;border:1px solid rgba(200,60,60,.2);border-radius:8px;font-size:.82rem;margin-bottom:12px}.cp-san-box strong{color:#e05050;font-family:var(--font-mono, monospace)}.cp-stat-block{margin-bottom:12px}.cp-stat-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--detail-cor, var(--glow4));margin-bottom:6px;font-family:var(--font-ui)}.cp-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:6px}.cp-stat-item{display:flex;flex-direction:column;align-items:center;padding:5px;background:#ffffff0a;border-radius:6px;border:1px solid rgba(255,255,255,.06)}.cp-stat-key{font-size:.65rem;color:var(--color-text-dim);font-family:var(--font-ui)}.cp-stat-val{font-size:.9rem;color:var(--color-text-bright);font-family:var(--font-mono, monospace);font-weight:700}.cp-ataque-row{display:flex;justify-content:space-between;padding:5px 8px;background:#ffffff08;border-radius:6px;font-size:.82rem;margin-bottom:3px}.cp-ataque-row strong{color:var(--color-fail);font-family:var(--font-mono, monospace)}.cp-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.cp-tag{padding:3px 8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;font-size:.72rem;color:var(--color-text-dim)}.cp-tag.skill{border-color:#0f83;color:var(--glow3);text-transform:capitalize}.cp-habilidades{margin-top:10px}.cp-feiticos{display:flex;flex-direction:column;gap:10px;height:100%;overflow:hidden}.cp-filters{flex-shrink:0;display:flex;flex-direction:column;gap:6px}.cp-card-grid{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding-right:2px}.cp-feitico-card{padding:10px 12px;background:#0003;border:1px solid color-mix(in srgb,var(--fc-cor, var(--border)) 30%,var(--border));border-radius:10px;cursor:pointer;transition:all .18s}.cp-feitico-card:hover{background:#ffffff0a}.cp-feitico-card.open{background:color-mix(in srgb,var(--fc-cor, var(--glow4)) 8%,transparent);border-color:var(--fc-cor, var(--glow4))}.cp-fc-header{display:flex;gap:10px;align-items:flex-start}.cp-fc-icon{font-size:1.3rem;flex-shrink:0}.cp-fc-nome{font-family:var(--font-ui);font-weight:500;font-size:.88rem;color:var(--color-text-bright)}.cp-fc-escola{font-size:.72rem;color:var(--fc-cor, var(--color-text-dim));margin-top:2px}.cp-fc-custos{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.cp-custo{padding:2px 7px;border-radius:10px;font-size:.7rem;font-family:var(--font-mono, monospace)}.cp-custo.mp{background:#803cc826;color:#b080e0}.cp-custo.san{background:#c83c3c1f;color:#e08080}.cp-custo.tempo{background:#ffffff0f;color:var(--color-text-dim)}.cp-fc-detail{margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.06)}.cp-efeito{font-size:.82rem;color:var(--color-text);line-height:1.5;margin-top:6px}.cp-armas{display:flex;flex-direction:column;gap:10px;height:100%;overflow:hidden}.cp-armas-table{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.cp-armas-header{display:grid;grid-template-columns:1fr auto auto auto;gap:8px;padding:5px 10px;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim);font-family:var(--font-ui);border-bottom:1px solid var(--border)}.cp-arma-row{display:grid;grid-template-columns:1fr auto auto auto;gap:8px;padding:7px 10px;background:#ffffff05;border-radius:6px;align-items:center;border-left:2px solid var(--arma-cor, transparent);font-size:.82rem;transition:background .12s}.cp-arma-row:hover{background:#ffffff0d}.cp-arma-nome{display:flex;align-items:center;gap:7px;color:var(--color-text)}.cp-arma-icon{font-size:1rem}.cp-arma-dano{font-family:var(--font-mono, monospace);color:var(--color-fail);font-weight:600;text-align:right}.cp-arma-alcance,.cp-arma-tiros{color:var(--color-text-dim);font-size:.75rem;text-align:right}.cp-state{padding:14px;text-align:center;font-size:.82rem;border-radius:8px}.cp-loading{color:var(--glow3);background:#00ff880d}.cp-erro{color:var(--color-fail);background:#f871710d}.cp-vazio{color:var(--color-text-dim);background:#ffffff05}@media (max-width: 900px){.cp-tabs{flex-wrap:nowrap;overflow-x:auto}.cp-tab{min-width:132px;justify-content:flex-start}.cp-gm-chip{margin-left:0}}.spell-library{display:flex;flex-direction:column;gap:1rem;height:100%;color:var(--color-text)}.sl-head,.sl-toolbar,.sl-list,.sl-viewer-shell,.sl-state{border:1px solid rgba(255,255,255,.08);border-radius:24px;background:radial-gradient(circle at top right,rgba(212,175,55,.08),transparent 28%),linear-gradient(180deg,#0b171cf2,#071015f5);box-shadow:inset 0 1px #ffffff0a}.sl-head,.sl-toolbar,.sl-list,.sl-viewer-shell,.sl-state{padding:1rem 1.1rem}.sl-kicker,.sl-viewer-chip{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-title)}.sl-kicker{color:var(--color-gold)}.sl-title{margin:.2rem 0 0;color:var(--color-text-bright);font-family:var(--font-title)}.sl-subtitle{margin:.55rem 0 0;color:var(--color-text-dim);line-height:1.6;max-width:60ch}.sl-toolbar{display:flex;flex-direction:column;gap:.8rem}.sl-search{display:flex;align-items:center;gap:.6rem;padding:.82rem .9rem;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#ffffff09;color:var(--color-text-dim)}.sl-search input{width:100%;min-width:0;border:none;background:transparent;color:var(--color-text-bright);outline:none}.sl-type-filters{display:flex;flex-wrap:wrap;gap:.5rem}.sl-type-btn,.sl-viewer-chip{padding:.42rem .7rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text-dim);cursor:pointer}.sl-type-btn.active{color:var(--color-gold-bright);border-color:#d4af3747;background:#d4af3714}.sl-layout{display:grid;grid-template-columns:minmax(300px,.78fr) minmax(0,1.22fr);gap:1rem;min-height:720px}.sl-list,.sl-viewer-shell{display:flex;flex-direction:column;gap:.8rem;min-height:0}.sl-list{overflow:auto}.sl-card{display:flex;flex-direction:column;gap:.55rem;padding:.9rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:inherit;text-align:left;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease}.sl-card:hover{transform:translateY(-1px);border-color:#10b98138}.sl-card.active{border-color:#d4af373d;background:#d4af3714}.sl-card-header,.sl-card-meta,.sl-viewer-head,.sl-viewer-tags{display:flex;justify-content:space-between;gap:.7rem;align-items:flex-start}.sl-card-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:14px;border:1px solid rgba(212,175,55,.18);background:#d4af3714;color:var(--color-gold-bright)}.sl-card-info{min-width:0;flex:1}.sl-card-name,.sl-viewer-title{color:var(--color-text-bright);font-family:var(--font-title)}.sl-card-en,.sl-card-desc,.sl-card-meta,.sl-viewer-copy{color:var(--color-text-dim)}.sl-card-en{font-size:.76rem;margin-top:.12rem}.sl-card-desc{margin:0;font-size:.82rem;line-height:1.55}.sl-card-meta{flex-wrap:wrap;justify-content:flex-start;font-size:.72rem}.sl-card-meta span,.sl-rare-badge{display:inline-flex;align-items:center;gap:.32rem;padding:.26rem .5rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.sl-rare-badge{color:var(--color-gold-bright)}.sl-viewer-shell{overflow:hidden}.sl-viewer-head{align-items:center}.sl-viewer-copy{margin-top:.25rem;line-height:1.55}.sl-viewer-tags{flex-wrap:wrap;justify-content:flex-start}.sl-viewer-chip{color:var(--color-text-dim)}.sl-viewer-frame{flex:1;min-height:620px;width:100%;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:#03080beb}.sl-state{color:var(--color-text-dim);line-height:1.55}.sl-state--error{border-color:#ef444438;background:#ef444414;color:#ffb7b7}@media (max-width: 1024px){.sl-layout{grid-template-columns:1fr;min-height:0}.sl-list{max-height:360px}}@media (max-width: 720px){.sl-card-header,.sl-viewer-head{flex-direction:column;align-items:stretch}.sl-viewer-frame{min-height:480px}}.rules-panel{display:flex;flex-direction:column;height:100%;min-height:0;gap:.75rem}.rp-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.2rem .15rem 0}.rp-heading{min-width:0}.rp-eyebrow{display:block;margin-bottom:.2rem;color:var(--color-teal-bright);font-family:var(--font-ui);font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.rp-heading h2{margin:0;color:var(--color-text-bright);font-family:var(--font-title);font-size:1rem;letter-spacing:0}.rp-heading p{margin:.3rem 0 0;color:var(--color-text-dim);font-size:.74rem;line-height:1.45}.rp-tabs-wrap{min-width:0}.rp-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem}.rp-tab-btn{position:relative;display:flex;align-items:flex-start;gap:.65rem;min-width:0;min-height:68px;padding:.75rem;border:1px solid rgba(255,255,255,.09);border-radius:8px;background:#ffffff06;color:var(--color-text-dim);text-align:left;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast),color var(--transition-fast)}.rp-tab-btn:hover:not(.active){border-color:#ffffff2e;background:#ffffff0d;color:var(--color-text-bright)}.rp-tab-btn.active{border-color:#d4af3766;background:#d4af3717;color:var(--color-gold-bright);box-shadow:inset 3px 0 #d4af37ad}.rp-tab-btn:focus-visible{outline:2px solid rgba(13,148,136,.72);outline-offset:2px}.rp-tab-icon{width:17px;height:17px;flex-shrink:0;margin-top:.08rem}.rp-tab-copy{display:flex;flex-direction:column;gap:.22rem;min-width:0}.rp-tab-copy strong{color:currentColor;font-family:var(--font-ui);font-size:.72rem;font-weight:700;line-height:1.25}.rp-tab-copy small{display:-webkit-box;overflow:hidden;color:var(--color-text-dim);font-size:.62rem;line-height:1.35;-webkit-box-orient:vertical;-webkit-line-clamp:2}.rp-gm-chip{display:inline-flex;align-items:center;gap:.35rem;flex-shrink:0;padding:.35rem .6rem;border:1px solid rgba(245,158,11,.28);border-radius:999px;background:#f59e0b1a;color:#f7b955;font-size:.63rem;font-weight:700}.rp-rules-help{border:1px solid rgba(13,148,136,.2);border-radius:8px;background:#0d94880e}.rp-rules-help summary{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;color:var(--color-text-dim);font-size:.68rem;line-height:1.4;cursor:pointer;list-style:none}.rp-rules-help summary::-webkit-details-marker{display:none}.rp-rules-help summary svg{flex-shrink:0;color:var(--color-teal-bright)}.rp-rules-help summary strong{color:var(--color-text-bright)}.rp-rules-help-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem;padding:0 .75rem .75rem 2.1rem}.rp-rules-help-grid span{display:flex;flex-direction:column;gap:.15rem;padding-left:.55rem;border-left:2px solid rgba(13,148,136,.34);color:var(--color-text-dim);font-size:.62rem;line-height:1.35}.rp-rules-help-grid strong{color:var(--color-text-bright);font-size:.66rem}.rp-content{flex:1;overflow:hidden;min-height:0}@media (max-width: 980px){.rp-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 620px){.rp-header{flex-direction:column}.rp-tabs,.rp-rules-help-grid{grid-template-columns:1fr}.rp-tab-btn{min-height:58px}.rp-rules-help-grid{padding-left:.75rem}}.ship-panel{padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem;position:relative;overflow:hidden}.ship-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-gold-dim),transparent)}.ship-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.ship-stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-family:var(--font-ui);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim)}.stat-value-row{display:flex;align-items:baseline;gap:.25rem}.stat-num{font-family:var(--font-mono);font-size:1.25rem;font-weight:600}.stat-max{font-size:.8rem;opacity:.6}.stat-unit{font-size:.7rem;color:var(--color-text-dim);text-transform:lowercase}.stat-bar-bg{height:3px;background:#0000004d;border-radius:1px;overflow:hidden}.stat-bar-fill{height:100%;transition:width var(--transition-slow)}.ship-actions{margin-top:.5rem;padding-top:1rem;border-top:1px dashed var(--color-border)}.ship-edit-form{display:flex;flex-direction:column;gap:.75rem}.form-group-row{display:flex;gap:.75rem}.edit-input-group{flex:1;display:flex;flex-direction:column;gap:.2rem}.edit-input-group label{font-size:.65rem}.edit-input-group input{padding:.35rem .5rem;font-size:.9rem;font-family:var(--font-mono)}.ship-edit-btns{display:flex;gap:.5rem;margin-top:.25rem}.ship-edit-btns .btn{flex:1}.ship-loading,.ship-empty{padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:1rem;min-height:420px}.ship-empty-copy{max-width:520px;display:grid;gap:.45rem}.ship-empty-copy h3{margin:0;font-family:var(--font-title);color:var(--color-text-bright);letter-spacing:.04em}.ship-kicker{font-family:var(--font-ui);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-gold)}.ship-create-form{width:min(560px,100%);display:grid;gap:.9rem;padding:1rem;border:1px solid rgba(201,164,74,.18);border-radius:var(--radius-md);background:#0a14109e;box-shadow:inset 0 1px #ffffff09}.ship-create-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.6rem}.ship-field{display:grid;gap:.3rem;text-align:left}.ship-field-wide{grid-column:1 / -1}.ship-field span{font-family:var(--font-ui);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-dim)}.ship-field input{width:100%;min-width:0;padding:.55rem .65rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#0000003d;color:var(--color-text);font-family:var(--font-mono)}.ship-field input:focus-visible{outline:none;border-color:#00ff8873;box-shadow:0 0 0 2px #00ff8829}.ship-error{width:min(560px,100%);padding:.65rem .8rem;border:1px solid rgba(239,68,68,.28);border-radius:var(--radius-sm);background:#ef444414;color:var(--color-fail);font-size:.78rem;text-align:left}.ship-empty-note{max-width:420px;color:var(--color-text-dim)}.btn-sm{padding:.4rem .8rem;font-size:.8rem}@media (max-width: 780px){.ship-empty{align-items:stretch;padding:1rem;min-height:360px}.ship-create-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.soundtracks-root{display:flex;flex-direction:column;gap:12px;min-height:100%;padding:18px;color:#dce9df;background:radial-gradient(circle at top right,rgba(212,175,55,.08),transparent 25%),radial-gradient(circle at left center,rgba(16,185,129,.06),transparent 28%),linear-gradient(180deg,#041214f5,#020c0efa);border-radius:24px;border:1px solid rgba(72,115,96,.28);box-shadow:inset 0 1px #ffffff0a,0 18px 50px #00000038}.soundtracks-header,.soundtracks-card{border:1px solid rgba(100,132,117,.18);background:linear-gradient(180deg,#08191cf0,#051214f5),#ffffff05;border-radius:20px;box-shadow:inset 0 1px #ffffff08}.soundtracks-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px}.soundtracks-kicker{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:#f0d28f}.soundtracks-header h3{margin:.2rem 0 0;color:#f7f4e9;font-size:1.45rem;font-family:Cinzel,Georgia,serif}.soundtracks-header p{margin:.45rem 0 0;max-width:62ch;color:#8fa398;line-height:1.6;font-size:.92rem}.soundtracks-status{display:flex;flex-direction:column;align-items:flex-end;gap:10px;max-width:320px}.soundtracks-pill,.soundtracks-template-tags span{display:inline-flex;align-items:center;justify-content:center;padding:.38rem .72rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#a9beb2;font-size:.74rem}.soundtracks-pill.is-ready{color:#f0d28f;border-color:#d4af3747;background:#d4af3714}.soundtracks-helper{color:#7f978b;font-size:.78rem;line-height:1.5;text-align:right}.soundtracks-layout{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr);gap:12px;min-height:0;align-items:start}.soundtracks-column{display:flex;flex-direction:column;gap:12px;min-width:0}.soundtracks-card{display:flex;flex-direction:column;gap:14px;padding:16px;min-width:0}.soundtracks-card--full{grid-column:1 / -1}.soundtracks-card-head,.soundtracks-card-title,.soundtracks-current-meta,.soundtracks-result,.soundtracks-result-actions,.soundtracks-card-actions{display:flex;gap:10px}.soundtracks-card-head{align-items:flex-start;justify-content:space-between}.soundtracks-card-title{align-items:flex-start;color:#f7f4e9}.soundtracks-card-title strong{display:block;color:#f7f4e9;font-family:Cinzel,Georgia,serif}.soundtracks-card-title span{display:block;margin-top:2px;color:#8fa398;line-height:1.5;font-size:.82rem}.soundtracks-link-btn,.soundtracks-btn,.soundtracks-sfx-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:#a9beb2;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease,color .16s ease}.soundtracks-account-strip{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:18px;border:1px solid rgba(255,255,255,.06);background:#ffffff06}.soundtracks-avatar,.soundtracks-result-cover img,.soundtracks-cover img{overflow:hidden}.soundtracks-avatar{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#f0d28f;flex-shrink:0}.soundtracks-avatar img,.soundtracks-result-cover img,.soundtracks-cover img{width:100%;height:100%;object-fit:cover}.soundtracks-account-copy{display:flex;min-width:0;flex-direction:column;gap:2px}.soundtracks-account-copy strong{color:#f7f4e9;font-family:Cinzel,Georgia,serif}.soundtracks-account-copy span{color:#9eb2a5;line-height:1.5}.soundtracks-link-btn:hover,.soundtracks-btn:hover,.soundtracks-sfx-btn:hover{transform:translateY(-1px);border-color:#10b9813d}.soundtracks-link-btn,.soundtracks-btn{padding:.58rem .92rem;font-size:.78rem;font-weight:600}.soundtracks-btn--primary{color:#f8e7b8;border-color:#d4af3759;background:linear-gradient(135deg,#65410aeb,#916314eb)}.soundtracks-btn--ghost{color:#b6c9be}.soundtracks-btn--danger{color:#f5c1c1;border-color:#ef444438;background:#ef444414}.soundtracks-btn:disabled,.soundtracks-link-btn:disabled,.soundtracks-sfx-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.soundtracks-current-body{display:flex;flex-direction:column;gap:14px;padding:18px;border-radius:18px;border:1px solid rgba(255,255,255,.06);background:linear-gradient(135deg,color-mix(in srgb,var(--template-accent, rgba(27, 57, 72, .8)) 44%,rgba(10,16,19,.96)),#050f12f5),#ffffff08}.soundtracks-embed{width:100%;min-height:352px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:#040a0ceb}.soundtracks-current-meta{align-items:center}.soundtracks-cover,.soundtracks-result-cover{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff0d;color:#f0d28f}.soundtracks-cover{width:72px;height:72px}.soundtracks-result-cover{width:46px;height:46px}.soundtracks-cover--template,.soundtracks-result-cover--template{background:radial-gradient(circle at top left,rgba(255,255,255,.08),transparent 42%),color-mix(in srgb,var(--template-accent, rgba(27, 57, 72, .8)) 62%,rgba(9,17,19,.98))}.soundtracks-current-title{color:#f7f4e9;font-family:Cinzel,Georgia,serif;font-size:1.18rem}.soundtracks-current-subtitle,.soundtracks-template-note span,.soundtracks-result-copy span,.soundtracks-empty p{color:#b3c1ba;line-height:1.6}.soundtracks-current-type,.soundtracks-result-copy small{color:#f0d28f;text-transform:uppercase;letter-spacing:.08em;font-size:.68rem}.soundtracks-template-note{display:flex;flex-direction:column;gap:4px}.soundtracks-form{display:flex;flex-direction:column;gap:12px}.soundtracks-field{display:flex;flex-direction:column;gap:6px}.soundtracks-field span{color:#9eb2a5;font-size:.74rem;letter-spacing:.04em;text-transform:uppercase}.soundtracks-input{width:100%;min-width:0;padding:.85rem .95rem;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#ffffff09;color:#f7f4e9;outline:none;font:inherit;transition:border-color .16s ease,background .16s ease}.soundtracks-input:focus{border-color:#10b98142;background:#ffffff0d}.soundtracks-input::placeholder{color:#62786f}.soundtracks-input--multiline{min-height:104px;resize:vertical}.soundtracks-template-note strong,.soundtracks-empty strong,.soundtracks-result-copy strong{color:#f7f4e9}.soundtracks-template-strip{display:flex;flex-wrap:wrap;gap:8px}.soundtracks-template-chip{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:.55rem .9rem;border-radius:999px;border:1px solid rgba(212,175,55,.18);background:#d4af370f;color:#f2dfb0;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease}.soundtracks-template-chip:hover{transform:translateY(-1px);border-color:#d4af375c;background:#d4af371a}.soundtracks-template-tags{display:flex;flex-wrap:wrap;gap:8px}.soundtracks-library-list{display:flex;flex-direction:column;gap:10px;max-height:540px;overflow:auto;padding-right:4px}.soundtracks-library-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff06}.soundtracks-library-item.is-active{border-color:#d4af3742;box-shadow:inset 0 0 0 1px #d4af3714}.soundtracks-library-copy{display:flex;min-width:0;flex:1;flex-direction:column;gap:2px}.soundtracks-library-copy strong{color:#f7f4e9}.soundtracks-library-copy span{color:#aebfb8;line-height:1.5}.soundtracks-library-copy small{color:#f0d28f;text-transform:uppercase;letter-spacing:.08em;font-size:.68rem}.soundtracks-library-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.soundtracks-results{display:flex;flex-direction:column;gap:10px}.soundtracks-result{align-items:center;padding:12px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(135deg,color-mix(in srgb,var(--template-accent, rgba(27, 57, 72, .8)) 20%,rgba(10,16,19,.98)),#050f12f5),#ffffff05}.soundtracks-result.is-active{border-color:#d4af3747;box-shadow:inset 0 0 0 1px #d4af3714}.soundtracks-result-copy{display:flex;flex:1;min-width:0;flex-direction:column;gap:2px}.soundtracks-result-actions{align-items:center;flex-wrap:wrap;justify-content:flex-end}.soundtracks-empty{display:flex;align-items:flex-start;gap:12px;padding:14px;border-radius:16px;border:1px dashed rgba(255,255,255,.1);background:#ffffff06;color:#9eb2a5}.soundtracks-empty--compact{padding:12px}.soundtracks-setup{display:flex;flex-direction:column;gap:8px;padding:14px 16px;border-radius:18px;border:1px solid rgba(212,175,55,.18);background:#d4af370f;color:#e9dcc0}.soundtracks-setup strong{color:#f7f4e9;font-family:Cinzel,Georgia,serif}.soundtracks-setup p{margin:0;color:#c2cdbf;line-height:1.6}.soundtracks-setup code{display:inline-flex;align-items:center;width:fit-content;max-width:100%;padding:.48rem .72rem;border-radius:12px;background:#040c0eb8;color:#f0d28f;font-size:.78rem;word-break:break-all}.soundtracks-error{padding:.85rem 1rem;border-radius:16px;border:1px solid rgba(239,68,68,.18);background:#681f1f2e;color:#ffd6d6}.soundtracks-sfx-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.soundtrack-collapsible{gap:0}.soundtracks-collapse-head{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;list-style:none}.soundtracks-collapse-head::-webkit-details-marker{display:none}.soundtracks-collapse-label{color:#9eb2a5;font-size:.78rem}.soundtracks-sfx-pad{display:flex;flex-direction:column;gap:10px;padding:12px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,color-mix(in srgb,var(--pad-color, rgba(18, 29, 33, .9)) 72%,rgba(8,14,16,.95)),#050c0ef5),#ffffff05}.soundtracks-sfx-pad.is-active{border-color:#10b98147;box-shadow:inset 0 0 0 1px #10b98114}.soundtracks-sfx-pad.is-readonly{opacity:.72}.soundtracks-sfx-btn{width:100%;padding:.62rem .72rem;justify-content:space-between;font-family:Cinzel,Georgia,serif;font-size:.82rem}.soundtracks-sfx-dot{display:inline-block;width:8px;height:8px;background:#10b981;border-radius:50%;box-shadow:0 0 12px #10b981cc;animation:soundtracks-pulse 1s ease-in-out infinite}@keyframes soundtracks-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.75)}}.soundtracks-sfx-pad input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;border-radius:999px;background:#ffffff1f;outline:none}.soundtracks-sfx-pad input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#f0d28f;border:1px solid rgba(0,0,0,.18)}.soundtracks-sfx-pad input[type=range]::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#f0d28f;border:1px solid rgba(0,0,0,.18)}@media (max-width: 1180px){.soundtracks-layout{grid-template-columns:1fr}.soundtracks-card--full{grid-column:auto}}@media (max-width: 720px){.soundtracks-root{padding:14px}.soundtracks-header{flex-direction:column}.soundtracks-status{align-items:flex-start;max-width:none}.soundtracks-helper{text-align:left}.soundtracks-sfx-grid{grid-template-columns:1fr}.soundtracks-library-item{flex-direction:column;align-items:stretch}.soundtracks-library-actions{justify-content:flex-start}.soundtracks-result{flex-direction:column;align-items:stretch}.soundtracks-result-actions{justify-content:flex-start}}.market-panel{display:flex;flex-direction:column;gap:1rem;padding:1rem}.market-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--color-border);padding-bottom:.5rem}.port-add-form{display:flex;flex-direction:column;gap:.5rem;padding:1rem}.port-selector{display:flex;flex-direction:column;gap:.4rem}.port-selector label{font-size:.75rem;color:var(--color-text-dim);text-transform:uppercase}.market-inventory{flex:1}.market-list{display:flex;flex-direction:column;gap:.75rem}.section-subtitle{font-size:.75rem;color:var(--color-gold);text-transform:uppercase;font-weight:700;margin-bottom:.25rem}.market-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:background var(--transition-fast)}.market-row:hover{background:var(--color-raised)}.market-item-info{display:flex;flex-direction:column}.m-item-name{font-size:.95rem;font-weight:600;color:var(--color-text-bright)}.m-item-meta{font-size:.7rem;color:var(--color-text-dim)}.market-price{display:flex;align-items:center;gap:.75rem}.price-tag{font-family:var(--font-mono);color:var(--color-gold);font-weight:700}.btn-edit-sm{background:none;border:none;color:var(--color-text-dim);cursor:pointer;font-size:.8rem}.market-loading{padding:2rem;text-align:center}.scene-controls{position:absolute;right:14px;bottom:52px;z-index:38;width:min(390px,calc(100% - 28px));max-height:min(720px,calc(100% - 76px));overflow-y:auto;border:1px solid rgba(148,163,184,.28);border-radius:8px;background:#0b111c;box-shadow:0 18px 48px #0000006b;color:var(--color-text-bright)}.scene-controls__header{position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.8rem .9rem;border-bottom:1px solid rgba(148,163,184,.2);background:#0b111c}.scene-controls__header>div{display:grid;gap:.12rem}.scene-controls__header span{color:var(--color-text-dim);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.scene-controls__header strong{font-size:.92rem}.scene-controls__icon{display:grid;place-items:center;width:34px;height:34px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--color-text-dim);cursor:pointer}.scene-controls__icon:hover,.scene-controls__icon:focus-visible{border-color:#94a3b84d;color:var(--color-text-bright);outline:2px solid rgba(6,182,212,.35);outline-offset:1px}.scene-controls__section{display:grid;gap:.72rem;margin:0;padding:.82rem .9rem;border:0;border-bottom:1px solid rgba(148,163,184,.16)}.scene-controls__section:last-child{border-bottom:0}.scene-controls__section legend,.scene-controls__section h3{display:flex;align-items:center;gap:.42rem;width:100%;margin:0;padding:0;color:#d7e3ef;font-size:.77rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase}.scene-controls__section legend span{margin-left:auto;color:var(--color-text-dim);font-size:.63rem;font-weight:500}.scene-controls__section:disabled{opacity:.64}.scene-controls__split,.scene-controls__viewport-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}.scene-controls__viewport-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.scene-controls__field,.scene-controls__range{display:grid;gap:.34rem;min-width:0}.scene-controls__field>span:first-child,.scene-controls__range>span:first-child{display:flex;align-items:center;justify-content:space-between;gap:.5rem;color:var(--color-text-dim);font-size:.71rem}.scene-controls__range output{color:#bae6fd;font-family:var(--font-mono)}.scene-controls__field>input,.scene-controls__number,.scene-controls__color-value{min-height:34px;border:1px solid rgba(148,163,184,.24);border-radius:6px;background:#070c14;color:var(--color-text-bright)}.scene-controls__field>input{width:100%;padding:.42rem .55rem;font-family:var(--font-mono);font-size:.75rem}.scene-controls__number,.scene-controls__color-value{display:flex;align-items:center}.scene-controls__number input{width:100%;min-width:0;padding:.42rem .2rem .42rem .5rem;border:0;outline:0;background:transparent;color:inherit;font-family:var(--font-mono);font-size:.74rem}.scene-controls__number>span{padding-right:.5rem;color:var(--color-text-dim);font-size:.68rem}.scene-controls__color-value{gap:.48rem;padding:.28rem .42rem}.scene-controls__color-value input{width:28px;height:24px;padding:0;border:0;border-radius:4px;background:transparent;cursor:pointer}.scene-controls__color-value code{color:var(--color-text-dim);font-size:.7rem}.scene-controls__range input{width:100%;accent-color:var(--color-cyan)}.scene-controls__segmented{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:2px;padding:3px;border:1px solid rgba(148,163,184,.22);border-radius:7px;background:#070c14}.scene-controls__segmented button{min-height:30px;padding:.3rem .42rem;border:0;border-radius:4px;background:transparent;color:var(--color-text-dim);cursor:pointer;font-size:.69rem}.scene-controls__segmented button:hover,.scene-controls__segmented button:focus-visible{color:var(--color-text-bright);outline:2px solid rgba(6,182,212,.35);outline-offset:-1px}.scene-controls__segmented button.is-active{background:#164e63;color:#ecfeff}.scene-controls__toggle{display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-height:34px;color:var(--color-text-dim);font-size:.72rem}.scene-controls__toggle>span{display:flex;align-items:center;gap:.42rem}.scene-controls__toggle input{width:34px;height:18px;accent-color:var(--color-cyan)}.scene-controls__action{display:flex;align-items:center;gap:.48rem;width:100%;min-height:36px;padding:.45rem .58rem;border:1px solid rgba(148,163,184,.24);border-radius:6px;background:#111a28;color:var(--color-text-bright);cursor:pointer;font-size:.72rem;text-align:left}.scene-controls__action:hover,.scene-controls__action:focus-visible{border-color:#06b6d4a3;outline:2px solid rgba(6,182,212,.25);outline-offset:1px}.scene-controls__action--primary{border-color:#0e7490;background:#164e63;color:#ecfeff}.scene-controls__action kbd{margin-left:auto;color:var(--color-text-dim);font-family:var(--font-mono);font-size:.62rem;font-weight:400}@media (max-width: 760px){.scene-controls{right:10px;bottom:88px;left:10px;width:auto;max-height:calc(100% - 150px)}.scene-controls__viewport-grid{grid-template-columns:repeat(3,minmax(78px,1fr));overflow-x:auto}}@media (prefers-reduced-motion: reduce){.scene-controls *{scroll-behavior:auto}}.hex-map-container{position:relative;display:flex;flex-direction:column;height:100%;min-height:520px;overflow:hidden;background:radial-gradient(circle at 20% 12%,rgba(20,184,166,.11),transparent 32%),radial-gradient(circle at 80% 18%,rgba(148,163,184,.08),transparent 34%),#050810;color:var(--color-text)}.hex-hidden-input{display:none}.hex-map-toolbar{position:relative;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.68rem .85rem;border-bottom:1px solid rgba(148,163,184,.18);background:#050810e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hex-map-title{display:grid;gap:.1rem;min-width:0}.hex-map-title strong{color:var(--color-text-bright);font-size:.98rem;line-height:1.1}.hex-map-kicker{color:var(--color-text-dim);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.hex-map-toolbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:.45rem;flex-wrap:wrap}.hex-upload-button,.hex-tool-button{min-height:34px;padding:.38rem .72rem;font-size:.8rem;cursor:pointer}.hex-tool-button.is-active{border-color:var(--color-cyan);color:var(--color-cyan);box-shadow:0 0 0 1px #06b6d42e}.hex-icon-button{display:grid;place-items:center;width:34px;height:34px;border:1px solid rgba(148,163,184,.26);border-radius:var(--radius-sm);background:#0f172adb;color:var(--color-text-bright);cursor:pointer}.hex-icon-button:hover,.hex-icon-button:focus-visible,.hex-tool-button:focus-visible,.hex-upload-button:focus-visible{outline:2px solid rgba(6,182,212,.35);outline-offset:2px}.hex-zoom-readout{min-width:42px;color:var(--color-text-dim);font-family:var(--font-mono);font-size:.75rem;text-align:center}.hex-map-viewport{position:relative;flex:1;overflow:hidden;cursor:grab;background:linear-gradient(rgba(148,163,184,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.04) 1px,transparent 1px),#050810;background-size:48px 48px;touch-action:none}.hex-map-viewport:active{cursor:grabbing}.hex-map-viewport.tool-select,.hex-map-viewport.tool-text{cursor:crosshair}.hex-map-viewport.tool-fog,.hex-map-viewport.tool-draw{cursor:cell}.hex-map-viewport.tool-measure{cursor:crosshair}.hex-scene{position:absolute;top:0;left:0;overflow:hidden;transform-origin:0 0;border:1px solid rgba(148,163,184,.2);border-radius:6px;background:radial-gradient(circle at center,#0f172aeb,#020617f5),#020617;box-shadow:0 22px 80px #0000006b;-webkit-user-select:none;user-select:none}.hex-map-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;background:#020617}.hex-map-empty-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-content:center;gap:.35rem;padding:1rem;text-align:center;background:radial-gradient(circle at center,rgba(14,116,144,.2),transparent 38%),repeating-linear-gradient(45deg,rgba(148,163,184,.06) 0 1px,transparent 1px 18px),#07111d}.hex-map-empty-backdrop strong{color:var(--color-text-bright);font-size:1.05rem}.hex-map-empty-backdrop span{color:var(--color-text-dim);font-size:.86rem}.hex-grid-layer,.hex-token-layer,.hex-fog-layer,.hex-drawing-layer,.hex-measure-layer,.hex-text-layer{position:absolute;top:0;right:0;bottom:0;left:0}.hex-grid-layer{z-index:6;pointer-events:all}.hex-grid-layer.is-passive,.hex-grid-layer.is-passive .hex-cell{pointer-events:none}.hex-fog-layer{z-index:2;pointer-events:none}.hex-drawing-layer{z-index:4;filter:drop-shadow(0 2px 2px rgba(0,0,0,.42));pointer-events:none}.hex-measure-layer{z-index:8;pointer-events:none}.hex-measure-item line{stroke:#facc15f5;stroke-width:3;stroke-dasharray:8 5;filter:drop-shadow(0 2px 2px rgba(0,0,0,.5))}.hex-measure-item circle{fill:#facc15;stroke:#050810e6;stroke-width:3}.hex-measure-item text{fill:var(--color-text-bright);font-family:var(--font-mono);font-size:16px;font-weight:800;paint-order:stroke;stroke:#050810f0;stroke-width:5px;text-anchor:middle}.hex-text-layer{z-index:9;pointer-events:none}.hex-map-text{position:absolute;max-width:260px;border:1px solid rgba(250,204,21,.3);border-radius:7px;background:#050810c7;box-shadow:0 6px 18px #00000057;color:#facc15;font-family:var(--font-mono);font-weight:800;line-height:1.2;padding:.18rem .35rem;pointer-events:all;text-align:left;transform:translate(-50%,-50%);white-space:normal}button.hex-map-text{cursor:pointer}.hex-map-text:hover,.hex-map-text:focus-visible{border-color:#facc15b8;outline:2px solid rgba(250,204,21,.24);outline-offset:2px}.hex-grid-layer.grid-solid .hex-cell-poly{stroke-dasharray:none}.hex-grid-layer.grid-dashed .hex-cell-poly{stroke-dasharray:8 5}.hex-grid-layer.grid-dotted .hex-cell-poly{stroke-dasharray:2 6;stroke-linecap:round}.hex-token-layer{pointer-events:none;z-index:12}.hex-cell{cursor:pointer}.hex-cell-poly{stroke:var(--hex-grid-color, rgba(226, 232, 240, .38));stroke-width:var(--hex-grid-width, 1);transition:fill .14s ease,stroke .14s ease,stroke-width .14s ease}.hex-cell.is-grid-only .hex-cell-poly{stroke:var(--hex-grid-color, rgba(125, 211, 252, .2))}.hex-cell.has-tile .hex-cell-poly{stroke:var(--hex-grid-color, rgba(45, 212, 191, .54))}.hex-cell:hover .hex-cell-poly{stroke:#facc15e6;stroke-width:2}.hex-cell.is-hidden .hex-cell-poly{fill:#050810b3}.hex-cell-label{fill:#f1f5f9d1;font-family:var(--font-mono);font-size:12px;font-weight:700;text-anchor:middle;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.7)}.hex-hidden-dot{fill:var(--color-fumble);opacity:.74;pointer-events:none}.hex-token{position:absolute;z-index:12;display:grid;justify-items:center;transform:translate(-50%,-50%);pointer-events:all;cursor:grab;touch-action:none}.hex-token:active{cursor:grabbing}.hex-token.is-hidden-token{opacity:.52;filter:grayscale(.8)}.hex-token.is-selected .hex-token-avatar,.hex-token.is-selected .hex-token-image{border-color:#c4b5fdf2;box-shadow:0 0 0 3px #080d14b8,0 0 0 5px #c4b5fd47,0 14px 30px #00000061}.hex-token.is-locked .hex-token-avatar,.hex-token.is-locked .hex-token-image{border-style:dashed}.hex-token-avatar,.hex-token-image{display:grid;place-items:center;width:48px;height:48px;border:2px solid rgba(34,211,238,.9);border-radius:50%;background:radial-gradient(circle at 35% 28%,rgba(255,255,255,.18),transparent 35%),#0e74909e;color:var(--color-text-bright);font-family:var(--font-mono);font-size:.74rem;font-weight:800;box-shadow:0 0 0 3px #080d14b8,0 10px 24px #00000057,0 0 22px #22d3ee3d}.hex-token-image{object-fit:cover}.hex-token-label{max-width:120px;margin-top:.25rem;padding:.12rem .4rem;overflow:hidden;border:1px solid rgba(148,163,184,.18);border-radius:999px;background:#050810d1;color:var(--color-text-bright);font-family:var(--font-mono);font-size:.64rem;text-overflow:ellipsis;white-space:nowrap}.hex-token-actions{position:absolute;top:calc(100% + 9px);left:50%;display:flex;gap:.35rem;opacity:0;pointer-events:none;transform:translate(-50%,-4px);transition:opacity .13s ease,transform .13s ease}.hex-token.is-selected .hex-token-actions,.hex-token:hover .hex-token-actions,.hex-token:focus-within .hex-token-actions{opacity:1;pointer-events:auto;transform:translate(-50%)}.hex-token-action{display:inline-grid;place-items:center;border:1px solid rgba(148,163,184,.26);border-radius:var(--radius-sm);background:#050810eb;color:var(--color-text-bright);cursor:pointer;font-size:.66rem;padding:.24rem .44rem;white-space:nowrap}.hex-token-action.icon{width:32px;height:32px;padding:0}.hex-token-action:hover,.hex-token-action:focus-visible{border-color:var(--color-cyan);color:var(--color-cyan);outline:none}.hex-token-action.danger:hover,.hex-token-action.danger:focus-visible{border-color:var(--color-fail);color:var(--color-fail)}.hex-token-form{position:absolute;top:74px;right:12px;z-index:40;display:grid;gap:.75rem;width:min(320px,calc(100% - 24px));padding:.85rem;border:1px solid rgba(6,182,212,.28);border-radius:var(--radius-lg);background:#050810f0;box-shadow:0 18px 45px #00000059;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hex-token-form label{display:grid;gap:.35rem;color:var(--color-text-muted);font-size:.76rem}.hex-token-form input{min-height:38px;width:100%;border:1px solid rgba(148,163,184,.26);border-radius:var(--radius-sm);background:#ffffff0f;color:var(--color-text-bright);font:inherit;padding:.45rem .6rem}.hex-token-form input:focus{border-color:var(--color-cyan);outline:2px solid rgba(6,182,212,.34)}.hex-token-form-actions{display:flex;justify-content:flex-end;gap:.5rem}.hex-token-form.with-asset-drawer{right:440px}.hex-asset-drawer{position:absolute;top:64px;right:68px;bottom:48px;z-index:37;display:flex;flex-direction:column;width:min(360px,calc(100% - 92px));overflow:hidden;border:1px solid rgba(148,163,184,.22);border-radius:14px;background:#050810f0;box-shadow:0 22px 56px #00000061;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.hex-asset-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.78rem .86rem;border-bottom:1px solid rgba(148,163,184,.16)}.hex-asset-header div{display:grid;gap:.1rem;min-width:0}.hex-asset-header span{color:var(--color-text-dim);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.hex-asset-header strong{overflow:hidden;color:var(--color-text-bright);font-size:.92rem;text-overflow:ellipsis;white-space:nowrap}.hex-drawer-close{display:grid;place-items:center;width:32px;height:32px;border:1px solid rgba(148,163,184,.22);border-radius:10px;background:#0f172ad1;color:var(--color-text-bright);cursor:pointer}.hex-drawer-close:hover,.hex-drawer-close:focus-visible{border-color:var(--color-cyan);color:var(--color-cyan);outline:none}.hex-asset-tabs{display:grid;grid-template-columns:1fr 1fr;gap:.3rem;padding:.62rem .72rem 0}.hex-asset-tabs button,.hex-asset-actions .btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem}.hex-asset-tabs button{min-height:34px;border:1px solid rgba(148,163,184,.18);border-radius:10px;background:#0f172ab3;color:var(--color-text-dim);cursor:pointer;font-size:.76rem}.hex-asset-tabs button:hover,.hex-asset-tabs button:focus-visible,.hex-asset-tabs button.is-active{border-color:#06b6d46b;background:#0891b229;color:var(--color-text-bright);outline:none}.hex-asset-search{display:flex;align-items:center;gap:.42rem;margin:.62rem .72rem 0;min-height:36px;padding:0 .58rem;border:1px solid rgba(148,163,184,.2);border-radius:10px;background:#02061785;color:var(--color-text-dim)}.hex-asset-search input{min-width:0;width:100%;border:0;background:transparent;color:var(--color-text-bright);font:inherit;font-size:.78rem;outline:none}.hex-asset-search input::placeholder{color:var(--color-text-dim)}.hex-asset-actions{display:flex;gap:.45rem;padding:.62rem .72rem}.hex-asset-upload{cursor:pointer}.hex-asset-list{display:grid;gap:.5rem;min-height:0;overflow:auto;padding:0 .72rem .8rem}.hex-asset-card{display:grid;grid-template-columns:54px minmax(0,1fr) auto;align-items:center;gap:.62rem;padding:.5rem;border:1px solid rgba(148,163,184,.16);border-radius:12px;background:#0f172a9e}.hex-asset-card:hover,.hex-asset-card:focus-within{border-color:#c4b5fd61;background:#1e293bad}.hex-asset-thumb{display:grid;place-items:center;width:54px;height:42px;overflow:hidden;border:1px solid rgba(148,163,184,.2);border-radius:8px;background:#020617b3;color:var(--color-text-dim)}.hex-asset-thumb img{width:100%;height:100%;object-fit:cover}.hex-asset-meta{display:grid;gap:.12rem;min-width:0}.hex-asset-meta strong{overflow:hidden;color:var(--color-text-bright);font-size:.78rem;text-overflow:ellipsis;white-space:nowrap}.hex-asset-meta span{overflow:hidden;color:var(--color-text-dim);font-size:.68rem;text-overflow:ellipsis;white-space:nowrap}.hex-asset-place{min-height:30px;border:1px solid rgba(148,163,184,.22);border-radius:9px;background:#0206178c;color:var(--color-text-bright);cursor:pointer;font-size:.7rem;padding:0 .48rem}.hex-asset-place:hover,.hex-asset-place:focus-visible{border-color:var(--color-cyan);color:var(--color-cyan);outline:none}.hex-asset-empty{display:grid;gap:.24rem;padding:1.1rem .9rem;border:1px dashed rgba(148,163,184,.22);border-radius:12px;color:var(--color-text-dim);text-align:center}.hex-asset-empty strong{color:var(--color-text-bright);font-size:.86rem}.hex-asset-empty span{font-size:.74rem;line-height:1.4}.hex-context-toolbar{position:absolute;top:76px;left:50%;z-index:39;display:flex;align-items:center;gap:.34rem;max-width:min(720px,calc(100% - 170px));padding:.38rem;border:1px solid rgba(148,163,184,.2);border-radius:18px;background:#0f172adb;box-shadow:0 16px 38px #00000052;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);transform:translate(-50%)}.hex-tool-option{display:grid;place-items:center;width:36px;height:36px;border:0;border-radius:12px;background:transparent;color:#e2e8f0cc;cursor:pointer}.hex-tool-option:hover,.hex-tool-option:focus-visible,.hex-tool-option.is-active{background:#8b5cf647;color:#ddd6fe;outline:none}.hex-color-swatch{position:relative;display:grid;place-items:center;width:36px;height:36px;border-radius:12px;cursor:pointer}.hex-color-swatch span{width:22px;height:22px;border:2px solid rgba(226,232,240,.72);border-radius:8px}.hex-color-swatch input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.hex-inline-range{display:flex;align-items:center;gap:.42rem;min-width:160px;color:var(--color-text-dim);font-size:.72rem}.hex-inline-range input{min-width:78px;accent-color:#8b5cf6}.hex-inline-range strong{min-width:34px;color:var(--color-text-bright);font-family:var(--font-mono);font-size:.68rem}.hex-inline-text{display:flex;align-items:center;gap:.42rem;min-width:220px;color:var(--color-text-dim);font-size:.72rem}.hex-inline-text input{min-height:30px;min-width:140px;width:100%;border:1px solid rgba(148,163,184,.22);border-radius:9px;background:#02061794;color:var(--color-text-bright);font:inherit;padding:.25rem .45rem}.hex-inline-text input:focus{border-color:var(--color-cyan);outline:2px solid rgba(6,182,212,.3)}.hex-context-action{min-height:32px;border:1px solid rgba(148,163,184,.22);border-radius:10px;background:#02061775;color:var(--color-text-bright);cursor:pointer;font-size:.72rem;padding:0 .58rem;white-space:nowrap}.hex-context-action:hover,.hex-context-action:focus-visible{border-color:#facc157a;color:#facc15;outline:none}.hex-context-copy{padding:0 .48rem;color:var(--color-text-dim);font-size:.72rem;white-space:nowrap}.hex-tool-rail{position:absolute;top:50%;right:14px;z-index:28;display:grid;gap:.28rem;padding:.38rem;border:1px solid rgba(148,163,184,.18);border-radius:18px;background:#0f172ac7;box-shadow:0 16px 38px #00000057;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transform:translateY(-50%)}.hex-rail-button{display:grid;place-items:center;width:38px;height:38px;border:0;border-radius:14px;background:transparent;color:#e2e8f0d1;cursor:pointer}.hex-rail-button:hover,.hex-rail-button:focus-visible{background:#94a3b824;color:var(--color-text-bright);outline:2px solid rgba(6,182,212,.34);outline-offset:2px}.hex-rail-button.is-active{background:#8b5cf647;color:#c4b5fd}.hex-map-statusbar{position:relative;z-index:20;display:flex;align-items:center;gap:.85rem;min-height:38px;padding:.42rem .85rem;border-top:1px solid rgba(148,163,184,.16);background:#050810db;color:var(--color-text-dim);font-size:.75rem}.hex-scene-control-chip{display:flex;align-items:center;gap:.35rem;margin-left:auto;min-height:30px;border:1px solid rgba(148,163,184,.22);border-radius:999px;background:#0f172abd;color:var(--color-text-bright);cursor:pointer;font-family:var(--font-mono);font-size:.72rem;margin-right:64px;padding:.25rem .58rem;white-space:nowrap}.hex-scene-control-chip:hover,.hex-scene-control-chip:focus-visible,.hex-scene-control-chip.is-active{border-color:#c4b5fd85;color:#c4b5fd;outline:none}.hex-details{position:absolute;right:14px;bottom:52px;z-index:35;width:min(300px,calc(100% - 28px));overflow:hidden;border:1px solid rgba(250,204,21,.28);border-radius:var(--radius-lg);background:#050810f0;box-shadow:0 18px 46px #00000061;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hex-details-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.78rem .86rem;border-bottom:1px solid rgba(148,163,184,.18)}.hex-details-header div{display:grid;gap:.12rem}.hex-details-header span{color:var(--color-text-dim);font-size:.72rem}.hex-details-header strong{color:var(--color-text-bright);font-family:var(--font-mono)}.hex-details-header button{display:grid;place-items:center;width:30px;height:30px;border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-sm);background:#0f172ab8;color:var(--color-text-bright);cursor:pointer}.hex-details-body{display:grid;gap:.55rem;padding:.82rem .86rem}.hex-details-body p{display:grid;gap:.08rem;margin:0;color:var(--color-text-bright);font-size:.84rem}.hex-details-body p span,.hex-details-body small{color:var(--color-text-dim);font-size:.72rem}.hex-details-notes{line-height:1.45}.hex-map-notice{position:absolute;top:82px;left:50%;z-index:50;width:min(520px,calc(100% - 24px));transform:translate(-50%);border:1px solid rgba(239,68,68,.35);border-radius:var(--radius-md);background:#280c10f0;color:var(--color-text-bright);padding:.65rem .8rem;font-size:.82rem;box-shadow:0 14px 32px #00000047}.map-surface-state{min-height:420px;background:radial-gradient(circle at top,rgba(0,255,136,.06),transparent 58%),var(--color-abyss)}@media (max-width: 760px){.hex-map-container{min-height:560px}.hex-map-toolbar{align-items:flex-start;flex-direction:column;padding:.7rem}.hex-map-toolbar-actions{width:100%;justify-content:flex-start}.hex-map-statusbar{align-items:flex-start;flex-direction:column;gap:.38rem}.hex-details{right:10px;bottom:88px;left:10px;width:auto}.hex-token-form{top:118px;right:10px;left:10px;width:auto}.hex-token-form.with-asset-drawer{right:10px}.hex-asset-drawer{top:118px;right:10px;bottom:142px;left:10px;width:auto}.hex-asset-card{grid-template-columns:48px minmax(0,1fr)}.hex-asset-place{grid-column:1 / -1;width:100%}.hex-token-actions{opacity:1;pointer-events:auto;transform:translate(-50%)}.hex-context-toolbar{top:128px;right:10px;left:10px;max-width:none;overflow-x:auto;transform:none}.hex-inline-range{min-width:150px}.hex-inline-text{min-width:220px}.hex-tool-rail{top:auto;right:10px;bottom:88px;grid-auto-flow:column;grid-template-columns:none;transform:none}.hex-rail-button{width:34px;height:34px;border-radius:12px}.hex-scene-control-chip{width:fit-content;margin-left:0;margin-right:56px}}.illusion-root{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;overflow:hidden}.illusion-fragment{position:absolute;background:repeating-linear-gradient(45deg,rgba(180,83,9,.7) 0px,rgba(180,83,9,.7) 2px,rgba(0,212,255,.4) 2px,rgba(0,212,255,.4) 4px,transparent 4px,transparent 8px);mix-blend-mode:screen;border:1px solid rgba(0,212,255,.3);border-radius:2px}.gr-root{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg);font-family:var(--f-b)}.gr-topbar{display:flex;align-items:center;gap:10px;padding:0 16px;height:46px;flex-shrink:0;background:#030d08e6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(0,255,136,.07);z-index:20}.gr-back-btn{display:flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--txt3);font-size:10px;font-family:var(--f-m);letter-spacing:.1em;cursor:pointer;white-space:nowrap;transition:all .18s}.gr-back-btn:hover{color:var(--glow2);border-color:#00ff881f;background:#00ff880a}.gr-breadcrumb{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:6px;background:#00ff880d;border:1px solid rgba(0,255,136,.1);color:var(--glow2);font-size:10px;font-family:var(--f-m);letter-spacing:.1em;white-space:nowrap}.gr-breadcrumb.is-idle{color:var(--txt3);background:#ffffff06;border-color:#ffffff12}.gr-conditions{display:flex;align-items:center;gap:.4rem;flex:1;justify-content:center}.gr-cond-chip{display:flex;align-items:center;gap:4px;padding:2px 7px;border-radius:99px;border:1px solid var(--border);background:#ffffff06;font-size:.65rem;color:var(--txt4)}.gr-cond-sep{width:1px;height:12px;background:var(--border)}.gr-topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto;min-width:0}.gr-session-label{font-size:10px;color:var(--txt3);letter-spacing:.12em;text-transform:uppercase}.gr-session-name{font-size:10px;font-family:var(--f-m);color:var(--txt2);letter-spacing:.04em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.gr-role-badge{padding:3px 9px;border-radius:4px;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:#00ff8812;border:1px solid rgba(0,255,136,.12);color:var(--glow2)}.gr-role-badge.gm{background:#ff6b351f;border-color:#ff6b3540;color:#ff6b35}.gr-conn-pill{display:inline-flex;align-items:center;gap:5px;height:24px;padding:0 9px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#00000042;color:var(--txt3);font-family:var(--f-m);font-size:9px;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap}.gr-conn-pill.online{color:var(--color-success);border-color:#00ff882e;background:#00ff880e}.gr-conn-pill.offline{color:var(--txt4)}.gr-conn-dot{width:22px;height:22px;border-radius:50%;border:1px solid rgba(0,255,136,.15);background:#0000004d;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.gr-body{flex:1;display:flex;overflow:hidden;min-height:0}.gr-icon-nav{width:72px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;background:#030d08f2;border-right:1px solid rgba(0,255,136,.07);z-index:10;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;padding:8px 0}.gr-icon-nav::-webkit-scrollbar{display:none}.grin-top{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1;width:100%;padding:4px 0 10px}.grin-group-label{width:100%;padding:5px 8px 2px;color:#c9a44ab8;font-family:var(--f-m);font-size:8px;letter-spacing:.14em;line-height:1;text-align:center;text-transform:uppercase}.grin-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:64px;min-height:54px;padding:8px 6px;border:1px solid rgba(255,255,255,.03);border-radius:10px;background:#ffffff03;color:var(--txt3);cursor:pointer;transition:all .18s}.grin-btn:hover{background:#ffffff0f;border-color:#ffffff24;color:var(--txt2)}.grin-btn.active{color:var(--glow2);background:#00ff8821;border-color:#00ff8838;box-shadow:0 0 0 1px #00ff8826,0 0 16px #00ff8826}.grin-btn.active svg{filter:drop-shadow(0 0 3px var(--glow4))}.grin-btn.grin-gm.active{background:#c9a44a24;color:var(--brass);border-color:#c9a44a59;box-shadow:0 0 0 1px #c9a44a2e,0 0 16px #c9a44a24}.grin-btn.grin-gm.active svg{filter:drop-shadow(0 0 3px var(--brass3))}.grin-label{font-family:var(--f-m);font-size:8.5px;font-weight:600;letter-spacing:.08em;line-height:1.1;text-transform:uppercase;white-space:normal;overflow:hidden;text-overflow:ellipsis;max-width:60px;text-wrap:balance;text-align:center}.grin-icon{width:18px;height:18px;flex-shrink:0}.gr-icon{flex-shrink:0}.gr-icon-tool{width:14px;height:14px}.gr-icon-fab{width:22px;height:22px}.grin-board{opacity:.82}.grin-board:hover{opacity:1}.grin-board.board-active{opacity:1;background:#00ff880d;color:var(--glow2)}.grin-rule{width:48px;height:1px;background:#ffffff14;margin:5px auto;flex-shrink:0}.grin-btn:focus-visible{outline:none;border-color:#00ff8880;box-shadow:0 0 0 2px #00ff8838}.gr-main-view{flex:1;position:relative;overflow:hidden;min-width:0}.gr-map-area{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;transition:filter .2s ease,opacity .2s ease}.gr-map-area.map-behind{filter:blur(2px) brightness(.5);pointer-events:none}.gr-map-bar{display:flex;align-items:center;gap:.6rem;padding:0 .75rem;height:34px;flex-shrink:0;background:var(--color-abyss);border-bottom:1px solid var(--color-border)}.gr-map-title{display:flex;align-items:center;gap:5px;font-size:.7rem;color:var(--color-text-dim);letter-spacing:.05em;font-family:var(--font-title)}.gr-fog-chip{font-size:.6rem;padding:1px 6px;border-radius:99px;background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:var(--color-fail);letter-spacing:.04em}.gr-map-toggle{margin-left:auto;display:flex;gap:2px;background:var(--color-deep);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px}.gr-toggle-btn{display:flex;align-items:center;justify-content:center;width:26px;height:22px;border:none;border-radius:3px;background:transparent;color:var(--color-text-dim);cursor:pointer;transition:all var(--transition-fast)}.gr-toggle-btn.on{background:var(--color-raised);color:var(--color-text-bright)}.gr-map-content{flex:1;overflow:hidden}.gr-panels-wrap{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;z-index:15;pointer-events:none}.gr-panels-wrap--split{position:relative;inset:auto;width:50%;min-width:450px;max-width:800px;flex:none}.gr-panel-overlay{position:relative;display:flex;flex-direction:column;pointer-events:auto;transition:width .3s ease,flex .3s ease;height:100%}.gr-panel-overlay--divider{border-right:1px solid rgba(0,255,136,.08)}.gr-panel-overlay.full-flex{flex:1;width:100%;background:var(--bg2)}.gr-panel-overlay.split-width{flex:none;width:50%;min-width:450px;max-width:800px;border-right:1px solid rgba(0,255,136,.08);box-shadow:10px 0 30px #00000080;background:#051510f5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.gr-po-header{flex-shrink:0;padding:14px var(--pad);border-bottom:1px solid rgba(0,255,136,.06);background:#05151099;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:space-between}.panel-head{gap:.5rem}.gr-po-title{display:flex;align-items:center;gap:10px;font-family:var(--f-t);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--brass2)}.gr-po-title svg{color:var(--brass3)}.gr-po-title .ph-icon{font-size:14px}.ph-title{display:flex;align-items:center;gap:8px;min-width:0;flex:1;font-family:var(--font-title);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-bright)}.ph-title span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ph-icon{color:var(--color-gold);flex-shrink:0}.ph-layout-controls{display:flex;gap:4px;background:#0000004d;padding:3px;border-radius:6px;border:1px solid rgba(255,255,255,.05);margin-right:8px;box-shadow:inset 0 2px 4px #00000080}.ph-layout-btn{width:28px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--txt4);cursor:pointer;transition:all var(--transition-fast)}.ph-layout-btn:hover{color:var(--txt2);background:#ffffff0d}.ph-layout-btn.is-inactive{opacity:.58}.ph-layout-btn.active-layout{color:var(--glow2);background:#00ff881a;border-color:#0f83;opacity:1}.ph-layout-btn:focus-visible{outline:none;border-color:#00ff8875;box-shadow:0 0 0 2px #00ff8838}.ph-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.gr-po-back{display:flex;align-items:center;gap:6px}.gr-po-close{width:26px;height:26px;border-radius:6px;background:none;border:1px solid var(--border);color:var(--txt3);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .17s}.gr-po-close:hover{border-color:var(--red2);color:var(--red);background:#c0392b12}.gr-po-body{flex:1;overflow-y:auto;padding:var(--pad);background:transparent}.panel-body{min-height:0}.gr-po-body>*{min-height:0}.gr-chat-fab{position:fixed;right:1rem;bottom:1rem;width:56px;height:56px;border:1px solid rgba(0,255,136,.26);border-radius:999px;background:linear-gradient(180deg,#041c14f5,#04120ef7);color:var(--color-text-bright);box-shadow:0 10px 22px #0006,0 0 0 1px #00ff881f;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;z-index:52;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.gr-chat-fab:hover{transform:translateY(-2px);border-color:#0f86;box-shadow:0 12px 26px #00000073,0 0 0 1px #00ff8838}.gr-chat-fab.active{background:linear-gradient(180deg,#062e21f7,#051c14fa);border-color:#00ff8880;box-shadow:0 0 0 2px #00ff883d,0 12px 28px #00000080}.gr-chat-fab:focus-visible{outline:none;box-shadow:0 0 0 3px #00ff8854,0 10px 26px #00000073}.gr-chat-drawer{position:fixed;bottom:calc(1rem + 66px);right:1rem;width:min(360px,calc(100vw - 1.2rem));height:min(62vh,460px);display:flex;flex-direction:column;background:var(--color-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:50;overflow:hidden}.gr-chat-head{display:flex;align-items:center;justify-content:space-between;padding:0 .75rem;height:36px;flex-shrink:0;border-bottom:1px solid var(--color-border);background:var(--color-abyss);font-family:var(--font-title);font-size:.75rem;color:var(--color-text-dim)}.gr-chat-head span{display:flex;align-items:center;gap:5px}.gr-chat-head button{background:none;border:none;color:var(--color-text-dim);cursor:pointer;font-size:.9rem;line-height:1;padding:2px 4px;border-radius:3px;transition:all var(--transition-fast)}.gr-chat-head button:hover{background:var(--color-raised);color:var(--color-text)}.gr-chat-close{display:inline-flex;align-items:center;justify-content:center}.gr-chat-body{flex:1;overflow:hidden;min-height:0}.ph-close{width:28px;height:28px;border-radius:7px;border:1px solid var(--border);background:transparent;color:var(--txt3);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.ph-close:hover{color:var(--red);border-color:#e74c3c80;background:#e74c3c14}.ph-close svg{width:14px;height:14px}@media (max-width: 1024px){.gr-topbar{gap:6px;padding:0 10px}.gr-conditions,.gr-session-label,.gr-session-name{display:none}.gr-icon-nav{width:58px}.grin-btn{width:52px;min-height:46px}.grin-label{max-width:46px}.grin-group-label{display:none}.gr-panel-overlay.split-width,.gr-panels-wrap--split{width:min(70%,680px);min-width:0}}@media (max-width: 780px){.gr-topbar{height:42px}.gr-topbar-right{gap:5px}.gr-breadcrumb{display:none}.gr-conn-pill{width:24px;padding:0;justify-content:center}.gr-conn-pill svg{flex-shrink:0}.gr-conn-pill{font-size:0}.gr-role-badge{font-size:8px;padding:2px 6px}.gr-icon-nav{width:52px;padding:6px 0}.grin-btn{width:42px;min-height:42px;padding:6px 3px}.grin-label{display:none}.gr-panels-wrap,.gr-panels-wrap--split,.gr-panel-overlay.split-width,.gr-panel-overlay.full-flex{width:100%!important;min-width:0!important;max-width:none!important;flex:1!important}.gr-po-header{padding:12px 10px;gap:.4rem}.ph-layout-controls{margin-right:0;display:none}.ph-actions .btn{padding:4px 6px;font-size:8px}.gr-po-body{padding:.8rem}.gr-chat-drawer{left:.6rem;right:.6rem;bottom:calc(.6rem + 62px);width:auto;max-width:none;height:min(62vh,460px)}.gr-chat-fab{width:50px;height:50px;right:.6rem;bottom:.6rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root{--color-void: #030d08;--color-abyss: #051510;--color-deep: #091e17;--bg: #030d08;--bg2: #051510;--bg3: #091e17;--card: #0e2920;--card2: #152f25;--card3: #1a3a2c;--color-surface: #0e2920;--color-raised: #152f25;--border: #1c3d2e;--border2: #2a5040;--hover: #1f4535;--color-border: #1c3d2e;--color-border-bright: #2a5040;--color-border-gold: rgba(201, 164, 74, .4);--glow: #00ff88;--glow2: #00e07a;--glow3: #00b560;--glow4: #007042;--glow5: #003d22;--brass: #c9a44a;--brass2: #9a7a32;--brass3: #6b551f;--copper: #a0522d;--color-gold: #c9a44a;--color-gold-bright: #e8cd7b;--color-gold-dim: #9a7a32;--color-gold-glow: rgba(201, 164, 74, .3);--red: #e74c3c;--red2: #c0392b;--purple: #9055c8;--purple2: #6a3a9a;--blue: #2980b9;--teal: #16a085;--warn: #f39c12;--color-success: #00e07a;--color-fail: #e74c3c;--color-fumble: #d86c5a;--color-cyan: #65d8ff;--txt: #d8f5ea;--txt2: #a8d4bc;--txt3: #5e8a72;--txt4: #2d4a3a;--txt5: #1a2e22;--color-text: #d8f5ea;--color-text-dim: #5e8a72;--color-text-bright: #ffffff;--color-teal: #16a085;--color-teal-bright: #00e07a;--color-teal-dim: rgba(22, 160, 133, .2);--color-teal-glow: rgba(0, 224, 122, .3);--f-d: "Cinzel Decorative", serif;--f-t: "Cinzel", serif;--f-b: "IM Fell DW Pica", serif;--f-m: "Courier Prime", monospace;--font-title: var(--f-d);--font-body: var(--f-b);--font-ui: var(--f-t);--font-mono: var(--f-m);--font-serif: var(--f-t);--glass: rgba(14, 41, 32, .82);--blur: 18px;--r: 13px;--rsm: 8px;--rxs: 5px;--pad: 1.2rem;--gap: .9rem;--radius-sm: var(--rsm);--radius-md: var(--r);--radius-lg: 20px;--radius-full: 9999px;--shadow: 0 8px 32px rgba(0, 0, 0, .55), 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 56px rgba(0, 0, 0, .7);--shadow-spatial: var(--shadow);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .3s cubic-bezier(.22, 1, .36, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{background:var(--bg);color:var(--txt);font-family:var(--f-b);font-size:15px;line-height:1.45;width:100%;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--glow4)}*{scrollbar-width:thin;scrollbar-color:var(--border2) transparent}h1,h2,h3,h4{font-family:var(--font-title);font-weight:600;color:var(--color-text-bright);letter-spacing:.05em;line-height:1.25}h1{font-size:2.2rem;text-transform:uppercase;letter-spacing:.1em}h2{font-size:1.6rem}h3{font-size:1.25rem}h4{font-size:1rem;letter-spacing:.08em}p{line-height:1.6;color:var(--color-text)}small{font-size:.8rem;color:var(--color-text-dim)}.glass{position:relative;background:linear-gradient(180deg,#ffffff06,#fff0),#0e2920c7;-webkit-backdrop-filter:blur(var(--blur));backdrop-filter:blur(var(--blur));border:1px solid rgba(0,255,136,.09);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;transition:border-color .22s}.glass:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;pointer-events:none;background:linear-gradient(90deg,transparent 5%,rgba(0,255,136,.15) 40%,rgba(201,164,74,.11) 65%,transparent 95%)}.glass:hover{border-color:#00ff8829}.glass.nautical:before{background:repeating-linear-gradient(90deg,var(--brass3) 0,var(--brass3) 4px,var(--brass2) 4px,var(--brass2) 9px,var(--brass) 9px,var(--brass) 11px,var(--brass2) 11px,var(--brass2) 16px,var(--brass3) 16px,var(--brass3) 20px);height:3px;opacity:.6}.glass.glow-card{border-color:#00ff8824;box-shadow:var(--shadow),0 0 28px #00ff8812}.text-dim{color:var(--color-text-dim)}.text-bright{color:var(--color-text-bright)}.text-gold{color:var(--color-gold-bright);text-shadow:0 0 8px var(--color-gold-dim)}.text-mono{font-family:var(--font-mono)}.text-center{text-align:center}.sec{font-family:var(--f-t);font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:var(--brass3);display:flex;align-items:center;gap:10px;margin:0 0 14px}.sec:before{content:"⚓";font-size:7px;color:var(--brass2)}.sec:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(201,164,74,.2),transparent)}.sec.mt{margin-top:22px}.sec .sec-action{margin-left:auto;font-size:9px}.btn{background:none;border:1px solid var(--border);color:var(--txt3);border-radius:var(--rsm);padding:6px 14px;font-family:var(--f-m);font-size:10px;letter-spacing:.07em;cursor:pointer;transition:all .17s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.btn:hover{border-color:var(--glow4);color:var(--glow2);box-shadow:0 0 10px #00ff881a}.btn.primary{background:linear-gradient(135deg,var(--glow4),var(--glow5));border-color:var(--glow4);color:var(--glow);box-shadow:0 0 14px #00ff8826}.btn.primary:hover{box-shadow:0 0 24px #00ff8847;transform:translateY(-1px)}.btn.brass{border-color:var(--brass3);color:var(--brass)}.btn.brass:hover{border-color:var(--brass);box-shadow:0 0 10px #c9a44a33}.btn.danger{border-color:#c0392b66;color:var(--red2)}.btn.danger:hover{border-color:var(--red);color:var(--red);box-shadow:0 0 10px #e74c3c26}.btn.ghost{border-color:transparent;color:var(--txt4)}.btn.ghost:hover{color:var(--txt);background:#ffffff0d}.btn.sm{padding:4px 10px;font-size:9px}.btn.xs{padding:3px 8px;font-size:8px}.btn.icon{width:28px;height:28px;padding:0;justify-content:center;border-radius:6px}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-full{width:100%}.form-group{display:flex;flex-direction:column;gap:.4rem}label{font-family:var(--f-m);font-weight:500;font-size:.75rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.1em}input,textarea,select,.inp{background:var(--card2);border:1px solid var(--border);color:var(--txt);border-radius:var(--rsm);padding:7px 11px;font-family:var(--f-m);font-size:11px;outline:none;transition:border-color .2s;width:100%}input:focus,textarea:focus,select:focus,.inp:focus{border-color:var(--glow4);box-shadow:0 0 0 2px #00704226}.inp::placeholder{color:var(--txt4);font-style:italic}textarea.inp{resize:vertical;min-height:80px;line-height:1.5;font-family:var(--f-b);font-size:13px}.g2{display:grid;grid-template-columns:1fr 1fr;gap:8px}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.flex{display:flex;align-items:center;gap:8px}.flex-end{display:flex;justify-content:flex-end;gap:6px}.flex-between{display:flex;align-items:center;justify-content:space-between;gap:8px}.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;font-family:var(--f-m);font-size:9px;letter-spacing:.1em;text-transform:uppercase;border:1px solid;border-radius:999px}.chip.green{border-color:#00ff884d;color:var(--glow2);background:#00ff8812}.chip.brass{border-color:#c9a44a4d;color:var(--brass);background:#c9a44a12}.chip.red{border-color:#c0392b4d;color:var(--red2);background:#c0392b12}.chip.purple{border-color:#9055c84d;color:#b580e8;background:#9055c812}.chip.dim{border-color:var(--border);color:var(--txt4);background:transparent}.chip.pulse{animation:cp 2s ease-in-out infinite}@keyframes cp{0%,to{opacity:1}50%{opacity:.6}}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;font-family:var(--f-m);font-size:9px;letter-spacing:.1em;text-transform:uppercase;border:1px solid;border-radius:999px}.card{position:relative;background:linear-gradient(180deg,#ffffff06,#fff0),#0e2920c7;-webkit-backdrop-filter:blur(var(--blur));backdrop-filter:blur(var(--blur));border:1px solid rgba(0,255,136,.09);border-radius:var(--r);box-shadow:var(--shadow)}.panel-header-title{font-family:var(--f-t);font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:var(--brass3);display:flex;align-items:center;gap:10px;margin:0 0 14px}:root{--color-parchment: #f0ddb4;--color-olive: #7e9e66;--color-olive-bright: #b8d5a1;--color-olive-dim: rgba(126, 158, 102, .2);--color-amber: #c9a44a;--color-amber-dim: rgba(201, 164, 74, .18);--color-cyan-dim: rgba(101, 216, 255, .16);--color-purple-dim: rgba(144, 85, 200, .18);--glow-fumble: 0 0 12px rgba(216, 108, 90, .24);--glow-gold: 0 0 14px rgba(201, 164, 74, .3);--glow-teal: 0 0 16px rgba(0, 224, 122, .2);--shadow-teal: 0 10px 30px rgba(0, 112, 66, .25);--shadow-xl: 0 18px 50px rgba(0, 0, 0, .65)}.btn.btn-primary{background:linear-gradient(135deg,var(--glow4),var(--glow5));border-color:var(--glow4);color:var(--glow);box-shadow:0 0 14px #00ff8826}.btn.btn-primary:hover{box-shadow:0 0 24px #00ff8847;transform:translateY(-1px)}.btn.btn-ghost{border-color:transparent;color:var(--txt4)}.btn.btn-ghost:hover{color:var(--txt);background:#ffffff0d}.btn.btn-sm{padding:4px 10px;font-size:9px}.btn.btn-xs{padding:3px 8px;font-size:8px}.glass-pane{position:relative;background:linear-gradient(180deg,#ffffff06,#fff0),#0e2920c7;-webkit-backdrop-filter:blur(var(--blur));backdrop-filter:blur(var(--blur));border:1px solid rgba(0,255,136,.09);border-radius:var(--r);box-shadow:var(--shadow)}.badge-gm{border-color:#c9a44a66;color:var(--color-gold-bright);background:#c9a44a1a}.badge-player{border-color:#00ff884d;color:var(--glow2);background:#00ff8812}.badge-online{border-color:#00ff8847;color:var(--glow2);background:#00ff8814}.spinner{width:1rem;height:1rem;border-radius:999px;border:2px solid rgba(216,245,234,.25);border-top-color:var(--glow2);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid rgba(0,255,136,.55);outline-offset:2px}
