/* === 8Move Care — Home Care Patient Workflow === */

/* Light Theme (default) */
:root, [data-theme="light"] {
  --bg: #f8fafc;
  --sf: #ffffff;
  --sf2: #f1f5f9;
  --sf3: #e2e8f0;
  --bd: #e2e8f0;
  --bdl: #cbd5e1;
  --tx: #1e293b;
  --txd: #64748b;
  --txm: #64748b;
  --blue: #3b82f6;
  --cyan: #0891b2;
  --emerald: #059669;
  --amber: #d97706;
  --rose: #e11d48;
  --violet: #7c3aed;
  --pink: #db2777;
  --shadow: rgba(0,0,0,.08);
  --hdr-bg: linear-gradient(180deg, #ffffff, #f8fafc);
  --h1-from: #1e293b;
  --h1-to: #475569;
  --elevation-1: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
  --elevation-3: 0 10px 20px rgba(0,0,0,.1), 0 3px 6px rgba(0,0,0,.06);
  --ease-standard: cubic-bezier(0.2, 0, 0, 1);
}

/* Dark Theme */
[data-theme="dark"] {
  --bg: #0a0e1a;
  --sf: #111827;
  --sf2: #1a2237;
  --sf3: #232d45;
  --bd: #2a3654;
  --bdl: #374870;
  --tx: #e2e8f0;
  --txd: #8896b3;
  --txm: #5a6a8a;
  --blue: #3b82f6;
  --cyan: #06b6d4;
  --emerald: #10b981;
  --amber: #f59e0b;
  --rose: #f43f5e;
  --violet: #8b5cf6;
  --pink: #ec4899;
  --shadow: rgba(0,0,0,.3);
  --hdr-bg: linear-gradient(180deg, rgba(17,24,39,.95), rgba(10,14,26,.98));
  --h1-from: #fff;
  --h1-to: #94a3b8;
  --elevation-1: 0 1px 3px rgba(0,0,0,.2), 0 1px 2px rgba(0,0,0,.15);
  --elevation-3: 0 10px 20px rgba(0,0,0,.25), 0 3px 6px rgba(0,0,0,.15);
  --ease-standard: cubic-bezier(0.2, 0, 0, 1);
}

/* Reset */
* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--bg);
  color: var(--tx);
  min-height: 100vh;
  overflow-x: hidden;
}

[data-theme="dark"] body::before,
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

[data-theme="dark"] body::before {
  background:
    radial-gradient(ellipse 80% 50% at 50% -20%, rgba(59,130,246,.08), transparent),
    radial-gradient(ellipse 60% 40% at 80% 100%, rgba(139,92,246,.06), transparent);
}

/* App Container */
.app { position: relative; z-index: 1; }

/* Header */
.hdr {
  padding: 40px 24px 32px;
  border-bottom: 1px solid var(--bd);
  background: var(--hdr-bg);
}

