:root {
  --color-brand-primary: #f4b400;
  --color-brand-secondary: #1f2937;
  --color-brand-accent: #f59e0b;
  --color-brand-honey: #f6c343;

  --color-ui-bg: #ffffff;
  --color-ui-surface: #f9fafb;
  --color-ui-border: #e5e7eb;
  --color-ui-text: #111827;
  --color-ui-muted: #6b7280;

  --color-state-success: #16a34a;
  --color-state-warning: #d97706;
  --color-state-danger: #dc2626;
  --color-state-info: #2563eb;
  --color-focus: #2563eb;

  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;

  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 8px 20px rgba(0, 0, 0, 0.1);

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;

  --duration-fast: 120ms;
  --duration-normal: 200ms;
  --duration-slow: 320ms;
  --ease-standard: cubic-bezier(0.2, 0, 0, 1);

  --font-base: "Manrope", system-ui, sans-serif;
  --font-mono: "Space Mono", ui-monospace, monospace;
  --font-size-sm: 0.875rem;
  --font-size-md: 1rem;
  --font-size-lg: 1.25rem;
  --font-size-xl: 1.7rem;
  --font-size-2xl: 2.4rem;

  --layout-max: 1220px;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  font-family: var(--font-base);
  background:
    radial-gradient(circle at 16% 8%, rgba(246, 195, 67, 0.32), transparent 34%),
    radial-gradient(circle at 84% 92%, rgba(37, 99, 235, 0.16), transparent 36%),
    var(--color-ui-bg);
  color: var(--color-ui-text);
  line-height: 1.5;
}

html[data-surface="admin"] body {
  background:
    radial-gradient(circle at 18% 18%, rgba(37, 99, 235, 0.2), transparent 38%),
    radial-gradient(circle at 82% 80%, rgba(15, 23, 42, 0.18), transparent 44%),
    var(--color-ui-bg);
}

.skip {
  position: absolute;
  top: -100px;
  left: var(--space-4);
  background: #000;
  color: #fff;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  z-index: 50;
}

.skip:focus {
  top: var(--space-4);
}

.skip-modules {
  top: -160px;
}

.skip-modules:focus {
  top: calc(var(--space-4) + 44px);
}

.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;
}

.orb {
  position: fixed;
  width: 34vmax;
  height: 34vmax;
  border-radius: 50%;
  filter: blur(70px);
  opacity: 0.2;
  pointer-events: none;
  z-index: -1;
}

.orb-a {
  left: -12vmax;
  top: -12vmax;
  background: var(--color-brand-primary);
}

.orb-b {
  right: -10vmax;
  bottom: -14vmax;
  background: #34d399;
}

.hero,
.layout {
  width: min(var(--layout-max), 94vw);
  margin-inline: auto;
}

.hero {
  padding: var(--space-10) 0 var(--space-6);
}

.eyebrow {
  margin: 0;
  font: 700 var(--font-size-sm) / 1.3 var(--font-mono);
  letter-spacing: 0.11em;
  color: var(--color-brand-accent);
}

.hero h1 {
  margin: var(--space-2) 0 0;
  font-size: clamp(2rem, 6vw, 4rem);
  line-height: 1.05;
}

.hero-copy {
  margin: var(--space-3) 0 0;
  max-width: 72ch;
  color: var(--color-ui-muted);
}

.hero-motto {
  margin: var(--space-2) 0 0;
  font: 700 var(--font-size-sm) / 1.4 var(--font-mono);
  color: color-mix(in oklab, var(--color-brand-secondary) 72%, var(--color-state-info));
}

