/* ── Design tokens ─────────────────────────────────────────────── */
:root {
  color-scheme: light;

  /* Sidebar (dark) */
  --sidebar-bg:       #0e1117;
  --sidebar-border:   #1e2530;
  --sidebar-text:     #c9d0dc;
  --sidebar-muted:    #5a6476;
  --sidebar-hover-bg: #181e28;
  --sidebar-active-bg:#1c2740;
  --sidebar-active-fg:#6eaaf4;

  /* Main surface */
  --bg:            #f5f6f8;
  --surface:       #ffffff;
  --surface-2:     #f9fafb;
  --border:        #e4e7ec;
  --border-strong: #c9d0dc;

  /* Text */
  --text:   #111827;
  --muted:  #6b7280;
  --faint:  #9ca3af;

  /* Accent – blue */
  --blue:        #3b82f6;
  --blue-dark:   #1d4ed8;
  --blue-soft:   #eff6ff;
  --blue-border: #bfdbfe;

  /* Status */
  --green:       #059669;
  --green-soft:  #ecfdf5;
  --green-border:#a7f3d0;
  --red:         #dc2626;
  --red-soft:    #fef2f2;
  --red-border:  #fecaca;
  --amber:       #d97706;
  --amber-soft:  #fffbeb;
  --amber-border:#fde68a;

  /* Layout */
  --sidebar-w:       220px;
  --map-height:      305px;
  --param-w:         260px;
  --field-radius:    7px;
  --card-radius:     11px;
  --shadow-sm:       0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
  --shadow-md:       0 4px 16px rgba(0,0,0,.10), 0 2px 6px rgba(0,0,0,.06);
  --shadow-lg:       0 20px 60px rgba(0,0,0,.18);
}

/* ── Reset ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: Inter, "Segoe UI", system-ui, -apple-system, sans-serif;
  font-size: 13px;
  line-height: 1.4;
  min-width: 960px;
}

/* ── Base elements ──────────────────────────────────────────────── */
button, input, textarea, select {
  font: inherit;
  line-height: 1.4;
  min-width: 0;
}

input, textarea, select {
  width: 100%;
  border: 1px solid var(--border-strong);
  border-radius: var(--field-radius);
  padding: 7px 10px;
  color: var(--text);
  background: var(--surface);
  font-size: 13px;
  transition: border-color .15s, box-shadow .15s;
}
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(59,130,246,.15);
}
textarea { resize: vertical; }

label {
  display: grid;
  gap: 4px;
  color: var(--muted);
  font-size: 13px;
}
small {
  color: var(--faint);
  font-size: 12px;
  line-height: 1.4;
}

/* ── Buttons ───────────────────────────────────────────────────── */
button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: 1px solid var(--border-strong);
  border-radius: var(--field-radius);
  padding: 8px 14px;
  color: var(--text);
  background: var(--surface);
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  transition: background .15s, border-color .15s, box-shadow .15s, transform .1s;
}
button:hover  { background: var(--surface-2); border-color: var(--border-strong); }
button:active { transform: scale(.98); }

button.primary {
  background: var(--blue);
  border-color: var(--blue);
  color: #fff;
  font-weight: 600;
  box-shadow: 0 1px 4px rgba(59,130,246,.35);
}
button.primary:hover  { background: var(--blue-dark); border-color: var(--blue-dark); }

button.success {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
  font-weight: 600;
}
button.success:hover { background: #047857; border-color: #047857; }

button.danger {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
  font-weight: 600;
}
button.danger:hover { background: #b91c1c; border-color: #b91c1c; }

.text-button {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--blue);
  font-size: 13px;
  box-shadow: none;
}
.text-button:hover { background: transparent; text-decoration: underline; }

/* ── App shell ─────────────────────────────────────────────────── */
.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: var(--sidebar-w) minmax(0, 1fr);
}
.app-shell > * { min-width: 0; }

/* ── Sidebar ───────────────────────────────────────────────────── */
.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  background: var(--sidebar-bg);
  border-right: 1px solid var(--sidebar-border);
  padding: 16px 12px 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* Brand */
.brand {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 0 2px 14px;
  border-bottom: 1px solid var(--sidebar-border);
  margin-bottom: 6px;
}
.brand-mark {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  background: var(--blue);
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: -.5px;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(59,130,246,.45);
}
.brand-name {
  font-size: 15px;
  font-weight: 700;
  color: #e8ecf4;
  letter-spacing: -.2px;
}
.brand-subtitle {
  margin-top: 2px;
  font-size: 11px;
  color: var(--sidebar-muted);
  line-height: 1.3;
}

/* Language switch */
.language-switch {
  display: flex;
  gap: 5px;
  padding: 4px 2px;
}
.language-switch button {
  flex: 1;
  padding: 5px 0;
  border-radius: 6px;
  background: transparent;
  border: 1px solid var(--sidebar-border);
  color: var(--sidebar-muted);
  font-size: 12px;
  font-weight: 500;
}
.language-switch button:hover {
  background: var(--sidebar-hover-bg);
  border-color: #2e3a4e;
  color: var(--sidebar-text);
}
.language-switch button.active {
  background: var(--sidebar-active-bg);
  border-color: rgba(110,170,244,.35);
  color: var(--sidebar-active-fg);
  font-weight: 600;
}

