/* Sprint 5.3 UI Polish: Swiss Industrial Premium refinement only. */
:root {
  --shadow: 0 18px 54px rgba(11, 15, 20, .10);
  --shadow-tight: 0 8px 24px rgba(11, 15, 20, .075);
  --radius-lg: 14px;
}

button,
.moduleCard,
.screenHead,
.missionCard,
.todayHero,
.timerCommandCard,
.previewContextButton,
.tabRail button,
.bottomNav button,
select,
input,
textarea {
  transition: background-color .16s ease, border-color .16s ease, box-shadow .16s ease, color .16s ease, transform .12s ease;
}

button:active { transform: translateY(1px); }
button:hover { box-shadow: 0 10px 26px rgba(11, 15, 20, .08); }

h2 {
  font-size: clamp(24px, 2.7vw, 38px);
  line-height: 1.04;
  font-weight: 880;
}

h3 {
  margin-top: 6px;
  font-size: clamp(18px, 1.8vw, 24px);
  line-height: 1.08;
  font-weight: 840;
}

p { margin-top: 7px; }

.appHeader h1 {
  font-size: clamp(26px, 2.5vw, 38px);
  font-weight: 880;
}

.appHeader span,
.todayIntro span,
.activeJobCard span,
.timerCommandCard span,
.moduleCard span,
.packPanel span,
.screenHead span,
.missionCard span,
.reportDraft span,
.entryPanel span,
.todaySummaryGrid span {
  font-size: 11px;
  letter-spacing: .06em;
}

.appShell { padding-top: max(10px, env(safe-area-inset-top)); }
.workspace { gap: 12px; }
.screen { gap: 13px; }

.dataStatus {
  min-height: 32px;
  padding: 6px 10px;
  box-shadow: 0 6px 18px rgba(11, 15, 20, .055);
}

.dataStatus strong,
.dataStatus small { font-size: 11px; }

.todayHero {
  gap: 14px;
  padding: 20px;
  box-shadow: 0 22px 64px rgba(11, 15, 20, .22);
}

.todayIntro p,
.activeJobCard p { line-height: 1.32; }

.activeJobCard {
  padding: 15px;
  border-radius: 12px;
}

.activeJobCard strong {
  min-height: 30px;
  margin-top: 12px;
  padding: 0 10px;
  font-size: 12px;
}

.timerCommandCard {
  gap: 14px;
  padding: 18px;
  box-shadow: 0 20px 58px rgba(11, 15, 20, .22), inset 0 1px 0 rgba(255, 255, 255, .07);
}

.timerCommandCard h2 { font-size: clamp(25px, 2.6vw, 38px); }

.timerActions { gap: 8px; }

.bigTimerButton,
.dangerAction,
.submitAction {
  min-height: 58px;
  font-size: 17px;
}

.primaryAction {
  box-shadow: 0 10px 26px rgba(184, 255, 44, .18), inset 0 1px 0 rgba(255,255,255,.34) !important;
}

.primaryAction:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 32px rgba(184, 255, 44, .24), inset 0 1px 0 rgba(255,255,255,.38) !important;
}

.mainActionRow,
.headActions,
.cardActions,
.heroActions { gap: 8px; }

.cardActions .primaryAction {
  min-height: 54px;
  font-size: 15px;
}

.cardActions button:not(.primaryAction) {
  color: rgba(27, 36, 48, .72);
  background: rgba(238, 242, 246, .55);
  border-color: rgba(27, 36, 48, .08);
  box-shadow: none;
}

.cardActions button:first-child:not(.primaryAction) {
  background: transparent;
  border-color: rgba(27, 36, 48, .10);
}

.todaySummaryGrid { gap: 10px; }

.todaySummaryGrid article,
.metricGrid article {
  min-height: 96px;
  padding: 14px;
}

.todaySummaryGrid strong { font-size: 24px; }
.todaySummaryGrid small { font-size: 12px; }

.fieldQuickActions { gap: 8px; }
.fieldQuickActions button {
  min-height: 66px;
  border: 1px solid rgba(27, 36, 48, .08);
  box-shadow: 0 8px 20px rgba(11, 15, 20, .055);
}

.moduleCard {
  min-height: 112px;
  padding: 15px;
}

