@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;700&family=Noto+Sans+TC:wght@400;500;700&display=swap");

:root {
  --bg: #e7ece5;
  --paper: rgba(247, 244, 237, 0.92);
  --paper-strong: rgba(252, 249, 243, 0.98);
  --panel-line: rgba(53, 67, 51, 0.12);
  --panel-shadow: 0 28px 70px rgba(26, 37, 34, 0.16);
  --ink: #18241e;
  --ink-soft: rgba(24, 36, 30, 0.7);
  --forest: #244c3a;
  --forest-strong: #173628;
  --moss: #5f7f55;
  --gold: #d19f3a;
  --clay: #a2573f;
  --danger: #8f383a;
  --night: #132236;
  --stage-shadow: linear-gradient(180deg, rgba(8, 17, 25, 0.1), transparent 18%), linear-gradient(0deg, rgba(8, 17, 25, 0.22), transparent 26%);
  --radius-xl: 28px;
  --radius-lg: 22px;
  --radius-md: 16px;
  --radius-sm: 12px;
  --font-display: "Space Grotesk", "Noto Sans TC", sans-serif;
  --font-body: "Noto Sans TC", "PingFang TC", sans-serif;
  --font-mono: "SFMono-Regular", "IBM Plex Mono", monospace;
  --condition-clear: linear-gradient(145deg, rgba(255, 242, 198, 0.98), rgba(247, 201, 96, 0.88));
  --condition-cloudy: linear-gradient(145deg, rgba(232, 238, 242, 0.98), rgba(183, 198, 210, 0.88));
  --condition-rain: linear-gradient(145deg, rgba(209, 230, 255, 0.98), rgba(113, 160, 232, 0.84));
  --condition-storm: linear-gradient(145deg, rgba(219, 221, 255, 0.98), rgba(124, 110, 221, 0.86));
  --condition-night: linear-gradient(145deg, rgba(33, 50, 77, 0.98), rgba(68, 94, 138, 0.9));
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  font-family: var(--font-body);
  color: var(--ink);
  background:
    radial-gradient(circle at top left, rgba(95, 127, 85, 0.18), transparent 26%),
    radial-gradient(circle at top right, rgba(209, 159, 58, 0.14), transparent 24%),
    linear-gradient(180deg, #eff3ec 0%, var(--bg) 100%);
}

body {
  overflow: hidden;
}

button,
input,
select {
  font: inherit;
}

[hidden] {
  display: none !important;
}

.app-shell {
  position: relative;
  width: 100vw;
  height: 100vh;
}

.shell-card,
.shell-block {
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.52), rgba(255, 255, 255, 0.2)),
    var(--paper);
  border: 1px solid rgba(255, 255, 255, 0.7);
  box-shadow: var(--panel-shadow);
}

.mission-panel {
  position: absolute;
  top: 20px;
  left: 20px;
  bottom: 20px;
  z-index: 40;
  width: min(380px, calc(100vw - 40px));
  overflow: hidden;
  border-radius: 32px;
}

.panel-scroll {
  height: 100%;
  overflow: auto;
  padding: 18px;
  display: grid;
  gap: 16px;
  background:
    radial-gradient(circle at top right, rgba(209, 159, 58, 0.16), transparent 32%),
    repeating-linear-gradient(180deg, rgba(36, 76, 58, 0.03), rgba(36, 76, 58, 0.03) 1px, transparent 1px, transparent 22px);
}

.shell-block {
  border-radius: var(--radius-xl);
  padding: 18px;
  border: 1px solid var(--panel-line);
}

.hero-block {
  padding: 8px 6px 2px;
  background: transparent;
  box-shadow: none;
  border: 0;
}

.eyebrow,
.section-kicker {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.7rem;
  color: var(--ink-soft);
}

.hero-block h1,
.section-head h2,
.empty-callout h2 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.04em;
}

.hero-block h1 {
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 0.95;
  max-width: 11ch;
}

.hero-copy {
  margin: 16px 0 0;
  max-width: 30ch;
  line-height: 1.65;
  color: var(--ink-soft);
}

.status-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.status-tile {
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(36, 76, 58, 0.08);
  background: rgba(255, 255, 255, 0.5);
}

.status-label {
  display: block;
  margin-bottom: 8px;
  font-size: 0.78rem;
  color: var(--ink-soft);
}

.status-tile strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.05rem;
}

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.section-head h2 {
  font-size: 1.22rem;
}

.section-meta {
  font-size: 0.82rem;
  color: var(--ink-soft);
}

.control-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.field {
  display: grid;
  gap: 8px;
}

.field span {
  font-size: 0.82rem;
  color: var(--ink-soft);
}

.field input,
.field select,
.primary-button,
.ghost-button,
.menu-panel button,
.mini-button,
.pin-list-main {
  min-height: 48px;
  border-radius: 14px;
}

.field input,
.field select {
  width: 100%;
  border: 1px solid rgba(53, 67, 51, 0.14);
  padding: 0 14px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
}

.primary-button,
.ghost-button,
.menu-panel button,
.mini-button {
  border: 0;
  cursor: pointer;
}

