:root{--bg:#faf3e6;--card-bg:#fffdfa;--card-border:#e7ddcd;--fg:#20242b;--fg-secondary:#4b4438;--muted:#6b6358;--input-bg:#fffdfa;--input-border:#d9cbb5;--input-focus:#9d2235;--input-focus-ring:#9d223533;--accent-fill:#9d2235;--accent-fg:#fdf3ea;--gold:#d99a1f;--gold-bright:#ffd166;--success:#15803d;--success-bg:#f0fdf4;--warning:#92400e;--warning-bg:#fffbeb;--error:#b91c1c;--error-bg:#fef2f2;--pill-bg:#f3ece1;--pill-hover:#ece2d2;--pin-ring-inner:#fdf9f2;--pin-ring-outer:#1b1610}@media (prefers-color-scheme:dark){:root{--bg:#14171d;--card-bg:#1b1f27;--card-border:#2b313c;--fg:#e9e6e1;--fg-secondary:#d9d5cb;--muted:#c9cfd8;--input-bg:#14171d;--input-border:#3b414c;--input-focus:#ff8097;--input-focus-ring:#ff809740;--accent-fill:#9e3346;--accent-fg:#ffe1e7;--gold:#ffd166;--gold-bright:#ffd166;--success:#4ade80;--success-bg:#052e16;--warning:#fbbf24;--warning-bg:#1c1004;--error:#fca5a5;--error-bg:#1f0707;--pill-bg:#252a33;--pill-hover:#2f3540;--pin-ring-inner:#f5ede0;--pin-ring-outer:#0b0805}}*,:before,:after{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5}.app{flex-direction:column;gap:16px;max-width:1180px;margin:0 auto;padding:16px;display:flex;container-type:inline-size}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.button-primary,.button-secondary,.button-danger{font:inherit;cursor:pointer;letter-spacing:.01em;border-radius:8px;padding:10px 18px;font-size:15px;font-weight:600}.button-primary{background:var(--accent-fill);color:var(--accent-fg);border:none}.button-primary:hover{filter:brightness(1.08)}.button-primary:disabled{opacity:.6;cursor:progress}.button-secondary{background:var(--pill-bg);color:var(--fg);border:1px solid var(--input-border)}.button-secondary:hover{border-color:var(--input-focus)}.button-secondary:disabled{opacity:.5;cursor:not-allowed}.button-danger{color:var(--error);border:1px solid var(--error);background:0 0}.button-danger:hover{background:var(--error-bg)}.button-primary:focus-visible,.button-secondary:focus-visible,.button-danger:focus-visible{outline:2px solid var(--input-focus);outline-offset:2px}.landing{flex-direction:column;align-items:flex-start;gap:12px;display:flex}.landing-eyebrow{text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:0;font-size:12px;font-weight:700}.landing-title{letter-spacing:-.02em;color:var(--fg);margin:0;font-size:24px;font-weight:800}.landing-subtitle{color:var(--fg-secondary);max-width:60ch;margin:0;font-size:16px;line-height:1.6}.status-view{text-align:center;color:var(--fg-secondary);flex-direction:column;align-items:center;gap:14px;padding:48px 16px;display:flex}.map-frame{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;width:100%;max-width:460px;margin:0 auto;padding:8px;position:relative}.map-surface{aspect-ratio:1648/2551;cursor:grab;touch-action:none;background:#f4efe6;border-radius:8px;width:100%;position:relative;overflow:hidden}.map-surface-editable{cursor:crosshair}.map-surface:active{cursor:grabbing}.map-zoom-wrapper{transform-origin:0 0;will-change:transform;position:absolute;inset:0}.map-surface-img{object-fit:fill;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;display:block}@media (prefers-color-scheme:dark){.map-surface{background:#201d18}.map-surface-img{filter:brightness(.9)}}.pin-layer{pointer-events:none;position:absolute;inset:0}.map-surface:focus-visible{outline:3px solid var(--input-focus);outline-offset:2px}.map-zoom-controls{z-index:2;flex-direction:column;gap:6px;display:flex;position:absolute;top:14px;right:14px}.map-zoom-btn{width:38px;height:38px;color:var(--fg);background:var(--card-bg);border:1px solid var(--input-border);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;font-size:22px;font-weight:600;line-height:1;display:flex;box-shadow:0 1px 3px #00000047}.map-zoom-btn:hover{background:var(--pill-hover);border-color:var(--input-focus)}.map-zoom-btn:focus-visible{outline:2px solid var(--input-focus);outline-offset:2px}.map-caption{flex-direction:column;gap:2px;margin:8px 2px 2px;display:flex}.map-caption-hint{color:var(--fg-secondary);font-size:12.5px;font-weight:600;line-height:1.4}.map-caption-credit{color:var(--muted);font-size:11.5px;line-height:1.4}.pin-marker{transform-origin:50% 100%;width:40px;height:40px;transform:translate(-50%, -100%) scale(calc(1 / var(--zoom,1)));cursor:grab;pointer-events:auto;touch-action:none;background:0 0;border:none;justify-content:center;align-items:flex-end;padding:0;display:flex;position:absolute}.pin-marker-dot{background:var(--pin-color-light);border:2px solid var(--pin-ring-inner);width:18px;height:18px;box-shadow:0 0 0 2px var(--pin-ring-outer), 0 2px 4px #00000080;border-radius:50% 50% 50% 0;transform:rotate(45deg)}@media (prefers-color-scheme:dark){.pin-marker-dot{background:var(--pin-color-dark)}}.pin-marker.editing .pin-marker-dot{box-shadow:0 0 0 2px var(--pin-ring-outer), 0 0 0 5px var(--input-focus-ring), 0 2px 4px #00000080}.pin-marker.highlighted .pin-marker-dot{box-shadow:0 0 0 2px var(--pin-ring-outer), 0 0 0 5px var(--gold-bright), 0 2px 4px #00000080}.pin-marker:focus-visible{outline:2px solid var(--input-focus);outline-offset:2px;border-radius:4px}@media (prefers-reduced-motion:no-preference){@keyframes pin-pop{0%{opacity:0;transform:translate(-50%,-100%)scale(0)}60%{transform:translate(-50%, -100%) scale(calc(1.15 / var(--zoom,1)));opacity:1}to{transform:translate(-50%, -100%) scale(calc(1 / var(--zoom,1)));opacity:1}}.pin-marker{animation:.22s ease-out pin-pop}}.color-picker{flex-direction:column;gap:8px;display:flex}.color-picker-caption{color:var(--fg-secondary);margin:0;font-size:13px;font-weight:600}.color-swatches{flex-wrap:wrap;gap:8px;display:flex}.color-swatch{background:var(--pill-bg);border:1px solid var(--input-border);cursor:pointer;color:var(--fg);border-radius:999px;align-items:center;gap:6px;min-height:40px;padding:6px 10px 6px 6px;font-size:14px;display:flex}.color-swatch:hover{border-color:var(--input-focus)}.color-swatch.selected{border-color:var(--input-focus);background:var(--pill-hover);font-weight:600}.color-swatch:focus-visible{outline:2px solid var(--input-focus);outline-offset:2px}.color-swatch-dot{background:var(--swatch-color-light);border:1px solid #00000026;border-radius:50%;flex-shrink:0;width:16px;height:16px}@media (prefers-color-scheme:dark){.color-swatch-dot{background:var(--swatch-color-dark);border-color:#fff3}}.color-swatch-name{white-space:nowrap}.legend{border:1px solid var(--card-border);border-radius:10px;flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex;overflow:hidden}.legend-empty{border:1px dashed var(--card-border);border-radius:10px;padding:16px}.legend-hint{color:var(--muted);margin:0;font-size:14px}.legend-row{background:var(--card-bg);border:none;border-bottom:1px solid var(--card-border);cursor:pointer;width:100%;font:inherit;color:var(--fg);text-align:left;align-items:center;gap:10px;padding:8px 12px;font-size:14px;display:flex}li:last-child .legend-row{border-bottom:none}.legend-row:hover{background:var(--pill-bg)}.legend-row.highlighted{background:var(--pill-hover);font-weight:600}.legend-row:focus-visible{outline:2px solid var(--input-focus);outline-offset:-2px}.legend-swatch{background:var(--swatch-color-light);border:1px solid #00000026;border-radius:50%;flex-shrink:0;width:14px;height:14px}@media (prefers-color-scheme:dark){.legend-swatch{background:var(--swatch-color-dark);border-color:#fff3}}.legend-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.pin-editor{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;flex-direction:column;gap:12px;padding:14px;display:flex}.pin-editor-field{flex-direction:column;gap:4px;display:flex}.pin-editor-field-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.pin-editor input[type=text]{font:inherit;color:var(--fg);background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;outline:none;padding:8px 11px;font-size:16px}.pin-editor input[type=text]:focus{border-color:var(--input-focus);box-shadow:0 0 0 3px var(--input-focus-ring)}.pin-editor-actions{flex-wrap:wrap;gap:10px;display:flex}.map-bar{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;flex-direction:column;gap:12px;padding:14px;display:flex}.map-bar-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.map-bar-name{min-width:160px;font:inherit;color:var(--fg);background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;outline:none;flex:1;padding:7px 11px;font-size:17px;font-weight:700}.map-bar-name:focus{border-color:var(--input-focus);box-shadow:0 0 0 3px var(--input-focus-ring)}.sync-badge{white-space:nowrap;border-radius:999px;padding:4px 10px;font-size:13px;font-weight:600}.sync-badge-saved{color:var(--success);background:var(--success-bg)}.sync-badge-saving{color:var(--muted);background:var(--pill-bg)}.sync-badge-pending{color:var(--warning);background:var(--warning-bg)}.sync-badge-error{color:var(--error);background:var(--error-bg)}.map-bar-links{border-top:1px solid var(--card-border);flex-direction:column;gap:8px;padding-top:10px;display:flex}.map-bar-link-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.map-bar-link-label{color:var(--fg-secondary);font-size:13px;font-weight:600}.map-bar-link-caption{color:var(--muted);margin:0;font-size:13px;line-height:1.5}.map-bar-link-subtext{color:var(--muted);margin:2px 0 0;font-size:12px;line-height:1.4}.readonly-view{flex-direction:column;gap:14px;display:flex}.readonly-eyebrow{text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:0;font-size:12px;font-weight:700}.readonly-title{color:var(--fg);margin:-6px 0 0;font-size:22px;font-weight:800}.readonly-duplicate-caption{color:var(--muted);margin:-6px 0 0;font-size:13px}.editor{flex-direction:column;gap:14px;display:flex}@container (width>=700px){.editor{grid-template-columns:minmax(280px,380px) minmax(320px,560px);grid-template-areas:"bar bar""map aux""map legend""key key""royals royals";justify-content:start;align-items:start;gap:14px 16px;display:grid}.editor>.map-bar{grid-area:bar}.editor>.map-frame{grid-area:map;align-self:start}.editor>.color-picker,.editor>.pin-editor{grid-area:aux;align-self:start}.editor>.legend{grid-area:legend;align-self:start}.editor>.map-key{grid-area:key;align-self:start}.editor>.royal-encampments{grid-area:royals;align-self:start}}.block-pulse{transform-origin:50%;width:56px;height:56px;transform:translate(-50%, -50%) scale(calc(1 / var(--zoom,1)));border:3px solid var(--gold-bright);box-shadow:0 0 0 2px var(--pin-ring-outer), 0 0 12px 3px #d99a1f8c;pointer-events:none;border-radius:50%;position:absolute}@media (prefers-reduced-motion:no-preference){@keyframes block-pulse-ring{0%{opacity:0;transform:translate(-50%, -50%) scale(calc(.45 / var(--zoom,1)))}45%{opacity:1;transform:translate(-50%, -50%) scale(calc(1.1 / var(--zoom,1)))}to{opacity:.9;transform:translate(-50%, -50%) scale(calc(1 / var(--zoom,1)))}}.block-pulse{animation:1.9s ease-out block-pulse-ring}}.map-info{flex-direction:column;gap:14px;width:100%;display:flex}.info-panel{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;overflow:hidden}.info-panel-summary{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:14px;list-style:none;display:flex}.info-panel-summary::-webkit-details-marker{display:none}.info-panel-heading{flex-wrap:wrap;flex:auto;align-items:baseline;gap:2px 10px;min-width:0;display:flex}.info-panel-summary:after{content:"";border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);flex:none;width:9px;height:9px;transition:transform .15s;transform:rotate(45deg)}.info-panel[open]>.info-panel-summary:after{transform:rotate(-135deg)}.info-panel-summary:focus-visible{outline:2px solid var(--input-focus);outline-offset:-2px}.info-panel-title{color:var(--fg);font-size:16px;font-weight:700}.info-panel-hint{color:var(--muted);font-size:13px}.info-panel-body{border-top:1px solid var(--card-border);padding:0 14px 16px}.map-key .info-panel-body{grid-template-columns:1fr;gap:8px 24px;padding-top:14px;display:grid}@container (width>=680px){.map-key .info-panel-body{grid-template-columns:repeat(3,minmax(0,1fr))}}.key-group{min-width:0}.key-group-title{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:6px 0 8px;font-size:13px;font-weight:700}.key-list{flex-direction:column;gap:7px;margin:0;padding:0;list-style:none;display:flex}.key-row{color:var(--fg-secondary);align-items:center;gap:10px;font-size:14px;line-height:1.35;display:flex}.key-row-mark{flex:none;justify-content:center;align-items:center;width:26px;display:inline-flex}.key-row-label{min-width:0}.key-icon{width:20px;height:20px;display:block}.key-icon--line{width:26px;height:auto}.key-swatch{border-radius:5px;width:20px;height:20px;display:block;box-shadow:inset 0 0 0 1px #00000080}.key-swatch--noncamp{background:#e7dfca}.key-swatch--parking{background:#c7c7c7}.key-swatch--royal{background:#a98fc9}.key-swatch--xblock{background:#3f6b3d}.key-swatch--water{background:#a9cbe0}@media (prefers-color-scheme:dark){.key-swatch{box-shadow:inset 0 0 0 1px #ffffff73}}.key-area-list{flex-direction:column;gap:9px;margin:0;padding:0;list-style:none;display:flex}.key-area-row{align-items:flex-start;gap:10px;display:flex}.key-area-num{color:#fff;background:#9d2235;border-radius:50%;flex:none;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:700;display:inline-flex}@media (prefers-color-scheme:dark){.key-area-num{color:#ffeef2;background:#8c2a3c}}.key-area-text{flex-direction:column;gap:2px;min-width:0;display:flex}.key-area-label{color:var(--fg);font-size:14px;font-weight:600;line-height:1.35}.key-area-detail{color:var(--muted);font-size:13px;line-height:1.4}.key-credit{border-top:1px solid var(--card-border);color:var(--muted);grid-column:1/-1;margin:6px 0 0;padding-top:12px;font-size:13px;line-height:1.5}.key-credit-link{color:var(--input-focus);text-underline-offset:2px;text-decoration:underline}@media (prefers-color-scheme:dark){.key-credit-link{color:#ffb3c0}}.key-credit-link:focus-visible{outline:2px solid var(--input-focus);outline-offset:2px;border-radius:3px}.royals-list{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:8px;margin:0;padding:14px 0 0;list-style:none;display:grid}.royals-row{background:var(--pill-bg);border:1px solid var(--card-border);cursor:pointer;width:100%;font:inherit;color:var(--fg);text-align:left;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;display:flex}.royals-row:hover{background:var(--pill-hover);border-color:var(--input-focus)}.royals-row.is-active{border-color:var(--input-focus);box-shadow:inset 3px 0 0 var(--accent-fill);background:var(--pill-hover)}.royals-row:focus-visible{outline:2px solid var(--input-focus);outline-offset:1px}.royals-kingdom{text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;font-weight:600;overflow:hidden}.royals-block{letter-spacing:.02em;color:#fff;background:#9d2235;border-radius:999px;flex:none;padding:2px 8px;font-size:13px;font-weight:700}@media (prefers-color-scheme:dark){.royals-block{color:#ffeef2;background:#8c2a3c}}.royals-note{color:var(--muted);margin:12px 0 0;font-size:13px;line-height:1.45}.embedded body{background:0 0}.embedded .app{max-width:none;padding:0}