.screenHead {
  padding: 17px;
  gap: 14px;
}

.screenHead p { max-width: 680px; }

.missionCard {
  gap: 14px;
  padding: 15px;
  box-shadow: 0 8px 22px rgba(11, 15, 20, .06);
}

.missionCard strong { margin-top: 8px; }

/* Keep the ORARI status accent language, just make it crisper. */
.priority-hoch,
.priority-normal,
.priority-tief {
  border-left-width: 5px;
}

.priority-hoch { border-left-color: var(--warning); }
.priority-normal { border-left-color: var(--primary); }
.priority-tief { border-left-color: var(--accent); }

.tabRail { gap: 6px; }
.tabRail button {
  min-height: 42px;
  min-width: 98px;
  padding: 0 12px;
}

.metricGrid { gap: 10px; }
.metricGrid strong { font-size: 18px; }

.reportDraft,
.moduleGrid,
.splitGrid,
.entryChoiceGrid,
.formGrid { gap: 12px; }

.timeForm {
  gap: 13px;
  padding: 17px;
}

.entryPanel {
  gap: 10px;
  padding: 14px;
}

.formPreview {
  min-height: 56px;
  padding: 12px 14px;
}

.packPanel { padding: 15px; gap: 13px; }
.chipList { gap: 6px; }
.chipList span { min-height: 30px; }

.heroPanel {
  gap: 14px;
  padding: 20px;
  box-shadow: 0 22px 64px rgba(11, 15, 20, .20);
}
.heroPanel h2 { font-size: clamp(26px, 2.6vw, 40px); }

.previewContextButton:hover,
.headerAction:hover,
.iconButton:hover {
  border-color: rgba(184, 255, 44, .30);
}

.previewContextPanel {
  gap: 14px;
  padding: 16px;
  box-shadow: 0 28px 76px rgba(11, 15, 20, .40);
}

.previewPanelHead h2 { font-size: 18px; }
.previewRoleGrid button { min-height: 38px; }
.previewHint { padding: 9px 11px; }

.moduleRail {
  gap: 5px;
}

.moduleRail button,
.drawerNav button {
  min-height: 42px;
  grid-template-columns: 28px minmax(0, 1fr);
  border-radius: 9px;
}

.moduleRail button.active,
.drawerNav button.active {
  box-shadow: 0 9px 22px rgba(184, 255, 44, .14);
}

.bottomNav {
  border-radius: 16px;
  box-shadow: 0 14px 38px rgba(11, 15, 20, .30);
}

.bottomNav button { min-height: 56px; }

