@font-face{font-family:MedievalSharp;font-style:normal;font-weight:400;font-display:swap;src:url(/assets/fonts/medievalsharp-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:MedievalSharp;font-style:normal;font-weight:400;font-display:swap;src:url(/assets/fonts/medievalsharp-latin-ext.woff2) format("woff2");unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#24170f;background:#15120f;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--border: #8a6332;--border-bright: #d3a94f;--ink-muted: #6b5740;--panel: #f3dfb3;--panel-deep: #d7b978;--accent: #8f2d22;--accent-strong: #5c1711;--forest: #214f37;--gold: #c89632;--sand: #dbc081;--stone: #211c19;--stone-mid: #3a3027;--violet: #59456e;--heading-font: "MedievalSharp", cursive;--parchment-bg: linear-gradient(rgb(255 232 178 / 72%), rgb(224 186 111 / 68%)), url(/assets/ui/map-board.jpg);--stone-bg: linear-gradient(rgb(12 10 9 / 16%), rgb(12 10 9 / 46%)), url(/assets/ui/fantasy-backdrop.jpg)}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0;background:var(--stone-bg);background-attachment:fixed;background-position:center;background-size:auto,cover}button,select,input{font:inherit}button{cursor:pointer}.home-page{min-height:100vh;display:grid;place-items:center;padding:28px;background:var(--stone-bg);background-position:center;background-size:auto,cover}.home-shell{width:min(640px,100%);display:grid;grid-template-columns:1fr;gap:24px;align-items:stretch}.home-heading{text-align:center}.home-heading p,.graph-title p{margin:0 0 8px;color:var(--gold);font-family:var(--heading-font);font-size:.8rem;font-weight:400;letter-spacing:0;text-transform:uppercase;text-shadow:0 1px 0 #120c08}.home-heading p{font-size:1.08rem}.home-heading h1,.graph-title h1,.empty-state h1{margin:0;color:#f8e8b7;font-family:var(--heading-font);font-weight:400;font-size:clamp(2.4rem,8vw,5.6rem);line-height:.98;letter-spacing:0;text-shadow:0 2px 0 #3b1b12,0 8px 22px rgb(0 0 0 / 46%)}.template-form{display:grid;gap:20px;padding:26px;border:3px solid #5e3b1d;border-radius:8px;background:var(--parchment-bg);background-position:center;background-size:auto,cover;box-shadow:0 0 0 1px #d9ad57,0 0 0 5px #160e08b8,inset 0 0 0 1px #fff8ce99,inset 0 0 28px #5f32102e,0 24px 80px #00000070}label{position:relative;display:grid;gap:9px;color:#5b321e;font-size:.86rem;font-weight:900;text-transform:uppercase;text-shadow:0 1px 0 rgb(255 239 185 / 62%)}.template-form label:after{content:"";position:absolute;right:17px;bottom:19px;width:10px;height:10px;border-right:2px solid #4a2a12;border-bottom:2px solid #4a2a12;pointer-events:none;transform:rotate(45deg);filter:drop-shadow(0 1px 0 rgb(255 237 174 / 62%))}select{width:100%;min-height:48px;padding:0 44px 0 16px;color:#2b180d;border:2px solid #5b3518;border-radius:4px;background:linear-gradient(135deg,transparent 0 10px,rgb(255 236 169 / 34%) 10px 12px,transparent 12px),linear-gradient(225deg,transparent 0 10px,rgb(255 236 169 / 34%) 10px 12px,transparent 12px),linear-gradient(180deg,#fff0bd,#d8b16a 48%,#ad7a37);box-shadow:0 0 0 1px #ecbe5999,inset 0 2px #fffbdcb3,inset 0 -4px #4827113d,0 4px #45271466;font-weight:850;appearance:none}select:hover{background:linear-gradient(135deg,transparent 0 10px,rgb(255 236 169 / 40%) 10px 12px,transparent 12px),linear-gradient(225deg,transparent 0 10px,rgb(255 236 169 / 40%) 10px 12px,transparent 12px),linear-gradient(180deg,#fff6ca,#e0ba72 48%,#b9823b)}select:focus,button:focus-visible,input:focus-visible{outline:3px solid rgb(211 169 79 / 36%);outline-offset:2px}.primary-button,.ghost-button,.secondary-button{min-height:44px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;gap:10px;border:1px solid transparent;font-weight:800}.primary-button{color:#fff1c2;border:2px solid #3a1510;background:linear-gradient(135deg,transparent 0 11px,rgb(255 204 112 / 22%) 11px 13px,transparent 13px),linear-gradient(225deg,transparent 0 11px,rgb(255 204 112 / 22%) 11px 13px,transparent 13px),linear-gradient(180deg,#bd4b31,#8b2b1d 48%,#55150f);box-shadow:0 0 0 1px #d79f42,inset 0 1px #ffda9a57,inset 0 -4px #300d096b,0 5px #2a0e0a,0 12px 24px #26100a47;text-transform:uppercase;text-shadow:0 2px 0 #36120d}.primary-button:hover{background:linear-gradient(135deg,transparent 0 11px,rgb(255 204 112 / 26%) 11px 13px,transparent 13px),linear-gradient(225deg,transparent 0 11px,rgb(255 204 112 / 26%) 11px 13px,transparent 13px),linear-gradient(180deg,#cf5b3e,#922f20 48%,#5b1710)}.ghost-button{min-height:46px;padding:0 16px;color:#f3dfb3;background:linear-gradient(135deg,transparent 0 10px,rgb(255 226 151 / 16%) 10px 12px,transparent 12px),linear-gradient(225deg,transparent 0 10px,rgb(255 226 151 / 16%) 10px 12px,transparent 12px),linear-gradient(180deg,#4a3726,#2b211b 48%,#140f0d);border:2px solid #8e672e;box-shadow:0 0 0 1px #e7b45347,inset 0 1px #ffe8b22e,inset 0 -3px #00000057,0 4px #120c08;font-size:1rem;text-shadow:0 2px 0 #120c08}.secondary-button{min-height:34px;padding:0 10px;color:#f5dfa9;background:linear-gradient(180deg,#6f3424,#421812);border-color:#ad7d38;font-size:.82rem;box-shadow:inset 0 1px #ffebaf33}.graph-page{min-height:100vh;display:grid;grid-template-rows:auto minmax(760px,max(760px,min(1040px,72vw))) auto;background:var(--stone-bg);background-attachment:fixed;background-position:center;background-size:auto,cover}.graph-header{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;padding:14px 20px 16px;border-bottom:2px solid #9b7134;background:linear-gradient(180deg,#1a1411d1,#0b0908eb),url(/assets/ui/fantasy-backdrop.jpg);background-position:top center;background-size:auto,cover;box-shadow:inset 0 -1px #ffebaa29,0 10px 28px #00000057}.graph-title h1{font-size:1.45rem;line-height:1.1}.graph-title p{margin:2px 0 0}.variant-picker{display:inline-flex;align-items:center;gap:10px;color:#f8e8b7;font-weight:850;text-transform:uppercase;text-shadow:0 2px 0 #120c08}.variant-button-group{display:inline-flex;gap:6px;padding:6px;border:2px solid #8e672e;border-radius:6px;background:linear-gradient(180deg,#0f0b09,#2b211b);box-shadow:0 0 0 1px #e7b45338,inset 0 0 14px #000000a8,0 4px #0b0807}.variant-button{width:42px;height:38px;display:grid;place-items:center;border:2px solid #7e5b2d;border-radius:4px;color:#ead09a;background:linear-gradient(135deg,transparent 0 9px,rgb(255 226 151 / 12%) 9px 11px,transparent 11px),linear-gradient(225deg,transparent 0 9px,rgb(255 226 151 / 12%) 9px 11px,transparent 11px),linear-gradient(180deg,#4a3726,#2c2119 48%,#15100d);font-weight:850;box-shadow:inset 0 1px #ffe8b221,inset 0 -3px #00000047;text-shadow:0 2px 0 #120c08}.variant-button.is-active{color:#2c1709;border-color:#4a2a12;background:linear-gradient(135deg,transparent 0 9px,rgb(255 251 220 / 40%) 9px 11px,transparent 11px),linear-gradient(225deg,transparent 0 9px,rgb(255 251 220 / 40%) 9px 11px,transparent 11px),linear-gradient(180deg,#ffe28a,#c58b31 48%,#8a541d);box-shadow:0 0 0 1px #f4d06b,inset 0 1px #fffcd6b3,inset 0 -3px #5e310f47,0 0 18px #f4d06b61;text-shadow:0 1px 0 rgb(255 237 174 / 62%)}.graph-workspace{min-width:0;min-height:0;display:grid;grid-template-columns:minmax(0,1fr);padding:10px 12px 12px;overflow:hidden}.graph-canvas-wrap{min-width:0;min-height:0;display:grid;overflow:hidden}.connection-legend{display:flex;flex-wrap:wrap;align-items:center;gap:10px 16px;margin:0 20px 14px;padding:10px 14px;color:#f3dfb3;font-size:.86rem;font-weight:800;border:1px solid #8a6332;border-radius:8px;background:linear-gradient(180deg,#32271fe0,#1b1613e5);box-shadow:inset 0 1px #ffebaa1a}.connection-legend-title{color:#d3a94f}.connection-legend span:not(.connection-legend-title){display:inline-flex;align-items:center;gap:7px}.legend-line{width:28px;height:0;border-top:4px solid currentColor;border-radius:999px}.legend-line-road{color:#2f7d3b}.legend-line-optional{color:#d4a51f}.legend-line-roadless{color:#b93c32}.graph-canvas{width:100%;height:100%;min-height:0;display:block;border:2px solid #4d341b;border-radius:10px;background:linear-gradient(#ffeec42e,#dbaf5e14),url(/assets/ui/map-board.jpg);background-position:center;background-size:auto,100% 100%;box-shadow:inset 0 0 0 1px #ffeeb47a,0 18px 64px #00000085}.mobile-zone-details{display:none}.graph-grid{opacity:.26}.graph-grid line{stroke:#5c39196b;stroke-width:1}.graph-edge{fill:none;stroke:#513b25;stroke-linecap:round;stroke-linejoin:round;stroke-width:3;filter:drop-shadow(0 1px 0 rgb(255 240 190 / 42%))}.graph-edge-control{cursor:pointer}.graph-edge-hit{fill:none;stroke:transparent;stroke-linecap:round;stroke-linejoin:round;stroke-width:22;pointer-events:stroke}.graph-edge-control.is-selected .graph-edge{stroke:#fff0a8;stroke-width:5;filter:drop-shadow(0 0 5px rgb(255 213 91 / 70%))}.connection-portal .graph-edge{stroke:#68448e}.road-rule-mandatory-road .graph-edge{stroke:#2f8a45}.road-rule-optional-roadless-or-absent .graph-edge,.road-rule-mandatory-roadless .graph-edge{stroke:#bd3b2d}.road-rule-optional-road .graph-edge{stroke:#d8b032}.road-rule-optional-road.road-status-has-road .graph-edge{stroke:#2f7d3b}.road-rule-optional-road.road-status-no-road .graph-edge{stroke:#b93c32}.connection-offroad .graph-edge{stroke-dasharray:none}.edge-wide{stroke-width:4;stroke-dasharray:none}.connection-subterraneanGate .graph-edge{stroke-dasharray:none}.connection-optional.optional-unknown .graph-edge,.connection-optional.optional-absent .graph-edge{opacity:.38}.connection-optional.optional-present .graph-edge{opacity:1}.graph-edge-label{pointer-events:none}.edge-label-marker{fill:#f8e9bf;stroke:#61411c;stroke-width:1.5;filter:drop-shadow(0 2px 2px rgb(0 0 0 / 38%))}.edge-portal-image{image-rendering:pixelated;pointer-events:none;filter:drop-shadow(0 1px 1px rgb(23 32 27 / 35%))}.graph-edge-labels text{fill:#26170e;font-size:17px;font-weight:850;pointer-events:none}.graph-node{cursor:pointer}.graph-node .node-fill{fill:#2a231d}.graph-node .node-frame{fill:none;stroke:#1a110b;stroke-width:3;filter:drop-shadow(0 2px 2px rgb(0 0 0 / 36%))}.graph-node.is-selected .node-frame{stroke:#f4d06b;stroke-width:5;filter:drop-shadow(0 0 7px rgb(255 213 91 / 70%))}.graph-node.zone-type-central .node-frame{stroke-width:5}.node-terrain-image,.node-town-image{pointer-events:none;image-rendering:pixelated}.node-resource-marker{pointer-events:none}.node-resource-marker rect{fill:#f7e6b8;stroke:#1b120c;stroke-width:1.5;filter:drop-shadow(0 1px 1px rgb(0 0 0 / 42%))}.node-resource-marker image{image-rendering:pixelated}.graph-node text{fill:#24170f;font-weight:850;paint-order:stroke;pointer-events:none;stroke:#f8e9bfe5;stroke-linejoin:round;stroke-width:3px}.node-label,.zone-type-label{font-size:11px}.zone-type-label{fill:#7a2519}.zone-type-starting .zone-type-label{fill:#2d6045}.zone-type-central .zone-type-label{fill:#24170f}.terrain-none .node-fill{fill:#2a231d}.terrain-dirt .node-fill{fill:#d7c5a5}.terrain-sand .node-fill{fill:#e0bf72}.terrain-grass .node-fill{fill:#cfe2c4}.terrain-highlands .node-fill{fill:#b7ce93}.terrain-snow .node-fill{fill:#d9ebef}.terrain-swamp .node-fill{fill:#9eb88f}.terrain-rough .node-fill{fill:#d7b184}.terrain-wasteland .node-fill{fill:#d6ac62}.terrain-subterranean .node-fill{fill:#c4b5cf}.terrain-lava .node-fill{fill:#d28f74}.owner-none .owner-strip{display:none}.owner-bg-none{fill:#f3dfb3;background:#f3dfb3}.owner-red .owner-strip,.owner-bg-red{fill:#c92e27;background:#c92e27}.owner-blue .owner-strip,.owner-bg-blue{fill:#2363b7;background:#2363b7}.owner-tan .owner-strip,.owner-bg-tan{fill:#b38c58;background:#b38c58}.owner-green .owner-strip,.owner-bg-green{fill:#2f8a45;background:#2f8a45}.owner-orange .owner-strip,.owner-bg-orange{fill:#d46d20;background:#d46d20}.owner-purple .owner-strip,.owner-bg-purple{fill:#7246a1;background:#7246a1}.owner-teal .owner-strip,.owner-bg-teal{fill:#168a89;background:#168a89}.owner-pink .owner-strip,.owner-bg-pink{fill:#cc6d9d;background:#cc6d9d}.zone-details{min-width:0;min-height:0;overflow:auto;padding:16px;border:2px solid var(--border);border-radius:8px;background:var(--parchment-bg);background-position:center;background-size:auto,cover;box-shadow:inset 0 0 0 1px #fff8ce94,inset 0 0 24px #522d1029,0 18px 60px #00000052}.zone-details-in-modal{height:100%;max-height:min(720px,calc(100vh - 32px));overflow:auto;border:0;border-radius:0;box-shadow:none}.zone-details-heading{display:flex;gap:12px;align-items:center;padding-bottom:14px;border-bottom:2px solid rgb(138 99 50 / 42%)}.owner-dot{width:18px;height:18px;flex:0 0 auto;border:2px solid #22150d;border-radius:999px;box-shadow:0 0 0 2px #f4d06b4d,0 2px 4px #00000042}.zone-details h2,.zone-details h3,.zone-details p,.zone-property-list{margin:0}.zone-details h2{color:#3d1b12;font-family:var(--heading-font);font-size:1.34rem;font-weight:400;line-height:1.1}.zone-details-heading p,.zone-empty{color:#6b5740;font-size:.9rem}.town-visual-block{position:relative;display:grid;gap:10px;margin-top:16px;padding:12px;border:1px solid #aa7f3c;border-radius:8px;background:linear-gradient(180deg,#fff2cab3,#c38f4238);box-shadow:inset 0 1px #fffce0a8}.town-visual-block span{display:block;color:#6a3d24;font-size:.76rem;font-weight:800;text-transform:uppercase}.town-visual-block strong{display:block;margin-top:2px;font-size:1.06rem}.town-portrait{width:100%;height:170px;object-fit:contain;image-rendering:pixelated;border:2px solid #8a6332;border-radius:6px;background:linear-gradient(180deg,#332820,#171310)}.zone-property-list{display:grid;gap:10px;padding:16px 0}.zone-property-list div{display:grid;grid-template-columns:minmax(88px,.8fr) minmax(0,1fr);gap:12px;align-items:baseline}.zone-property-list dt{color:#6a3d24;font-size:.78rem;font-weight:800;text-transform:uppercase}.zone-property-list dd{min-height:34px;margin:0;display:flex;gap:8px;align-items:center;justify-content:space-between;font-weight:750}.terrain-value{min-width:0;display:inline-flex;align-items:center;gap:8px}.terrain-indicator{width:24px;height:24px;flex:0 0 auto;object-fit:cover;image-rendering:pixelated;border:1px solid #1b120c;border-radius:6px;background:#f8e9bf;box-shadow:0 1px 2px #00000038}.terrain-indicator-empty{display:inline-block;border-color:#8a6332;background:linear-gradient(135deg,transparent 46%,#8a6332 47%,#8a6332 53%,transparent 54%),#f8e9bf}.portal-value{width:100%;min-width:0;display:inline-flex;align-items:center;gap:10px}.portal-indicator{width:42px;height:42px;flex:0 0 auto;object-fit:contain;image-rendering:pixelated;border:1px solid #8a6332;border-radius:7px;background:#f8e9bf}.inline-edit-button{width:30px;height:30px;flex:0 0 auto;display:grid;place-items:center;border:1px solid #9b7134;border-radius:7px;color:#f4d06b;background:linear-gradient(180deg,#44362a,#211916);box-shadow:inset 0 1px #ffe8b224}.town-visual-block>.inline-edit-button{position:absolute;right:10px;bottom:10px}.inline-edit-control{min-height:34px;padding-left:9px;font-size:.9rem}.inline-checkbox{display:inline-flex;gap:8px;align-items:center;color:#24170f;font-weight:750}.inline-checkbox input{width:16px;height:16px;accent-color:var(--accent)}.mine-section{display:grid;gap:10px;padding-top:2px}.mine-section h3{font-size:.86rem;text-transform:uppercase;color:#6a3d24}.mine-section-heading{display:flex;align-items:center;justify-content:space-between;gap:8px}.mine-list{display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0;list-style:none}.mine-list li{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;border:1px solid #9b7134;border-radius:7px;background:linear-gradient(180deg,#fff0c2,#d7b978);font-size:.82rem;font-weight:800;box-shadow:inset 0 1px #fffce0ad,0 1px 2px #00000024}.resource-icon{width:18px;height:18px;object-fit:contain;image-rendering:pixelated;flex:0 0 auto}.zone-reset-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;padding-top:14px;border-top:2px solid rgb(138 99 50 / 38%)}.zone-done-button{margin-left:auto}.template-notes{display:grid;margin:0 20px 24px;border:2px solid var(--border);border-radius:8px;background:var(--parchment-bg);background-position:center;background-size:auto,cover;overflow:hidden;box-shadow:inset 0 0 0 1px #fff8ce8a,0 16px 44px #00000047}.template-notes h2,.template-notes h3{margin:0}.template-notes h2{color:#3d1b12;font-family:var(--heading-font);font-size:1.3rem;font-weight:400}.template-notes-toggle{width:100%;min-height:54px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 18px;border:0;color:#24170f;background:transparent;text-align:left}.template-notes-toggle-icon{flex:0 0 auto;color:var(--accent);transition:transform .16s ease}.template-notes-toggle[aria-expanded=true] .template-notes-toggle-icon{transform:rotate(180deg)}.template-notes-content{display:grid;gap:14px;padding:0 18px 18px}.note-block{display:grid;gap:8px}.note-block h3{color:#6a3d24;font-size:.82rem;text-transform:uppercase}.note-block ul{display:grid;gap:6px;margin:0;padding-left:18px}.note-block li{line-height:1.35}.note-block a{color:var(--accent);font-weight:800}.zone-modal{position:fixed;inset:0;z-index:20;display:grid;place-items:center;padding:24px;background:linear-gradient(#080605b8,#080605cc),url(/assets/ui/fantasy-backdrop.jpg);background-position:center;background-size:auto,cover}.zone-modal-panel{position:relative;width:min(500px,100%);max-height:min(720px,calc(100vh - 32px));overflow:hidden;border:3px solid #8a6332;border-radius:8px;background:var(--parchment-bg);background-position:center;background-size:auto,cover;box-shadow:inset 0 0 0 1px #fff8ce94,0 30px 110px #0000007a}.modal-close-button{position:absolute;top:12px;right:12px;z-index:1;width:36px;height:36px;display:grid;place-items:center;border:1px solid #9b7134;border-radius:7px;color:#f4d06b;background:linear-gradient(180deg,#44362a,#211916);box-shadow:inset 0 1px #ffe8b224,0 2px 4px #00000038}.empty-state{display:grid;place-items:center;padding:24px;color:#f8e8b7}@media(max-width:720px){.home-page{place-items:stretch}.home-shell{grid-template-columns:1fr;gap:26px;align-content:center}.graph-header{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px 16px;padding:12px 20px 14px}.ghost-button{justify-self:start}.variant-picker{grid-column:1 / -1}.graph-page{display:block}.graph-workspace{grid-template-columns:1fr;gap:12px;padding:12px;overflow:hidden}.graph-canvas-wrap{overflow-x:auto;overflow-y:hidden;padding-bottom:6px}.graph-canvas{width:100%;min-width:clamp(760px,130vw,960px);height:auto}.zone-details{min-height:auto;overflow:visible}.mobile-zone-details{display:block}.zone-modal:not(.connection-modal){display:none}.template-notes{margin:0 12px 18px}}
