/* ============================================================
   SCHUBBAUER REDESIGN — Drop-in Override
   Direction 1: Soft & Friendly (Claude Design Mockup)
   ============================================================
   Lade als LETZTE Stylesheet im <head> nach dem internen <style>.
   Verwendet hohe Spezifitaet + !important damit es ueberschreibt.
   ============================================================ */

/* === Brand Tokens (override existing :root) === */
:root {
  --bg: #faf5ed !important;
  --surface: #ffffff !important;
  --surface-2: #f5efe2 !important;
  --surface-3: #ece5d6 !important;
  --border: rgba(30, 20, 10, 0.08) !important;
  --border-soft: rgba(30, 20, 10, 0.05) !important;
  --border-strong: rgba(30, 20, 10, 0.15) !important;
  --text: #3b322a !important;
  --text-strong: #1a1410 !important;
  --text-muted: #857a6c !important;
  --text-faint: #bcb2a3 !important;
  --primary: #1d4ed8 !important;
  --primary-dark: #0e2a73 !important;
  --primary-soft: #e6edff !important;
  --primary-tint: #f0f4ff !important;
  --accent: #e87457 !important;
  --accent-dark: #b54a30 !important;
  --accent-soft: #fde7df !important;
  --danger: #c4533e !important;
  --danger-soft: #fadcd4 !important;
  --warning: #d49532 !important;
  --warning-soft: #f8ecd1 !important;
  --success: #2f8d6a !important;
  --success-soft: #dcf0e6 !important;
  --weekend: #f5efe2 !important;
  --holiday: #fadcd4 !important;
  --today: #e6edff !important;
}

/* === Body === */
html, body {
  background: #faf5ed !important;
  font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif !important;
  color: #3b322a !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
}

* {
  font-family: inherit !important;
}

/* Allow icon fonts and chips with explicit fonts */
.logo-text, .logo-tagline, .day-card-name, h1, h2, h3, h4, h5, h6,
button, input, select, textarea, .chip, .vehicle-chip, .absence-chip,
.stat-number, .ed-eyebrow, .day-strip-day .dsd-date, .day-strip-day .dsd-name {
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
}

/* === Header — clean white masthead === */
header.app-header {
  background: rgba(255, 255, 255, 0.92) !important;
  backdrop-filter: saturate(180%) blur(14px) !important;
  -webkit-backdrop-filter: saturate(180%) blur(14px) !important;
  border-bottom: 1px solid rgba(30, 20, 10, 0.06) !important;
  box-shadow: 0 1px 3px rgba(30, 20, 10, 0.04) !important;
  padding: 14px 24px !important;
}

header.app-header::after { content: none !important; display: none !important; }

/* Logo */
.logo {
  gap: 12px !important;
  margin-right: 16px !important;
}
.logo .logo-img-header {
  height: 44px !important;
  max-width: 220px !important;
  object-fit: contain !important;
}
.logo .logo-text {
  font-weight: 800 !important;
  font-size: 18px !important;
  letter-spacing: 0.02em !important;
  color: #1a1410 !important;
}
.logo .logo-tagline {
  font-style: normal !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: #857a6c !important;
}

/* Week-Nav buttons (‹ › Heute Tag) */
.week-nav button.icon, .week-nav button {
  border-radius: 12px !important;
  padding: 8px 14px !important;
  background: rgba(30, 20, 10, 0.04) !important;
  border: none !important;
  font-weight: 600 !important;
  color: #1a1410 !important;
  box-shadow: none !important;
}
.week-nav button:hover {
  background: rgba(30, 20, 10, 0.08) !important;
}
#today-btn, #view-mode-toggle {
  background: rgba(30, 20, 10, 0.04) !important;
  border-radius: 12px !important;
  border: none !important;
  font-weight: 600 !important;
}

.week-label {
  font-weight: 700 !important;
  color: #1a1410 !important;
}

