@tailwind base;
@tailwind components;
@tailwind utilities;

:root {
  --linen: #fbf7f0;
  --cream: #f7f0e6;
  --ink: #251f1a;
  --cocoa: #6e5a49;
  --gold: #b98e48;
  --petal: #f0d8cf;
  --line: rgba(37, 31, 26, 0.12);
  --card: rgba(255, 255, 255, 0.64);
  --shadow: 0 24px 80px rgba(37, 31, 26, 0.10);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--linen);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 320px;
  background:
    radial-gradient(circle at top left, rgba(240, 216, 207, 0.7), transparent 34rem),
    radial-gradient(circle at 88% 10%, rgba(185, 142, 72, 0.16), transparent 24rem),
    var(--linen);
  color: var(--ink);
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
textarea {
  font: inherit;
}

::selection {
  background: rgba(185, 142, 72, 0.25);
}

.skip-link {
  position: absolute;
  left: 1rem;
  top: 1rem;
  z-index: 50;
  transform: translateY(-160%);
  border-radius: 999px;
  background: var(--ink);
  color: white;
  padding: 0.75rem 1rem;
  transition: transform 160ms ease;
}

.skip-link:focus {
  transform: translateY(0);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.site-shell {
  min-height: 100vh;
  overflow: hidden;
}

.site-header,
.mobile-nav,
.hero,
.section,
.site-footer {
  width: min(72rem, calc(100% - 2rem));
  margin-inline: auto;
}

.site-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-block: 1.25rem;
}

.brand-mark,
.footer-brand {
  font-family: Georgia, "Times New Roman", serif;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 1.35rem;
  line-height: 1;
}

.desktop-nav,
.header-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.desktop-nav {
  gap: 1.35rem;
}

.nav-link,
.mobile-nav-link,
.footer-links a {
  color: var(--cocoa);
  font-size: 0.925rem;
  transition: color 160ms ease, opacity 160ms ease;
}

.nav-link:hover,
.nav-link.is-active,
.mobile-nav-link:hover,
.footer-links a:hover {
  color: var(--ink);
}

.mobile-menu-button {
  display: none;
  width: 2.75rem;
  height: 2.75rem;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.45);
  cursor: pointer;
}

.mobile-menu-button span[aria-hidden="true"] {
  position: absolute;
  width: 1.1rem;
  height: 1px;
  background: var(--ink);
  transition: transform 160ms ease;
}

.mobile-menu-button span[aria-hidden="true"]:last-child {
  transform: translateY(0.35rem);
}

.mobile-menu-button[aria-expanded="true"] span[aria-hidden="true"]:first-of-type {
  transform: rotate(45deg);
}

.mobile-menu-button[aria-expanded="true"] span[aria-hidden="true"]:last-child {
  transform: rotate(-45deg);
}

.mobile-nav {
  display: grid;
  gap: 0.75rem;
  border: 1px solid var(--line);
  border-radius: 1.5rem;
  background: rgba(255, 255, 255, 0.72);
  padding: 1rem;
  box-shadow: var(--shadow);
}

.mobile-nav[hidden] {
  display: none;
}

.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(18rem, 0.9fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  padding-block: clamp(4rem, 8vw, 7rem);
}

.compact-hero {
  grid-template-columns: minmax(0, 52rem);
  padding-block: clamp(3.5rem, 7vw, 6rem);
}

.eyebrow {
  margin: 0 0 1rem;
  color: var(--gold);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1,
h2,
h3,
.font-display {
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 500;
}

h1 {
  max-width: 14ch;
  margin-bottom: 1.5rem;
  font-size: clamp(3.4rem, 9vw, 7rem);
  line-height: 0.92;
  letter-spacing: -0.055em;
}

.compact-hero h1 {
  max-width: 15ch;
  font-size: clamp(3rem, 7vw, 5.9rem);
}

h2 {
  margin-bottom: 1rem;
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 1;
  letter-spacing: -0.035em;
}

h3 {
  margin-bottom: 0.7rem;
  font-size: 1.45rem;
  line-height: 1.12;
}

p {
  color: var(--cocoa);
  line-height: 1.72;
}

.lede {
  max-width: 42rem;
  font-size: clamp(1.08rem, 2vw, 1.32rem);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 2rem;
}

.button {
  display: inline-flex;
  min-height: 2.85rem;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 0.78rem 1.25rem;
  font-weight: 700;
  font-size: 0.92rem;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.button:hover {
  transform: translateY(-1px);
}

.button-primary {
  background: var(--ink);
  color: #fff;
  box-shadow: var(--shadow);
}

.button-secondary,
.button-outline {
  border-color: var(--line);
  background: rgba(255, 255, 255, 0.55);
  color: var(--ink);
}

.button-outline:hover,
.button-secondary:hover {
  border-color: rgba(37, 31, 26, 0.36);
}

.button-small {
  min-height: 2.4rem;
  padding: 0.55rem 1rem;
  font-size: 0.85rem;
}

.ritual-card,
.info-card,
.notice-panel,
.contact-card,
.form-card,
.faq-item {
  border: 1px solid var(--line);
  background: var(--card);
  box-shadow: var(--shadow);
  backdrop-filter: blur(16px);
}

.ritual-card {
  border-radius: 2rem;
  padding: clamp(1.5rem, 4vw, 2.4rem);
}

.ritual-card h2 {
  font-size: clamp(2rem, 4vw, 3.3rem);
}

.stat-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 2rem;
}

.stat-grid div {
  border-radius: 1.2rem;
  background: rgba(255, 255, 255, 0.64);
  padding: 1rem;
}

.stat-grid strong {
  display: block;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 2rem;
  line-height: 1;
}

.stat-grid span {
  display: block;
  margin-top: 0.4rem;
  color: var(--cocoa);
  font-size: 0.88rem;
}

.section {
  padding-block: clamp(2.8rem, 6vw, 5.5rem);
}

.split-section {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: clamp(1.5rem, 5vw, 4rem);
  align-items: start;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.split-section p:last-child {
  font-size: clamp(1.05rem, 2vw, 1.25rem);
}

.section-heading {
  max-width: 46rem;
  margin-bottom: 2rem;
}

.card-grid {
  display: grid;
  gap: 1rem;
}

.card-grid.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.card-grid.five {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.info-card {
  border-radius: 1.5rem;
  padding: 1.25rem;
}

.step-number,
.timeline-item span {
  display: inline-flex;
  margin-bottom: 1rem;
  color: var(--gold);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.18em;
}

.callout-band {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  border-radius: 2rem;
  background: linear-gradient(135deg, rgba(37, 31, 26, 0.95), rgba(84, 63, 46, 0.95));
  padding: clamp(1.5rem, 4vw, 2.5rem);
}

.callout-band h2,
.callout-band p {
  color: #fff;
}

.callout-band .eyebrow {
  color: #f3d397;
}

.callout-band .button-primary {
  flex: 0 0 auto;
  background: #fff;
  color: var(--ink);
}

.notice-panel {
  border-radius: 2rem;
  padding: clamp(1.5rem, 4vw, 2.5rem);
}

.timeline-section {
  display: grid;
  gap: 1rem;
}

.timeline-item {
  display: grid;
  grid-template-columns: 4rem 1fr;
  gap: 1rem;
  border-bottom: 1px solid var(--line);
  padding-bottom: 1.25rem;
}

.timeline-item h2 {
  font-size: clamp(1.8rem, 3vw, 2.7rem);
}

.faq-list {
  display: grid;
  gap: 0.85rem;
}

.faq-item {
  border-radius: 1.3rem;
  padding: 0.2rem 1.25rem;
}

.faq-item summary {
  cursor: pointer;
  list-style: none;
  padding: 1rem 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.28rem;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item summary::after {
  content: "+";
  float: right;
  color: var(--gold);
}

.faq-item[open] summary::after {
  content: "–";
}

.faq-item p {
  max-width: 58rem;
  padding-bottom: 1rem;
}

.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: 1rem;
  align-items: start;
}

.contact-card,
.form-card {
  border-radius: 1.6rem;
  padding: clamp(1.25rem, 3vw, 2rem);
}

.form-card {
  display: grid;
  gap: 1rem;
}

.form-card label {
  display: grid;
  gap: 0.45rem;
  color: var(--cocoa);
  font-weight: 700;
  font-size: 0.9rem;
}

.form-card input,
.form-card textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.75);
  color: var(--ink);
  padding: 0.88rem 1rem;
  outline: none;
}

.form-card input:focus,
.form-card textarea:focus {
  border-color: rgba(185, 142, 72, 0.75);
  box-shadow: 0 0 0 4px rgba(185, 142, 72, 0.14);
}

.form-note {
  margin-bottom: 0;
  font-size: 0.88rem;
}

.site-footer {
  margin-top: 4rem;
  border-top: 1px solid var(--line);
  padding-block: 2.5rem;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 0.7fr 0.7fr 1fr;
  gap: 1.5rem;
}

.footer-heading {
  margin-bottom: 0.75rem;
  color: var(--ink);
  font-weight: 800;
}

.footer-note,
.footer-links a {
  font-size: 0.9rem;
}

.footer-links {
  display: grid;
  gap: 0.55rem;
}

.footer-contact {
  margin-top: 1rem;
  color: var(--ink);
  font-weight: 700;
}

@media (max-width: 980px) {
  .desktop-nav {
    display: none;
  }

  .mobile-menu-button {
    display: inline-flex;
  }

  .hero,
  .split-section,
  .contact-grid {
    grid-template-columns: 1fr;
  }

  .card-grid.three,
  .card-grid.five,
  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .site-header,
  .mobile-nav,
  .hero,
  .section,
  .site-footer {
    width: min(100% - 1rem, 72rem);
  }

  .header-actions .button-outline {
    display: none;
  }

  .hero {
    padding-block: 3rem;
  }

  h1 {
    font-size: clamp(3rem, 18vw, 4.4rem);
  }

  .hero-actions,
  .callout-band {
    align-items: stretch;
    flex-direction: column;
  }

  .button {
    width: 100%;
  }

  .card-grid.three,
  .card-grid.five,
  .footer-grid,
  .stat-grid {
    grid-template-columns: 1fr;
  }

  .timeline-item {
    grid-template-columns: 1fr;
  }
}

/* Milestone 2: office request backend form */
.request-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(22rem, 1fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: start;
  padding-bottom: clamp(4rem, 8vw, 7rem);
}

.card-soft,
.success-card {
  border: 1px solid var(--line);
  border-radius: 2rem;
  background: var(--card);
  box-shadow: var(--shadow);
  padding: clamp(1.5rem, 4vw, 2.5rem);
}

.request-intro h2,
.success-card h2 {
  font-size: clamp(2rem, 4vw, 3.1rem);
}

.compact-process {
  margin-top: 1.5rem;
}

.compact-process article {
  display: grid;
  grid-template-columns: 2.5rem 1fr;
  gap: 1rem;
  align-items: start;
  padding-block: 1rem;
  border-top: 1px solid var(--line);
}

.compact-process span {
  color: var(--gold);
  font-weight: 800;
  letter-spacing: 0.12em;
}

.compact-process p {
  margin: 0;
  color: var(--cocoa);
  line-height: 1.65;
}

.form-row.two-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.form-card select {
  width: 100%;
  min-height: 3rem;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.75);
  color: var(--ink);
  padding: 0.85rem 1rem;
}

.optional {
  color: var(--cocoa);
  font-size: 0.82em;
  font-weight: 400;
}

.field-error {
  margin: 0.35rem 0 0;
  color: #9f2f24;
  font-size: 0.875rem;
}

.form-alert {
  border: 1px solid rgba(159, 47, 36, 0.24);
  border-radius: 1rem;
  background: rgba(159, 47, 36, 0.08);
  color: #7d261d;
  padding: 0.9rem 1rem;
  line-height: 1.5;
}

.honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.button-wide {
  width: 100%;
  justify-content: center;
}

.success-card code {
  border-radius: 0.5rem;
  background: rgba(37, 31, 26, 0.08);
  padding: 0.15rem 0.35rem;
  font-size: 0.9rem;
}

.compact-actions {
  margin-top: 1.5rem;
}

@media (max-width: 860px) {
  .request-grid,
  .form-row.two-columns {
    grid-template-columns: 1fr;
  }
}

.drop-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.drop-card,
.drop-status-card {
  border: 1px solid var(--line);
  border-radius: 2rem;
  background: rgba(255, 255, 255, 0.62);
  box-shadow: var(--shadow);
  padding: clamp(1.25rem, 3vw, 2rem);
}

.drop-card {
  display: flex;
  min-height: 26rem;
  flex-direction: column;
  gap: 1rem;
}

.drop-card h3 {
  font-size: clamp(2rem, 3.5vw, 3rem);
  letter-spacing: -0.04em;
}

.progress-block {
  margin-block: auto 0.5rem;
}

.progress-row,
.drop-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  color: var(--cocoa);
  font-size: 0.9rem;
}

.progress-track {
  height: 0.55rem;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(37, 31, 26, 0.1);
  margin-top: 0.6rem;
}

.progress-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--gold);
}

.drop-meta {
  flex-wrap: wrap;
  justify-content: flex-start;
  margin-block: 0.25rem 0.5rem;
}

.drop-meta span {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.55);
  padding: 0.45rem 0.7rem;
}

.office-hero {
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 24rem);
}

.drop-status-card h2 {
  font-size: clamp(2.2rem, 5vw, 4rem);
}

.drop-meta.vertical {
  display: grid;
  justify-content: stretch;
}

.form-note {
  margin: 0.9rem 0 0;
  font-size: 0.9rem;
}

@media (max-width: 860px) {
  .drop-grid,
  .office-hero {
    grid-template-columns: 1fr;
  }
}

/* Milestone 3.1: keep PRG success anchor clear of sticky/browser chrome. */
#vote-interest {
  scroll-margin-top: 2rem;
}

/* Milestone 4: Admin Lite Dashboard */
.admin-body {
  min-height: 100vh;
  background: #f6f0e7;
}

.admin-shell {
  display: grid;
  grid-template-columns: 18rem minmax(0, 1fr);
  min-height: 100vh;
}

.admin-sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  border-right: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.52);
  padding: 1.25rem;
  backdrop-filter: blur(18px);
}

.admin-brand {
  display: grid;
  gap: 0.25rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.35rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-brand span {
  color: var(--gold);
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.22em;
}

.admin-nav {
  display: grid;
  gap: 0.45rem;
}

.admin-nav-link,
.admin-public-link,
.admin-link-button {
  border-radius: 999px;
  color: var(--cocoa);
  font-size: 0.92rem;
  font-weight: 700;
  padding: 0.75rem 0.95rem;
}

.admin-nav-link:hover,
.admin-nav-link.is-active {
  background: var(--ink);
  color: #fff;
}

.admin-public-link {
  margin-top: auto;
  border: 1px solid var(--line);
  text-align: center;
}

.admin-user-card {
  display: grid;
  gap: 0.2rem;
  border: 1px solid var(--line);
  border-radius: 1.25rem;
  background: rgba(255, 255, 255, 0.66);
  padding: 1rem;
}

.admin-user-card p {
  margin: 0;
  font-size: 0.8rem;
}

.admin-link-button {
  border: 0;
  background: transparent;
  cursor: pointer;
  padding-inline: 0;
  text-decoration: underline;
}

.admin-main {
  width: min(100% - 2rem, 86rem);
  margin-inline: auto;
  padding-block: 2rem 4rem;
}

.admin-auth-panel {
  width: min(100%, 34rem);
  margin: 12vh auto;
  border: 1px solid var(--line);
  border-radius: 2rem;
  background: var(--card);
  box-shadow: var(--shadow);
  padding: clamp(1.5rem, 5vw, 3rem);
}

.admin-auth-panel h1,
.admin-page-header h1 {
  max-width: none;
  font-size: clamp(2.6rem, 6vw, 5rem);
}

.admin-login-form {
  margin-top: 1.5rem;
}

.admin-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.admin-page-header p {
  max-width: 48rem;
}

.admin-stat-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.85rem;
  margin-bottom: 1rem;
}

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

.admin-stat-grid article,
.admin-card {
  border: 1px solid var(--line);
  border-radius: 1.5rem;
  background: rgba(255, 255, 255, 0.68);
  box-shadow: var(--shadow);
  padding: 1rem;
}

.admin-stat-grid span,
.admin-muted,
.admin-table small {
  color: var(--cocoa);
  font-size: 0.82rem;
}

.admin-stat-grid strong {
  display: block;
  margin-top: 0.3rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 2.4rem;
  line-height: 1;
}

.admin-grid-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

.admin-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.admin-card-header h2,
.admin-card h2 {
  margin-bottom: 0.2rem;
  font-size: clamp(1.7rem, 3vw, 2.6rem);
}

.admin-card-header a {
  color: var(--gold);
  font-weight: 800;
}

.admin-table-wrap {
  overflow-x: auto;
}

.admin-table {
  width: 100%;
  min-width: 44rem;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.admin-table-wide {
  min-width: 82rem;
}

.admin-table th,
.admin-table td {
  border-bottom: 1px solid var(--line);
  padding: 0.75rem;
  text-align: left;
  vertical-align: top;
}

.admin-table th {
  color: var(--gold);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.admin-badge,
.admin-pill-row span {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--ink);
  padding: 0.35rem 0.6rem;
  font-size: 0.78rem;
  font-weight: 800;
}

.admin-filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.admin-filter-bar label,
.admin-inline-form,
.admin-inline-form select,
.admin-filter-bar input,
.admin-filter-bar select,
.admin-card select {
  font-size: 0.9rem;
}

.admin-filter-bar label {
  display: grid;
  gap: 0.35rem;
  color: var(--cocoa);
  font-weight: 800;
}

.admin-filter-bar input,
.admin-filter-bar select,
.admin-inline-form select,
.admin-card select {
  min-height: 2.6rem;
  border: 1px solid var(--line);
  border-radius: 0.8rem;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  padding: 0.55rem 0.7rem;
}

.admin-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.admin-inline-form {
  display: flex;
  gap: 0.4rem;
  align-items: center;
}

.admin-inline-form button {
  min-height: 2.6rem;
  border: 0;
  border-radius: 999px;
  background: var(--ink);
  color: #fff;
  cursor: pointer;
  font-weight: 800;
  padding: 0.5rem 0.8rem;
}

.admin-drop-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.admin-drop-card {
  display: grid;
  gap: 0.75rem;
}

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

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

  .admin-nav {
    grid-template-columns: repeat(auto-fit, minmax(7rem, 1fr));
  }

  .admin-stat-grid,
  .admin-grid-two,
  .admin-drop-grid {
    grid-template-columns: 1fr;
  }

  .admin-page-header {
    flex-direction: column;
  }
}

/* Milestone 5: Subscription Cycle pricing */
.subscription-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(20rem, 32rem);
  gap: 1rem;
  align-items: stretch;
}

.subscription-price-card,
.subscription-detail-card {
  min-height: 100%;
}

.subscription-lists {
  padding-top: 0;
}

.date-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.date-chip-list span {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  color: var(--cocoa);
  font-size: 0.82rem;
  font-weight: 800;
  padding: 0.36rem 0.62rem;
}

.date-chip-list span.is-remaining {
  border-color: rgba(185, 142, 72, 0.42);
  background: rgba(185, 142, 72, 0.12);
  color: var(--ink);
}

.form-card select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.75);
  color: var(--ink);
  padding: 0.88rem 1rem;
  outline: none;
}

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

/* Milestone 6: Route-aware cycles */
.form-row.three-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.checkbox-label {
  display: flex;
  gap: 0.6rem;
  align-items: center;
  color: var(--cocoa);
  font-weight: 800;
}

.checkbox-label input {
  width: auto;
}

.cycle-theme-name {
  color: var(--gold);
  font-weight: 800;
}

.route-aware-list {
  padding-top: 0;
}

.route-cycle-card {
  min-height: 100%;
}

.cycle-routes-card {
  scroll-margin-top: 2rem;
}

@media (max-width: 860px) {
  .form-row.three-columns {
    grid-template-columns: 1fr;
  }
}

/* Milestone 7: Stripe Checkout foundation */
.route-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: auto;
}

.route-card-actions .button {
  flex: 1 1 10rem;
}

.reservation-result-card {
  margin-top: clamp(3rem, 7vw, 6rem);
}

.reservation-result-card h1 {
  max-width: 14ch;
  font-size: clamp(3rem, 7vw, 5rem);
}

.form-card button[disabled] {
  cursor: not-allowed;
  opacity: 0.55;
  transform: none;
}

.admin-stat-grid {
  grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
}

.delivery-date-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}

.delivery-date-pill {
  border: 1px solid rgba(43, 33, 27, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  padding: 0.45rem 0.75rem;
  font-size: 0.9rem;
}

.delivery-date-pill.is-past {
  opacity: 0.45;
}

/* Milestone 9.1: Subscriber portal layout hotfix */
.page-hero,
.content-section {
  width: min(72rem, calc(100% - 2rem));
  margin-inline: auto;
}

.page-hero {
  padding-block: clamp(3rem, 7vw, 6rem);
}

.page-hero.compact-hero {
  display: block;
}

.page-hero form {
  margin-top: 1.25rem;
}

.content-section {
  padding-block: clamp(1.25rem, 3vw, 2.5rem);
}

.content-section + .content-section {
  padding-top: 0;
}

.narrow-section {
  max-width: 48rem;
}

.two-column-section {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  align-items: stretch;
}

.two-column-section > .form-card {
  min-height: 100%;
}

.subscriber-portal-summary {
  padding-top: 0;
}

.delivery-date-grid {
  align-items: center;
}

@media (max-width: 860px) {
  .two-column-section {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .page-hero,
  .content-section {
    width: min(100% - 1rem, 72rem);
  }

  .page-hero {
    padding-block: 3rem;
  }
}


/* Milestone 10: Operations roster */
.roster-stat-grid {
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
}

.roster-filter-bar select,
.roster-filter-bar input[type="date"] {
  min-width: 11rem;
}

.roster-alert {
  margin-bottom: 1rem;
}

.roster-date-nav a {
  text-decoration: none;
}

.roster-route-summary {
  margin-bottom: 1rem;
}

.roster-update-form {
  display: grid;
  grid-template-columns: minmax(9rem, 12rem) minmax(16rem, 1fr) auto;
  gap: 0.5rem;
  align-items: center;
}

.roster-update-form select,
.roster-update-form input {
  min-height: 2.4rem;
  border: 1px solid var(--line);
  border-radius: 0.8rem;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  padding: 0.5rem 0.65rem;
}

.roster-update-form button {
  min-height: 2.4rem;
  border: 0;
  border-radius: 999px;
  background: var(--ink);
  color: #fff;
  cursor: pointer;
  font-weight: 800;
  padding: 0.5rem 0.85rem;
}

.roster-update-form small {
  grid-column: 1 / -1;
  color: var(--cocoa);
}

@media (max-width: 760px) {
  .roster-update-form {
    grid-template-columns: 1fr;
  }
}

/* Milestone 12: Production calendar */
.production-stat-grid {
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
}

.production-filter-bar input[type="date"],
.production-filter-bar select {
  min-width: 10rem;
}

.production-window-nav a {
  text-decoration: none;
}

.production-calendar-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(19rem, 1fr));
  gap: 1rem;
  align-items: stretch;
}