.primary-button,
.menu-panel button {
  background: linear-gradient(135deg, var(--forest), var(--forest-strong));
  color: white;
  box-shadow: 0 16px 28px rgba(36, 76, 58, 0.24);
}

.ghost-button {
  background: rgba(255, 255, 255, 0.8);
  color: var(--ink);
  border: 1px solid rgba(53, 67, 51, 0.12);
}

.control-form .primary-button {
  grid-column: 1 / -1;
}

.guide-card {
  background:
    linear-gradient(180deg, rgba(255, 250, 237, 0.85), rgba(249, 240, 213, 0.82)),
    var(--paper-strong);
}

.guide-list {
  margin: 0;
  padding-left: 20px;
  display: grid;
  gap: 10px;
  color: var(--ink-soft);
  line-height: 1.6;
}

.pin-list {
  display: grid;
  gap: 10px;
}

.pin-list-empty {
  padding: 18px;
  border-radius: 18px;
  border: 1px dashed rgba(53, 67, 51, 0.18);
  background: rgba(255, 255, 255, 0.4);
}

.pin-list-empty strong {
  display: block;
  margin-bottom: 6px;
}

.pin-list-empty p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.6;
}

.pin-list-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  padding: 10px;
  border-radius: 18px;
  border: 1px solid rgba(53, 67, 51, 0.12);
  background: rgba(255, 255, 255, 0.52);
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.pin-list-item.is-active {
  border-color: rgba(36, 76, 58, 0.28);
  box-shadow: 0 14px 28px rgba(36, 76, 58, 0.12);
  transform: translateY(-1px);
}

.pin-list-main {
  display: grid;
  gap: 6px;
  align-content: start;
  padding: 12px 14px;
  text-align: left;
  border: 0;
  background: rgba(255, 255, 255, 0.62);
}

.pin-order {
  font-family: var(--font-display);
  font-size: 0.78rem;
  color: var(--ink-soft);
}

.pin-coordinate {
  font-family: var(--font-mono);
  font-size: 0.94rem;
}

.pin-summary,
.pin-meta {
  color: var(--ink-soft);
  font-size: 0.82rem;
  line-height: 1.45;
}

.pin-list-actions {
  display: grid;
  align-content: start;
  gap: 8px;
}

.mini-button {
  min-width: 76px;
  padding: 0 12px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--ink);
  border: 1px solid rgba(53, 67, 51, 0.14);
}

.mini-button.danger {
  background: rgba(143, 56, 58, 0.94);
  color: white;
  border-color: transparent;
}

.map-shell {
  position: absolute;
  inset: 0;
}

#map {
  width: 100%;
  height: 100%;
}

.map-vignette {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: var(--stage-shadow);
}

.stage-badge {
  position: absolute;
  top: 24px;
  right: 24px;
  z-index: 30;
  width: min(320px, calc(100vw - 460px));
  padding: 18px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(21, 35, 54, 0.88), rgba(21, 35, 54, 0.72)),
    rgba(19, 34, 54, 0.72);
  color: white;
}

.stage-badge .eyebrow,
.stage-caption {
  color: rgba(255, 255, 255, 0.74);
}

.stage-badge strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.02rem;
  line-height: 1.25;
}

.stage-caption {
  margin: 10px 0 0;
  line-height: 1.5;
  font-size: 0.84rem;
}

.empty-callout {
  position: absolute;
  left: min(432px, calc(100vw - 380px));
  bottom: 24px;
  z-index: 30;
  width: min(360px, calc(100vw - 472px));
  padding: 18px 20px;
  border-radius: 26px;
}

.empty-callout h2 {
  font-size: 1.45rem;
  line-height: 1.02;
  margin-bottom: 10px;
}

.empty-callout p:last-child {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.6;
}

.menu-panel {
  position: absolute;
  z-index: 60;
  min-width: 240px;
  padding: 14px;
  border-radius: 22px;
}

.menu-panel button {
  width: 100%;
  margin-top: 8px;
}

.menu-caption {
  margin: 10px 2px 0;
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--ink-soft);
}

.status-toast {
  position: absolute;
  left: 50%;
  bottom: 24px;
  z-index: 60;
  transform: translateX(-50%);
  padding: 12px 18px;
  border-radius: 999px;
  background: rgba(24, 36, 30, 0.92);
  color: white;
  box-shadow: 0 16px 36px rgba(24, 36, 30, 0.2);
}

.weather-card {
  width: 306px;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  box-shadow: 0 22px 42px rgba(17, 26, 22, 0.2);
  background: var(--condition-cloudy);
}

.weather-card.theme-clear {
  background: var(--condition-clear);
}

.weather-card.theme-cloudy {
  background: var(--condition-cloudy);
}

.weather-card.theme-rain {
  background: var(--condition-rain);
}

.weather-card.theme-storm {
  background: var(--condition-storm);
}

.weather-card.theme-night {
  background: var(--condition-night);
  color: #f5f8ff;
}

