:root {
    --color-background-primary: #ffffff;
    --color-background-secondary: #d4d0c4;
    --color-text-primary: #0d1f1a;
    --color-text-secondary: #3a5048;
    --color-text-tertiary: #6a8c84;
    --color-border-tertiary: #d8e8e4;
    --font-sans: 'Outfit', sans-serif;
    --border-radius-lg: 14px;
    --border-radius-md: 9px;
    --green: #1D9E75;
    --green-light: rgba(29,158,117,0.12);
    --green-dark: #0F6E56;
    --red: #e05252;
    --red-light: #fdeaea;
    --amber: #E8930A;
    --amber-dark: #b45309;
    --amber-light: rgba(232,147,10,0.12);
    --nav-bg: #0d0d0d;
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  body { font-family: var(--font-sans); background: var(--color-background-secondary); }
  .app { width: 100%; margin: 0 auto; padding: 0 0 20px; background: var(--color-background-secondary); min-height: 100vh; }

  .header { padding: 10px 16px; background: var(--nav-bg); border-bottom: 0.5px solid #1a1a1a; display: flex; align-items: center; justify-content: center; }
  .header-title { font-size: 14px; font-weight: 700; color: var(--amber); letter-spacing: 0.06em; text-transform: uppercase; }
  .header-date { font-size: 12px; color: #666; margin-top: 1px; }

  .nav { display: flex; background: var(--nav-bg); border-bottom: 0.5px solid #1a1a1a; position: sticky; top: 0; z-index: 10; }
  .nav-btn { flex: 1; padding: 12px 4px 10px; font-size: 11px; font-weight: 500; color: #666; background: none; border: none; border-bottom: 2px solid transparent; cursor: pointer; display: flex; flex-direction: column; align-items: center; gap: 3px; transition: color 0.15s; font-family: var(--font-sans); letter-spacing: 0.03em; text-transform: uppercase; }
  .nav-btn i { font-size: 19px; }
  .nav-btn.active { color: var(--amber); border-bottom-color: var(--amber); }

  .page { display: none; padding: 16px; overflow: visible; }
  .page.active { display: block !important; visibility: visible !important; opacity: 1 !important; }
  .section-title { font-size: 10px; font-weight: 600; color: var(--color-text-tertiary); text-transform: uppercase; letter-spacing: 0.08em; margin: 20px 0 10px; }
  .card { background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-lg); padding: 14px 16px; margin-bottom: 10px; }

  /* Conditions — 2x2 then moon row below */
  .conditions-bar { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px; margin-bottom: 8px; }
  .cond-card { background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-md); padding: 10px 12px; }
  .cond-card.peak { border-color: var(--amber); background: var(--amber-light); }
  .cond-label { font-size: 10px; color: var(--color-text-tertiary); margin-bottom: 2px; text-transform: uppercase; letter-spacing: 0.06em; }
  .cond-val { font-size: 14px; font-weight: 400; color: var(--color-text-primary); }
  .cond-card.peak .cond-val { color: #92400e; }
  .cond-card.peak .cond-label { color: #b45309; }

  /* Moon arc chart card */
  .moon-detail-card { background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-md); padding: 11px 14px 10px; margin-bottom: 8px; }
  #moon-arc-canvas { display: block; width: 100%; cursor: default; }
  .moon-arc-times { display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; margin-top: 8px; }
  .moon-arc-time-item { text-align: center; background: var(--color-background-secondary); border-radius: 8px; padding: 6px 4px; }
  .moon-arc-time-label { font-size: 9px; color: var(--color-text-tertiary); text-transform: uppercase; letter-spacing: 0.05em; }
  .moon-arc-time-val { font-size: 12px; font-weight: 600; color: var(--color-text-primary); margin-top: 2px; }
  .moon-arc-time-item.is-peak .moon-arc-time-val { color: var(--amber); }
  .moon-arc-time-item.is-peak .moon-arc-time-label { color: var(--amber); }

  /* Location picker */
  .loc-wrapper { position: relative; }
  .loc-input { width: 100%; border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-md); padding: 9px 11px; font-size: 15px; font-family: var(--font-sans); color: var(--color-text-primary); background: var(--color-background-primary); }
  .loc-input:focus { outline: none; border-color: var(--amber); }
  .loc-dropdown { position: absolute; top: 100%; left: 0; right: 0; background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-md); max-height: 180px; overflow-y: auto; z-index: 50; box-shadow: 0 4px 16px rgba(0,0,0,0.1); display: none; }
  .loc-dropdown.open { display: block; }
  .loc-option { padding: 10px 12px; font-size: 14px; color: var(--color-text-primary); cursor: pointer; border-bottom: 0.5px solid var(--color-border-tertiary); }
  .loc-option:last-child { border-bottom: none; }
  .loc-option:active, .loc-option.highlighted { background: var(--amber-light); color: var(--amber-dark); }
  .loc-option em { font-style: normal; font-weight: 600; color: var(--amber-dark); }
  .loc-coords { font-size: 11px; color: var(--color-text-tertiary); margin-top: 3px; }

  label { display: block; font-size: 12px; color: var(--color-text-secondary); margin-bottom: 4px; margin-top: 12px; text-transform: uppercase; letter-spacing: 0.05em; }
  .log-field-group { margin-bottom: 20px; }
  .log-field-label { font-size: 11px; font-weight: 600; color: var(--color-text-tertiary); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 8px; }
  .log-field-group input:focus { border-color: var(--amber) !important; }
  input[type=text], input[type=number], select, textarea { width: 100%; border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-md); padding: 9px 11px; font-size: 15px; font-family: var(--font-sans); color: var(--color-text-primary); background: var(--color-background-primary); transition: border-color 0.15s; }
  input:focus, select:focus, textarea:focus { outline: none; border-color: var(--amber); }
  .row2 { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; }
  .btn-primary { width: 100%; margin-top: 18px; padding: 13px; background: var(--amber); color: #fff; border: none; border-radius: var(--border-radius-md); font-size: 15px; font-weight: 600; cursor: pointer; font-family: var(--font-sans); transition: opacity 0.15s; }
  .btn-primary:active { opacity: 0.85; }
  .btn-secondary { width: 100%; margin-top: 8px; padding: 11px; background: transparent; color: var(--color-text-secondary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-md); font-size: 14px; cursor: pointer; font-family: var(--font-sans); }

  .tag-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
  .tag { font-size: 12px; color: var(--amber-dark); background: var(--amber-light); padding: 5px 11px; border-radius: 20px; cursor: pointer; border: 0.5px solid transparent; transition: all 0.12s; font-family: var(--font-sans); }
  .tag.selected { background: var(--amber); color: #fff; }

  .edit-banner { background: #fff8e1; border: 0.5px solid #ffe082; border-radius: var(--border-radius-md); padding: 8px 12px; margin-bottom: 10px; font-size: 12px; color: #7a5c00; display: none; align-items: center; gap: 6px; }
  .edit-banner.visible { display: flex; }

  /* Catches */
  .catches-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
  .export-btn { display: flex; align-items: center; gap: 5px; padding: 7px 12px; font-size: 12px; font-weight: 500; color: var(--amber-dark); background: var(--green-light); border: none; border-radius: 20px; cursor: pointer; font-family: var(--font-sans); }
  .export-btn i { font-size: 14px; }

  .catch-wrapper { position: relative; margin-bottom: 8px; border-radius: var(--border-radius-lg); overflow: hidden; }
  .catch-actions { position: absolute; right: 0; top: 0; bottom: 0; display: flex; align-items: stretch; border-radius: 0 var(--border-radius-lg) var(--border-radius-lg) 0; overflow: hidden; }
  .catch-action-btn { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; width: 64px; border: none; cursor: pointer; font-size: 10px; font-weight: 600; font-family: var(--font-sans); text-transform: uppercase; letter-spacing: 0.05em; }
  .catch-action-btn i { font-size: 18px; }
  .catch-action-btn.edit { background: #e8f4ff; color: #2563a8; }
  .catch-action-btn.delete { background: var(--red-light); color: var(--red); }

  .catch-card { background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-left: 3px solid #7a9a4a; border-radius: 0 var(--border-radius-lg) var(--border-radius-lg) 0; padding: 12px 14px; display: flex; align-items: center; gap: 12px; position: relative; z-index: 1; transform: translateX(0); transition: transform 0.25s cubic-bezier(0.25,0.46,0.45,0.94); cursor: pointer; will-change: transform; }
  .catch-card.swiped { transform: translateX(-130px); }
  .catch-icon { width: 36px; height: 36px; background: rgba(122,154,74,0.12); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #7a9a4a; font-size: 18px; flex-shrink: 0; }
  .catch-info { flex: 1; min-width: 0; }
  .catch-name { font-size: 15px; font-weight: 600; color: var(--color-text-primary); }
  .catch-meta { font-size: 12px; color: var(--color-text-secondary); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .catch-badge { font-size: 13px; color: var(--amber-dark); background: var(--amber-light); padding: 4px 9px; border-radius: 20px; white-space: nowrap; flex-shrink: 0; font-weight: 500; filter: grayscale(1); }
  .catch-size-badge { font-size: 14px; font-weight: 600; color: #7a9a4a; white-space: nowrap; flex-shrink: 0; }
  .catch-hint { font-size: 10px; color: var(--color-text-tertiary); text-align: right; padding: 0 4px 4px; letter-spacing: 0.03em; }

  /* Insights */
  .stat-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px; }
  .stat-card { background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-md); padding: 14px; }
  .stat-num { font-size: 26px; font-weight: 600; color: var(--amber); letter-spacing: -0.5px; }
  .stat-label { font-size: 11px; color: var(--color-text-secondary); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.04em; }
  .insight-row { display: flex; align-items: flex-start; gap: 10px; padding: 10px 0; border-bottom: 0.5px solid var(--color-border-tertiary); }
  .insight-row:last-child { border-bottom: none; }
  .insight-icon { font-size: 17px; color: var(--amber); margin-top: 1px; flex-shrink: 0; }
  .insight-text { font-size: 13px; color: var(--color-text-primary); line-height: 1.5; }
  .insight-sub { font-size: 12px; color: var(--color-text-secondary); margin-top: 2px; }
  .moon-ssession { display: flex; flex-direction: column; gap: 0; padding: 6px 0; }
  .moon-phase { text-align: center; flex: 1; }
  .moon-glyph { font-size: 22px; display: block; filter: grayscale(1); }
  .plan-day-glyph { font-size: 24px; flex-shrink: 0; filter: grayscale(1); }  .moon-name { font-size: 10px; color: var(--color-text-secondary); margin-top: 2px; }
  .moon-score { font-size: 11px; font-weight: 600; color: var(--amber); }
  .moon-active .moon-glyph { filter: drop-shadow(0 0 5px #E8930A); }

  .empty-state { text-align: center; padding: 40px 0; color: var(--color-text-secondary); font-size: 14px; }
  .empty-state i { font-size: 38px; color: var(--color-border-tertiary); display: block; margin-bottom: 8px; }

  /* Location hint chip */
  .loc-hint { font-size: 11px; color: var(--color-text-tertiary); margin-top: 5px; display: flex; align-items: center; gap: 4px; }

  /* Delete overlay */
  .overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.35); z-index: 100; display: flex; align-items: flex-end; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.2s; }
  .overlay.visible { opacity: 1; pointer-events: all; }
  .confirm-sheet { background: var(--color-background-primary); border-radius: 20px 20px 0 0; padding: 24px 20px 36px; width: 100%; max-width: 390px; transform: translateY(100%); transition: transform 0.25s cubic-bezier(0.25,0.46,0.45,0.94); }
  .overlay.visible .confirm-sheet { transform: translateY(0); }
  .confirm-title { font-size: 17px; font-weight: 600; color: var(--color-text-primary); margin-bottom: 6px; }
  .confirm-sub { font-size: 14px; color: var(--color-text-secondary); margin-bottom: 20px; }
  .btn-danger { width: 100%; padding: 13px; background: var(--red); color: #fff; border: none; border-radius: var(--border-radius-md); font-size: 15px; font-weight: 600; cursor: pointer; font-family: var(--font-sans); margin-bottom: 10px; }
  .btn-cancel { width: 100%; padding: 12px; background: var(--color-background-secondary); color: var(--color-text-secondary); border: none; border-radius: var(--border-radius-md); font-size: 15px; cursor: pointer; font-family: var(--font-sans); }

  .toast { position: fixed; bottom: 100px; left: 50%; transform: translateX(-50%) translateY(20px); background: #0d1f1a; color: #fff; padding: 9px 18px; border-radius: 20px; font-size: 13px; opacity: 0; pointer-events: none; transition: opacity 0.2s, transform 0.2s; z-index: 200; white-space: nowrap; }
  .toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

  /* Peak badge */
  .peak-badge { display: inline-flex; align-items: center; gap: 4px; background: var(--amber-light); color: var(--amber-dark); border-radius: 20px; padding: 3px 9px; font-size: 11px; font-weight: 600; margin-left: 6px; }

  /* Home action buttons */
  .home-action-btn { display: flex; flex-direction: row; align-items: center; justify-content: flex-start; gap: 10px; padding: 14px 12px; background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-lg); cursor: pointer; font-family: var(--font-sans); font-size: 11px; font-weight: 600; color: var(--color-text-primary); transition: background 0.12s; text-transform: uppercase; letter-spacing: 0.06em; }
  .home-action-btn:active { background: var(--amber-light); border-color: var(--amber); color: var(--amber-dark); }
  .home-action-btn i { font-size: 26px; color: var(--amber); }

  /* Sessions */
  .session-card { background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-lg); padding: 13px 14px; margin-bottom: 8px; cursor: pointer; transition: background 0.12s; }
  .session-card:active { background: var(--green-light); }
  .session-card-header { display: flex; align-items: flex-start; justify-content: space-between; }
  .session-card-title { font-size: 15px; font-weight: 600; color: var(--color-text-primary); }
  .session-card-date { font-size: 12px; color: var(--color-text-secondary); margin-top: 2px; }
  .session-card-meta { font-size: 12px; color: var(--color-text-secondary); margin-top: 5px; display: flex; gap: 10px; flex-wrap: wrap; }
  .session-card-badge { font-size: 11px; background: var(--amber-light); color: var(--amber-dark); padding: 2px 8px; border-radius: 20px; font-weight: 500; }
  .session-badge { font-size: 10px; background: #e8f4ff; color: #2563a8; padding: 2px 7px; border-radius: 10px; font-weight: 500; margin-left: 5px; }
  .session-new-btn { display: flex; align-items: center; gap: 6px; padding: 9px 16px; background: var(--amber); color: #fff; border: none; border-radius: 20px; font-size: 13px; font-weight: 600; cursor: pointer; font-family: var(--font-sans); }
  .session-new-btn i { font-size: 15px; }
  /* Session form sheet */
  .catch-select-item { display: flex; align-items: center; gap: 10px; padding: 9px 0; border-bottom: 0.5px solid var(--color-border-tertiary); cursor: pointer; }
  .catch-select-item:last-child { border-bottom: none; }
  .catch-select-check { width: 20px; height: 20px; border-radius: 50%; border: 1.5px solid var(--color-border-tertiary); flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
  .catch-select-check.checked { background: var(--green); border-color: var(--amber); }
  .catch-select-check.checked::after { content: '✓'; color: #fff; font-size: 11px; }
  .catch-select-info { flex: 1; min-width: 0; }
  .catch-select-name { font-size: 14px; font-weight: 500; color: var(--color-text-primary); }
  .catch-select-meta { font-size: 11px; color: var(--color-text-secondary); margin-top: 1px; }
  .plan-day-row { display: flex; align-items: center; gap: 12px; padding: 10px 14px; background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-md); margin-bottom: 6px; cursor: pointer; transition: background 0.12s; }
  .plan-day-row:active { background: var(--green-light); }
  .plan-day-date { min-width: 44px; }
  .plan-day-dow { font-size: 11px; color: var(--color-text-tertiary); text-transform: uppercase; letter-spacing: 0.05em; }
  .plan-day-num { font-size: 20px; font-weight: 600; color: var(--color-text-primary); line-height: 1.1; }
  .plan-day-glyph { font-size: 24px; flex-shrink: 0; }
  .plan-day-info { flex: 1; min-width: 0; }
  .plan-day-phase { font-size: 13px; font-weight: 500; color: var(--color-text-primary); }
  .plan-day-illum { font-size: 12px; color: var(--color-text-secondary); margin-top: 1px; }
  .plan-day-illum-bar { height: 3px; border-radius: 2px; background: var(--color-border-tertiary); margin-top: 4px; overflow: hidden; }
  .plan-day-illum-fill { height: 3px; border-radius: 2px; background: var(--amber); }
  .plan-day-chevron { color: var(--color-text-tertiary); font-size: 14px; }
  .plan-day-row.is-today .plan-day-num { color: var(--amber); }
  .plan-day-row.is-today { border-color: var(--amber); }
  .bite-window-row { display: flex; align-items: center; justify-content: space-between; padding: 7px 0; border-bottom: 0.5px solid var(--color-border-tertiary); }
  .bite-window-row:last-child { border-bottom: none; padding-bottom: 0; }
  .bite-window-label { display: flex; align-items: center; gap: 7px; font-size: 13px; color: var(--color-text-primary); }
  .bite-window-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--amber); flex-shrink: 0; }
  .bite-window-time { font-size: 12px; color: var(--color-text-secondary); font-weight: 500; }
  .bite-window-row.active-now .bite-window-label { color: var(--amber); font-weight: 600; }
  .bite-window-row.active-now .bite-window-dot { background: var(--green); box-shadow: 0 0 6px rgba(29,158,117,0.5); }
  .wx-card { background: var(--color-background-secondary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-md); padding: 10px 12px; margin-top: 8px; }
  .wx-header { display: flex; align-items: center; justify-content: space-between; }
  .wx-title { font-size: 10px; font-weight: 600; color: var(--color-text-tertiary); text-transform: uppercase; letter-spacing: 0.07em; }
  .wx-fetch-btn { display: flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 500; color: var(--amber-dark); background: var(--amber-light); border: none; border-radius: 20px; padding: 4px 10px; cursor: pointer; font-family: var(--font-sans); transition: opacity 0.15s; }
  .wx-fetch-btn:disabled { opacity: 0.5; cursor: default; }
  .wx-fetch-btn i { font-size: 12px; }
  .wx-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px; margin-top: 8px; }
  .wx-item { background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-radius: 8px; padding: 7px 10px; }
  .wx-item-label { font-size: 10px; color: var(--color-text-tertiary); text-transform: uppercase; letter-spacing: 0.06em; }
  .wx-item-val { font-size: 14px; font-weight: 400; color: var(--color-text-primary); margin-top: 1px; }
  .wx-item-unit { font-size: 10px; font-weight: 400; color: var(--color-text-secondary); }
  .wx-item.trend-rising  { border-color: #86efac; background: #f0fdf4; }
  .wx-item.trend-falling { border-color: #fca5a5; background: #fff1f2; }
  .wx-item.trend-rising  .wx-item-val { color: #166534; }
  .wx-item.trend-falling .wx-item-val { color: #991b1b; }
  .wx-status { font-size: 11px; color: var(--color-text-tertiary); margin-top: 6px; min-height: 16px; }

  /* Auth screen */
  .auth-screen { position: fixed; inset: 0; background: #0d1f1a; z-index: 1000; display: flex; flex-direction: column; align-items: center; justify-content: center; overflow: hidden; }
  .auth-logo { font-size: 48px; margin-bottom: 8px; }
  .auth-title { font-size: 26px; font-weight: 700; color: #fff; letter-spacing: -0.5px; margin-bottom: 4px; }
  .auth-subtitle { font-size: 13px; color: rgba(255,255,255,0.5); margin-bottom: 36px; }
  .auth-card { background: rgba(255,255,255,0.06); border: 0.5px solid rgba(255,255,255,0.12); border-radius: 18px; padding: 24px 20px; width: 100%; max-width: 340px; }
  .auth-tab-row { display: flex; background: rgba(255,255,255,0.08); border-radius: 10px; padding: 3px; margin-bottom: 20px; }
  .auth-tab { flex: 1; padding: 8px; font-size: 13px; font-weight: 600; color: rgba(255,255,255,0.5); background: none; border: none; border-radius: 8px; cursor: pointer; font-family: var(--font-sans); transition: all 0.15s; }
  .auth-tab.active { background: var(--amber); color: #fff; }
  .auth-label { font-size: 11px; color: rgba(255,255,255,0.5); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 6px; margin-top: 14px; display: block; }
  .auth-input { width: 100%; background: rgba(255,255,255,0.08); border: 0.5px solid rgba(255,255,255,0.15); border-radius: 10px; padding: 11px 13px; font-size: 15px; color: #fff; font-family: var(--font-sans); }
  .auth-input:focus { outline: none; border-color: var(--amber); }
  .auth-input::placeholder { color: rgba(255,255,255,0.25); }
  .auth-btn { width: 100%; margin-top: 20px; padding: 13px; background: var(--amber); color: #fff; border: none; border-radius: 10px; font-size: 15px; font-weight: 600; cursor: pointer; font-family: var(--font-sans); }
  .auth-btn:disabled { opacity: 0.5; cursor: default; }
  .auth-error { font-size: 12px; color: #f87171; margin-top: 10px; text-align: center; min-height: 16px; }
  .auth-loading { display: none; position: fixed; inset: 0; background: #0d1f1a; z-index: 999; align-items: center; justify-content: center; flex-direction: column; gap: 12px; }
  .auth-loading.visible { display: flex; }
  .auth-spinner { width: 32px; height: 32px; border: 3px solid rgba(232,147,10,0.3); border-top-color: var(--amber); border-radius: 50%; animation: spin 0.8s linear infinite; }
  .auth-loading-text { font-size: 13px; color: rgba(255,255,255,0.5); }
  .user-menu-btn { background: none; border: none; cursor: pointer; font-size: 20px; color: #888; padding: 4px; }
  .user-sheet { position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 200; display: flex; align-items: flex-end; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.2s; }
  .user-sheet.visible { opacity: 1; pointer-events: all; }
  .user-sheet-inner { background: var(--color-background-primary); border-radius: 20px 20px 0 0; width: 100%; max-width: 390px; padding: 20px 20px 40px; transform: translateY(100%); transition: transform 0.25s cubic-bezier(0.25,0.46,0.45,0.94); }
  .user-sheet.visible .user-sheet-inner { transform: translateY(0); }
  .user-sheet-handle { width: 36px; height: 4px; background: var(--color-border-tertiary); border-radius: 2px; margin: 0 auto 16px; }
  .user-email { font-size: 14px; font-weight: 500; color: var(--color-text-primary); margin-bottom: 4px; }
  .user-since { font-size: 12px; color: var(--color-text-tertiary); margin-bottom: 20px; }
  .user-logout-btn { width: 100%; padding: 12px; background: var(--red-light); color: var(--red); border: none; border-radius: var(--border-radius-md); font-size: 14px; font-weight: 600; cursor: pointer; font-family: var(--font-sans); }

  /* Detail sheet */
  .detail-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 110; display: flex; align-items: flex-end; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.22s; }
  .detail-overlay.visible { opacity: 1; pointer-events: all; }
  .detail-sheet { background: var(--color-background-secondary); border-radius: 22px 22px 0 0; width: 100%; max-width: 390px; max-height: 90vh; overflow-y: auto; transform: translateY(100%); transition: transform 0.28s cubic-bezier(0.25,0.46,0.45,0.94); padding-bottom: 32px; }
  .detail-overlay.visible .detail-sheet { transform: translateY(0); }
  .detail-handle { width: 36px; height: 4px; background: var(--color-border-tertiary); border-radius: 2px; margin: 12px auto 0; }
  .detail-header { padding: 14px 16px 12px; display: flex; align-items: flex-start; justify-content: space-between; border-bottom: 0.5px solid var(--color-border-tertiary); background: var(--color-background-primary); }
  .detail-species { font-size: 20px; font-weight: 600; color: var(--color-text-primary); letter-spacing: -0.3px; }
  .detail-date { font-size: 12px; color: var(--color-text-secondary); margin-top: 2px; }
  .detail-close { width: 30px; height: 30px; border-radius: 50%; background: var(--color-background-secondary); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--color-text-secondary); font-size: 16px; flex-shrink: 0; margin-left: 10px; margin-top: 2px; }
  .detail-body { padding: 14px 16px; }
  .detail-section { background: var(--color-background-primary); border: 0.5px solid var(--color-border-tertiary); border-radius: var(--border-radius-lg); padding: 12px 14px; margin-bottom: 10px; }
  .detail-section-title { font-size: 10px; font-weight: 600; color: var(--color-text-tertiary); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 10px; }
  .detail-row { display: flex; align-items: center; justify-content: space-between; padding: 6px 0; border-bottom: 0.5px solid var(--color-border-tertiary); }
  .detail-row:last-child { border-bottom: none; padding-bottom: 0; }
  .detail-row-label { font-size: 12px; color: var(--color-text-secondary); display: flex; align-items: center; gap: 6px; }
  .detail-row-label i { font-size: 14px; color: var(--color-text-tertiary); }
  .detail-row-val { font-size: 13px; font-weight: 500; color: var(--color-text-primary); text-align: right; max-width: 55%; }
  .detail-size-grid { display: grid; grid-template-columns: 1fr; gap: 8px; }
  .detail-size-card { background: var(--color-background-secondary); border-radius: var(--border-radius-md); padding: 10px 12px; text-align: center; }
  .detail-size-num { font-size: 22px; font-weight: 600; color: var(--color-text-primary); }
  .detail-size-label { font-size: 11px; color: var(--color-text-secondary); margin-top: 1px; text-transform: uppercase; letter-spacing: 0.04em; }
  .detail-moon-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-top: 2px; }
  .detail-moon-item { text-align: center; background: var(--color-background-secondary); border-radius: var(--border-radius-md); padding: 8px 4px; }
  .detail-moon-icon { font-size: 15px; display: block; margin-bottom: 2px; }
  .detail-moon-lbl { font-size: 9px; color: var(--color-text-tertiary); text-transform: uppercase; letter-spacing: 0.05em; }
  .detail-moon-val { font-size: 12px; font-weight: 600; color: var(--color-text-primary); margin-top: 2px; }
  .detail-notes { font-size: 13px; color: var(--color-text-primary); line-height: 1.6; padding: 4px 0; }
  .detail-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 4px 16px 0; }
  .detail-edit-btn { padding: 12px; background: var(--amber-light); color: var(--amber-dark); border: none; border-radius: var(--border-radius-md); font-size: 14px; font-weight: 600; cursor: pointer; font-family: var(--font-sans); display: flex; align-items: center; justify-content: center; gap: 6px; }
  .detail-delete-btn { padding: 12px; background: var(--red-light); color: var(--red); border: none; border-radius: var(--border-radius-md); font-size: 14px; font-weight: 600; cursor: pointer; font-family: var(--font-sans); display: flex; align-items: center; justify-content: center; gap: 6px; }
  .detail-tag { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; color: var(--amber-dark); background: var(--green-light); padding: 4px 10px; border-radius: 20px; font-family: var(--font-sans); }  .filter-select { padding:9px 11px;background:var(--color-background-primary);border:0.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);font-family:var(--font-sans);font-size:14px;color:var(--color-text-primary);appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236a8c84' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;outline:none;cursor:pointer;width:100%; }
  input.filter-select { background-image:none; }