.production-day-card {
  display: flex;
  min-height: 21rem;
  flex-direction: column;
  gap: 1rem;
}

.production-day-card.is-today {
  border-color: rgba(185, 142, 72, 0.45);
  box-shadow: 0 20px 60px rgba(185, 142, 72, 0.16);
}

.production-day-card.is-muted {
  opacity: 0.72;
}

.production-day-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.production-day-header h2 {
  margin: 0;
  font-size: clamp(1.8rem, 3vw, 2.8rem);
}

.production-day-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
}

.production-day-metrics span,
.production-status-line span {
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.58);
  color: var(--cocoa);
  font-size: 0.78rem;
  padding: 0.55rem;
}

.production-day-metrics strong {
  display: block;
  color: var(--ink);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.55rem;
  line-height: 1;
}

.production-status-line {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.production-route-list {
  display: grid;
  gap: 0.45rem;
  margin-top: auto;
}

.production-route-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  color: var(--ink);
  padding: 0.55rem 0.75rem;
  text-decoration: none;
}

.production-route-list span {
  color: var(--gold);
  font-weight: 800;
}

@media (max-width: 640px) {
  .production-day-metrics {
    grid-template-columns: 1fr;
  }

  .production-day-header {
    display: grid;
  }
}


/* Milestone 13: Office expansion workflow */
.expansion-table .compact-form {
  min-width: 18rem;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.expansion-table input,
.expansion-table select {
  min-width: 0;
}

.expansion-table .button {
  margin-top: 0.35rem;
}

@media (max-width: 980px) {
  .expansion-table .form-row.two-columns {
    grid-template-columns: 1fr;
  }
}

/* Milestone 14 launch hardening UI */
.readiness-pass { border-color: rgba(71, 128, 75, .25); color: #2f6f3e; }
.readiness-warning { border-color: rgba(184, 128, 44, .28); color: #a96f1f; }
.readiness-fail { border-color: rgba(160, 54, 42, .28); color: #9d2f24; }
.admin-checklist { display: grid; gap: .75rem; margin: 1rem 0 0; padding-left: 1.15rem; color: var(--color-cocoa, #6c5848); }
.admin-log-tail { max-height: 360px; overflow: auto; padding: 1rem; border-radius: 1rem; background: rgba(43, 33, 27, .05); white-space: pre-wrap; font-size: .82rem; line-height: 1.5; }
.notice.success { border-color: rgba(71, 128, 75, .25); color: #2f6f3e; }

/* Milestone 16: Office Drop CRUD */
.admin-wide-form,
.admin-card-subsection,
.admin-building-form {
  margin-top: 1rem;
}

.admin-card-subsection {
  border: 1px solid var(--line);
  border-radius: 1.25rem;
  padding: 1rem;
  background: rgba(255,255,255,0.45);
}

.admin-card-subsection h2,
.admin-card h3 {
  margin-bottom: 0.75rem;
  font-size: clamp(1.4rem, 2.4vw, 2.1rem);
}

.admin-wide-form {
  background: rgba(255,255,255,0.62);
  box-shadow: var(--shadow);
}

.admin-building-form {
  border: 1px solid var(--line);
  border-radius: 1.25rem;
  padding: 1rem;
  background: rgba(255,255,255,0.6);
}

.admin-danger-form,
.danger-card {
  margin-top: 0.6rem;
}

.danger-card {
  border-color: rgba(160,52,38,0.22);
  background: rgba(255,246,242,0.7);
}

.admin-drop-card.is-muted {
  opacity: 0.72;
}

.alert.error-alert {
  border: 1px solid rgba(160,52,38,0.28);
  border-radius: 1rem;
  background: rgba(255,246,242,0.82);
  padding: 1rem;
  margin-bottom: 1rem;
  color: #8b2e22;
}

.admin-inline-form input {
  min-height: 2.6rem;
  border: 1px solid var(--line);
  border-radius: 0.8rem;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  padding: 0.55rem 0.7rem;
}


/* Milestone 17: Structured diagnostics */
.diagnostics-filter-bar input { min-width: 11rem; }
.diagnostics-table td:nth-child(4) { max-width: 28rem; }
.diagnostics-level-error { border-color: rgba(164, 53, 53, .35); background: rgba(164, 53, 53, .12); color: #7a2727; }
.diagnostics-level-warning { border-color: rgba(185, 142, 72, .35); background: rgba(185, 142, 72, .14); color: #7a5220; }
.diagnostics-level-info { border-color: rgba(43, 33, 27, .12); }

/* Milestone 17.3: Admin audit UI tightening */
.audit-table {
  table-layout: fixed;
  min-width: 90rem;
}
.audit-table .audit-col-when { width: 10.5rem; }
.audit-table .audit-col-actor { width: 8.75rem; }
.audit-table .audit-col-action { width: 18rem; }
.audit-table .audit-col-entity { width: 9rem; }
.audit-table .audit-col-changed { width: 7.5rem; }
.audit-table .audit-col-ip { width: 8.75rem; }
.audit-table .audit-col-path { width: 8rem; }
.audit-table .audit-col-summary { width: auto; }
.audit-actor-name,
.audit-actor-ip {
  display: block;
}
.audit-actor-ip {
  margin-top: 0.25rem;
  color: var(--cocoa);
  white-space: nowrap;
  word-break: normal;
  overflow-wrap: normal;
  font-size: 0.78rem;
  line-height: 1.25;
}
.audit-table td:nth-child(1),
.audit-table td:nth-child(2),
.audit-table td:nth-child(6) {
  white-space: nowrap;
}
.audit-table td:nth-child(7),
.audit-table td:nth-child(8) {
  overflow-wrap: anywhere;
}
.audit-json-view {
  line-height: 1.32;
}
.audit-json-line {
  min-height: 0;
  padding-block: 0.03rem;
}
.audit-json-line.is-changed {
  margin-block: 0.08rem;
}

/* Milestone 18.1: Admin users bugfix + compact admin UI + diagnostics detail readability */
.admin-sidebar {
  gap: 0.75rem;
  padding-block: 1rem;
  overflow-y: auto;
}
.admin-nav {
  gap: 0.18rem;
}
.admin-nav-link,
.admin-public-link,
.admin-link-button {
  padding: 0.52rem 0.85rem;
  font-size: 0.88rem;
}
.admin-user-card {
  padding: 0.8rem;
}
.admin-user-card p {
  font-size: 0.74rem;
}
.diagnostics-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: 0.85rem;
  margin-bottom: 1rem;
}
.diagnostics-summary-grid article {
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 1.25rem;
  background: rgba(255, 255, 255, 0.68);
  box-shadow: var(--shadow);
  padding: 1rem;
}
.diagnostics-summary-grid span {
  display: block;
  color: var(--cocoa);
  font-size: 0.78rem;
  margin-bottom: 0.4rem;
}
.diagnostics-summary-grid strong {
  display: block;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: clamp(0.88rem, 1.2vw, 1.05rem);
  line-height: 1.32;
  word-break: break-word;
  overflow-wrap: anywhere;
  color: var(--ink);
}
.diagnostics-summary-grid article:nth-child(3),
.diagnostics-summary-grid article:nth-child(4) {
  grid-column: span 2;
}
@media (max-width: 760px) {
  .diagnostics-summary-grid article:nth-child(3),
  .diagnostics-summary-grid article:nth-child(4) {
    grid-column: span 1;
  }
}

/* Milestone 20: public conversion path polish */
.section-heading-with-action {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  max-width: none;
}

.section-heading-with-action > div {
  max-width: 48rem;
}

.info-card-link {
  display: grid;
  color: inherit;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.info-card-link:hover {
  transform: translateY(-2px);
  border-color: rgba(185, 142, 72, 0.38);
  background: rgba(255, 255, 255, 0.76);
}

.card-link-label {
  align-self: end;
  margin-top: 1rem;
  color: var(--gold);
  font-weight: 800;
  font-size: 0.9rem;
}

.cycle-mini-note {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  border-top: 1px solid var(--line);
  margin-top: 1.4rem;
  padding-top: 1rem;
  color: var(--cocoa);
  font-size: 0.9rem;
}

.cycle-mini-note span {
  font-weight: 800;
  color: var(--ink);
}

.cycle-mini-note a {
  color: var(--gold);
  font-weight: 800;
}

.route-preview-section {
  padding-top: clamp(2rem, 4vw, 3.5rem);
}

.home-drop-grid .drop-card,
.home-drop-card {
  min-height: 24rem;
}

.route-card-topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.route-status-pill {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--cocoa);
  font-size: 0.72rem;
  font-weight: 800;
  padding: 0.34rem 0.62rem;
}

.route-status-accepting-reservations {
  border-color: rgba(70, 130, 90, 0.28);
  background: rgba(70, 130, 90, 0.10);
  color: #2f6b44;
}

.route-status-gathering-interest {
  border-color: rgba(185, 142, 72, 0.32);
  background: rgba(185, 142, 72, 0.12);
  color: #7a5220;
}

.route-status-waitlist {
  border-color: rgba(37, 31, 26, 0.16);
  background: rgba(37, 31, 26, 0.06);
  color: var(--cocoa);
}

.area-note,
.lede-small {
  border-left: 3px solid rgba(185, 142, 72, 0.45);
  padding-left: 0.85rem;
  color: var(--cocoa);
  font-size: 0.95rem;
}

.route-philosophy-section {
  padding-block: clamp(2rem, 4vw, 3.5rem);
}

@media (max-width: 860px) {
  .section-heading-with-action {
    display: grid;
  }
}

.form-row.three-columns {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.form-row.four-columns {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.admin-checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  gap: 0.65rem 1rem;
}

.admin-checkbox-grid label {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0.55rem 0.75rem;
  background: rgba(255, 255, 255, 0.62);
}

.admin-preline {
  white-space: pre-wrap;
  color: var(--cocoa);
}

@media (max-width: 900px) {
  .form-row.three-columns,
  .form-row.four-columns {
    grid-template-columns: 1fr;
  }
}

/* Milestone 23.1 procurement UI tightening */
.procurement-pack-form{display:grid;grid-template-columns:minmax(12rem,1.2fr) minmax(10rem,1fr) minmax(8rem,.75fr) repeat(3,minmax(8rem,.75fr)) minmax(7rem,.65fr) auto;gap:.75rem;align-items:end;margin:1.25rem 0;}
.procurement-pack-form label{display:flex;flex-direction:column;gap:.35rem;min-width:0;}
.procurement-pack-form input,.procurement-pack-form select{width:100%;min-width:0;}
.procurement-pack-form .button{align-self:end;white-space:nowrap;}
@media (max-width:1200px){.procurement-pack-form{grid-template-columns:repeat(4,minmax(0,1fr));}.procurement-pack-form .button{grid-column:auto;}}
@media (max-width:760px){.procurement-pack-form{grid-template-columns:1fr;}.procurement-pack-form .button{width:100%;}}

/* Milestone 27.1: procurement plan UI cleanup */
.procurement-plans-header h1,
.procurement-plan-header h1 {
  font-size: clamp(2.8rem, 5.2vw, 4.6rem);
  line-height: 0.94;
  overflow-wrap: anywhere;
}

.procurement-plan-header {
  align-items: flex-start;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
  gap: 0.85rem;
  align-items: end;
}

.form-grid label {
  display: grid;
  gap: 0.35rem;
  color: var(--cocoa);
  font-weight: 800;
}

.form-grid input,
.form-grid select,
.form-grid textarea,
.procurement-plan-items-table input,
.procurement-plan-items-table select {
  width: 100%;
  min-height: 2.55rem;
  border: 1px solid var(--line);
  border-radius: 0.8rem;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  padding: 0.55rem 0.7rem;
  font: inherit;
}

.form-grid textarea {
  resize: vertical;
}

.form-wide {
  grid-column: 1 / -1;
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.procurement-plan-status-form {
  grid-template-columns: minmax(9rem, 12rem) minmax(14rem, 1fr) minmax(18rem, 2fr);
  align-items: end;
}

.procurement-plan-items-table {
  min-width: 92rem;
}

.procurement-plan-items-table th:nth-child(1),
.procurement-plan-items-table td:nth-child(1) {
  width: 13rem;
}

.procurement-plan-items-table th:nth-child(2),
.procurement-plan-items-table td:nth-child(2) {
  width: 9rem;
  white-space: nowrap;
}

.procurement-plan-items-table th:nth-child(3),
.procurement-plan-items-table td:nth-child(3) {
  width: 20rem;
}

.procurement-plan-items-table th:nth-child(4),
.procurement-plan-items-table td:nth-child(4) {
  width: 11rem;
}

.procurement-plan-items-table th:nth-child(5),
.procurement-plan-items-table td:nth-child(5) {
  width: 21rem;
}

.procurement-plan-items-table th:last-child,
.procurement-plan-items-table td:last-child {
  width: 7rem;
  text-align: right;
}

.procurement-plan-items-table td:nth-child(5) {
  display: grid;
  grid-template-columns: minmax(8rem, 10rem) 1fr 1fr;
  gap: 0.45rem;
  align-items: center;
}

.procurement-plan-items-table td:nth-child(5) select {
  grid-column: 1 / 2;
}

.procurement-plan-items-table td:nth-child(5) input {
  min-width: 0;
}

.procurement-plans-table th:first-child,
.procurement-plans-table td:first-child {
  min-width: 15rem;
}

@media (max-width: 1100px) {
  .procurement-plan-status-form {
    grid-template-columns: 1fr;
  }

  .procurement-plan-items-table td:nth-child(5) {
    display: table-cell;
  }

  .procurement-plan-items-table td:nth-child(5) input,
  .procurement-plan-items-table td:nth-child(5) select {
    margin-bottom: 0.35rem;
  }
}

.kitchen-card-issue-form,
.inline-form {
  display: grid;
  gap: 0.45rem;
}

.admin-inline-fields {
  display: grid;
  grid-template-columns: repeat(3, minmax(4.5rem, 1fr)) auto;
  gap: 0.4rem;
  align-items: center;
}

.admin-inline-fields input {
  min-width: 0;
}

@media (max-width: 900px) {
  .admin-inline-fields {
    grid-template-columns: 1fr;
  }
}

/* Milestone 29.1: kitchen task card UI cleanup */
.kitchen-card-items-table {
  table-layout: fixed;
}

.kitchen-card-items-table th:nth-child(1),
.kitchen-card-items-table td:nth-child(1) {
  width: 9.5rem;
}

.kitchen-card-items-table th:nth-child(2),
.kitchen-card-items-table td:nth-child(2),
.kitchen-card-items-table th:nth-child(3),
.kitchen-card-items-table td:nth-child(3) {
  width: 6.5rem;
}

.kitchen-card-items-table th:nth-child(4),
.kitchen-card-items-table td:nth-child(4) {
  width: 32rem;
}

.kitchen-card-items-table th:nth-child(5),
.kitchen-card-items-table td:nth-child(5) {
  width: 16rem;
}

.kitchen-card-items-table th:last-child,
.kitchen-card-items-table td:last-child {
  width: 6rem;
  text-align: right;
}

.kitchen-issue-form,
.kitchen-status-form {
  display: grid;
  gap: 0.55rem;
}

.kitchen-issue-form select,
.kitchen-status-form select,
.kitchen-status-form input,
.kitchen-qty-grid input {
  width: 100%;
  min-width: 0;
}

.kitchen-qty-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(4.8rem, 1fr)) auto;
  gap: 0.45rem;
  align-items: end;
}

.kitchen-qty-grid label {
  display: grid;
  gap: 0.22rem;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.kitchen-qty-grid .button {
  white-space: nowrap;
}

.kitchen-lot-hint {
  margin: 0;
  max-width: 28rem;
}

@media (max-width: 1150px) {
  .kitchen-card-items-table {
    table-layout: auto;
  }
  .kitchen-qty-grid {
    grid-template-columns: 1fr;
  }
  .kitchen-card-items-table th:nth-child(1),
  .kitchen-card-items-table td:nth-child(1),
  .kitchen-card-items-table th:nth-child(2),
  .kitchen-card-items-table td:nth-child(2),
  .kitchen-card-items-table th:nth-child(3),
  .kitchen-card-items-table td:nth-child(3),
  .kitchen-card-items-table th:nth-child(4),
  .kitchen-card-items-table td:nth-child(4),
  .kitchen-card-items-table th:nth-child(5),
  .kitchen-card-items-table td:nth-child(5),
  .kitchen-card-items-table th:last-child,
  .kitchen-card-items-table td:last-child {
    width: auto;
  }
}

/* Milestone 30: production workflow v2 */
.admin-header-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    align-items: center;
}

.production-workflow-card h2 {
    margin-bottom: 0.15rem;
}

.production-workflow-wrap {
    max-width: 100%;
    overflow-x: auto;
    padding-bottom: 0.5rem;
    -webkit-overflow-scrolling: touch;
}

.production-workflow-table {
    min-width: 1300px;
    table-layout: fixed;
}

.production-workflow-table th:nth-child(1),
.production-workflow-table td:nth-child(1) { width: 115px; }
.production-workflow-table th:nth-child(2),
.production-workflow-table td:nth-child(2) { width: 240px; }
.production-workflow-table th:nth-child(3),
.production-workflow-table td:nth-child(3) { width: 210px; }
.production-workflow-table th:nth-child(4),
.production-workflow-table td:nth-child(4) { width: 285px; }
.production-workflow-table th:nth-child(5),
.production-workflow-table td:nth-child(5) { width: 330px; }
.production-workflow-table th:nth-child(6),
.production-workflow-table td:nth-child(6) { width: 120px; }

.production-workflow-table td {
    vertical-align: top;
}

.production-workflow-table tr.is-muted-row {
    opacity: 0.68;
}

.production-readiness-stack {
    display: grid;
    gap: 0.65rem;
}

.production-section-label {
    display: block;
    margin-bottom: 0.25rem;
    color: var(--gold);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.admin-mini-metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-top: 0.45rem;
    color: var(--muted);
    font-size: 0.88rem;
}

.admin-mini-metrics span {
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 0.12rem 0.45rem;
    background: rgba(255,255,255,0.55);
}

.production-day-form {
    display: grid;
    gap: 0.55rem;
}

.production-day-form label {
    display: grid;
    gap: 0.2rem;
    font-size: 0.85rem;
    color: var(--muted-strong);
}

.production-day-form input,
.production-day-form select {
    width: 100%;
    min-width: 0;
}

.production-day-control-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.admin-action-list {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.admin-action-list .button {
    justify-content: center;
    width: 100%;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.admin-badge.is-muted {
    color: var(--muted-strong);
    opacity: 0.78;
}

.admin-compact-list {
    margin: 0;
    padding-left: 1.1rem;
}

.admin-compact-list li + li {
    margin-top: 0.25rem;
}

.production-blockers {
    color: var(--muted-strong);
    font-size: 0.88rem;
}

/* Milestone 33: kitchens/location assignment */
.admin-detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin: 0;
}

.admin-detail-grid div {
    border: 1px solid var(--line);
    border-radius: 1rem;
    padding: 1rem;
    background: rgba(255, 255, 255, 0.62);
}

.admin-detail-grid dt {
    color: var(--gold);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.admin-detail-grid dd {
    margin: 0.35rem 0 0;
    color: var(--ink);
}

/* Milestone 35: supplier price history */
.supplier-price-form {
  align-items: end;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

.supplier-price-form label {
  display: grid;
  gap: 0.35rem;
  min-width: 10rem;
  color: var(--cocoa);
  font-weight: 800;
}

.supplier-price-form .form-wide {
  min-width: 18rem;
  flex: 1 1 18rem;
}

/* Milestone 36: label compliance foundation */
.nutrition-facts-card {
  overflow: hidden;
}

.nutrition-facts-card .nutrition-facts-table {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
}

.nutrition-facts-card .nutrition-facts-table td:first-child {
  font-weight: 800;
}

.nutrition-facts-card .nutrition-facts-table td:last-child {
  width: 5.75rem;
  text-align: right;
  white-space: nowrap;
}

.admin-action-list.compact {
  gap: 0.35rem;
}

.admin-action-list.compact .button {
  min-height: 2.15rem;
  padding-top: 0.45rem;
  padding-bottom: 0.45rem;
  font-size: 0.8rem;
}

/* Milestone 37: Customer-facing menu history */
.menu-reveal-section .form-card {
  min-width: 0;
}

.menu-reveal-stack,
.customer-menu-history,
.customer-menu-timeline {
  display: grid;
  gap: 0.85rem;
}

.customer-menu-history {
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
}

.menu-reveal-card,
.customer-menu-timeline-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  border: 1px solid var(--line);
  border-radius: 1.2rem;
  background: rgba(255, 255, 255, 0.62);
  padding: 1rem;
}

.menu-reveal-card h3,
.customer-menu-timeline-row h3 {
  margin: 0.15rem 0 0.35rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.35rem, 2.4vw, 2rem);
  line-height: 1.05;
}

.menu-reveal-card p,
.customer-menu-timeline-row p {
  margin: 0.25rem 0;
  color: var(--cocoa);
}

.menu-reveal-meta {
  display: flex;
  flex: 0 0 auto;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.4rem;
  min-width: 7rem;
  color: var(--cocoa);
  font-size: 0.82rem;
  text-align: right;
}

.menu-reveal-meta span,
.menu-reveal-meta a {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  padding: 0.32rem 0.58rem;
  font-weight: 800;
}

.menu-reveal-meta a {
  color: var(--gold);
}

.customer-menu-timeline-row.is-hidden-menu {
  background: rgba(255, 255, 255, 0.42);
}

.customer-menu-timeline-row.is-hidden-menu h3,
.customer-menu-timeline-row.is-hidden-menu p {
  color: rgba(37, 31, 26, 0.62);
}

@media (max-width: 720px) {
  .menu-reveal-card,
  .customer-menu-timeline-row {
    display: grid;
  }

  .menu-reveal-meta {
    align-items: flex-start;
    min-width: 0;
    text-align: left;
  }
}

/* Milestone 38: Ops dashboard v2 */
.ops-stat-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ops-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

.ops-card {
  min-width: 0;
}

.ops-wide-card {
  margin-top: 1rem;
}

.ops-action-card {
  grid-row: span 2;
}

.ops-list {
  display: grid;
  gap: 0.75rem;
}

.ops-list.compact {
  gap: 0.55rem;
}

.ops-list-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.85rem;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.55);
  padding: 0.8rem;
}

.ops-list-row.compact {
  align-items: center;
  padding: 0.65rem;
}

.ops-list-row p {
  margin: 0.25rem 0;
  color: var(--cocoa);
  font-size: 0.88rem;
}

.ops-list-row .button {
  flex: 0 0 auto;
}

.ops-metric-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.85rem;
}

.ops-metric-strip span {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  color: var(--cocoa);
  padding: 0.36rem 0.62rem;
  font-size: 0.82rem;
}

.ops-metric-strip strong {
  color: var(--ink);
}

.ops-mini-table-wrap {
  overflow-x: auto;
}

.ops-mini-table {
  min-width: 38rem;
}

.ops-readiness-table {
  min-width: 74rem;
}

.admin-badge.is-danger {
  border-color: rgba(150, 54, 44, 0.3);
  background: rgba(150, 54, 44, 0.09);
  color: #7a2f26;
}

.admin-badge.is-warning {
  border-color: rgba(185, 142, 72, 0.35);
  background: rgba(185, 142, 72, 0.12);
  color: #7a5220;
}

.admin-badge.is-good {
  border-color: rgba(71, 128, 75, 0.3);
  background: rgba(71, 128, 75, 0.1);
  color: #2f6f3e;
}

@media (max-width: 980px) {
  .ops-stat-grid,
  .ops-dashboard-grid {
    grid-template-columns: 1fr;
  }

  .ops-action-card {
    grid-row: auto;
  }
}

/* Milestone 39: Stabilization QA */
.qa-stat-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.qa-stat-grid article {
  min-width: 0;
  overflow: hidden;
}

.qa-stat-grid article:nth-child(n + 3) strong {
  max-width: 100%;
  font-size: clamp(1rem, 1.45vw, 1.45rem);
  line-height: 1.14;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.qa-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.qa-summary-item {
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.56);
  padding: 0.75rem;
  min-width: 0;
}

.qa-summary-item span {
  display: block;
  color: var(--muted);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.qa-summary-item strong {
  display: block;
  margin-top: 0.28rem;
  overflow-wrap: anywhere;
}

.qa-check-table {
  min-width: 56rem;
}

.qa-wide-card {
  margin-top: 1rem;
}

.qa-module-table {
  min-width: 46rem;
}

.qa-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

.qa-small-table-wrap {
  max-height: 28rem;
  overflow: auto;
}

.qa-small-table {
  min-width: 40rem;
}

@media (max-width: 980px) {
  .qa-stat-grid,
  .qa-summary-grid,
  .qa-dashboard-grid {
    grid-template-columns: 1fr;
  }
}

/* Milestone 40: public/admin UI overflow cleanup */
.contact-card,
.form-card,
.info-card,
.notice-panel,
.ritual-card,
.admin-card,
.admin-stat-grid article,
.qa-summary-item,
.ops-card,
.ops-wide-card,
.ops-action-card,
.menu-reveal-card {
  min-width: 0;
}

.contact-card {
  overflow: hidden;
}

.contact-email {
  max-width: 100%;
  font-size: clamp(1.9rem, 3.2vw, 2.65rem);
  line-height: 1.04;
  letter-spacing: -0.045em;
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.footer-contact,
.admin-card code,
.admin-card pre,
.admin-muted,
.admin-table small,
.info-card h2,
.info-card h3,
.form-card h2,
.contact-card h2,
.notice-panel h2,
.menu-reveal-card h3 {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.button,
.admin-card .button,
.form-card .button,
.contact-card .button {
  min-width: 0;
  white-space: normal;
  text-align: center;
}

.admin-table-wrap,
.production-workflow-wrap,
.ops-table-wrap {
  max-width: 100%;
  -webkit-overflow-scrolling: touch;
}

.admin-table td,
.admin-table th {
  overflow-wrap: anywhere;
}

.admin-table td .button,
.admin-table td select,
.admin-table td input,
.admin-table td textarea {
  max-width: 100%;
}

@media (max-width: 980px) {
  .contact-email {
    font-size: clamp(1.75rem, 5.8vw, 2.4rem);
  }
}

@media (max-width: 640px) {
  .contact-card,
  .form-card {
    padding-inline: 1rem;
  }

  .contact-email {
    font-size: clamp(1.35rem, 7vw, 1.9rem);
  }
}

/* M41 lifecycle/archive controls */
.admin-table .compact-actions,
.admin-action-list.compact,
.compact-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-top: 0;
}

.compact-actions form,
.admin-action-list.compact form {
  margin: 0;
}

.button-ghost {
  border-color: rgba(37, 31, 26, 0.18);
  background: transparent;
  color: var(--muted);
}

.button-ghost:hover {
  border-color: rgba(37, 31, 26, 0.34);
  color: var(--ink);
}


/* M41.1: archive rollout regression layout fixes */
.admin-table th {
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: normal;
}

.admin-inline-form {
  flex-wrap: nowrap;
}

.admin-inline-form button {
  white-space: nowrap;
}

.office-requests-table {
  min-width: 96rem;
}

.office-requests-table th,
.office-requests-table td {
  overflow-wrap: normal;
  word-break: normal;
}

.office-requests-table td:nth-child(4),
.office-requests-table td:nth-child(5),
.office-requests-table td:nth-child(6),
.office-requests-table td:nth-child(9),
.office-requests-table td:nth-child(10) {
  overflow-wrap: anywhere;
}

.office-requests-table td:last-child {
  min-width: 13rem;
}

.office-requests-table .admin-inline-form select {
  min-width: 7rem;
}

.diagnostics-summary-grid article:nth-child(11) strong {
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: normal;
}

/* M42: recipe tree + recipe item editing */
.recipe-tree-index-table {
  min-width: 62rem;
}

.recipe-item-edit-card {
  max-width: 78rem;
}

.recipe-tree-wrap {
  overflow: hidden;
}

.recipe-tree-canvas {
  max-width: 100%;
  overflow-x: auto;
  padding-bottom: 0.5rem;
  -webkit-overflow-scrolling: touch;
}

.recipe-tree-node {
  min-width: 58rem;
  margin-left: calc(var(--recipe-tree-depth, 0) * 1.25rem);
}

.recipe-tree-node.depth-0 { --recipe-tree-depth: 0; }
.recipe-tree-node.depth-1 { --recipe-tree-depth: 1; }
.recipe-tree-node.depth-2 { --recipe-tree-depth: 2; }
.recipe-tree-node.depth-3 { --recipe-tree-depth: 3; }
.recipe-tree-node.depth-4 { --recipe-tree-depth: 4; }
.recipe-tree-node.depth-5 { --recipe-tree-depth: 5; }
.recipe-tree-node.depth-6 { --recipe-tree-depth: 6; }

.recipe-tree-card {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: center;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 0.85rem;
  background: rgba(255, 255, 255, 0.74);
  padding: 0.48rem 0.75rem;
  box-shadow: 0 8px 20px rgba(37, 31, 26, 0.035);
}

.recipe-tree-recipe-card {
  margin-top: 0.45rem;
  background: rgba(37, 31, 26, 0.035);
}

.recipe-tree-item-card {
  margin-top: 0.32rem;
}

.recipe-tree-card h3,
.recipe-tree-card h4,
.recipe-tree-card p {
  margin: 0;
}

.recipe-tree-card h3 {
  font-size: clamp(1.25rem, 1.6vw, 1.55rem);
  line-height: 1.05;
}

.recipe-tree-card h4 {
  font-size: 0.98rem;
  line-height: 1.18;
}

.recipe-tree-card p {
  line-height: 1.25;
}

.recipe-tree-card .button-small {
  padding: 0.38rem 0.72rem;
  min-height: auto;
  white-space: nowrap;
}

.recipe-tree-card small {
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  font-size: 0.72rem;
  color: var(--cocoa);
}

.recipe-tree-kicker {
  display: inline-block;
  margin-bottom: 0.1rem;
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 700;
}

.recipe-tree-branch {
  position: relative;
  margin-left: 1rem;
  padding-left: 1rem;
  border-left: 1px solid rgba(37, 31, 26, 0.16);
}

.recipe-tree-branch::before {
  content: '';
  position: absolute;
  top: 1rem;
  left: 0;
  width: 0.8rem;
  border-top: 1px solid rgba(37, 31, 26, 0.16);
}

.recipe-tree-branch.is-ingredient .recipe-tree-item-card {
  background: rgba(255, 255, 255, 0.92);
}

.recipe-tree-leaf,
.recipe-tree-warning {
  margin: 0.35rem 0 0 1rem;
  padding: 0.45rem 0.7rem;
  border-radius: 0.75rem;
  background: rgba(255, 255, 255, 0.65);
  border: 1px dashed rgba(37, 31, 26, 0.18);
  color: var(--cocoa);
}

.recipe-tree-warning {
  color: #7a4a12;
  background: rgba(176, 111, 17, 0.08);
}

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

  .recipe-tree-canvas {
    padding-bottom: 1rem;
  }
}

/* Milestone 43.1: static grouped admin navigation */
.admin-nav-section {
  min-width: 0;
  border: 1px solid transparent;
  border-radius: 1rem;
}

.admin-nav-section[open] {
  border-color: rgba(40, 31, 26, 0.08);
  background: rgba(255, 255, 255, 0.34);
}

.admin-nav-section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
  cursor: pointer;
  border-radius: 999px;
  color: var(--gold);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  line-height: 1.15;
  list-style: none;
  padding: 0.48rem 0.72rem;
  text-transform: uppercase;
  user-select: none;
}

.admin-nav-section-title::-webkit-details-marker {
  display: none;
}

.admin-nav-section-title span:last-child {
  color: var(--cocoa);
  font-size: 0.7rem;
  opacity: 0.62;
  transform: rotate(-90deg);
  transition: transform 0.15s ease;
}

.admin-nav-section[open] .admin-nav-section-title span:last-child {
  transform: rotate(0deg);
}

.admin-nav-section.is-active .admin-nav-section-title {
  color: var(--ink);
}

.admin-nav-section-links {
  display: grid;
  gap: 0.12rem;
  padding: 0 0.35rem 0.35rem;
}

.admin-nav-section-links .admin-nav-link {
  padding-left: 0.72rem;
  padding-right: 0.72rem;
}

@media (max-width: 980px) {
  .admin-nav-section {
    min-width: 0;
  }

  .admin-nav-section-links {
    grid-template-columns: repeat(auto-fit, minmax(7rem, 1fr));
  }
}

.permissions-matrix-wrap {
  max-width: 100%;
}

.permissions-matrix-table {
  min-width: 74rem;
}

.permissions-matrix-table code {
  white-space: nowrap;
  font-size: 0.78rem;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.8rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0.24rem 0.55rem;
  font-size: 0.76rem;
  font-weight: 800;
  color: var(--cocoa);
  background: rgba(255,255,255,0.52);
}

.status-pill-ok {
  color: var(--ink);
  border-color: rgba(185, 142, 72, 0.35);
  background: rgba(185, 142, 72, 0.12);
}

.admin-list {
  margin: 0.6rem 0 0;
  padding-left: 1.2rem;
  color: var(--cocoa);
}

.admin-list li + li {
  margin-top: 0.45rem;
}

/* M45: immediate admin cleanup */
.office-request-list {
  display: grid;
  gap: 1rem;
  margin-top: 1.25rem;
  min-width: 0;
}

.office-request-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(14rem, 18rem);
  gap: 1rem;
  padding: 1rem;
  border: 1px solid rgba(37, 31, 26, 0.11);
  border-radius: 1.25rem;
  background: rgba(255, 255, 255, 0.62);
  min-width: 0;
}

.office-request-main,
.office-request-update {
  min-width: 0;
}

.office-request-title-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  min-width: 0;
}

.office-request-title-row h2 {
  margin: 0.1rem 0 0.2rem;
  font-size: clamp(1.6rem, 3vw, 2.35rem);
  line-height: 0.95;
  overflow-wrap: anywhere;
}

.office-request-badges,
.office-request-update-form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  align-items: center;
}

.office-request-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.8rem;
  margin: 0.95rem 0 0;
}

.office-request-meta-grid div,
.office-request-message {
  min-width: 0;
}

.office-request-meta-grid dt,
.office-request-update h3,
.office-request-message strong {
  margin: 0 0 0.22rem;
  color: var(--accent);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.office-request-meta-grid dd {
  margin: 0;
  overflow-wrap: anywhere;
}

.office-request-message {
  margin-top: 0.95rem;
  padding-top: 0.8rem;
  border-top: 1px solid rgba(37, 31, 26, 0.10);
}

.office-request-message p {
  margin: 0.25rem 0 0;
  overflow-wrap: anywhere;
}

.office-request-update {
  align-self: stretch;
  padding: 0.85rem;
  border: 1px solid rgba(37, 31, 26, 0.10);
  border-radius: 1rem;
  background: rgba(250, 247, 241, 0.72);
}

.office-request-update h3 {
  color: var(--ink);
}

.office-request-update-form {
  flex-direction: column;
  align-items: stretch;
}

.office-request-update-form label,
.office-request-update-form select,
.office-request-update-form button {
  width: 100%;
}

@media (max-width: 1100px) {
  .office-request-card {
    grid-template-columns: 1fr;
  }

  .office-request-meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* M46 MFA / auth policy UI */
.admin-auth-wide {
    max-width: 58rem;
}
.mfa-setup-grid {
    grid-template-columns: minmax(15rem, 20rem) minmax(16rem, 1fr);
    margin-bottom: 1.25rem;
}
.mfa-qr-card svg,
.mfa-qr svg {
    max-width: 100%;
    height: auto;
    background: #fff;
    border-radius: 1rem;
}
.mfa-secret {
    font-size: clamp(1.1rem, 2vw, 1.65rem) !important;
    overflow-wrap: anywhere;
    word-break: break-word;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}
.mfa-recovery-warning {
    margin-bottom: 1rem;
}

.recovery-code-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
    gap: 0.75rem;
    margin: 1rem 0 1.5rem;
}
.recovery-code-grid code {
    display: block;
    padding: 0.85rem 1rem;
    border: 1px solid var(--border, rgba(35, 28, 23, 0.12));
    border-radius: 1rem;
    background: rgba(255,255,255,0.65);
    font-size: 1rem;
    text-align: center;
}
.auth-policy-table .small-input,
.small-input {
    width: 5.5rem;
}
.mfa-effective-policy {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.75rem;
}
@media (max-width: 900px) {
    .mfa-setup-grid {
        grid-template-columns: 1fr;
    }
}

/* M47 protected permissions editor */
.permissions-editor-card {
  overflow: hidden;
}
.permissions-editor-wrap {
  max-width: 100%;
  overflow-x: auto;
}
.permissions-editor-table {
  min-width: 1180px;
}
.permissions-editor-table th,
.permissions-editor-table td {
  vertical-align: top;
}
.permissions-editor-table th small {
  display: block;
  margin-top: 0.15rem;
  color: var(--muted);
  letter-spacing: 0.06em;
  text-transform: none;
}
.permission-cell {
  text-align: center;
  white-space: nowrap;
}
.toggle-compact {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-width: 4.8rem;
  padding: 0.28rem 0.45rem;
  border: 1px solid rgba(37, 31, 26, 0.10);
  border-radius: 999px;
  background: rgba(255,255,255,0.56);
  font-size: 0.78rem;
  font-weight: 700;
  cursor: pointer;
}
.toggle-compact input {
  width: auto;
  margin: 0;
}

/* Milestone 48 — public cookie notice */
.cookie-notice,
.cookie-settings-button {
  position: fixed;
  z-index: 80;
}

.cookie-notice[hidden],
.cookie-settings-button[hidden],
.cookie-notice-preferences[hidden],
.cookie-notice-actions [hidden] {
  display: none !important;
}

.cookie-notice {
  right: clamp(1rem, 3vw, 2rem);
  bottom: clamp(1rem, 3vw, 2rem);
  left: clamp(1rem, 3vw, 2rem);
  display: flex;
  justify-content: flex-end;
  pointer-events: none;
}

.cookie-notice-card {
  width: min(46rem, 100%);
  border: 1px solid rgba(37, 31, 26, 0.14);
  border-radius: 1.6rem;
  background: rgba(255, 252, 247, 0.96);
  box-shadow: 0 24px 80px rgba(37, 31, 26, 0.18);
  padding: clamp(1rem, 2vw, 1.35rem);
  pointer-events: auto;
  backdrop-filter: blur(18px);
}

.cookie-notice-copy {
  min-width: 0;
}

.cookie-notice-copy .eyebrow {
  margin-bottom: 0.45rem;
}

.cookie-notice-copy h2 {
  margin-bottom: 0.55rem;
  font-size: clamp(1.45rem, 3vw, 2rem);
  letter-spacing: -0.025em;
}

.cookie-notice-copy p {
  margin-bottom: 0.55rem;
  font-size: 0.94rem;
  line-height: 1.55;
}

.cookie-notice-meta,
.cookie-notice-meta a {
  font-size: 0.86rem;
}

.cookie-notice-meta a {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}

.cookie-notice-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.9rem;
}

.cookie-notice-preferences {
  display: grid;
  gap: 0.65rem;
  margin-top: 0.85rem;
}

.cookie-pref-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.7rem;
  align-items: start;
  border: 1px solid rgba(37, 31, 26, 0.1);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.54);
  padding: 0.75rem;
}