.hero-controls {
  margin-top: var(--space-5);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

.hero-actions {
  margin-top: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

html[data-surface="admin"] .eyebrow {
  color: var(--color-state-info);
}

.control {
  display: grid;
  gap: 6px;
  font-size: var(--font-size-sm);
  min-width: 230px;
}

.control-voice {
  align-content: start;
}

.voice-status {
  margin: 0;
}

body.a11y-motor-template {
  --font-size-sm: 1rem;
  --font-size-md: 1.125rem;
}

body.a11y-motor-template .hero-controls {
  gap: var(--space-4);
  align-items: stretch;
}

body.a11y-motor-template .control {
  min-width: 280px;
  gap: 8px;
}

body.a11y-motor-template .tab,
body.a11y-motor-template .btn,
body.a11y-motor-template input,
body.a11y-motor-template select,
body.a11y-motor-template textarea,
body.a11y-motor-template .switch {
  min-height: 56px;
  font-size: var(--font-size-md);
}

body.a11y-motor-template label,
body.a11y-motor-template .switch,
body.a11y-motor-template .consent {
  font-size: var(--font-size-md);
}

body.a11y-motor-template .tab,
body.a11y-motor-template .btn {
  padding-left: calc(var(--space-4) + 4px);
  padding-right: calc(var(--space-4) + 4px);
}

body.a11y-motor-template .form-inline {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

body.a11y-motor-template :focus-visible {
  outline-width: 4px;
  outline-offset: 3px;
  box-shadow: 0 0 0 5px color-mix(in oklab, var(--color-focus) 26%, white);
}

.layout {
  display: grid;
  gap: var(--space-4);
  padding-bottom: var(--space-10);
}

.front-layer {
  display: grid;
  gap: var(--space-4);
}

.public-page-layer {
  display: grid;
  gap: var(--space-4);
}

.public-page-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-3);
}

.public-page-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-2);
}

.public-page-outline {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--space-2);
  padding: var(--space-2);
  border-radius: var(--radius-md);
  border: 1px dashed color-mix(in oklab, var(--color-ui-border) 60%, var(--color-state-info));
  background: color-mix(in oklab, #fff 92%, var(--color-state-info) 8%);
}

.public-page-outline .control {
  display: grid;
  gap: 6px;
  min-width: 220px;
}

.public-page-content {
  display: grid;
  gap: var(--space-3);
}

.public-page-block {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 70%, var(--color-brand-primary));
  background: #fff;
}

.public-page-block h3 {
  margin: 0;
}

.public-page-media {
  display: grid;
  gap: var(--space-2);
}

.public-page-media img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 70%, var(--color-brand-primary));
}

.public-page-meta {
  color: var(--color-ui-muted);
}

.public-page-summary {
  font-weight: 600;
}

.public-page-block ul,
.public-page-block ol {
  padding-left: var(--space-4);
  margin: 0;
}

.front-portal-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
}

.front-hero-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-2);
}

.front-portal-stats {
  display: grid;
  gap: var(--space-2);
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.front-stat-card {
  display: grid;
  gap: 6px;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px dashed color-mix(in oklab, var(--color-ui-border) 65%, var(--color-state-info));
  background: #fff;
}

.front-stat-card small {
  color: var(--color-ui-muted);
  font-size: var(--font-size-sm);
}

.front-stat-card strong {
  font-size: clamp(1.4rem, 2.6vw, 2rem);
  line-height: 1;
}

.front-journeys {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-3);
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 72%, var(--color-brand-primary));
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, #fff 88%, var(--color-brand-primary) 12%);
}

.front-journey-grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.front-journey-card {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 72%, var(--color-brand-secondary));
  background: rgba(255, 255, 255, 0.86);
}

.front-journey-card h4 {
  margin: 0;
  font-size: var(--font-size-lg);
}

.front-feed-grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.front-feed-card,
.front-detail-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-ui-border);
  background: rgba(255, 255, 255, 0.92);
}

.front-feed-list {
  display: grid;
  gap: var(--space-2);
}

.front-feed-item {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 80%, var(--color-state-info));
  background: color-mix(in oklab, #fff 92%, var(--color-ui-surface));
}

.front-feed-item h4 {
  margin: 0;
  font-size: var(--font-size-md);
}

.front-feed-item p {
  margin: 0;
}

.front-feed-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.front-badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 72%, var(--color-state-info));
  background: #fff;
  color: var(--color-ui-muted);
  font: 700 12px/1 var(--font-mono);
}

.front-feed-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.front-detail-card {
  border-color: color-mix(in oklab, var(--color-ui-border) 62%, var(--color-brand-accent));
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 251, 235, 0.92)),
    #fff;
}

