:root{color-scheme:light;font-family:Georgia,Times New Roman,serif;background:#1d2617;color:#3d2a17;--parchment: #efe0b8;--parchment-deep: #d8bd7e;--ink: #3d2a17;--muted-ink: #705330;--forest: #263a22;--forest-soft: #52683f;--moss: #71834e;--wood: #6a3f22;--wood-dark: #3b2115;--brass: #b9822d;--brass-light: #e7c067;--danger: #8f332b;--shadow: rgba(43, 27, 13, .38)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:radial-gradient(circle at 18% 10%,rgba(231,192,103,.2),transparent 28%),radial-gradient(circle at 85% 12%,rgba(113,131,78,.32),transparent 26%),linear-gradient(135deg,rgba(46,31,17,.28) 0 1px,transparent 1px 18px),linear-gradient(180deg,#334725,#1d2617 58%,#11160f);color:var(--ink)}button,input,select,textarea{font:inherit}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid rgba(231,192,103,.65);outline-offset:2px}.app-shell{max-width:1500px;margin:0 auto;padding:24px}.view-only,.builder-shell,.mission-shell{width:100vw;min-height:100vh}.mission-shell{display:grid;place-items:center;padding:24px}.mission-card,.mission-map-card,.map-panel,.legend-panel,.builder-panel,.view-controls{border:2px solid rgba(102,62,28,.8);background:linear-gradient(135deg,#fff7daad,#d8bd7e80),radial-gradient(circle at 20% 18%,rgba(255,255,255,.32),transparent 28%),var(--parchment);box-shadow:0 18px 42px var(--shadow),inset 0 0 0 1px #fff7da8c,inset 0 0 34px #693f1c2e}.mission-card,.mission-map-card{position:relative;width:min(720px,100%);padding:clamp(24px,5vw,48px);border-radius:24px 10px}.mission-card:before,.mission-map-card:before,.builder-panel:before,.legend-panel:before,.map-panel:before{content:"";position:absolute;top:10px;right:10px;bottom:10px;left:10px;pointer-events:none;border:1px solid rgba(185,130,45,.45);border-radius:inherit}.mission-card--centered{text-align:center}.mission-card h1,.mission-map-card h1,.hero h1{margin:0;color:#2f210f;font-size:clamp(2.2rem,6vw,4.7rem);line-height:.95;letter-spacing:-.04em;text-shadow:0 2px 0 rgba(255,244,203,.65)}.mission-location{margin:12px 0 0;color:var(--forest-soft);font-weight:700;letter-spacing:.01em}.mission-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.primary-button,.secondary-button,.tertiary-button,.reset-button,.legend-button,.view-controls__button,.builder-palette__item,.delete-button{cursor:pointer;transition:transform .16s ease,filter .16s ease,background .16s ease,border-color .16s ease}.primary-button,.secondary-button{border-radius:999px;padding:14px 22px;font-weight:800}.tertiary-button{border:1px solid rgba(118,86,44,.65);border-radius:999px;padding:14px 22px;background:linear-gradient(180deg,#f5e2b8,#d6be8a);color:#4c3215;font-weight:800;box-shadow:inset 0 1px #fffae0bf,0 8px 18px #4631142e}.primary-button{border:1px solid #6c401c;background:linear-gradient(180deg,var(--brass-light),var(--brass));color:#241304;box-shadow:inset 0 1px #fff5becc,0 8px 18px #472a1147}.secondary-button{border:1px solid rgba(70,91,48,.75);background:linear-gradient(180deg,#6f824d,#3f562e);color:#fff6d8;box-shadow:inset 0 1px #fff5be33,0 8px 18px #22331947}.primary-button:hover,.secondary-button:hover,.tertiary-button:hover,.view-controls__button:hover,.legend-button:hover,.reset-button:hover,.builder-palette__item:hover,.delete-button:hover{transform:translateY(-1px);filter:brightness(1.05) saturate(1.03)}.tertiary-button:disabled{cursor:not-allowed;opacity:.55;transform:none;filter:none}.mission-map-card{position:fixed;z-index:20;right:16px;bottom:16px;width:min(460px,calc(100vw - 32px));padding:20px}.mission-map-card h1{font-size:clamp(1.3rem,4vw,2rem)}.mission-map-card p:not(.eyebrow){color:var(--muted-ink)}.view-only{position:relative;overflow:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:#172010}.view-controls{position:fixed;z-index:20;top:16px;left:16px;display:inline-flex;gap:8px;padding:8px;border-radius:18px}.view-controls__button{min-width:48px;border:1px solid rgba(102,62,28,.55);border-radius:14px;padding:10px 14px;background:#fff7da61;color:var(--ink);font-size:1rem;font-weight:800}.music-toggle{position:fixed;z-index:30;top:16px;right:16px;min-width:0;width:52px;border:1px solid rgba(102,62,28,.7);border-radius:999px;padding:10px 0;background:linear-gradient(180deg,#fff7daf0,#d6be8aeb);color:#2f210f;font-size:1.05rem;font-weight:900;box-shadow:0 8px 18px #472a1138;cursor:pointer;transition:transform .16s ease,filter .16s ease;display:grid;place-items:center}.music-toggle:hover{transform:translateY(-1px);filter:brightness(1.04)}.map-scroll{width:100vw;height:100vh;overflow:auto;display:flex;align-items:center;justify-content:center;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y}.map-spacer{position:relative;flex:none;width:4739px;height:4739px}.map-stage{position:absolute;left:0;top:0;width:4739px;height:4739px;transform-origin:top left;will-change:transform}.builder-shell{display:grid;grid-template-columns:240px minmax(0,1fr) 360px;gap:20px;padding:20px;background:radial-gradient(circle at top left,rgba(231,192,103,.16),transparent 34%),linear-gradient(180deg,#304122eb,#172010)}.hero{margin-bottom:20px}.eyebrow{margin:0 0 8px;text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-weight:800;color:#6e4b1d}.lead{margin:12px 0 0;max-width:60ch;color:var(--muted-ink);font-size:1.08rem;line-height:1.6}.mode-switch{display:inline-flex;gap:8px;margin-top:16px;padding:6px;border:1px solid rgba(102,62,28,.45);border-radius:18px;background:#fff7da6b}.mode-switch__button{border:0;border-radius:14px;padding:10px 16px;background:transparent;color:var(--muted-ink);cursor:pointer}.mode-switch__button--active{background:linear-gradient(180deg,var(--brass-light),var(--brass));color:#241304;font-weight:700}.map-panel,.legend-panel,.builder-panel{position:relative;border-radius:22px 8px}.map-panel,.legend-panel,.builder-panel,.mission-card,.mission-map-card{isolation:isolate}.map-panel{padding:16px}.map-frame{position:relative;width:100%;aspect-ratio:1 / 1;overflow:hidden;border:5px solid #5e3a1f;border-radius:18px;background:var(--forest);box-shadow:inset 0 0 32px #1410096b,0 10px 24px #1410093d;isolation:isolate}.map-frame--full{position:absolute;left:0;top:0;width:100%;height:100%;aspect-ratio:auto;border-radius:0;border:0}.map-image{display:block;width:100%;height:100%;object-fit:cover;position:relative;z-index:0;filter:saturate(.95) sepia(.08) contrast(.96)}.map-image--native{width:100%;height:100%;object-fit:fill}.marker-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.marker{position:absolute;width:60px;height:60px;padding:0;border:0;background:transparent;transform:translate(-50%,-50%) scale(var(--marker-scale, 1));cursor:pointer;transition:transform .18s ease,opacity .18s ease,filter .18s ease}.marker img{position:relative;z-index:1;display:block;width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 4px 5px rgba(36,19,4,.55)) drop-shadow(0 0 5px color-mix(in srgb,var(--marker-color) 35%,transparent));animation:bob 2.4s ease-in-out infinite}.marker-pulse{position:absolute;top:12px;right:12px;bottom:12px;left:12px;border:2px solid color-mix(in srgb,var(--marker-color) 55%,var(--brass));border-radius:999px;background:color-mix(in srgb,var(--marker-color) 16%,transparent);animation:pulse 2.4s infinite ease-out}.marker--active{opacity:1}.marker--active:hover{transform:translate(-50%,-50%) scale(calc(var(--marker-scale, 1) * 1.12))}.marker--dim{opacity:.18;filter:grayscale(.7)}.marker--builder{width:72px;height:72px}.marker--selected{filter:drop-shadow(0 0 12px color-mix(in srgb,var(--brass-light) 80%,var(--marker-color)))}.marker-label{position:absolute;left:50%;top:-22px;transform:translate(-50%);font-size:.7rem;padding:3px 8px;border:1px solid rgba(102,62,28,.55);border-radius:999px;background:#efe0b8eb;color:var(--ink);white-space:nowrap}.legend-panel,.builder-panel{padding:18px}.legend-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.legend-header h2,.builder-editor h3{margin:0;color:#2f210f}.legend-header h2{font-size:1.2rem}.reset-button,.legend-button,.builder-palette__item{border:1px solid rgba(102,62,28,.55);border-radius:16px;color:var(--ink);background:#fff7da6b}.reset-button{padding:10px 14px;font-weight:700}.legend-grid{display:grid;grid-template-columns:1fr;gap:10px}.legend-button{display:flex;align-items:center;gap:12px;padding:12px 14px;text-align:left}.legend-button img,.builder-palette__item img{width:34px;height:34px;object-fit:contain;filter:drop-shadow(0 2px 3px rgba(43,27,13,.28))}.builder-palette{display:grid;grid-template-columns:1fr;gap:10px;margin-top:14px}.builder-palette__item{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:grab}.map-frame--builder{cursor:crosshair}.legend-button--selected{border-color:color-mix(in srgb,var(--legend-accent) 70%,var(--wood));background:color-mix(in srgb,var(--legend-accent) 18%,var(--parchment));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--legend-accent) 35%,transparent)}.legend-footer{margin-top:16px;color:var(--muted-ink)}.legend-footer p{margin:0}.builder-actions{display:flex;gap:8px;margin-bottom:12px}.json-output{width:100%;min-height:320px;margin:8px 0 16px;padding:14px;border:1px solid rgba(102,62,28,.55);border-radius:18px;background:#3d2a17e0;color:#fff2cc;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.82rem;resize:vertical}.builder-editor{display:grid;gap:12px}.builder-editor label{display:grid;gap:6px;font-size:.9rem;color:var(--muted-ink)}.builder-editor input,.builder-editor select{width:100%;padding:10px 12px;border:1px solid rgba(102,62,28,.55);border-radius:14px;background:#fff7da94;color:var(--ink)}.builder-coords{display:flex;justify-content:space-between;gap:12px;color:var(--muted-ink)}.delete-button{border:1px solid rgba(143,51,43,.72);border-radius:16px;padding:10px 14px;background:#8f332b24;color:#63211c}.small{font-size:.875rem;color:var(--muted-ink);line-height:1.5}@keyframes pulse{0%{transform:scale(.8);opacity:.7}70%{transform:scale(1.4);opacity:0}to{transform:scale(1.4);opacity:0}}@keyframes bob{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.035)}}@media (max-width: 1024px){.builder-shell{grid-template-columns:1fr}.legend-grid,.builder-palette{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.mission-shell,.builder-shell{padding:12px}.mission-card{padding:24px 20px}.view-controls{top:12px;left:12px}.mission-map-card{right:12px;bottom:12px;width:calc(100vw - 24px)}.legend-grid,.builder-palette{grid-template-columns:1fr}.marker{width:52px;height:52px}.builder-actions,.mission-actions{flex-direction:column}}