/* Nav */
.side-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 6px 0;
  border-top: 1px solid var(--sidebar-border);
  border-bottom: 1px solid var(--sidebar-border);
  margin: 4px 0;
}
.nav-button {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 9px 12px;
  text-align: left;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  color: var(--sidebar-text);
  font-size: 13px;
  font-weight: 500;
  box-shadow: none;
  text-decoration: none;
  transition: background .15s, color .15s;
}
.nav-button:hover  { background: var(--sidebar-hover-bg); border-color: transparent; color: #e8ecf4; }
.nav-button.active { background: var(--sidebar-active-bg); border-color: rgba(110,170,244,.25); color: var(--sidebar-active-fg); }

/* Account dock */
.account-dock {
  margin-top: auto;
  padding: 12px;
  border-radius: 10px;
  background: #141924;
  border: 1px solid var(--sidebar-border);
  display: grid;
  gap: 9px;
}
.dock-label { font-size: 11px; color: var(--sidebar-muted); letter-spacing: .3px; text-transform: uppercase; }
.dock-user  { font-size: 13px; font-weight: 600; color: var(--sidebar-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.account-dock button.primary {
  width: 100%;
  padding: 8px;
  font-size: 13px;
}
.account-dock .text-button.hidden { display: none !important; }
.account-dock .text-button {
  color: var(--sidebar-muted);
  font-size: 12px;
  justify-self: start;
}
.account-dock .text-button:hover { color: var(--sidebar-text); text-decoration: none; }

.sidebar-footer {
  padding-top: 10px;
  font-size: 11px;
  color: var(--sidebar-muted);
  text-align: center;
}
.sidebar-footer a { color: var(--sidebar-muted); text-decoration: underline; }
.sidebar-footer a:hover { color: var(--sidebar-text); }

/* ── Main area ─────────────────────────────────────────────────── */
.main {
  padding: 12px 16px;
  display: grid;
  align-content: start;
  gap: 14px;
}

.view {
  display: grid;
  gap: 16px;
  width: 100%;
  max-width: 1380px;
}

/* ── Panel ─────────────────────────────────────────────────────── */
.panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  padding: 12px 14px;
  box-shadow: var(--shadow-sm);
}

.panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 8px;
}
.panel h1 { font-size: 18px; font-weight: 700; letter-spacing: -.2px; margin: 0; }
.panel h2 { font-size: 15px; font-weight: 600; margin: 0; }
.panel-subheader h2 { font-size: 14px; font-weight: 600; margin: 0; }
.panel p, .panel-subheader p { margin: 3px 0 0; color: var(--muted); font-size: 12px; }

/* ── Workspace layout ──────────────────────────────────────────── */
.workspace-layout {
  display: grid;
  grid-template-columns: var(--param-w) minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  overflow: visible;
}

/* Parameter stack */
.parameter-stack { display: grid; gap: 4px; align-content: start; overflow: visible; }

.field-card {
  padding: 5px 9px;
  border: 1px solid var(--border);
  border-left: 3px solid var(--blue);
  border-radius: var(--field-radius);
  background: var(--surface-2);
  display: grid;
  gap: 3px;
  transition: border-color .15s, background .15s, box-shadow .15s;
}
.field-card:hover {
  border-color: var(--border-strong);
  border-left-color: var(--blue-dark);
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.field-label,
.field-card > span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  min-height: 16px;
}
.field-label > span:first-child,
.field-card > span:not(.help-wrap) {
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .4px;
}
.inline-field-hint {
  color: var(--faint);
  font-size: .95em;
  font-weight: 500;
}
.field-card input, .field-card select { height: 27px; font-size: 13px; padding: 3px 8px; }
.field-card small { font-size: 10px; line-height: 1.25; }

/* Map panel */
.outlet-picker { display: grid; gap: 4px; }
.map-panel { min-width: 0; }

.section-heading { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-bottom: 3px; }
.section-heading h2 { font-size: 13px; font-weight: 600; margin: 0; color: var(--text); }
.section-heading p  { margin: 0; color: var(--muted); font-size: 11px; }

.outlet-map, .boundary-map {
  border: 1px solid var(--border);
  border-radius: 9px;
  background: #e8ecf0;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.outlet-map { height: var(--map-height); }
.boundary-map { min-height: 460px; }

.outlet-map,
.outlet-map .leaflet-container,
.outlet-map .leaflet-grab,
.outlet-map .leaflet-dragging .leaflet-grab,
.outlet-map .leaflet-interactive {
  cursor: crosshair !important;
}

/* Outlet marker pin */
.outlet-marker {
  width: 22px; height: 22px;
  background: #ef4444;
  border: 3px solid #fff;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  box-shadow: 0 3px 10px rgba(0,0,0,.3);
}
.outlet-marker::after {
  content: "";
  position: absolute;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,.85);
  left: 5px; top: 5px;
}

/* ── Auto-calibration toggle ────────────────────────────────────── */
.switch-row {
  margin-top: 8px;
  padding: 8px 12px;
  border: 1px solid var(--blue-border);
  border-radius: 10px;
  background: var(--blue-soft);
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  color: var(--text);
  cursor: pointer;
  transition: border-color .15s, background .15s;
}
.switch-row:hover { border-color: #93c5fd; }
.switch-row.active { border-color: var(--green-border); background: var(--green-soft); }

.switch-row input {
  flex: 0 0 auto;
  width: 42px; height: 24px;
  padding: 0;
  appearance: none;
  border-radius: 999px;
  background: #cbd5e1;
  border-color: #cbd5e1;
  position: relative;
  transition: background .2s;
}
.switch-row input::before {
  content: "";
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #fff;
  position: absolute;
  left: 3px; top: 3px;
  transition: transform .18s;
  box-shadow: 0 1px 4px rgba(0,0,0,.2);
}
.switch-row input:checked { background: var(--green); border-color: var(--green); }
.switch-row input:checked::before { transform: translateX(18px); }
.switch-row strong { font-size: 13px; font-weight: 600; }
.switch-row small { display: block; margin-top: 1px; }

/* Help popover */
.help-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  margin-left: 5px;
  z-index: 1200;
}
.help-button {
  width: 18px; height: 18px;
  padding: 0;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  color: var(--blue);
  border-color: var(--blue-border);
  background: #fff;
  box-shadow: none;
}
.help-popover {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 3000;
  width: min(360px, calc(100vw - 28px));
  max-height: calc(100vh - 28px);
  overflow: auto;
  padding: 12px 14px;
  border: 1px solid var(--blue-border);
  border-radius: 9px;
  background: #fff;
  box-shadow: var(--shadow-md);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  line-height: 1.5;
  text-transform: none;
  letter-spacing: 0;
}

/* ── Calibration panel ──────────────────────────────────────────── */
.calibration-panel {
  margin-top: 8px;
  padding: 10px;
  border: 1px solid var(--blue-border);
  border-radius: 10px;
  background: #f8fbff;
}
.panel-subheader { margin-bottom: 8px; }

.year-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 8px;
}
.year-card {
  padding: 8px;
  border: 1px solid var(--border);
  border-radius: 9px;
  background: var(--surface);
  display: grid;
  gap: 6px;
}
.year-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .35px;
}
.year-inputs { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 6px; font-size: 13px; color: var(--muted); }
.year-inputs input { height: 28px; padding: 3px 8px; }
.range-note { font-size: 10px; color: var(--faint); }