.front-detail-body {
  display: grid;
  gap: var(--space-2);
}

.front-detail-body p,
.front-detail-body ul {
  margin: 0;
}

.front-detail-body ul {
  padding-left: 1.25rem;
}

.front-empty {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px dashed color-mix(in oklab, var(--color-ui-border) 75%, var(--color-state-warning));
  background: color-mix(in oklab, #fff 90%, var(--color-state-warning) 10%);
}

.front-empty strong {
  font-size: var(--font-size-md);
}

.front-empty .note {
  color: var(--color-ui-text);
}

.front-slogans {
  margin: 0;
  padding-left: 1.25rem;
  display: grid;
  gap: var(--space-2);
}

.portal-hub-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 68%, var(--color-brand-secondary));
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.96)),
    #fff;
}

.portal-hub-card-compact {
  gap: var(--space-2);
  padding: var(--space-2);
}

.portal-hub-grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.portal-hub-grid-wide {
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
}

.portal-hub-section-stack {
  display: grid;
  gap: var(--space-3);
  align-content: start;
}

.portal-hub-context-grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.portal-hub-list {
  display: grid;
  gap: var(--space-2);
}

.portal-hub-item {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 72%, var(--color-state-info));
  background: color-mix(in oklab, #fff 94%, var(--color-ui-surface));
}

.portal-hub-item[data-active="true"] {
  border-color: var(--color-brand-secondary);
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--color-brand-secondary) 22%, #fff);
}

.portal-hub-item h5,
.portal-hub-item p {
  margin: 0;
}

.portal-hub-item h5 {
  font-size: var(--font-size-md);
}

.portal-hub-item-head {
  display: flex;
  justify-content: space-between;
  gap: var(--space-2);
  align-items: flex-start;
}

.portal-hub-item-kicker {
  color: var(--color-ui-muted);
  font-size: var(--font-size-sm);
}

.portal-hub-item-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.portal-hub-item-actions,
.portal-hub-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.legacy-workspace-shell,
.legacy-workspace-group {
  display: grid;
  gap: var(--space-3);
}

.legacy-workspace-shell {
  margin-block: var(--space-3);
}

.legacy-workspace-shell[hidden],
.legacy-workspace-group[hidden] {
  display: none;
}

.portal-hub-fieldset {
  display: grid;
  gap: var(--space-2);
  margin: 0;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 76%, var(--color-brand-secondary));
  background: color-mix(in oklab, #fff 96%, var(--color-ui-surface));
}

.portal-hub-fieldset legend {
  padding: 0 var(--space-1);
  font-weight: 700;
}

.portal-hub-form-grid {
  display: grid;
  gap: var(--space-2);
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  align-items: end;
}

.portal-hub-form-grid label:has(textarea) {
  grid-column: 1 / -1;
}

.portal-hub-control-note {
  margin: 0;
}

.portal-hub-highlight {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px dashed color-mix(in oklab, var(--color-ui-border) 70%, var(--color-state-success));
  background: color-mix(in oklab, #fff 90%, var(--color-state-success) 10%);
}

.portal-hub-highlight strong {
  font-size: var(--font-size-md);
}

.portal-hub-detail-list {
  margin: 0;
  padding-left: 1.25rem;
  display: grid;
  gap: var(--space-2);
}

.portal-hub-progress {
  display: grid;
  gap: 6px;
}

.portal-hub-progress progress {
  width: 100%;
  height: 16px;
  accent-color: var(--color-brand-secondary);
}

.portal-hub-progress-label {
  display: flex;
  justify-content: space-between;
  gap: var(--space-2);
  flex-wrap: wrap;
  color: var(--color-ui-muted);
  font-size: var(--font-size-sm);
}

.portal-hub-summary-grid {
  display: grid;
  gap: var(--space-2);
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.portal-hub-summary-card {
  display: grid;
  gap: 4px;
  padding: var(--space-2);
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 78%, var(--color-brand-accent));
  background: rgba(255, 255, 255, 0.95);
}

.portal-hub-summary-card strong {
  font-size: var(--font-size-md);
}

.portal-checkout-sheet {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: var(--space-4);
}

.portal-checkout-sheet[hidden] {
  display: none;
}

.portal-checkout-sheet__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.55);
  backdrop-filter: blur(6px);
}

