/* ============================================
   DESIGN TOKENS
   ============================================ */
:root {
  /* Colors */
  --color-bg: #f4f4f5;
  --color-surface: #ffffff;
  --color-ink: #18181b;
  --color-ink-dark: #09090b;
  --color-muted: #71717a;
  --color-line: #e4e4e7;
  --color-line-subtle: #f4f4f5;
  --color-primary: #2563eb;
  --color-primary-hover: #1d4ed8;
  --color-red: #ef4444;
  --color-red-dark: #b91c1c;
  --color-green: #10b981;
  --color-green-dark: #15803d;
  --color-yellow: #facc15;
  --color-yellow-dark: #713f12;
  --color-yellow-body: #854d0e;
  --color-purple: #7c3aed;
  --color-amber-bg: #fff7ed;

  /* Typography */
  --font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-size-xs: 11px;
  --font-size-sm: 12px;
  --font-size-base: 13px;
  --font-size-md: 14px;
  --font-size-lg: 15px;
  --font-size-xl: 19px;

  /* Spacing */
  --space-xs: 4px;
  --space-sm: 6px;
  --space-md: 8px;
  --space-base: 10px;
  --space-lg: 12px;
  --space-xl: 14px;
  --space-2xl: 16px;
  --space-3xl: 20px;
  --space-4xl: 28px;

  /* Radii */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 10px;
  --radius-xl: 12px;
  --radius-full: 50%;
  --radius-phone: 44px;

  /* Shadows */
  --shadow-phone: 0 30px 60px -15px rgba(0,0,0,0.25), 0 0 0 2px #27272a;
  --shadow-card: 0 1px 3px rgba(0,0,0,0.04);
  --shadow-overlay: 0 2px 6px rgba(0,0,0,0.04);
  --shadow-pin: 0 4px 12px rgba(37,99,235,0.4);

  /* Motion */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --duration-fast: 150ms;
  --duration-normal: 250ms;
  --stagger-delay: 30ms;
}

/* ============================================
   RESETS & BASE
   ============================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: var(--font-family);
  background: var(--color-bg);
  min-height: 100vh;
  display: flex;
  justify-content: center;
  padding: 40px 20px;
  color: var(--color-ink);
  font-size: var(--font-size-md);
  -webkit-font-smoothing: antialiased;
}
button { font-family: var(--font-family); cursor: pointer; }
input, textarea, select { font-family: var(--font-family); }

/* ============================================
   PHONE FRAME
   ============================================ */
.phone-desktop-wrapper {
  display: flex;
  justify-content: center;
  align-items: flex-start;
}
.phone {
  width: 390px;
  min-height: 780px;
  max-height: 844px;
  background: var(--color-surface);
  border-radius: var(--radius-phone);
  border: 10px solid var(--color-ink);
  box-shadow: var(--shadow-phone);
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
}
.notch {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 120px;
  height: 28px;
  background: var(--color-ink);
  border-bottom-left-radius: 18px;
  border-bottom-right-radius: 18px;
  z-index: 100;
}
.status-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 28px 8px;
  font-size: var(--font-size-base);
  font-weight: 600;
  background: var(--color-surface);
  flex-shrink: 0;
  z-index: 50;
}
.status-time { letter-spacing: 0.02em; }
.status-icons { display: flex; gap: 5px; align-items: center; }
.status-icon svg { width: 16px; height: 16px; }
.home-indicator {
  width: 134px;
  height: 5px;
  background: var(--color-ink);
  border-radius: 3px;
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
}
.phone-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: relative;
}

/* ============================================
   APP HEADER
   ============================================ */
.app-header {
  padding: 12px 16px 14px;
  border-bottom: 1px solid var(--color-line);
  background: var(--color-surface);
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
  z-index: 40;
}
.back-btn {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-line-subtle);
  border: 1px solid var(--color-line);
  cursor: pointer;
  transition: transform var(--duration-fast) var(--ease-out);
  color: var(--color-ink);
}
.back-btn:active { transform: scale(0.93); }
.header-titles { flex: 1; }
.header-title { font-size: var(--font-size-lg); font-weight: 600; color: var(--color-ink); }
.header-sub { font-size: var(--font-size-xs); color: var(--color-muted); margin-top: 1px; }
.header-actions { display: flex; gap: 6px; }
.icon-btn {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  position: relative;
  cursor: pointer;
  color: var(--color-ink);
  transition: transform var(--duration-fast) var(--ease-out);
}
.icon-btn:active { transform: scale(0.93); }
.icon-btn.primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}
.notif-dot {
  position: absolute;
  top: 7px;
  right: 8px;
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: var(--color-red);
  border: 2px solid var(--color-surface);
}

