:root{--paper:#f4efe4;--paper-2:#ece5d4;--paper-3:#e0d7c1;--ink:#1f1b16;--ink-2:#4a4338;--ink-3:#847c6d;--ink-4:#b8af9c;--rule:#1f1b16;--rule-soft:#1f1b162e;--rule-softer:#1f1b161a;--accent-red:#a8442a;--accent-blue:#3a5d7a;--accent-gold:#b08838;--accent-green:#4d6a3a;--serif:"Crimson Pro", "Iowan Old Style", Georgia, serif;--hand:"Caveat", "Bradley Hand", cursive;--mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:var(--ink-3) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--paper-2);border-left:1px solid var(--rule-softer)}::-webkit-scrollbar-thumb{background:var(--ink-4);border:2px solid var(--paper-2);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}::-webkit-scrollbar-thumb:active{background:var(--ink-2)}::-webkit-scrollbar-corner{background:var(--paper-2)}.box.dark,.ai-panel .ai-body.dark,.sm-node.ai{scrollbar-color:var(--ink-4) transparent}.box.dark::-webkit-scrollbar-track{background:#ffffff0a;border-left:1px solid #ffffff14}.box.dark::-webkit-scrollbar-thumb{background:var(--ink-3);border:2px solid var(--ink)}.box.dark::-webkit-scrollbar-thumb:hover{background:var(--ink-4)}html,body{background:var(--paper);color:var(--ink);font-family:var(--serif);background-image:radial-gradient(#1f1b1609 1px,#0000 1px),radial-gradient(#1f1b1606 1px,#0000 1px);background-position:0 0,1px 2px;background-size:3px 3px,7px 7px;margin:0;padding:0;font-size:16px;line-height:1.45}.app{grid-template-columns:220px 1fr;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--rule);background:var(--paper);scrollbar-width:thin;scrollbar-color:var(--ink-4) transparent;align-self:start;height:100vh;padding:22px 18px;position:sticky;top:0;overflow-y:auto}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{border-left:1px solid var(--rule-softer);background:0 0}.sidebar::-webkit-scrollbar-thumb{background:var(--ink-4);border:2px solid var(--paper);border-radius:4px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}.sidebar h1{font-family:var(--serif);letter-spacing:-.01em;margin:0 0 2px;font-size:22px;font-weight:600}.sidebar .tag{font-family:var(--hand);color:var(--accent-red);margin-bottom:22px;font-size:18px;display:block;transform:rotate(-1.5deg)}.nav-group{margin-top:18px}.nav-label{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px;font-size:10px}.nav a{color:var(--ink);cursor:pointer;border-radius:4px;margin:0 -8px;padding:5px 8px;font-size:15px;text-decoration:none;display:block}.nav a:hover{background:var(--paper-2)}.nav a.active{background:var(--ink);color:var(--paper);font-weight:500}.nav a .num{font-family:var(--mono);color:var(--ink-3);margin-right:8px;font-size:10px}.nav a.active .num{color:var(--paper-3)}.main{max-width:1280px;padding:32px 44px 80px}.surface-head{border-bottom:1px solid var(--rule);justify-content:space-between;align-items:baseline;margin-bottom:28px;padding-bottom:14px;display:flex}.surface-head .crumbs{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px;font-size:11px}.surface-head h2{font-family:var(--serif);letter-spacing:-.015em;margin:0;font-size:36px;font-weight:600}.surface-head .who{font-family:var(--hand);color:var(--accent-blue);font-size:22px;transform:rotate(-1deg)}.box{border:1px solid var(--rule);background:var(--paper);padding:14px 16px;position:relative}.box.dashed{border-style:dashed}.box.soft{border-color:var(--rule-soft)}.box.filled{background:var(--paper-2)}.box.dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}.box-title{justify-content:space-between;align-items:baseline;margin-bottom:10px;display:flex}.box-title h3{font-family:var(--serif);letter-spacing:-.01em;margin:0;font-size:18px;font-weight:600}.box-title .meta{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.placeholder{border:1px dashed var(--rule-soft);font-family:var(--mono);color:var(--ink-3);letter-spacing:.04em;text-align:center;background:repeating-linear-gradient(135deg,#0000 0 6px,#1f1b160f 6px 7px);justify-content:center;align-items:center;min-height:80px;padding:20px;font-size:11px;display:flex}.chip{border:1px solid var(--rule);font-family:var(--mono);letter-spacing:.04em;background:var(--paper);border-radius:999px;align-items:center;gap:6px;padding:2px 8px;font-size:10px;display:inline-flex}.chip.red{border-color:var(--accent-red);color:var(--accent-red)}.chip.blue{border-color:var(--accent-blue);color:var(--accent-blue)}.chip.gold{border-color:var(--accent-gold);color:var(--accent-gold)}.chip.green{border-color:var(--accent-green);color:var(--accent-green)}.chip.solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}.kbd{font-family:var(--mono);border:1px solid var(--rule-soft);background:var(--paper);border-bottom-width:2px;border-radius:3px;padding:1px 5px;font-size:10px;display:inline-block}.hand{font-family:var(--hand);color:var(--accent-red);font-size:18px;line-height:1.1}.hand.blue{color:var(--accent-blue)}.hand.ink{color:var(--ink)}.arrow{font-family:var(--hand);color:var(--accent-red);font-size:22px;display:inline-block}.stat{font-family:var(--mono);color:var(--ink-2);font-size:11px}.stat b{color:var(--ink);font-weight:600}.muted{color:var(--ink-3)}.tiny{font-size:11px;font-family:var(--mono);color:var(--ink-3)}.row{gap:14px;display:flex}.col{flex-direction:column;gap:14px;display:flex}.grid-2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}hr.rule{border:0;border-top:1px solid var(--rule);margin:24px 0}hr.rule.dashed{border-top-style:dashed;border-color:var(--rule-soft)}.section-title{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);align-items:center;gap:10px;margin:28px 0 10px;font-size:11px;display:flex}.section-title:after{content:"";border-top:1px dashed var(--rule-soft);flex:1}.tabs{border-bottom:1px solid var(--rule);gap:0;margin-bottom:14px;display:flex}.tab{font-family:var(--serif);border:1px solid var(--rule);background:var(--paper-2);cursor:pointer;color:var(--ink-2);border-bottom:none;border-top-left-radius:4px;border-top-right-radius:4px;margin-bottom:-1px;padding:8px 14px;font-size:15px}.tab+.tab{border-left:none}.tab.active{background:var(--paper);color:var(--ink);border-bottom:1px solid var(--paper);font-weight:600}table.inv{border-collapse:collapse;width:100%;font-size:14px}table.inv th{text-align:left;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);border-bottom:1px solid var(--rule);padding:6px 8px;font-size:10px;font-weight:500}table.inv td{border-bottom:1px dashed var(--rule-soft);vertical-align:top;padding:8px}table.inv tr.group td{background:var(--paper-2);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);border-bottom:1px solid var(--rule);font-size:11px}table.inv tr:hover td{background:#1f1b1608}.map-wrap{border:1px solid var(--rule);background:var(--paper-2);aspect-ratio:16/10;position:relative;overflow:hidden}.map-wrap .map-bg{background:radial-gradient(38% 60% at 30% 55%,#a8442a2e,#0000 70%),radial-gradient(28% 40% at 65% 45%,#3a5d7a38,#0000 70%),radial-gradient(22% 30% at 78% 70%,#b0883833,#0000 70%),repeating-linear-gradient(45deg,#0000 0 16px,#1f1b160a 16px 17px),repeating-linear-gradient(-45deg,#0000 0 16px,#1f1b160a 16px 17px);position:absolute;inset:0}.map-wrap .coastline{border:1.5px solid var(--ink-2);opacity:.35;border-radius:36% 50% 40% 55%/50% 40% 55% 35%;position:absolute;inset:8% 6%}.pin{font-family:var(--mono);white-space:nowrap;font-size:10px;position:absolute;transform:translate(-50%,-100%)}.pin .dot{background:var(--ink);border:2px solid var(--paper);width:10px;height:10px;box-shadow:0 0 0 1px var(--ink);border-radius:50%;margin:0 auto}.pin.red .dot{background:var(--accent-red);box-shadow:0 0 0 1px var(--accent-red)}.pin.blue .dot{background:var(--accent-blue);box-shadow:0 0 0 1px var(--accent-blue)}.pin.gold .dot{background:var(--accent-gold);box-shadow:0 0 0 1px var(--accent-gold)}.pin.green .dot{background:var(--accent-green);box-shadow:0 0 0 1px var(--accent-green)}.pin .lbl{background:var(--paper);border:1px solid var(--rule-soft);border-radius:2px;margin-top:3px;padding:1px 5px}.influence{pointer-events:none;mix-blend-mode:multiply;border-radius:50%;position:absolute}.sitemap{background:var(--paper);border:1px solid var(--rule);min-height:560px;padding:30px;position:relative}.sm-node{border:1px solid var(--rule);background:var(--paper);width:180px;box-shadow:3px 3px 0 var(--ink);padding:10px 12px;position:absolute}.sm-node.dm{box-shadow:3px 3px 0 var(--accent-red)}.sm-node.player{box-shadow:3px 3px 0 var(--accent-blue)}.sm-node.shared{box-shadow:3px 3px 0 var(--accent-gold)}.sm-node.ai{box-shadow:3px 3px 0 var(--ink);background:var(--ink);color:var(--paper)}.sm-node h4{font-family:var(--serif);margin:0 0 4px;font-size:15px;font-weight:600}.sm-node ul{font-family:var(--mono);color:var(--ink-3);margin:4px 0 0;padding-left:14px;font-size:10px}.sm-node.ai ul{color:var(--paper-3)}.btn{font-family:var(--serif);border:1px solid var(--rule);background:var(--paper);cursor:pointer;color:var(--ink);align-items:center;gap:6px;padding:5px 12px;font-size:14px;display:inline-flex}.btn:hover{background:var(--paper-2)}.btn.primary{background:var(--ink);color:var(--paper)}.btn.danger{border-color:var(--accent-red);color:var(--accent-red)}.btn.sm{padding:2px 8px;font-size:12px}.ai-panel{border:1px solid var(--rule);background:var(--paper);grid-template-rows:auto 1fr auto;height:560px;display:grid;overflow:hidden}.ai-panel .ai-tabs{border-bottom:1px solid var(--rule);background:var(--paper-2);display:flex}.ai-panel .ai-tab{font-family:var(--serif);text-align:center;cursor:pointer;color:var(--ink-2);border-right:1px solid var(--rule-soft);flex:1;padding:8px 10px;font-size:14px}.ai-panel .ai-tab:last-child{border-right:none}.ai-panel .ai-tab.active{background:var(--paper);color:var(--ink);font-weight:600}.ai-panel .ai-tab .sub{font-family:var(--mono);color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;margin-top:2px;font-size:9px;display:block}.ai-body{flex-direction:column;gap:12px;padding:16px;display:flex;overflow:auto}.ai-msg{gap:10px;font-size:14px;display:flex}.ai-msg .who{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);min-width:70px;padding-top:3px;font-size:10px}.ai-msg.npc .who{color:var(--accent-red)}.ai-msg.dm .who{color:var(--ink)}.ai-msg.ai .who,.ai-msg.player .who{color:var(--accent-blue)}.ai-msg .body{border-left:2px solid var(--rule-soft);flex:1;padding-left:10px}.ai-msg.npc .body{border-color:var(--accent-red);font-style:italic}.ai-msg .body em.stage{color:var(--ink-3);font-size:13px;font-style:italic;display:block}.composer{border-top:1px solid var(--rule);background:var(--paper-2);align-items:center;gap:8px;padding:10px 12px;display:flex}.composer .input{border:1px solid var(--rule-soft);background:var(--paper);font-family:var(--serif);color:var(--ink-3);flex:1;padding:6px 10px;font-size:14px}.pc-card{border:1px solid var(--rule);background:var(--paper);grid-template-columns:1fr auto;align-items:baseline;gap:4px 12px;padding:12px 14px;display:grid}.pc-card .name{font-family:var(--serif);font-size:18px;font-weight:600}.pc-card .role{font-family:var(--hand);color:var(--accent-blue);font-size:16px}.pc-card .stats{font-family:var(--mono);color:var(--ink-2);border-top:1px dashed var(--rule-soft);flex-wrap:wrap;grid-column:1/-1;gap:10px;margin-top:4px;padding-top:8px;font-size:11px;display:flex}.bar{background:var(--paper-2);border:1px solid var(--rule);height:8px;position:relative;overflow:hidden}.bar>span{background:var(--ink);height:100%;display:block}.bar.red>span{background:var(--accent-red)}.bar.blue>span{background:var(--accent-blue)}.bar.gold>span{background:var(--accent-gold)}.bar.green>span{background:var(--accent-green)}.clock{width:56px;height:56px;display:inline-block;position:relative}.clock svg{width:100%;height:100%}.card{border:1px solid var(--rule);background:var(--paper);padding:12px 14px;position:relative}.card .head{justify-content:space-between;align-items:baseline;margin-bottom:6px;display:flex}.card .head h4{font-family:var(--serif);margin:0;font-size:17px;font-weight:600}.card .head .type{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.card p{color:var(--ink-2);margin:6px 0;font-size:14px}.card .footer{border-top:1px dashed var(--rule-soft);flex-wrap:wrap;gap:8px;margin-top:10px;padding-top:8px;display:flex}.dot{background:var(--ink);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:4px;display:inline-block}.dot.red{background:var(--accent-red)}.dot.blue{background:var(--accent-blue)}.dot.gold{background:var(--accent-gold)}.dot.green{background:var(--accent-green)}.aside{font-family:var(--hand);color:var(--accent-red);border-left:2px solid var(--accent-red);background:#a8442a0a;margin:8px 0;padding:6px 12px;font-size:18px;line-height:1.15}.aside.blue{color:var(--accent-blue);border-color:var(--accent-blue);background:#3a5d7a0a}.inline-card{border:1px solid var(--rule);background:var(--paper);margin-top:8px;padding:10px 12px;position:relative}.inline-card.dashed{border-style:dashed}.inline-card.solid-dm{border-color:var(--ink);box-shadow:3px 3px 0 var(--ink)}.inline-card.from-ai{border-color:var(--accent-blue)}.inline-card.from-dm{border-color:var(--ink)}.inline-card.from-player{border-color:var(--accent-blue)}.inline-card .ic-head{justify-content:space-between;align-items:baseline;margin-bottom:6px;display:flex}.inline-card .ic-kind{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-size:9px}.inline-card .ic-from-ai .ic-kind{color:var(--accent-blue)}.inline-card h5{font-family:var(--serif);margin:0;font-size:15px;font-weight:600}.inline-card .ic-prompt{color:var(--ink-2);margin:2px 0 8px;font-size:13px;line-height:1.4}.inline-card .ic-meta{font-family:var(--mono);color:var(--ink-3);letter-spacing:.04em;margin-top:6px;font-size:10px}.choice-row{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.choice{border:1px solid var(--rule);background:var(--paper-2);font-family:var(--serif);color:var(--ink);cursor:pointer;border-radius:2px;align-items:center;gap:6px;padding:5px 10px;font-size:13px;display:inline-flex;position:relative}.choice:hover{background:var(--paper)}.choice .key{font-family:var(--mono);background:var(--ink);color:var(--paper);border-radius:2px;margin-right:2px;padding:1px 4px;font-size:9px}.choice .cost{font-family:var(--mono);color:var(--ink-3);margin-left:4px;font-size:10px}.choice.selected{background:var(--ink);color:var(--paper);border-color:var(--ink)}.choice.selected .key{background:var(--paper);color:var(--ink)}.choice.selected .cost{color:var(--paper-3)}.choice.danger{border-color:var(--accent-red)}.choice.danger.selected{background:var(--accent-red);border-color:var(--accent-red)}.choice.gold{border-color:var(--accent-gold)}.choice.green{border-color:var(--accent-green)}.choice.disabled{opacity:.4;cursor:not-allowed}.dice-prompt{border:1px dashed var(--rule);background:var(--paper-2);align-items:center;gap:10px;margin-top:6px;padding:8px 10px;display:flex}.dice-prompt .die{border:1.5px solid var(--ink);width:32px;height:32px;font-family:var(--mono);background:var(--paper);justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex;transform:rotate(-3deg)}.dice-prompt .formula{font-family:var(--mono);color:var(--ink-2);font-size:12px}.dice-prompt .dc{font-family:var(--mono);color:var(--accent-red);margin-left:auto;font-size:11px}.pill-multi{flex-wrap:wrap;gap:4px;display:flex}.pill-multi label{border:1px solid var(--rule-soft);background:var(--paper);cursor:pointer;align-items:center;gap:4px;padding:3px 8px;font-size:12px;display:inline-flex}.pill-multi input{margin:0}.poll-row{grid-template-columns:100px 1fr 32px;align-items:center;gap:8px;margin-top:4px;font-size:12px;display:grid}.poll-row .poll-bar{background:var(--paper-2);border:1px solid var(--rule-soft);height:6px;position:relative}.poll-row .poll-bar>span{background:var(--accent-blue);height:100%;display:block}.modal-grid{grid-template-columns:repeat(2,1fr);gap:22px;display:grid}@media (max-width:1100px){.modal-grid{grid-template-columns:1fr}}.modal-stage{background:repeating-linear-gradient(45deg, #1f1b160d 0 8px, transparent 8px 18px), var(--paper-2);border:1px solid var(--rule);justify-content:center;align-items:flex-start;min-height:320px;padding:28px 22px;display:flex;position:relative}.modal-stage.tall{min-height:480px}.modal-stage .stage-tag{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);font-size:10px;position:absolute;top:8px;left:10px}.modal-stage .stage-trigger{font-family:var(--hand);color:var(--accent-red);text-align:right;max-width:60%;font-size:16px;position:absolute;bottom:8px;right:10px;transform:rotate(-1deg)}.modal{background:var(--paper);border:1px solid var(--rule);box-shadow:4px 4px 0 var(--ink), 0 0 0 6px var(--paper-2);width:100%;max-width:460px;position:relative}.modal.wide{max-width:620px}.modal.narrow{max-width:360px}.modal.danger{box-shadow:4px 4px 0 var(--accent-red), 0 0 0 6px var(--paper-2)}.modal.dm{box-shadow:4px 4px 0 var(--ink), 0 0 0 6px var(--paper-2)}.modal.player{box-shadow:4px 4px 0 var(--accent-blue), 0 0 0 6px var(--paper-2)}.modal.gold{box-shadow:4px 4px 0 var(--accent-gold), 0 0 0 6px var(--paper-2)}.modal-head{border-bottom:1px solid var(--rule);justify-content:space-between;align-items:baseline;padding:12px 16px 10px;display:flex}.modal-head .kind{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.modal-head h4{font-family:var(--serif);letter-spacing:-.01em;margin:2px 0 0;font-size:18px;font-weight:600}.modal-head .x{font-family:var(--mono);color:var(--ink-3);cursor:pointer;border:1px solid var(--rule-soft);align-self:flex-start;padding:2px 6px;font-size:14px}.modal-body{color:var(--ink-2);padding:14px 16px;font-size:14px;line-height:1.5}.modal-body p{margin:0 0 10px}.modal-body p:last-child{margin-bottom:0}.modal-body label.field{margin-top:10px;display:block}.modal-body label.field>span{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-bottom:4px;font-size:10px;display:block}.modal-body input[type=text],.modal-body input[type=number],.modal-body textarea,.modal-body select{border:1px solid var(--rule);background:var(--paper-2);width:100%;font-family:var(--serif);color:var(--ink);padding:6px 10px;font-size:14px}.modal-body textarea{resize:vertical;min-height:70px}.modal-body .hint{font-family:var(--mono);color:var(--ink-3);letter-spacing:.04em;margin-top:4px;font-size:10px}.modal-body hr{border:0;border-top:1px dashed var(--rule-soft);margin:12px 0}.modal-foot{background:var(--paper-2);border-top:1px solid var(--rule);align-items:center;gap:8px;padding:10px 14px;display:flex}.modal-foot .spacer{flex:1}.modal-foot .note{font-family:var(--mono);color:var(--ink-3);letter-spacing:.04em;font-size:10px}.modal-list{border:1px solid var(--rule-soft);background:var(--paper-2);font-size:13px}.modal-list>div{border-bottom:1px dashed var(--rule-soft);justify-content:space-between;gap:10px;padding:6px 10px;display:flex}.modal-list>div:last-child{border-bottom:none}.modal-list .k{font-family:var(--mono);color:var(--ink-3);letter-spacing:.04em;font-size:11px}.seg{border:1px solid var(--rule);background:var(--paper-2);display:inline-flex}.seg>span{font-size:12px;font-family:var(--serif);border-right:1px solid var(--rule-soft);color:var(--ink-2);cursor:pointer;padding:4px 10px}.seg>span:last-child{border-right:none}.seg>span.on{background:var(--ink);color:var(--paper)}.radio-row{flex-direction:column;gap:6px;margin-top:8px;display:flex}.radio-row label{border:1px solid var(--rule-soft);background:var(--paper);cursor:pointer;align-items:flex-start;gap:8px;padding:6px 10px;display:flex}.radio-row label.on{border-color:var(--ink);background:var(--paper-2)}.radio-row label .radio{border:1px solid var(--ink);border-radius:50%;flex-shrink:0;width:12px;height:12px;margin-top:4px}.radio-row label.on .radio{background:radial-gradient(circle, var(--ink) 0 4px, transparent 5px)}.radio-row label .lbl-main{font-family:var(--serif);color:var(--ink);font-size:14px;display:block}.radio-row label .lbl-sub{font-family:var(--mono);color:var(--ink-3);letter-spacing:.04em;margin-top:2px;font-size:10px;display:block}.modal-dim{pointer-events:none;background:#1f1b1659;position:absolute;inset:0}.ic-footer{border-top:1px dashed var(--rule-soft);color:var(--ink-3);align-items:center;gap:6px;margin-top:10px;padding-top:8px;font-size:11px;display:flex}.ic-footer .spacer{flex:1}.sprite-group{margin-top:36px}.sprite-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;display:grid}.sprite-card{border:1px solid var(--rule-soft);background:var(--paper);flex-direction:column;align-items:center;padding:10px 8px 12px;transition:border-color .12s,box-shadow .12s;display:flex;position:relative}.sprite-card:hover{border-color:var(--rule);box-shadow:2px 2px 0 var(--ink)}.sprite-cell{background:var(--paper-2);border:1px solid var(--rule-soft);flex-shrink:0;place-items:center;margin-bottom:10px;display:grid;position:relative}.sprite-grid-bg{pointer-events:none;background-image:linear-gradient(90deg,#1f1b161f 1px,#0000 1px),linear-gradient(#1f1b161f 1px,#0000 1px);background-position:-1px -1px;background-size:25px 25px;position:absolute;inset:0}.sprite-grid-bg:after{content:"";background-image:linear-gradient(90deg,#1f1b1652 1px,#0000 1px),linear-gradient(#1f1b1652 1px,#0000 1px);background-position:-1px -1px;background-size:50px 50px;position:absolute;inset:0}.sprite-meta{text-align:center;flex-direction:column;gap:3px;width:100%;display:flex}.sprite-name{font-family:var(--mono);color:var(--ink);justify-content:center;align-items:center;gap:6px;font-size:12px;display:inline-flex}.sprite-name .dot{background:var(--ink);border-radius:50%;width:8px;height:8px;display:inline-block}.sprite-name .dot.red{background:var(--accent-red)}.sprite-name .dot.blue{background:var(--accent-blue)}.sprite-name .dot.gold{background:var(--accent-gold)}.sprite-name .dot.green{background:var(--accent-green)}.sprite-role{color:var(--ink-2);font-size:12px;font-style:italic;line-height:1.3}.sprite-path{font-family:var(--mono);color:var(--ink-3);margin-top:2px;font-size:10px}.app-shell{grid-template-rows:auto 1fr;grid-template-areas:"header""main";width:100%;min-height:100vh;display:grid}.app-shell-header{background:var(--paper);border-bottom:1px solid var(--rule);z-index:50;grid-area:header;align-items:center;gap:10px;padding:10px 14px;display:flex;position:sticky;top:0}.app-shell-header h1{font-family:var(--serif);letter-spacing:-.01em;margin:0;font-size:18px;font-weight:600}.app-shell-header .icon-btn{border:1px solid var(--rule-soft);cursor:pointer;color:var(--ink);background:0 0;border-radius:6px;padding:6px 10px;font-size:16px}.app-shell-header .icon-btn:hover{background:var(--paper-2)}.app-sidebar{background:var(--paper);border-right:1px solid var(--rule);z-index:60;grid-area:sidebar;width:84vw;max-width:280px;padding:18px 14px;transition:transform .22s;position:fixed;inset:0 auto 0 0;overflow-y:auto;transform:translate(-100%)}.app-sidebar.open{transform:translate(0)}.app-sidebar-backdrop{z-index:55;background:#1f1b1680;display:none;position:fixed;inset:0}.app-sidebar-backdrop.open{display:block}.app-main{flex-direction:column;grid-area:main;gap:14px;min-width:0;padding:14px;display:flex;overflow-x:hidden}.app-communicator{background:var(--paper);border-left:1px solid var(--rule);z-index:60;flex-direction:column;grid-area:communicator;width:92vw;max-width:360px;transition:transform .22s;display:flex;position:fixed;inset:0 0 0 auto;overflow-y:auto;transform:translate(100%)}.app-communicator.open{transform:translate(0)}.communicator-toggle{z-index:40;background:var(--ink);color:var(--paper);cursor:pointer;width:52px;height:52px;box-shadow:4px 4px 0 var(--paper-3);border:none;border-radius:999px;font-size:22px;position:fixed;bottom:18px;right:18px}@media (min-width:768px){.app-shell{grid-template:"sidebar main"1fr"sidebar main"/minmax(180px,220px) minmax(0,1fr)}.app-shell-header{display:none}.app-sidebar{top:0;width:auto;max-width:none;height:100vh;position:sticky;inset:auto;transform:none}.app-sidebar-backdrop{display:none!important}.app-main{padding:18px}}@media (min-width:1280px){.app-shell{grid-template-columns:minmax(180px,220px) minmax(0,1fr) minmax(280px,340px);grid-template-areas:"sidebar main communicator"}.app-communicator{top:0;width:auto;max-width:none;height:100vh;position:sticky;inset:auto;transform:none}.communicator-toggle{display:none}}.nav-item{color:var(--ink);font-family:var(--serif);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:4px;align-items:center;gap:10px;width:calc(100% + 16px);margin:2px -8px;padding:8px 10px;font-size:15px;text-decoration:none;display:flex}.nav-item:hover{background:var(--paper-2)}.nav-item.active{background:var(--ink);color:var(--paper);font-weight:500}.nav-item .glyph{text-align:center;flex-shrink:0;width:20px;font-size:16px}.nav-section{margin-top:16px}.nav-section-label{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px;font-size:10px}.comm-head{border-bottom:1px solid var(--rule);align-items:center;gap:10px;padding:12px 14px;display:flex}.comm-head h3{font-family:var(--serif);flex:1;margin:0;font-size:16px;font-weight:600}.comm-channels{border-bottom:1px solid var(--rule-soft);flex-wrap:wrap;gap:4px;padding:8px 12px;display:flex;overflow-x:auto}.comm-messages{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.comm-msg{background:var(--paper-2);border-radius:6px;flex-direction:column;gap:2px;max-width:85%;padding:8px 10px;display:flex}.comm-msg.self{background:var(--accent-blue);color:var(--paper);align-self:flex-end}.comm-msg .who{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;opacity:.7;font-size:9px}.comm-msg .body{white-space:pre-wrap;font-size:13px;line-height:1.4}.comm-input{border-top:1px solid var(--rule);align-items:flex-end;gap:6px;padding:10px 12px;display:flex}.comm-input textarea{min-height:36px;max-height:120px;font-family:var(--serif);background:var(--paper);border:1px solid var(--rule-soft);resize:vertical;border-radius:4px;flex:1;padding:6px 8px;font-size:14px}.ui-card{background:var(--paper);border:1px solid var(--rule);padding:14px 16px}.ui-card.dashed{border-style:dashed}.ui-card.soft{border-color:var(--rule-soft)}.ui-card.filled{background:var(--paper-2)}.ui-card.danger{border-color:var(--accent-red)}.ui-card.gold{border-color:var(--accent-gold)}.ui-card-head{justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:8px;display:flex}.ui-card-head h3{font-family:var(--serif);letter-spacing:-.01em;margin:0;font-size:16px;font-weight:600}.ui-card-head .meta{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);font-size:10px}
