:root{--bg: #0f1115;--panel: #181b22;--border: #272b33;--text: #e5e7eb;--muted: #9ca3af;--accent: #ef4444;--accent-dim: #7f1d1d;--ok: #22c55e;--title-scale: 1;--title-color: #ef4444;--landmark-scale: 1;--landmark-color: #ef4444}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.5}header{padding:20px 32px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.header-main{min-width:0}header h1{margin:0 0 4px;font-size:22px;font-weight:600;letter-spacing:-.01em}.subtitle{margin:0;color:var(--muted);font-size:14px}.search-box{position:relative;width:100%;max-width:380px}.search-box input{width:100%;background:#0f1115;color:var(--text);border:1px solid var(--border);border-radius:6px;padding:10px 12px 10px 36px;font-size:14px;font-family:inherit;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='%239ca3af' stroke-width='1.8'><circle cx='8.5' cy='8.5' r='5'/><line x1='12.5' y1='12.5' x2='17' y2='17' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:10px center;background-size:16px}.search-box input:focus{outline:none;border-color:var(--accent)}.search-box input::-webkit-search-cancel-button{-webkit-appearance:none;-moz-appearance:none;appearance:none}.search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--panel);border:1px solid var(--border);border-radius:6px;max-height:320px;overflow-y:auto;z-index:100;box-shadow:0 8px 24px #0006}.search-result{padding:10px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--border);transition:background 80ms}.search-result:last-child{border-bottom:none}.search-result:hover,.search-result.active{background:#0f1115}.search-result .place-name{font-weight:500;color:var(--text)}.search-result .place-context{color:var(--muted);font-size:11.5px;margin-top:2px}.search-empty,.search-loading{padding:10px 14px;color:var(--muted);font-size:13px;text-align:center}.layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:20px;max-width:1280px;margin:0 auto;padding:24px 24px 60px;align-items:start}main{display:grid;gap:20px;min-width:0}.sidebar{position:sticky;top:24px;max-height:calc(100vh - 48px);overflow:hidden;display:flex;flex-direction:column;padding:16px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sidebar-header h2{margin:0;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.gallery{display:grid;gap:10px;overflow-y:auto;padding-right:4px;flex:1}.gallery-empty{font-size:13px;margin:0;padding:12px 0;text-align:center}.gallery-item{background:#0f1115;border:1px solid var(--border);border-radius:6px;overflow:hidden;cursor:pointer;transition:border-color .12s;position:relative;display:block;color:inherit;text-decoration:none}.gallery-item:hover{border-color:var(--accent)}.gallery-item.draft{border-style:dashed;padding:28px 4px 4px}.gallery-item.draft .meta{padding:2px 10px 6px}.gallery-item .draft-badge{position:absolute;top:6px;left:6px;background:#ef4444f2;color:#fff;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:2px 6px;border-radius:3px;pointer-events:none;z-index:1}.gallery-item .delete-btn{position:absolute;top:6px;right:6px;background:#000000b3;color:#fff;border:none;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:14px;line-height:1;padding:0;opacity:.7;transition:opacity .12s,background .12s;z-index:1}.gallery-item:hover .delete-btn{opacity:1}.gallery-item .delete-btn:hover{background:var(--accent)}.gallery-item img{width:100%;aspect-ratio:841 / 594;object-fit:cover;display:block;background:#000}.gallery-item .meta{padding:6px 10px 8px;display:grid;gap:2px}.gallery-item .gallery-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-item .gallery-date{font-size:11px;color:var(--muted)}@media (max-width: 880px){.layout{grid-template-columns:1fr}.sidebar{position:static;max-height:none}.gallery{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));max-height:320px}}.panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:20px}.hidden{display:none}.preview-panel{display:grid;gap:14px}.preview-controls{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between}.toggle-group{display:inline-flex;background:#0f1115;border:1px solid var(--border);border-radius:6px;overflow:hidden}.toggle-btn{background:transparent;color:var(--muted);border:none;padding:7px 14px;font-size:13px;font-family:inherit;cursor:pointer;transition:background .12s,color .12s}.toggle-btn:hover{color:var(--text)}.toggle-btn.active{background:var(--accent);color:#fff}.switch{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.switch input{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.switch:hover{color:var(--text)}.preview-frame{position:relative;width:100%;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:#000;margin:0 auto;box-sizing:border-box;padding:0;transition:padding .18s,background .18s}.preview-frame.landscape{aspect-ratio:841 / 594}.preview-frame.portrait{aspect-ratio:594 / 841;max-width:520px}.preview-frame.with-margin{background:#fafafa}.preview-frame.landscape.with-margin{padding:1.78%}.preview-frame.portrait.with-margin{padding:2.53%}.preview-inner{position:relative;width:100%;height:100%;overflow:hidden}#map{width:100%;height:100%;transition:filter .2s}.preview-frame.bw #map .mapboxgl-canvas{filter:grayscale(1) contrast(1.08)}.preview-frame.locked{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}.preview-frame.locked:after{content:"🔒 Locked";position:absolute;top:12px;right:12px;background:#ef4444eb;color:#fff;font-size:11px;font-weight:600;padding:4px 8px;border-radius:4px;pointer-events:none;z-index:3}.poster-title{position:absolute;top:18px;left:22px;color:var(--accent);font-family:Futura,Futura Condensed,Century Gothic,Avenir Next Condensed,Impact,sans-serif;font-weight:700;font-size:calc(clamp(18px,3.2vw,36px) * var(--title-scale));color:var(--title-color);letter-spacing:.08em;text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.6);pointer-events:none;-webkit-user-select:none;user-select:none;z-index:2}.poster-title:empty:before{content:""}.hint{margin:0;color:var(--muted);font-size:13px}.landmarks-panel{display:grid;gap:10px}.landmarks-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.landmarks-header h2{margin:0;font-size:16px;font-weight:600}.landmarks-actions{display:flex;align-items:center;gap:14px;font-size:13px}.link-btn{background:none;border:none;color:var(--muted);font-family:inherit;font-size:13px;cursor:pointer;padding:0}.link-btn:hover{color:var(--accent)}.landmarks-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:4px 12px;max-height:260px;overflow-y:auto;padding-right:4px}.landmarks-list:empty:before{content:"Fetching landmarks…";color:var(--muted);font-size:13px;grid-column:1 / -1;padding:8px 0}.landmark-item{display:flex;align-items:center;gap:8px;padding:6px 4px;font-size:13px;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:4px;transition:background .12s}.landmark-item:hover{background:#0f1115}.landmark-item input{accent-color:var(--accent);margin:0;flex-shrink:0}.landmark-item .notable-dot{color:var(--accent);font-size:10px;flex-shrink:0}.landmark-item .fame-rank{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 5px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;border-radius:9px;flex-shrink:0;letter-spacing:0}.landmark-item .name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.landmark-item.off-frame .name{color:var(--muted);font-style:italic}.landmark-item .landmark-edit{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:0 4px;line-height:1;opacity:0;flex-shrink:0;transition:opacity .12s,color .12s}.landmark-item:hover .landmark-edit{opacity:1}.landmark-item .landmark-edit:hover{color:var(--accent)}.landmark-item .landmark-reset{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;padding:0 4px;line-height:1;flex-shrink:0;transition:color .12s}.landmark-item .landmark-reset:hover{color:#dc2626}.tone-controls{border-top:1px solid var(--border);padding-top:10px;margin-top:2px}.tone-controls summary{cursor:pointer;font-size:13px;color:var(--muted);-webkit-user-select:none;user-select:none;padding:2px 0;list-style:none;display:flex;align-items:center;gap:6px}.tone-controls summary::-webkit-details-marker{display:none}.tone-controls summary:before{content:"▸";font-size:10px;transition:transform .12s}.tone-controls[open] summary:before{transform:rotate(90deg)}.tone-controls summary:hover{color:var(--text)}.tone-sliders{display:grid;gap:12px 16px;margin-top:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.tone-sliders label{display:grid;gap:4px}.tone-sliders label>span{font-size:12px;color:var(--muted);display:flex;justify-content:space-between;align-items:baseline;gap:8px}.tone-sliders label>span output{font-family:SF Mono,Menlo,Consolas,monospace;font-size:11px;color:var(--text)}.tone-sliders input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer}#tone-reset{grid-column:1 / -1;justify-self:start;font-size:12px}@media (max-width: 520px){.tone-sliders{grid-template-columns:1fr}}.poster-scale{display:flex!important;align-items:flex-end;gap:10px;padding:0 10px 10px 0!important;background:transparent!important;box-shadow:none!important;color:#fff;pointer-events:none}.poster-scale-group{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.poster-scale-bar{height:6px;background-image:linear-gradient(to right,white 0%,white 25%,transparent 25%,transparent 50%,white 50%,white 75%,transparent 75%,transparent 100%);border:1px solid white;box-sizing:border-box;transition:width .12s linear}.poster-scale-label{font-family:SF Mono,Menlo,Consolas,monospace;font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.7)}.poster-compass{width:20px;height:20px;border:1px solid white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:SF Mono,Menlo,Consolas,monospace;font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.7);flex-shrink:0}.landmark-marker{color:var(--landmark-color);font-family:Futura,Futura Condensed,Century Gothic,Avenir Next Condensed,Impact,sans-serif;font-weight:700;font-size:calc(clamp(8px,.75vw,11px) * var(--landmark-scale));letter-spacing:.06em;text-transform:uppercase;text-shadow:0 1px 3px rgba(0,0,0,.8),0 0 2px rgba(0,0,0,.9);pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap;transform-origin:center}.landmark-dot{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:SF Mono,Menlo,Consolas,monospace;font-size:10px;font-weight:700;line-height:1;color:#fff;border:1px solid rgba(0,0,0,.55);box-shadow:0 1px 3px #0009;pointer-events:auto;-webkit-user-select:none;user-select:none}.landmark-dot.dot-red{background:var(--accent)}.landmark-dot.dot-yellow{background:#facc15;color:#111;border-color:#00000080}.landmark-dot.dot-selected{background:var(--accent);border:2px solid white;box-shadow:0 0 0 1px #0009,0 1px 4px #000000b3}.poster-legend{position:absolute;bottom:14px;left:18px;display:grid;grid-template-columns:1fr 1fr;gap:calc(3px * var(--landmark-scale)) calc(18px * var(--landmark-scale));max-width:58%;color:#fff;font-family:Futura,Century Gothic,Avenir Next Condensed,sans-serif;font-weight:700;font-size:calc(clamp(8px,.75vw,11px) * var(--landmark-scale));letter-spacing:.06em;text-transform:uppercase;text-shadow:0 1px 3px rgba(0,0,0,.85),0 0 2px rgba(0,0,0,.9);pointer-events:none;-webkit-user-select:none;user-select:none;z-index:2}.poster-legend .legend-entry{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;gap:6px;align-items:baseline}.poster-legend .legend-num{color:var(--accent);min-width:1.5ch;text-align:right}.landmarks-toggles{display:flex;flex-wrap:wrap;gap:10px 18px;padding:2px 0 4px}.text-size-row{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;padding:4px 0}@media (max-width: 520px){.text-size-row{grid-template-columns:1fr}}.landmark-size-row{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:6px 0 4px;font-size:12px;color:var(--muted)}.landmark-size-row .label{display:flex;align-items:baseline;gap:8px;white-space:nowrap}.landmark-size-row output{font-family:SF Mono,Menlo,Consolas,monospace;font-size:11px;color:var(--text);min-width:3ch}.landmark-size-row input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer}.landmark-size-row input[type=color]{width:20px;height:20px;padding:0;border:1px solid var(--border);border-radius:4px;background:none;cursor:pointer;vertical-align:middle;margin-left:4px;flex-shrink:0}.landmark-size-row input[type=color]::-webkit-color-swatch-wrapper{padding:2px}.landmark-size-row input[type=color]::-webkit-color-swatch{border:none;border-radius:2px}form.panel{display:grid;gap:14px}form label{display:grid;gap:6px}form label>span{font-size:13px;color:var(--muted)}form input,form select{background:#0f1115;color:var(--text);border:1px solid var(--border);border-radius:6px;padding:10px 12px;font-size:14px;font-family:inherit}form input:focus,form select:focus{outline:none;border-color:var(--accent)}.bbox-summary{display:grid;gap:4px;padding:12px;background:#0f1115;border:1px solid var(--border);border-radius:6px;font-size:13px}.bbox-summary>span{color:var(--muted)}.bbox-summary output{font-family:SF Mono,Menlo,Consolas,monospace;font-size:12.5px}.muted{color:var(--muted)}button[type=submit],button.secondary{border-radius:6px;padding:12px 18px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .12s,border-color .12s,color .12s}button[type=submit]{background:var(--accent);color:#fff;border:1px solid var(--accent)}button[type=submit]:hover:not(:disabled){background:#dc2626;border-color:#dc2626}button[type=submit]:disabled{background:var(--accent-dim);border-color:var(--accent-dim);cursor:not-allowed;opacity:.6}button.secondary{background:transparent;color:var(--text);border:1px solid var(--border)}button.secondary:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}button.secondary:disabled{cursor:not-allowed;opacity:.5}button.secondary.small{padding:5px 10px;font-size:12px;font-weight:500;border-radius:5px}button.secondary.small.stale{border-color:var(--accent);color:var(--accent)}.form-actions{display:flex;gap:10px;flex-wrap:wrap}.form-actions button[type=submit]{flex:1}.progress-bar{height:6px;background:#0f1115;border:1px solid var(--border);border-radius:3px;overflow:hidden;margin:12px 0 6px}#progress-fill{height:100%;width:0%;background:var(--accent);transition:width .3s ease}#status-text{margin:0;font-weight:500}.previews{display:grid;gap:16px;grid-template-columns:1fr 1fr}.previews figure{margin:0;display:grid;gap:8px}.previews img{width:100%;border-radius:6px;border:1px solid var(--border);background:#0f1115}.previews figcaption{font-size:13px;color:var(--muted);display:flex;justify-content:space-between;align-items:center}.previews a{color:var(--accent);text-decoration:none;font-weight:500}.previews a:hover{text-decoration:underline}.overlay-download{margin:16px 0 0;padding:12px 14px;font-size:13px;color:var(--muted);background:#0f1115;border:1px solid var(--border);border-radius:6px;line-height:1.5}.overlay-download a{color:var(--accent);text-decoration:none;font-weight:600;white-space:nowrap;margin-left:4px}.overlay-download a:hover{text-decoration:underline}@media (max-width: 640px){.previews{grid-template-columns:1fr}.preview-controls{flex-direction:column;align-items:stretch}}