.hdr-top {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

.logo {
  width: 40px;
  height: 40px;
  object-fit: contain;
  flex-shrink: 0;
}

/* Theme-aware logo */
.logo-dark { display: none; }
[data-theme="dark"] .logo-light { display: none; }
[data-theme="dark"] .logo-dark { display: block; }

.hdr h1 {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -.5px;
  background: linear-gradient(135deg, var(--h1-from), var(--h1-to));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.hdr-sub {
  font-size: 14px;
  color: var(--txd);
  margin-top: 4px;
  line-height: 1.6;
}

/* Language Switcher */
.lang-sw { display: flex; gap: 4px; margin-left: auto; }

.lang-b {
  padding: 6px 14px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 700;
  font-family: 'DM Mono', monospace;
  border: 1px solid var(--bd);
  background: 0;
  color: var(--txd);
  cursor: pointer;
  transition: all .2s;
}

.lang-b:hover { border-color: var(--bdl); color: var(--tx); }
.lang-b.on { background: var(--blue); border-color: var(--blue); color: #fff; }

/* Badges */
.bdg-row { display: flex; gap: 8px; margin-top: 16px; flex-wrap: wrap; }

.bdg {
  padding: 5px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  font-family: 'DM Mono', monospace;
  border: 1px solid;
}

.bdg-g { background: rgba(16,185,129,.15); color: var(--emerald); border-color: rgba(16,185,129,.3); }
.bdg-a { background: rgba(245,158,11,.15); color: var(--amber); border-color: rgba(245,158,11,.3); }
.bdg-v { background: rgba(139,92,246,.15); color: var(--violet); border-color: rgba(139,92,246,.3); }
.bdg-b { background: rgba(59,130,246,.15); color: var(--blue); border-color: rgba(59,130,246,.3); }

/* Tabs */
.tabs {
  display: flex;
  gap: 8px;
  padding: 12px 24px;
  background: var(--sf);
  border-bottom: 1px solid var(--bd);
  overflow-x: auto;
}

.tab {
  padding: 10px 20px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--txd);
  cursor: pointer;
  border: 0;
  background: 0;
  transition: all .2s;
  white-space: nowrap;
  font-family: 'DM Sans', sans-serif;
}

.tab:hover { color: var(--tx); background: var(--sf2); }
.tab.on { color: #fff; background: var(--blue); }

/* Main Content */
.mn { padding: 32px 24px 64px; }
.vw { display: none; }
.vw.on { display: block; }

/* Section Headers */
.dh { margin-bottom: 32px; }
.dh h2 { font-size: 24px; font-weight: 700; line-height: 1.3; margin-bottom: 12px; }
.dh p { color: var(--txd); font-size: 14px; line-height: 1.6; }

/* Legend */
.lg { display: flex; gap: 24px; margin-bottom: 24px; flex-wrap: wrap; }
.lg-i { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--txd); }
.lg-d { width: 10px; height: 10px; border-radius: 3px; }

/* Phase Cards Grid */
.pg { display: grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: 24px; margin-top: 24px; }

.pc {
  background: var(--sf);
  border: 1px solid var(--bd);
  border-radius: 12px;
  padding: 24px;
  box-shadow: var(--elevation-1);
  transition: box-shadow 0.2s var(--ease-standard), transform 0.2s var(--ease-standard), border-color 0.2s var(--ease-standard);
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.pc::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  border-radius: 12px 12px 0 0;
}

.pc-c0::before { background: linear-gradient(90deg, var(--cyan), var(--blue)); }
.pc-c1::before { background: linear-gradient(90deg, var(--blue), var(--violet)); }
.pc-c2::before { background: linear-gradient(90deg, var(--violet), var(--pink)); }
.pc-c3::before { background: linear-gradient(90deg, var(--emerald), var(--cyan)); }
.pc-c4::before { background: linear-gradient(90deg, var(--amber), var(--rose)); }
.pc-c5::before { background: linear-gradient(90deg, var(--rose), var(--violet)); }
.pc-c6::before { background: linear-gradient(90deg, var(--violet), var(--blue)); }
.pc-c7::before { background: linear-gradient(90deg, var(--emerald), var(--violet)); }

.pc:hover {
  border-color: var(--bdl);
  transform: translateY(-4px);
  box-shadow: var(--elevation-3);
}

.pn {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  color: var(--txm);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 12px;
}

.pt { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.pd { font-size: 14px; color: var(--txd); line-height: 1.6; margin-bottom: 16px; }

.ptags { display: flex; flex-wrap: wrap; gap: 6px; }

.ptag {
  padding: 3px 10px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 600;
  font-family: 'DM Mono', monospace;
}

.ptag-v { background: rgba(139,92,246,.12); color: var(--violet); }
.ptag-a { background: rgba(245,158,11,.12); color: var(--amber); }

/* Overview 4-Column Grid */
.ov-grid {
  display: grid;
  grid-template-columns: 1fr 2fr 2fr 1fr;
  gap: 16px;
  margin-top: 24px;
  align-items: start;
  width: 100%;
}

.ov-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
}

.ov-col .pc {
  flex: none;
  padding: 20px;
}

.ov-col .pc .pd {
  font-size: 12px;
  line-height: 1.5;
}

.ov-col .pc .pt {
  font-size: 15px;
}

.ov-col .pc .pn {
  font-size: 10px;
  margin-bottom: 8px;
}

.ov-col-label {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  color: var(--txm);
  text-transform: uppercase;
  letter-spacing: 2px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--bd);
  min-height: 28px;
}

/* Summary Stats */
.ss { margin-top: 48px; }
.ss h3 { font-size: 18px; font-weight: 700; margin-bottom: 20px; }
.sg { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }

.sc {
  background: var(--sf);
  border: 1px solid var(--bd);
  border-radius: 12px;
  padding: 24px;
  text-align: center;
  box-shadow: var(--elevation-1);
}

.sv { font-size: 36px; font-weight: 700; font-family: 'DM Mono', monospace; margin-bottom: 4px; }
.sl { font-size: 13px; color: var(--txd); }
.sv-g { color: var(--emerald); }
.sv-a { color: var(--amber); }
.sv-r { color: var(--rose); }

/* Flow Steps */
.flow-container {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.fs {
  display: grid;
  grid-template-columns: 72px 1fr 320px;
  gap: 24px;
  align-items: start;
  animation: fi .4s ease both;
}

/* Timeline Column */
.tc { display: flex; flex-direction: column; align-items: center; }

.td {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
  z-index: 2;
}

.tl { width: 2px; flex: 1; min-height: 24px; background: var(--bd); z-index: 1; }
.tl-d { background: repeating-linear-gradient(to bottom, var(--bd) 0px, var(--bd) 6px, transparent 6px, transparent 12px); }

/* Step Content Card */
.stc {
  background: var(--sf);
  border: 1px solid var(--bd);
  border-radius: 12px;
  padding: 24px;
  box-shadow: var(--elevation-1);
  transition: border-color 0.2s var(--ease-standard);
}

.stc:hover { border-color: var(--bdl); }

.stl {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--blue);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 6px;
}

.stt { font-size: 16px; font-weight: 700; margin-bottom: 8px; }
.std { font-size: 14px; color: var(--txd); line-height: 1.6; margin-bottom: 14px; }

/* Actors */
.sta { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }

.ac {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--sf2);
  border-radius: 8px;
  font-size: 12px;
  color: var(--tx);
  font-weight: 600;
}