/* ── Form actions ───────────────────────────────────────────────── */
.form-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  padding-top: 8px;
  margin-top: 8px;
  border-top: 1px solid var(--border);
}
.large-action {
  min-width: 220px;
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 600;
  border-radius: 8px;
}

/* ── Jobs list ──────────────────────────────────────────────────── */
.jobs-list { display: grid; gap: 10px; }

.job-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  padding: 16px;
  display: grid;
  gap: 12px;
  box-shadow: var(--shadow-sm);
}

.job-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.job-title { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.job-title h3 { font-size: 16px; font-weight: 700; margin: 0; }

.job-meta {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  font-size: 12px;
  color: var(--muted);
}
.job-meta span {
  padding: 7px 10px;
  border-radius: 7px;
  background: var(--surface-2);
  border: 1px solid var(--border);
}

.job-status-bar {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 9px;
  background: var(--surface-2);
}
.job-status-bar strong { font-size: 15px; font-weight: 700; }
.job-status-bar span   { font-size: 13px; color: var(--muted); }

.job-status-bar.processing,
.job-status-bar.boundary_confirmation_required { border-color: var(--blue-border);  background: var(--blue-soft);  }
.job-status-bar.waiting_admin_approval{ border-color: var(--amber-border); background: var(--amber-soft); }
.job-status-bar.completed            { border-color: var(--green-border); background: var(--green-soft); }
.job-status-bar.rejected,
.job-status-bar.failed,
.job-status-bar.expired              { border-color: var(--red-border);   background: var(--red-soft);   }

.download-note {
  padding: 11px 14px;
  border: 1px solid var(--amber-border);
  border-radius: 9px;
  color: var(--amber);
  background: var(--amber-soft);
  font-size: 13px;
  font-weight: 600;
}

/* Pill badges */
.pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .2px;
}
.pill.processing, .pill.boundary_confirmation_required {
  color: var(--blue-dark); background: var(--blue-soft); border: 1px solid var(--blue-border);
}
.pill.waiting_admin_approval {
  color: var(--amber); background: var(--amber-soft); border: 1px solid var(--amber-border);
}
.pill.completed {
  color: var(--green); background: var(--green-soft); border: 1px solid var(--green-border);
}
.pill.rejected, .pill.failed, .pill.expired {
  color: var(--red); background: var(--red-soft); border: 1px solid var(--red-border);
}

/* Actions row */
.actions { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }

/* Button link (anchor styled as button) */
.button-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  border: 1px solid var(--border-strong);
  border-radius: var(--field-radius);
  padding: 8px 14px;
  color: var(--text);
  background: var(--surface);
  font-size: 13px;
  font-weight: 500;
  transition: background .15s;
}
.button-link:hover { background: var(--surface-2); }
.button-link.primary { background: var(--blue); border-color: var(--blue); color: #fff; font-weight: 600; }
.button-link.primary:hover { background: var(--blue-dark); }

/* ── Admin ──────────────────────────────────────────────────────── */
.admin-toolbar {
  margin-bottom: 14px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.admin-header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.admin-filter-label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
}

.admin-filter-label select {
  min-width: 180px;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  font: inherit;
}

.admin-select-all,
.admin-job-select {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
}

.admin-select-all input,
.admin-job-select input {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
}

.admin-job-card .job-title {
  align-items: center;
}

.admin-job-select {
  margin-right: 2px;
}

.maintenance-panel {
  margin-bottom: 12px;
  padding: 12px 14px;
  border: 1px solid var(--amber-border);
  border-radius: 10px;
  background: var(--amber-soft);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.maintenance-panel p {
  margin: 4px 0 0;
}

.maintenance-banner {
  position: fixed;
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3400;
  width: min(620px, calc(100vw - 40px));
  padding: 14px 18px;
  border: 1px solid var(--amber-border);
  border-radius: 14px;
  background: rgba(255, 251, 235, .96);
  color: var(--text);
  box-shadow: var(--shadow-lg);
  display: flex;
  align-items: center;
  gap: 14px;
}

.maintenance-banner strong {
  display: block;
  font-size: 15px;
  font-weight: 800;
}

.maintenance-banner p {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.maintenance-animation {
  width: 46px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  flex-shrink: 0;
}

.maintenance-animation span {
  width: 6px;
  height: 12px;
  border-radius: 999px;
  background: var(--amber);
  animation: hydro-maintenance-wave 1s ease-in-out infinite;
}

.maintenance-animation span:nth-child(2) { animation-delay: .14s; }
.maintenance-animation span:nth-child(3) { animation-delay: .28s; }

@keyframes hydro-maintenance-wave {
  0%, 100% { height: 12px; opacity: .55; }
  50% { height: 34px; opacity: 1; }
}

/* ── Processing overlay ─────────────────────────────────────────── */
.processing-overlay {
  position: fixed;
  inset: 0;
  z-index: 2200;
  display: grid;
  place-items: center;
  padding: 40px;
  background: rgba(15, 17, 23, 0.65);
  backdrop-filter: blur(6px);
}
.processing-card {
  width: min(600px, 100%);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 16px;
  padding: 36px 40px;
  text-align: center;
  background: #0e1117;
  box-shadow: 0 32px 80px rgba(0,0,0,.6);
}
.processing-card h2 {
  margin: 18px 0 10px;
  color: #e8ecf4;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -.3px;
}
.processing-card p {
  margin: 0;
  color: #8b98ae;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.55;
}
.processing-progress {
  height: 4px;
  margin: 22px auto 0;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  max-width: 320px;
}
.processing-progress span {
  display: block;
  width: 45%;
  height: 100%;
  border-radius: inherit;
  background: var(--blue);
  animation: hydro-progress 1.4s ease-in-out infinite;
}
.processing-subhint {
  margin-top: 10px !important;
  color: #4a5568 !important;
  font-size: 12px !important;
}

#queueOverlayCloseBtn {
  margin-top: 20px;
}

.spinner {
  width: 52px; height: 52px;
  margin: 0 auto;
  border: 4px solid rgba(255,255,255,.08);
  border-top-color: var(--blue);
  border-radius: 50%;
  animation: hydro-spin .9s linear infinite;
}

@keyframes hydro-spin    { to { transform: rotate(360deg); } }
@keyframes hydro-progress {
  0%   { transform: translateX(-120%); }
  100% { transform: translateX(280%); }
}

/* ── Modals ─────────────────────────────────────────────────────── */
.modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(10,12,18,.55);
  backdrop-filter: blur(4px);
}
.modal-card {
  width: min(500px, 100%);
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--surface);
  box-shadow: var(--shadow-lg);
  padding: 20px 22px;
  display: grid;
  gap: 16px;
}
.boundary-modal-card {
  width: min(1200px, calc(100vw - 48px));
  max-height: calc(100vh - 48px);
  overflow: auto;
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}
.modal-header h2 { margin: 0; font-size: 17px; font-weight: 700; }
.modal-header p  { margin: 5px 0 0; color: var(--muted); font-size: 13px; }

.icon-button {
  width: 32px; height: 32px;
  padding: 0;
  border-radius: 50%;
  font-size: 20px;
  line-height: 1;
  color: var(--muted);
  border-color: var(--border);
  flex-shrink: 0;
}

