:root {
  --doco-red: #14AFE6;
  --doco-red-dark: #0B3A57;
  --doco-gold: #FFD200;
  --doco-cream: #FFF8DE;
  --doco-rice: #FAFACD;
  --doco-blue: #14AFE6;
  --doco-blue-dark: #0B3A57;
  --doco-yellow: #FFD200;
  --doco-green: #41B43C;
  --doco-danger: #EB000F;
  --ink: #123047;
  --muted: #557083;
  --line: #CDE8F2;
  --card: #ffffff;
  --ok: #41B43C;
  --warn: #FFD200;
  --bad: #EB000F;
  font-family: Inter, "Segoe UI", "Microsoft YaHei", "Noto Sans Thai", Arial, sans-serif;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  color: var(--ink);
  background: var(--doco-rice);
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  border: 0;
  cursor: pointer;
}

.login-shell {
  min-height: 100vh;
  min-height: 100dvh;
  display: grid;
  place-items: center;
  padding: 32px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 12% 10%, rgba(213, 155, 74, .28), transparent 30%),
    radial-gradient(circle at 86% 20%, rgba(167, 45, 58, .16), transparent 30%),
    linear-gradient(135deg, #fffaf1, #f6e9df 55%, #efd8ce);
}

.login-shell::before {
  content: "";
  position: absolute;
  inset: -24%;
  z-index: 0;
  background:
    conic-gradient(from 120deg at 55% 45%, rgba(213, 155, 74, .26), transparent 16%, rgba(167, 45, 58, .18), transparent 44%, rgba(255, 248, 234, .42), transparent 72%, rgba(213, 155, 74, .26));
  filter: blur(40px);
  opacity: .66;
  animation: loginGlow 18s ease-in-out infinite alternate;
}

.login-shell::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(117, 28, 40, .045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(117, 28, 40, .035) 1px, transparent 1px),
    radial-gradient(circle at center, rgba(255, 255, 255, .30), transparent 56%);
  background-size: 42px 42px, 42px 42px, 100% 100%;
  opacity: .46;
}

.login-ambient {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}

.login-ambient span {
  position: absolute;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  border: 1px solid rgba(213, 155, 74, .30);
  background: radial-gradient(circle, rgba(255, 248, 234, .26), transparent 63%);
  opacity: .56;
  animation: loginFloat 16s ease-in-out infinite;
}

.login-ambient span:nth-child(1) {
  left: 7%;
  top: 12%;
}

.login-ambient span:nth-child(2) {
  right: 8%;
  top: 18%;
  width: 180px;
  height: 180px;
  animation-delay: -5s;
}

.login-ambient span:nth-child(3) {
  left: 54%;
  bottom: -80px;
  width: 320px;
  height: 320px;
  animation-delay: -9s;
}

.login-card {
  width: min(1010px, 100%);
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
  position: relative;
  z-index: 1;
  background: rgba(255, 252, 247, .84);
  border: 1px solid rgba(167, 45, 58, .14);
  border-radius: 26px;
  box-shadow:
    0 34px 100px rgba(117, 28, 40, .22),
    0 1px 0 rgba(255, 255, 255, .80) inset;
  overflow: hidden;
  backdrop-filter: blur(22px) saturate(1.12);
  animation: loginCardIn .72s cubic-bezier(.22, 1, .36, 1) both;
}

.login-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .46);
}

.brand-panel {
  min-height: 560px;
  padding: 46px;
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 248, 234, .20), transparent 28%),
    radial-gradient(circle at 76% 78%, rgba(213, 155, 74, .42), transparent 34%),
    linear-gradient(145deg, #8f2532 0%, var(--doco-red) 46%, #c84c4d 68%, #e0a04d 100%);
  color: white;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 34px;
}

.brand-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(circle at 24px 24px, rgba(255, 248, 234, .12) 0 2px, transparent 3px),
    linear-gradient(120deg, rgba(255, 255, 255, .16), transparent 28%, transparent 72%, rgba(255, 248, 234, .14));
  background-size: 34px 34px, 100% 100%;
  opacity: .72;
}

.brand-panel::after {
  content: "";
  position: absolute;
  right: -116px;
  bottom: -126px;
  width: 330px;
  height: 330px;
  border-radius: 50%;
  border: 34px solid rgba(255, 248, 234, .30);
  filter: drop-shadow(0 18px 36px rgba(117, 28, 40, .18));
  animation: brandRingPulse 6s ease-in-out infinite;
}

.brand-orbit {
  position: absolute;
  right: -96px;
  bottom: -92px;
  z-index: 1;
  width: 360px;
  height: 360px;
  pointer-events: none;
}

.brand-orbit span {
  position: absolute;
  inset: 0;
  border: 1px solid rgba(255, 248, 234, .22);
  border-radius: 50%;
  animation: orbitBreath 8s ease-in-out infinite;
}

.brand-orbit span:nth-child(2) {
  inset: 54px;
  animation-delay: -2.4s;
}

.brand-orbit span:nth-child(3) {
  inset: 108px;
  animation-delay: -4.8s;
}

.brand-mark {
  width: 76px;
  height: 76px;
  display: grid;
  place-items: center;
  border-radius: 22px;
  background: #fff8ea;
  color: var(--doco-red);
  font-size: 22px;
  font-weight: 900;
  letter-spacing: .5px;
  position: relative;
  z-index: 2;
  box-shadow:
    0 16px 36px rgba(117, 28, 40, .18),
    0 1px 0 rgba(255, 255, 255, .72) inset;
}

.brand-copy {
  position: relative;
  z-index: 2;
}

.brand-kicker {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 11px;
  border: 1px solid rgba(255, 248, 234, .32);
  border-radius: 999px;
  background: rgba(255, 248, 234, .12);
  color: rgba(255, 248, 234, .92);
  font-size: 12px;
  font-weight: 800;
  backdrop-filter: blur(12px);
}

.brand-panel h1 {
  margin: 22px 0 12px;
  font-size: 42px;
  line-height: 1.05;
  max-width: 460px;
}

.brand-panel p {
  margin: 0;
  max-width: 420px;
  line-height: 1.7;
  opacity: .92;
}

.login-signal-row {
  position: relative;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.login-signal-row span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 10px;
  border: 1px solid rgba(255, 248, 234, .28);
  border-radius: 999px;
  background: rgba(33, 27, 24, .14);
  color: rgba(255, 248, 234, .90);
  font-size: 12px;
  font-weight: 800;
  backdrop-filter: blur(14px);
}

.login-form {
  padding: 52px 48px;
  display: grid;
  gap: 19px;
  align-content: center;
  position: relative;
  background:
    radial-gradient(circle at 100% 0%, rgba(213, 155, 74, .14), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, .74), rgba(255, 255, 255, .50));
}

.login-form::before {
  content: "";
  position: absolute;
  left: 0;
  top: 44px;
  bottom: 44px;
  width: 1px;
  background: linear-gradient(transparent, rgba(213, 155, 74, .42), transparent);
}

.login-form-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 6px;
}

.login-form-top h2 {
  margin: 4px 0 0;
  color: var(--ink);
  font-size: 30px;
  line-height: 1.1;
}

.login-mode-hint {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.login-eyebrow {
  display: inline-flex;
  color: var(--doco-red);
  font-size: 12px;
  font-weight: 900;
}

.auth-mode-switch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  padding: 5px;
  border: 1px solid rgba(167, 45, 58, .13);
  border-radius: 14px;
  background: rgba(255, 255, 255, .70);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .72);
}

.auth-mode-switch button {
  min-height: 38px;
  border-radius: 10px;
  background: transparent;
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease;
}

.auth-mode-switch button.active {
  background: #fff;
  color: var(--doco-red-dark);
  box-shadow: 0 8px 20px rgba(117, 28, 40, .12);
}

.login-form .field,
.login-form .btn,
.login-form .error {
  animation: loginItemIn .58s cubic-bezier(.22, 1, .36, 1) both;
}

.login-form .field:nth-of-type(1) {
  animation-delay: .08s;
}

.login-form .field:nth-of-type(2) {
  animation-delay: .15s;
}

.login-form .btn {
  position: relative;
  overflow: hidden;
  min-height: 48px;
  box-shadow: 0 14px 30px rgba(167, 45, 58, .24);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.login-form .btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 0 32%, rgba(255, 255, 255, .28) 46%, transparent 60% 100%);
  transform: translateX(-120%);
  transition: transform .55s ease;
}

.login-form .btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 40px rgba(167, 45, 58, .30);
}

.login-form .btn:hover::before {
  transform: translateX(120%);
}

.login-form .btn span {
  position: relative;
  z-index: 1;
}

.login-form .input {
  min-height: 48px;
  background: rgba(255, 255, 255, .86);
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease, background .2s ease;
}

.login-form .input:focus {
  transform: translateY(-1px);
  background: #fff;
}

.login-help {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.login-register-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border-radius: 12px;
  border: 1px solid rgba(167, 45, 58, .18);
  background: rgba(255, 255, 255, .62);
  color: var(--doco-red-dark);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}

.login-register-link:hover {
  transform: translateY(-1px);
  border-color: rgba(167, 45, 58, .34);
  background: #fff;
}

.register-card {
  grid-template-columns: minmax(0, .95fr) minmax(380px, 1fr);
}

.register-brand {
  min-height: 620px;
}

.register-flow {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 10px;
}

.register-flow span {
  display: flex;
  align-items: center;
  min-height: 40px;
  padding: 9px 12px;
  border: 1px solid rgba(255, 248, 234, .28);
  border-radius: 12px;
  background: rgba(33, 27, 24, .16);
  color: rgba(255, 248, 234, .92);
  font-size: 13px;
  font-weight: 900;
  backdrop-filter: blur(14px);
}

.register-flow span::before {
  content: "";
  width: 14px;
  height: 2px;
  margin-right: 10px;
  border-radius: 2px;
  background: #fff8ea;
}

.register-form {
  align-content: center;
}

.field {
  display: grid;
  gap: 7px;
}

.field span,
.form-grid label span {
  color: var(--muted);
  font-size: 13px;
}

.input,
.select,
textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px 13px;
  background: white;
  color: var(--ink);
  outline: none;
}

.input:focus,
.select:focus,
textarea:focus {
  border-color: var(--doco-red);
  box-shadow: 0 0 0 3px rgba(167, 45, 58, .12);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  padding: 10px 16px;
  border-radius: 12px;
  background: var(--doco-red);
  color: white;
  font-weight: 700;
}

.btn.secondary {
  background: #fff4ee;
  color: var(--doco-red-dark);
}

.btn.ghost {
  background: transparent;
  color: var(--doco-red);
  border: 1px solid var(--line);
}

.btn.danger {
  background: #fff1f1;
  color: var(--bad);
  border: 1px solid rgba(190, 52, 65, .25);
}

.btn.danger.solid {
  background: var(--bad);
  color: #fff;
  border-color: var(--bad);
}

.icon-btn {
  width: 38px;
  height: 38px;
  display: inline-grid;
  place-items: center;
  border-radius: 10px;
  background: #fff7f2;
  color: var(--doco-red-dark);
  font-size: 24px;
  line-height: 1;
}

.quick-logins {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(33, 27, 24, .42);
  backdrop-filter: blur(3px);
}

.modal-card {
  width: min(620px, 100%);
  max-height: min(760px, calc(100vh - 36px));
  overflow: auto;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 24px 70px rgba(33, 27, 24, .24);
}

.modal-card form {
  display: grid;
}

.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 22px 14px;
  border-bottom: 1px solid var(--line);
}

.modal-header h2 {
  margin: 0;
  font-size: 21px;
}

.modal-header p {
  margin: 6px 0 0;
  color: var(--muted);
  line-height: 1.5;
}

.modal-body {
  padding: 18px 22px;
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 22px 22px;
  border-top: 1px solid var(--line);
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}

.detail-grid article {
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff9f1;
}

.detail-grid strong {
  display: block;
  font-size: 22px;
}

.detail-grid span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
}

.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px;
}

.lang-switch button {
  border-radius: 999px;
  padding: 7px 10px;
  color: var(--muted);
  background: transparent;
  font-weight: 800;
}

.lang-switch button.active {
  background: var(--doco-red);
  color: #fff;
}

.app-shell {
  min-height: 100vh;
}

.mobile-shell {
  max-width: 440px;
  min-height: 100vh;
  margin: 0 auto;
  background: #f7f4ef;
  padding-bottom: 84px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, .04);
}

.mobile-header {
  padding: 18px 18px 14px;
  background: #fff;
  display: flex;
  align-items: center;
  gap: 12px;
  position: sticky;
  top: 0;
  z-index: 4;
}

.logo-circle {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: var(--doco-red);
  color: white;
  display: grid;
  place-items: center;
  font-weight: 900;
  font-size: 14px;
  flex: none;
}

.header-title {
  flex: 1;
}

.header-title strong {
  display: block;
  font-size: 20px;
}

.header-title small {
  color: var(--muted);
}

.scan-btn {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: var(--doco-cream);
  color: var(--doco-red);
  font-size: 20px;
}

.mobile-content {
  padding: 14px;
}