.portal-checkout-sheet__card {
  position: relative;
  z-index: 1;
  width: min(760px, 100%);
  display: grid;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 72%, var(--color-brand-secondary));
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(248, 250, 252, 0.97)),
    #fff;
  box-shadow: 0 30px 80px rgba(15, 23, 42, 0.24);
}

.portal-hub-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.portal-hub-audio-step {
  display: grid;
  gap: 4px;
}

.portal-hub-audio-step strong,
.portal-hub-audio-step p {
  margin: 0;
}

.admin-layer {
  display: grid;
  gap: var(--space-4);
}

.admin-layer-intro h2 {
  margin: 0;
}

.card {
  background: color-mix(in oklab, var(--color-ui-surface) 92%, white);
  border: 1px solid var(--color-ui-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-4);
}

.concept-card {
  display: grid;
  gap: var(--space-3);
}

.concept-head {
  display: grid;
  gap: var(--space-2);
}

.concept-head p {
  margin: 0;
}

.concept-grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.concept-tile {
  border: 1px dashed color-mix(in oklab, var(--color-ui-border) 65%, var(--color-state-info));
  border-radius: var(--radius-md);
  background: #fff;
  padding: var(--space-3);
}

.concept-tile h3 {
  margin: 0 0 var(--space-2);
  font-size: 1.05rem;
}

.concept-tile p {
  margin: 0;
  color: var(--color-ui-muted);
  font-size: var(--font-size-sm);
}

.concept-action {
  margin-top: var(--space-3);
  width: 100%;
}

.concept-action-status {
  min-height: 1.25rem;
}

.status-card {
  display: grid;
  gap: var(--space-3);
}

.status-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}

.status-head h2,
.module-card h2,
.module-card h3 {
  margin: 0;
}

.status-line {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-ui-muted);
}

.dot {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: #94a3b8;
  box-shadow: 0 0 0 8px rgba(2, 132, 199, 0.08);
}

.status-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: var(--space-2);
}

.kpi {
  border: 1px dashed color-mix(in oklab, var(--color-ui-border) 75%, var(--color-state-info));
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  background: #fff;
}

.kpi strong {
  display: block;
  font-size: var(--font-size-lg);
}

.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.module-submenu {
  display: grid;
  gap: var(--space-2);
  margin: calc(var(--space-2) * -1) 0 var(--space-3);
  padding: var(--space-2);
  border: 1px dashed color-mix(in oklab, var(--color-ui-border) 65%, var(--color-state-info));
  border-radius: var(--radius-md);
  background: color-mix(in oklab, #fff 92%, var(--color-ui-surface));
}

.dynamic-interface-card {
  display: grid;
  gap: var(--space-2);
  margin: 0 0 var(--space-3);
  padding: var(--space-3);
  border: 1px dashed color-mix(in oklab, var(--color-ui-border) 65%, var(--color-state-success));
  border-radius: var(--radius-md);
  background: color-mix(in oklab, #fff 90%, var(--color-state-success) 10%);
}

.dynamic-interface-card h3 {
  margin: 0;
  font-size: var(--font-size-base);
}

.dynamic-interface-needs {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: 0;
  padding: 0;
}

.dynamic-interface-needs li {
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 70%, var(--color-state-success));
  background: #fff;
  color: var(--color-ui-text);
  padding: 0 12px;
  font: 700 0.75rem/1 var(--font-mono);
}

.dynamic-interface-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.dynamic-interface-debug {
  margin: 0 0 var(--space-3);
  padding: var(--space-2) var(--space-3);
  border: 1px dashed color-mix(in oklab, var(--color-ui-border) 65%, var(--color-state-warning));
  border-radius: var(--radius-md);
  background: color-mix(in oklab, #fff 92%, var(--color-state-warning) 8%);
}

.dynamic-interface-debug > summary {
  cursor: pointer;
  font-weight: 700;
}

.module-submenu-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.module-submenu-chip {
  min-height: 34px;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 70%, var(--color-state-info));
  background: #fff;
  color: var(--color-ui-text);
  padding: 0 12px;
  font: 700 0.75rem/1 var(--font-mono);
  cursor: pointer;
}

.module-submenu-chip[data-active="true"] {
  background: var(--color-brand-secondary);
  border-color: var(--color-brand-secondary);
  color: #fff;
}

.tab {
  min-height: 44px;
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 78%, var(--color-state-info));
  border-radius: 999px;
  background: color-mix(in oklab, #fff 90%, var(--color-ui-surface));
  color: var(--color-ui-text);
  padding: 0 var(--space-4);
  font: 700 var(--font-size-sm) / 1 var(--font-mono);
  cursor: pointer;
  transition:
    background var(--duration-fast) var(--ease-standard),
    border-color var(--duration-fast) var(--ease-standard),
    color var(--duration-fast) var(--ease-standard),
    box-shadow var(--duration-fast) var(--ease-standard);
}

.tab:hover {
  border-color: color-mix(in oklab, var(--color-state-info) 58%, white);
}

.tab.is-active {
  background: var(--color-brand-secondary);
  color: #fff;
  border-color: var(--color-brand-secondary);
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--color-brand-secondary) 32%, white);
}