/* Boundary review modal */
.boundary-review-title {
  padding: 8px 14px;
  border-left: 4px solid var(--blue);
  border-radius: 0 6px 6px 0;
  color: var(--blue-dark);
  background: var(--blue-soft);
  font-size: 18px !important;
  font-weight: 700 !important;
  letter-spacing: -.2px;
}
.boundary-review-modal .modal-header {
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.preview-layout {
  display: grid;
  grid-template-columns: minmax(360px, 1fr) minmax(280px, 360px);
  gap: 16px;
}
.boundary-review-layout { grid-template-columns: minmax(600px, 1fr) minmax(280px, 340px); }
.boundary-review-layout .boundary-map { min-height: 580px; }
.boundary-summary { display: grid; gap: 12px; }

.grid-cell-line {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 9px 0;
  border-bottom: 1px solid var(--border);
}
.grid-cell-line span  { color: var(--muted); font-size: 13px; font-weight: 500; }
.grid-cell-line strong{ color: var(--text); font-family: var(--mono); font-size: 14px; font-weight: 700; letter-spacing: 0; line-height: 1.35; }

.boundary-confirm-callout {
  display: grid;
  gap: 8px;
  padding: 14px 16px;
  border: 1px solid rgba(18, 184, 148, .32);
  border-left: 4px solid var(--accent);
  border-radius: 10px;
  background: rgba(18, 184, 148, .08);
}

.boundary-confirm-callout .boundary-review-title {
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
}

.boundary-confirm-callout p {
  margin: 0;
  color: var(--text);
  font-size: 13px;
  line-height: 1.5;
}

dl { margin: 0; border-top: 1px solid var(--border); }
dl div {
  display: grid;
  grid-template-columns: 110px minmax(0,1fr);
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
dt { color: var(--muted); font-size: 13px; }
dd { margin: 0; font-weight: 600; font-size: 13px; }

.boundary-modal-actions { display: grid; gap: 9px; }
.boundary-modal-actions button { width: 100%; }

/* Auth modal */
.auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  padding: 4px;
  border-radius: 9px;
  background: var(--surface-2);
  border: 1px solid var(--border);
}
.auth-tabs button {
  border: 0;
  background: transparent;
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
  box-shadow: none;
}
.auth-tabs button.active { background: var(--surface); color: var(--blue); box-shadow: var(--shadow-sm); border-radius: 6px; }
.auth-tabs button:hover  { background: transparent; }

#emailAuthPanel   { display: grid; gap: 12px; }
.auth-panel       { display: grid; gap: 12px; }
.modal-primary    { margin-top: 2px; }
.email-auth-toggle{ justify-self: center; }

.google-signin-panel {
  display: grid;
  justify-content: center;
  gap: 8px;
  padding: 4px 0;
}
.google-auth-note { margin: 0; color: var(--muted); font-size: 12px; text-align: center; }
.password-note    { color: var(--faint); font-size: 11px; }
.button-grid      { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }

/* ── Layout tuner ───────────────────────────────────────────────── */
.layout-tuner {
  position: fixed;
  top: 16px; right: 16px;
  z-index: 650;
  width: 220px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: rgba(255,255,255,.96);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(8px);
  overflow: hidden;
}
.layout-tuner summary { padding: 10px 13px; color: var(--blue); font-size: 13px; font-weight: 700; cursor: pointer; list-style: none; }
.layout-tuner summary::-webkit-details-marker { display: none; }
.layout-tuner[open] { padding-bottom: 10px; }
.layout-tuner label { padding: 7px 13px 0; gap: 5px; }
.layout-tuner span  { font-size: 11px; color: var(--muted); font-weight: 600; }
.layout-tuner input[type="range"] { height: 24px; padding: 0; border: 0; accent-color: var(--blue); background: transparent; }

/* ── Utility ────────────────────────────────────────────────────── */
.wide    { grid-column: 1 / -1; }
.hidden  { display: none !important; }

.form-message { min-height: 18px; margin: 0; color: var(--muted); font-size: 12px; line-height: 1.4; }
.error  { color: var(--red) !important; }
.ok     { color: var(--green) !important; }
.muted  { color: var(--muted); }
.small  { font-size: 12px; }

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 980px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar   { position: static; height: auto; }
  .workspace-layout, .preview-layout, .year-grid, .job-meta {
    grid-template-columns: 1fr;
  }
  .panel-header, .job-header { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 520px) {
  .sidebar, .main { padding: 12px; }
  .brand-name     { font-size: 14px; }
  .button-grid    { grid-template-columns: 1fr; }
  .outlet-map     { height: 240px; }
  .form-actions   { justify-content: stretch; }
  .large-action   { width: 100%; min-width: 0; }
}

/* ── Hydro2go scientific instrument theme ───────────────────────── */
:root {
  color-scheme: light;
  --bg: #f7fafc;
  --bg-app: #ffffff;
  --surface: #ffffff;
  --surface-2: #f3f7fb;
  --border: #dbe5ee;
  --border-strong: #b8c7d6;
  --accent: #12b894;
  --accent-2: #2f7df6;
  --warn: #b7791f;
  --danger: #d83b4a;
  --text: #102033;
  --muted: #60758a;
  --faint: #9aaabb;
  --blue: #2f7df6;
  --blue-dark: #1661d8;
  --blue-soft: rgba(47, 125, 246, .09);
  --blue-border: rgba(47, 125, 246, .24);
  --green: #12b894;
  --green-soft: rgba(18, 184, 148, .10);
  --green-border: rgba(18, 184, 148, .26);
  --red: #d83b4a;
  --red-soft: rgba(216, 59, 74, .09);
  --red-border: rgba(216, 59, 74, .24);
  --amber: #b7791f;
  --amber-soft: rgba(183, 121, 31, .10);
  --amber-border: rgba(183, 121, 31, .25);
  --grad-brand: linear-gradient(135deg, #14c7a4, #2f7df6);
  --grad-btn: linear-gradient(135deg, #16c89f, #10a984);
  --sans: "Sora", system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --sidebar-bg: var(--surface);
  --sidebar-border: var(--border);
  --sidebar-text: var(--text);
  --sidebar-muted: var(--muted);
  --sidebar-hover-bg: var(--surface-2);
  --sidebar-active-bg: rgba(31, 212, 160, .10);
  --sidebar-active-fg: var(--accent);
  --shadow-sm: 0 1px 2px rgba(16, 32, 51, .05);
  --shadow-md: 0 16px 42px rgba(37, 60, 88, .12);
  --shadow-lg: 0 24px 80px rgba(37, 60, 88, .18);
  --sidebar-w: 232px;
  --map-height: clamp(420px, calc(100vh - 338px), 520px);
  --param-w: 360px;
  --field-gap: 8px;
  --main-pad-x: 28px;
}

html, body { min-height: 100%; }
body {
  min-width: 1080px;
  background: var(--bg-app);
  color: var(--text);
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: 0;
}

button, input, select, textarea { font-family: var(--sans); }
input, textarea, select {
  background: #ffffff;
  border-color: var(--border);
  color: var(--text);
  border-radius: 8px;
  font-family: var(--mono);
  font-size: 14.5px;
  padding: 11px 14px;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(18, 184, 148, .14);
}
input::placeholder { color: var(--faint); }
label { color: var(--muted); }

button {
  background: var(--surface);
  border-color: var(--border);
  color: var(--text);
  border-radius: 8px;
  box-shadow: none;
}
button:hover { background: var(--surface-2); border-color: var(--border-strong); }
button.primary {
  background: var(--grad-btn);
  border-color: transparent;
  color: #ffffff;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(18, 184, 148, .22);
}
button.primary:hover {
  background: var(--grad-btn);
  box-shadow: 0 14px 32px rgba(18, 184, 148, .28);
  transform: translateY(-1px);
}
button.success {
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
}
button.danger {
  background: transparent;
  border-color: rgba(255, 95, 109, .38);
  color: var(--danger);
}
.text-button { color: var(--accent); }
.ghost-button {
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  font-weight: 600;
  text-decoration: none;
}
.ghost-button:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(18, 184, 148, .08);
}
a.ghost-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Landing page */
.landing-view {
  position: relative;
  height: 100vh;
  min-height: 640px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  background: var(--bg);
  color: var(--text);
}
.landing-glow {
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 70% 50% at 50% -10%, rgba(18,184,148,.16), transparent 60%),
    radial-gradient(ellipse 60% 40% at 85% 30%, rgba(47,125,246,.11), transparent 55%),
    radial-gradient(ellipse 50% 40% at 10% 70%, rgba(18,184,148,.07), transparent 50%);
}
.landing-topo {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: .42;
  pointer-events: none;
}
.landing-nav {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 0 0 auto;
  padding: clamp(14px, 2.2vh, 24px) 48px;
}
.landing-logo {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text);
  font-size: 17px;
  font-weight: 700;
}
.landing-logo:hover { background: transparent; color: var(--text); }
.landing-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}
.landing-language {
  padding: 0;
  border: 0;
}
.landing-language button {
  min-width: 54px;
  padding: 6px 10px;
  font-family: var(--mono);
  font-size: 11px;
}
.landing-hero {
  position: relative;
  z-index: 1;
  max-width: 1040px;
  margin: 0 auto;
  padding: clamp(24px, 6vh, 72px) 32px clamp(22px, 4vh, 42px);
  text-align: center;
}
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: clamp(16px, 2.8vh, 30px);
  padding: 7px 15px;
  border: 1px solid var(--border);
  border-radius: 30px;
  background: rgba(255, 255, 255, .82);
  color: var(--muted);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.signal-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
}
.landing-hero h1 {
  margin: 0 0 clamp(16px, 2.6vh, 26px);
  font-size: clamp(46px, min(7vw, 9vh), 78px);
  line-height: 1.04;
  letter-spacing: 0;
}
.landing-hero h1 span:first-child {
  display: block;
  font-weight: 800;
}
.landing-hero h1 span:last-child {
  display: block;
  font-weight: 200;
  background: var(--grad-brand);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.landing-hero p {
  max-width: 630px;
  margin: 0 auto clamp(24px, 3.8vh, 38px);
  color: var(--muted);
  font-size: 17px;
  font-weight: 300;
  line-height: 1.58;
}
.landing-cta {
  display: flex;
  justify-content: center;
  gap: 14px;
}
.hero-primary, .hero-ghost {
  min-height: 50px;
  padding: 14px 28px;
  font-size: 14px;
}
.landing-steps {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 960px;
  margin: 0 auto clamp(18px, 3vh, 34px);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  background: var(--border);
  gap: 1px;
}
.landing-steps article {
  padding: clamp(18px, 3vh, 28px) 26px;
  background: rgba(255, 255, 255, .88);
  backdrop-filter: blur(8px);
}
.landing-steps span {
  display: block;
  margin-bottom: 12px;
  color: var(--accent);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 1px;
}
.landing-steps h2 {
  margin: 0 0 8px;
  font-size: 15px;
}
.landing-steps p {
  margin: 0;
  color: var(--muted);
  font-size: 12.5px;
  font-weight: 300;
  line-height: 1.55;
}

/* App shell */
.app-shell {
  min-height: 100vh;
  background: var(--bg-app);
}
.sidebar {
  padding: 0;
  background: var(--surface);
}
.sidebar::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--grad-brand);
}
.brand {
  padding: 28px 20px 20px;
  margin: 0;
}
.brand-mark {
  width: 34px;
  height: 34px;
  background: var(--grad-brand);
  color: #ffffff;
  font-family: var(--mono);
  box-shadow: none;
}
.brand-name {
  color: var(--text);
  font-family: var(--sans);
}
.brand-subtitle {
  color: transparent;
  background: linear-gradient(90deg, #2f7df6, #12b894, #c98a1c, #d85aa5, #6c63ff, #2f7df6);
  background-size: 220% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  font-weight: 400;
  font-size: 13px;
  line-height: 1.25;
  word-break: keep-all;
}
.language-switch {
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
}
.language-switch button {
  font-family: var(--mono);
  border-color: var(--border);
}
.language-switch button.active {
  background: transparent;
  color: var(--accent);
  border-color: rgba(18, 184, 148, .40);
}
.side-nav {
  gap: 2px;
  padding: 18px 12px;
  border-top: 0;
  border-bottom: 0;
}
.side-nav::before {
  content: "WORKSPACE";
  padding: 0 8px 8px;
  color: var(--faint);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1.8px;
}
.nav-button {
  justify-content: flex-start;
  gap: 10px;
  color: var(--muted);
}
.nav-button::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--faint);
}
.nav-button.active {
  background: rgba(18, 184, 148, .10);
  color: var(--accent);
}
.nav-button.active::before {
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
}
.account-dock {
  margin: auto 12px 12px;
  background: var(--bg-app);
  border-color: var(--border);
}
.dock-label {
  color: var(--faint);
  font-family: var(--mono);
  letter-spacing: 1.4px;
}
.dock-user { color: var(--text); }
.sidebar-footer {
  padding: 0 20px 16px;
  color: var(--muted);
}
.sidebar-footer a { color: var(--accent); }

