:root{--bg0:#0a0a0e;--bg1:#111117;--bg2:#18181f;--bg3:#1f1f28;--bg4:#26262f;--bg5:#2e2e3a;--border:#2a2a36;--border-l:#38384a;--accent:#7c6af7;--ah:#9580ff;--adim:#2d2870;--text:#dddde8;--td:#9999b0;--muted:#55556a;--green:#4ec994;--red:#e06c75;--yellow:#e5c07b;--blue:#61afef;--font-ui:"SF Mono", "Fira Code", ui-monospace, monospace;--font-read:-apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg0);color:var(--text);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:13px}.auth-screen{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--bg1);border:1px solid var(--border);border-radius:12px;width:100%;max-width:340px;padding:28px 24px}.auth-card h1{color:var(--accent);letter-spacing:1px;text-align:center;margin-bottom:18px;font-size:16px}.field{margin-bottom:12px;display:block}.field label{color:var(--td);margin-bottom:4px;font-size:11px;display:block}.field input{background:var(--bg3);border:1px solid var(--border);width:100%;color:var(--text);border-radius:6px;outline:none;padding:9px 11px;font-family:inherit;font-size:13px}.field input:focus{border-color:var(--accent)}.btn{background:var(--adim);border:1px solid var(--accent);width:100%;color:var(--ah);cursor:pointer;border-radius:6px;padding:10px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.btn:hover{background:var(--accent);color:#fff}.link{text-align:center;color:var(--accent);cursor:pointer;background:0 0;border:none;margin-top:14px;font-family:inherit;font-size:12px;display:block}.error{color:var(--red);min-height:16px;margin-top:10px;font-size:12px}.role-badge{color:var(--muted);font-size:10px}.nav-bar{border-bottom:1px solid var(--border);gap:4px;margin-bottom:12px;padding-bottom:8px;display:flex}.nav-tab{background:var(--bg2);border:1px solid var(--border);color:var(--td);cursor:pointer;border-radius:6px;padding:7px 14px;font-family:inherit;font-size:12px;transition:all .12s}.nav-tab:hover{color:var(--text);border-color:var(--border-l)}.nav-tab.active{background:var(--adim);border-color:var(--accent);color:var(--ah)}.dice-wrap{flex-direction:column;gap:12px;height:calc(100vh - 130px);display:flex}.dice-controls{background:var(--bg1);border:1px solid var(--border);border-radius:8px;padding:14px}.dice-quick{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.dice-btn{background:var(--bg3);border:1px solid var(--border-l);color:var(--text);cursor:pointer;border-radius:6px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .12s}.dice-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.dice-custom{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.dice-custom input[type=text]{background:var(--bg3);border:1px solid var(--border);min-width:140px;color:var(--text);border-radius:6px;outline:none;flex:1;padding:9px 11px;font-family:inherit;font-size:13px}.dice-custom input[type=text]:focus{border-color:var(--accent)}.dice-custom .btn{width:auto;padding:9px 20px}.dice-secret{color:var(--yellow);cursor:pointer;white-space:nowrap;align-items:center;gap:5px;font-size:11px;display:flex}.dice-err{color:var(--red);min-height:14px;margin-top:8px;font-size:12px}.dice-feed{background:var(--bg2);border:1px solid var(--border);border-radius:8px;flex-direction:column;flex:1;gap:6px;padding:8px;display:flex;overflow-y:auto}.dice-empty{color:var(--muted);text-align:center;padding:24px;font-size:12px}.dice-row{background:var(--bg3);border:1px solid var(--border);border-radius:6px;justify-content:space-between;align-items:center;gap:12px;padding:8px 12px;display:flex}.dice-meta{align-items:center;gap:8px;min-width:0;display:flex}.dice-meta strong{color:var(--accent);font-size:12px}.dice-name{color:var(--td);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.dice-tag-dm{color:var(--yellow);font-size:10px}.dice-result{white-space:nowrap;align-items:baseline;gap:8px;display:flex}.dice-total{color:var(--green);font-size:18px;font-weight:700}.dice-detail{color:var(--muted);font-size:11px}.char-wrap{gap:12px;height:calc(100vh - 130px);display:flex}.char-list{flex-direction:column;gap:6px;width:210px;min-width:210px;display:flex;overflow-y:auto}.char-card{text-align:left;background:var(--bg2);border:1px solid var(--border);cursor:pointer;color:var(--text);border-radius:8px;padding:9px 11px;font-family:inherit;transition:all .12s}.char-card:hover{border-color:var(--border-l)}.char-card.active{border-color:var(--accent);background:var(--bg3)}.char-card-top{justify-content:space-between;align-items:center;display:flex}.char-card-top strong{color:var(--accent);font-size:13px}.char-mine{color:var(--yellow);font-size:11px}.char-card-sub{color:var(--td);margin:2px 0 6px;font-size:10px}.char-hpbar{background:var(--bg5);border-radius:3px;height:4px;overflow:hidden}.char-hpbar span{background:var(--green);height:100%;display:block}.char-card-hp{color:var(--muted);margin-top:3px;font-size:10px}.char-empty{color:var(--muted);text-align:center;padding:16px;font-size:12px}.char-sheet{background:var(--bg1);border:1px solid var(--border);border-radius:8px;flex:1;min-width:0;padding:14px 16px;overflow-y:auto}.sheet-head{border-bottom:1px solid var(--border);margin-bottom:12px;padding-bottom:10px}.sheet-name{color:var(--accent);background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:18px;font-weight:700}.sheet-id-line{flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px;display:flex}.sf,.sf-num input{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:5px;outline:none;padding:5px 7px;font-family:inherit;font-size:11px}.sf:focus,.sf-num input:focus{border-color:var(--accent)}.sf-num{color:var(--td);align-items:center;gap:4px;font-size:11px;display:flex}.sf-num input{width:50px}.sheet-combat{flex-wrap:wrap;gap:10px;margin-bottom:14px;display:flex}.combat-stat{background:var(--bg2);border:1px solid var(--border);text-align:center;border-radius:8px;min-width:72px;padding:8px 10px}.cs-label{color:var(--td);text-transform:uppercase;font-size:10px}.cs-val{justify-content:center;align-items:baseline;gap:2px;display:flex}.cs-val input{width:46px;color:var(--text);text-align:center;background:0 0;border:none;outline:none;font-family:inherit;font-size:18px;font-weight:700}.cs-suffix{color:var(--muted);font-size:10px}.cs-hint{color:var(--green);font-size:10px}.combat-hp{background:var(--bg2);border:1px solid var(--border);border-radius:8px;flex:1;min-width:200px;padding:8px 12px}.hp-label{color:var(--td);text-transform:uppercase;font-size:10px}.hp-row{align-items:center;gap:6px;margin:2px 0;display:flex}.hp-btn{background:var(--bg4);border:1px solid var(--border-l);color:var(--text);cursor:pointer;border-radius:5px;width:26px;height:26px;font-family:inherit;font-size:15px}.hp-btn:hover{background:var(--accent);color:#fff}.hp-cur,.hp-max{background:var(--bg3);border:1px solid var(--border);width:56px;color:var(--text);text-align:center;border-radius:5px;outline:none;padding:4px;font-family:inherit;font-size:16px;font-weight:700}.hp-cur{color:var(--green)}.hp-sep{color:var(--muted)}.hp-tmp{color:var(--td);align-items:center;gap:4px;font-size:10px;display:flex}.hp-tmp input{background:var(--bg3);border:1px solid var(--border);width:46px;color:var(--blue);text-align:center;border-radius:4px;outline:none;padding:2px;font-family:inherit;font-size:12px}.sheet-cols{align-items:flex-start;gap:14px;display:flex}.sheet-col-left{width:280px;min-width:280px}.sheet-col-right{flex:1;min-width:0}.sheet-abilities{grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:14px;display:grid}.ability-box{background:var(--bg2);border:1px solid var(--border);text-align:center;border-radius:8px;padding:6px}.ab-label{color:var(--td);font-size:10px}.ab-mod{color:var(--accent);font-size:18px;font-weight:700}.ab-score{background:var(--bg3);border:1px solid var(--border);width:40px;color:var(--text);text-align:center;border-radius:4px;outline:none;padding:2px;font-family:inherit;font-size:12px}.sheet-block{background:var(--bg2);border:1px solid var(--border);border-radius:8px;margin-bottom:12px;padding:10px 12px}.sheet-block h3{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:8px;margin-bottom:8px;font-size:11px;display:flex}.prof-row{cursor:pointer;align-items:center;gap:8px;padding:3px 0;font-size:12px;display:flex}.prof-bonus{text-align:center;width:28px;color:var(--green);font-weight:600}.prof-name{flex:1}.prof-name em{color:var(--muted);font-size:10px}.exp-toggle{border:1px solid var(--border-l);background:var(--bg3);width:18px;height:18px;color:var(--muted);cursor:pointer;border-radius:4px;font-family:inherit;font-size:10px}.exp-toggle.on{background:var(--adim);border-color:var(--accent);color:var(--ah)}.exp-badge{color:var(--accent);font-size:10px}.atk-line{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:6px;padding:4px 0;font-size:12px;display:flex}.atk-line strong{color:var(--text);min-width:120px}.atk-line.edit input,.spell-line.edit input{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:4px;outline:none;flex:1;min-width:60px;padding:4px 6px;font-family:inherit;font-size:11px}.mini-add,.mini-del{background:var(--bg4);border:1px solid var(--border-l);color:var(--text);cursor:pointer;border-radius:4px;width:20px;height:20px;font-family:inherit;font-size:13px;line-height:1}.mini-add:hover{background:var(--green);color:#fff}.mini-del:hover{background:var(--red);color:#fff}.slots-row{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.slot-pill{background:var(--bg3);border:1px solid var(--border);color:var(--blue);border-radius:10px;padding:3px 7px;font-size:10px}.spell-group{margin-bottom:8px}.spell-lv{color:var(--td);text-transform:uppercase;margin-bottom:3px;font-size:10px}.spell-line{padding:2px 0;font-size:12px}.spell-line.edit{align-items:center;gap:6px;display:flex}.sheet-text{background:var(--bg3);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font-read);resize:vertical;white-space:pre-wrap;border-radius:6px;outline:none;padding:8px 10px;font-size:12px;line-height:1.5}.sheet-text:focus{border-color:var(--accent)}.init-wrap{flex-direction:column;gap:12px;height:calc(100vh - 130px);display:flex}.init-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.init-round{color:var(--td);font-size:13px}.init-round strong{color:var(--accent);font-size:18px}.init-controls{flex-wrap:wrap;gap:8px;display:flex}.init-ctrl{width:auto;padding:7px 14px}.init-readonly{color:var(--muted);font-size:12px}.init-add{background:var(--bg2);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;padding:10px;display:flex}.init-add input{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:6px;outline:none;padding:8px 10px;font-family:inherit;font-size:12px}.init-add input:focus{border-color:var(--accent)}.init-add input:first-child{flex:1;min-width:140px}.init-add .btn{width:auto;padding:8px 16px}.init-list{flex-direction:column;flex:1;gap:6px;display:flex;overflow-y:auto}.init-row{background:var(--bg2);border:1px solid var(--border);border-left:3px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;display:flex}.init-row.active{border-left-color:var(--accent);background:var(--bg3);box-shadow:0 0 0 1px var(--adim)}.init-row.dead{opacity:.5}.init-order{text-align:center;width:22px;color:var(--muted);font-size:12px}.init-score input{background:var(--bg3);border:1px solid var(--border);width:48px;color:var(--yellow);text-align:center;border-radius:5px;outline:none;padding:4px;font-family:inherit;font-size:15px;font-weight:700}.init-score span{color:var(--yellow);text-align:center;width:48px;font-size:15px;font-weight:700;display:inline-block}.init-name{flex:1;min-width:0}.init-name strong{color:var(--text);font-size:13px}.init-conds{flex-wrap:wrap;gap:4px;margin-top:3px;display:flex}.cond-tag{background:var(--adim);color:var(--ah);border-radius:10px;align-items:center;gap:3px;padding:2px 6px;font-size:10px;display:inline-flex}.cond-x{color:var(--ah);cursor:pointer;background:0 0;border:none;padding:0;font-size:11px;line-height:1}.eff-tag{background:var(--bg3);color:var(--td);border-radius:10px;align-items:center;gap:3px;padding:2px 6px;font-size:10px;display:inline-flex}.eff-tag em{color:var(--accent);font-style:normal;font-weight:700}.eff-tag.conc{background:#7c6af72e}.eff-tag.expired{opacity:.55}.eff-tag.expired em{color:var(--red)}.eff-add{gap:3px;display:inline-flex}.eff-btn{border:1px dashed var(--border-l);color:var(--muted);cursor:pointer;background:0 0;border-radius:10px;padding:2px 6px;font-size:10px}.eff-btn:hover{border-color:var(--accent);color:var(--text)}.init-hp{flex-wrap:wrap;align-items:center;gap:4px;min-width:140px;display:flex}.hp-btn.sm{width:22px;height:22px;font-size:13px}.init-hp-in{background:var(--bg3);border:1px solid var(--border);width:48px;color:var(--green);text-align:center;border-radius:5px;outline:none;padding:3px;font-family:inherit;font-size:13px;font-weight:700}.init-hpmax{color:var(--muted);font-size:11px}.init-nohp{color:var(--muted)}.init-hpbar{background:var(--bg5);border-radius:2px;width:100%;height:3px;margin-top:2px;overflow:hidden}.init-hpbar span{background:var(--green);height:100%;display:block}.init-actions{align-items:center;gap:6px;display:flex}.cond-select{background:var(--bg3);border:1px solid var(--border);color:var(--td);cursor:pointer;border-radius:5px;outline:none;padding:5px;font-family:inherit;font-size:11px}.accordion{flex-direction:column;gap:4px;display:flex}.accordion-item{background:var(--bg3);border:1px solid var(--border);border-radius:6px;overflow:hidden}.accordion-item.has-detail .accordion-head{cursor:pointer}.accordion-head{justify-content:space-between;align-items:center;gap:8px;padding:7px 10px;display:flex}.accordion-item.has-detail:hover .accordion-head{background:var(--bg4)}.accordion-title{color:var(--text);font-size:12px}.accordion-item.has-detail .accordion-title{color:var(--accent)}.accordion-caret{color:var(--muted);font-size:10px;transition:transform .15s}.accordion-item.open .accordion-caret{transform:rotate(90deg)}.accordion-body{color:var(--td);white-space:pre-wrap;font-size:11px;line-height:1.5;font-family:var(--font-read);border-top:1px solid var(--border);padding:7px 10px 9px;display:none}.accordion-item.open .accordion-body{display:block}.spell-edit{background:var(--bg3);border:1px solid var(--border);border-radius:6px;margin-bottom:4px;padding:7px 8px}.spell-edit-top{align-items:center;gap:6px;display:flex}.spell-edit-top input{background:var(--bg2);border:1px solid var(--border);color:var(--text);border-radius:4px;outline:none;flex:1;padding:5px 7px;font-family:inherit;font-size:11px}.spell-lvl-sel{background:var(--bg2);border:1px solid var(--border);color:var(--td);cursor:pointer;border-radius:4px;outline:none;padding:5px;font-family:inherit;font-size:11px}.spell-desc-in{background:var(--bg2);border:1px solid var(--border);width:100%;color:var(--td);font-family:var(--font-read);border-radius:4px;outline:none;margin-top:5px;padding:5px 7px;font-size:11px}.spell-desc-in:focus,.spell-edit-top input:focus{border-color:var(--accent)}.feats-hint{color:var(--muted);margin-top:6px;font-size:10px}.sheet-owner{flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px;display:flex}.sheet-owner label{color:var(--td);font-size:11px}.sheet-owner select{min-width:160px}.sheet-del{width:auto;padding:4px 10px;font-size:11px}.feats-editor{margin-top:8px}.feats-editor summary{cursor:pointer;color:var(--accent);-webkit-user-select:none;user-select:none;font-size:11px}.feats-editor[open] summary{margin-bottom:6px}.init-temp{align-items:center;gap:3px;margin-left:6px;display:inline-flex}.init-temp-lbl{color:var(--yellow);text-transform:uppercase;letter-spacing:.3px;font-size:9px}.init-temp-in{border:1px solid var(--yellow);width:42px;color:var(--yellow);text-align:center;background:0 0;border-radius:4px;padding:2px 4px;font-size:12px}.init-temp-badge{color:var(--yellow);font-size:11px;font-weight:700}.chat-wrap{flex-direction:column;gap:12px;max-width:820px;height:calc(100vh - 150px);margin:0 auto;display:flex}.chat-bar{justify-content:space-between;align-items:center;gap:10px;display:flex}.chat-channels{gap:8px;display:flex}.chat-chan{border:1px solid var(--border);color:var(--td);cursor:pointer;background:0 0;border-radius:999px;padding:7px 16px;font-size:13px;font-weight:500;transition:all .15s}.chat-chan:hover{border-color:var(--accent);color:var(--text)}.chat-chan.active{background:var(--accent);border-color:var(--accent);color:#fff}.chat-clear{border:1px solid var(--border);color:var(--td);cursor:pointer;background:0 0;border-radius:999px;padding:7px 14px;font-size:12px;transition:all .15s}.chat-clear:hover{color:#e06c75;border-color:#e06c75}.chat-peers{flex-wrap:wrap;gap:6px;padding:2px 0;display:flex}.chat-peers-empty{color:var(--muted);font-size:12px}.chat-peer{border:1px solid var(--border);background:var(--bg2);color:var(--td);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:5px 12px;font-size:12px;display:inline-flex}.chat-peer:before{content:"";background:var(--peer,var(--accent));border-radius:50%;width:8px;height:8px}.chat-peer:hover{border-color:var(--accent);color:var(--text)}.chat-peer.active{background:var(--adim);border-color:var(--accent);color:var(--ah)}.chat-feed{border:1px solid var(--border);background:var(--bg1);border-radius:14px;flex-direction:column;flex:1;gap:3px;padding:14px;display:flex;overflow-y:auto}.chat-empty{color:var(--td);margin:auto;font-size:14px}.chat-day{justify-content:center;align-items:center;margin:14px 0 8px;display:flex}.chat-day span{color:var(--td);background:var(--bg2);text-transform:capitalize;border-radius:999px;padding:3px 12px;font-size:11px}.chat-msg{align-self:flex-start;gap:9px;max-width:80%;margin-top:8px;display:flex}.chat-msg.grouped{margin-top:2px}.chat-msg.mine{flex-direction:row-reverse;align-self:flex-end}.chat-avatar{color:#fff;border-radius:50%;flex:0 0 34px;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex}.chat-avatar-spacer{flex:0 0 34px}.chat-bubble{background:var(--bg2);border-radius:14px;padding:8px 13px}.chat-msg.mine .chat-bubble{background:#7c6af733;border:1px solid #7c6af759}.chat-msg-head{align-items:baseline;gap:8px;margin-bottom:3px;display:flex}.chat-msg-head strong{font-size:12.5px}.chat-msg.mine .chat-msg-head{flex-direction:row-reverse}.chat-time{color:var(--td);font-size:10px}.chat-body{white-space:pre-wrap;word-break:break-word;color:var(--text);font-size:14px;line-height:1.4}.chat-form{gap:8px;display:flex}.chat-form input{border-radius:10px;flex:1;padding:11px 14px}.chat-send{white-space:nowrap}.chat-err{color:#e06c75;min-height:14px;font-size:12px}.map-root{flex-direction:column;gap:8px;height:calc(100vh - 140px);display:flex}.map-toolbar{background:var(--bg1);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;align-items:flex-end;gap:6px 12px;padding:8px 10px;display:flex}.map-tool-group{border-right:1px solid var(--border);flex-flow:wrap;align-items:center;gap:4px;padding:14px 12px 0 0;display:flex;position:relative}.map-tool-group:last-child{border-right:none;padding-right:0}.map-tool-group[data-label]:before{content:attr(data-label);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-size:8.5px;font-weight:700;position:absolute;top:1px;left:2px}.map-tool,.map-btn{border:1px solid var(--border);background:var(--bg2);min-width:34px;height:32px;color:var(--text);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0 8px;font-size:15px;transition:border-color .12s,background .12s;display:inline-flex}.map-tool:hover,.map-btn:hover{border-color:var(--accent);background:var(--bg3)}.map-tool.active{background:var(--accent);border-color:var(--accent);color:#fff}.layer-btn.active{background:var(--adim);border-color:var(--accent);color:var(--ah)}.layer-btn:not(.active){opacity:.4}.map-zoom{text-align:center;min-width:46px;color:var(--td);font-size:12px}.map-num{color:var(--td);align-items:center;gap:4px;font-size:11px;display:inline-flex}.map-num input{border:1px solid var(--border);background:var(--bg2);width:52px;color:var(--text);border-radius:6px;padding:5px 6px;font-size:12px}.map-sel{border:1px solid var(--border);background:var(--bg2);color:var(--text);border-radius:6px;padding:5px;font-size:12px}.map-btn input[type=file]{display:none}.map-viewport{border:1px solid var(--border);background:var(--bg0);touch-action:none;cursor:grab;-webkit-user-select:none;user-select:none;border-radius:12px;flex:1;position:relative;overflow:hidden}.map-viewport[data-tool=ruler],.map-viewport[data-tool=reveal],.map-viewport[data-tool=hide],.map-viewport[data-tool=wall],.map-viewport[data-tool=door],.map-viewport[data-tool=tmpl],.map-viewport[data-tool=light],.map-viewport[data-tool=select]{cursor:crosshair}.map-viewport[data-tool=ping]{cursor:pointer}.map-viewport:active{cursor:grabbing}.map-scene{transform-origin:0 0;will-change:transform;position:absolute;top:0;left:0}.map-bg{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:100%;height:100%;position:absolute;top:0;left:0}.map-fog{pointer-events:none;position:absolute;top:0;left:0}.map-tokens{width:100%;height:100%;position:absolute;top:0;left:0}.map-token{color:#0a0a0e;-webkit-user-select:none;user-select:none;border:2px solid #ffffffd9;border-radius:50%;justify-content:center;align-items:center;font-weight:800;display:flex;position:absolute;box-shadow:0 2px 8px #00000080}.map-token.editable{cursor:grab}.map-token.dragging{cursor:grabbing;opacity:.85;z-index:5}.map-token-label{pointer-events:none;text-shadow:0 1px 2px #fff6}.map-ruler{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0;overflow:visible}.ruler-line{stroke:var(--yellow);stroke-width:3px;stroke-dasharray:8 6}.ruler-dot{fill:var(--yellow)}.map-tmpl{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0;overflow:visible}.tmpl-shape{fill:#e56c7538;stroke:#e56c75e6;stroke-width:2px}.tmpl-dot{fill:#e56c75f2}.map-pings{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.map-ping{position:absolute;transform:translate(-50%,-50%)}.map-ping-ring{border:3px solid var(--red);border-radius:50%;width:48px;height:48px;margin:-24px 0 0 -24px;animation:1.1s ease-out 2 pingPulse;display:block}.map-ping-name{white-space:nowrap;color:#fff;background:#0009;border-radius:6px;padding:1px 6px;font-size:11px;position:absolute;top:14px;left:50%;transform:translate(-50%)}@keyframes pingPulse{0%{opacity:1;transform:scale(.3)}to{opacity:0;transform:scale(1.4)}}.map-hud{color:var(--yellow);background:#000000b3;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600;display:none;position:absolute;bottom:12px;left:12px}.map-empty{text-align:center;color:var(--td);justify-content:center;align-items:center;display:none;position:absolute;top:0;bottom:0;left:0;right:0}.map-empty-hint{color:var(--muted);font-size:12px}.map-token{position:absolute;overflow:visible}.map-token-hp{background:#0009;border-radius:3px;height:11%;min-height:6px;position:absolute;bottom:-11%;left:8%;right:8%;overflow:hidden}.map-token-hp .hpfill{border-radius:0 0 3px 3px;position:absolute;top:42%;bottom:0;left:0}.map-token-hp .hptmp{background:#61afefd9;border-bottom:1px solid #00000080;border-radius:3px 3px 0 0;height:42%;position:absolute;top:0;left:0}.map-token.hidden-dm{opacity:.55;outline:2px dashed #7c6af7cc}.map-token-eye{background:var(--accent);border-radius:50%;padding:1px 2px;font-size:.5em;position:absolute;top:-6%;right:-6%}.map-token.active-turn{box-shadow:0 0 0 3px var(--yellow), 0 0 14px 2px #e5c07bcc;animation:1.4s ease-in-out infinite tokenPulse}@keyframes tokenPulse{0%,to{box-shadow:0 0 0 3px var(--yellow), 0 0 10px 1px #e5c07b99}50%{box-shadow:0 0 0 4px var(--yellow), 0 0 18px 4px #e5c07bf2}}@media (prefers-reduced-motion:reduce){.map-token.active-turn{animation:none}}.map-token.selected{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 10px 1px #7c6af7b3}.map-token.locked{cursor:default}.map-token-lock{background:var(--bg0);border-radius:50%;padding:1px 2px;font-size:.42em;position:absolute;top:-6%;left:-6%}.map-token-name{color:#fff;white-space:nowrap;pointer-events:none;background:#0009;border-radius:4px;padding:0 4px;font-size:.32em;font-weight:600;position:absolute;bottom:-26%;left:50%;transform:translate(-50%)}.map-token-conds{pointer-events:none;gap:2px;display:flex;position:absolute;top:-14%;left:50%;transform:translate(-50%)}.map-token-conds .cond{background:#0000008c;border-radius:4px;padding:0 1px;font-size:.4em;line-height:1.2}.map-conds{max-height:60vh;overflow-y:auto}.map-conds button{justify-content:space-between;gap:10px;display:flex}.map-conds button.on{background:var(--adim);color:var(--ah)}.map-conds .ck{color:var(--green)}.map-ctx{z-index:200;background:var(--bg2);border:1px solid var(--border-l);border-radius:10px;flex-direction:column;min-width:190px;padding:5px;display:flex;position:fixed;box-shadow:0 8px 24px #00000080}.map-ctx button{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 12px;font-size:13px;display:block}.map-ctx button:hover{background:var(--bg4)}.map-ctx button.danger{color:var(--red)}.map-tool.active,.map-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.ho-wrap{flex-direction:column;gap:14px;display:flex}.ho-editor{background:var(--bg1);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:10px;padding:12px;display:flex}.ho-types{gap:6px;display:flex}.ho-type{border:1px solid var(--border);background:var(--bg2);color:var(--td);cursor:pointer;border-radius:8px;flex:none;padding:6px 12px;font-size:13px}.ho-type:hover{border-color:var(--accent)}.ho-type.active{background:var(--accent);border-color:var(--accent);color:#fff}.ho-fields{flex-wrap:wrap;gap:8px;display:flex}.ho-input{border:1px solid var(--border);background:var(--bg2);color:var(--text);border-radius:8px;flex:180px;padding:8px 10px;font-size:13px}.ho-textarea{resize:vertical;flex-basis:100%;min-height:120px;font-family:inherit;line-height:1.5}.ho-file{border:1px dashed var(--border-l);background:var(--bg2);color:var(--muted);cursor:pointer;border-radius:8px;flex:180px;align-items:center;padding:8px 10px;font-size:13px;display:flex}.ho-file:hover{border-color:var(--accent);color:var(--text)}.ho-actions{align-items:center;gap:12px;display:flex}.ho-actions .btn{width:auto;margin:0}.ho-err{color:var(--red);font-size:12px}.ho-list{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.ho-empty{text-align:center;color:var(--muted);grid-column:1/-1;padding:40px 0}.ho-card{background:var(--bg1);border:1px solid var(--border);border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.ho-card.letter{border-color:var(--yellow)}.ho-card-head{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 12px;display:flex}.ho-type-icon{font-size:18px}.ho-card-titles{flex:1;min-width:0}.ho-card-titles h3{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:14px;overflow:hidden}.ho-card-titles p{color:var(--muted);margin:2px 0 0;font-size:11px}.ho-badge{background:var(--bg3);color:var(--td);white-space:nowrap;border-radius:999px;padding:2px 7px;font-size:10px}.ho-badge.targeted{background:var(--adim);color:var(--ah)}.ho-del{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 4px;font-size:14px}.ho-del:hover{color:var(--red);background:var(--bg3)}.ho-time{color:var(--muted);white-space:nowrap;font-size:10px}.ho-img{width:100%;height:auto;display:block}.ho-imglink{display:block}.ho-img-loading{text-align:center;color:var(--muted);padding:30px;font-size:12px}.ho-text-body{color:var(--text);white-space:pre-wrap;word-break:break-word;padding:14px;font-size:13px;line-height:1.6}.ho-text-body.letter{background:var(--bg2);color:var(--td);font-family:Georgia,Times New Roman,serif;font-style:italic}.search-overlay{z-index:1300;opacity:0;background:#00000080;justify-content:center;align-items:flex-start;padding-top:12vh;transition:opacity .12s;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.search-overlay.show{opacity:1}.search-box{background:var(--bg2);border:1px solid var(--border-l);border-radius:14px;flex-direction:column;width:min(620px,92vw);max-height:70vh;display:flex;overflow:hidden;box-shadow:0 24px 70px #0009}.search-input{border:none;border-bottom:1px solid var(--border);color:var(--text);background:0 0;outline:none;padding:16px;font-size:15px}.search-results{padding:6px;overflow-y:auto}.search-hint{color:var(--muted);text-align:center;padding:20px;font-size:13px}.search-item{text-align:left;cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;display:flex}.search-item:hover,.search-item.sel{background:var(--adim)}.search-ic{font-size:16px}.search-txt{flex-direction:column;min-width:0;display:flex}.search-txt strong{white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.search-txt span{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.search-foot{border-top:1px solid var(--border);color:var(--muted);padding:8px 14px;font-size:11px}.toast-host{z-index:1200;flex-direction:column;gap:8px;max-width:min(360px,90vw);display:flex;position:fixed;bottom:16px;right:16px}.toast{background:var(--bg2);border:1px solid var(--border-l);color:var(--text);opacity:0;border-radius:10px;align-items:center;gap:8px;padding:10px 14px;font-size:13px;transition:opacity .2s,transform .2s;display:flex;transform:translateY(8px);box-shadow:0 8px 24px #00000080}.toast.show{opacity:1;transform:none}.toast-icon{font-size:16px}.toast-success{border-color:var(--green)}.toast-warn{border-color:var(--yellow)}.toast-info{border-color:var(--accent)}.nav-badge{background:var(--red);color:#fff;vertical-align:middle;border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;margin-left:6px;padding:0 4px;font-size:10px;font-weight:700;display:inline-flex}.rollable{cursor:pointer;border-radius:5px;transition:background .12s,color .12s}.rollable:hover{background:var(--adim);color:var(--ah)}.atk-line.rollable:hover{outline:1px solid var(--accent)}.cmp-wrap{gap:14px;height:calc(100vh - 140px);display:flex}.cmp-side{flex-direction:column;gap:8px;width:280px;min-width:240px;display:flex}.cmp-kinds{flex-wrap:wrap;gap:4px;display:flex}.cmp-kind{border:1px solid var(--border);background:var(--bg2);color:var(--td);cursor:pointer;border-radius:8px;padding:5px 9px;font-size:13px}.cmp-kind:hover{border-color:var(--accent)}.cmp-kind.active{background:var(--accent);border-color:var(--accent);color:#fff}.cmp-search{border:1px solid var(--border);background:var(--bg2);color:var(--text);border-radius:8px;padding:8px 10px;font-size:13px}.cmp-new{width:auto;margin:0}.cmp-list{border:1px solid var(--border);background:var(--bg1);border-radius:10px;flex-direction:column;flex:1;gap:3px;padding:6px;display:flex;overflow-y:auto}.cmp-empty,.cmp-placeholder{color:var(--muted);text-align:center;padding:30px 10px;font-size:13px}.cmp-item{color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:7px;align-items:center;gap:8px;padding:7px 9px;font-size:13px;display:flex}.cmp-item:hover{background:var(--bg3)}.cmp-item.active{background:var(--adim);color:var(--ah)}.cmp-item-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cmp-detail{border:1px solid var(--border);background:var(--bg1);border-radius:12px;flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.cmp-detail-head{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:12px 16px;display:flex}.cmp-detail-icon{font-size:22px}.cmp-detail-head h2{color:var(--text);margin:0;font-size:17px}.cmp-badge{background:var(--bg3);color:var(--td);border-radius:999px;padding:2px 8px;font-size:10px}.cmp-detail-actions{align-items:center;gap:6px;margin-left:auto;display:flex}.cmp-act{width:auto;margin:0;padding:6px 12px;font-size:12px}.cmp-icon-btn{border:1px solid var(--border);background:var(--bg2);color:var(--td);cursor:pointer;border-radius:8px;padding:6px 9px;font-size:14px}.cmp-icon-btn:hover{border-color:var(--accent);color:var(--text)}.cmp-icon-btn.danger:hover{border-color:var(--red);color:var(--red)}.cmp-detail-body{flex:1;padding:16px;overflow-y:auto}.cmp-stats{gap:8px;margin-bottom:12px;display:flex}.cmp-stats span{background:var(--bg3);color:var(--td);border-radius:8px;padding:3px 10px;font-size:12px}.cmp-table{border-collapse:collapse;width:100%;max-width:520px;margin-bottom:12px}.cmp-table td{border:1px solid var(--border);padding:4px 10px;font-size:13px}.cmp-table td:first-child{text-align:center;width:48px;color:var(--muted)}.cmp-roll-result{color:var(--text);padding:0 16px 14px;font-size:15px}.cmp-muted{color:var(--muted)}.cmp-name-input{border:1px solid var(--border);background:var(--bg2);width:100%;color:var(--text);border-radius:8px;margin-bottom:8px;padding:8px 10px;font-size:15px}.cmp-row{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.cmp-field{color:var(--td);flex-direction:column;gap:3px;font-size:11px;display:flex}.cmp-field input{border:1px solid var(--border);background:var(--bg2);width:90px;color:var(--text);border-radius:6px;padding:6px 8px;font-size:13px}.cmp-desc{resize:vertical;border:1px solid var(--border);background:var(--bg2);width:100%;min-height:200px;color:var(--text);border-radius:8px;padding:10px;font-family:ui-monospace,monospace;font-size:13px;line-height:1.5}.cmp-hint{color:var(--muted);margin-top:6px;font-size:11px}.cmp-trow{align-items:center;gap:6px;margin-bottom:5px;display:flex}.cmp-trow .cmp-w{border:1px solid var(--border);background:var(--bg2);width:60px;color:var(--text);border-radius:6px;padding:6px}.cmp-trow .cmp-t{border:1px solid var(--border);background:var(--bg2);color:var(--text);border-radius:6px;flex:1;padding:6px 8px}.offline-banner{z-index:1100;background:var(--red);color:#fff;text-align:center;border-radius:999px;max-width:92vw;padding:8px 16px;font-size:12px;font-weight:600;position:fixed;bottom:16px;left:50%;transform:translate(-50%);box-shadow:0 6px 20px #00000080}.md{word-break:break-word;line-height:1.6}.md>:first-child{margin-top:0}.md>:last-child{margin-bottom:0}.md h1,.md h2,.md h3,.md h4{color:var(--accent);margin:.8em 0 .4em;line-height:1.3}.md h1{font-size:1.5em}.md h2{font-size:1.3em}.md h3{font-size:1.12em}.md h4{font-size:1em}.md p{margin:.5em 0}.md ul,.md ol{margin:.5em 0;padding-left:1.5em}.md li{margin:.2em 0}.md a{color:var(--blue);text-decoration:underline}.md a:hover{color:var(--accent)}.md strong{color:var(--text)}.md em{color:var(--td)}.md code{background:var(--bg3);border-radius:4px;padding:1px 5px;font-family:ui-monospace,monospace;font-size:.9em}.md pre{background:var(--bg0);border:1px solid var(--border);border-radius:8px;margin:.6em 0;padding:10px 12px;overflow-x:auto}.md pre code{background:0 0;padding:0}.md blockquote{border-left:3px solid var(--accent);color:var(--td);margin:.6em 0;padding:.2em 0 .2em 12px}.md hr{border:none;border-top:1px solid var(--border);margin:1em 0}.md table{border-collapse:collapse;margin:.6em 0}.md th,.md td{border:1px solid var(--border);padding:4px 8px}.md img{border-radius:6px;max-width:100%;height:auto}.vault-head{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:6px 12px;display:flex}.vault-path{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11px;overflow:hidden}.vault-toggle{border:1px solid var(--border);background:var(--bg2);color:var(--td);cursor:pointer;border-radius:6px;padding:4px 10px;font-size:12px}.vault-toggle:hover{border-color:var(--accent);color:var(--text)}.vault-editor-area{background:var(--bg2);color:#c8c8d8;resize:none;border:none;outline:none;flex:1;padding:24px 36px;font-family:ui-monospace,monospace;font-size:14px;line-height:1.8}.vault-preview{color:var(--text);flex:1;padding:24px 36px;font-size:14px;overflow-y:auto}.modal-overlay{z-index:1000;opacity:0;background:#0000008c;justify-content:center;align-items:center;padding:20px;transition:opacity .15s;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal-overlay.show{opacity:1}.modal-card{background:var(--bg2);border:1px solid var(--border-l);border-radius:14px;width:min(440px,100%);padding:20px;transition:transform .15s;transform:translateY(8px)scale(.98);box-shadow:0 20px 60px #0009}.modal-overlay.show .modal-card{transform:none}.modal-title{color:var(--accent);margin:0 0 8px;font-size:15px}.modal-msg{color:var(--text);white-space:pre-wrap;margin:0 0 14px;font-size:13px;line-height:1.5}.modal-input{border:1px solid var(--border);background:var(--bg1);width:100%;color:var(--text);border-radius:8px;margin-bottom:14px;padding:9px 11px;font-family:inherit;font-size:13px}.modal-input:focus{border-color:var(--accent);outline:none}.modal-textarea{resize:vertical;min-height:120px;line-height:1.5}.modal-actions{justify-content:flex-end;gap:8px;display:flex}.modal-btn{border:1px solid var(--border);background:var(--bg3);color:var(--text);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:13px}.modal-btn:hover{border-color:var(--accent)}.modal-ok{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.modal-ok:hover{filter:brightness(1.08)}.modal-ok.danger{background:var(--red);border-color:var(--red)}.modal-cancel{color:var(--td);background:0 0}.sn-wrap{flex-direction:column;gap:14px;max-width:780px;display:flex}.sn-composer{background:var(--bg1);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:8px;padding:12px;display:flex}.sn-input{resize:vertical;border:1px solid var(--border);background:var(--bg2);width:100%;min-height:90px;color:var(--text);border-radius:8px;padding:10px;font-family:inherit;font-size:13px;line-height:1.5}.sn-composer-actions{justify-content:flex-end;align-items:center;gap:12px;display:flex}.sn-composer-actions .btn{width:auto;margin:0}.sn-hint{color:var(--muted);flex:1;font-size:11px}.sn-err{color:var(--red);font-size:12px}.sn-list{flex-direction:column;gap:10px;display:flex}.sn-empty{text-align:center;color:var(--muted);padding:40px 0}.sn-note{background:var(--bg1);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.sn-note-head{align-items:center;gap:8px;margin-bottom:6px;display:flex}.sn-time{color:var(--accent);text-transform:capitalize;flex:1;font-size:11px}.sn-note-actions{gap:4px;display:flex}.sn-edit,.sn-del{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 5px;font-size:13px}.sn-edit:hover{color:var(--text);background:var(--bg3)}.sn-del:hover{color:var(--red);background:var(--bg3)}.sn-body{color:var(--text);white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.6}