.hero-banner {
  min-height: 174px;
  border-radius: 0 0 24px 24px;
  margin: 0 -14px 14px;
  padding: 28px 22px;
  color: #fff;
  background:
    radial-gradient(circle at 82% 42%, rgba(255, 248, 234, .36), transparent 24%),
    linear-gradient(135deg, #a72d3a, #d45b50 62%, #e6a449);
  overflow: hidden;
  position: relative;
}

.hero-banner::after {
  content: "";
  position: absolute;
  right: -44px;
  bottom: -54px;
  width: 170px;
  height: 170px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .18);
  box-shadow: inset 0 0 0 22px rgba(255, 248, 234, .28);
}

.hero-banner h2 {
  margin: 0 0 10px;
  font-size: 30px;
  line-height: 1.05;
}

.hero-banner p {
  margin: 0;
  opacity: .92;
}

.today-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.today-strip article {
  min-width: 0;
  border-radius: 14px;
  padding: 12px;
  background: #fff;
  border: 1px solid rgba(117, 28, 40, .08);
}

.today-strip strong {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 16px;
}

.today-strip span {
  color: var(--muted);
  font-size: 12px;
}

.today-command {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: stretch;
  margin-bottom: 12px;
  padding: 14px;
  border-radius: 18px;
  color: #fff;
  background: linear-gradient(135deg, #a72d3a, #c34a42 62%, #d88935);
  box-shadow: 0 14px 34px rgba(117, 28, 40, .18);
}

.today-command-main {
  min-width: 0;
  display: grid;
  align-content: center;
  gap: 5px;
}

.today-command-main span,
.today-command-main small {
  color: rgba(255, 255, 255, .82);
  font-size: 12px;
}

.today-command-main strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 24px;
  line-height: 1.05;
}

.today-command-metrics {
  display: grid;
  grid-template-columns: repeat(2, 74px);
  gap: 8px;
}

.today-command-metrics button {
  min-width: 0;
  min-height: 72px;
  padding: 9px 8px;
  border-radius: 14px;
  background: rgba(255, 255, 255, .16);
  color: #fff;
  text-align: left;
  border: 1px solid rgba(255, 255, 255, .22);
  cursor: pointer;
}

.today-command-metrics strong {
  display: block;
  font-size: 21px;
  line-height: 1;
}

.today-command-metrics span {
  display: block;
  margin-top: 7px;
  font-size: 11px;
  line-height: 1.2;
  color: rgba(255, 255, 255, .86);
}

.quick-actions-card {
  padding-top: 14px;
  padding-bottom: 14px;
}

.daily-closure {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  margin-bottom: 12px;
  padding: 12px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(117, 28, 40, .08);
}

.daily-closure strong {
  display: block;
  font-size: 18px;
}

.daily-closure span,
.daily-closure small {
  color: var(--muted);
  font-size: 12px;
}

.daily-closure progress {
  width: 100%;
  height: 10px;
  accent-color: var(--primary);
}

.next-task-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
  padding: 14px;
  border-radius: 16px;
  color: #fff;
  background: #211b18;
  box-shadow: 0 14px 34px rgba(33, 27, 24, .16);
}

.next-task-panel.complete {
  color: var(--ink);
  background: #fff;
  border: 1px solid rgba(47, 140, 90, .18);
  box-shadow: 0 10px 26px rgba(47, 140, 90, .08);
}

.next-task-panel div {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.next-task-panel span,
.next-task-panel small {
  color: rgba(255, 255, 255, .72);
  font-size: 12px;
}

.next-task-panel.complete span {
  color: var(--ok);
}

.next-task-panel strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 17px;
}

.next-task-panel button {
  flex: none;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 12px;
  background: var(--doco-gold);
  color: #211b18;
  font-weight: 900;
}

.task-filter-chips {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}

.task-filter-chips button {
  display: grid;
  gap: 4px;
  min-height: 54px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fffaf4;
  color: var(--muted);
  text-align: left;
}

.task-filter-chips button.active {
  border-color: rgba(167, 45, 58, .34);
  background: #fff1ea;
  color: var(--doco-red);
}

.task-filter-chips span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
}

.task-filter-chips strong {
  color: var(--ink);
  font-size: 18px;
  line-height: 1;
}

.task-phase {
  position: relative;
  padding-left: 14px;
}

.task-phase::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 24px;
  bottom: 0;
  width: 2px;
  border-radius: 999px;
  background: #eadfd3;
}

.task-phase:last-child::before {
  bottom: calc(100% - 26px);
}

.task-phase-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 2px 0 10px;
}

.task-phase-head div {
  min-width: 0;
}

.task-phase-head span {
  color: var(--doco-red-dark);
  font-size: 14px;
  font-weight: 900;
}

.task-phase-head p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.task-phase-head strong {
  flex: none;
  padding: 5px 8px;
  border-radius: 999px;
  background: #fff4ee;
  color: var(--doco-red);
  font-size: 12px;
}

.task-phase-list {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}

.quiz-card {
  margin-top: 24px;
  padding: 18px;
  border-radius: 14px;
  background: #fffdfb;
  border: 1px solid rgba(117, 28, 40, .1);
}

.quiz-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 0;
  color: var(--text);
}

.quiz-check input {
  margin-top: 3px;
}

.quiz-question-block {
  margin: 14px 0;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}

.quiz-question-text {
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--ink);
}

.quiz-choices {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.quiz-choice {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 10px;
  border: 1px solid var(--line);
  cursor: pointer;
  transition: background .2s;
}

.quiz-choice:hover {
  background: var(--doco-cream);
}

.quiz-choice.chosen {
  background: rgba(117, 28, 40, .06);
  border-color: var(--doco-red);
}

.quiz-choice.correct {
  background: rgba(47, 140, 90, .08);
  border-color: var(--ok);
}

.quiz-choice.correct .choice-marker {
  color: var(--ok);
  font-weight: bold;
}

.quiz-choice.wrong {
  background: rgba(190, 52, 65, .08);
  border-color: var(--bad);
}

.quiz-choice.wrong .choice-marker {
  color: var(--bad);
  font-weight: bold;
}

.quiz-result-bar {
  display: flex;
  gap: 16px;
  padding: 10px;
  margin: 10px 0;
  background: var(--doco-cream);
  border-radius: 10px;
  font-size: 14px;
}

.quiz-passed-badge {
  padding: 14px;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  color: var(--ok);
  background: rgba(47, 140, 90, .06);
  border-radius: 12px;
  margin: 10px 0;
}

.quiz-failed-badge {
  padding: 14px;
  text-align: center;
  font-size: 16px;
  color: var(--bad);
  background: rgba(190, 52, 65, .06);
  border-radius: 12px;
  margin: 10px 0;
}

.quiz-edit-block {
  border-radius: 8px;
}

.quiz-edit-choice {
  margin-left: 12px;
}

.warn-panel {
  background: #fff3cd !important;
  border: 2px solid #ffc107 !important;
}

.module-card {
  background: var(--card);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 10px 30px rgba(117, 28, 40, .06);
  margin-bottom: 12px;
}

.module-title {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 12px;
}

.module-title h3 {
  margin: 0;
  font-size: 18px;
}

.module-title span {
  color: var(--muted);
  font-size: 13px;
}

.icon-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px 8px;
}

.icon-grid.four {
  grid-template-columns: repeat(4, 1fr);
}

.icon-item {
  display: grid;
  justify-items: center;
  gap: 8px;
  color: var(--ink);
  text-align: center;
  min-height: 78px;
}

.icon-badge {
  width: 44px;
  height: 44px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  color: var(--doco-red);
  background: #fff3ed;
  border: 1px solid #f0d5c7;
  font-size: 22px;
  position: relative;
}

.dot {
  position: absolute;
  right: -5px;
  top: -7px;
  min-width: 19px;
  height: 19px;
  padding: 0 5px;
  border-radius: 999px;
  background: #ed1d2f;
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 11px;
  font-weight: 900;
}

.notice-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 13px 14px;
  background: #fff;
  border-radius: 16px;
  margin-bottom: 12px;
}

.notice-row strong {
  color: var(--doco-red-dark);
}

.notice-row span {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.task-card,
.message-row,
.admin-card {
  background: #fff;
  border: 1px solid rgba(117, 28, 40, .08);
  border-radius: 16px;
  padding: 14px;
  margin-bottom: 10px;
}

.task-card.next-card {
  border-color: rgba(213, 155, 74, .62);
  box-shadow: 0 12px 30px rgba(213, 155, 74, .16);
}

.task-card header,
.message-row {
  display: flex;
  gap: 12px;
  align-items: center;
}

.task-phase-dot {
  flex: none;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: var(--doco-red);
  box-shadow: 0 0 0 5px #fff1ea;
}

.task-phase-dot.operating {
  background: var(--doco-gold);
  box-shadow: 0 0 0 5px #fff6e6;
}

.task-phase-dot.handover {
  background: #4666b0;
  box-shadow: 0 0 0 5px #eef2ff;
}

.task-phase-dot.closing {
  background: var(--ink);
  box-shadow: 0 0 0 5px #eee9e4;
}

.task-phase-dot.other {
  background: var(--muted);
  box-shadow: 0 0 0 5px #f3eee9;
}

.task-card header div:first-of-type,
.message-text {
  flex: 1;
  min-width: 0;
}

.task-card h4,
.message-row h4 {
  margin: 0 0 4px;
  font-size: 16px;
  line-height: 1.25;
}

.task-card p,
.message-row p,
.admin-card p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.danger-note {
  margin-top: 8px !important;
  color: var(--bad) !important;
}

.overdue-card {
  border-color: rgba(190, 52, 65, .35);
  box-shadow: 0 10px 28px rgba(190, 52, 65, .08);
}

.muted {
  color: var(--muted);
}

.submit-proof {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 12px;
  align-items: end;
}

.submit-proof .file-input {
  grid-column: 1 / -1;
}

.submit-proof .btn {
  grid-column: 1 / -1;
}

.task-progress {
  flex: none;
  min-width: 44px;
  padding: 5px 8px;
  border-radius: 999px;
  background: #fff4ee;
  color: var(--doco-red-dark);
  font-size: 12px;
  font-weight: 900;
  text-align: center;
}

.task-checklist-panel {
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fffaf4;
  overflow: hidden;
}

.task-checklist-panel summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 46px;
  padding: 12px 14px;
  color: var(--ink);
  font-weight: 900;
  cursor: pointer;
}

.task-checklist-panel summary strong {
  color: var(--doco-red);
  font-size: 13px;
}

.task-checklist-panel .submit-proof {
  margin: 0;
  padding: 12px;
  border-top: 1px solid var(--line);
}

.task-step-list {
  margin: 0;
  padding: 0 14px 12px 34px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.7;
}

.check-field {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
}

.check-field input {
  width: 20px;
  height: 20px;
  accent-color: var(--doco-red);
  flex: none;
}

.check-field span {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.check-field strong {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.35;
}

.check-field small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.task-input-field {
  display: grid;
  gap: 7px;
}

.task-input-field span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 800;
}

.task-input-field.abnormal .input {
  border-color: rgba(199, 121, 25, .55);
  background: #fffaf0;
  box-shadow: 0 0 0 3px rgba(199, 121, 25, .10);
}

.field-alert {
  display: none;
  flex: none;
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(199, 121, 25, .12);
  color: var(--warn);
  font-size: 11px;
  font-weight: 900;
}

.task-input-field.abnormal .field-alert {
  display: inline-flex;
}

.task-input-field,
.submit-proof .check-field {
  grid-column: 1 / -1;
}

.submit-proof-actions {
  position: sticky;
  bottom: 0;
  z-index: 2;
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  margin: 4px -12px -12px;
  padding: 10px 12px;
  border-top: 1px solid var(--line);
  background: rgba(255, 250, 244, .94);
  backdrop-filter: blur(10px);
}

.submit-proof-actions .btn {
  grid-column: auto;
  min-height: 42px;
  padding: 0 18px;
}

.draft-status {
  min-height: 16px;
  color: var(--muted);
  font-size: 12px;
}

.daily-report-preview {
  grid-column: 1 / -1;
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(167, 45, 58, .14);
  border-radius: 12px;
  background: #fff;
}

.daily-report-preview > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.daily-report-preview strong {
  color: var(--doco-red-dark);
  font-size: 13px;
}

.daily-report-preview button {
  min-height: 32px;
  padding: 0 10px;
  border-radius: 9px;
  background: #fff2ea;
  color: var(--doco-red);
  font-size: 12px;
  font-weight: 900;
}

.daily-report-preview pre {
  margin: 0;
  padding: 10px;
  border-radius: 10px;
  background: #fffaf4;
  color: var(--ink);
  white-space: pre-wrap;
  word-break: break-word;
  font-family: inherit;
  font-size: 12px;
  line-height: 1.55;
}

.daily-report-toolbar {
  display: grid;
  gap: 10px;
}

.daily-report-list {
  display: grid;
  gap: 12px;
}

.daily-report-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(117, 28, 40, .08);
  border-radius: 14px;
  background: #fffdfb;
}

.daily-report-card header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.daily-report-card header div {
  display: grid;
  gap: 4px;
}

.daily-report-card header strong {
  color: var(--ink);
  font-size: 16px;
}