.tab[aria-selected="true"] {
  font-weight: 800;
}

.tab[hidden] {
  display: none;
}

.panel {
  display: grid;
  gap: var(--space-3);
}

.panel.is-active {
  border: 2px solid color-mix(in oklab, var(--color-state-info) 30%, white);
  border-radius: var(--radius-md);
  background: #fff;
  padding: var(--space-3);
}

.stack {
  display: grid;
  gap: var(--space-3);
}

.panel-grid {
  display: grid;
  gap: var(--space-3);
}

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

.form {
  display: grid;
  gap: var(--space-2);
}

.note {
  margin: 0;
  color: var(--color-ui-muted);
  font-size: var(--font-size-sm);
}

.form-inline {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  align-items: end;
}

label,
.switch,
.consent {
  display: grid;
  gap: 6px;
  color: var(--color-ui-muted);
  font-size: var(--font-size-sm);
}

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

input,
select,
textarea {
  min-height: 44px;
  padding: 0 var(--space-3);
  border: 1px solid var(--color-ui-border);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--color-ui-text);
  transition:
    border-color var(--duration-fast) var(--ease-standard),
    box-shadow var(--duration-fast) var(--ease-standard),
    background var(--duration-fast) var(--ease-standard);
}

input:hover,
select:hover,
textarea:hover {
  border-color: color-mix(in oklab, var(--color-ui-border) 40%, var(--color-state-info));
}

input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  border-color: var(--color-focus);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-focus) 26%, white);
}

textarea {
  min-height: 120px;
  padding-top: var(--space-2);
  padding-bottom: var(--space-2);
  resize: vertical;
}

button {
  min-height: 44px;
}

.btn {
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 0 var(--space-4);
  font: 700 var(--font-size-sm) / 1 var(--font-mono);
  cursor: pointer;
  transition: transform var(--duration-fast) var(--ease-standard), filter var(--duration-fast) var(--ease-standard);
}

.btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.03);
}

.btn:disabled,
button:disabled,
input:disabled,
select:disabled,
textarea:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.btn-primary {
  background: var(--color-brand-primary);
  color: #111;
}

.btn-secondary {
  background: var(--color-state-info);
  color: #fff;
}

.btn-danger {
  background: var(--color-state-danger);
  color: #fff;
}

.btn-ghost {
  background: transparent;
  border-color: var(--color-ui-border);
  color: var(--color-ui-text);
}

.btn-control {
  width: 100%;
}

.out {
  margin: 0;
  background: #0f172a;
  color: #cbd5e1;
  border-radius: var(--radius-md);
  padding: var(--space-3);
  min-height: 64px;
  font: 400 12px/1.5 var(--font-mono);
  white-space: pre-wrap;
  word-break: break-word;
}

.webmail-frame {
  width: 100%;
  min-height: 70vh;
  border: 1px solid var(--color-ui-border);
  border-radius: var(--radius-md);
  background: #fff;
}