.acd { width: 6px; height: 6px; border-radius: 50%; }

/* Sub-bullets */
.sbs { display: flex; flex-direction: column; gap: 6px; }

.sb {
  display: flex;
  align-items: start;
  gap: 8px;
  font-size: 13px;
  color: var(--txd);
  line-height: 1.5;
}

.sbi { flex-shrink: 0; margin-top: 2px; font-size: 12px; }

/* Module Panel (right sidebar) */
.mp {
  background: var(--sf2);
  border: 1px solid var(--bd);
  border-radius: 12px;
  padding: 20px;
  position: relative;
}

.mp::before {
  content: '';
  position: absolute;
  left: -13px;
  top: 20px;
  width: 12px;
  height: 2px;
  background: var(--bd);
}

.ml {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.ml-e { color: var(--emerald); }
.ml-a { color: var(--amber); }
.ml-n { color: var(--rose); }

.mm { font-size: 14px; font-weight: 700; margin-bottom: 6px; }
.md { font-size: 13px; color: var(--txd); line-height: 1.5; margin-bottom: 10px; }

/* Effort Bar */
.eb { height: 6px; background: var(--sf3); border-radius: 3px; overflow: hidden; margin-bottom: 4px; }
.ef { height: 100%; border-radius: 3px; transition: width .6s ease; }
.el { font-size: 11px; font-family: 'DM Mono', monospace; color: var(--txm); }

/* Best Practices */
.bp {
  margin-top: 32px;
  padding: 24px;
  background: var(--sf);
  border: 1px solid var(--bd);
  border-radius: 12px;
}

.bp h3 { font-size: 16px; font-weight: 700; margin-bottom: 16px; }
.bpg { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 12px; }

.bpi {
  padding: 14px;
  background: var(--sf2);
  border-radius: 8px;
  border: 1px solid var(--bd);
}

.bps { font-size: 11px; font-family: 'DM Mono', monospace; color: var(--cyan); margin-bottom: 6px; }
.bpt { font-size: 13px; color: var(--txd); line-height: 1.5; }

/* Theme Toggle */
.theme-toggle {
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 14px;
  border: 1px solid var(--bd);
  background: var(--sf2);
  color: var(--txd);
  cursor: pointer;
  transition: all .2s;
  line-height: 1;
}

.theme-toggle:hover { border-color: var(--bdl); color: var(--tx); }

/* Light theme adjustments */
[data-theme="light"] .bdg-g { background: rgba(5,150,105,.08); color: #059669; border-color: rgba(5,150,105,.2); }
[data-theme="light"] .bdg-a { background: rgba(217,119,6,.08); color: #d97706; border-color: rgba(217,119,6,.2); }
[data-theme="light"] .bdg-v { background: rgba(124,58,237,.08); color: #7c3aed; border-color: rgba(124,58,237,.2); }
[data-theme="light"] .bdg-b { background: rgba(59,130,246,.08); color: #3b82f6; border-color: rgba(59,130,246,.2); }
[data-theme="light"] .ptag-v { background: rgba(124,58,237,.08); color: #7c3aed; }
[data-theme="light"] .ptag-a { background: rgba(217,119,6,.08); color: #d97706; }

/* Animation */
@keyframes fi {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Focus States (Accessibility) */
button:focus-visible,
[onclick]:focus-visible {
  outline: 2px solid var(--blue);
  outline-offset: 2px;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* Desktop only — no responsive breakpoints */

/* === Catalog Benchmark Cards === */
.cat-bench {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--bd);
}

.cat-bench-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--txd);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.cat-bench-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.cat-bench-card {
  background: var(--sf2);
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 12px 14px;
  transition: border-color .15s;
}

.cat-bench-card:hover {
  border-color: var(--bdl);
}

.cat-bench-src {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  color: var(--cyan);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
  font-weight: 500;
}

.cat-bench-txt {
  font-size: 12px;
  color: var(--txd);
  line-height: 1.5;
}

.cat-bench-txt strong {
  color: var(--tx);
  font-weight: 600;
}