.daily-report-card header span:not(.status) {
  color: var(--muted);
  font-size: 12px;
}

.daily-report-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.daily-report-metrics div {
  padding: 10px;
  border-radius: 10px;
  background: #fff7f2;
}

.daily-report-metrics span {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.daily-report-metrics strong {
  display: block;
  margin-top: 4px;
  color: var(--ink);
  font-size: 18px;
}

.template-builder textarea {
  resize: vertical;
  line-height: 1.55;
}

.task-template-studio-panel,
.template-list-panel,
.task-publish-panel {
  overflow: visible;
}

.template-studio-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.template-studio-title h2 {
  margin: 0;
}

.template-studio-title p {
  margin: 5px 0 0;
  max-width: 680px;
  color: var(--muted);
  line-height: 1.55;
}

.task-template-studio {
  display: grid;
  gap: 16px;
}

.template-basic-grid {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(180px, .72fr) minmax(210px, .72fr);
  gap: 12px;
  align-items: end;
}

.template-basic-grid label {
  min-width: 0;
}

.template-submit-row,
.template-drawer-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.template-builder-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 16px;
  align-items: start;
}

.template-builder-workbench {
  display: grid;
  gap: 12px;
}

.template-builder-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(20, 175, 230, .16);
  border-radius: 8px;
  background: transparent;
}

.template-builder-head strong {
  display: block;
  color: var(--ink);
}

.template-builder-head span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.template-builder-head.secondary-head {
  margin-top: 4px;
  background: transparent;
}

.template-row-list {
  display: grid;
  gap: 10px;
}

.template-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 36px;
  gap: 8px 10px;
  align-items: start;
  padding: 10px 12px;
  border: 1px solid rgba(20, 175, 230, .14);
  border-radius: 8px;
  background: #fbfdff;
}

.template-row.compact {
  grid-template-columns: 34px minmax(0, 1fr) 160px auto 36px;
}

.template-row-index {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: var(--doco-blue-soft);
  color: var(--doco-blue-dark);
  font-weight: 900;
  font-size: 12px;
}

.template-row-wide {
  grid-column: 2 / 4;
  min-width: 0;
}

.template-row-toggle {
  grid-column: 2;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 32px;
  padding-top: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.template-row-remove {
  grid-column: 3;
  grid-row: 1;
  width: 34px;
  height: 34px;
  margin-top: 21px;
}

@media (min-width: 981px) {
  .template-row:not(.compact) {
    grid-template-columns: 34px minmax(180px, .78fr) minmax(260px, 1.15fr) 74px 36px;
    align-items: start;
  }

  .template-row:not(.compact) .template-row-wide,
  .template-row:not(.compact) .template-row-toggle,
  .template-row:not(.compact) .template-row-remove {
    grid-column: auto;
    grid-row: auto;
  }

  .template-row:not(.compact) .template-row-toggle {
    margin-top: 24px;
  }

  .template-row:not(.compact) .template-row-remove {
    margin-top: 22px;
  }
}

.template-steps-field {
  display: grid;
  gap: 6px;
}

.template-preview-card {
  position: sticky;
  top: 14px;
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(11, 58, 87, .13);
  border-radius: 8px;
  background: #f8fcff;
  box-shadow: none;
}

.template-preview-top span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.template-preview-top strong {
  display: block;
  margin-top: 4px;
  color: var(--ink);
  font-size: 20px;
}

.template-preview-proof {
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(255, 210, 0, .22);
  color: var(--doco-blue-dark);
  font-size: 12px;
  font-weight: 900;
}

.template-preview-list {
  display: grid;
  gap: 8px;
}

.template-preview-item {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 9px;
  padding: 9px;
  border: 1px solid rgba(20, 175, 230, .14);
  border-radius: 8px;
  background: #fff;
}

.template-preview-item > span {
  width: 22px;
  height: 22px;
  border: 2px solid rgba(20, 175, 230, .55);
  border-radius: 6px;
  background: #fff;
}

.template-preview-item strong {
  display: block;
  font-size: 13px;
}

.template-preview-item small,
.template-preview-empty {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.template-drawer-actions {
  justify-content: flex-start;
}

.template-list-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.template-list-head h2 {
  margin: 0;
}

.template-list-head p {
  margin: 4px 0 0;
  color: var(--muted);
}

.template-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
}

.template-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(20, 175, 230, .14);
  border-radius: 8px;
  background: rgba(255, 255, 255, .92);
}

.template-card header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.template-card header strong {
  display: block;
  color: var(--ink);
  font-size: 15px;
}

.template-card header div > span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
}

.template-card-meta,
.template-card-fields {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.template-card-meta span,
.template-card-fields span {
  padding: 5px 8px;
  border-radius: 999px;
  background: #f8fcff;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.template-card footer {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

[data-theme="dark"] .template-builder-head,
[data-theme="dark"] .template-row,
[data-theme="dark"] .template-preview-card,
[data-theme="dark"] .template-preview-item,
[data-theme="dark"] .template-card {
  background: rgba(15, 23, 42, .78);
  border-color: rgba(148, 163, 184, .18);
}

[data-theme="dark"] .template-builder-head.secondary-head {
  background: rgba(15, 23, 42, .58);
}

[data-theme="dark"] .template-preview-card {
  box-shadow: none;
}

[data-theme="dark"] .template-preview-item > span {
  background: transparent;
}

[data-theme="dark"] .template-card-meta span,
[data-theme="dark"] .template-card-fields span {
  background: rgba(148, 163, 184, .10);
}

@media (max-width: 980px) {
  .template-basic-grid {
    grid-template-columns: 1fr;
  }

  .template-builder-layout {
    grid-template-columns: 1fr;
  }

  .template-preview-card {
    position: static;
  }

  .template-row,
  .template-row.compact {
    grid-template-columns: 30px 1fr;
  }

  .template-row-wide,
  .template-row-toggle,
  .template-row-remove {
    grid-column: 2;
  }

  .template-row-toggle,
  .template-row-remove {
    padding-top: 0;
    margin-top: 0;
  }

  .template-row.compact .template-row-toggle,
  .template-row.compact .template-row-remove {
    grid-column: 2;
  }
}

@media (max-width: 640px) {
  .template-builder-head {
    align-items: stretch;
    flex-direction: column;
  }

  .template-builder-head .btn {
    width: 100%;
  }

  .template-studio-title {
    display: block;
  }

  .template-row,
  .template-row.compact {
    grid-template-columns: 1fr;
  }

  .template-row-index {
    width: fit-content;
    min-width: 30px;
  }

  .template-row-wide,
  .template-row-toggle,
  .template-row-remove {
    grid-column: 1;
  }

  .template-submit-row,
  .template-drawer-actions,
  .template-card footer {
    display: grid;
    grid-template-columns: 1fr;
  }

  .template-submit-row .btn,
  .template-drawer-actions .btn,
  .template-card footer .btn {
    width: 100%;
  }
}

.photo-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.photo-strip img {
  width: 58px;
  height: 58px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: #fff;
}

.warn-panel {
  border-color: rgba(199, 121, 25, .28);
  background: #fffaf0;
}

.week-grid {
  display: grid;
  grid-template-columns: 150px repeat(7, minmax(92px, 1fr));
  gap: 1px;
  overflow-x: auto;
  background: #f0e7de;
  border: 1px solid #f0e7de;
  border-radius: 14px;
}

.week-head,
.week-user,
.week-cell {
  background: #fff;
  min-height: 58px;
  padding: 10px;
}

.week-head {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-align: center;
}

.week-user {
  font-weight: 800;
}

.week-cell strong {
  display: block;
  color: var(--doco-red);
  font-size: 13px;
}

.week-cell small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
}

.status {
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 12px;
  font-weight: 800;
  background: #f3eee9;
  color: var(--muted);
}

.status.pending,
.status.rejected {
  background: #fff1f1;
  color: var(--bad);
}

.status.overdue {
  background: #ffe8e8;
  color: var(--bad);
}

.status.submitted {
  background: #fff7df;
  color: var(--warn);
}

.status.done {
  background: #eaf7ef;
  color: var(--ok);
}

.status.cancelled {
  background: #eee9e4;
  color: var(--muted);
}

button:disabled {
  cursor: not-allowed;
  opacity: .45;
}

.bottom-nav {
  position: fixed;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: min(440px, 100%);
  height: 72px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: rgba(255, 255, 255, .96);
  border-top: 1px solid rgba(117, 28, 40, .08);
  backdrop-filter: blur(12px);
  padding-bottom: env(safe-area-inset-bottom);
}

.bottom-nav button {
  background: transparent;
  color: #b7aea6;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 3px;
  font-size: 12px;
}

.bottom-nav button strong {
  font-size: 22px;
  line-height: 1;
}

.bottom-nav .nav-icon {
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
}

.bottom-nav .nav-icon svg {
  width: 23px;
  height: 23px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.bottom-nav button.active {
  color: var(--doco-red);
}

.admin-shell {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: 100vh;
}

.admin-side {
  background: #fff;
  padding: 22px;
  border-right: 1px solid var(--line);
  position: sticky;
  top: 0;
  height: 100vh;
}

.admin-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 26px;
}

.admin-nav {
  display: grid;
  gap: 8px;
}

.admin-nav button {
  text-align: left;
  border-radius: 13px;
  padding: 12px;
  background: transparent;
  color: var(--muted);
}

.admin-nav button.active {
  background: #fff2ea;
  color: var(--doco-red);
  font-weight: 800;
}

.admin-main {
  padding: 24px;
  min-width: 0;
  position: relative;
}

.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
  gap: 16px;
}

.topbar h1 {
  margin: 0;
  font-size: 28px;
}

.stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.stat-grid.compact {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.stat {
  background: #fff;
  border-radius: 18px;
  padding: 18px;
  border: 1px solid rgba(117, 28, 40, .08);
}

.stat strong {
  display: block;
  font-size: 28px;
  margin-bottom: 4px;
}

.stat span {
  color: var(--muted);
}

.stat-grid.compact .stat {
  padding: 12px;
}

.stat-grid.compact .stat strong {
  font-size: 20px;
}

.filter-bar {
  display: grid;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
  gap: 10px;
  margin: 12px 0 14px;
}

.workbench-list {
  display: grid;
  gap: 8px;
}

.workbench-list > div:not(.empty) {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid rgba(117, 28, 40, .08);
  border-radius: 10px;
  background: #fffdfb;
}

.workbench-list strong {
  font-size: 13px;
}

.workbench-list span {
  color: var(--muted);
  min-width: 0;
}

.drawer {
  position: fixed;
  top: 0;
  right: -420px;
  width: 420px;
  height: 100vh;
  background: #fff;
  box-shadow: -4px 0 24px rgba(0,0,0,.12);
  transition: right .25s ease;
  z-index: 1000;
  display: flex;
  flex-direction: column;
}

.drawer.open {
  right: 0;
}

.drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid var(--line);
}

.drawer-header h2 {
  margin: 0;
  font-size: 20px;
}

.drawer-close {
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: var(--muted);
  padding: 4px 8px;
}

.drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}

@media (max-width: 860px) {
  .drawer {
    right: -100%;
    width: 100%;
  }
}

@media (max-width: 520px) {
  .drawer-header {
    padding: 14px 16px;
  }
  .drawer-body {
    padding: 16px;
  }
}

/* ===== PDF Document Viewer ===== */
.pdf-viewer {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #f5f5f5;
  z-index: 1000;
  overflow-y: auto;
  padding: 20px;
}

.pdf-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  padding: 12px 16px;
  background: white;
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

.pdf-toolbar-actions {
  display: flex;
  gap: 8px;
}

.pdf-document {
  max-width: 800px;
  margin: 0 auto;
  background: white;
  padding: 60px 80px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  border-radius: 4px;
  min-height: calc(100vh - 200px);
}

.pdf-header {
  text-align: center;
  margin-bottom: 40px;
  padding-bottom: 30px;
  border-bottom: 2px solid #333;
}

.pdf-logo {
  display: inline-block;
  background: #D44522;
  color: white;
  width: 60px;
  height: 60px;
  line-height: 60px;
  border-radius: 50%;
  font-weight: bold;
  font-size: 18px;
  margin-bottom: 20px;
}

.pdf-title {
  font-size: 28px;
  font-weight: bold;
  margin: 16px 0 8px;
  color: #333;
  line-height: 1.4;
}

.pdf-title-en {
  font-size: 20px;
  color: #666;
  margin: 8px 0;
  font-weight: normal;
}

.pdf-title-th {
  font-size: 18px;
  color: #888;
  margin: 8px 0 16px;
  font-weight: normal;
}

.pdf-meta {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-top: 16px;
  font-size: 14px;
  color: #666;
}

.pdf-divider {
  height: 1px;
  background: #ddd;
  margin: 30px 0;
}

.pdf-body {
  font-size: 16px;
  line-height: 1.8;
  color: #333;
}

.pdf-section {
  margin-bottom: 30px;
}

.pdf-section-title {
  font-size: 20px;
  font-weight: bold;
  color: #D44522;
  margin-bottom: 16px;
  padding-bottom: 8px;
  border-bottom: 1px solid #eee;
}

.pdf-content {
  margin-bottom: 30px;
}

.pdf-content p {
  margin: 8px 0;
}