#mediaEmbedPreviewFrame {
  width: 100%;
  min-height: 320px;
  border: 1px solid var(--color-ui-border);
  border-radius: var(--radius-md);
  background: #000;
}

.media-gallery-grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
}

.media-gallery-card {
  display: grid;
  gap: var(--space-2);
  border: 1px solid var(--color-ui-border);
  border-radius: var(--radius-md);
  background: #fff;
  padding: var(--space-3);
}

.media-gallery-card h5 {
  margin: 0;
  font-size: var(--font-size-md);
}

.media-gallery-preview {
  width: 100%;
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 82%, #fff);
  border-radius: var(--radius-sm);
  background: #f8fafc;
  min-height: 120px;
  overflow: hidden;
}

.media-gallery-preview img,
.media-gallery-preview video,
.media-gallery-preview audio,
.media-gallery-preview iframe {
  width: 100%;
  display: block;
}

.media-gallery-preview iframe {
  min-height: 180px;
  border: 0;
}

.oncall-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 64px;
  border-radius: 999px;
  padding: 2px 10px;
  margin-inline: 8px;
  font: 700 12px/1 var(--font-mono);
  border: 1px solid transparent;
}

.oncall-ok {
  background: color-mix(in oklab, var(--color-state-success) 22%, white);
  color: #065f46;
  border-color: color-mix(in oklab, var(--color-state-success) 38%, white);
}

.oncall-warn {
  background: color-mix(in oklab, var(--color-state-warning) 24%, white);
  color: #92400e;
  border-color: color-mix(in oklab, var(--color-state-warning) 42%, white);
}

.oncall-crit {
  background: color-mix(in oklab, var(--color-state-danger) 20%, white);
  color: #991b1b;
  border-color: color-mix(in oklab, var(--color-state-danger) 38%, white);
}

.oncall-unknown {
  background: color-mix(in oklab, var(--color-ui-border) 65%, white);
  color: var(--color-ui-muted);
  border-color: color-mix(in oklab, var(--color-ui-border) 80%, var(--color-ui-muted));
}

.data-table-wrap {
  overflow: auto;
  border: 1px solid var(--color-ui-border);
  border-radius: var(--radius-md);
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

.data-table th,
.data-table td {
  text-align: left;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-ui-border);
}

.data-table th {
  background: color-mix(in oklab, var(--color-ui-surface) 84%, var(--color-brand-primary));
}

#conceptScreenMatrixTableBody tr[data-status="ok"] td:last-child {
  color: #065f46;
  font-weight: 700;
}

#conceptScreenMatrixTableBody tr[data-status="partial"] td:last-child {
  color: #92400e;
  font-weight: 700;
}

#conceptScreenMatrixTableBody tr[data-status="gap"] td:last-child {
  color: #991b1b;
  font-weight: 700;
}

#openApiMatrixTableBody tr[data-active="true"] td {
  background: color-mix(in oklab, var(--color-brand-primary) 12%, #fff);
}

.execution-board-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.execution-board-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--color-ui-border);
  background: #fff;
  color: var(--color-ui-text);
  padding: 4px 10px;
  font: 700 12px/1 var(--font-mono);
}

.execution-board-chip[data-kind="progress"] {
  background: color-mix(in oklab, var(--color-state-info) 18%, #fff);
  border-color: color-mix(in oklab, var(--color-state-info) 40%, #fff);
}

.execution-board-task-cell {
  display: grid;
  gap: 6px;
  min-width: 220px;
}

.execution-board-task-cell > strong {
  font-size: var(--font-size-sm);
}

.execution-board-task-cell .note {
  font-size: 12px;
}

.execution-board-status-select,
.execution-board-inline-input {
  min-height: 36px;
  height: 36px;
  padding: 0 10px;
  font-size: 12px;
}

.execution-board-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 220px;
}

.execution-board-actions .btn {
  min-height: 36px;
  padding: 0 12px;
}

#executionBoardTableBody tr[data-status="planned"] td:nth-child(5) {
  color: #374151;
  font-weight: 700;
}

