:root{color-scheme:light dark;font-family:SF Pro Text,SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg: #f6f3ee;--bg-2: #fff5e8;--bg-3: #edf1f6;--ink: #1d1e22;--ink-soft: #5a5e66;--border: rgba(15, 23, 42, .12);--card: #ffffff;--surface: #ffffff;--surface-muted: #f4f5f7;--chip: rgba(29, 30, 34, .08);--accent: #ef6b3a;--accent-soft: #f2a766;--shadow: 0 24px 60px rgba(15, 23, 42, .12);--grid: rgba(29, 30, 34, .15);--grid-soft: rgba(29, 30, 34, .08);--horizon-line: rgba(29, 30, 34, .2);--map-ocean: #eef2f6;--map-land: rgba(29, 30, 34, .15);--map-land-stroke: rgba(29, 30, 34, .2);--map-grid: rgba(29, 30, 34, .08)}:root[data-theme=dark]{--bg: #0f1117;--bg-2: #1a1f2b;--bg-3: #0b0f15;--ink: #f5f7fb;--ink-soft: #a6adbb;--border: rgba(148, 163, 184, .18);--card: #151a22;--surface: #151a22;--surface-muted: #1f2633;--chip: rgba(255, 255, 255, .1);--accent: #ff8652;--accent-soft: #ffb37d;--shadow: 0 24px 60px rgba(0, 0, 0, .45);--grid: rgba(255, 255, 255, .25);--grid-soft: rgba(255, 255, 255, .12);--horizon-line: rgba(255, 255, 255, .22);--map-ocean: #10141c;--map-land: rgba(255, 255, 255, .12);--map-land-stroke: rgba(255, 255, 255, .18);--map-grid: rgba(255, 255, 255, .08)}@media(prefers-color-scheme:dark){:root[data-theme=system]{--bg: #0f1117;--bg-2: #1a1f2b;--bg-3: #0b0f15;--ink: #f5f7fb;--ink-soft: #a6adbb;--border: rgba(148, 163, 184, .18);--card: #151a22;--surface: #151a22;--surface-muted: #1f2633;--chip: rgba(255, 255, 255, .1);--accent: #ff8652;--accent-soft: #ffb37d;--shadow: 0 24px 60px rgba(0, 0, 0, .45);--grid: rgba(255, 255, 255, .25);--grid-soft: rgba(255, 255, 255, .12);--horizon-line: rgba(255, 255, 255, .22);--map-ocean: #10141c;--map-land: rgba(255, 255, 255, .12);--map-land-stroke: rgba(255, 255, 255, .18);--map-grid: rgba(255, 255, 255, .08)}}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,var(--bg-2) 0%,var(--bg) 45%,var(--bg-3) 100%);color:var(--ink)}#root{min-height:100vh}a{color:inherit;text-decoration:none}button,input{font-family:inherit}.app{max-width:1280px;margin:0 auto;padding:32px 32px 40px;display:flex;flex-direction:column;gap:24px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.topbar-controls{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:flex-end}.control-group{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.control-label{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft)}.eyebrow{text-transform:uppercase;letter-spacing:.16em;font-size:12px;color:var(--ink-soft);margin:0 0 6px}h1{margin:0 0 6px;font-size:28px;font-weight:600}h2{margin:0;font-size:20px;font-weight:600}h3{margin:0 0 12px;font-size:15px;font-weight:600}.subtitle{margin:0;color:var(--ink-soft);font-size:14px}.segment{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:4px;box-shadow:0 10px 30px #0f172a14}.segment-button{border:none;background:transparent;padding:8px 16px;border-radius:999px;font-size:13px;color:var(--ink-soft);cursor:pointer;transition:all .2s ease}.segment-button.active{background:var(--accent);color:#fff}.content{display:grid;grid-template-columns:340px 1fr;gap:24px;align-items:start}.panel{display:flex;flex-direction:column;gap:20px;padding:20px;background:var(--card);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);position:sticky;top:16px;height:fit-content;max-height:calc(100vh - 32px);overflow-y:auto}.panel-section{display:flex;flex-direction:column;gap:12px}.mode-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.mode-option{border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--ink-soft);padding:10px 12px;font-size:13px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.mode-option.active{background:var(--surface-muted);color:var(--ink);border-color:#ef6b3a59}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--ink-soft)}.field-row{display:grid;gap:12px}.field-row-2{grid-template-columns:repeat(2,minmax(0,1fr))}.field input[type=text],.field input[type=number],.field input[type=date]{padding:10px 12px;border-radius:12px;border:1px solid var(--border);font-size:14px;color:var(--ink);background:var(--surface)}.input-error{border-color:#dc262699;background:#fef2f299}.field.inline{flex-direction:row;align-items:center;justify-content:space-between}.helper{font-size:12px;color:var(--ink-soft);margin:0}.map-card{border-radius:16px;overflow:hidden;border:1px solid rgba(15,23,42,.12);background:var(--surface-muted)}.map-svg{width:100%;height:auto;display:block;cursor:crosshair}.map-ocean{fill:var(--map-ocean)}.map-land{fill:var(--map-land);stroke:var(--map-land-stroke);stroke-width:.6}.map-grid{stroke:var(--map-grid);stroke-width:.6}.map-marker{fill:var(--accent);stroke:#fff;stroke-width:1.4}.map-marker-ring{fill:#ef6b3a33}.map-hint{font-size:11px;color:var(--ink-soft);padding:8px 12px 12px;margin:0}.map-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-soft)}.error{font-size:12px;color:#b42318}.slider input[type=range]{width:100%}.slider-meta{display:flex;align-items:center;justify-content:space-between;margin-top:8px;font-size:12px;color:var(--ink-soft)}.muted{color:var(--ink-soft)}.time-pill{background:#ef6b3a26;color:var(--accent);padding:4px 10px;border-radius:999px;font-weight:600}.secondary-button{border:1px solid var(--border);padding:10px 14px;border-radius:12px;font-size:13px;background:var(--surface-muted);color:var(--ink);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.export-row{display:flex;gap:10px}.export-button{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px}.button-icon{color:var(--ink-soft);line-height:0}.button-icon svg{display:block;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.main-panel{display:flex;flex-direction:column;gap:20px}.card{background:var(--card);border-radius:24px;border:1px solid var(--border);box-shadow:var(--shadow);padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.pill{background:var(--chip);color:var(--ink-soft);font-size:12px;padding:6px 10px;border-radius:999px}.tag{background:var(--chip);color:var(--ink-soft);font-size:11px;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.08em}.chart-wrapper{display:flex;flex-direction:column;align-items:center;gap:12px}.chart-card svg{width:100%;max-width:520px;height:auto}.three-scene{width:100%;max-width:560px;height:min(60vh,480px);min-height:320px;border-radius:14px;overflow:hidden;border:1px solid var(--border);background:radial-gradient(circle at 50% 20%,rgba(59,130,246,.1),transparent 62%),linear-gradient(180deg,var(--surface-muted),var(--card));box-shadow:inset 0 1px #ffffff73}.three-canvas{width:100%;height:100%;display:block}.chart-helper{margin:0;font-size:12px;color:var(--ink-soft);opacity:.9}:root[data-theme=dark] .three-scene{background:radial-gradient(circle at 50% 20%,rgba(96,165,250,.12),transparent 62%),linear-gradient(180deg,#141a24,#10161f);box-shadow:inset 0 1px #ffffff0f}.horizon{fill:#ef6b3a08;stroke:var(--horizon-line);stroke-width:1.2}.grid-ring{fill:none;stroke:var(--grid-soft);stroke-dasharray:3 4}.grid-axis{stroke:var(--grid);stroke-width:1}.cardinal{font-size:12px;fill:var(--ink-soft)}.path{fill:none;stroke-linecap:round;stroke-width:2.4}.path-muted{stroke:#1d1e2233;stroke-dasharray:5 6}.path-solid{stroke:url(#sunPathGlow)}.path-golden{stroke:#ef6b3acc;stroke-width:3}.path-blue{stroke:#3b82f699;stroke-width:3}.current-glow{fill:#ef6b3a4d}.current-point{fill:var(--accent);stroke:#fff;stroke-width:2}.chart-legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--ink-soft)}.chart-legend-3d{gap:10px;justify-content:center}.chart-legend-3d .legend-item{border:1px solid var(--border);border-radius:999px;padding:4px 8px;background:var(--surface)}.month-strip{width:100%;max-width:520px;display:flex;flex-wrap:wrap;gap:8px}.month-chip{display:inline-flex;align-items:center;gap:6px;font-size:11px;padding:4px 8px;border-radius:999px;border:1px solid var(--border);color:var(--ink-soft);background:var(--surface)}.month-chip.active{color:var(--ink);font-weight:600;background:var(--surface-muted)}.month-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.legend-item{display:inline-flex;align-items:center;gap:6px}.legend-swatch{width:14px;height:6px;border-radius:999px;display:inline-block}.legend-swatch.solid{background:var(--accent)}.legend-swatch.muted{background:#1d1e2233}.legend-swatch.marker{background:#ef6b3a99;border-radius:50%;width:10px;height:10px}.legend-swatch.golden{background:#ef6b3acc}.legend-swatch.blue{background:#3b82f699}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.stat-card{background:var(--surface-muted);border-radius:16px;padding:16px;border:1px solid rgba(15,23,42,.06)}.stat-label{margin:0 0 6px;color:var(--ink-soft);font-size:12px}.stat-value{margin:0 0 4px;font-size:18px;font-weight:600}.stat-note{margin:0;font-size:12px;color:var(--ink-soft)}.footer{font-size:12px;color:var(--ink-soft);text-align:center;padding-bottom:20px}@media(max-width:980px){.content{grid-template-columns:1fr}.panel{position:static;max-height:none;overflow:visible}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.app{padding:20px}.three-scene{height:min(56vh,360px);min-height:280px}.stats-grid{grid-template-columns:1fr}.segment{width:100%;justify-content:space-between}}