.pdf-content ul {
  margin: 8px 0;
  padding-left: 24px;
}

.pdf-content li {
  margin: 6px 0;
  line-height: 1.6;
}

.pdf-content .checklist {
  list-style: none;
  padding-left: 0;
}

.pdf-content .checklist-item {
  display: flex;
  align-items: flex-start;
  margin: 8px 0;
  padding: 8px 12px;
  background: #f9f9f9;
  border-radius: 4px;
  border-left: 3px solid #ddd;
}

.pdf-content .checklist-item .checkbox {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid #ddd;
  border-radius: 3px;
  margin-right: 10px;
  flex-shrink: 0;
  text-align: center;
  line-height: 16px;
  font-size: 14px;
}

.pdf-content .checklist-item .checkbox.checked {
  background: #D44522;
  border-color: #D44522;
  color: white;
}

.pdf-footer {
  margin-top: 60px;
  padding-top: 20px;
  border-top: 1px solid #eee;
  font-size: 12px;
  color: #999;
}

.pdf-footer-content {
  display: flex;
  justify-content: space-between;
}

/* Print styles */
@media print {
  .pdf-toolbar {
    display: none;
  }
  
  .pdf-viewer {
    background: white;
    padding: 0;
  }
  
  .pdf-document {
    box-shadow: none;
    padding: 40px;
  }
}

/* Mobile responsive */
@media (max-width: 860px) {
  .pdf-viewer {
    padding: 10px;
  }
  
  .pdf-document {
    padding: 30px 20px;
    min-height: auto;
  }
  
  .pdf-title {
    font-size: 22px;
  }
  
  .pdf-toolbar {
    flex-direction: column;
    gap: 10px;
  }
  
  .pdf-toolbar-actions {
    width: 100%;
    justify-content: flex-end;
  }
}

@media (max-width: 520px) {
  .pdf-document {
    padding: 20px 16px;
  }
  
  .pdf-title {
    font-size: 18px;
  }
  
  .pdf-section-title {
    font-size: 16px;
  }
  
  .pdf-body {
    font-size: 14px;
  }
}

.panel {
  background: #fff;
  border-radius: 20px;
  padding: 18px;
  border: 1px solid rgba(117, 28, 40, .08);
  margin-bottom: 16px;
  min-width: 0;
}

.panel h2 {
  margin: 0 0 14px;
  font-size: 20px;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  align-items: end;
}

.form-grid label {
  display: grid;
  gap: 6px;
}

.toolbar-row {
  display: flex;
  align-items: end;
  gap: 12px;
  flex-wrap: wrap;
}

.toolbar-row label {
  display: grid;
  gap: 6px;
  min-width: 240px;
}

.toolbar-row label span {
  color: var(--muted);
  font-size: 13px;
}

.table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

table {
  width: 100%;
  border-collapse: collapse;
  min-width: 760px;
}

th,
td {
  text-align: left;
  padding: 11px 10px;
  border-bottom: 1px solid #f0e7de;
  vertical-align: top;
}