@media (min-width: 860px) {
  body {
    background:
      linear-gradient(90deg, #0B0F14 0, #0B0F14 calc(50% - 640px + 206px), transparent calc(50% - 640px + 206px)),
      linear-gradient(180deg, #0B0F14 0, #0B0F14 126px, transparent 126px),
      linear-gradient(135deg, #ffffff 0, var(--bg) 52%, #edf3f8 100%);
  }

  .appShell {
    width: min(1380px, 100%);
    padding: 14px 24px 38px;
  }

  .appHeader {
    grid-template-columns: 196px minmax(0, 1fr) auto;
    min-height: 78px;
    margin-bottom: 2px;
  }

  .workspace { gap: 14px; }

  .mainLayout {
    grid-template-columns: 196px minmax(720px, 1fr);
    gap: 22px;
  }

  .moduleRail {
    min-height: calc(100dvh - 106px);
    padding: 14px 10px;
    border-radius: 18px;
  }

  .moduleRail::before {
    margin: 0 8px 14px;
    font-size: 18px;
  }

  .screen {
    max-width: 1120px;
    gap: 14px;
  }

  .todayHero {
    min-height: 238px;
    padding: 26px;
    grid-template-columns: minmax(0, 1.1fr) minmax(300px, .9fr);
  }

  .todayIntro h2 {
    font-size: clamp(36px, 3vw, 52px);
  }

  .activeJobCard { padding: 19px; }

  .timerCommandCard {
    min-height: 156px;
    grid-template-columns: minmax(220px, 310px) minmax(0, 1fr);
    padding: 22px;
  }

  .timerCommandCard h2 {
    font-size: clamp(30px, 2.5vw, 42px);
  }

  .bigTimerButton,
  .dangerAction { min-height: 62px; }

  .todaySummaryGrid article { min-height: 104px; }
  .fieldQuickActions button { min-height: 68px; }
  .screenHead { padding: 19px; }
  .moduleCard { padding: 16px; }
  .heroPanel { padding: 22px; }
}

@media (min-width: 1280px) {
  :root { --max: 1280px; }
  .appShell { padding-left: 30px; padding-right: 30px; }
  .appHeader { grid-template-columns: 204px minmax(0, 1fr) auto; }
  .mainLayout { grid-template-columns: 204px minmax(780px, 1fr); gap: 24px; }
  .screen { max-width: 1140px; }
}

@media (max-width: 859px) {
  .appShell { padding-top: max(7px, env(safe-area-inset-top)); }
  .previewSwitcher { margin-top: -2px; }
  .screen { gap: 12px; }
  .dataStatus { order: 5; }
}

@media (max-width: 640px) {
  body {
    background:
      linear-gradient(180deg, #0B0F14 0, #0B0F14 128px, transparent 128px),
      linear-gradient(135deg, #ffffff 0, var(--bg) 52%, #edf3f8 100%);
  }

  .appShell {
    padding: max(6px, env(safe-area-inset-top)) 8px calc(100px + env(safe-area-inset-bottom));
  }

  .appHeader {
    min-height: 62px;
    grid-template-columns: 40px minmax(0, 1fr) auto;
    gap: 10px;
  }

  .appHeader h1 { font-size: 25px; }
  .appHeader span { font-size: 10px; }

  .iconButton,
  .headerAction {
    min-width: 40px;
    min-height: 40px;
    padding: 0 9px;
  }

  .headerAction { min-width: 64px; }

  .previewContextButton { min-height: 38px; }

  h2 { font-size: 25px; }
  h3 { font-size: 19px; }

  p { line-height: 1.34; }

  .todayHero {
    gap: 10px;
    padding: 13px;
    border-radius: 16px;
  }

  .todayIntro h2 { font-size: 28px; }
  .todayIntro p { margin-top: 5px; }

  .activeJobCard {
    padding: 12px;
    border-radius: 12px;
  }

  .activeJobCard h3 { font-size: 18px; }
  .activeJobCard p { display: none; }
  .activeJobCard strong { margin-top: 10px; }

  .timerCommandCard {
    gap: 11px;
    padding: 13px;
    border-radius: 16px;
  }

  .timerCommandCard h2 { font-size: 26px; }

  .bigTimerButton,
  .dangerAction,
  .submitAction {
    min-height: 54px;
    font-size: 16px;
  }

  .mainActionRow,
  .headActions,
  .cardActions { gap: 7px; }

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

  .todaySummaryGrid article {
    min-height: 72px;
    padding: 9px;
    gap: 4px;
  }

  .todaySummaryGrid span {
    font-size: 9px;
    letter-spacing: .03em;
  }

  .todaySummaryGrid strong { font-size: 18px; }
  .todaySummaryGrid small { font-size: 10px; line-height: 1.2; }

  .fieldQuickActions { gap: 7px; }
  .fieldQuickActions button {
    min-height: 58px;
    font-size: 11px;
  }

  .screenHead,
  .missionCard,
  .moduleCard,
  .timeForm,
  .entryPanel,
  .packPanel,
  .heroPanel {
    padding: 13px;
    border-radius: 14px;
  }

  .missionCard strong { margin-top: 7px; }

  .cardActions .primaryAction,
  .cardActions button {
    min-height: 48px;
  }

  .moduleCard { min-height: 96px; }
  .metricGrid article { min-height: 80px; padding: 11px; }

  .bottomNav {
    left: max(6px, env(safe-area-inset-left));
    right: max(6px, env(safe-area-inset-right));
    bottom: max(6px, env(safe-area-inset-bottom));
    padding: 5px;
  }

  .bottomNav button {
    min-height: 52px;
    font-size: 11px;
  }
}

@media (max-width: 380px) {
  .todaySummaryGrid { grid-template-columns: 1fr; }
  .fieldQuickActions { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .fieldQuickActions button { font-size: 10px; }
}