.main {
  padding: clamp(10px, 1.6vh, 18px) var(--main-pad-x) 14px;
  background:
    radial-gradient(ellipse 60% 30% at 72% 0%, rgba(47,125,246,.08), transparent 60%),
    var(--bg);
}
.view {
  max-width: 1500px;
}
.panel {
  background: var(--surface);
  border-color: var(--border);
  border-radius: 14px;
  box-shadow: none;
}
#workspaceView .panel {
  padding: 0;
  overflow: hidden;
}
.workflow-header {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  padding: 10px 18px;
  border-bottom: 1px solid var(--border);
  background: var(--surface-2);
}
.workflow-step {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 26px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}
.workflow-step span {
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border: 1px solid var(--border-strong);
  border-radius: 50%;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 11px;
}
.workflow-step.active {
  color: var(--accent);
}
.workflow-step.active span {
  border-color: rgba(18, 184, 148, .55);
  background: rgba(18, 184, 148, .12);
  color: var(--accent);
}
.panel-header, .panel-subheader {
  background: var(--surface-2);
  border-bottom-color: var(--border);
}
.panel-header h1, .panel-subheader h2 {
  color: var(--text);
  font-size: 20px;
  letter-spacing: 0;
}
.panel-header p { color: var(--muted); }

.workspace-layout {
  grid-template-columns: minmax(300px, var(--param-w)) minmax(680px, 1fr);
  gap: 16px;
  padding: 14px 18px 12px;
  align-items: stretch;
}
.parameter-stack {
  display: grid;
  align-content: start;
  gap: var(--field-gap);
}
.field-card {
  padding: 8px 10px;
  border-color: var(--border);
  background: var(--bg-app);
  border-radius: 10px;
}
.field-card > span:first-child,
.field-card > span:not(.help-wrap),
.field-label,
.field-label > span:first-child,
.year-title {
  color: var(--muted);
  font-family: var(--sans) !important;
  font-size: 12.5px !important;
  font-weight: 600;
  text-transform: none !important;
  letter-spacing: 0 !important;
}
.field-card input,
.field-card select {
  min-height: 40px;
  font-size: 14.5px;
  padding: 9px 12px;
}
.year-pair {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--field-gap);
}
.map-panel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  min-height: 0;
  height: 100%;
  border-color: var(--border);
  background: var(--bg-app);
  overflow: hidden;
}
.section-heading {
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
}
.section-heading h2 {
  color: var(--text);
  font-size: 14.5px;
  font-weight: 700;
}
.outlet-map {
  height: 100%;
  min-height: 0;
  background: #eef4f8;
}
.leaflet-container {
  background: #eef4f8;
  font-family: var(--sans);
}
.leaflet-control-attribution {
  background: rgba(255, 255, 255, .78) !important;
  color: var(--muted) !important;
}
.leaflet-control-zoom a {
  background: var(--surface) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}