/* ============================================
   SCROLL AREA
   ============================================ */
.scroll-area {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  background: #fafafa;
  padding-bottom: 20px;
  -webkit-overflow-scrolling: touch;
}

/* ============================================
   HERO
   ============================================ */
.hero {
  background: var(--color-surface);
  padding: var(--space-2xl);
  border-bottom: 1px solid var(--color-line);
  animation: slideUp var(--duration-normal) var(--ease-out);
}
.crumb { font-size: var(--font-size-xs); color: var(--color-muted); margin-bottom: 10px; }
.crumb span { color: var(--color-ink); font-weight: 500; }
.wo-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.wo-id { font-size: var(--font-size-sm); color: var(--color-muted); font-weight: 500; font-family: 'Inter', monospace; }
.wo-title { font-size: var(--font-size-xl); font-weight: 700; color: var(--color-ink-dark); margin-top: 4px; line-height: 1.3; }

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.badge-priority { background: #fef2f2; color: var(--color-red-dark); border: 1px solid #fecaca; }
.badge-priority-sm { background: #fef2f2; color: var(--color-red-dark); border: 1px solid #fecaca; font-size: 10px; padding: 2px 6px; border-radius: 4px; font-weight: 600; }
.badge-status { background: #eff6ff; color: #1d4ed8; border: 1px solid #bfdbfe; }
.badge-neutral { background: var(--color-line-subtle); color: #3f3f46; border: 1px solid var(--color-line); }
.badge-row { display: flex; gap: 6px; margin-top: 12px; flex-wrap: wrap; }
.badge-dot { width: 6px; height: 6px; border-radius: var(--radius-full); display: inline-block; }

/* ============================================
   SECTION CARD
   ============================================ */
.section {
  background: var(--color-surface);
  margin: 12px 12px 0;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.section-no-header .section-head { display: none; }
.section-head {
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--color-line-subtle);
}
.section-title {
  font-size: var(--font-size-base);
  font-weight: 600;
  color: var(--color-ink);
  display: flex;
  align-items: center;
  gap: 8px;
}
.section-title svg { width: 14px; height: 14px; color: var(--color-muted); }
.section-action {
  font-size: var(--font-size-sm);
  color: var(--color-primary);
  font-weight: 500;
  cursor: pointer;
}
.section-action:active { opacity: 0.7; }

.detail-sections .section {
  animation: slideUp var(--duration-normal) var(--ease-out) both;
}
.detail-sections .section:nth-child(1) { animation-delay: 0ms; }
.detail-sections .section:nth-child(2) { animation-delay: 50ms; }
.detail-sections .section:nth-child(3) { animation-delay: 100ms; }
.detail-sections .section:nth-child(4) { animation-delay: 150ms; }
.detail-sections .section:nth-child(5) { animation-delay: 200ms; }
.detail-sections .section:nth-child(6) { animation-delay: 250ms; }
.detail-sections .safety-note {
  animation: slideUp var(--duration-normal) var(--ease-out) 150ms both;
}

/* ============================================
   MAP
   ============================================ */
.map {
  height: 140px;
  background:
    radial-gradient(circle at 30% 40%, #dbeafe 0%, transparent 35%),
    radial-gradient(circle at 70% 60%, #dcfce7 0%, transparent 35%),
    linear-gradient(135deg, #f8fafc 0%, #e0e7ff 100%);
  position: relative;
  border-bottom: 1px solid var(--color-line-subtle);
}
.map svg.roads { position: absolute; inset: 0; width: 100%; height: 100%; }
.pin {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -100%);
  width: 30px;
  height: 30px;
  border-radius: 50% 50% 50% 0;
  background: var(--color-primary);
  rotate: -45deg;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-pin);
}
.pin::after {
  content: '';
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
  background: #fff;
  rotate: 45deg;
}
.map-overlay {
  position: absolute;
  bottom: 10px;
  left: 10px;
  right: 10px;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: 8px 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: var(--shadow-overlay);
}
.map-overlay-text { font-size: var(--font-size-xs); color: var(--color-muted); }
.map-overlay-text strong { color: var(--color-ink); font-weight: 600; font-size: var(--font-size-sm); display: block; }
.nav-btn {
  background: var(--color-primary);
  color: #fff;
  border: none;
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  transition: transform var(--duration-fast) var(--ease-out);
}
.nav-btn:active { transform: scale(0.95); }

/* ============================================
   INFO ROWS
   ============================================ */
.info-list { padding: 4px 14px; }
.info-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 10px 0;
  border-bottom: 1px solid var(--color-line-subtle);
  font-size: var(--font-size-base);
}
.info-row:last-child { border-bottom: none; }
.info-label { color: var(--color-muted); font-weight: 500; font-size: var(--font-size-sm); }
.info-value { color: var(--color-ink); font-weight: 500; text-align: right; max-width: 60%; }
.info-value.mono { font-family: ui-monospace, 'SF Mono', monospace; }

/* ============================================
   CUSTOMER ROW
   ============================================ */
.cust-row { padding: 12px 14px; display: flex; align-items: center; gap: 12px; }
.avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background: linear-gradient(135deg, var(--color-primary), var(--color-purple));
  color: #fff;
  font-weight: 600;
  font-size: var(--font-size-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cust-info { flex: 1; }
.cust-name { font-size: var(--font-size-md); font-weight: 600; color: var(--color-ink); }
.cust-meta { font-size: var(--font-size-xs); color: var(--color-muted); margin-top: 2px; }
.cust-actions { display: flex; gap: 6px; }
.cust-actions .icon-btn { width: 34px; height: 34px; }

/* ============================================
   SAFETY NOTE
   ============================================ */
.safety-note {
  margin: 12px;
  padding: 12px 14px;
  background: #fef9c3;
  border: 1px solid #fde68a;
  border-radius: var(--radius-xl);
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.safety-icon {
  width: 28px;
  height: 28px;
  border-radius: var(--radius-md);
  background: var(--color-yellow);
  color: var(--color-yellow-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.safety-title { font-size: var(--font-size-sm); font-weight: 700; color: var(--color-yellow-dark); margin-bottom: 3px; }
.safety-body { font-size: var(--font-size-sm); color: var(--color-yellow-body); line-height: 1.45; }

/* ============================================
   INSTRUCTIONS
   ============================================ */
.instr { padding: 12px 14px; font-size: 12.5px; color: #3f3f46; line-height: 1.55; }
.instr p + p { margin-top: 8px; }

/* ============================================
   RELATED CASE
   ============================================ */
.case-link {
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: background var(--duration-fast);
}
.case-link:active { background: var(--color-line-subtle); }
.case-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  background: #eff6ff;
  color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.case-text { flex: 1; }
.case-id { font-size: var(--font-size-sm); font-weight: 600; color: var(--color-ink); }
.case-desc { font-size: var(--font-size-xs); color: var(--color-muted); margin-top: 1px; }
.chev { color: #a1a1aa; display: flex; }

/* ============================================
   CTA BAR
   ============================================ */
.cta-bar {
  background: var(--color-surface);
  border-top: 1px solid var(--color-line);
  padding: 12px 16px 24px;
  display: flex;
  gap: 8px;
  flex-shrink: 0;
  z-index: 40;
}
.btn {
  flex: 1;
  padding: 12px 14px;
  border-radius: var(--radius-lg);
  font-size: var(--font-size-md);
  font-weight: 600;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: transform var(--duration-fast) var(--ease-out), background var(--duration-fast);
}
.btn:active { transform: scale(0.97); }
.btn-secondary {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  color: var(--color-ink);
  flex: 0 0 auto;
  padding: 12px 14px;
}
.btn-primary { background: var(--color-primary); color: #fff; }
.btn-primary:hover { background: var(--color-primary-hover); }
.btn-primary:disabled {
  background: #93c5fd;
  cursor: not-allowed;
  transform: none;
}

/* ============================================
   TOAST
   ============================================ */
.toast-container {
  position: absolute;
  bottom: 80px;
  left: 12px;
  right: 12px;
  z-index: 200;
  transform: translateY(20px);
  opacity: 0;
  transition: transform var(--duration-normal) var(--ease-out), opacity var(--duration-normal) var(--ease-out);
  pointer-events: none;
}
.toast-container.toast-visible {
  transform: translateY(0);
  opacity: 1;
}
.toast {
  padding: 10px 14px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

/* ============================================
   LOGIN SCREEN
   ============================================ */
.login-screen {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 24px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}
.login-brand {
  text-align: center;
  margin-bottom: 40px;
  animation: fadeIn 0.4s var(--ease-out);
}
.login-logo {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--color-primary), #3b82f6);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  color: #fff;
  box-shadow: 0 4px 16px rgba(37,99,235,0.3);
}
.login-logo-icon svg { width: 24px; height: 24px; }
.login-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-ink-dark);
  margin-bottom: 4px;
}
.login-subtitle {
  font-size: var(--font-size-base);
  color: var(--color-muted);
}
.login-card {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px;
  background: var(--color-surface);
  border: 2px solid var(--color-line);
  border-radius: var(--radius-xl);
  cursor: pointer;
  transition: border-color var(--duration-fast), box-shadow var(--duration-fast), transform var(--duration-fast) var(--ease-out);
  animation: slideUp 0.3s var(--ease-out) 0.1s both;
}
.login-card:active { transform: scale(0.98); }
.login-card-selected {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(37,99,235,0.1);
}
.login-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 700;
  font-size: 16px;
  flex-shrink: 0;
}
.login-info { flex: 1; }
.login-name { font-size: var(--font-size-lg); font-weight: 600; color: var(--color-ink); }
.login-role { font-size: var(--font-size-sm); color: var(--color-muted); margin-top: 2px; }
.login-team { font-size: var(--font-size-xs); color: var(--color-primary); font-weight: 500; margin-top: 2px; }
.login-check { color: var(--color-muted); }
.login-btn {
  width: 100%;
  margin-top: 20px;
  padding: 14px;
  background: #93c5fd;
  color: #fff;
  border: none;
  border-radius: var(--radius-lg);
  font-size: var(--font-size-md);
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: not-allowed;
  transition: background var(--duration-fast), transform var(--duration-fast) var(--ease-out);
  animation: slideUp 0.3s var(--ease-out) 0.2s both;
}
.login-btn-active {
  background: var(--color-primary);
  cursor: pointer;
}
.login-btn-active:active { transform: scale(0.97); }
.login-btn-active:hover { background: var(--color-primary-hover); }
.login-footer {
  margin-top: 32px;
  text-align: center;
  font-size: var(--font-size-xs);
  color: var(--color-muted);
  display: flex;
  flex-direction: column;
  gap: 4px;
  animation: fadeIn 0.4s var(--ease-out) 0.3s both;
}
.login-version { font-size: 10px; }

/* ============================================
   WORK ORDER LIST
   ============================================ */
.wo-summary-row {
  display: flex;
  gap: 8px;
  padding: 14px 16px 6px;
}
.wo-summary-pill {
  padding: 4px 10px;
  border-radius: 20px;
  font-size: var(--font-size-sm);
  font-weight: 600;
}
.wo-summary-remaining {
  background: #eff6ff;
  color: #1d4ed8;
}
.wo-summary-completed {
  background: #f0fdf4;
  color: var(--color-green-dark);
}
.filter-tabs {
  display: flex;
  gap: 6px;
  padding: 10px 16px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.filter-tabs::-webkit-scrollbar { display: none; }
.filter-pill {
  padding: 6px 14px;
  border-radius: 20px;
  font-size: var(--font-size-sm);
  font-weight: 500;
  border: 1px solid var(--color-line);
  background: var(--color-surface);
  color: var(--color-muted);
  white-space: nowrap;
  cursor: pointer;
  transition: all var(--duration-fast);
}
.filter-pill:active { transform: scale(0.95); }
.filter-pill.active {
  background: var(--color-ink);
  color: var(--color-surface);
  border-color: var(--color-ink);
}
.wo-list { padding: 0 12px 12px; }
.wo-card {
  display: flex;
  align-items: stretch;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: 8px;
  cursor: pointer;
  transition: transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast);
}
.wo-card:active {
  transform: scale(0.98);
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.wo-card-bar {
  width: 4px;
  flex-shrink: 0;
}
.wo-card-content {
  flex: 1;
  padding: 12px 12px 12px 10px;
}
.wo-card-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 4px;
}
.wo-card-id {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-ink);
}
.wo-card-addr {
  font-size: var(--font-size-sm);
  color: var(--color-muted);
  margin-bottom: 8px;
}
.wo-card-badges {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.wo-card-badges .badge {
  font-size: 10px;
  padding: 2px 6px;
}
.wo-card-chevron {
  display: flex;
  align-items: center;
  padding: 0 10px;
  color: #a1a1aa;
}

/* ============================================
   METER CAPTURE
   ============================================ */
.reading-input-area {
  display: flex;
  align-items: baseline;
  justify-content: center;
  padding: 24px 14px 16px;
  gap: 8px;
}
.reading-input {
  width: 160px;
  text-align: center;
  font-size: 36px;
  font-weight: 700;
  color: var(--color-ink-dark);
  border: none;
  border-bottom: 3px solid var(--color-primary);
  background: transparent;
  outline: none;
  padding: 4px 0;
  font-family: ui-monospace, 'SF Mono', monospace;
}
.reading-input::placeholder { color: #d4d4d8; font-weight: 400; }
.reading-unit {
  font-size: var(--font-size-md);
  color: var(--color-muted);
  font-weight: 500;
}
.meter-status-pills {
  display: flex;
  gap: 8px;
  padding: 0 14px 16px;
}
.status-pill {
  flex: 1;
  padding: 10px;
  border-radius: var(--radius-md);
  border: 1.5px solid var(--color-line);
  background: var(--color-surface);
  font-size: var(--font-size-sm);
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  cursor: pointer;
  color: var(--color-muted);
  transition: all var(--duration-fast);
}
.status-pill:active { transform: scale(0.97); }
.status-pill-dot { width: 8px; height: 8px; border-radius: var(--radius-full); }
.status-pill-connected.active {
  border-color: var(--color-green);
  background: #f0fdf4;
  color: var(--color-green-dark);
}
.status-pill-disconnected.active {
  border-color: var(--color-red);
  background: #fef2f2;
  color: var(--color-red-dark);
}

/* Photo Slots */
.photo-slots { padding: 8px 14px 14px; display: flex; flex-direction: column; gap: 8px; }
.photo-slot {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1.5px dashed var(--color-line);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--duration-fast);
}
.photo-slot:active { transform: scale(0.98); }
.photo-slot-captured {
  border-style: solid;
  border-color: var(--color-green);
  background: #f0fdf4;
}
.photo-slot-camera { color: var(--color-muted); display: flex; }
.photo-slot-check { color: var(--color-green); display: flex; animation: fadeIn var(--duration-normal) var(--ease-out); }
.photo-slot-info { flex: 1; }
.photo-slot-label { font-size: var(--font-size-base); font-weight: 500; color: var(--color-ink); display: block; }
.photo-required { font-size: var(--font-size-xs); color: var(--color-red); font-weight: 500; }
.photo-optional { font-size: var(--font-size-xs); color: var(--color-muted); font-weight: 500; }

/* Quarantine Notice */
.quarantine-notice {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin: 12px;
  padding: 10px 12px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  color: #1d4ed8;
  line-height: 1.45;
}
.quarantine-notice svg { flex-shrink: 0; margin-top: 1px; }

/* ============================================
   WORK COMPLETION
   ============================================ */
.completion-section-title {
  padding: 16px 16px 8px;
  font-size: var(--font-size-base);
  font-weight: 600;
  color: var(--color-ink);
}
.completion-cards {
  padding: 0 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.completion-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px;
  background: var(--color-surface);
  border: 1.5px solid var(--color-line);
  border-radius: var(--radius-xl);
  cursor: pointer;
  transition: all var(--duration-fast);
}
.completion-card:active { transform: scale(0.98); }
.completion-card-radio { flex-shrink: 0; }
.radio-outer {
  width: 20px;
  height: 20px;
  border-radius: var(--radius-full);
  border: 2px solid #d4d4d8;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color var(--duration-fast);
}
.radio-inner {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
  animation: scaleIn var(--duration-fast) var(--ease-out);
}
.completion-card-text { flex: 1; }
.completion-card-label { font-size: var(--font-size-md); font-weight: 600; color: var(--color-ink); }
.completion-card-desc { font-size: var(--font-size-xs); color: var(--color-muted); margin-top: 2px; }
.completion-card-dot { width: 8px; height: 8px; border-radius: var(--radius-full); flex-shrink: 0; }

/* Reason dropdown */
.reason-dropdown-area {
  padding: 12px 12px 0;
}
.reason-label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: 6px;
}
.select-wrapper {
  position: relative;
}
.select-wrapper svg {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--color-muted);
}
.reason-select {
  width: 100%;
  padding: 10px 36px 10px 12px;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  color: var(--color-ink);
  background: var(--color-surface);
  appearance: none;
  cursor: pointer;
}
.reason-select:focus { outline: 2px solid var(--color-primary); outline-offset: -1px; }

/* Notes */
.completion-notes {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  color: var(--color-ink);
  resize: none;
  line-height: 1.5;
}
.completion-notes:focus { outline: 2px solid var(--color-primary); outline-offset: -1px; }
.completion-notes::placeholder { color: #a1a1aa; }

/* Sync indicator */
.sync-indicator {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 8px 12px;
  padding: 10px 12px;
  font-size: var(--font-size-sm);
  color: var(--color-muted);
  background: var(--color-line-subtle);
  border-radius: var(--radius-md);
}
.sync-indicator svg { flex-shrink: 0; }

/* Submitted banner */
.submitted-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 12px;
  padding: 12px;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: var(--radius-md);
  font-size: var(--font-size-md);
  font-weight: 600;
  color: var(--color-green-dark);
}

/* ============================================
   MODAL
   ============================================ */
.modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 300;
  opacity: 0;
  transition: opacity var(--duration-fast);
  padding: 24px;
}
.modal-overlay.modal-visible { opacity: 1; }
.modal-card {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  padding: 24px;
  width: 100%;
  max-width: 320px;
  box-shadow: 0 20px 40px rgba(0,0,0,0.15);
  transform: scale(0.95);
  transition: transform var(--duration-normal) var(--ease-out);
}
.modal-visible .modal-card { transform: scale(1); }
.modal-title { font-size: var(--font-size-lg); font-weight: 700; color: var(--color-ink-dark); margin-bottom: 8px; }
.modal-body { font-size: var(--font-size-base); color: var(--color-muted); line-height: 1.5; margin-bottom: 20px; }
.modal-body strong { color: var(--color-ink); }
.modal-actions { display: flex; gap: 8px; }
.modal-btn {
  flex: 1;
  padding: 10px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-md);
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: transform var(--duration-fast) var(--ease-out);
}
.modal-btn:active { transform: scale(0.97); }
.modal-btn-cancel { background: var(--color-line-subtle); color: var(--color-ink); border: 1px solid var(--color-line); }
.modal-btn-confirm { background: var(--color-primary); color: #fff; }

/* ============================================
   EMPTY STATE
   ============================================ */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 24px;
  text-align: center;
}
.empty-state-emoji { font-size: 48px; margin-bottom: 16px; }
.empty-state-title { font-size: var(--font-size-lg); font-weight: 600; color: var(--color-ink); margin-bottom: 4px; }
.empty-state-subtitle { font-size: var(--font-size-base); color: var(--color-muted); }

/* ============================================
   ANIMATIONS
   ============================================ */
@keyframes slideUp {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes scaleIn {
  from { transform: scale(0); }
  to { transform: scale(1); }
}

/* Staggered list items */
.stagger-item {
  animation: slideUp var(--duration-normal) var(--ease-out) both;
  animation-delay: calc(var(--stagger) * var(--stagger-delay));
}