/* Header actions buttons - polished pills */
.header-actions button,
button#add-site-btn,
button#copy-week-btn,
button#add-absence-btn,
button#logout-btn,
button#manage-btn,
button#change-pin-btn,
button#my-times-btn {
  border-radius: 14px !important;
  padding: 9px 16px !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  border: 1px solid rgba(30, 20, 10, 0.1) !important;
  background: white !important;
  color: #1a1410 !important;
  box-shadow: 0 1px 3px rgba(30, 20, 10, 0.04) !important;
}
.header-actions button:hover {
  background: #f5efe2 !important;
  border-color: rgba(30, 20, 10, 0.18) !important;
}
button#add-site-btn,
button.primary {
  background: #1d4ed8 !important;
  color: white !important;
  border-color: #1d4ed8 !important;
  box-shadow: 0 4px 14px -3px rgba(29, 78, 216, 0.4) !important;
  font-weight: 700 !important;
}
button#add-site-btn:hover, button.primary:hover {
  background: #0e2a73 !important;
  border-color: #0e2a73 !important;
  box-shadow: 0 6px 20px -3px rgba(29, 78, 216, 0.5) !important;
  transform: translateY(-1px) !important;
}

/* Stempel-Btn (Worker) */
.stamp-btn {
  background: #2f8d6a !important;
  border-color: #2f8d6a !important;
  color: white !important;
  border-radius: 14px !important;
  padding: 9px 16px !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 14px -3px rgba(47, 141, 106, 0.4) !important;
}
.stamp-btn.clocked-in {
  background: #e87457 !important;
  border-color: #e87457 !important;
  box-shadow: 0 4px 14px -3px rgba(232, 116, 87, 0.5) !important;
}