#executionBoardTableBody tr[data-status="in_progress"] td:nth-child(5) {
  color: #92400e;
  font-weight: 700;
}

#executionBoardTableBody tr[data-status="blocked"] td:nth-child(5) {
  color: #991b1b;
  font-weight: 700;
}

#executionBoardTableBody tr[data-status="done"] td:nth-child(5) {
  color: #065f46;
  font-weight: 700;
}

.epics {
  margin: 0;
  padding-left: 1.2rem;
  display: grid;
  gap: 8px;
}

.badge {
  display: inline-flex;
  min-width: 36px;
  justify-content: center;
  border-radius: 999px;
  background: var(--color-brand-honey);
  padding: 2px 9px;
  margin-right: 8px;
  font: 700 12px/1 var(--font-mono);
  color: #111;
}

.openapi-tree-shell {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1fr) minmax(0, 1fr);
  align-items: start;
}

.openapi-tree-nav,
.openapi-tree-editor,
.openapi-tree-preview {
  border: 1px solid var(--color-ui-border);
  border-radius: var(--radius-md);
  background: #fff;
  padding: var(--space-3);
}

.openapi-tree-nav {
  max-height: 72vh;
  overflow: auto;
}

.openapi-tree-preview {
  display: grid;
  gap: var(--space-2);
}

.openapi-preview-frame {
  width: 100%;
  min-height: 54vh;
  border: 1px solid var(--color-ui-border);
  border-radius: var(--radius-sm);
  background: #fff;
}

.openapi-tree-nav-list {
  display: grid;
  gap: var(--space-2);
}

.openapi-tree-module,
.openapi-tree-screen {
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 80%, #fff);
  border-radius: var(--radius-sm);
  background: color-mix(in oklab, var(--color-ui-surface) 92%, #fff);
  padding: 6px 8px;
}

.openapi-tree-group {
  border: 1px solid color-mix(in oklab, var(--color-ui-border) 72%, #fff);
  border-radius: var(--radius-sm);
  background: color-mix(in oklab, var(--color-ui-surface) 96%, #fff);
  padding: 8px;
}

.openapi-tree-group > summary {
  cursor: pointer;
  font-weight: 800;
}

.openapi-tree-group-content {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}

.openapi-tree-module > summary,
.openapi-tree-screen > summary {
  cursor: pointer;
  font-weight: 700;
}

.openapi-tree-function-list {
  display: grid;
  gap: 6px;
  margin-top: 8px;
}

.openapi-tree-function-btn {
  text-align: left;
  border: 1px solid var(--color-ui-border);
  border-radius: var(--radius-sm);
  background: #fff;
  color: var(--color-ui-text);
  padding: 8px 10px;
}

.openapi-tree-function-btn[data-active="true"] {
  border-color: var(--color-focus);
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--color-focus) 22%, #fff);
}

.openapi-tree-function-meta {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: var(--color-ui-muted);
}

[data-anim] {
  opacity: 0;
  transform: translateY(12px);
  animation: fadeInUp var(--duration-slow) var(--ease-standard) forwards;
}

[data-anim]:nth-child(2) {
  animation-delay: 60ms;
}

.reduce-motion * {
  animation: none !important;
  transition: none !important;
}

:focus-visible {
  outline: 3px solid var(--color-focus);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--color-focus) 22%, white);
}

@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 980px) {
  .front-portal-head,
  .front-hero-actions,
  .hero-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .front-feed-grid {
    grid-template-columns: 1fr;
  }

  .portal-hub-grid,
  .portal-hub-grid-wide,
  .portal-hub-context-grid {
    grid-template-columns: 1fr;
  }

  .panel-grid.two {
    grid-template-columns: 1fr;
  }

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

  .openapi-tree-nav {
    max-height: 46vh;
  }
}

@media (max-width: 760px) {
  .hero {
    padding-top: var(--space-8);
  }

  .portal-hub-item-head,
  .status-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .portal-checkout-sheet {
    padding: var(--space-2);
  }

  .tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 4px;
  }

  .tab {
    white-space: nowrap;
    min-width: max-content;
  }

  .webmail-frame {
    min-height: 62vh;
  }
}
