/* TrueSpec theme for Swagger UI (/docs).
 * Layered ON TOP of the default swagger-ui.css (injected by the custom /docs
 * route in app/main.py). Palette mirrors the portal's base.html :root.
 * Source of truth for the brand colors: project_brand memory + base.html. */
:root {
  --ts-bg: #f5efe4;            /* cream — page */
  --ts-surface: #ffffff;
  --ts-border: #e7dfd0;        /* cream-border */
  --ts-text: #1b2a33;          /* slate */
  --ts-muted: #7a6f5d;         /* body-brown */
  --ts-primary: #1b2a33;       /* slate — buttons */
  --ts-primary-hover: #18242b; /* ink */
  --ts-accent: #cf8a3b;        /* amber — focus / hover / links */
  --ts-radius: 6px;
}

body { background: var(--ts-bg); }
.swagger-ui { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; }
.swagger-ui,
.swagger-ui .info .title,
.swagger-ui .opblock-tag,
.swagger-ui .opblock .opblock-summary-operation-id,
.swagger-ui .opblock-description-wrapper p,
.swagger-ui .markdown p,
.swagger-ui table thead tr th,
.swagger-ui .parameter__name,
.swagger-ui .response-col_status { color: var(--ts-text); }
.swagger-ui .info .title small,
.swagger-ui .info .title small pre { background: var(--ts-primary); }

/* ---- Branded header (injected by the /docs route; FastAPI's swagger uses
 *      BaseLayout, which has no native topbar) — portal-style white bar ---- */
.ts-docs-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 24px;
  background: var(--ts-surface);
  border-bottom: 1px solid var(--ts-border);
  box-shadow: 0 1px 2px rgba(27, 42, 51, .04);
}
.ts-docs-header .ts-docs-logo img { height: 34px; display: block; }
.ts-docs-header .ts-docs-nav { display: flex; gap: 18px; align-items: center; font-size: 15px; }
.ts-docs-header .ts-docs-nav a { color: var(--ts-text); text-decoration: none; }
.ts-docs-header .ts-docs-nav a:hover { color: var(--ts-accent); }

/* ---- Links ---- */
.swagger-ui a,
.swagger-ui .info a { color: var(--ts-text); }
.swagger-ui a:hover,
.swagger-ui .info a:hover { color: var(--ts-accent); }

/* ---- Buttons (Authorize / Execute / generic) ---- */
.swagger-ui .btn { border-radius: var(--ts-radius); }
.swagger-ui .btn.authorize,
.swagger-ui .btn.execute {
  background: var(--ts-primary);
  color: #fff;
  border-color: var(--ts-primary);
}
.swagger-ui .btn.authorize:hover,
.swagger-ui .btn.execute:hover { background: var(--ts-primary-hover); border-color: var(--ts-primary-hover); }
.swagger-ui .btn.authorize { color: var(--ts-primary); background: var(--ts-surface); }  /* outlined until lock */
.swagger-ui .btn.authorize span { color: var(--ts-primary); }
.swagger-ui .btn.authorize svg { fill: var(--ts-primary); }
.swagger-ui .btn.authorize.locked { background: var(--ts-primary); }
.swagger-ui .btn.authorize.locked span,
.swagger-ui .btn.authorize.locked svg { color: #fff; fill: #fff; }

/* ---- Operation blocks: white cards, brand borders ---- */
.swagger-ui .opblock {
  background: var(--ts-surface);
  border-radius: var(--ts-radius);
  box-shadow: 0 1px 2px rgba(27, 42, 51, .05);
}
.swagger-ui .opblock.opblock-get { border-color: var(--ts-border); }
.swagger-ui .opblock.opblock-get .opblock-summary { border-color: var(--ts-border); }
.swagger-ui .opblock.opblock-get .opblock-summary-method { background: var(--ts-primary); }
.swagger-ui .opblock-tag { border-bottom: 1px solid var(--ts-border); }
.swagger-ui .opblock-tag:hover { background: rgba(207, 138, 59, .06); }

/* ---- Authorize container + form fields ---- */
.swagger-ui .scheme-container {
  background: var(--ts-surface);
  border: 1px solid var(--ts-border);
  border-radius: var(--ts-radius);
  box-shadow: none;
}
.swagger-ui select,
.swagger-ui input[type=text],
.swagger-ui input[type=email],
.swagger-ui input[type=password],
.swagger-ui textarea {
  border-radius: var(--ts-radius);
  border-color: var(--ts-border);
}
.swagger-ui input:focus,
.swagger-ui select:focus,
.swagger-ui textarea:focus { outline: 2px solid var(--ts-accent); outline-offset: 1px; }

/* ---- Models / schemas ---- */
.swagger-ui section.models { background: var(--ts-surface); border-color: var(--ts-border); border-radius: var(--ts-radius); }
.swagger-ui section.models .model-container { background: var(--ts-bg); border-radius: var(--ts-radius); }
.swagger-ui .model-box { border-radius: var(--ts-radius); }