/* User badge */
.user-badge {
  background: #f0f4ff !important;
  color: #0e2a73 !important;
  border-radius: 999px !important;
  padding: 5px 14px !important;
  font-weight: 700 !important;
  font-size: 12px !important;
}
.user-badge.editor { background: #dcf0e6 !important; color: #2f8d6a !important; }

/* === Tabs as Segmented Control (statt voller Breite Underline) === */
.app-tabs {
  background: rgba(30, 20, 10, 0.05) !important;
  padding: 5px !important;
  border-radius: 999px !important;
  border: none !important;
  width: fit-content !important;
  margin: 12px 24px !important;
  display: inline-flex !important;
  gap: 2px !important;
  box-shadow: none !important;
  overflow: visible !important;
}
.app-tab {
  border-radius: 999px !important;
  padding: 8px 18px !important;
  background: transparent !important;
  border: none !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  color: #857a6c !important;
  box-shadow: none !important;
  margin: 0 !important;
  font-style: normal !important;
}
.app-tab:hover {
  color: #1a1410 !important;
  background: rgba(255, 255, 255, 0.5) !important;
}
.app-tab.active {
  background: #ffffff !important;
  color: #1d4ed8 !important;
  box-shadow: 0 2px 6px rgba(30, 20, 10, 0.08) !important;
  border-bottom: none !important;
}

/* === Legend bar (Heute · Wochenende · Feiertag) === */
.legend {
  background: transparent !important;
  border-bottom: none !important;
  padding: 6px 24px 10px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #857a6c !important;
}
.legend-swatch {
  border-radius: 4px !important;
  width: 10px !important;
  height: 10px !important;
}
.sync-indicator {
  background: #dcf0e6 !important;
  color: #2f8d6a !important;
  padding: 5px 14px !important;
  border-radius: 999px !important;
  font-weight: 700 !important;
  font-size: 11px !important;
  border: 1px solid rgba(47, 141, 106, 0.2) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.sync-indicator.error {
  background: #fadcd4 !important;
  color: #c4533e !important;
  border-color: rgba(196, 83, 62, 0.2) !important;
}

/* === Worker / Vehicle Pool Sidebar === */
aside.worker-pool {
  background: white !important;
  border-right: 1px solid rgba(30, 20, 10, 0.06) !important;
  padding: 16px !important;
}
aside.worker-pool h3 {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: #857a6c !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  margin: 0 0 10px 0 !important;
}
.pool-hint {
  font-size: 11px !important;
  color: #bcb2a3 !important;
  font-weight: 500 !important;
  margin-bottom: 10px !important;
}

/* === Chip — colored pill, more polished === */
.chip {
  border-radius: 999px !important;
  padding: 5px 12px !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  letter-spacing: -0.005em !important;
  border: 1px solid rgba(0, 0, 0, 0.06) !important;
  box-shadow: 0 2px 6px -1px rgba(30, 20, 10, 0.12) !important;
  line-height: 1.5 !important;
}
.chip.is-am::before, .chip.is-pm::before { display: none !important; }
.chip.is-am, .chip.is-pm { padding-left: 12px !important; }

/* Slot badges */
.chip .slot-badge {
  background: rgba(255,255,255,0.95) !important;
  color: rgba(0,0,0,0.7) !important;
  border-radius: 999px !important;
  padding: 1px 7px !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  margin-left: 4px !important;
  letter-spacing: 0.02em !important;
  box-shadow: none !important;
  border: none !important;
}

/* Vehicle chip */
.vehicle-chip, .vehicle-chip-cell {
  background: #1a1410 !important;
  color: white !important;
  border-radius: 999px !important;
  padding: 4px 10px !important;
  font-weight: 600 !important;
  font-size: 11px !important;
  border: none !important;
  box-shadow: 0 2px 6px -1px rgba(30,20,10,0.2) !important;
}

/* === Week Grid === */
table.week-grid {
  border-radius: 18px !important;
  border: 1px solid rgba(30, 20, 10, 0.06) !important;
  background: white !important;
  box-shadow: 0 4px 20px -8px rgba(30, 20, 10, 0.08) !important;
  overflow: hidden !important;
}
table.week-grid thead th {
  background: #f5efe2 !important;
  border-bottom: 1px solid rgba(30, 20, 10, 0.06) !important;
  padding: 14px 8px !important;
}
table.week-grid thead th .day-name {
  font-weight: 700 !important;
  color: #857a6c !important;
  letter-spacing: 0.06em !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
}
table.week-grid thead th .day-date {
  font-weight: 800 !important;
  color: #1a1410 !important;
  font-size: 18px !important;
  margin-top: 4px !important;
}
table.week-grid thead th.today {
  background: #e6edff !important;
}
table.week-grid thead th.today .day-name,
table.week-grid thead th.today .day-date {
  color: #1d4ed8 !important;
}

th.row-header {
  background: white !important;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  color: #1a1410 !important;
  border-right: 1px solid rgba(30, 20, 10, 0.06) !important;
  padding: 14px !important;
}
th.row-header .site-notes {
  font-weight: 500 !important;
  color: #857a6c !important;
  font-size: 11px !important;
}

td.day-cell {
  background: white !important;
  border-bottom: 1px solid rgba(30, 20, 10, 0.05) !important;
  border-right: 1px solid rgba(30, 20, 10, 0.04) !important;
  padding: 8px !important;
}
td.day-cell.weekend { background: #fafaf3 !important; }
td.day-cell.today { background: rgba(230, 237, 255, 0.5) !important; }
td.day-cell.holiday { background: #fdf3ec !important; }
td.day-cell.inactive {
  background: repeating-linear-gradient(45deg, #f5efe2, #f5efe2 6px, #ece5d6 6px, #ece5d6 7px) !important;
  opacity: 0.5 !important;
}

.cell-day-note {
  background: #fff8e0 !important;
  border-left: 3px solid #d49532 !important;
  border-radius: 6px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #6b4d12 !important;
}

/* Plan badges (3/3 ok, 2/3 under, 4/3 over) */
.plan-badge {
  border-radius: 8px !important;
  padding: 2px 7px !important;
  font-weight: 800 !important;
  font-size: 10px !important;
  border: none !important;
}
.plan-badge.plan-ok { background: #dcf0e6 !important; color: #2f8d6a !important; }
.plan-badge.plan-under { background: #f8ecd1 !important; color: #b07a14 !important; }
.plan-badge.plan-over { background: #fadcd4 !important; color: #c4533e !important; }
.plan-badge.plan-empty { background: rgba(30,20,10,0.06) !important; color: #857a6c !important; }

/* Cell-actions (📝 ×) — als Mini-Pills */
.cell-action {
  border-radius: 999px !important;
  width: 26px !important;
  height: 26px !important;
  border: none !important;
  background: white !important;
  box-shadow: 0 2px 6px rgba(30,20,10,0.15) !important;
}
.cell-action.note-btn { background: #d49532 !important; color: white !important; }
.cell-action.deactivate-btn { background: white !important; color: #857a6c !important; border: 1px solid rgba(30,20,10,0.1) !important; }

/* Site action mini buttons (Doku, Bearbeiten, ×) */
th.row-header button.mini {
  border-radius: 999px !important;
  padding: 4px 10px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  background: rgba(30, 20, 10, 0.04) !important;
  border: none !important;
  color: #1a1410 !important;
  box-shadow: none !important;
}
th.row-header button.mini:hover {
  background: rgba(30, 20, 10, 0.08) !important;
}
th.row-header button.mini.doku {
  background: #f0f4ff !important;
  color: #1d4ed8 !important;
}

/* === Cards (Verwaltung, Stat, Day) === */
.verw-card, .day-site-card, .day-absence-card, .stat-card, .dashboard-section, .dashboard-hero, .login-card {
  border-radius: 22px !important;
  border: 1px solid rgba(30, 20, 10, 0.06) !important;
  background: white !important;
  box-shadow: 0 2px 14px -4px rgba(30, 20, 10, 0.10) !important;
}
.verw-card:hover, .day-site-card:hover, .stat-card:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px -6px rgba(30, 20, 10, 0.16) !important;
  border-color: rgba(30, 20, 10, 0.12) !important;
}

.verw-card-name, .day-card-name {
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  font-weight: 800 !important;
  color: #1a1410 !important;
  letter-spacing: -0.02em !important;
}

/* Stat-cards: colorful icon + big number */
.stat-card {
  padding: 22px !important;
}
.stat-icon {
  width: 52px !important;
  height: 52px !important;
  border-radius: 16px !important;
}
.stat-number {
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  font-weight: 800 !important;
  font-size: 32px !important;
  color: #1a1410 !important;
}
.stat-label {
  font-weight: 600 !important;
  color: #857a6c !important;
}

/* Dashboard Hero */
.dashboard-hero {
  padding: 28px 32px !important;
  background: linear-gradient(135deg, #1d4ed8 0%, #0e2a73 100%) !important;
  color: white !important;
  border: none !important;
  box-shadow: 0 12px 32px -8px rgba(29, 78, 216, 0.25) !important;
}
.dh-greeting { color: white !important; font-weight: 800 !important; font-size: 28px !important; }
.dh-greeting strong { color: white !important; font-weight: 800 !important; }
.dh-greeting em { color: #fde7df !important; font-style: normal !important; font-weight: 800 !important; }
.dh-date { color: rgba(255,255,255,0.8) !important; font-weight: 500 !important; }
.dh-logo svg { color: white !important; opacity: 0.9 !important; }

/* === Sub-Nav Pills (in Verwaltung) === */
.verw-subnav {
  background: rgba(30, 20, 10, 0.05) !important;
  padding: 5px !important;
  border-radius: 999px !important;
  border: none !important;
  width: fit-content !important;
}
.verw-subnav .vsub {
  border-radius: 999px !important;
  padding: 8px 18px !important;
  background: transparent !important;
  font-weight: 600 !important;
  font-style: normal !important;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  color: #857a6c !important;
}
.verw-subnav .vsub.active {
  background: white !important;
  color: #1d4ed8 !important;
  box-shadow: 0 2px 6px rgba(30, 20, 10, 0.08) !important;
}

/* === Day Strip === */
.day-strip {
  background: transparent !important;
  border: none !important;
  gap: 8px !important;
}
.day-strip-day {
  border-radius: 16px !important;
  background: white !important;
  border: 1px solid rgba(30, 20, 10, 0.06) !important;
  box-shadow: 0 1px 3px rgba(30, 20, 10, 0.04) !important;
  padding: 12px 8px !important;
}
.day-strip-day .dsd-name {
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  font-weight: 700 !important;
  color: #857a6c !important;
}
.day-strip-day .dsd-date {
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  font-weight: 800 !important;
  color: #1a1410 !important;
}
.day-strip-day.today .dsd-date,
.day-strip-day.today .dsd-name { color: #1d4ed8 !important; }
.day-strip-day.selected {
  background: #1d4ed8 !important;
  border-color: #1d4ed8 !important;
  box-shadow: 0 6px 16px -4px rgba(29, 78, 216, 0.4) !important;
}
.day-strip-day.selected .dsd-name,
.day-strip-day.selected .dsd-date { color: white !important; }

/* === Day Card === */
.day-card-head {
  padding: 16px 18px 14px !important;
  background: #f5efe2 !important;
  border-bottom: 1px solid rgba(30, 20, 10, 0.06) !important;
}
.day-card-section { padding: 14px 18px !important; }
.day-card-label {
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  font-weight: 700 !important;
  font-size: 11px !important;
  letter-spacing: 0.06em !important;
  color: #857a6c !important;
}

/* === Dialogs === */
.dialog {
  border-radius: 24px !important;
  background: white !important;
  border: 1px solid rgba(30, 20, 10, 0.08) !important;
  box-shadow: 0 24px 48px -12px rgba(30, 20, 10, 0.25) !important;
}
.dialog h2:first-child {
  background: white !important;
  border-bottom: 1px solid rgba(30, 20, 10, 0.06) !important;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  font-weight: 800 !important;
  font-size: 22px !important;
  color: #1a1410 !important;
  letter-spacing: -0.02em !important;
}
.dialog h2:first-child::before { display: none !important; }
.dialog .actions {
  background: #faf5ed !important;
  border-top: 1px solid rgba(30, 20, 10, 0.06) !important;
  border-bottom-left-radius: 24px !important;
  border-bottom-right-radius: 24px !important;
}

.dialog input[type="text"], .dialog input[type="email"], .dialog input[type="tel"],
.dialog input[type="number"], .dialog input[type="date"], .dialog select, .dialog textarea,
.stamm-input {
  border-radius: 14px !important;
  border: 1px solid rgba(30, 20, 10, 0.1) !important;
  padding: 12px 14px !important;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  font-size: 14px !important;
  background: white !important;
}
.dialog input:focus, .dialog select:focus, .dialog textarea:focus,
.stamm-input:focus {
  outline: none !important;
  border-color: #1d4ed8 !important;
  box-shadow: 0 0 0 3px rgba(29, 78, 216, 0.12) !important;
}

/* Backdrop */
.dialog-backdrop {
  background: rgba(30, 20, 10, 0.4) !important;
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
}

/* === Login === */
.login-card {
  border-radius: 28px !important;
  padding: 48px 36px !important;
  background: white !important;
  border: 1px solid rgba(30, 20, 10, 0.06) !important;
  box-shadow: 0 24px 60px -16px rgba(30, 20, 10, 0.18) !important;
}
.login-btn-google, .login-btn-pin {
  border-radius: 14px !important;
  padding: 14px !important;
  font-weight: 700 !important;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
}
#pin-input {
  border-radius: 14px !important;
  padding: 14px !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  text-align: center !important;
  letter-spacing: 0.3em !important;
}

/* === Doku Dialog === */
.doku-dialog {
  border-radius: 24px !important;
}
.doku-header {
  background: white !important;
  border-bottom: 1px solid rgba(30, 20, 10, 0.06) !important;
  padding: 18px 22px !important;
}
.doku-header h2 {
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  font-weight: 800 !important;
}
.doku-tabs { background: #faf5ed !important; }
.doku-tab {
  font-weight: 700 !important;
  border-bottom-width: 3px !important;
}
.doku-tab.active { color: #1d4ed8 !important; border-bottom-color: #1d4ed8 !important; }

.doku-photo-btn {
  background: #fde7df !important;
  color: #b54a30 !important;
  border: 2px solid #e87457 !important;
  border-radius: 14px !important;
}
.doku-send-btn {
  background: #1d4ed8 !important;
  color: white !important;
  border: none !important;
  border-radius: 14px !important;
  box-shadow: 0 4px 12px -3px rgba(29, 78, 216, 0.4) !important;
  font-weight: 700 !important;
}

/* === Empty States === */
.empty-state, .verw-empty-hero {
  border-radius: 24px !important;
  background: white !important;
  border: 1px solid rgba(30, 20, 10, 0.06) !important;
  box-shadow: 0 4px 16px -4px rgba(30, 20, 10, 0.08) !important;
  padding: 64px 32px !important;
}
.empty-state::before { display: none !important; }

/* === Toast === */
.toast {
  border-radius: 16px !important;
  background: #1a1410 !important;
  font-weight: 600 !important;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif !important;
  padding: 14px 20px !important;
  box-shadow: 0 12px 32px -8px rgba(0,0,0,0.3) !important;
}
.toast.success { background: #2f8d6a !important; }
.toast.warning { background: #d49532 !important; }
.toast.error { background: #c4533e !important; }

/* === Mobile === */
@media (max-width: 700px) {
  header.app-header { padding: 10px 12px !important; gap: 6px !important; }
  .app-tabs { margin: 8px 12px !important; padding: 4px !important; }
  .app-tab { padding: 6px 14px !important; font-size: 12px !important; }
  .header-actions button { padding: 6px 10px !important; font-size: 11px !important; }
  .verw-subnav .vsub { padding: 6px 12px !important; font-size: 12px !important; }
}
