/* =========================================================
   CareOS — Layout & Doc Shell
   ========================================================= */

.shell {
  max-width: 1480px;
  margin: 0 auto;
  padding: 0 var(--s-9);
}

/* ---------- Top bar ---------- */
.topbar {
  position: sticky; top: 0; z-index: 20;
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s-5) var(--s-9);
  background: color-mix(in oklch, var(--bg) 88%, transparent);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--line);
}
.brand {
  display: flex; align-items: center; gap: var(--s-3);
  font-family: var(--font-display);
  font-size: 22px; letter-spacing: var(--tr-display);
}
.brand-mark {
  width: 28px; height: 28px; position: relative;
}
.brand-mark::before, .brand-mark::after {
  content: ""; position: absolute; inset: 0;
  border-radius: 50%;
}
.brand-mark::before { background: var(--ink); transform: scale(0.55); }
.brand-mark::after {
  border: 1.5px solid var(--ink);
  animation: pulseRing 2.4s var(--ease-out-expo) infinite;
}
@keyframes pulseRing {
  0% { transform: scale(0.55); opacity: 1; }
  100% { transform: scale(1); opacity: 0; }
}
.topbar nav {
  display: flex; gap: var(--s-7);
  font-size: var(--fs-sm); color: var(--text-soft);
}
.topbar nav a {
  color: inherit; text-decoration: none;
  padding-bottom: 2px;
  border-bottom: 1px solid transparent;
  transition: color var(--t-quick) var(--ease-out-expo),
              border-color var(--t-quick) var(--ease-out-expo);
}
.topbar nav a:hover { color: var(--text); border-color: var(--ink); }
.topbar .meta { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--muted); }

/* ---------- Hero ---------- */
.hero {
  padding: var(--s-13) 0 var(--s-12);
  border-bottom: 1px solid var(--line);
  position: relative; overflow: hidden;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--s-11);
  align-items: end;
}
.hero h1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(64px, 9vw, var(--fs-6xl));
  line-height: 0.92;
  letter-spacing: var(--tr-display);
  margin: 0 0 var(--s-6);
  color: var(--ink);
}
.hero h1 em {
  font-style: italic;
  color: var(--sage-700);
}
.hero .lede {
  font-size: var(--fs-lg);
  line-height: 1.45;
  color: var(--text-soft);
  max-width: 50ch;
  margin: 0;
}
.hero-side {
  display: grid; gap: var(--s-5);
  padding-bottom: var(--s-3);
}
.hero-meta {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5) var(--s-7);
  border-top: 1px solid var(--line); padding-top: var(--s-5);
}
.hero-meta dt { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: var(--tr-eyebrow); text-transform: uppercase; color: var(--muted); margin-bottom: 4px; }
.hero-meta dd { margin: 0; font-size: var(--fs-md); color: var(--text); }

/* ---------- Section ---------- */
section.s {
  padding: var(--s-12) 0;
  border-bottom: 1px solid var(--line);
}
.s-head {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--s-9);
  margin-bottom: var(--s-9);
  align-items: baseline;
}
.s-head .id {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tr-eyebrow);
  text-transform: uppercase;
  color: var(--muted);
}
.s-head h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-3xl);
  letter-spacing: var(--tr-display);
  line-height: 1;
  margin: 0 0 var(--s-3);
}
.s-head p {
  font-size: var(--fs-md);
  color: var(--text-soft);
  max-width: 60ch;
  line-height: 1.5;
  margin: 0;
}

/* Subsection */
.sub {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--s-9);
  padding: var(--s-8) 0;
  border-top: 1px dashed var(--line);
}
.sub:first-of-type { border-top: 0; padding-top: 0; }
.sub-label .eyebrow { display: block; margin-bottom: var(--s-2); }
.sub-label h3 { margin: 0; font-size: var(--fs-lg); font-weight: 500; letter-spacing: var(--tr-tight); }
.sub-label p { margin: var(--s-2) 0 0; font-size: var(--fs-sm); color: var(--muted); max-width: 36ch; }

/* Card */
.card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-5);
}

/* Utility row */
.row { display: flex; align-items: center; gap: var(--s-3); flex-wrap: wrap; }
.col { display: flex; flex-direction: column; gap: var(--s-3); }

/* Footer */
footer.f {
  padding: var(--s-10) 0 var(--s-9);
  display: flex; justify-content: space-between; align-items: end;
  color: var(--muted); font-family: var(--font-mono); font-size: var(--fs-xs);
  letter-spacing: var(--tr-eyebrow); text-transform: uppercase;
}

@media (max-width: 980px) {
  .shell, .topbar { padding-left: var(--s-6); padding-right: var(--s-6); }
  .hero-grid, .s-head, .sub { grid-template-columns: 1fr; gap: var(--s-6); }
  .hero { padding: var(--s-11) 0 var(--s-10); }
}
