.map-panel{position:relative;width:100%;height:100%;background:#2a1f14;overflow:hidden}.map-panel .map-title{position:absolute;top:8px;left:12px;font-family:IBM Plex Mono,monospace;font-size:11px;color:#c8b090;letter-spacing:.12em;text-transform:uppercase;z-index:4;pointer-events:none}.map-panel .map-grid{display:grid;position:absolute;top:0;left:0;gap:1px;will-change:transform}.map-panel .cell{display:flex;align-items:center;justify-content:center;font-family:IBM Plex Mono,monospace;font-size:9px;color:#c8b090;background:#1e160e;border:1px solid #3a2a18;cursor:default;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;-webkit-user-select:none;user-select:none;position:relative}.map-panel .cell[data-has-occupant=true]{background:#2a3040;cursor:pointer;color:#d8c8a8}.map-panel .cell--selected{outline:2px solid #4a7ba8;outline-offset:-2px;z-index:1}.map-panel .cell--aoe{background:#a8504847;border-color:#a8504880}.map-panel .cell--drag-source{opacity:.45}.map-panel .cell--drop-valid{outline:2px dashed #6aa86a;outline-offset:-2px;background:#6aa86a2e;z-index:2}.map-panel .cell--drop-invalid{outline:2px dashed #a85050;outline-offset:-2px;background:#a850502e;cursor:not-allowed;z-index:2}.map-panel .cell--fog-explored{filter:brightness(.42) saturate(.5)}.map-panel .cell--fog-hidden{background:#0a0806!important;border-color:#0a0806!important;color:transparent!important}.map-panel--combat .map-grid{border:1px solid #5a4a36}.hover-tip{position:absolute;background:#0e1015eb;border:1px solid #3a4150;border-radius:2px;padding:4px 7px;font-family:IBM Plex Mono,monospace;font-size:10px;color:#ece4cf;pointer-events:none;white-space:nowrap;z-index:100;transform:translate(8px,8px)}.message{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.narration-message{margin-bottom:16px}.message.system-message{margin-bottom:8px;opacity:.95}.check-chip,.state-chip{font-weight:500}.message.system-message .system-chip strong{opacity:.9}.player-message{align-items:flex-end}.message-bubble{padding:10px 14px;border-radius:8px;font-size:14px;line-height:1.4;max-width:70%;word-wrap:break-word}.player-bubble{background-color:var(--gold-bg);color:var(--gold);border:1px solid var(--gold-dim)}.system-message{display:flex;flex-direction:column;gap:8px;align-items:center}.system-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background-color:var(--card);color:var(--text-dim);border-radius:4px;border:1px solid var(--border);font-size:12px;font-weight:500}.system-chip strong{color:var(--text);font-weight:600}.badge{padding:2px 8px;border-radius:3px;font-size:11px;font-weight:600;text-transform:uppercase}.badge-success{background-color:#44b86e26;color:var(--success)}.badge-failed{background-color:#c9444426;color:var(--danger)}.rejection-chip{background-color:#c944441a;border-color:var(--danger);color:var(--danger)}.approval-chip{background-color:#44b86e1a;border-color:var(--success);color:var(--success)}.error-chip{background-color:#c944441a;border-color:var(--danger);color:var(--danger)}.narration-message{align-items:flex-start}.narration-body{padding:12px 0;font-size:14px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-wrap:break-word}.narration-cursor{display:inline-block;animation:blink 1s infinite;margin-left:2px}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.narration-streaming{opacity:.9}.narration-streaming .narration-body{animation:subtlePulse 1s ease-in-out infinite}@keyframes subtlePulse{0%,to{opacity:.9}50%{opacity:1}}.check-chip{justify-content:center;gap:12px}.check-body-placeholder{max-width:100%;font-size:12px;color:var(--text-dim);background-color:var(--card);border:1px dashed var(--border);border-radius:4px;padding:8px;overflow-x:auto}.check-body-placeholder pre{margin:0;font-family:Courier New,monospace;font-size:11px}.state-change-message{align-items:center}.state-chip{display:inline-flex;padding:6px 12px;border-radius:4px;font-size:13px;font-weight:500;border:1px solid}.state-chip-positive{background-color:#44b86e1a;color:var(--success);border-color:var(--success)}.state-chip-negative{background-color:#c944441a;color:var(--danger);border-color:var(--danger)}.reasoning-details{width:100%;margin-top:4px}.reasoning-details summary{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:12px;color:var(--text-dim);padding:4px 8px;border-radius:3px;transition:background-color .15s ease}.reasoning-details summary:hover{background-color:var(--card)}.reasoning-body{margin-top:8px;padding:8px 12px;background-color:var(--card);border-left:2px solid var(--gold-dim);border-radius:3px;font-size:12px;color:var(--text-dim);line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.clarification-message{align-items:flex-start}.clarification-body{width:100%;display:flex;flex-direction:column;gap:8px}.clarification-body p{margin:0;color:var(--text);font-size:13px;line-height:1.5}.clarification-question{margin:0;font-size:14px;line-height:1.4;color:var(--text)}.clarification-options{display:flex;flex-direction:column;gap:6px;margin:8px 0 0}.clarification-option-button{padding:8px 12px;background-color:var(--card);border:1px solid var(--border);border-radius:3px;font-size:13px;color:var(--gold);cursor:pointer;transition:all .15s ease;text-align:left}.clarification-option-button:hover:not(:disabled){background-color:var(--gold-bg);border-color:var(--gold-dim)}.clarification-option-button:active:not(:disabled){transform:translateY(1px)}.clarification-option-button:disabled{opacity:.6;cursor:not-allowed}.clarification-option-button:focus{outline:2px solid var(--gold);outline-offset:1px}.clarification-input-form{display:flex;flex-direction:column;gap:6px;margin-top:8px}.clarification-textarea{padding:8px 12px;background-color:var(--card);border:1px solid var(--border);border-radius:3px;font-size:13px;color:var(--text);font-family:inherit;resize:vertical;min-height:50px}.clarification-textarea:focus{outline:2px solid var(--gold);outline-offset:-1px;border-color:var(--gold-dim)}.clarification-textarea:disabled{opacity:.6;cursor:not-allowed}.clarification-submit-button{padding:6px 12px;background-color:var(--gold);border:1px solid var(--gold-dim);border-radius:3px;color:var(--bg);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease}.clarification-submit-button:hover:not(:disabled){background-color:var(--gold-dim)}.clarification-submit-button:active:not(:disabled){transform:translateY(1px)}.clarification-submit-button:disabled{opacity:.5;cursor:not-allowed}.clarification-submit-button:focus{outline:2px solid var(--gold);outline-offset:1px}.clarification-answered{align-items:center}.clarification-chip-answered{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background-color:#44b86e1a;color:var(--success);border:1px solid var(--success);border-radius:4px;font-size:12px;font-weight:500;animation:fadeInDelay .2s ease-out}.clarification-chip-label{color:var(--text-dim);font-weight:400}.clarification-chip-answer{font-weight:600;color:var(--success)}.approval-summary{padding:8px 12px;background-color:var(--card);border-radius:3px}.reasoning-expander{display:flex;flex-direction:column;gap:.5rem}.reasoning-button{align-self:flex-start;padding:.4rem .8rem;background-color:transparent;border:1px solid var(--border);border-radius:3px;color:var(--text-dim);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.reasoning-button:hover{border-color:var(--border-hi);color:var(--text);background-color:var(--gold-bg)}.reasoning-button:focus{outline:2px solid var(--gold);outline-offset:2px}.reasoning-button[aria-expanded=true]{border-color:var(--gold);color:var(--gold);background-color:var(--gold-bg)}.reasoning-panel{padding:.75rem 1rem;background-color:var(--card);border-left:2px solid var(--gold);border-radius:0 3px 3px 0;font-size:.85rem;color:var(--text-dim);line-height:1.5}.reasoning-panel p{margin:0;white-space:pre-wrap;word-wrap:break-word}.dice-roll{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background-color:var(--card);border:1px solid var(--border);border-radius:4px;font-family:Monaco,Menlo,monospace;font-size:.9rem;color:var(--text);animation:slideIn .3s ease-out}.dice-roll-header{display:flex;align-items:center;gap:1rem}.die-face{display:flex;align-items:center;gap:.5rem;font-weight:700;animation:dieTumble .6s cubic-bezier(.34,1.56,.64,1)}@keyframes dieTumble{0%{transform:rotateX(0) rotateY(0) scale(.8);opacity:0}50%{transform:rotateX(720deg) rotateY(360deg) scale(1.05);opacity:1}to{transform:rotateX(0) rotateY(0) scale(1);opacity:1}}.die-value{font-size:1.5rem;color:var(--gold);display:inline-block;animation:dieScale .6s cubic-bezier(.34,1.56,.64,1)}@keyframes dieScale{0%{transform:scale(0)}60%{transform:scale(1.15)}to{transform:scale(1)}}.die-type{font-size:1rem;color:var(--text-dim);animation:fadeInDelay .3s ease-out .3s both}@keyframes fadeInDelay{0%{opacity:0}to{opacity:1}}.skill-path{display:flex;align-items:center;gap:.5rem;font-size:.9rem;animation:fadeInDelay .3s ease-out .15s both}.skill-path .label{color:var(--text-dim);font-weight:500}.skill-path .path{color:var(--gold);font-weight:500}.bonus-breakdown,.roll-total{font-size:.85rem;color:var(--text-dim);animation:fadeInDelay .3s ease-out .25s both}.bonus-breakdown .equation,.roll-total .equation{font-family:Monaco,Menlo,monospace;color:var(--text)}.difficulty-row{display:flex;align-items:center;gap:.75rem;font-size:.9rem;padding-top:.5rem;border-top:1px solid var(--border);animation:fadeInDelay .3s ease-out .35s both}.difficulty{color:var(--text-dim);font-weight:500}.badge{padding:.25rem .75rem;border-radius:3px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;animation:badgePulse .4s ease-out .4s both}@keyframes badgePulse{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.badge-success{background-color:var(--success);color:var(--bg)}.badge-failed{background-color:var(--danger);color:#fff}.chat-feed-container{display:flex;flex-direction:column;height:100%;gap:0}.chat-feed{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:0;min-height:0}.chat-feed-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-faint);font-size:14px;text-align:center}.chat-feed-form{display:flex;flex-direction:column;gap:8px;padding:12px;border-top:1px solid var(--border);background-color:var(--bg)}.chat-textarea{padding:10px 12px;background-color:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:13px;resize:vertical;min-height:60px;max-height:120px;line-height:1.4;transition:border-color .15s ease}.chat-textarea:focus{outline:none;border-color:var(--gold-dim)}.chat-textarea:disabled{opacity:.6;cursor:not-allowed}.chat-textarea::placeholder{color:var(--text-faint)}.chat-form-actions{display:flex;flex-direction:column;gap:8px}.preset-buttons{display:flex;flex-direction:column;gap:6px}.preset-button{padding:8px 12px;background-color:var(--card);color:var(--text-dim);border:1px solid var(--border);border-radius:4px;font-size:12px;cursor:pointer;transition:all .15s ease;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preset-button:hover:not(:disabled){background-color:var(--gold-bg);color:var(--gold);border-color:var(--gold-dim)}.preset-button:active:not(:disabled){transform:scale(.98)}.preset-button:disabled{opacity:.5;cursor:not-allowed}.submit-button{padding:10px 16px;background-color:var(--gold-bg);color:var(--gold);border:1px solid var(--gold-dim);border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.submit-button:hover:not(:disabled){background-color:var(--gold-dim)}.submit-button:active:not(:disabled){transform:scale(.98)}.submit-button:disabled{opacity:.5;cursor:not-allowed}.submit-button-busy{display:flex;align-items:center;gap:8px}.busy-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.busy-indicator{display:inline-flex;align-items:center;gap:6px;font-size:12px}.busy-dots{display:inline-flex;gap:4px;align-items:center}.busy-dots .dot{display:inline-block;width:4px;height:4px;background-color:var(--text-dim);border-radius:50%;animation:bounce 1.4s infinite}.busy-dots .dot:nth-child(1){animation-delay:0s}.busy-dots .dot:nth-child(2){animation-delay:.2s}.busy-dots .dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.5;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}@media (max-width: 600px){.preset-buttons{display:none}.chat-textarea{min-height:50px}}.character-sidebar{display:flex;flex-direction:column;gap:12px;padding:0;font-family:Georgia,serif}.character-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;background-color:var(--panel);flex-shrink:0}.character-info{flex:1;min-width:0}.character-name{font-size:16px;font-weight:600;color:var(--text);line-height:1.2}.character-meta{font-size:12px;color:var(--text-dim);margin-top:2px}.character-reset-btn{padding:6px 12px;background-color:var(--gold-bg);border:1px solid var(--gold-dim);border-radius:3px;color:var(--gold);font-size:11px;font-weight:500;letter-spacing:.5px;cursor:pointer;white-space:nowrap;transition:all .15s ease-out;font-family:system-ui,-apple-system,sans-serif}.character-reset-btn:hover:not(:disabled){background-color:var(--gold-dim);border-color:var(--gold);color:var(--text)}.character-reset-btn:disabled{opacity:.5;cursor:not-allowed}.character-section{padding:12px 16px;background-color:var(--card);border:1px solid var(--border);border-radius:4px;display:flex;flex-direction:column;gap:8px;transition:background-color .3s ease-out}.character-section.highlight{animation:section-highlight 1s ease-out}@keyframes section-highlight{0%{background-color:#c9a84c26}to{background-color:var(--card)}}.section-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);margin-bottom:2px;font-weight:600}.text-faint{color:var(--text-faint);font-size:12px}.pool-row{display:flex;flex-direction:column;gap:3px;margin-bottom:6px}.pool-row:last-child{margin-bottom:0}.pool-header{display:flex;justify-content:space-between;align-items:center}.pool-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim)}.pool-value{font-size:12px;color:var(--text);font-weight:500;font-family:system-ui,-apple-system,sans-serif}.pool-bar-bg{height:6px;background-color:var(--bg);border-radius:3px;overflow:hidden;border:1px solid var(--border)}.pool-bar-fill{height:100%;border-radius:2px;transition:width .3s ease-out}.pool-health{background-color:var(--hp)}.pool-mana{background-color:var(--mp)}.pool-stamina{background-color:var(--sp)}.attributes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.attribute-card{background-color:var(--bg);border:1px solid var(--border);border-radius:3px;padding:8px 4px;text-align:center}.attribute-label{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);margin-bottom:4px}.attribute-value{font-size:20px;color:var(--gold);font-weight:600;line-height:1;font-family:system-ui,-apple-system,sans-serif}.skill-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.skill-row{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:2px;font-size:12px;transition:background-color .15s ease-out}.skill-row:hover{background-color:var(--bg)}.skill-indent{color:var(--text-faint);font-size:10px;flex-shrink:0}.skill-name{flex:1;color:var(--text);font-weight:500}.skill-rank{color:var(--gold-dim);font-size:11px;font-family:system-ui,-apple-system,sans-serif}.inventory-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.inventory-item{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;border-radius:2px;font-size:12px;background-color:var(--bg);border:1px solid transparent;transition:all .15s ease-out}.inventory-item:hover{background-color:#c9a84c1a;border-color:var(--gold-dim)}.inventory-name{color:var(--text);flex:1;font-weight:500}.inventory-qty{color:var(--text-dim);font-size:11px;font-family:system-ui,-apple-system,sans-serif}.session-container{display:grid;grid-template-columns:1fr 300px;gap:16px;padding:16px;height:100%;overflow:hidden}.session-chat-feed,.session-sidebar{display:flex;flex-direction:column;min-width:0;overflow:hidden}.session-panel{display:flex;flex-direction:column;background-color:var(--card);border:1px solid var(--border);border-radius:4px;overflow:hidden}.session-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:var(--panel);border-bottom:1px solid var(--border);font-size:12px;font-weight:500;color:var(--text-dim)}.session-panel-body{flex:1;overflow:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.session-feed-message{padding:8px 12px;border-radius:4px;font-size:13px;line-height:1.4;color:var(--text)}.session-feed-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-faint);font-size:14px;text-align:center}.session-form-group{display:flex;flex-direction:column;gap:8px}.session-input{padding:8px;background-color:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:13px;font-family:system-ui,-apple-system,sans-serif}.session-input::placeholder{color:var(--text-dim)}.session-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px var(--gold-bg)}.session-button{padding:8px 16px;background-color:var(--gold-bg);color:var(--gold);border:1px solid var(--gold-dim);border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s ease-out}.session-button:hover:not(:disabled){background-color:var(--gold-dim);border-color:var(--gold)}.session-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.session-container{grid-template-columns:1fr;grid-template-rows:1fr auto}.session-sidebar{flex-direction:row}}:root{--chrome-0: #0e1015;--chrome-1: #14171c;--chrome-2: #1c2028;--chrome-3: #262b35;--chrome-4: #353b48;--line: #2a2f3a;--line-2: #3a4150;--parchment-0: #ede0c4;--parchment-1: #e3d3b1;--parchment-2: #d8c39a;--parchment-shadow: #b9a173;--ink: #2a221a;--ink-soft: #5a4a36;--text-0: #ece4cf;--text-1: #c8c0aa;--text-2: #8a8578;--text-3: #5d5a52;--ring-pc: #4a7ba8;--ring-friend: #6a8a5c;--ring-neutral: #8a857a;--ring-unknown: #c89a4a;--ring-hostile: #a85048;--serif: "Cormorant Garamond", "EB Garamond", Georgia, serif;--sans: "IBM Plex Sans", system-ui, sans-serif;--mono: "IBM Plex Mono", ui-monospace, monospace}.app{width:100%;height:100%;display:grid;grid-template-rows:64px 1fr;min-width:0;min-height:0;overflow:hidden;background:var(--chrome-1);background-image:radial-gradient(ellipse at top,rgba(80,75,60,.05),transparent 60%),radial-gradient(ellipse at bottom right,rgba(40,60,80,.04),transparent 60%)}.cstrip{display:flex;align-items:stretch;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#181b22,#14171c);position:relative;z-index:5}.cstrip-portrait{width:64px;height:64px;flex-shrink:0;position:relative;border-right:1px solid var(--line);background:#20242d;overflow:hidden}.cstrip-portrait .portrait-fill{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 38%,#6a5d49 0 22%,transparent 23%),linear-gradient(180deg,#3a342a,#1f1c16)}.cstrip-portrait .portrait-fill:after{content:"";position:absolute;left:50%;bottom:6px;transform:translate(-50%);width:38px;height:22px;background:#4a3f30;border-radius:50% 50% 8px 8px/60% 60% 8px 8px}.cstrip-portrait .hood{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 30%,transparent 25%,rgba(20,18,14,.7) 55%)}.cstrip-name{display:flex;flex-direction:column;justify-content:center;padding:0 18px 0 16px;border-right:1px solid var(--line);min-width:180px}.cstrip-name .name{font-family:var(--serif);font-size:22px;font-weight:500;line-height:1;color:var(--text-0);letter-spacing:.01em}.cstrip-name .sub{font-family:var(--sans);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-2);margin-top:5px}.cstrip-bars{display:flex;align-items:center;gap:20px;padding:0 22px;border-right:1px solid var(--line);flex:1}.bar-block{display:flex;flex-direction:column;gap:4px;min-width:130px}.bar-label{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--sans);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-2)}.bar-label .val{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--text-1)}.bar-track{height:6px;background:#0c0e12;border:1px solid #22262e;border-radius:1px;position:relative;overflow:hidden}.bar-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(180deg,#8a2a26,#6a1e1c);box-shadow:inset 0 1px #ffc8b42e}.bar-fill.mana{background:linear-gradient(180deg,#2a4a7a,#1e3a60);box-shadow:inset 0 1px #b4c8ff2e}.bar-empty{color:var(--text-3)}.pips{display:flex;gap:4px;align-items:center}.pip{width:9px;height:9px;border-radius:50%;background:#c89a4a;box-shadow:0 0 0 1px #0c0e12,inset 0 1px #ffdca066}.pip.spent{background:#2a2620;box-shadow:0 0 0 1px #0c0e12,inset 0 1px #0006}.pip-block{display:flex;flex-direction:column;gap:6px;min-width:78px}.attrs{display:flex;gap:6px;align-items:center}.attr-chip{display:flex;flex-direction:column;align-items:center;width:42px;padding:5px 0 4px;border:1px solid var(--line-2);background:#181b22;border-radius:2px}.attr-chip .a-label{font-family:var(--sans);font-size:9px;letter-spacing:.15em;color:var(--text-2);text-transform:uppercase}.attr-chip .a-val{font-family:var(--mono);font-size:13px;color:var(--text-0);margin-top:1px}.attr-chip.dex .a-val{color:#d8c08a}.action-chips{display:flex;gap:6px;padding-left:10px}.ac{font-family:var(--sans);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;padding:5px 9px;border:1px solid var(--line-2);border-radius:2px;background:#181b22;color:var(--text-1)}.ac.spent{color:var(--text-3);border-color:#22262e;background:#10131a;text-decoration:line-through;text-decoration-color:var(--text-3)}.ac.free{color:#c89a4a;border-color:#5a4628}.cstrip-tools{display:flex;align-items:center;gap:8px;padding:0 14px}.btn-ghost{font-family:var(--sans);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-1);background:transparent;border:1px solid var(--line-2);border-radius:2px;padding:8px 14px;cursor:pointer;transition:background .12s ease,border-color .12s ease}.btn-ghost:hover{background:#1f242e;border-color:#4a5061;color:var(--text-0)}.btn-sheet{display:flex;align-items:center;gap:8px}.btn-sheet:before{content:"";width:11px;height:13px;background:linear-gradient(var(--text-1),var(--text-1)) center/100% 1px no-repeat,linear-gradient(var(--text-1),var(--text-1)) center 4px/100% 1px no-repeat,linear-gradient(var(--text-1),var(--text-1)) center 8px/70% 1px no-repeat;border:1px solid var(--text-1);border-radius:1px}.state-switcher{display:flex;gap:0;border:1px solid var(--line-2);border-radius:2px;margin-right:6px;overflow:hidden}.state-switcher button{font-family:var(--sans);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;padding:7px 10px;background:#181b22;color:var(--text-2);border:none;border-right:1px solid var(--line);cursor:pointer;transition:all .12s ease}.state-switcher button:last-child{border-right:none}.state-switcher button:hover{color:var(--text-0)}.state-switcher button.active{background:#2a2620;color:#d8c08a;box-shadow:inset 0 -2px #8a6a30}.stage{display:grid;grid-template-columns:45% 55%;min-height:0;overflow:hidden}.stage>.left{display:flex;flex-direction:column;min-height:0;overflow:hidden;border-right:1px solid var(--line)}.stage>.right{display:grid;grid-template-rows:55% 45%;min-height:0;overflow:hidden}.stage>.right>*{min-height:0;overflow:hidden}.scene-panel{position:relative;width:100%;height:100%;background:#0a0c10;overflow:hidden}.scene-inner{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.scene-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text-3);-webkit-user-select:none;user-select:none}.scene-placeholder-icon{width:48px;height:48px;border:1px solid var(--line-2);border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:20px;opacity:.4}.scene-placeholder-label{font-family:var(--sans);font-size:10px;letter-spacing:.18em;text-transform:uppercase;opacity:.4}.scene-grain{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.06;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px}.scene-dm{position:absolute;top:10px;right:10px;display:flex;gap:6px;z-index:10}.dm-btn{font-size:14px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#0e1015b3;border:1px solid var(--line-2);border-radius:2px;color:var(--text-2);cursor:pointer;transition:background .12s ease,color .12s ease}.dm-btn:hover{background:#1e222ce6;color:var(--text-0)}.scene-caption{position:absolute;bottom:10px;left:12px;display:flex;align-items:center;gap:7px;font-family:var(--sans);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-2);background:#0a0c10a6;padding:4px 10px;border-radius:2px;pointer-events:none}.scene-caption .loc{color:var(--text-1)}.scene-caption .divider{color:var(--text-3)}.scene-caption .place{color:var(--text-2)}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#06070ab3;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:center;justify-content:center;animation:ps-fadein .2s ease}@keyframes ps-fadein{0%{opacity:0}to{opacity:1}}.sheet{width:720px;max-width:92vw;max-height:86vh;background:var(--chrome-2);border:1px solid var(--line-2);border-radius:2px;display:grid;grid-template-columns:220px 1fr;overflow:hidden;box-shadow:0 24px 60px #0009;position:relative}.sheet-side{background:#16191f;border-right:1px solid var(--line);padding:22px 18px;display:flex;flex-direction:column;gap:14px}.sheet-pic{width:100%;aspect-ratio:1;background:#20242d;border:2px solid var(--ring-pc);border-radius:2px;position:relative;overflow:hidden}.sheet-pic:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 38%,#6a5d49 0 22%,transparent 23%),linear-gradient(180deg,#3a342a,#1f1c16)}.sheet-pic:before{content:"";position:absolute;left:50%;bottom:14px;transform:translate(-50%);width:50%;height:28%;background:#4a3f30;border-radius:50% 50% 8px 8px/60% 60% 8px 8px}.sheet h2{font-family:var(--serif);font-size:26px;margin:0;color:var(--text-0);font-weight:500;letter-spacing:.01em}.sheet .ch-role{font-family:var(--sans);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-2);margin-top:4px}.sheet-main{padding:22px 24px;overflow-y:auto}.sheet-main h3{font-family:var(--sans);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-2);margin:0 0 10px;font-weight:500}.sheet-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:22px}.sheet-stat{border:1px solid var(--line);padding:10px 12px;border-radius:2px;background:#181b22}.sheet-stat .sk{font-family:var(--sans);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-2)}.sheet-stat .sv{font-family:var(--serif);font-size:22px;color:var(--text-0);margin-top:2px;line-height:1.1}.sheet-stat .sv small{font-family:var(--mono);font-size:11px;color:var(--text-2);margin-left:4px}.sheet-list{display:flex;flex-direction:column;gap:6px;margin-bottom:18px;padding:0}.sheet-list li{list-style:none;display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dashed var(--line);font-size:12px;color:var(--text-1)}.sheet-list li .tag{font-family:var(--mono);font-size:10.5px;color:var(--text-3)}.sheet-close{position:absolute;top:12px;right:12px}.init-strip{height:56px;flex-shrink:0;background:linear-gradient(180deg,#1b1f27,#161922);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 14px;gap:10px;overflow:hidden}.init-label{font-family:var(--sans);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-2);padding-right:8px;border-right:1px solid var(--line);margin-right:4px;flex-shrink:0}.init-label .rnd{display:block;font-family:var(--mono);font-size:11px;color:var(--text-1);letter-spacing:.04em;text-transform:none;margin-top:2px}.init-list{display:flex;gap:8px;align-items:center}.init-token{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border:1px solid var(--line-2);border-radius:2px;background:#1a1e26;position:relative}.init-token.current{border-color:#8a6a30;background:#2a2620;box-shadow:0 0 0 1px #c89a4a40,0 2px 12px #c89a4a1f}.init-token.current:before{content:"▾";position:absolute;top:-16px;left:50%;transform:translate(-50%);color:#c89a4a;font-size:13px}.init-dot{width:26px;height:26px;border-radius:50%;background:#20242d;position:relative;flex-shrink:0}.init-meta{display:flex;flex-direction:column;line-height:1.1}.init-meta .nm{font-family:var(--sans);font-size:11px;color:var(--text-0)}.init-meta .num{font-family:var(--mono);font-size:10px;color:var(--text-2);margin-top:1px}.dm-panel{position:fixed;top:64px;right:0;bottom:0;z-index:50;display:flex;flex-direction:row;align-items:flex-start;pointer-events:none}.dm-panel-tab{pointer-events:all;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);background:var(--chrome-3);border:1px solid var(--line-2);border-right:none;border-radius:4px 0 0 4px;color:var(--text-1);font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;padding:12px 6px;cursor:pointer;position:relative;align-self:flex-start;margin-top:64px;transition:background .15s}.dm-panel-tab:hover{background:var(--chrome-4);color:var(--text-0)}.dm-panel-badge{display:inline-block;background:#a85048;color:#fff;border-radius:50%;width:16px;height:16px;font-size:10px;font-weight:700;text-align:center;line-height:16px;position:absolute;top:4px;right:50%;transform:translate(50%);writing-mode:horizontal-tb;transform:rotate(180deg) translate(50%)}.dm-panel.open .dm-panel-tab{background:var(--chrome-4);color:var(--text-0)}.dm-panel-body{pointer-events:all;width:320px;height:100%;background:var(--chrome-1);border-left:1px solid var(--line-2);display:flex;flex-direction:column;overflow:hidden}.dm-autoapprove{padding:10px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px;flex-shrink:0}.dm-autoapprove-label{display:flex;align-items:center;gap:6px;color:var(--text-1);font-family:var(--sans);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}.dm-autoapprove-hint{color:var(--text-2);font-family:var(--sans);font-size:11px;flex:1;min-width:0}.dm-cost-estimate{padding:5px 14px;border-bottom:1px solid var(--line);color:var(--text-2);font-family:var(--mono, monospace);font-size:10px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dm-tabs{display:flex;border-bottom:1px solid var(--line);flex-shrink:0}.dm-btn-tab{flex:1;background:transparent;border:none;border-right:1px solid var(--line);color:var(--text-2);font-family:var(--sans);font-size:12px;padding:8px 4px;cursor:pointer;transition:background .1s,color .1s}.dm-btn-tab:last-child{border-right:none}.dm-btn-tab:hover{background:var(--chrome-2);color:var(--text-1)}.dm-btn-tab.active{background:var(--chrome-2);color:var(--text-0);font-weight:600}.dm-queue{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:8px}.dm-queue-empty{padding:24px 14px;color:var(--text-2);font-family:var(--sans);font-size:12px;text-align:center}.dm-queue-error{padding:6px 14px;background:#a8504826;color:#c87870;font-family:var(--mono);font-size:11px;flex-shrink:0}.dm-queue-card{background:var(--chrome-2);border:1px solid var(--line-2);border-radius:4px;padding:10px;display:flex;flex-direction:column;gap:6px}.dm-queue-summary{color:var(--text-0);font-family:var(--sans);font-size:13px;font-weight:600}.dm-queue-reasoning-toggle{background:transparent;border:none;color:var(--text-2);font-family:var(--sans);font-size:11px;cursor:pointer;text-align:left;padding:0}.dm-queue-reasoning-toggle:hover{color:var(--text-1)}.dm-queue-reasoning{background:var(--chrome-0);border:1px solid var(--line);border-radius:3px;padding:8px;color:var(--text-1);font-family:var(--mono);font-size:11px;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto;margin:0}.dm-queue-edit{display:flex;flex-direction:column;gap:4px}.dm-queue-edit-label{color:var(--text-2);font-family:var(--sans);font-size:11px}.dm-queue-edit-textarea{background:var(--chrome-0);border:1px solid var(--line-2);border-radius:3px;color:var(--text-0);font-family:var(--mono);font-size:11px;padding:6px;resize:vertical;width:100%;box-sizing:border-box}.dm-queue-edit-error{color:#c87870;font-family:var(--sans);font-size:11px}.dm-queue-actions{display:flex;gap:6px}.dm-btn{background:var(--chrome-3);border:1px solid var(--line-2);border-radius:3px;color:var(--text-1);font-family:var(--sans);font-size:12px;padding:5px 10px;cursor:pointer;transition:background .1s,color .1s}.dm-btn:hover:not(:disabled){background:var(--chrome-4);color:var(--text-0)}.dm-btn:disabled{opacity:.5;cursor:not-allowed}.dm-btn.primary{background:#3a5c7a;border-color:#4a7ba8;color:#c8dff0}.dm-btn.primary:hover:not(:disabled){background:#4a6c8a}.dm-btn.danger{background:#a850484d;border-color:#a85048;color:#e09090}.dm-btn.danger:hover:not(:disabled){background:#a8504880}.dm-inject{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px}.dm-inject-kind{display:flex;gap:4px}.dm-inject-textarea{background:var(--chrome-0);border:1px solid var(--line-2);border-radius:3px;color:var(--text-0);font-family:var(--sans);font-size:12px;padding:8px;resize:vertical;width:100%;box-sizing:border-box}.dm-inject-textarea.mono{font-family:var(--mono);font-size:11px}.dm-inject-npc{display:flex;flex-direction:column;gap:6px}.dm-inject-input{background:var(--chrome-0);border:1px solid var(--line-2);border-radius:3px;color:var(--text-0);font-family:var(--sans);font-size:12px;padding:6px 8px;width:100%;box-sizing:border-box}.dm-inject-status{font-family:var(--sans);font-size:12px;padding:4px 8px;border-radius:3px}.dm-inject-status.success{background:#3c785033;color:#80c090}.dm-inject-status.error{background:#a8504833;color:#c87870}html,body,#root{margin:0;padding:0;height:100%;width:100%;overflow:hidden;background:#0e1015}*,*:before,*:after{box-sizing:border-box}*{scrollbar-width:thin;scrollbar-color:transparent transparent;transition:scrollbar-color .2s ease}*:hover{scrollbar-color:rgba(160,140,100,.35) transparent}*::-webkit-scrollbar{width:8px;height:8px;background:transparent}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background-color:transparent;border-radius:4px;border:2px solid transparent;background-clip:padding-box;transition:background-color .2s ease}*:hover::-webkit-scrollbar-thumb{background-color:#a08c644d}*::-webkit-scrollbar-thumb:hover{background-color:#c8aa6e8c}*::-webkit-scrollbar-corner{background:transparent}:root{--bg: #0f0e0d;--panel: #1a1815;--card: #231f1c;--border: #3d3530;--border-hi: #5a5047;--gold: #c9a84c;--gold-dim: #8a6f2e;--gold-bg: #3d3015;--text: #e8dcc8;--text-dim: #9b8e7a;--text-faint: #4a4240;--hp: #c94444;--hp-bg: #3d1515;--mp: #4472c9;--mp-bg: #152040;--sp: #44b86e;--sp-bg: #153325;--danger: #c94444;--success: #44b86e}