th {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

td:last-child {
  white-space: nowrap;
}

.empty {
  text-align: center;
  color: var(--muted);
  padding: 28px;
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 86px;
  transform: translateX(-50%);
  background: #211b18;
  color: #fff;
  padding: 10px 14px;
  border-radius: 999px;
  z-index: 10;
  box-shadow: 0 10px 30px rgba(0, 0, 0, .2);
}

@keyframes loginGlow {
  0% {
    transform: translate3d(-2%, -1%, 0) rotate(0deg) scale(1);
  }

  100% {
    transform: translate3d(2%, 2%, 0) rotate(10deg) scale(1.05);
  }
}

@keyframes loginFloat {
  0%, 100% {
    transform: translate3d(0, 0, 0) scale(1);
  }

  50% {
    transform: translate3d(18px, -24px, 0) scale(1.04);
  }
}

@keyframes loginCardIn {
  0% {
    opacity: 0;
    transform: translateY(18px) scale(.985);
  }

  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes loginItemIn {
  0% {
    opacity: 0;
    transform: translateY(10px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes brandRingPulse {
  0%, 100% {
    transform: scale(1);
    opacity: .78;
  }

  50% {
    transform: scale(1.04);
    opacity: 1;
  }
}

@keyframes orbitBreath {
  0%, 100% {
    transform: scale(1);
    opacity: .36;
  }

  50% {
    transform: scale(1.08);
    opacity: .78;
  }
}

@media (prefers-reduced-motion: reduce) {
  .login-shell::before,
  .login-ambient span,
  .login-card,
  .brand-panel::after,
  .brand-orbit span,
  .login-form .field,
  .login-form .btn,
  .login-form .error {
    animation: none;
  }

  .login-form .btn,
  .login-form .input {
    transition: none;
  }
}

@media (max-width: 860px) {
  .login-card {
    grid-template-columns: 1fr;
  }

  .brand-panel {
    min-height: 340px;
    padding: 34px;
  }

  .register-brand {
    min-height: 390px;
  }

  .login-form {
    padding: 38px 34px;
  }

  .login-form::before {
    display: none;
  }

  .admin-shell {
    grid-template-columns: 1fr;
  }

  .admin-main {
    padding: 18px;
  }

  .admin-side {
    height: auto;
    position: static;
  }

  .admin-nav {
    grid-template-columns: repeat(2, 1fr);
  }

  .stat-grid,
  .stat-grid.compact,
  .filter-bar,
  .form-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 520px) {
  body {
    background: #f7f4ef;
  }

  .login-shell {
    padding: 0;
  }

  .login-card {
    min-height: 100vh;
    min-height: 100dvh;
    border-radius: 0;
  }

  .brand-panel {
    min-height: 310px;
    padding: 30px 26px;
  }

  .register-brand {
    min-height: 360px;
  }

  .brand-panel h1 {
    font-size: 34px;
  }

  .brand-panel p {
    line-height: 1.58;
  }

  .login-form {
    padding: 30px 24px 32px;
  }

  .login-form-top {
    align-items: stretch;
    flex-direction: column-reverse;
    gap: 14px;
  }

  .login-form-top .lang-switch {
    align-self: flex-start;
    gap: 6px !important;
    padding: 5px !important;
  }

  .login-form-top .lang-switch button {
    min-height: 30px !important;
    padding: 6px 10px !important;
    font-size: 12px !important;
  }

  .login-form-top h2 {
    font-size: 26px;
  }

  .register-flow {
    gap: 8px;
  }

  .register-flow span {
    min-height: 34px;
    font-size: 12px;
  }

  .login-signal-row {
    gap: 7px;
  }

  .quick-logins,
  .stat-grid,
  .stat-grid.compact,
  .filter-bar,
  .form-grid {
    grid-template-columns: 1fr;
  }

  .next-task-panel {
    align-items: stretch;
    flex-direction: column;
  }

  .next-task-panel button {
    width: 100%;
  }

  .task-filter-chips {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .workbench-list > div:not(.empty) {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .modal-backdrop {
    align-items: end;
    padding: 10px;
  }

  .modal-card {
    max-height: calc(100vh - 20px);
    border-radius: 18px 18px 10px 10px;
  }

  .modal-header,
  .modal-body,
  .modal-actions {
    padding-left: 16px;
    padding-right: 16px;
  }

  .modal-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .detail-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Employee performance trend */
.perf-trend {
  margin-top: 16px;
}

.perf-grid {
  display: grid;
  gap: 14px;
}

.perf-item {
  padding: 10px 0;
  border-bottom: 1px solid rgba(117, 28, 40, .06);
}

.perf-item:last-child {
  border-bottom: none;
}

.perf-label {
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 4px;
}

.perf-values {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-size: 14px;
}

.perf-values strong {
  font-size: 20px;
  color: var(--primary);
}

.perf-week {
  color: var(--text);
}

.trend-up {
  color: #22c55e;
  font-weight: 600;
}

.trend-down {
  color: #ef4444;
  font-weight: 600;
}

.trend-flat {
  color: var(--muted);
  font-weight: 600;
}

/* Top 3 employees */
.top3-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.top3-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 8px;
  background: rgba(117, 28, 40, .04);
}

.top3-rank {
  font-size: 18px;
}

.back-btn {
  background: none;
  border: none;
  font-size: 28px;
  color: var(--doco-red);
  cursor: pointer;
  padding: 4px 8px;
  margin-right: 4px;
}

.inventory-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px;
  background: var(--card);
  border-radius: 8px;
  border: 1px solid var(--line);
}

.inventory-item label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
}

.inventory-item .muted {
  font-size: 12px;
  color: var(--muted);
}

.inventory-item input {
  width: 100%;
  margin-top: 4px;
}

.task-review-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px;
  margin-bottom: 12px;
}

.task-review-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--line);
}

.task-review-header .muted {
  font-size: 12px;
  color: var(--muted);
}

.task-review-body {
  margin-bottom: 12px;
}

.field-row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  border-bottom: 1px dashed rgba(0, 0, 0, 0.05);
}

.field-label {
  display: grid;
  gap: 3px;
  font-size: 14px;
  color: var(--muted);
}

.field-label small {
  font-size: 12px;
  line-height: 1.45;
  color: var(--muted);
}

.field-value {
  font-size: 14px;
  font-weight: 600;
}

.photo-review {
  display: flex;
  gap: 8px;
  margin-top: 8px;
  flex-wrap: wrap;
}

.review-note {
  background: var(--doco-cream);
  padding: 8px;
  border-radius: 6px;
  margin-top: 8px;
  font-size: 13px;
  color: var(--warn);
}

.task-review-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

/* ═══════════════════════════════════════════
   Alpine.js 组件样式
   ═══════════════════════════════════════════ */

/* x-cloak: 隐藏未初始化的 Alpine 元素 */
[x-cloak] {
  display: none !important;
}

/* Toast 容器 */
.toast-container {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10000;
  pointer-events: none;
}

.toast-container .toast {
  background: var(--ink);
  color: #fff;
  padding: 10px 20px;
  border-radius: 8px;
  font-size: 14px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  white-space: nowrap;
}

/* Toast 过渡动画 */
.toast-enter {
  animation: toastIn 0.3s ease-out;
}

.toast-leave {
  animation: toastOut 0.3s ease-in;
}

@keyframes toastIn {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes toastOut {
  from { opacity: 1; transform: translateY(0); }
  to { opacity: 0; transform: translateY(-10px); }
}

/* Modal 过渡动画 */
.modal-enter {
  animation: modalIn 0.2s ease-out;
}

.modal-leave {
  animation: modalOut 0.2s ease-in;
}

@keyframes modalIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes modalOut {
  from { opacity: 1; }
  to { opacity: 0; }
}

/* Alpine 任务过滤按钮激活状态 */
.btn.ghost.active {
  background: var(--doco-red);
  color: #fff;
  border-color: var(--doco-red);
}

/* ═══ 主题切换按钮 ═══ */
.theme-toggle-btn {
  width: 38px;
  height: 38px;
  display: inline-grid;
  place-items: center;
  border-radius: 10px;
  background: #fff7f2;
  border: 1px solid var(--line);
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  transition: background 0.2s, border-color 0.2s;
  flex-shrink: 0;
}

.theme-toggle-btn:hover {
  background: var(--doco-cream);
}

/* ═══ 暗色模式：styles.css 组件覆盖 ═══ */
[data-theme="dark"] body {
  color: #e0e0e0;
  background: #1a1a1a;
}

[data-theme="dark"] .login-shell {
  background:
    radial-gradient(circle at 14% 12%, rgba(213, 155, 74, .14), transparent 30%),
    radial-gradient(circle at 82% 22%, rgba(167, 45, 58, .20), transparent 32%),
    linear-gradient(135deg, #201817, #171514 54%, #120f0e);
}

[data-theme="dark"] .login-shell::before {
  background:
    conic-gradient(from 120deg at 55% 45%, rgba(213, 155, 74, .18), transparent 18%, rgba(167, 45, 58, .22), transparent 44%, rgba(255, 248, 234, .10), transparent 74%, rgba(213, 155, 74, .14));
  opacity: .52;
}

[data-theme="dark"] .login-shell::after {
  background-image:
    linear-gradient(rgba(255, 248, 234, .035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 248, 234, .026) 1px, transparent 1px),
    radial-gradient(circle at center, rgba(255, 248, 234, .05), transparent 58%);
  opacity: .54;
}

[data-theme="dark"] .login-ambient span {
  border-color: rgba(213, 155, 74, .20);
  background: radial-gradient(circle, rgba(213, 155, 74, .10), transparent 64%);
}

[data-theme="dark"] .login-card {
  background: rgba(28, 24, 22, .78);
  border-color: rgba(255, 248, 234, .10);
  box-shadow:
    0 34px 110px rgba(0, 0, 0, .58),
    0 1px 0 rgba(255, 248, 234, .08) inset;
}

[data-theme="dark"] .brand-panel {
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 248, 234, .13), transparent 28%),
    radial-gradient(circle at 76% 78%, rgba(213, 155, 74, .32), transparent 34%),
    linear-gradient(145deg, #6f1f29 0%, #8b2230 48%, #a33d3e 68%, #b8843e 100%);
}

[data-theme="dark"] .brand-mark {
  background: #231c19;
  color: #e8a04a;
  box-shadow:
    0 16px 36px rgba(0, 0, 0, .30),
    0 1px 0 rgba(255, 248, 234, .10) inset;
}

[data-theme="dark"] .brand-kicker,
[data-theme="dark"] .login-signal-row span {
  border-color: rgba(255, 248, 234, .22);
  background: rgba(33, 27, 24, .24);
}

[data-theme="dark"] .login-form {
  background:
    radial-gradient(circle at 100% 0%, rgba(213, 155, 74, .09), transparent 34%),
    linear-gradient(180deg, rgba(35, 31, 29, .78), rgba(29, 25, 23, .92));
}

[data-theme="dark"] .login-form::before {
  background: linear-gradient(transparent, rgba(213, 155, 74, .24), transparent);
}

[data-theme="dark"] .login-form-top h2 {
  color: #fff8ea;
}

[data-theme="dark"] .login-eyebrow {
  color: #e8a04a;
}

[data-theme="dark"] .login-register-link {
  border-color: rgba(255, 248, 234, .12);
  background: rgba(255, 248, 234, .06);
  color: #f0c37a;
}

[data-theme="dark"] .login-register-link:hover {
  border-color: rgba(240, 195, 122, .28);
  background: rgba(255, 248, 234, .10);
}

[data-theme="dark"] .register-flow span {
  border-color: rgba(255, 248, 234, .18);
  background: rgba(20, 17, 16, .24);
}

[data-theme="dark"] .input,
[data-theme="dark"] .select,
[data-theme="dark"] textarea {
  background: #2a2a2a;
  border-color: #434343;
  color: #e0e0e0;
}

[data-theme="dark"] .input:focus,
[data-theme="dark"] .select:focus,
[data-theme="dark"] textarea:focus {
  border-color: #c84c4d;
  box-shadow: 0 0 0 3px rgba(200, 76, 77, .2);
}

[data-theme="dark"] .field span,
[data-theme="dark"] .form-grid label span {
  color: #8c8c8c;
}

[data-theme="dark"] .btn {
  background: #a72d3a;
  color: #fff;
}

[data-theme="dark"] .btn.secondary {
  background: #2a2a2a;
  color: #e8a04a;
}

[data-theme="dark"] .btn.ghost {
  background: transparent;
  color: #e8a04a;
  border-color: #434343;
}

[data-theme="dark"] .btn.danger {
  background: rgba(190, 52, 65, .15);
  color: #ff7875;
  border-color: rgba(190, 52, 65, .3);
}

[data-theme="dark"] .icon-btn {
  background: #2a2a2a;
  color: #e8a04a;
}

[data-theme="dark"] .theme-toggle-btn {
  background: #2a2a2a;
  border-color: #434343;
}

[data-theme="dark"] .theme-toggle-btn:hover {
  background: #333;
}

[data-theme="dark"] .mobile-settings-btn {
  background: #2a2a2a !important;
  color: #e8a04a !important;
  border-color: #434343 !important;
}

[data-theme="dark"] .mobile-settings-panel {
  background: #1f1f1f !important;
  border-color: #434343 !important;
  box-shadow: 0 16px 38px rgba(0, 0, 0, .48) !important;
}

[data-theme="dark"] .mobile-language-options button {
  background: #2a2a2a !important;
  color: #e0e0e0 !important;
}

[data-theme="dark"] .mobile-language-options button.active {
  background: var(--doco-red) !important;
  color: #fff !important;
}

[data-theme="dark"] .modal-backdrop {
  background: rgba(0, 0, 0, .65);
}

[data-theme="dark"] .modal-card {
  background: #1f1f1f;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .6);
}

[data-theme="dark"] .modal-header {
  border-bottom-color: #434343;
}

[data-theme="dark"] .modal-header h2 {
  color: #e0e0e0;
}

[data-theme="dark"] .modal-actions {
  border-top-color: #434343;
}

[data-theme="dark"] .detail-grid article {
  background: #2a2a2a;
  border-color: #434343;
}

[data-theme="dark"] .detail-grid strong {
  color: #e0e0e0;
}

[data-theme="dark"] .lang-switch {
  background: #2a2a2a;
  border-color: #434343;
}

[data-theme="dark"] .mobile-shell {
  background: #1a1a1a;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, .04);
}

[data-theme="dark"] .mobile-header {
  background: #1f1f1f;
}

[data-theme="dark"] .header-title strong {
  color: #e0e0e0;
}

[data-theme="dark"] .hero-banner {
  background:
    radial-gradient(circle at 82% 42%, rgba(255, 248, 234, .12), transparent 24%),
    linear-gradient(135deg, #8b2230, #a33d3e 62%, #b8843e);
}

[data-theme="dark"] .today-command {
  background: linear-gradient(135deg, #7f1d2a, #8f332f 62%, #8f5f28);
  box-shadow: 0 14px 34px rgba(0, 0, 0, .34);
}

[data-theme="dark"] .today-strip article {
  background: #2a2a2a;
  border-color: rgba(255, 255, 255, .06);
}

[data-theme="dark"] .today-strip strong {
  color: #e0e0e0;
}

[data-theme="dark"] .daily-closure {
  background: #2a2a2a;
  border-color: rgba(255, 255, 255, .06);
}

[data-theme="dark"] .daily-closure strong {
  color: #e0e0e0;
}

[data-theme="dark"] .next-task-panel {
  background: #111;
  box-shadow: 0 14px 34px rgba(0, 0, 0, .34);
}

[data-theme="dark"] .next-task-panel.complete,
[data-theme="dark"] .task-filter-chips button,
[data-theme="dark"] .task-phase-head strong {
  background: #2a2a2a;
  border-color: rgba(255, 255, 255, .08);
}

[data-theme="dark"] .next-task-panel.complete strong,
[data-theme="dark"] .task-filter-chips strong {
  color: #e0e0e0;
}

[data-theme="dark"] .task-filter-chips button.active {
  background: rgba(167, 45, 58, .18);
  border-color: rgba(200, 76, 77, .42);
  color: #e8a04a;
}

[data-theme="dark"] .task-phase::before {
  background: #434343;
}

[data-theme="dark"] .task-phase-head span,
[data-theme="dark"] .task-phase-head strong {
  color: #e8a04a;
}

[data-theme="dark"] .quiz-card {
  background: #2a2a2a;
  border-color: rgba(255, 255, 255, .06);
}

[data-theme="dark"] .quiz-question-text {
  color: #e0e0e0;
}

[data-theme="dark"] .quiz-choice {
  background: #1f1f1f;
  border-color: #434343;
}

[data-theme="dark"] .quiz-choice:hover {
  background: #333;
}

[data-theme="dark"] .quiz-choice.chosen {
  background: rgba(167, 45, 58, .15);
  border-color: #c84c4d;
}

[data-theme="dark"] .quiz-result-bar {
  background: #2a2a2a;
}

[data-theme="dark"] .module-card {
  background: #2a2a2a;
  box-shadow: 0 10px 30px rgba(0, 0, 0, .3);
}

[data-theme="dark"] .module-title h3 {
  color: #e0e0e0;
}

[data-theme="dark"] .icon-item {
  color: #e0e0e0;
}

[data-theme="dark"] .icon-badge {
  background: #333;
  border-color: #434343;
  color: #e8a04a;
}

[data-theme="dark"] .notice-row {
  background: #2a2a2a;
}

[data-theme="dark"] .notice-row strong {
  color: #e8a04a;
}

[data-theme="dark"] .task-card,
[data-theme="dark"] .message-row,
[data-theme="dark"] .admin-card {
  background: #2a2a2a;
  border-color: rgba(255, 255, 255, .06);
}

[data-theme="dark"] .task-card.next-card {
  border-color: rgba(213, 155, 74, .42);
  box-shadow: 0 12px 30px rgba(0, 0, 0, .28);
}

[data-theme="dark"] .task-card h4,
[data-theme="dark"] .message-row h4 {
  color: #e0e0e0;
}

[data-theme="dark"] .task-progress,
[data-theme="dark"] .task-checklist-panel,
[data-theme="dark"] .check-field {
  background: #1f1f1f;
  border-color: #434343;
}

[data-theme="dark"] .task-checklist-panel summary,
[data-theme="dark"] .check-field strong,
[data-theme="dark"] .task-input-field span {
  color: #e0e0e0;
}

[data-theme="dark"] .submit-proof-actions {
  background: rgba(31, 31, 31, .94);
  border-top-color: #434343;
}

[data-theme="dark"] .task-input-field.abnormal .input {
  background: rgba(199, 121, 25, .10);
  border-color: rgba(199, 121, 25, .45);
}

[data-theme="dark"] .daily-report-preview,
[data-theme="dark"] .daily-report-card {
  background: #1f1f1f;
  border-color: #434343;
}

[data-theme="dark"] .daily-report-preview strong,
[data-theme="dark"] .daily-report-card header strong,
[data-theme="dark"] .daily-report-metrics strong {
  color: #e0e0e0;
}

[data-theme="dark"] .daily-report-preview button {
  background: rgba(167, 45, 58, .18);
  color: #e8a04a;
}

[data-theme="dark"] .daily-report-preview pre,
[data-theme="dark"] .daily-report-metrics div {
  background: #2a2a2a;
  color: #e0e0e0;
}

[data-theme="dark"] .warn-panel {
  background: rgba(199, 121, 25, .12) !important;
  border-color: rgba(199, 121, 25, .3);
}

[data-theme="dark"] .week-grid {
  background: #333;
  border-color: #333;
}

[data-theme="dark"] .week-head,
[data-theme="dark"] .week-user,
[data-theme="dark"] .week-cell {
  background: #2a2a2a;
}

[data-theme="dark"] .week-cell strong {
  color: #e8a04a;
}

[data-theme="dark"] .status {
  background: #333;
  color: #8c8c8c;
}

[data-theme="dark"] .status.pending,
[data-theme="dark"] .status.rejected,
[data-theme="dark"] .status.overdue {
  background: rgba(190, 52, 65, .15);
  color: #ff7875;
}

[data-theme="dark"] .status.submitted {
  background: rgba(250, 173, 20, .12);
  color: #ffc53d;
}

[data-theme="dark"] .status.done {
  background: rgba(82, 196, 26, .12);
  color: #73d13d;
}

[data-theme="dark"] .bottom-nav {
  background: rgba(30, 30, 30, .96);
  border-top-color: rgba(255, 255, 255, .06);
}

[data-theme="dark"] .bottom-nav button {
  color: #595959;
}

[data-theme="dark"] .bottom-nav button.active {
  color: #e8a04a;
}

[data-theme="dark"] .admin-side {
  background: #1f1f1f;
  border-right-color: #434343;
}

[data-theme="dark"] .admin-nav button {
  color: #8c8c8c;
}

[data-theme="dark"] .admin-nav button.active {
  background: rgba(167, 45, 58, .15);
  color: #e8a04a;
}

[data-theme="dark"] .panel {
  background: #2a2a2a;
  border-color: rgba(255, 255, 255, .06);
}

[data-theme="dark"] .panel h2 {
  color: #e0e0e0;
}

[data-theme="dark"] .stat {
  background: #2a2a2a;
  border-color: rgba(255, 255, 255, .06);
}

[data-theme="dark"] .stat strong {
  color: #e0e0e0;
}

[data-theme="dark"] table {
  border-color: #434343;
}

[data-theme="dark"] th {
  color: #8c8c8c;
}

[data-theme="dark"] td {
  border-bottom-color: #333;
  color: #e0e0e0;
}

[data-theme="dark"] .empty {
  color: #595959;
}

[data-theme="dark"] .drawer {
  background: #1f1f1f;
  box-shadow: -4px 0 24px rgba(0, 0, 0, .5);
}

[data-theme="dark"] .drawer-header {
  border-bottom-color: #434343;
}

[data-theme="dark"] .drawer-header h2 {
  color: #e0e0e0;
}

[data-theme="dark"] .drawer-close {
  color: #8c8c8c;
}

[data-theme="dark"] .scan-btn {
  background: #2a2a2a;
  color: #e8a04a;
}

[data-theme="dark"] .back-btn {
  color: #e8a04a;
}

[data-theme="dark"] .workbench-list > div:not(.empty) {
  background: #2a2a2a;
  border-color: rgba(255, 255, 255, .06);
}

[data-theme="dark"] .workbench-list strong {
  color: #e0e0e0;
}

[data-theme="dark"] .inventory-item {
  background: #2a2a2a;
  border-color: #434343;
}

[data-theme="dark"] .task-review-card {
  background: #2a2a2a;
  border-color: #434343;
}

[data-theme="dark"] .task-review-header {
  border-bottom-color: #434343;
}

[data-theme="dark"] .field-row {
  border-bottom-color: rgba(255, 255, 255, .06);
}

[data-theme="dark"] .review-note {
  background: rgba(213, 155, 74, .1);
}

[data-theme="dark"] .pdf-viewer {
  background: #1a1a1a;
}

[data-theme="dark"] .pdf-toolbar {
  background: #2a2a2a;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .3);
}

[data-theme="dark"] .pdf-document {
  background: #1f1f1f;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .3);
}

[data-theme="dark"] .pdf-title {
  color: #e0e0e0;
}

[data-theme="dark"] .pdf-body {
  color: #bfbfbf;
}

[data-theme="dark"] .pdf-section-title {
  color: #e8a04a;
}

[data-theme="dark"] .pdf-content .checklist-item {
  background: #2a2a2a;
  border-left-color: #434343;
}

[data-theme="dark"] .photo-strip img {
  border-color: #434343;
  background: #2a2a2a;
}

[data-theme="dark"] .check-field {
  border-color: #434343;
  background: #262626;
}

[data-theme="dark"] .check-field strong {
  color: #fff8ea;
}

[data-theme="dark"] .check-field small,
[data-theme="dark"] .field-label small {
  color: #9f9a94;
}

[data-theme="dark"] .task-progress {
  background: rgba(167, 45, 58, .22);
  color: #e8a04a;
}

[data-theme="dark"] .task-checklist-panel {
  background: #202020;
  border-color: #434343;
}

[data-theme="dark"] .task-checklist-panel summary {
  color: #fff8ea;
}

[data-theme="dark"] .task-checklist-panel summary strong {
  color: #e8a04a;
}

[data-theme="dark"] .task-checklist-panel .submit-proof {
  border-top-color: #434343;
}

[data-theme="dark"] .quiz-edit-choice {
  color: #e0e0e0;
}

[data-theme="dark"] .toast-container .toast {
  background: #434343;
}

[data-theme="dark"] .role-admin {
  background: rgba(146, 64, 14, .2);
  color: #e8a04a;
}

[data-theme="dark"] .role-manager {
  background: rgba(30, 64, 175, .2);
  color: #69b1ff;
}

[data-theme="dark"] .role-employee {
  background: rgba(55, 65, 81, .3);
  color: #bfbfbf;
}

[data-theme="dark"] .action-login {
  background: rgba(47, 140, 90, .15);
  color: #73d13d;
}

[data-theme="dark"] .action-logout,
[data-theme="dark"] .action-delete {
  background: rgba(190, 52, 65, .15);
  color: #ff7875;
}

[data-theme="dark"] .action-create {
  background: rgba(30, 64, 175, .15);
  color: #69b1ff;
}

[data-theme="dark"] .action-update,
[data-theme="dark"] .action-export {
  background: rgba(250, 173, 20, .12);
  color: #ffc53d;
}

[data-theme="dark"] .action-permission_change {
  background: rgba(157, 23, 77, .15);
  color: #f759ab;
}

[data-theme="dark"] .action-password_change {
  background: rgba(107, 33, 168, .15);
  color: #d3adf7;
}

[data-theme="dark"] .action-backup {
  background: rgba(17, 94, 89, .15);
  color: #5cdbd3;
}

[data-theme="dark"] .action-session_timeout {
  background: rgba(133, 77, 14, .15);
  color: #ffc53d;
}

[data-theme="dark"] .backup-table th {
  background-color: #333;
}

[data-theme="dark"] .backup-table tr:hover {
  background-color: #333;
}

[data-theme="dark"] .backup-filename {
  color: #69b1ff;
}

[data-theme="dark"] .notification-panel {
  background: #1f1f1f;
  border-color: #434343;
}

[data-theme="dark"] .notification-header {
  background: #1f1f1f;
  border-bottom-color: #434343;
}

[data-theme="dark"] .notification-header h4 {
  color: #e0e0e0;
}

[data-theme="dark"] .notification-item {
  border-bottom-color: #333;
}

[data-theme="dark"] .notification-item:hover {
  background: #2a2a2a;
}

[data-theme="dark"] .notification-item.unread {
  background: rgba(24, 144, 255, .08);
}

[data-theme="dark"] .notification-title {
  color: #e0e0e0;
}

[data-theme="dark"] .perf-item {
  border-bottom-color: rgba(255, 255, 255, .06);
}

[data-theme="dark"] .top3-item {
  background: rgba(255, 255, 255, .04);
}

[data-theme="dark"] .audit-log-table .data-table th {
  background: #333;
  border-bottom-color: #434343;
}

[data-theme="dark"] .audit-log-table .data-table td {
  border-bottom-color: #333;
}

[data-theme="dark"] .audit-log-table .data-table tbody tr:hover {
  background: #333;
}

[data-theme="dark"] .quiz-passed-badge {
  background: rgba(47, 140, 90, .1);
  color: #73d13d;
}

[data-theme="dark"] .quiz-failed-badge {
  background: rgba(190, 52, 65, .1);
  color: #ff7875;
}

[data-theme="dark"] .quiz-choice.correct {
  background: rgba(47, 140, 90, .12);
  border-color: #73d13d;
}

[data-theme="dark"] .quiz-choice.wrong {
  background: rgba(190, 52, 65, .12);
  border-color: #ff7875;
}

[data-theme="dark"] .quiz-choice.correct .choice-marker {
  color: #73d13d;
}

[data-theme="dark"] .quiz-choice.wrong .choice-marker {
  color: #ff7875;
}

/* Bug fix: SOP content preview truncation on mobile */
.sop-content-preview {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  margin: 0;
}

/* Mobile header layout fix */
@media (max-width: 768px) {
  .mobile-header {
    min-height: 58px !important;
    max-height: none !important;
    padding: 8px 10px !important;
    gap: 8px !important;
    overflow: visible !important;
  }

  .mobile-header .logo-circle,
  .mobile-header .back-btn {
    width: 32px !important;
    height: 32px !important;
    flex: 0 0 32px !important;
  }

  .mobile-header .back-btn {
    display: grid !important;
    place-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 10px !important;
    background: var(--doco-cream) !important;
    border: 1px solid var(--line) !important;
    line-height: 1 !important;
  }

  .mobile-header .header-title {
    min-width: 0 !important;
    white-space: normal !important;
    line-height: 1.15 !important;
  }

  .mobile-header .header-title strong,
  .mobile-header .header-title small {
    display: block !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .mobile-header .header-title strong {
    font-size: 15px !important;
  }

  .mobile-header .header-title small {
    margin-top: 3px !important;
    font-size: 11px !important;
  }

  .mobile-header-actions {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    flex: 0 0 auto !important;
  }

  .mobile-header-actions .notification-bell {
    width: 28px !important;
    height: 28px !important;
  }

  .mobile-header-actions .theme-toggle-btn {
    width: 30px !important;
    height: 30px !important;
  }

  .mobile-settings-wrap {
    position: relative !important;
    flex: 0 0 auto !important;
  }

  .mobile-settings-btn {
    width: 30px !important;
    height: 30px !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 10px !important;
    border: 1px solid var(--line) !important;
    background: var(--doco-cream) !important;
    color: var(--doco-red) !important;
    font-size: 20px !important;
    line-height: 1 !important;
    cursor: pointer !important;
  }

  .mobile-settings-panel {
    position: absolute !important;
    top: calc(100% + 8px) !important;
    right: 0 !important;
    z-index: 60 !important;
    width: 168px !important;
    padding: 10px !important;
    border-radius: 12px !important;
    border: 1px solid var(--line) !important;
    background: #F8FCFF !important;
    box-shadow: 0 12px 32px rgba(48, 20, 12, .16) !important;
  }

  .mobile-settings-title {
    margin-bottom: 8px !important;
    color: var(--muted) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
  }

  .mobile-language-options {
    display: grid !important;
    gap: 6px !important;
  }

  .mobile-language-options button {
    min-height: 34px !important;
    padding: 0 10px !important;
    border-radius: 8px !important;
    border: 1px solid transparent !important;
    background: #f7f4ef !important;
    color: var(--ink) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-align: left !important;
    cursor: pointer !important;
  }

  .mobile-language-options button.active {
    border-color: rgba(167, 45, 58, .18) !important;
    background: var(--doco-red) !important;
    color: #fff !important;
  }

  .mobile-header .scan-btn {
    display: none !important;
  }
}

@media (max-width: 360px) {
  .mobile-header {
    min-height: 52px !important;
  }

  .mobile-header .header-title small {
    display: none !important;
  }

  .today-command {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .today-command-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .today-command-metrics button {
    min-height: 58px;
  }
}
/* ========== 鎵嬫満绔綋楠屼紭鍖?========== */

/* 1. 搴曢儴瀵艰埅浼樺寲 */
.bottom-nav .nav-item {
  min-height: 56px;
  padding: 8px 0;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: all 0.2s ease;
  position: relative;
}

.bottom-nav .nav-item.active {
  color: var(--color-primary, #a72d3a);
  font-weight: 600;
}

.bottom-nav .nav-item.active::after {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 24px;
  height: 3px;
  background: var(--color-primary, #a72d3a);
  border-radius: 0 0 3px 3px;
}

.bottom-nav .nav-item:active {
  transform: scale(0.95);
  opacity: 0.8;
}

/* 2. 鎸夐挳鎸夊帇鏁堟灉 */
.btn, button, .clickable {
  transition: transform 0.15s ease, opacity 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}

.btn:active, button:active, .clickable:active {
  transform: scale(0.96);
  opacity: 0.9;
}

/* 3. 绉诲姩绔簳閮ㄥ脊绐?*/
@media (max-width: 768px) {
  .modal-card, .dialog-card {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    top: auto !important;
    max-height: 85vh !important;
    margin: 0 !important;
    border-radius: 16px 16px 0 0 !important;
    transform: translateY(100%);
    animation: slideUp 0.3s ease-out forwards;
    padding-bottom: env(safe-area-inset-bottom, 20px);
  }

  .modal-overlay {
    align-items: flex-end !important;
  }

  .modal-backdrop {
    background: rgba(0,0,0,0.5);
  }
}

@keyframes slideUp {
  to { transform: translateY(0); }
}

/* 4. 椤甸潰鍒囨崲鍔ㄧ敾 */
.page-enter {
  animation: pageIn 0.25s ease-out;
}

@keyframes pageIn {
  from { opacity: 0; transform: translateX(20px); }
  to { opacity: 1; transform: translateX(0); }
}

/* 5. 楠ㄦ灦灞忓姞杞芥晥鏋?*/
.skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: 8px;
}

@keyframes shimmer {
  to { background-position: -200% 0; }
}

/* 6. 瑙︽懜鍖哄煙浼樺寲 */
input, select, textarea {
  font-size: 16px !important; /* 闃叉iOS鑷姩缂╂斁 */
}

.clickable, .nav-item, .list-item {
  min-height: 44px;
  display: flex;
  align-items: center;
}

/* 7. 瀹夊叏鍖哄煙閫傞厤 */
@supports (padding: max(0px)) {
  .bottom-nav {
    padding-bottom: max(8px, env(safe-area-inset-bottom));
    height: calc(56px + env(safe-area-inset-bottom));
  }
  body {
    padding-bottom: calc(56px + env(safe-area-inset-bottom));
  }
}

/* DOCO VI Pocket Universe Theme */
:root {
  --doco-blue: #14AFE6;
  --doco-blue-dark: #0B3A57;
  --doco-blue-soft: #EAF8FE;
  --doco-yellow: #FFD200;
  --doco-green: #41B43C;
  --doco-danger: #EB000F;
  --doco-cream: #FFF8DE;
  --doco-rice: #FAFACD;
  --doco-pale: #F6F7D2;
  --doco-red: var(--doco-blue);
  --doco-red-dark: var(--doco-blue-dark);
  --doco-gold: var(--doco-yellow);
  --primary: var(--doco-blue);
  --ink: #123047;
  --muted: #557083;
  --line: #CDE8F2;
  --card: #FFFFFF;
  --ok: var(--doco-green);
  --warn: var(--doco-yellow);
  --bad: var(--doco-danger);
  --color-primary: var(--doco-blue);
  --color-primary-hover: #48C4F2;
  --color-primary-active: #0B7FB8;
  --color-success: var(--doco-green);
  --color-warning: var(--doco-yellow);
  --color-error: var(--doco-danger);
  --color-info: var(--doco-blue);
  --color-text-primary: var(--ink);
  --color-text-secondary: var(--muted);
  --color-text-tertiary: #8AA3AF;
  --color-border: var(--line);
  --color-bg: #FFFFFF;
  --color-bg-secondary: #F8FCFF;
  --color-bg-tertiary: var(--doco-pale);
  --color-bg-hover: var(--doco-blue-soft);
}

body {
  color: var(--ink);
  background:
    linear-gradient(180deg, #F8FCFF 0%, #FAFACD 100%);
}

::selection {
  background: rgba(255, 210, 0, .55);
  color: var(--doco-blue-dark);
}

.login-shell {
  background:
    linear-gradient(135deg, rgba(20, 175, 230, .14) 0%, rgba(246, 247, 210, .92) 50%, rgba(255, 248, 222, .96) 100%);
}

.login-shell::before {
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, rgba(20, 175, 230, .14) 0 1px, transparent 1px 42px),
    repeating-linear-gradient(90deg, rgba(20, 175, 230, .10) 0 1px, transparent 1px 42px);
  filter: none;
  opacity: .38;
  animation: none;
}

.login-shell::after {
  background:
    linear-gradient(130deg, transparent 0 45%, rgba(255, 210, 0, .16) 45% 55%, transparent 55% 100%);
  background-size: 100% 100%;
  opacity: .72;
}

.login-ambient span {
  width: 220px;
  height: 66px;
  border-radius: 50%;
  border: 2px solid rgba(20, 175, 230, .24);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .58), rgba(255, 210, 0, .16));
  box-shadow: 0 18px 36px rgba(11, 58, 87, .08);
  opacity: .50;
}

.login-ambient span:nth-child(2) {
  width: 160px;
  height: 50px;
}

.login-ambient span:nth-child(3) {
  width: 280px;
  height: 84px;
}

.login-card {
  background: rgba(255, 255, 255, .88);
  border-color: rgba(20, 175, 230, .18);
  box-shadow:
    0 34px 90px rgba(11, 58, 87, .16),
    0 1px 0 rgba(255, 255, 255, .90) inset;
}

.brand-panel {
  background:
    linear-gradient(145deg, #0B3A57 0%, #14AFE6 58%, #6ED3F7 100%);
  color: #FFFFFF;
}

.brand-panel::before {
  background:
    radial-gradient(circle at 24px 24px, rgba(255, 255, 255, .14) 0 2px, transparent 3px),
    linear-gradient(120deg, rgba(255, 255, 255, .16), transparent 28%, transparent 72%, rgba(255, 210, 0, .22));
  background-size: 34px 34px, 100% 100%;
}

.brand-panel::after,
.brand-orbit span {
  border-color: rgba(255, 210, 0, .36);
  filter: drop-shadow(0 18px 36px rgba(11, 58, 87, .20));
}

.brand-mark {
  background: var(--doco-cream);
  color: var(--doco-blue-dark);
  box-shadow:
    0 16px 36px rgba(11, 58, 87, .18),
    inset 0 -10px 0 rgba(255, 210, 0, .34);
}

.brand-kicker,
.login-signal-row span,
.register-flow span {
  border-color: rgba(255, 255, 255, .32);
  background: rgba(11, 58, 87, .18);
  color: rgba(255, 255, 255, .94);
}

.login-form {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .88), rgba(255, 248, 222, .54));
}

.login-form::before {
  background: linear-gradient(transparent, rgba(20, 175, 230, .36), transparent);
}

.login-eyebrow {
  color: var(--doco-blue);
}

.auth-mode-switch,
.lang-switch {
  border-color: rgba(20, 175, 230, .18);
  background: rgba(255, 255, 255, .78);
}

.auth-mode-switch button.active {
  color: var(--doco-blue-dark);
  box-shadow: 0 8px 20px rgba(11, 58, 87, .10);
}

.input,
.select,
textarea {
  border-color: var(--line);
  color: var(--ink);
}

.input:focus,
.select:focus,
textarea:focus {
  border-color: var(--doco-blue);
  box-shadow: 0 0 0 3px rgba(20, 175, 230, .15);
}

.btn,
.btn-primary {
  background: var(--doco-blue);
  color: #FFFFFF;
  box-shadow: 0 10px 24px rgba(20, 175, 230, .20);
}

.btn:hover,
.btn-primary:hover:not(:disabled) {
  background: #35BDEE;
}

.login-form .btn {
  background: var(--doco-blue);
  color: #FFFFFF;
  box-shadow: 0 14px 30px rgba(20, 175, 230, .24);
}

.login-form .btn:hover {
  background: #35BDEE;
  box-shadow: 0 18px 40px rgba(20, 175, 230, .28);
}

.btn.secondary,
.btn-secondary {
  background: var(--doco-cream);
  color: var(--doco-blue-dark);
  border-color: rgba(20, 175, 230, .18);
  box-shadow: none;
}

.btn.ghost,
.btn-ghost {
  color: var(--doco-blue-dark);
  border-color: rgba(20, 175, 230, .24);
  background: transparent;
  box-shadow: none;
}

.btn.danger,
.btn-danger,
.btn.danger.solid {
  background: rgba(235, 0, 15, .10);
  color: var(--doco-danger);
  border-color: rgba(235, 0, 15, .24);
  box-shadow: none;
}

.btn.danger.solid,
.btn-danger {
  background: var(--doco-danger);
  color: #FFFFFF;
}

.btn.warning.solid,
.btn-warning {
  background: var(--doco-yellow);
  color: var(--doco-blue-dark);
  border-color: rgba(11, 58, 87, .12);
  box-shadow: none;
}

.modal-warning .modal-header {
  background: var(--doco-yellow);
  color: var(--doco-blue-dark);
}

.modal-warning .modal-header h2,
.modal-warning .modal-header p {
  color: var(--doco-blue-dark);
}

.icon-btn,
.theme-toggle-btn,
.mobile-settings-btn,
.scan-btn,
.back-btn {
  background: var(--doco-cream) !important;
  color: var(--doco-blue-dark) !important;
  border-color: rgba(20, 175, 230, .20) !important;
}

.lang-switch button.active {
  background: var(--doco-blue);
  color: #FFFFFF;
}

.login-register-link {
  border-color: rgba(20, 175, 230, .22);
  background: rgba(255, 255, 255, .70);
  color: var(--doco-blue-dark);
}

.login-register-link:hover {
  border-color: rgba(20, 175, 230, .42);
}

.mobile-shell {
  background: var(--doco-pale);
  box-shadow: 0 0 0 1px rgba(20, 175, 230, .08);
}

.mobile-header {
  background: rgba(255, 255, 255, .94);
  border-bottom: 1px solid rgba(20, 175, 230, .10);
  backdrop-filter: blur(18px);
}

.logo-circle {
  background: var(--doco-blue);
  color: #FFFFFF;
  box-shadow: inset 0 -8px 0 rgba(11, 58, 87, .16);
}

.hero-banner,
.today-command {
  background:
    linear-gradient(135deg, #0B3A57 0%, #14AFE6 64%, #FFD200 100%);
  box-shadow: 0 16px 34px rgba(11, 58, 87, .18);
}

.hero-banner::after {
  right: -42px;
  bottom: -34px;
  width: 190px;
  height: 92px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .18);
  box-shadow:
    inset 0 -16px 0 rgba(255, 210, 0, .26),
    inset 0 0 0 18px rgba(255, 255, 255, .10);
  transform: rotate(-14deg);
}

.today-strip article,
.daily-closure,
.module-card,
.task-card,
.message-row,
.admin-card,
.panel,
.stat,
.quiz-card,
.task-review-card,
.inventory-item,
.workbench-list > div:not(.empty),
.daily-report-card,
.daily-report-preview {
  background: rgba(255, 255, 255, .94);
  border-color: rgba(20, 175, 230, .13);
  box-shadow: 0 10px 28px rgba(11, 58, 87, .07);
}

.task-card.next-card {
  border-color: rgba(255, 210, 0, .55);
  box-shadow: 0 12px 30px rgba(255, 210, 0, .18);
}

.next-task-panel {
  background: var(--doco-blue-dark);
  box-shadow: 0 14px 34px rgba(11, 58, 87, .18);
}

.next-task-panel button {
  background: var(--doco-yellow);
  color: var(--doco-blue-dark);
}

.next-task-panel.complete {
  border-color: rgba(65, 180, 60, .24);
  background: #FFFFFF;
}

.task-filter-chips button {
  background: #FFFFFF;
  border-color: rgba(20, 175, 230, .16);
}

.task-filter-chips button.active {
  border-color: rgba(20, 175, 230, .48);
  background: var(--doco-blue-soft);
  color: var(--doco-blue-dark);
}

.task-phase::before {
  background: rgba(20, 175, 230, .24);
}

.task-phase-head span,
.task-checklist-panel summary strong,
.notice-row strong,
.daily-report-preview button,
.week-cell strong {
  color: var(--doco-blue-dark);
}

.task-phase-head strong,
.task-progress {
  background: rgba(20, 175, 230, .10);
  color: var(--doco-blue-dark);
}

.task-checklist-panel,
.check-field,
.task-progress,
.daily-report-preview pre,
.daily-report-metrics div {
  background: #F8FCFF;
  border-color: rgba(20, 175, 230, .14);
}

.check-field input[type="checkbox"],
.field-label input[type="checkbox"],
input[type="checkbox"] {
  accent-color: var(--doco-green);
}

.mobile-settings-panel {
  border-color: rgba(20, 175, 230, .16) !important;
  box-shadow: 0 12px 32px rgba(11, 58, 87, .14) !important;
}

.mobile-language-options button {
  background: #F8FCFF !important;
  color: var(--ink) !important;
}

.mobile-language-options button.active {
  border-color: rgba(20, 175, 230, .28) !important;
  background: var(--doco-blue) !important;
  color: #FFFFFF !important;
}

.bottom-nav {
  background: rgba(255, 255, 255, .96);
  border-top-color: rgba(20, 175, 230, .12);
  box-shadow: 0 -10px 28px rgba(11, 58, 87, .08);
}

.bottom-nav button,
.bottom-nav .nav-item {
  color: #86A0AD;
}

.bottom-nav button.active,
.bottom-nav .nav-item.active {
  color: var(--doco-blue);
}

.bottom-nav .nav-item.active::after {
  background: var(--doco-yellow);
}

.admin-shell {
  background: linear-gradient(180deg, #F8FCFF, var(--doco-rice));
}

.admin-side {
  background:
    linear-gradient(180deg, #0B3A57 0%, #082B41 100%);
  color: #FFFFFF;
  border-right: 0;
}

.admin-brand {
  color: #FFFFFF;
}

.admin-nav button {
  color: rgba(255, 255, 255, .72);
}

.admin-nav button:hover {
  background: rgba(255, 255, 255, .08);
  color: #FFFFFF;
}

.admin-nav button.active {
  background: rgba(255, 255, 255, .14);
  color: #FFFFFF;
  box-shadow: inset 3px 0 0 var(--doco-yellow);
}

.admin-main {
  background:
    linear-gradient(180deg, #F8FCFF 0%, #FAFACD 100%);
}

th,
.backup-table th,
.audit-log-table .data-table th {
  background: #F8FCFF;
  color: var(--muted);
}

td {
  border-bottom-color: rgba(20, 175, 230, .10);
}

.table-mobile tbody tr {
  border-color: rgba(20, 175, 230, .14);
  background: #FFFFFF;
}

.table-mobile td {
  border-bottom-color: rgba(20, 175, 230, .10);
}

.status {
  background: #F8FCFF;
  color: var(--muted);
}

.status.pending {
  background: rgba(255, 210, 0, .24);
  color: #826300;
}

.status.submitted {
  background: rgba(20, 175, 230, .12);
  color: #0B76A5;
}

.status.done {
  background: rgba(65, 180, 60, .14);
  color: #2B8C2E;
}

.status.rejected,
.status.overdue,
.status.cancelled {
  background: rgba(235, 0, 15, .09);
  color: #B8000C;
}

.toast-container .toast,
.toast {
  border-radius: 14px;
  box-shadow: 0 14px 34px rgba(11, 58, 87, .16);
}

.toast-info {
  background: var(--doco-blue);
}

.toast-success {
  background: var(--doco-green);
}

.toast-warning {
  background: var(--doco-yellow);
  color: var(--doco-blue-dark);
}

.toast-error {
  background: var(--doco-danger);
}

.notification-bell:hover,
.notification-item:hover,
.table tbody tr:hover,
.backup-table tr:hover,
.audit-log-table .data-table tbody tr:hover {
  background: var(--doco-blue-soft);
}

.notification-badge {
  background: var(--doco-danger);
  box-shadow: 0 0 0 2px #FFFFFF;
}

.notification-item.unread {
  background: rgba(20, 175, 230, .06);
}

.role-admin {
  background: rgba(255, 210, 0, .22);
  color: #826300;
}

.role-manager,
.action-create,
.action-export {
  background: rgba(20, 175, 230, .12);
  color: #0B76A5;
}

.role-employee {
  background: rgba(85, 112, 131, .12);
  color: var(--doco-blue-dark);
}

.action-login,
.action-backup {
  background: rgba(65, 180, 60, .14);
  color: #2B8C2E;
}

.action-update,
.action-session_timeout {
  background: rgba(255, 210, 0, .24);
  color: #826300;
}

.action-logout,
.action-delete {
  background: rgba(235, 0, 15, .09);
  color: #B8000C;
}

.action-permission_change,
.action-password_change {
  background: rgba(20, 175, 230, .10);
  color: var(--doco-blue-dark);
}

.skeleton {
  background: linear-gradient(90deg, #EAF8FE 25%, #F8FCFF 50%, #EAF8FE 75%);
  background-size: 200% 100%;
}

[data-theme="dark"] {
  --doco-blue: #4EC8F3;
  --doco-blue-dark: #061D2B;
  --doco-blue-soft: rgba(78, 200, 243, .13);
  --doco-yellow: #FFD84D;
  --doco-green: #63D05E;
  --doco-danger: #FF5A63;
  --doco-cream: #162D3B;
  --doco-rice: #061D2B;
  --doco-pale: #0B2638;
  --doco-red: var(--doco-blue);
  --doco-red-dark: #BFEFFF;
  --doco-gold: var(--doco-yellow);
  --primary: var(--doco-blue);
  --ink: #EAF8FE;
  --muted: #94B3C1;
  --line: rgba(151, 213, 235, .22);
  --card: #0B2638;
  --ok: var(--doco-green);
  --warn: var(--doco-yellow);
  --bad: var(--doco-danger);
  --color-primary: var(--doco-blue);
  --color-primary-hover: #77D8FA;
  --color-primary-active: #14AFE6;
  --color-success: var(--doco-green);
  --color-warning: var(--doco-yellow);
  --color-error: var(--doco-danger);
  --color-info: var(--doco-blue);
  --color-text-primary: #EAF8FE;
  --color-text-secondary: #B5CCD6;
  --color-text-tertiary: #7C9CAC;
  --color-border: var(--line);
  --color-bg: #0B2638;
  --color-bg-secondary: #102F43;
  --color-bg-tertiary: #16384E;
  --color-bg-hover: rgba(78, 200, 243, .12);
}

[data-theme="dark"] body {
  background: linear-gradient(180deg, #061D2B 0%, #0B2638 100%);
  color: var(--ink);
}

[data-theme="dark"] .login-shell {
  background: linear-gradient(135deg, #061D2B 0%, #0B2638 54%, #123A4E 100%);
}

[data-theme="dark"] .login-card,
[data-theme="dark"] .login-form,
[data-theme="dark"] .mobile-header,
[data-theme="dark"] .today-strip article,
[data-theme="dark"] .daily-closure,
[data-theme="dark"] .module-card,
[data-theme="dark"] .task-card,
[data-theme="dark"] .message-row,
[data-theme="dark"] .admin-card,
[data-theme="dark"] .panel,
[data-theme="dark"] .stat,
[data-theme="dark"] .quiz-card,
[data-theme="dark"] .task-review-card,
[data-theme="dark"] .inventory-item,
[data-theme="dark"] .workbench-list > div:not(.empty),
[data-theme="dark"] .daily-report-card,
[data-theme="dark"] .daily-report-preview,
[data-theme="dark"] .modal-card,
[data-theme="dark"] .notification-panel {
  background: rgba(11, 38, 56, .94);
  border-color: var(--line);
  box-shadow: 0 14px 34px rgba(0, 0, 0, .26);
}

[data-theme="dark"] .brand-panel,
[data-theme="dark"] .hero-banner,
[data-theme="dark"] .today-command {
  background: linear-gradient(135deg, #061D2B 0%, #0B76A5 62%, #FFD84D 100%);
}

[data-theme="dark"] .admin-side {
  background: linear-gradient(180deg, #061D2B 0%, #04131E 100%);
}

[data-theme="dark"] .admin-main,
[data-theme="dark"] .admin-shell,
[data-theme="dark"] .mobile-shell {
  background: linear-gradient(180deg, #061D2B 0%, #0B2638 100%);
}

[data-theme="dark"] .bottom-nav {
  background: rgba(6, 29, 43, .96);
  border-top-color: var(--line);
}

[data-theme="dark"] .btn.secondary,
[data-theme="dark"] .btn-secondary,
[data-theme="dark"] .icon-btn,
[data-theme="dark"] .theme-toggle-btn,
[data-theme="dark"] .mobile-settings-btn,
[data-theme="dark"] .scan-btn,
[data-theme="dark"] .back-btn {
  background: #102F43 !important;
  color: #EAF8FE !important;
  border-color: var(--line) !important;
}

[data-theme="dark"] .input,
[data-theme="dark"] .select,
[data-theme="dark"] textarea,
[data-theme="dark"] .task-checklist-panel,
[data-theme="dark"] .check-field,
[data-theme="dark"] .task-progress,
[data-theme="dark"] .daily-report-preview pre,
[data-theme="dark"] .daily-report-metrics div {
  background: #102F43;
  border-color: var(--line);
  color: #EAF8FE;
}

[data-theme="dark"] th,
[data-theme="dark"] .backup-table th,
[data-theme="dark"] .audit-log-table .data-table th {
  background: #102F43;
}

[data-theme="dark"] .status,
[data-theme="dark"] .task-filter-chips button,
[data-theme="dark"] .task-phase-head strong {
  background: #102F43;
  border-color: var(--line);
}

[data-theme="dark"] .task-filter-chips button.active {
  background: rgba(78, 200, 243, .15);
  color: #EAF8FE;
  border-color: rgba(78, 200, 243, .36);
}

@media (prefers-reduced-motion: reduce) {
  .login-shell::before,
  .login-ambient span,
  .brand-panel::after,
  .brand-orbit span,
  .login-card,
  .login-form .field,
  .login-form .btn,
  .login-form .error {
    animation: none !important;
  }
}

@media (max-width: 520px) {
  .login-shell {
    align-items: start;
    padding: 0;
  }

  .login-card,
  .register-card {
    width: 100%;
    min-height: 100vh;
    border-radius: 0;
  }

  .brand-panel,
  .register-brand {
    min-height: 318px;
    padding: 28px 24px;
  }

  .brand-panel h1 {
    margin: 18px 0 10px;
    font-size: 34px;
    line-height: 1.08;
  }

  .brand-panel p {
    line-height: 1.55;
  }

  .brand-mark {
    width: 70px;
    height: 70px;
  }

  .login-signal-row {
    display: none;
  }

  .login-form,
  .register-form {
    padding: 32px 24px 36px;
    gap: 15px;
  }

  .login-form-top {
    gap: 12px;
  }

  .login-form-top h2 {
    font-size: 28px;
  }

  .register-flow {
    gap: 8px;
  }

  .register-flow span {
    min-height: 36px;
  }
}

/* Mobile surface polish: soften the old white blocks into DOCO blue paper. */
@media (max-width: 768px) {
  :root {
    --mobile-paper: rgba(248, 252, 255, .88);
    --mobile-paper-strong: rgba(234, 248, 254, .94);
    --mobile-paper-warm: rgba(255, 248, 222, .78);
    --mobile-stroke: rgba(20, 175, 230, .18);
    --mobile-shadow: 0 12px 30px rgba(11, 58, 87, .08);
  }

  html,
  body,
  #app {
    min-height: 100%;
    background:
      radial-gradient(circle at 12% 0%, rgba(20, 175, 230, .18), transparent 32%),
      radial-gradient(circle at 88% 18%, rgba(255, 210, 0, .24), transparent 28%),
      linear-gradient(180deg, #F8FCFF 0%, #EAF8FE 34%, #F6F7D2 100%);
  }

  body {
    color: var(--ink);
  }

  .mobile-shell {
    width: 100%;
    min-height: 100dvh;
    background:
      linear-gradient(180deg, rgba(248, 252, 255, .64) 0%, rgba(234, 248, 254, .74) 38%, rgba(246, 247, 210, .86) 100%);
    box-shadow: none;
    overflow-x: hidden;
  }

  .mobile-content {
    padding: 14px 12px 96px;
  }

  .mobile-header {
    background: linear-gradient(180deg, rgba(248, 252, 255, .96), rgba(234, 248, 254, .90)) !important;
    border-bottom: 1px solid var(--mobile-stroke) !important;
    box-shadow: 0 8px 24px rgba(11, 58, 87, .07);
  }

  .mobile-header .logo-circle {
    box-shadow:
      inset 0 -7px 0 rgba(11, 58, 87, .16),
      0 6px 16px rgba(20, 175, 230, .20);
  }

  .mobile-header .back-btn,
  .mobile-settings-btn,
  .scan-btn,
  .theme-toggle-btn,
  .icon-btn {
    background: linear-gradient(180deg, var(--doco-cream), #EAF8FE) !important;
    color: var(--doco-blue-dark) !important;
    border: 1px solid var(--mobile-stroke) !important;
  }

  .today-strip article,
  .daily-closure,
  .module-card,
  .task-card,
  .message-row,
  .admin-card,
  .panel,
  .stat,
  .quiz-card,
  .task-review-card,
  .inventory-item,
  .workbench-list > div:not(.empty),
  .daily-report-card,
  .daily-report-preview,
  .notice-row,
  .table-mobile tbody tr {
    background:
      linear-gradient(180deg, var(--mobile-paper), rgba(234, 248, 254, .76)) !important;
    border: 1px solid var(--mobile-stroke) !important;
    box-shadow: var(--mobile-shadow) !important;
  }

  .quick-actions-card,
  .task-list-section,
  .perf-trend {
    background:
      linear-gradient(180deg, var(--mobile-paper-warm), rgba(248, 252, 255, .90)) !important;
  }

  .today-command,
  .hero-banner {
    border: 1px solid rgba(255, 255, 255, .28);
    box-shadow: 0 18px 36px rgba(11, 58, 87, .16);
  }

  .next-task-panel.complete {
    background:
      linear-gradient(180deg, rgba(234, 248, 254, .92), rgba(255, 248, 222, .72)) !important;
    border-color: rgba(65, 180, 60, .24) !important;
  }

  .task-checklist-panel,
  .check-field,
  .task-progress,
  .daily-report-preview pre,
  .daily-report-metrics div,
  .task-filter-chips button,
  .field-row,
  .pdf-toolbar {
    background: rgba(248, 252, 255, .82) !important;
    border-color: var(--mobile-stroke) !important;
  }

  .check-field {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .64);
  }

  .task-checklist-panel .submit-proof {
    background: rgba(255, 248, 222, .42);
  }

  .submit-proof-actions {
    background: rgba(234, 248, 254, .94);
    border-top-color: var(--mobile-stroke);
  }

  .input,
  .select,
  textarea {
    background: rgba(255, 255, 255, .68);
    border-color: var(--mobile-stroke);
  }

  .input:focus,
  .select:focus,
  textarea:focus {
    background: rgba(255, 255, 255, .86);
  }

  .icon-badge {
    background: linear-gradient(180deg, #FFF8DE, #EAF8FE);
    border-color: rgba(20, 175, 230, .18);
    color: var(--doco-blue-dark);
    box-shadow: inset 0 -5px 0 rgba(255, 210, 0, .20);
  }

  .task-phase-dot {
    box-shadow: 0 0 0 5px rgba(234, 248, 254, .96);
  }

  .task-phase-dot.operating {
    box-shadow: 0 0 0 5px rgba(255, 248, 222, .96);
  }

  .mobile-settings-panel {
    background:
      linear-gradient(180deg, rgba(248, 252, 255, .98), rgba(234, 248, 254, .96)) !important;
    border-color: var(--mobile-stroke) !important;
    box-shadow: 0 16px 34px rgba(11, 58, 87, .16) !important;
  }

  .mobile-language-options button {
    background: rgba(255, 255, 255, .62) !important;
    border-color: rgba(20, 175, 230, .12) !important;
  }

  .bottom-nav {
    background: rgba(248, 252, 255, .94);
    border-top: 1px solid var(--mobile-stroke);
    box-shadow: 0 -12px 30px rgba(11, 58, 87, .10);
  }

  .bottom-nav button {
    color: #6F8C9A;
  }

  .bottom-nav button.active {
    color: var(--doco-blue-dark);
  }

  .bottom-nav button.active .nav-icon {
    color: var(--doco-blue);
  }

  .pdf-viewer {
    background:
      linear-gradient(180deg, #EAF8FE 0%, #F6F7D2 100%);
  }

  .pdf-document {
    background: #FFFDF3;
    border: 1px solid rgba(20, 175, 230, .13);
  }

  .modal-card,
  .dialog-card {
    background:
      linear-gradient(180deg, #F8FCFF 0%, #FFF8DE 100%) !important;
    border: 1px solid var(--mobile-stroke) !important;
  }
}

[data-theme="dark"] {
  --mobile-paper: rgba(11, 38, 56, .92);
  --mobile-paper-strong: rgba(16, 47, 67, .94);
  --mobile-paper-warm: rgba(22, 45, 59, .86);
  --mobile-stroke: rgba(151, 213, 235, .22);
  --mobile-shadow: 0 14px 34px rgba(0, 0, 0, .26);
}

@media (max-width: 768px) {
  [data-theme="dark"],
  [data-theme="dark"] body,
  [data-theme="dark"] #app {
    background:
      radial-gradient(circle at 12% 0%, rgba(78, 200, 243, .16), transparent 32%),
      radial-gradient(circle at 88% 18%, rgba(255, 216, 77, .12), transparent 28%),
      linear-gradient(180deg, #061D2B 0%, #0B2638 100%);
  }

  [data-theme="dark"] .mobile-shell {
    background:
      linear-gradient(180deg, rgba(6, 29, 43, .94) 0%, rgba(11, 38, 56, .96) 100%);
  }

  [data-theme="dark"] .mobile-header,
  [data-theme="dark"] .bottom-nav {
    background: rgba(6, 29, 43, .94) !important;
    border-color: var(--mobile-stroke) !important;
  }

  [data-theme="dark"] .mobile-header .back-btn,
  [data-theme="dark"] .mobile-settings-btn,
  [data-theme="dark"] .scan-btn,
  [data-theme="dark"] .theme-toggle-btn,
  [data-theme="dark"] .icon-btn,
  [data-theme="dark"] .mobile-language-options button {
    background: #102F43 !important;
    color: #EAF8FE !important;
    border-color: var(--mobile-stroke) !important;
  }

  [data-theme="dark"] .input:focus,
  [data-theme="dark"] .select:focus,
  [data-theme="dark"] textarea:focus {
    background: #102F43;
  }
}
