/* ===================================================================
   Ordinatus house design system — single source of truth for brand
   tokens and shared components. Linked by auth, portal, and intake
   surfaces. Namespace: --ord-*  (extends the original auth palette).

   Accent is the ONE brand color. On org-scoped surfaces it is injected
   per-request as  style="--ord-accent: {{ org.primary_color }}"  on
   <html> (Plan 2). Here it defaults to the house indigo. Auth is
   house-branded and does NOT inject an org accent.
   =================================================================== */
:root {
  /* Accent — brand. Derived tints below recompute when --ord-accent changes. */
  --ord-accent:          #130065;
  --ord-accent-ink:      color-mix(in srgb, var(--ord-accent) 78%, #000);
  --ord-accent-wash:     color-mix(in srgb, var(--ord-accent) 9%, var(--ord-card));
  --ord-focus:           color-mix(in srgb, var(--ord-accent) 35%, transparent);

  /* Neutrals — cool bias (light) */
  --ord-bg:              #f5f7fa;
  --ord-card:            #ffffff;
  --ord-heading:         #12161c;
  --ord-text:            #2a2f37;
  --ord-muted:           #64707f;
  --ord-border:          #d3d9e2;
  --ord-hairline:        #e7ebf0;

  /* Primary button = accent; secondary = neutral */
  --ord-primary:         var(--ord-accent);
  --ord-primary-hover:   color-mix(in srgb, var(--ord-accent) 86%, #fff);
  --ord-secondary:       #eaeef3;
  --ord-secondary-hover: #dee4ec;

  /* Semantic (separate from accent) */
  --ord-error:           #c2321f;
  --ord-good:            #2e7d4f;
  --ord-footer:          #8a94a3;

  --ord-radius:          10px;
  --ord-sans:            system-ui, -apple-system, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;
  --ord-mono:            ui-monospace, "SF Mono", "Cascadia Code", "Segoe UI Mono", Consolas, monospace;

  /* Sidebar rail — intentionally dark in BOTH themes (keeps the dark-header
     identity). Active item tinted with the surface accent. */
  --ord-rail-bg:        #14181f;
  --ord-rail-ink:       #e7ebf0;
  --ord-rail-ink-muted: #97a2b2;
  --ord-rail-active-bg: color-mix(in srgb, var(--ord-accent) 28%, #14181f);
  --ord-rail-border:    #262c36;
}

/* Dark neutrals — drive AUTO mode via device preference.
   KEEP IN SYNC with the :root[data-theme="dark"] block below — the two must
   hold identical token values (plain CSS can't share a block between an
   @media query and an attribute selector). */
@media (prefers-color-scheme: dark) {
  :root {
    --ord-bg:              #0e1116;
    --ord-card:            #171b22;
    --ord-heading:         #eef1f6;
    --ord-text:            #d6dbe3;
    --ord-muted:           #8a94a3;
    --ord-border:          #333b47;
    --ord-hairline:        #252b34;
    --ord-secondary:       #232a33;
    --ord-secondary-hover: #2c343f;
    --ord-primary-hover:   color-mix(in srgb, var(--ord-accent) 70%, #fff);
    --ord-accent-wash:     color-mix(in srgb, var(--ord-accent) 20%, var(--ord-card));
    /* Accent text must LIGHTEN on dark surfaces — the :root (light) ink darkens
       toward black, which is near-invisible on the dark card/wash. */
    --ord-accent-ink:      color-mix(in srgb, var(--ord-accent) 40%, #fff);
    --ord-rail-active-bg:  color-mix(in srgb, var(--ord-accent) 34%, #14181f);
  }
}
/* Explicit org/user choice overrides the device preference, both directions.
   KEEP IN SYNC with the @media (prefers-color-scheme: dark) block above. */
:root[data-theme="dark"] {
  --ord-bg: #0e1116; --ord-card: #171b22; --ord-heading: #eef1f6; --ord-text: #d6dbe3;
  --ord-muted: #8a94a3; --ord-border: #333b47; --ord-hairline: #252b34;
  --ord-secondary: #232a33; --ord-secondary-hover: #2c343f;
  --ord-primary-hover: color-mix(in srgb, var(--ord-accent) 70%, #fff);
  --ord-accent-wash: color-mix(in srgb, var(--ord-accent) 20%, var(--ord-card));
  --ord-accent-ink: color-mix(in srgb, var(--ord-accent) 40%, #fff);
  --ord-rail-active-bg: color-mix(in srgb, var(--ord-accent) 34%, #14181f);
}
:root[data-theme="light"] {
  --ord-bg: #f5f7fa; --ord-card: #ffffff; --ord-heading: #12161c; --ord-text: #2a2f37;
  --ord-muted: #64707f; --ord-border: #d3d9e2; --ord-hairline: #e7ebf0;
  --ord-secondary: #eaeef3; --ord-secondary-hover: #dee4ec;
  --ord-primary-hover: color-mix(in srgb, var(--ord-accent) 86%, #fff);
  --ord-accent-wash: color-mix(in srgb, var(--ord-accent) 9%, var(--ord-card));
  --ord-accent-ink: color-mix(in srgb, var(--ord-accent) 78%, #000);
}

*, *::before, *::after { box-sizing: border-box; }

/* -------- Auth surface -------- */
body.ord-auth {
  font-family: var(--ord-sans);
  line-height: 1.6;
  color: var(--ord-text);
  background: var(--ord-bg);
  margin: 0;
  padding: 20px;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.auth-card {
  width: 100%;
  max-width: var(--ord-auth-card-w, 400px);
  background: var(--ord-card);
  border: 1px solid var(--ord-hairline);
  padding: 40px;
  border-radius: var(--ord-radius);
  box-shadow: 0 1px 2px rgba(18,22,28,.04), 0 18px 40px -24px rgba(18,22,28,.28);
}
.auth-card h1 { margin: 0 0 8px 0; text-align: center; color: var(--ord-heading); font-size: 1.5rem; letter-spacing: -0.01em; }
.auth-subtitle { text-align: center; color: var(--ord-muted); font-size: 14px; margin: 0 0 30px 0; }

label { display: block; margin-bottom: 6px; font-weight: 500; color: var(--ord-text); }
.form-group { margin-bottom: 20px; }

input[type="text"], input[type="password"], input[type="email"],
input[type="tel"], input[type="url"], select, textarea {
  width: 100%; padding: 12px;
  border: 1px solid var(--ord-border); border-radius: 8px;
  font-size: 15px; font-family: inherit;
  color: var(--ord-text); background: var(--ord-bg);
  transition: border-color .12s, box-shadow .12s, background .12s;
}
input:focus, select:focus, textarea:focus {
  outline: none; border-color: var(--ord-accent);
  box-shadow: 0 0 0 3px var(--ord-focus); background: var(--ord-card);
}

.ord-auth button[type="submit"], .ord-auth .btn-primary {
  display: inline-block; width: 100%;
  background: var(--ord-primary); color: #fff; border: none;
  padding: 14px; font-size: 15px; border-radius: 8px; cursor: pointer;
  margin-top: 10px; text-align: center; text-decoration: none;
  font-family: inherit; font-weight: 600; transition: background .12s, filter .12s;
}
.ord-auth button[type="submit"]:hover, .ord-auth .btn-primary:hover { background: var(--ord-primary-hover); }
.ord-auth button[type="submit"]:focus-visible, .ord-auth .btn-primary:focus-visible { outline: 3px solid var(--ord-focus); outline-offset: 2px; }
.ord-auth .btn-secondary {
  display: inline-block; width: 100%;
  background: var(--ord-secondary); color: var(--ord-text); border: none;
  padding: 14px; font-size: 15px; border-radius: 8px; cursor: pointer;
  margin-top: 10px; text-align: center; text-decoration: none; font-family: inherit; font-weight: 600;
}
.ord-auth .btn-secondary:hover { background: var(--ord-secondary-hover); }

.auth-links { margin-top: 18px; text-align: center; font-size: 14px; }
.auth-links a { color: var(--ord-accent-ink); text-decoration: underline; }
.auth-links a:hover { color: var(--ord-accent); }

.help-text { color: var(--ord-muted); font-size: 13px; margin-top: 5px; }
.field-error { color: var(--ord-error); font-size: 13px; margin-top: 5px; }
.errorlist { list-style: none; margin: 0 0 6px 0; padding: 0; color: var(--ord-error); font-size: 13px; }
.error-list {
  background: color-mix(in srgb, var(--ord-error) 10%, var(--ord-card));
  border: 1px solid color-mix(in srgb, var(--ord-error) 30%, var(--ord-card));
  border-radius: 8px; padding: 15px; margin-bottom: 20px; color: var(--ord-error);
}
.error-list ul { margin: 0; padding-left: 20px; }
.error-list li { margin-bottom: 5px; }
.error-list li:last-child { margin-bottom: 0; }

.messages { list-style: none; margin: 0 0 20px 0; padding: 0; }
.messages li { padding: 12px 15px; border-radius: 8px; margin-bottom: 10px; font-size: 14px; border: 1px solid transparent; }
.messages li.success { background: color-mix(in srgb, var(--ord-good) 12%, var(--ord-card)); color: var(--ord-good); border-color: color-mix(in srgb, var(--ord-good) 30%, var(--ord-card)); }
.messages li.error { background: color-mix(in srgb, var(--ord-error) 12%, var(--ord-card)); color: var(--ord-error); border-color: color-mix(in srgb, var(--ord-error) 30%, var(--ord-card)); }
.messages li.info, .messages li.debug { background: var(--ord-accent-wash); color: var(--ord-accent-ink); border-color: color-mix(in srgb, var(--ord-accent) 25%, var(--ord-card)); }
.messages li.warning { background: color-mix(in srgb, #b7791f 12%, var(--ord-card)); color: #8a5a12; border-color: color-mix(in srgb, #b7791f 30%, var(--ord-card)); }

.auth-footer { margin-top: 24px; text-align: center; font-size: 12px; color: var(--ord-footer); line-height: 1.8; }
.auth-footer a { color: var(--ord-footer); text-decoration: underline; }
.auth-footer a:hover { color: var(--ord-accent); }
.auth-footer .sep { margin: 0 6px; color: var(--ord-border); }

/* Per-page contextual help link (top-right of dashboard content) */
.ord-page-help { text-align: right; margin: 0 0 8px; }
.ord-help-link {
  display: inline-flex; align-items: center; gap: 5px;
  color: var(--ord-muted); font-size: 13px; text-decoration: none;
}
.ord-help-link:hover { color: var(--ord-accent-ink); text-decoration: underline; }
.ord-help-icon { flex: none; }

/* -------- Portal surface -------- */
body.ord-portal { font-family: var(--ord-sans); color: var(--ord-text); background: var(--ord-bg); margin: 0; line-height: 1.6; }
.p-header { display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 14px 20px; background: var(--ord-card); border-bottom: 1px solid var(--ord-hairline); }
.p-header .header-left { display: flex; align-items: center; gap: 22px; }
.p-header h1 { margin: 0; font-size: 1.05rem; font-weight: 650; color: var(--ord-heading); }
.p-header .header-right { display: flex; align-items: center; gap: 14px; font-size: 13px; color: var(--ord-muted); }
.p-header .header-right a { color: var(--ord-muted); text-decoration: none; }
.p-header .header-right a:hover { color: var(--ord-accent-ink); }
.main { max-width: 1000px; margin: 0 auto; padding: 30px 20px; }
.page-header { margin-bottom: 24px; }
.page-header h2 { margin: 0; color: var(--ord-heading); letter-spacing: -.01em; }
.card { background: var(--ord-card); border: 1px solid var(--ord-hairline); border-radius: var(--ord-radius);
  margin-bottom: 24px; overflow: hidden; }
.card-header { padding: 14px 18px; border-bottom: 1px solid var(--ord-hairline);
  display: flex; justify-content: space-between; align-items: center; }
.card-header h3 { margin: 0; font-size: .95rem; color: var(--ord-heading); }
.card-body { padding: 20px; }
.request-list { list-style: none; margin: 0; padding: 0; }
.request-item { padding: 14px 18px; border-bottom: 1px solid var(--ord-hairline);
  display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.request-item:last-child { border-bottom: none; }
.request-item:hover { background: color-mix(in srgb, var(--ord-accent) 3%, var(--ord-card)); }
.request-customer { font-weight: 600; color: var(--ord-heading); margin-bottom: 3px; }
.request-meta { font-size: 12.5px; color: var(--ord-muted); }
.request-actions a { display: inline-block; padding: 7px 13px; color: var(--ord-accent-ink);
  border: 1px solid var(--ord-border); border-radius: 8px; text-decoration: none; font-size: 13px; font-weight: 600; }
.request-actions a:hover { border-color: var(--ord-accent); background: var(--ord-accent-wash); }
.empty-state { text-align: center; padding: 40px 20px; color: var(--ord-muted); }
.btn { display: inline-block; padding: 10px 18px; border-radius: 8px; font-size: 14px; font-weight: 600;
  text-decoration: none; cursor: pointer; border: none; font-family: inherit; }
.btn-primary { background: var(--ord-accent); color: #fff; }
.btn-primary:hover { filter: brightness(1.08); }
.btn-secondary { background: var(--ord-secondary); color: var(--ord-text); }
.btn-secondary:hover { background: var(--ord-secondary-hover); }
.detail-section { margin-bottom: 24px; }
.detail-section h4 { margin: 0 0 14px; color: var(--ord-heading); font-size: .95rem;
  padding-bottom: 8px; border-bottom: 1px solid var(--ord-hairline); }
.detail-row { display: flex; margin-bottom: 10px; }
.detail-label { width: 140px; font-weight: 600; color: var(--ord-muted); flex-shrink: 0; }
.detail-value { flex: 1; color: var(--ord-text); }
/* Status badges — semantic, mono */
.status-badge { display: inline-block; padding: 4px 9px; border-radius: 6px; font-family: var(--ord-mono);
  font-size: 10.5px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }
.status-new { background: color-mix(in srgb, #2563eb 14%, var(--ord-card)); color: #2563eb; }
.status-eligible { background: color-mix(in srgb, var(--ord-good) 15%, var(--ord-card)); color: var(--ord-good); }
.status-claimed { background: color-mix(in srgb, #b7791f 16%, var(--ord-card)); color: #8a5a12; }
.status-scheduling { background: var(--ord-accent-wash); color: var(--ord-accent-ink); }
.status-pending_payment { background: color-mix(in srgb, #c2185b 14%, var(--ord-card)); color: #c2185b; }
.status-confirmed { background: color-mix(in srgb, var(--ord-good) 15%, var(--ord-card)); color: var(--ord-good); }
.status-completed { background: var(--ord-secondary); color: var(--ord-muted); }
/* Messages (portal) */
.messages { margin-bottom: 20px; }
.message { padding: 12px 15px; border-radius: 8px; margin-bottom: 10px; border: 1px solid transparent; }
.message-success { background: color-mix(in srgb, var(--ord-good) 12%, var(--ord-card)); color: var(--ord-good); border-color: color-mix(in srgb, var(--ord-good) 30%, var(--ord-card)); }
.message-error { background: color-mix(in srgb, var(--ord-error) 12%, var(--ord-card)); color: var(--ord-error); border-color: color-mix(in srgb, var(--ord-error) 30%, var(--ord-card)); }
/* Impersonation banner */
.impersonation-banner { background: #b7791f; color: #fff; padding: 10px 20px;
  display: flex; justify-content: space-between; align-items: center; font-weight: 600; }
.impersonation-banner .stop-btn { background: #fff; color: var(--ord-heading); border: none;
  padding: 6px 16px; border-radius: 8px; font-size: 13px; font-weight: 600; cursor: pointer; }
@media (max-width: 600px) {
  .p-header { flex-direction: column; gap: 10px; align-items: flex-start; }
  .request-item { flex-direction: column; align-items: flex-start; }
  .detail-row { flex-direction: column; }
  .detail-label { width: auto; margin-bottom: 2px; }
}

/* -------- Public customer root (intake / account / booking) -------- */
body.ord-intake { font-family: var(--ord-sans); color: var(--ord-text); background: var(--ord-bg);
  margin: 0; padding: 20px; line-height: 1.6; }
.container { max-width: 700px; margin: 0 auto; background: var(--ord-card);
  border: 1px solid var(--ord-hairline); padding: 40px; border-radius: var(--ord-radius);
  box-shadow: 0 1px 2px rgba(18,22,28,.04), 0 18px 40px -24px rgba(18,22,28,.22); }
.container h1 { margin-top: 0; color: var(--ord-heading); letter-spacing: -.01em; }
.org-header { text-align: center; margin-bottom: 30px; padding-bottom: 20px; border-bottom: 1px solid var(--ord-hairline); }
.org-header p { color: var(--ord-muted); margin: 10px 0 0; }
.rate-limit-notice { background: color-mix(in srgb, #b7791f 12%, var(--ord-card));
  border: 1px solid color-mix(in srgb, #b7791f 30%, var(--ord-card)); color: #8a5a12;
  border-radius: 8px; padding: 12px 15px; margin-bottom: 20px; }

/* form-renderer classes ({{ form_html }}) */
.form-section { margin-bottom: 30px; padding-bottom: 25px; border-bottom: 1px solid var(--ord-hairline); }
.form-section:last-child { border-bottom: none; margin-bottom: 0; }
.section-title { font-size: 1.05rem; font-weight: 650; color: var(--ord-heading); margin: 0 0 6px;
  padding-bottom: 10px; border-bottom: 1px dashed var(--ord-border); letter-spacing: -.01em; }
.section-description { color: var(--ord-muted); font-size: 14px; margin: 0 0 20px; }
.form-section .form-group { margin-bottom: 20px; }
.form-group > label { display: block; margin-bottom: 6px; font-weight: 600; color: var(--ord-text); }
.required { color: var(--ord-accent); margin-left: 2px; }
.form-text-only { margin: 28px 0 20px; }
.form-text-only .text-only-heading { margin: 0 0 6px; font-size: 16px; font-weight: 600; color: var(--ord-heading); }
.form-text-only .text-only-body { color: var(--ord-text); line-height: 1.5; }
.ord-intake input[type="text"], .ord-intake input[type="email"], .ord-intake input[type="tel"], .ord-intake textarea {
  width: 100%; padding: 11px 13px; border: 1px solid var(--ord-border); border-radius: 8px;
  font-size: 15px; font-family: inherit; color: var(--ord-text); background: var(--ord-bg);
  transition: border-color .12s, box-shadow .12s, background .12s; }
.ord-intake input:focus, .ord-intake textarea:focus { outline: none; border-color: var(--ord-accent);
  box-shadow: 0 0 0 3px var(--ord-focus); background: var(--ord-card); }
.ord-intake textarea { min-height: 120px; resize: vertical; }
.sub-fields { display: flex; gap: 15px; }
.sub-field { flex: 1; }
.sub-field input { width: 100%; margin-bottom: 4px; }
.sub-label { display: block; font-size: 13px; color: var(--ord-muted); font-weight: normal; }
.word-count { font-size: 13px; color: var(--ord-muted); margin-top: 6px; }
.current-count { font-style: italic; }
.checkbox-group { display: flex; flex-direction: column; gap: 8px; }
.checkbox-group.columns-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 20px; }
.checkbox-option, .radio-option { display: flex; align-items: flex-start; gap: 8px; cursor: pointer; font-weight: normal; }
.checkbox-option input, .radio-option input { margin-top: 3px; flex-shrink: 0; accent-color: var(--ord-accent); }
.checkbox-option span, .radio-option span { font-size: 14px; line-height: 1.4; }
.radio-group { display: flex; flex-direction: column; gap: 8px; }
.matrix-wrapper { overflow-x: auto; }
.matrix-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.matrix-table th { text-align: center; padding: 10px 8px; font-weight: 600; color: var(--ord-muted);
  background: var(--ord-bg); border-bottom: 1px solid var(--ord-border); }
.matrix-table td { padding: 10px 8px; text-align: center; border-bottom: 1px solid var(--ord-hairline); }
.matrix-table td.row-label { text-align: left; color: var(--ord-text); }
.matrix-table input[type="radio"] { width: 16px; height: 16px; accent-color: var(--ord-accent); }
.checkbox-single { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; font-weight: normal; }
.checkbox-single input { margin-top: 3px; flex-shrink: 0; accent-color: var(--ord-accent); }
.checkbox-help-text { font-size: 14px; color: var(--ord-text); line-height: 1.5; margin: 0 0 12px;
  padding: 12px; background: var(--ord-bg); border-radius: 8px; }
.has-error input, .has-error textarea { border-color: var(--ord-error); }
.field-error { color: var(--ord-error); font-size: 13px; margin-top: 5px; }
.ord-intake button[type="submit"] { background: var(--ord-accent); color: #fff; border: none; padding: 14px 28px;
  font-size: 15px; border-radius: 8px; cursor: pointer; margin-top: 10px; font-weight: 600; font-family: inherit; }
.ord-intake button[type="submit"]:hover { filter: brightness(1.08); }
.ord-intake button[type="submit"]:disabled { opacity: .6; cursor: default; }
.success-icon { font-size: 48px; margin-bottom: 20px; color: var(--ord-good); }

/* Intake-only: numbered sections via CSS counter (decorative), two-column shell */
.container--wide { max-width: 1040px; background: none; border: none; box-shadow: none; padding: 0; }
.ord-intake .container--wide { counter-reset: intake-sec; }
.ord-intake .container--wide .form-section { counter-increment: intake-sec; position: relative; }
.ord-intake .container--wide .section-title::before {
  content: counter(intake-sec, decimal-leading-zero); font-family: var(--ord-mono); font-size: 12px;
  font-weight: 600; color: var(--ord-accent-ink); margin-right: 10px; }
.intake-grid { display: grid; grid-template-columns: 300px 1fr; gap: 48px; align-items: start; }
@media (max-width: 860px) { .intake-grid { grid-template-columns: 1fr; gap: 28px; } }
.intake-rail { position: sticky; top: 24px; }
@media (max-width: 860px) { .intake-rail { position: static; } }
.intake-rail .eyebrow { font-family: var(--ord-mono); font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ord-accent-ink); margin: 0 0 10px; }
.intake-rail h1 { font-size: 1.9rem; line-height: 1.15; letter-spacing: -.02em; margin: 0 0 14px;
  color: var(--ord-heading); text-wrap: balance; }
.intake-rail .lede { color: var(--ord-muted); margin: 0 0 26px; }
.steps { list-style: none; margin: 0; padding: 0; display: grid; gap: 2px; }
.steps li { display: grid; grid-template-columns: 30px 1fr; gap: 14px; padding: 12px 0; position: relative; }
.steps li:not(:last-child)::after { content: ""; position: absolute; left: 14px; top: 42px; bottom: -12px;
  width: 1px; background: var(--ord-border); }
.steps .n { font-family: var(--ord-mono); font-size: 12px; font-weight: 600; width: 30px; height: 30px;
  border-radius: 50%; border: 1px solid var(--ord-border); color: var(--ord-muted); display: grid;
  place-items: center; background: var(--ord-card); }
.steps li:first-child .n { border-color: var(--ord-accent); color: var(--ord-accent-ink); background: var(--ord-accent-wash); }
.steps .t { font-weight: 600; font-size: .92rem; color: var(--ord-heading); }
.steps .d { color: var(--ord-muted); font-size: .85rem; }
.intake-main .card { background: var(--ord-card); border: 1px solid var(--ord-hairline);
  border-radius: var(--ord-radius); overflow: hidden;
  box-shadow: 0 1px 2px rgba(18,22,28,.04), 0 18px 40px -24px rgba(18,22,28,.22); }
.intake-main .card .progress { height: 3px; background: var(--ord-hairline); }
.intake-main .card .card-inner { padding: 34px 36px; }
@media (max-width: 560px) { .intake-main .card .card-inner { padding: 24px 20px; } }

@media (max-width: 600px) {
  .container { padding: 25px 20px; }
  .sub-fields { flex-direction: column; gap: 10px; }
  .checkbox-group.columns-2 { grid-template-columns: 1fr; }
}

/* -------- Visitor theme switcher (all customer surfaces) -------- */
.theme-switch {
  position: fixed; right: 16px; bottom: 16px; z-index: 60;
  display: inline-flex; gap: 2px; padding: 3px;
  background: var(--ord-card); border: 1px solid var(--ord-border);
  border-radius: 999px; box-shadow: 0 6px 20px -10px rgba(18,22,28,.4);
  font-family: var(--ord-mono);
}
.theme-switch button {
  border: none; background: none; cursor: pointer;
  font: inherit; font-size: 11px; letter-spacing: .02em;
  color: var(--ord-muted); padding: 5px 11px; border-radius: 999px;
  transition: background .12s, color .12s;
}
.theme-switch button:hover { color: var(--ord-text); }
.theme-switch button[aria-pressed="true"] { background: var(--ord-accent); color: #fff; }
.theme-switch button:focus-visible { outline: 2px solid var(--ord-focus); outline-offset: 2px; }
@media (max-width: 560px) { .theme-switch button { padding: 5px 9px; } }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition: none !important; animation: none !important; }
}

/* ============================================================
   Internal dashboard shell (CAdmin / Trainer / Platform)
   ============================================================ */
/* Shell body: kill the default 8px UA margin so the rail meets the viewport
   edges (the bare <body> here has no surface class of its own). */
body.ord-shell { margin: 0; font-family: var(--ord-sans); line-height: 1.6; }
.ord-app { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh;
  background: var(--ord-bg); color: var(--ord-text); }
:root[data-sidebar-collapsed] .ord-app { grid-template-columns: 64px 1fr; }

.ord-sidebar { display: flex; flex-direction: column; background: var(--ord-rail-bg);
  color: var(--ord-rail-ink); border-right: 1px solid var(--ord-rail-border);
  position: sticky; top: 0; height: 100vh; overflow: hidden; }
.ord-sidebar-header { display: flex; align-items: center; justify-content: space-between;
  gap: 10px; padding: 14px 16px; border-bottom: 1px solid var(--ord-rail-border); min-height: 56px; }
.ord-sidebar-brand { display: flex; align-items: center; gap: 10px; font-weight: 650;
  font-size: 1rem; color: var(--ord-rail-ink); text-decoration: none; white-space: nowrap; overflow: hidden; }
.ord-sidebar-brand img { height: 28px; }
.ord-collapse-toggle { flex-shrink: 0; background: transparent; border: none; cursor: pointer;
  color: var(--ord-rail-ink-muted); padding: 6px; border-radius: 6px; line-height: 0; }
.ord-collapse-toggle:hover { color: var(--ord-rail-ink); background: rgba(255,255,255,0.06); }
.ord-collapse-toggle:focus-visible { outline: 2px solid var(--ord-accent); outline-offset: 2px; }
:root[data-sidebar-collapsed] .ord-collapse-toggle svg { transform: rotate(180deg); }

.ord-sidebar-nav { flex: 1; overflow-y: auto; padding: 10px 8px; }
.ord-nav-group { margin: 6px 0 10px; }
.ord-nav-label { font-family: var(--ord-mono); text-transform: uppercase; letter-spacing: .06em;
  font-size: 10.5px; color: var(--ord-rail-ink-muted); padding: 6px 10px; }
:root[data-sidebar-collapsed] .ord-nav-label { display: none; }
.ord-nav-item { display: flex; align-items: center; gap: 12px; padding: 9px 10px; border-radius: 8px;
  color: var(--ord-rail-ink-muted); text-decoration: none; font-size: 14px; white-space: nowrap;
  border-left: 3px solid transparent; }
.ord-nav-item:hover { color: var(--ord-rail-ink); background: rgba(255,255,255,0.05); }
.ord-nav-item.is-active { color: var(--ord-rail-ink); background: var(--ord-rail-active-bg);
  border-left-color: var(--ord-accent); }
.ord-nav-item:focus-visible { outline: 2px solid var(--ord-accent); outline-offset: -2px; }
.ord-nav-icon { width: 18px; height: 18px; flex-shrink: 0; fill: currentColor; }
.ord-nav-label-text { overflow: hidden; text-overflow: ellipsis; }
:root[data-sidebar-collapsed] .ord-nav-label-text { display: none; }
:root[data-sidebar-collapsed] .ord-nav-item { justify-content: center; gap: 0; }

.ord-sidebar-footer { border-top: 1px solid var(--ord-rail-border); padding: 12px 10px;
  display: flex; flex-direction: column; gap: 8px; font-size: 13px; }
.ord-sidebar-footer a { color: var(--ord-rail-ink-muted); text-decoration: none; padding: 5px 8px;
  border-radius: 6px; display: flex; align-items: center; gap: 8px; }
.ord-sidebar-footer a:hover { color: var(--ord-rail-ink); background: rgba(255,255,255,0.05); }
.ord-sidebar-footer .user-info { color: var(--ord-rail-ink-muted); font-size: 12px; padding: 4px 8px;
  overflow: hidden; text-overflow: ellipsis; }
:root[data-sidebar-collapsed] .ord-sidebar-footer .footer-label,
:root[data-sidebar-collapsed] .ord-sidebar-footer .user-info,
:root[data-sidebar-collapsed] .ord-sidebar-footer .theme-switch { display: none; }
/* Theme switch restyled for the dark rail. */
.ord-sidebar-footer .theme-switch { display: flex; gap: 4px; }
.ord-sidebar-footer .theme-switch button { flex: 1; background: rgba(255,255,255,0.06);
  color: var(--ord-rail-ink-muted); border: 1px solid var(--ord-rail-border); border-radius: 6px;
  padding: 5px 4px; font-size: 11px; cursor: pointer; }
.ord-sidebar-footer .theme-switch button[aria-pressed="true"] { color: var(--ord-rail-ink);
  background: var(--ord-rail-active-bg); border-color: var(--ord-accent); }
.ord-sidebar-footer .theme-switch button:focus-visible { outline: 2px solid var(--ord-accent); outline-offset: 1px; }

/* Main column + mobile topbar (hamburger hidden on desktop). */
.ord-main-col { min-width: 0; display: flex; flex-direction: column; }
/* Widen the content column for dense internal tables (global .main caps at
   1000px for the editorial portal — too tight for cadmin/platform data). */
.ord-main-col .main { max-width: 1280px; }
.ord-topbar { display: none; align-items: center; gap: 12px; padding: 10px 16px;
  background: var(--ord-rail-bg); color: var(--ord-rail-ink); border-bottom: 1px solid var(--ord-rail-border); }
.ord-menu-toggle { background: transparent; border: none; color: var(--ord-rail-ink); cursor: pointer;
  padding: 6px; line-height: 0; }
.ord-menu-toggle svg { width: 22px; height: 22px; fill: currentColor; }
.ord-backdrop { display: none; }

/* Off-canvas drawer under 768px. */
@media (max-width: 768px) {
  .ord-app { grid-template-columns: 1fr; }
  :root[data-sidebar-collapsed] .ord-app { grid-template-columns: 1fr; }
  .ord-topbar { display: flex; }
  .ord-sidebar { position: fixed; top: 0; left: 0; z-index: 60; width: 280px; height: 100vh;
    transform: translateX(-100%); transition: transform .2s ease; }
  :root[data-sidebar-collapsed] .ord-sidebar { width: 280px; }         /* drawer ignores collapse */
  :root[data-sidebar-collapsed] .ord-nav-label-text,
  :root[data-sidebar-collapsed] .ord-nav-label { display: revert; }     /* labels back inside the drawer */
  :root[data-sidebar-collapsed] .ord-nav-item { justify-content: flex-start; gap: 12px; }
  .ord-app[data-drawer-open] .ord-sidebar { transform: translateX(0); }
  .ord-app[data-drawer-open] .ord-backdrop { display: block; position: fixed; inset: 0; z-index: 55;
    background: rgba(0,0,0,0.5); }
}

/* ============================================================
   CAdmin page components (ported from cadmin/base.html inline <style>).
   Scoped under .ord-admin so surface-specific values don't collide with
   the portal/platform surfaces.
   ============================================================ */
.ord-admin .page-header p { margin: 5px 0 0; color: var(--ord-muted); }
/* Two-column content grid for admin pages — collapses only on the smallest
   screens so the wide content area isn't a single stacked column. */
.ord-admin .dash-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
.ord-admin .dash-cols > * { margin-bottom: 0; }
@media (max-width: 640px) { .ord-admin .dash-cols { grid-template-columns: 1fr; } }
.ord-admin .metrics-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 20px; margin-bottom: 30px; }
.ord-admin .metric-card { display: block; background: var(--ord-card); border: 1px solid var(--ord-hairline);
  border-radius: var(--ord-radius); padding: 20px; color: inherit; text-decoration: none;
  transition: border-color .12s, box-shadow .12s, background .12s, transform .12s; }
/* Whole card is the link — hover lifts/tints the entire box, never underlines text. */
a.metric-card, a.metric-card:hover, a.metric-card:focus { text-decoration: none; }
a.metric-card:hover { border-color: var(--ord-accent); background: var(--ord-accent-wash);
  transform: translateY(-2px);
  box-shadow: 0 1px 2px rgba(18,22,28,.04), 0 12px 26px -18px rgba(18,22,28,.4); }
a.metric-card:focus-visible { outline: 2px solid var(--ord-focus); outline-offset: 2px; }
.ord-admin .metric-card .metric-value { font-size: 2rem; font-weight: 650; color: var(--ord-heading); margin-bottom: 5px; }
.ord-admin .metric-card .metric-label { color: var(--ord-muted); font-size: 14px; }
.ord-admin .table-container { overflow-x: auto; }
.ord-admin table { width: 100%; border-collapse: collapse; }
.ord-admin th, .ord-admin td { padding: 12px 15px; text-align: left; border-bottom: 1px solid var(--ord-hairline); }
.ord-admin th { background: var(--ord-secondary); font-weight: 600; font-size: 13px; text-transform: uppercase;
  letter-spacing: .5px; color: var(--ord-muted); }
.ord-admin tbody tr:hover { background: color-mix(in srgb, var(--ord-accent) 4%, var(--ord-card)); }
.ord-admin .admin-badge { background: var(--ord-secondary); color: var(--ord-muted); padding: 3px 8px;
  border-radius: 3px; font-size: 11px; text-transform: uppercase; letter-spacing: .5px; }
/* Org subscription status badges (reuse the global .status-badge base). */
.ord-admin .status-active { background: color-mix(in srgb, var(--ord-good) 15%, var(--ord-card)); color: var(--ord-good); }
.ord-admin .status-inactive { background: color-mix(in srgb, var(--ord-error) 12%, var(--ord-card)); color: var(--ord-error); }
.ord-admin .status-trial { background: color-mix(in srgb, #b7791f 16%, var(--ord-card)); color: #8a5a12; }
/* Small button + inline field error (were cadmin-inline only). */
.ord-admin .btn-sm { padding: 6px 12px; font-size: 13px; }
.ord-admin .error-text { margin-top: 5px; font-size: 13px; color: var(--ord-error); }

/* ============================================================
   Trainer surface page components (ported from trainers/base.html
   inline <style>). Scoped under .ord-portal (the trainer/portal shell).
   ============================================================ */
.ord-portal .page-header { display: flex; justify-content: space-between; align-items: center; }
.ord-portal .form-label { display: block; margin-bottom: 6px; font-weight: 500; color: var(--ord-text); }
.ord-portal .form-input, .ord-portal .form-select { width: 100%; padding: 8px 12px;
  border: 1px solid var(--ord-border); border-radius: 8px; font-size: 14px; font-family: inherit;
  color: var(--ord-text); background: var(--ord-bg); }
.ord-portal .form-input:focus, .ord-portal .form-select:focus { outline: none; border-color: var(--ord-accent);
  box-shadow: 0 0 0 3px var(--ord-focus); background: var(--ord-card); }
.ord-portal .form-help { font-size: 12px; color: var(--ord-muted); margin-top: 4px; }
.ord-portal .form-error { color: var(--ord-error); font-size: 13px; margin-top: 4px; }
.ord-portal .form-checkbox-group { display: flex; flex-direction: column; gap: 8px; }
.ord-portal .form-checkbox-group label { display: flex; align-items: center; gap: 8px; font-weight: normal; }
.ord-portal .form-checkbox-group input[type="checkbox"] { width: auto; accent-color: var(--ord-accent); }
.ord-portal .table { width: 100%; border-collapse: collapse; }
.ord-portal .table th { text-align: left; padding: 12px; background: var(--ord-secondary);
  border-bottom: 2px solid var(--ord-border); font-weight: 600; font-size: 14px; color: var(--ord-muted); }
.ord-portal .table td { padding: 12px; border-bottom: 1px solid var(--ord-hairline); }
.ord-portal .table tr:hover { background: color-mix(in srgb, var(--ord-accent) 3%, var(--ord-card)); }
.ord-portal .btn-danger { background: var(--ord-error); color: #fff; }
.ord-portal .btn-danger:hover { filter: brightness(1.08); }
.ord-portal .status-active { color: var(--ord-good); }
.ord-portal .status-inactive { color: var(--ord-error); }
/* Screen-reader-only utility (used for visually-empty table headers). */
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); clip-path: inset(50%); white-space: nowrap; border: 0; }

/* ============================================================
   Platform console page components (ported from platform/base.html
   inline <style>). Scoped under .ord-platform. House accent only.
   ============================================================ */
.ord-platform .page-header p { margin: 5px 0 0; color: var(--ord-muted); }
.ord-platform .metrics-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; margin-bottom: 30px; }
.ord-platform .metric-card { background: var(--ord-card); border: 1px solid var(--ord-hairline);
  border-left: 4px solid var(--ord-accent); border-radius: var(--ord-radius); padding: 24px; }
.ord-platform .metric-card .metric-value { font-size: 2.5rem; font-weight: 700; color: var(--ord-heading); margin-bottom: 5px; }
.ord-platform .metric-card .metric-label { color: var(--ord-muted); font-size: 14px; font-weight: 500; }
.ord-platform .metric-card .metric-sub { color: var(--ord-muted); font-size: 13px; margin-top: 8px; }
.ord-platform table { width: 100%; border-collapse: collapse; }
.ord-platform th, .ord-platform td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--ord-hairline); }
.ord-platform th { background: var(--ord-secondary); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: .5px; color: var(--ord-muted); }
.ord-platform tbody tr:hover { background: color-mix(in srgb, var(--ord-accent) 4%, var(--ord-card)); }
.ord-platform td a { color: var(--ord-accent-ink); text-decoration: none; font-weight: 500; }
.ord-platform td a:hover { text-decoration: underline; }
.ord-platform .table-container { overflow-x: auto; }
.ord-platform .badge { display: inline-block; padding: 4px 10px; border-radius: 9999px; font-size: 12px; font-weight: 500; }
.ord-platform .badge-success { background: color-mix(in srgb, var(--ord-good) 15%, var(--ord-card)); color: var(--ord-good); }
.ord-platform .badge-warning { background: color-mix(in srgb, #b7791f 15%, var(--ord-card)); color: #8a5a12; }
.ord-platform .badge-danger { background: color-mix(in srgb, var(--ord-error) 15%, var(--ord-card)); color: var(--ord-error); }
.ord-platform .badge-info { background: var(--ord-accent-wash); color: var(--ord-accent-ink); }
.ord-platform .badge-gray { background: var(--ord-secondary); color: var(--ord-muted); }
.ord-platform .btn-danger { background: color-mix(in srgb, var(--ord-error) 12%, var(--ord-card)); color: var(--ord-error); }
.ord-platform .btn-danger:hover { background: color-mix(in srgb, var(--ord-error) 20%, var(--ord-card)); }
.ord-platform .toolbar { display: flex; gap: 12px; margin-bottom: 20px; }
.ord-platform .search-input { flex: 1; max-width: 300px; padding: 10px 14px; border: 1px solid var(--ord-border); border-radius: 6px; font-size: 14px; background: var(--ord-card); color: var(--ord-text); }
.ord-platform .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.ord-platform .detail-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 24px; }
.ord-platform .detail-section { margin-bottom: 24px; }
.ord-platform .detail-section h4 { margin: 0 0 16px; color: var(--ord-heading); font-size: 14px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }
.ord-platform .detail-row { display: flex; padding: 10px 0; border-bottom: 1px solid var(--ord-hairline); }
.ord-platform .detail-row:last-child { border-bottom: none; }
.ord-platform .detail-label { width: 160px; font-weight: 500; color: var(--ord-muted); flex-shrink: 0; }
.ord-platform .detail-value { flex: 1; color: var(--ord-text); }
.ord-platform .platform-badge { background: var(--ord-accent); color: #fff; padding: 3px 8px; border-radius: 3px; font-size: 11px; text-transform: uppercase; letter-spacing: .5px; font-weight: 600; }
@media (max-width: 768px) {
  .ord-platform .form-row, .ord-platform .detail-grid { grid-template-columns: 1fr; }
}

/* Platform maintenance-mode banner (was inline per-mode colors). */
.maintenance-banner { padding: 10px 20px; text-align: center; font-size: 14px; font-weight: 500; }
.maintenance-banner a { color: inherit; text-decoration: underline; }
.maintenance-full { background: color-mix(in srgb, var(--ord-error) 15%, var(--ord-card)); color: var(--ord-error); }
.maintenance-operations { background: color-mix(in srgb, #b7791f 15%, var(--ord-card)); color: #8a5a12; }
.maintenance-intake { background: var(--ord-accent-wash); color: var(--ord-accent-ink); }
.maintenance-integrations { background: color-mix(in srgb, #7c3aed 15%, var(--ord-card)); color: #6b21a8; }

/* ============================================================
   Reusable tab component (Settings-style). Tokenized so any admin
   page can adopt it; the Settings page keeps its own local copy.
   ============================================================ */
.ord-tabnav { display: flex; flex-wrap: wrap; gap: 4px; border-bottom: 1px solid var(--ord-hairline); margin-bottom: 20px; }
.ord-tab { background: none; border: none; border-bottom: 2px solid transparent; padding: 10px 14px;
  cursor: pointer; font-size: 14px; color: var(--ord-muted); white-space: nowrap; font-family: inherit; }
.ord-tab:hover { color: var(--ord-heading); }
.ord-tab.active { color: var(--ord-heading); border-bottom-color: var(--ord-accent); font-weight: 600; }
.ord-tab:focus-visible { outline: 2px solid var(--ord-focus); outline-offset: 2px; }
.ord-tabselect { display: none; }
@media (max-width: 768px) {
  .ord-tabnav { display: none; }
  .ord-tabselect { display: block; width: 100%; margin-bottom: 20px; }
}