.supported-region-rect {
  stroke-linecap: round;
  stroke-linejoin: round;
}
.supported-region-control {
  max-width: 280px;
  padding: 6px 9px;
  border: 1px solid rgba(14, 165, 233, .35);
  border-radius: 8px;
  background: rgba(255, 255, 255, .9);
  color: #075985;
  box-shadow: 0 6px 18px rgba(15, 23, 42, .12);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.35;
}
.outlet-marker {
  width: 18px;
  height: 18px;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  background: var(--accent);
  border: 2px solid #ffffff;
  box-shadow: 0 0 0 8px rgba(18, 184, 148, .18), 0 0 18px rgba(18, 184, 148, .48);
}
.outlet-marker::after {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  background: var(--bg-app);
}

.switch-row {
  margin: 0 18px 10px;
  padding: 12px 14px;
  border-color: var(--border);
  background: rgba(47, 125, 246, .07);
  border-radius: 14px;
}
.switch-row.active {
  border-color: rgba(18, 184, 148, .35);
  background: rgba(18, 184, 148, .10);
}
.switch-row strong {
  color: var(--text);
  font-size: 15px;
}
.switch-row input[type="checkbox"] {
  width: 46px;
  height: 24px;
  accent-color: var(--accent);
}
.calibration-panel {
  margin: 0 20px 18px;
  border-color: var(--border);
  border-left: 3px solid var(--accent);
  background: #f6fbff;
}
.year-card {
  background: var(--bg-app);
  border-color: var(--border);
}
.range-note { color: var(--accent-2); font-family: var(--mono); }
.form-actions {
  margin-top: 0;
  padding: 8px 18px 14px;
}
.large-action {
  min-width: 220px;
  min-height: 44px;
}