.cookie-pref-row input {
  margin-top: 0.25rem;
}

.cookie-pref-row strong,
.cookie-pref-row small {
  display: block;
}

.cookie-pref-row small {
  margin-top: 0.25rem;
  color: var(--cocoa);
  line-height: 1.45;
}

.cookie-settings-button {
  right: clamp(1rem, 2vw, 1.5rem);
  bottom: clamp(1rem, 2vw, 1.5rem);
  border: 1px solid rgba(37, 31, 26, 0.12);
  border-radius: 999px;
  background: rgba(255, 252, 247, 0.9);
  box-shadow: 0 12px 42px rgba(37, 31, 26, 0.12);
  color: var(--ink);
  cursor: pointer;
  font-size: 0.78rem;
  font-weight: 700;
  padding: 0.55rem 0.85rem;
  backdrop-filter: blur(14px);
}

@media (max-width: 640px) {
  .cookie-notice {
    right: 0.75rem;
    bottom: 0.75rem;
    left: 0.75rem;
  }

  .cookie-notice-actions .button {
    width: 100%;
  }

  .cookie-settings-button {
    right: 0.75rem;
    bottom: 0.75rem;
  }
}

.data-policy-grid {
  align-items: start;
}

.admin-check-list {
  display: grid;
  gap: 0.65rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.admin-check-list li {
  display: grid;
  gap: 0.25rem;
  border: 1px solid rgba(37, 31, 26, 0.08);
  border-radius: 0.95rem;
  background: rgba(255, 255, 255, 0.58);
  padding: 0.75rem 0.85rem;
  min-width: 0;
}

.admin-check-list li strong {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.admin-check-list li span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.data-policy-table code {
  white-space: normal;
  overflow-wrap: anywhere;
}

.data-policy-table th,
.data-policy-table td {
  vertical-align: top;
}

/* M53 delivery operations v2 */
.delivery-preview-table {
    min-width: 42rem;
}

.delivery-run-stops-table {
    min-width: 76rem;
}

.delivery-stop-form {
    display: grid;
    grid-template-columns: 4.5rem minmax(12rem, 1.2fr) minmax(14rem, 1.2fr) 6rem minmax(18rem, 1.7fr) minmax(12rem, 1fr) 5.5rem;
    gap: 0.75rem;
    align-items: start;
}

.delivery-stop-form label {
    display: grid;
    gap: 0.25rem;
    margin: 0;
}

.delivery-stop-form input,
.delivery-stop-form select {
    width: 100%;
    min-width: 0;
}

.delivery-stop-status-fields {
    display: grid;
    gap: 0.4rem;
}

.route-sheet-table {
    min-width: 70rem;
}

.route-sheet-table td,
.route-sheet-table th {
    vertical-align: top;
}

@media print {
    .admin-sidebar,
    .admin-topbar,
    .no-print,
    .admin-page-header .hero-actions {
        display: none !important;
    }

    .admin-shell,
    .admin-main {
        display: block !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .admin-card {
        box-shadow: none !important;
        border: 1px solid #ddd !important;
        page-break-inside: avoid;
    }

    .route-sheet-table {
        min-width: 0;
        width: 100%;
        font-size: 11px;
    }
}

.admin-long-cell {
  max-width: 28rem;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.qr-preview {
  width: min(18rem, 100%);
  height: auto;
  border-radius: 1rem;
  border: 1px solid var(--line);
  background: #fff;
  padding: 1rem;
}

.qa-events-header {
    align-items: flex-start;
}

.qa-ack-form {
    display: grid;
    grid-template-columns: minmax(16rem, 1fr) auto;
    gap: 0.75rem;
    align-items: end;
    margin: 0 0 1rem;
    padding: 0.85rem;
    border: 1px solid var(--line);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.72);
}

.qa-ack-form label {
    display: grid;
    gap: 0.35rem;
    margin: 0;
    min-width: 0;
}

.qa-ack-form input {
    width: 100%;
    min-width: 0;
}

.qa-events-table td,
.qa-events-table th {
    vertical-align: top;
}

@media (max-width: 760px) {
    .qa-ack-form {
        grid-template-columns: 1fr;
    }
}

.field-help {
    display: block;
    margin-top: 0.35rem;
    color: var(--muted);
    font-size: 0.88rem;
    line-height: 1.45;
}

.warning-alert {
    border: 1px solid rgba(176, 108, 20, 0.3);
    background: rgba(255, 248, 235, 0.82);
    color: var(--ink);
}

.office-drop-cycle-warning {
    margin: 0 0 1rem;
}

.office-drop-cycle-warning ul {
    margin: 0.75rem 0;
    padding-left: 1.2rem;
}

.office-drop-cycle-warning .admin-inline-form,
.office-drop-cycle-close-actions {
    margin-top: 0.7rem;
}

/* Utility: standalone forms triggered by external form-associated buttons. */
.admin-hidden-form { display: none !important; }

/* M56.3: Admin documentation foundation + contextual F1 help. */
.docs-stat-grid {
  margin-bottom: 1rem;
}

.docs-toolbar-card {
  margin-bottom: 1rem;
}

.docs-schema-group {
  margin-top: 1rem;
}

.docs-table-grid,
.docs-help-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.docs-help-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.docs-table-card,
.docs-help-grid article,
.docs-preview-block {
  border: 1px solid var(--line);
  border-radius: 1.25rem;
  background: rgba(255, 255, 255, 0.5);
  padding: 1rem;
}

.docs-table-card header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.8rem;
}

.docs-table-card h3,
.docs-help-grid h3,
.docs-preview-block h3 {
  margin-bottom: 0.35rem;
  font-size: 1.25rem;
}

.docs-key-row {
  margin-bottom: 0.75rem;
}

.docs-columns-table {
  min-width: 46rem;
  font-size: 0.84rem;
}

.docs-preview-block + .docs-preview-block {
  margin-top: 0.75rem;
}

.admin-help-fab {
  position: fixed;
  right: 1.25rem;
  bottom: 1.25rem;
  z-index: 70;
  border: 1px solid rgba(37, 31, 26, 0.18);
  border-radius: 999px;
  background: var(--ink);
  color: #fff;
  box-shadow: var(--shadow);
  cursor: pointer;
  font-weight: 900;
  letter-spacing: 0.02em;
  padding: 0.85rem 1.05rem;
}

.admin-help-drawer {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: flex;
  justify-content: flex-end;
  background: rgba(37, 31, 26, 0.2);
}

.admin-help-drawer[hidden] {
  display: none;
}

.admin-help-drawer-panel {
  width: min(100%, 32rem);
  height: 100%;
  overflow-y: auto;
  border-left: 1px solid var(--line);
  background: #fbf7f0;
  box-shadow: -24px 0 80px rgba(37, 31, 26, 0.16);
  padding: 1.25rem;
}

.admin-help-drawer-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.admin-help-drawer-header h2 {
  margin-bottom: 0.25rem;
  font-size: clamp(1.9rem, 4vw, 3rem);
}

.admin-help-close {
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  cursor: pointer;
  font-size: 1.35rem;
  line-height: 1;
}

.admin-help-language {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.admin-help-language button {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--cocoa);
  cursor: pointer;
  font-weight: 900;
  padding: 0.45rem 0.75rem;
}

.admin-help-language button.is-active {
  background: var(--ink);
  color: #fff;
}

.admin-help-content section,
.admin-help-highlight {
  border-top: 1px solid var(--line);
  padding-top: 1rem;
  margin-top: 1rem;
}

.admin-help-content h3 {
  margin-bottom: 0.45rem;
  font-size: 1.3rem;
}

.admin-help-highlight {
  border: 1px solid rgba(185, 142, 72, 0.35);
  border-radius: 1.25rem;
  background: rgba(185, 142, 72, 0.1);
  padding: 1rem;
}

.admin-help-anchor-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.admin-help-anchor-list span {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  font-size: 0.8rem;
  font-weight: 800;
  padding: 0.3rem 0.55rem;
}

@media (max-width: 980px) {
  .docs-table-grid,
  .docs-help-grid {
    grid-template-columns: 1fr;
  }

  .admin-help-fab {
    right: 0.8rem;
    bottom: 0.8rem;
  }
}

/* M63.1: Context help editor form layout polish */
.admin-form-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem 1rem;
  align-items: start;
}

.admin-form-grid label {
  display: grid;
  gap: 0.35rem;
  min-width: 0;
  color: var(--cocoa);
  font-size: 0.88rem;
  font-weight: 800;
}

.admin-form-grid input,
.admin-form-grid select,
.admin-form-grid textarea {
  width: 100%;
  min-width: 0;
  min-height: 2.55rem;
  border: 1px solid var(--line);
  border-radius: 0.8rem;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  padding: 0.55rem 0.7rem;
  font: inherit;
}

.admin-form-grid textarea {
  min-height: 7rem;
  resize: vertical;
}

.admin-form-grid .form-wide,
.admin-form-grid .form-actions {
  grid-column: 1 / -1;
}

.admin-form-grid .form-span-2 {
  grid-column: span 2;
}

.admin-form-grid .form-span-3 {
  grid-column: span 3;
}

.admin-help-editor-grid {
  margin-top: 0.5rem;
}

.admin-help-editor-grid .form-actions {
  padding-top: 0.2rem;
}

.admin-help-editor-grid .button {
  justify-self: start;
}

@media (max-width: 1180px) {
  .admin-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .admin-form-grid,
  .admin-form-grid .form-span-2,
  .admin-form-grid .form-span-3 {
    grid-template-columns: 1fr;
    grid-column: 1 / -1;
  }
}


/* M65: Database schema metadata, row counts and description dialogs. */
.docs-card-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.45rem;
}