.weather-card.theme-night .weather-card-subtitle,
.weather-card.theme-night .muted,
.weather-card.theme-night .daily-brief,
.weather-card.theme-night .metric-label {
  color: rgba(245, 248, 255, 0.74);
}

.weather-card.is-loading {
  opacity: 0.9;
}

.weather-card.is-error {
  background: linear-gradient(145deg, rgba(255, 238, 237, 0.98), rgba(244, 194, 196, 0.9));
}

.weather-card.is-active {
  box-shadow: 0 28px 52px rgba(17, 26, 22, 0.24);
}

.weather-card-header,
.weather-card-body,
.weather-card-actions {
  padding: 18px;
}

.weather-card-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
}

.weather-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.42);
  font-size: 0.76rem;
  font-weight: 700;
}

.weather-badge-symbol {
  font-size: 0.98rem;
}

.weather-card-title {
  margin: 10px 0 4px;
  font-family: var(--font-mono);
  font-size: 0.98rem;
  letter-spacing: -0.02em;
}

.weather-card-subtitle {
  margin: 0;
  font-size: 0.8rem;
  color: var(--ink-soft);
}

.temperature-stack {
  text-align: right;
}

.temperature-value {
  display: block;
  font-family: var(--font-display);
  font-size: 2.4rem;
  line-height: 0.9;
  letter-spacing: -0.06em;
}

.temperature-label {
  display: block;
  margin-top: 6px;
  font-size: 0.78rem;
  color: var(--ink-soft);
}

.weather-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.metric-pill {
  padding: 12px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.42);
}

.metric-label {
  display: block;
  margin-bottom: 6px;
  font-size: 0.76rem;
  color: var(--ink-soft);
}

.metric-pill strong {
  display: block;
  font-size: 1.02rem;
}

.daily-list {
  display: grid;
  gap: 8px;
}

.daily-item {
  display: grid;
  grid-template-columns: 1.05fr 0.9fr 0.9fr;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.42);
}

.daily-date {
  font-weight: 700;
}

.daily-brief {
  display: block;
  margin-top: 4px;
  font-size: 0.76rem;
  color: var(--ink-soft);
}

.daily-temp,
.daily-alt {
  display: block;
}

.weather-card-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.action-refresh,
.action-remove {
  border: 0;
  padding: 10px 14px;
  border-radius: 999px;
  cursor: pointer;
}

.action-refresh {
  background: rgba(255, 255, 255, 0.94);
  color: var(--ink);
}

.action-remove {
  background: rgba(143, 56, 58, 0.92);
  color: white;
}

.marker-dot {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 4px solid rgba(255, 255, 255, 0.92);
  background: linear-gradient(145deg, #315e49, #88c186);
  box-shadow: 0 12px 26px rgba(17, 26, 22, 0.25);
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.marker-dot.active {
  transform: scale(1.12);
  box-shadow: 0 18px 30px rgba(17, 26, 22, 0.3);
}

.sheet-backdrop {
  position: absolute;
  inset: 0;
  z-index: 62;
  background: rgba(17, 26, 22, 0.34);
}

.mobile-sheet {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 63;
  display: grid;
  gap: 14px;
  padding: 20px;
  border-radius: 28px;
}

.mobile-card-strip {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 45;
  display: none;
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 6px;
  scroll-snap-type: x mandatory;
}

.mobile-card-strip .weather-card {
  min-width: min(88vw, 330px);
  scroll-snap-align: start;
}

@media (max-width: 1120px) {
  .mission-panel {
    width: min(344px, calc(100vw - 36px));
  }

  .stage-badge {
    width: min(300px, calc(100vw - 412px));
  }

  .empty-callout {
    left: 382px;
    width: min(320px, calc(100vw - 418px));
  }
}

@media (max-width: 900px) {
  .mission-panel {
    top: 14px;
    left: 14px;
    right: 14px;
    bottom: auto;
    width: auto;
    max-height: min(44vh, 430px);
  }

  .panel-scroll {
    padding: 14px;
  }

  .guide-card,
  .pins-card {
    display: none;
  }

  .hero-block h1 {
    max-width: none;
    font-size: clamp(1.7rem, 7vw, 2.4rem);
  }

  .status-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .control-form {
    grid-template-columns: 1fr 1fr;
  }

  .stage-badge {
    top: auto;
    right: 14px;
    left: 14px;
    bottom: 184px;
    width: auto;
  }

  .empty-callout {
    left: 14px;
    right: 14px;
    bottom: 86px;
    width: auto;
  }

  .mobile-card-strip {
    display: flex;
  }
}

@media (max-width: 640px) {
  .status-grid {
    grid-template-columns: 1fr;
  }

  .control-form {
    grid-template-columns: 1fr;
  }

  .control-form .primary-button {
    grid-column: auto;
  }

  .mission-panel {
    max-height: min(52vh, 470px);
  }

  .stage-badge {
    bottom: 210px;
  }

  .empty-callout {
    bottom: 110px;
  }

  .weather-metrics {
    grid-template-columns: 1fr 1fr;
  }

  .daily-item {
    grid-template-columns: 1fr;
  }
}