.help-button {
  background: rgba(47, 125, 246, .10);
  border-color: rgba(47, 125, 246, .24);
  color: var(--accent-2);
}
.help-popover {
  z-index: 3200;
  background: var(--surface);
  border-color: var(--border-strong);
  color: var(--text);
  box-shadow: var(--shadow-lg);
  font-size: 13.5px;
}

/* Jobs */
.jobs-list {
  padding: 18px;
  gap: 12px;
}
.job-card {
  background: var(--surface);
  border-color: var(--border);
  border-radius: 12px;
  position: relative;
  overflow: hidden;
}
.job-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: var(--accent-2);
}
.job-card:has(.pill.completed)::before { background: var(--accent); }
.job-header h3 {
  color: var(--text);
  font-size: 16px;
}
.pill {
  border-radius: 30px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .4px;
  border-color: var(--border);
  background: var(--surface-2);
  color: var(--muted);
}
.pill.processing {
  color: var(--accent-2);
  background: rgba(47, 125, 246, .10);
  border-color: rgba(47, 125, 246, .24);
}
.pill.completed {
  color: var(--accent);
  background: rgba(18, 184, 148, .10);
  border-color: rgba(18, 184, 148, .24);
}
.pill.rejected {
  color: var(--danger);
  background: rgba(216, 59, 74, .10);
  border-color: rgba(216, 59, 74, .24);
}
.pill.waiting_admin_approval,
.pill.boundary_confirmation_required {
  color: var(--warn);
  background: rgba(183, 121, 31, .10);
  border-color: rgba(183, 121, 31, .24);
}
.job-status-bar {
  background: var(--bg-app);
  border-color: var(--border);
  color: var(--muted);
}
.job-status-bar strong { color: var(--text); }
.job-meta {
  color: var(--muted);
}
.job-meta span {
  background: var(--bg-app);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--muted);
  font-family: var(--mono);
}
.actions button { min-height: 38px; }

/* Modals and overlays */
.modal {
  background: rgba(16, 32, 51, .28);
  backdrop-filter: blur(8px);
}
.modal-card {
  background: var(--surface);
  border-color: var(--border);
  box-shadow: var(--shadow-lg);
}
.modal-header {
  border-bottom-color: var(--border);
}
.modal-header h2 { color: var(--text); }
.modal-header p { color: var(--muted); }
.icon-button {
  background: var(--bg-app);
  color: var(--muted);
}
.auth-tabs {
  background: var(--bg-app);
  border-color: var(--border);
}
.auth-tabs button.active {
  background: var(--surface-2);
  color: var(--accent);
  box-shadow: none;
}
.processing-overlay {
  background: rgba(16, 32, 51, .24);
  backdrop-filter: blur(8px);
}
.processing-card {
  background: var(--surface);
  border-color: var(--border);
  color: var(--text);
}
.processing-card h2 { color: var(--text); }
.processing-card p { color: var(--muted); }
.processing-progress {
  background: var(--surface-2);
}
.processing-progress span {
  background: var(--grad-brand);
}
.spinner {
  border-color: rgba(18, 184, 148, .18);
  border-top-color: var(--accent);
}
.boundary-review-title {
  color: var(--accent);
  background: rgba(18, 184, 148, .08);
  border-left-color: var(--accent);
}
.boundary-map {
  background: #eef4f8;
}
.grid-cell-line strong { color: var(--text); }
dl { border-top-color: var(--border); }
dl div { border-bottom-color: var(--border); }
dt { color: var(--muted); }
dd { color: var(--text); font-family: var(--mono); }

.error { color: var(--danger) !important; }
.ok { color: var(--accent) !important; }
.form-message { color: var(--muted); }
#jobError:empty { display: none; }

@media (max-height: 820px) {
  :root {
    --map-height: clamp(350px, calc(100vh - 405px), 470px);
  }
  .landing-steps p { font-size: 12px; line-height: 1.45; }
  .landing-steps h2 { font-size: 14px; }
  .hero-primary, .hero-ghost { min-height: 46px; padding: 12px 24px; }
}

button:disabled,
input:disabled,
select:disabled,
textarea:disabled {
  cursor: not-allowed;
  opacity: .62;
}

.layout-tuner {
  top: 18px;
  right: 18px;
  z-index: 2600;
  width: 240px;
  border-color: var(--border);
  background: rgba(255, 255, 255, .94);
  color: var(--text);
}
.layout-tuner summary {
  color: var(--accent);
  font-family: var(--sans);
}
.layout-tuner label {
  color: var(--muted);
}
.layout-tuner span {
  color: var(--muted);
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: 0;
}
.layout-tuner input[type="range"] {
  accent-color: var(--accent);
}