.button-small {
  padding: 0.45rem 0.7rem;
  min-height: auto;
  font-size: 0.82rem;
}

.docs-table-title {
  margin-top: 0.25rem;
}

.docs-meta-row {
  gap: 0.35rem;
}

.admin-warning {
  margin: 0.75rem 0;
  color: #7a3f00;
  background: rgba(184, 117, 28, 0.11);
  border: 1px solid rgba(184, 117, 28, 0.22);
  border-radius: 0.9rem;
  padding: 0.65rem 0.75rem;
}

.schema-description-dialog {
  width: min(54rem, calc(100vw - 2rem));
  max-width: min(54rem, calc(100vw - 2rem));
  border: 1px solid rgba(37, 31, 26, 0.16);
  border-radius: 1.5rem;
  padding: 1.4rem;
  background: #fffaf3;
  color: var(--ink);
  box-shadow: 0 32px 110px rgba(37, 31, 26, 0.28);
  opacity: 1;
}

.schema-description-dialog[open] {
  display: block;
}

.schema-description-dialog::backdrop {
  background: rgba(37, 31, 26, 0.58);
  backdrop-filter: blur(3px);
}

.schema-dialog-close-form {
  float: right;
  margin-left: 1rem;
}

.schema-description-list {
  display: grid;
  grid-template-columns: 13rem minmax(0, 1fr);
  gap: 0.65rem 1rem;
  margin-top: 1rem;
}

