:root{--ink:#141512;--panel:#efe1b8ea;--paper:#d8bd83;--red:#963845;--green:#6e8e61;--teal:#315f61;--gold:#e5b44f}*{box-sizing:border-box}body{margin:0;background:#111714;color:#1d1a14;font-family:Georgia,'Noto Serif SC','Microsoft YaHei',serif;overflow:hidden}.shell{width:100vw;height:100vh;padding:10px;display:flex;flex-direction:column;gap:8px;background:radial-gradient(circle at 52% 22%,#4d675e,#141916 68%)}.ink-panel{border:2px solid #18140d;border-radius:14px;background:var(--panel);box-shadow:0 4px 0 #0008,inset 0 0 30px #315f6129}.topbar{height:76px;display:flex;align-items:center;justify-content:space-between;padding:10px 14px}.topbar b{letter-spacing:1px}.topbar span{display:block;font-size:13px}.unit{font-size:14px}.chips{display:flex;gap:8px;flex-wrap:wrap}.chips span{background:#14201e;color:#f5df9d;padding:7px 10px;border-radius:999px;border:1px solid #dfbc62}.game-wrap{height:calc(100vh - 104px);display:grid;grid-template-columns:210px 1fr 250px;gap:8px}.left,.right{padding:10px;overflow:auto}button{font:700 13px/1.1 Georgia,'Noto Serif SC',serif;background:#14201e;color:#f5df9d;border:2px solid #090d0b;border-radius:10px;padding:9px 10px;margin:3px;box-shadow:0 2px 0 #000;cursor:pointer}button:hover{filter:brightness(1.18)}.left button{width:100%;margin:4px 0}.settings{background:#263833;color:#f2dc9d;border:1px solid #a87c48;border-radius:10px;padding:5px;margin:5px 0}.hidden{display:none!important}.meters{font-size:13px}.meters label{display:block;margin:12px 0}meter{width:100%;height:12px;accent-color:#6e8e61}.help{font-size:13px;line-height:1.35}.status{min-height:64px;max-height:110px;overflow:auto;background:#14201e;color:#f5df9d;border-radius:10px;padding:10px;border:1px dashed #dfbc62}.board{position:relative;overflow:hidden;border:3px solid #080b09;border-radius:18px;background:#18221e;box-shadow:inset 0 0 45px #000}.scene-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.04) contrast(1.06)}.asset-proof{position:absolute;z-index:4;border:1px solid #dfbc62;background:#e8d9b8cc;border-radius:8px;overflow:hidden;opacity:.88}.asset-proof img{display:block;width:100%;height:100%;object-fit:cover}.furniture-strip{right:8px;bottom:8px;width:116px;height:116px}.creature-strip{left:8px;bottom:8px;width:112px;height:112px}.routes{position:absolute;inset:0;z-index:5;pointer-events:none}.route-line{stroke:#f0d273;stroke-width:4;stroke-dasharray:8 8;filter:drop-shadow(0 1px 1px #000)}.route-line.closed{stroke:#963845;opacity:.38}.zones{position:absolute;inset:0;z-index:8;pointer-events:none}.zone{position:absolute;border:2px dashed #94bd75;background:#bfe39d1c;color:#fff0b8;text-shadow:1px 1px #000;padding:3px 6px;border-radius:12px;font-size:12px}.zone.path-on{border-style:solid;background:#315f614d}.door{position:absolute;width:20px;height:20px;border-radius:50%;background:#f1d463;color:#24180d;font-weight:bold;text-align:center;line-height:20px;border:2px solid #111;z-index:12}.prop{position:absolute;z-index:16;border:0;margin:0;padding:0;background-image:url('assets/generated/furniture-props.png');background-size:500% 500%;background-color:transparent;filter:drop-shadow(2px 5px 2px #0009);touch-action:none}.prop.editing{outline:2px dashed #f3de84}.prop.editing::before,.prop.editing::after{content:'';position:absolute;width:10px;height:10px;background:#f1dd75;border:2px solid #111}.prop.editing::before{left:-7px;top:-7px}.prop.editing::after{right:-7px;bottom:-7px}.fire{width:82px;height:82px;background-position:0% 0%}.pot{width:78px;height:78px;background-position:25% 0%}.tent{width:108px;height:88px;background-position:50% 0%}.bench{width:96px;height:76px;background-position:75% 0%}.lantern{width:70px;height:86px;background-position:0% 25%}.crate{width:90px;height:80px;background-position:25% 25%}.berries{width:72px;height:72px;background-position:50% 25%}.gatling{width:92px;height:70px;left:58%;top:57%;background-position:75% 25%}.gatling span{position:absolute;left:8px;top:-24px;background:#f5df95;color:#21180f;border:2px solid #21180f;border-radius:12px;padding:3px 8px;white-space:nowrap}.survivor{position:absolute;z-index:30;width:72px;height:76px;left:48%;top:47%;background-image:url('assets/generated/character-creatures.png');background-size:500% 500%;background-position:0% 0%;filter:drop-shadow(2px 5px 2px #000a);cursor:grab;touch-action:none}.survivor span{position:absolute;left:-4px;bottom:-18px;color:#fff3c4;text-shadow:1px 1px #000;font-size:12px}.monster{position:absolute;z-index:22;width:66px;height:66px;background-image:url('assets/generated/character-creatures.png');background-size:500% 500%;filter:drop-shadow(2px 4px 2px #000);transition:left .4s linear,top .4s linear}.m1{background-position:25% 0}.m2{background-position:50% 0}.m3{background-position:75% 0}.m4{background-position:0 25%}.m5{background-position:25% 25%}.damage{position:absolute;z-index:50;color:#ffdf6a;font:bold 22px Georgia;text-shadow:2px 2px #7a1010;animation:float 1.1s forwards}@keyframes float{to{transform:translateY(-35px);opacity:0}}.path-editor{position:absolute;left:14px;top:12px;right:14px;bottom:12px;z-index:40;border:2px solid #a7d675;border-radius:16px;background:#10120a35;pointer-events:none}.path-editor p{position:absolute;left:16px;bottom:8px;right:80px;color:#f3e5ab;background:#14201ee8;padding:8px;border-radius:8px}.plus{position:absolute;right:18px;bottom:14px;width:48px;height:44px;font-size:24px;pointer-events:auto}.failure{position:absolute;inset:15%;z-index:80;background:#151d1add;color:#f7dc98;border:4px double #e0bc65;border-radius:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 0 0 9999px #0008}.failure h2{font-size:34px;color:#f1b46a}.failure.win{background:#1d342cdd}.failure.win h2{color:#f6d870}.tabs{display:flex}.tabs button{flex:1}.tabs .active{background:#963845}.right h3{margin:10px 0 6px}.stock{height:100px;border:2px solid #18140d;border-radius:12px;overflow:hidden;background:#eadbb7}.stock img{width:100%;height:100%;object-fit:cover}.stock.creatures img{object-position:left top}.right ul{margin:8px 0 8px 18px;padding:0;font-size:13px;line-height:1.45}@media(max-width:900px){.game-wrap{grid-template-columns:160px 1fr}.right{display:none}.topbar{font-size:12px}.chips span{padding:5px}.left{font-size:12px}}