.schema-description-list dt {
  font-weight: 700;
  color: var(--muted);
}

.schema-description-list dd {
  margin: 0;
  word-break: break-word;
}

@media (max-width: 760px) {
  .schema-description-list {
    grid-template-columns: 1fr;
  }
}

/* M68: ER diagram explorer. */
.schema-er-controls {
  align-items: end;
}

.schema-er-render-wrap {
  overflow: auto;
  max-height: 72vh;
  border: 1px solid rgba(37, 31, 26, 0.12);
  border-radius: 1.2rem;
  background: #fffaf3;
  padding: 1rem;
}

.schema-er-render {
  min-width: 56rem;
  margin: 0;
  background: transparent;
}

.schema-er-render svg {
  max-width: none;
}

.admin-code-textarea {
  width: 100%;
  min-height: 24rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 0.85rem;
  line-height: 1.45;
  border: 1px solid rgba(37, 31, 26, 0.16);
  border-radius: 1rem;
  padding: 1rem;
  background: #fffaf3;
  color: var(--ink);
}

/* M69.1: keep compact schema-description action buttons readable inside narrow table cells. */
.schema-description-action {
  white-space: nowrap;
  width: 1%;
}
.schema-description-action .button {
  white-space: nowrap;
  min-width: 4.25rem;
}

/* M71: interactive ER SVG viewer. */
.schema-er-viewer-card:fullscreen {
  overflow: auto;
  background: var(--surface);
  padding: 1.5rem;
}

.schema-er-viewer-toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0.5rem 0 1rem;
}

.schema-er-zoom-status {
  color: var(--muted);
  font-size: 0.9rem;
  margin-left: 0.25rem;
}

.schema-er-viewer-card .schema-er-render-wrap {
  position: relative;
  overflow: hidden;
  min-height: 34rem;
  height: min(72vh, 52rem);
  cursor: grab;
  touch-action: none;
}

.schema-er-viewer-card:fullscreen .schema-er-render-wrap {
  height: calc(100vh - 12rem);
  max-height: none;
}

.schema-er-viewer-card .schema-er-render-wrap.is-dragging {
  cursor: grabbing;
}

.schema-er-viewer-card .schema-er-render {
  width: 100%;
  height: 100%;
  min-width: 0;
  white-space: normal;
}

.schema-er-svg {
  display: block;
  width: 100%;
  height: 100%;
  max-width: none;
  user-select: none;
}

@media (max-width: 760px) {
  .schema-er-viewer-card .schema-er-render-wrap {
    min-height: 26rem;
    height: 70vh;
  }
}

/* M72/M73: ER graph controls, process presets, filtering and highlights. */
.schema-er-stat-grid {
  grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
}

.schema-er-controls-m72,
.schema-er-controls-m73 {
  grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
}

.schema-er-controls-m72 input[type="search"],
.schema-er-controls-m73 input[type="search"] {
  width: 100%;
  min-width: 0;
}

.schema-er-actions {
  align-self: end;
}

.schema-er-preset-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0.85rem 0 0.35rem;
}

.schema-er-current-preset {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  margin-top: 0.9rem;
  padding: 0.85rem 1rem;
  border: 1px solid rgba(37, 31, 26, 0.12);
  border-radius: 1rem;
  background: rgba(214, 138, 71, 0.08);
}

.schema-er-current-preset span {
  color: var(--muted);
  font-size: 0.92rem;
}

.schema-er-preset-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
  gap: 0.75rem;
  margin: 0.95rem 0 0.45rem;
}

.schema-er-preset-card {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-height: 6.5rem;
  padding: 0.85rem 0.95rem;
  border: 1px solid rgba(37, 31, 26, 0.12);
  border-radius: 1rem;
  background: #fffaf3;
  color: inherit;
  text-decoration: none;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.schema-er-preset-card:hover,
.schema-er-preset-card:focus-visible,
.schema-er-preset-card.is-active {
  border-color: rgba(214, 138, 71, 0.55);
  box-shadow: 0 0.7rem 1.4rem rgba(37, 31, 26, 0.08);
  transform: translateY(-1px);
}

.schema-er-preset-card span {
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.35;
}

.schema-er-table-list tr.schema-er-table-highlight td {
  background: rgba(214, 138, 71, 0.12);
  box-shadow: inset 0 1px 0 rgba(214, 138, 71, 0.18), inset 0 -1px 0 rgba(214, 138, 71, 0.18);
}

.schema-er-table-list td:last-child {
  min-width: 11rem;
}

.schema-er-node-highlight rect,
.schema-er-node-highlight polygon,
.schema-er-node-highlight path {
  stroke: #9f4f18 !important;
  stroke-width: 2.5px !important;
  filter: drop-shadow(0 0 0.35rem rgba(214, 138, 71, 0.55));
}

.schema-er-node-highlight text {
  font-weight: 800 !important;
}

.schema-er-boundary-highlight rect,
.schema-er-boundary-highlight polygon,
.schema-er-boundary-highlight path {
  stroke-dasharray: 6 4;
  stroke-width: 2.25px !important;
}

@media (max-width: 760px) {
  .schema-er-controls-m72,
.schema-er-controls-m73 {
    grid-template-columns: 1fr;
  }
}

/* M74.1: admin documentation UI hotfix.
   Keep compact table badges/action buttons readable and make editor fields normal-weight. */
.admin-table .admin-action-cell,
.admin-table .admin-status-cell,
.admin-table .admin-quality-cell,
.admin-table .schema-description-action {
  width: 1%;
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: normal;
}

.admin-table .admin-action-cell .button,
.admin-table td .button.button-small,
.schema-description-action .button {
  width: auto;
  min-width: max-content;
  max-width: none;
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.admin-badge,
.admin-table td .admin-badge,
.admin-pill-row span {
  max-width: none;
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.admin-form-grid input,
.admin-form-grid select,
.admin-form-grid textarea {
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-weight: 400;
  line-height: 1.45;
}

.admin-form-grid textarea {
  font-size: 0.95rem;
}

.admin-form-grid input::placeholder,
.admin-form-grid textarea::placeholder {
  font-weight: 400;
}

.admin-code-textarea {
  font-weight: 400;
}

/* M82: customer feedback admin review queue. */
.feedback-review-list{display:grid;gap:1rem}.feedback-review-card{border:1px solid rgba(44,34,26,.12);border-radius:1rem;padding:1rem;background:#fffdf8}.feedback-review-card-main{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.feedback-review-card h3{margin:0 0 .25rem}.feedback-review-metrics{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0}.feedback-review-metrics span{border:1px solid rgba(44,34,26,.12);border-radius:999px;padding:.25rem .55rem;background:rgba(250,245,235,.75);white-space:nowrap}.feedback-review-comments{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1rem}.feedback-review-comments p{margin:.35rem 0 0;white-space:pre-wrap}.feedback-review-form{display:grid;grid-template-columns:repeat(4,minmax(9rem,1fr));gap:.75rem;align-items:end}.feedback-review-form label{display:grid;gap:.35rem;font-weight:700}.feedback-review-form select,.feedback-review-form textarea{font:inherit;font-weight:400}.feedback-review-form textarea{min-height:5rem;resize:vertical}.feedback-checkbox-label{grid-template-columns:auto 1fr;align-items:center;align-self:center}.feedback-notes-label{grid-column:1/-2}@media(max-width:900px){.feedback-review-card-main,.feedback-review-comments{grid-template-columns:1fr;display:grid}.feedback-review-form{grid-template-columns:1fr}.feedback-notes-label{grid-column:auto}}
.portal-honeypot{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important}

/* Block 4 cycle calendar and building list polish */
.cycle-calendar-wrap{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-top:1rem}.cycle-calendar-month{border:1px solid var(--admin-border,#e6ded4);border-radius:1rem;padding:1rem;background:rgba(255,255,255,.65)}.cycle-calendar-month h3{margin:0 0 .75rem}.cycle-calendar-weekdays,.cycle-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.35rem}.cycle-calendar-weekdays span{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--admin-muted,#8a7d70);text-align:center}.cycle-calendar-day{display:flex;align-items:center;justify-content:center;min-height:2rem;border-radius:999px;font-size:.85rem;border:1px solid transparent}.cycle-calendar-day.is-outside-month{opacity:.35}.cycle-calendar-day.is-active-date,.cycle-calendar-legend .is-active-date{background:#dceedd;border-color:#b9d7b9}.cycle-calendar-day.is-past,.cycle-calendar-legend .is-past{background:#ece9e4;border-color:#d9d3ca}.cycle-calendar-day.is-excluded,.cycle-calendar-legend .is-excluded{background:#f4dada;border-color:#e8b8b8}.cycle-calendar-legend{display:flex;gap:.5rem;flex-wrap:wrap}.cycle-calendar-legend span{border-radius:999px;padding:.25rem .65rem;font-size:.8rem;border:1px solid var(--admin-border,#e6ded4)}.admin-table .sensitive-note{max-width:22rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-muted-small{font-size:.82rem;color:var(--admin-muted,#8a7d70)}

/* Building entrance editor card layout */
.entrance-card-list {
  display: grid;
  gap: 1rem;
  margin-top: 1rem;
}

.entrance-editor-card {
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.72);
}

.entrance-editor-card .compact-form {
  margin-top: 0.75rem;
}

/* M112: route schedule planning cards */
.route-stop-card-list {
  display: grid;
  gap: 1rem;
}

.route-stop-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.74);
  padding: 1rem;
}

.route-stop-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 0.85rem;
}

.route-stop-card-head h3 {
  margin: 0;
}

.route-stop-grid {
  grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
}

.delivery-stop-form-with-time {
  grid-template-columns: minmax(4rem, .55fr) minmax(11rem, 1.2fr) minmax(12rem, 1.2fr) minmax(12rem, 1.1fr) minmax(6rem, .6fr) minmax(14rem, 1.5fr) minmax(12rem, 1.2fr) minmax(5rem, .5fr);
}

@media (max-width: 1100px) {
  .route-stop-card-head,
  .delivery-stop-form-with-time {
    display: grid;
    grid-template-columns: 1fr;
  }
}

/* M112-1: Route/kitchen UI cleanup after route primary kitchen timing. */
.metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(9.5rem, 1fr));
  gap: 0.75rem;
  margin: 1rem 0;
}

.metric-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 0.6rem 1.4rem rgba(43, 33, 27, 0.06);
  padding: 0.85rem 0.95rem;
}

.metric-card .metric-label,
.metric-card span {
  display: block;
  color: var(--cocoa);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  line-height: 1.2;
  text-transform: uppercase;
}

.metric-card strong {
  display: block;
  min-width: 0;
  margin-top: 0.3rem;
  overflow-wrap: anywhere;
  color: var(--ink);
  font-size: 1rem;
  line-height: 1.28;
}

.route-summary-grid {
  grid-template-columns: repeat(auto-fit, minmax(8.5rem, 1fr));
}

.route-stop-card-list {
  display: grid;
  gap: 1rem;
}

.route-stop-card {
  border: 1px solid var(--line);
  border-radius: 1.15rem;
  background: rgba(255, 255, 255, 0.72);
  padding: 1rem;
}

.route-stop-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.9rem;
}

.route-stop-card-head h3 {
  margin: 0 0 0.2rem;
}

.admin-form-grid .checkbox-label,
.route-stop-active-toggle {
  display: flex;
  grid-template-columns: none;
  align-items: center;
  align-self: end;
  gap: 0.55rem;
  min-height: 2.55rem;
}

.admin-form-grid .checkbox-label input[type="checkbox"],
.route-stop-active-toggle input[type="checkbox"] {
  width: 1rem;
  min-width: 1rem;
  max-width: 1rem;
  height: 1rem;
  min-height: 1rem;
  margin: 0;
  padding: 0;
  flex: 0 0 1rem;
  accent-color: var(--gold);
}

.admin-form-grid .checkbox-label span,
.route-stop-active-toggle span {
  line-height: 1.2;
}

.kitchen-route-assignment-list {
  display: grid;
  gap: 0.9rem;
}

.kitchen-route-assignment-card {
  border: 1px solid var(--line);
  border-radius: 1.15rem;
  background: rgba(255, 255, 255, 0.72);
  padding: 1rem;
}

.kitchen-route-assignment-title {
  display: grid;
  gap: 0.25rem;
}

.kitchen-route-assignment-title strong {
  color: var(--ink);
  font-size: 1rem;
}

.kitchen-route-assignment-title small {
  color: var(--cocoa);
  line-height: 1.35;
}

.kitchen-route-assignment-form {
  grid-template-columns: minmax(8rem, 0.9fr) minmax(7rem, 0.55fr) minmax(14rem, 1.4fr) minmax(12rem, 1fr) auto;
  align-items: end;
}

.kitchen-route-assignment-form .form-wide,
.kitchen-route-assign-form .form-wide {
  grid-column: 1 / -1;
}

.kitchen-route-assignment-form .form-span-2 {
  grid-column: span 1;
}

.kitchen-route-assignment-form .form-actions,
.kitchen-route-assign-form .form-actions {
  align-self: end;
}

.kitchen-route-assignment-form .button,
.kitchen-route-assign-form .button {
  min-height: 2.55rem;
  white-space: nowrap;
}

.kitchen-route-assign-form {
  grid-template-columns: minmax(14rem, 1.6fr) minmax(8rem, 0.8fr) minmax(7rem, 0.6fr) minmax(14rem, 1.2fr) auto;
  align-items: end;
}

@media (max-width: 1180px) {
  .kitchen-route-assignment-form,
  .kitchen-route-assign-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kitchen-route-assignment-form .form-actions,
  .kitchen-route-assign-form .form-actions {
    grid-column: 1 / -1;
  }
}

@media (max-width: 720px) {
  .route-stop-card-head {
    display: grid;
  }

  .kitchen-route-assignment-form,
  .kitchen-route-assign-form {
    grid-template-columns: 1fr;
  }
}

/* M113: kitchen-rooted operational hierarchy */
.hierarchy-filter-bar {
  align-items: end;
}

.hierarchy-summary-grid {
  grid-template-columns: repeat(auto-fit, minmax(8.5rem, 1fr));
}

.hierarchy-note-card {
  border-style: dashed;
}

.hierarchy-card {
  overflow: hidden;
}

.hierarchy-canvas {
  max-width: 100%;
  overflow-x: auto;
  padding: 0.25rem 0 0.75rem;
  -webkit-overflow-scrolling: touch;
}

.hierarchy-node {
  min-width: 64rem;
  margin-top: 0.55rem;
}

.hierarchy-node summary {
  cursor: pointer;
  list-style: none;
}

.hierarchy-node summary::-webkit-details-marker {
  display: none;
}

.hierarchy-node-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 0.9rem;
  background: rgba(255, 255, 255, 0.82);
  padding: 0.55rem 0.75rem;
  box-shadow: 0 8px 20px rgba(37, 31, 26, 0.035);
}

.hierarchy-node-card-root {
  background: rgba(37, 31, 26, 0.045);
}

.hierarchy-node-card-muted {
  background: rgba(255, 255, 255, 0.62);
}

.hierarchy-node-card-leaf {
  background: rgba(255, 255, 255, 0.92);
}

.hierarchy-node-main {
  display: grid;
  gap: 0.08rem;
  min-width: 0;
}

.hierarchy-node-main strong,
.hierarchy-node-main small {
  overflow-wrap: anywhere;
}

.hierarchy-node-main strong {
  color: var(--ink);
  line-height: 1.16;
}

.hierarchy-node-main small {
  color: var(--cocoa);
  line-height: 1.25;
}

.hierarchy-node-meta {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 0.45rem;
  min-width: max-content;
}

.hierarchy-kicker {
  display: inline-block;
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 700;
}

.hierarchy-route,
.hierarchy-stop,
.hierarchy-drop,
.hierarchy-building,
.hierarchy-entrance,
.hierarchy-company,
.hierarchy-branch {
  position: relative;
  margin-left: 1.05rem;
  padding-left: 1.05rem;
  border-left: 1px solid rgba(37, 31, 26, 0.16);
}

.hierarchy-route::before,
.hierarchy-stop::before,
.hierarchy-drop::before,
.hierarchy-building::before,
.hierarchy-entrance::before,
.hierarchy-company::before,
.hierarchy-branch::before {
  content: '';
  position: absolute;
  left: 0;
  top: 1.35rem;
  width: 0.82rem;
  border-top: 1px solid rgba(37, 31, 26, 0.16);
}

.hierarchy-empty {
  margin: 0.35rem 0 0 1.05rem;
  padding: 0.45rem 0.7rem;
  border: 1px dashed rgba(37, 31, 26, 0.18);
  border-radius: 0.75rem;
  background: rgba(255, 255, 255, 0.56);
  color: var(--cocoa);
}

.hierarchy-pending-subscribers {
  background: rgba(176, 111, 17, 0.08);
}

@media (max-width: 980px) {
  .hierarchy-node {
    min-width: 56rem;
  }

  .hierarchy-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* M114: office-drop-rooted operational hierarchy */
.hierarchy-office-drop-canvas .hierarchy-route-group,
.hierarchy-office-drop-canvas .hierarchy-building-group {
  margin-top: 0.7rem;
}

.hierarchy-office-drop > .hierarchy-node-card,
.hierarchy-office-drop > summary.hierarchy-node-card {
  border-color: rgba(176, 111, 17, 0.24);
}


/* M115: subscriber/reservation company-branch attachment */
.company-branch-attachment-form{align-items:end}.company-branch-attachment-form textarea{min-height:5rem}.hierarchy-linked-subscribers{background:rgba(22,163,74,.08);border-color:rgba(22,163,74,.18)}

/* M117: hierarchy data-quality dashboard */
.hierarchy-quality-category-table th,.hierarchy-quality-category-table td,.hierarchy-quality-issues-table th,.hierarchy-quality-issues-table td{vertical-align:top}.hierarchy-quality-issues-table td:nth-child(4),.hierarchy-quality-issues-table td:nth-child(5){min-width:16rem}.hierarchy-quality-badge{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.hierarchy-quality-critical{border-color:#d8a6a6;background:#fff1f1}.hierarchy-quality-warning{border-color:#dfc38a;background:#fff8e6}.hierarchy-quality-info{border-color:var(--admin-border,#e6ded4);background:rgba(255,255,255,.72)}

/* M121: hierarchy review status workflow */
.hierarchy-review-table textarea {
  min-width: 220px;
}

.hierarchy-review-form {
  display: grid;
  gap: 0.5rem;
  min-width: 260px;
}

.hierarchy-review-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
}

.hierarchy-review-status-badge {
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.hierarchy-review-status-new,
.hierarchy-review-status-acknowledged,
.hierarchy-review-status-in_progress,
.hierarchy-review-status-deferred {
  border-color: rgba(180, 83, 9, 0.35);
  background: rgba(254, 243, 199, 0.7);
}

.hierarchy-review-status-resolved_externally,
.hierarchy-review-status-not_an_issue {
  border-color: rgba(22, 101, 52, 0.25);
  background: rgba(220, 252, 231, 0.7);
}
