/* ==========================================================================
   ContentCreator Tailored UI — Documentation
   Visual design: FirstSpirit Brand & Design System (design.html)
   ========================================================================== */

/* ---- 1. TOKENS ---------------------------------------------------------- */
:root {
  /* Brand colors — ink */
  --fs-ink:        #1A1616;
  --fs-ink-80:     #46413f;
  --fs-ink-60:     #736e6c;
  --fs-ink-40:     #a3a09e;

  /* Brand colors — purple */
  --fs-purple:        #BD2EFF;
  --fs-purple-deep:   #8F18FF;
  --fs-purple-light:  #B5A8FF;

  /* Brand colors — blue */
  --fs-blue-deep:  #0000B0;
  --fs-blue:       #47ACFF;

  /* Surfaces & backgrounds */
  --fs-white:      #FFFFFF;
  --fs-paper:      #F4F6FA;
  --fs-bg-1:       #E4E7EF;
  --fs-bg-2:       #C7CDDE;
  --fs-line:       #DDE1EB;
  --fs-line-soft:  #EAEDF3;

  /* Signature gradient */
  --fs-gradient:        linear-gradient(135deg, #8F18FF 0%, #47ACFF 100%);
  --fs-gradient-purple: linear-gradient(135deg, #BD2EFF 0%, #8F18FF 100%);
  --fs-gradient-soft:   linear-gradient(135deg, #B5A8FF 0%, #47ACFF 100%);

  /* Semantic */
  --fs-success: #1F8A5B;
  --fs-warning: #C9821B;
  --fs-danger:  #C8344B;

  /* Typography */
  --fs-font: "Public Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  --fs-w-regular: 400;
  --fs-w-medium:  500;
  --fs-w-semi:    600;
  --fs-w-bold:    700;
  --fs-w-extra:   800;

  /* Type scale */
  --fs-h1:      2.25rem;   /* 36px */
  --fs-h2:      1.5rem;    /* 24px */
  --fs-h3:      1.125rem;  /* 18px */
  --fs-h4:      1rem;      /* 16px */
  --fs-body:    0.9375rem; /* 15px */
  --fs-small:   0.8125rem; /* 13px */
  --fs-caption: 0.75rem;   /* 12px */

  /* Spacing */
  --fs-1: 4px;   --fs-2: 8px;    --fs-3: 12px;  --fs-4: 16px;
  --fs-5: 24px;  --fs-6: 32px;   --fs-7: 48px;  --fs-8: 64px;
  --fs-9: 80px;

  /* Radii */
  --fs-r-sm:   6px;
  --fs-r-md:   10px;
  --fs-r-lg:   16px;
  --fs-r-pill: 999px;

  /* Shadows */
  --fs-shadow-sm: 0 1px 2px rgba(26,22,22,.06), 0 2px 6px rgba(26,22,22,.05);
  --fs-shadow-md: 0 4px 12px rgba(26,22,22,.08), 0 1px 3px rgba(26,22,22,.04);
  --fs-glow:      0 8px 28px rgba(143,24,255,.22);
}

/* ---- 2. RESET & BASE ---------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--fs-font);
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--fs-ink);
  background: var(--fs-bg-1);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-weight: var(--fs-w-extra);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--fs-ink);
}

p { margin: 0; text-wrap: pretty; }
a { color: var(--fs-purple-deep); text-decoration: none; }
a:hover { text-decoration: underline; }
strong { font-weight: var(--fs-w-bold); color: var(--fs-ink); }

code, .mono {
  font-family: "SFMono-Regular", ui-monospace, "Cascadia Code", Menlo, Consolas, monospace;
  font-size: 0.84em;
  background: color-mix(in srgb, var(--fs-purple-light) 18%, white);
  color: var(--fs-purple-deep);
  padding: 2px 6px;
  border-radius: 4px;
}

/* ---- 3. SHELL LAYOUT ---------------------------------------------------- */
.fs-shell {
  display: grid;
  grid-template-columns: 264px 1fr 220px;
  min-height: 100vh;
}

/* ---- 4. SIDEBAR --------------------------------------------------------- */
.fs-sidebar {
  position: sticky;
  top: 0;
  align-self: start;
  height: 100vh;
  background: var(--fs-white);
  border-right: 1px solid var(--fs-line);
  padding: var(--fs-5) var(--fs-4);
  display: flex;
  flex-direction: column;
  gap: var(--fs-4);
  overflow-y: auto;
  flex-shrink: 0;
}

.fs-brand {
  display: flex;
  align-items: center;
  gap: 11px;
  padding-bottom: var(--fs-4);
  border-bottom: 1px solid var(--fs-line-soft);
}

.fs-brand-mark {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: var(--fs-gradient);
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: var(--fs-w-extra);
  font-size: 17px;
  box-shadow: var(--fs-glow);
  flex-shrink: 0;
}

.fs-brand-name {
  font-weight: var(--fs-w-extra);
  font-size: 16px;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--fs-ink);
}

.fs-brand-sub {
  font-size: 10px;
  color: var(--fs-ink-60);
  font-weight: var(--fs-w-semi);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-top: 1px;
}

.fs-nav { display: flex; flex-direction: column; gap: 1px; }

.fs-nav a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 11px;
  border-radius: var(--fs-r-md);
  color: var(--fs-ink-80);
  font-size: 13.5px;
  font-weight: var(--fs-w-medium);
  transition: background .13s, color .13s;
  text-decoration: none;
}

.fs-nav a:hover { background: var(--fs-paper); color: var(--fs-ink); }

.fs-nav a.is-active {
  background: color-mix(in srgb, var(--fs-purple-light) 22%, white);
  color: var(--fs-purple-deep);
  font-weight: var(--fs-w-semi);
  box-shadow: inset 2px 0 0 var(--fs-purple-deep);
}

.fs-nav-label {
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fs-ink-40);
  font-weight: var(--fs-w-bold);
  padding: var(--fs-3) 11px var(--fs-1);
}

.fs-sidebar-footer {
  margin-top: auto;
  font-size: 11px;
  color: var(--fs-ink-40);
  line-height: 1.6;
  padding-top: var(--fs-4);
  border-top: 1px solid var(--fs-line-soft);
}

/* ---- 5. MAIN CONTENT ---------------------------------------------------- */
.fs-main {
  background: var(--fs-white);
  min-width: 0;
}

.doc-page {
  position: relative;
  max-width: 900px;
  padding: var(--fs-8) var(--fs-8) var(--fs-9);
}

/* ---- 6. PAGE HEADER ----------------------------------------------------- */
.doc-header {
  margin-bottom: var(--fs-7);
}

.doc-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: var(--fs-w-bold);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fs-purple-deep);
  margin-bottom: var(--fs-3);
}

.doc-kicker::before {
  content: "";
  width: 20px; height: 2px;
  background: var(--fs-gradient);
  border-radius: 2px;
}

.doc-title {
  font-size: var(--fs-h1);
  letter-spacing: -0.025em;
  line-height: 1.1;
  color: var(--fs-ink);
  margin-bottom: var(--fs-4);
}

.doc-intro {
  font-size: 1rem;
  color: var(--fs-ink-80);
  line-height: 1.7;
  max-width: 68ch;
}

/* ---- 7. CONTENT SECTIONS ------------------------------------------------ */
.doc-section {
  margin-bottom: var(--fs-8);
  scroll-margin-top: 32px;
}

.doc-section + .doc-section {
  border-top: 1px solid var(--fs-line);
  padding-top: var(--fs-7);
}

.doc-section h2 {
  font-size: var(--fs-h2);
  letter-spacing: -0.02em;
  margin-bottom: var(--fs-4);
  color: var(--fs-ink);
}

.doc-section h3 {
  font-size: var(--fs-h3);
  font-weight: var(--fs-w-bold);
  letter-spacing: -0.01em;
  margin-top: var(--fs-6);
  margin-bottom: var(--fs-3);
  color: var(--fs-ink);
}

.doc-section h4 {
  font-size: var(--fs-h4);
  font-weight: var(--fs-w-bold);
  margin-top: var(--fs-5);
  margin-bottom: var(--fs-2);
  color: var(--fs-ink);
}

.doc-section p {
  font-size: var(--fs-body);
  color: var(--fs-ink-80);
  line-height: 1.65;
  margin-bottom: var(--fs-3);
}

.doc-section p:last-child { margin-bottom: 0; }

.doc-section ul, .doc-section ol {
  padding-left: var(--fs-5);
  margin-bottom: var(--fs-3);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.doc-section li {
  font-size: var(--fs-body);
  color: var(--fs-ink-80);
  line-height: 1.55;
}

.doc-section ul li::marker { color: var(--fs-purple); }
.doc-section ol li::marker { color: var(--fs-purple-deep); font-weight: var(--fs-w-bold); }

/* ---- 8. TABLES ---------------------------------------------------------- */
.info-table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--fs-4) 0 var(--fs-5);
  font-size: 13.5px;
  border-radius: var(--fs-r-md);
  overflow: hidden;
  border: 1px solid var(--fs-line);
}

.info-table th {
  text-align: left;
  background: var(--fs-paper);
  font-size: 11px;
  font-weight: var(--fs-w-bold);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--fs-ink-60);
  padding: 10px 14px;
  border-bottom: 1px solid var(--fs-line);
}

.info-table td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--fs-line-soft);
  color: var(--fs-ink-80);
  vertical-align: top;
  line-height: 1.5;
}

.info-table tr:last-child td { border-bottom: none; }

.info-table tr:hover td { background: var(--fs-paper); }

.info-table td code {
  font-size: 12px;
  white-space: nowrap;
}

.info-table td strong { color: var(--fs-ink); }

/* ---- 9. INFO / ALERT BOXES ---------------------------------------------- */
.info-box {
  display: flex;
  gap: var(--fs-4);
  background: color-mix(in srgb, var(--fs-blue) 8%, white);
  border: 1px solid color-mix(in srgb, var(--fs-blue) 28%, transparent);
  border-radius: var(--fs-r-md);
  padding: var(--fs-4) var(--fs-5);
  margin: var(--fs-4) 0;
}

.info-box::before {
  content: "i";
  width: 22px; height: 22px;
  background: var(--fs-blue);
  color: #fff;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-weight: var(--fs-w-bold);
  font-size: 13px;
  flex-shrink: 0;
  margin-top: 1px;
  font-style: italic;
  font-family: Georgia, serif;
}

.alert-box {
  display: flex;
  gap: var(--fs-4);
  background: color-mix(in srgb, var(--fs-warning) 8%, white);
  border: 1px solid color-mix(in srgb, var(--fs-warning) 28%, transparent);
  border-radius: var(--fs-r-md);
  padding: var(--fs-4) var(--fs-5);
  margin: var(--fs-4) 0;
  color: var(--fs-ink-80);
  font-size: 14px;
  line-height: 1.55;
}

.alert-box::before {
  content: "!";
  width: 22px; height: 22px;
  background: var(--fs-warning);
  color: #fff;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-weight: var(--fs-w-bold);
  font-size: 13px;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ---- 10. CODE BLOCKS ---------------------------------------------------- */
.card.code-box,
.doc-code {
  background: var(--fs-ink);
  border-radius: var(--fs-r-md);
  padding: var(--fs-5) var(--fs-5);
  margin: var(--fs-4) 0;
  overflow-x: auto;
}

.card.code-box pre,
.doc-code pre {
  margin: 0;
  font-family: "SFMono-Regular", ui-monospace, Menlo, Consolas, monospace;
  font-size: 12.5px;
  line-height: 1.65;
  color: #e4e7ef;
  white-space: pre;
}

.card.code-box code,
.doc-code code {
  background: transparent;
  color: inherit;
  padding: 0;
  font-size: inherit;
}

/* override codehilite span colors — keep as plain white-on-dark */
.codehilite span { color: #c7cdde !important; }
.codehilite .err { color: #b5a8ff !important; }
.codehilite .k, .codehilite .kd { color: #47acff !important; }
.codehilite .nt, .codehilite .nb { color: #bd2eff !important; }
.codehilite .s2, .codehilite .s { color: #b5d8ff !important; }
.codehilite .mi { color: #47acff !important; }
.codehilite .kc { color: #bd2eff !important; }

/* ---- 11. AVAILABILITY BADGES -------------------------------------------- */
.avail-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11.5px;
  font-weight: var(--fs-w-bold);
  padding: 3px 9px;
  border-radius: var(--fs-r-pill);
  white-space: nowrap;
}

.avail-badge--available  { background: color-mix(in srgb, var(--fs-success) 14%, white); color: var(--fs-success); }
.avail-badge--groups     { background: color-mix(in srgb, var(--fs-purple-light) 28%, white); color: var(--fs-purple-deep); }
.avail-badge--unavailable{ background: color-mix(in srgb, var(--fs-danger) 12%, white); color: var(--fs-danger); }
.avail-badge--disabled   { background: var(--fs-bg-1); color: var(--fs-ink-60); }

/* ---- 12. FOCUS VISIBLE -------------------------------------------------- */
a:focus-visible,
.fs-nav a:focus-visible,
.doc-toc-nav a:focus-visible {
  outline: 2px solid var(--fs-purple-deep);
  outline-offset: 2px;
  border-radius: var(--fs-r-sm);
  text-decoration: none;
}

/* ---- 12b. HR ------------------------------------------------------------- */
hr {
  border: none;
  border-top: 1px solid var(--fs-line);
  margin: var(--fs-6) 0;
}

/* ---- 13. BLOCKQUOTE ----------------------------------------------------- */
blockquote {
  border-left: 3px solid var(--fs-purple-light);
  padding: var(--fs-3) var(--fs-5);
  margin: var(--fs-4) 0;
  background: var(--fs-paper);
  border-radius: 0 var(--fs-r-sm) var(--fs-r-sm) 0;
  color: var(--fs-ink-80);
  font-size: 14px;
  line-height: 1.6;
}

/* ---- 14. RIGHT TOC SIDEBAR ---------------------------------------------- */
.doc-toc {
  position: sticky;
  top: 0;
  align-self: start;
  height: 100vh;
  background: var(--fs-white);
  border-left: 1px solid var(--fs-line);
  padding: var(--fs-8) var(--fs-4) var(--fs-6);
  overflow-y: auto;
  flex-shrink: 0;
}

.doc-toc .fs-nav-label {
  margin-bottom: var(--fs-3);
}

.doc-toc-nav {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.doc-toc-nav a {
  display: block;
  padding: 6px 10px;
  border-radius: var(--fs-r-sm);
  color: var(--fs-ink-60);
  font-size: 12px;
  font-weight: var(--fs-w-medium);
  text-decoration: none;
  line-height: 1.4;
  transition: color .13s, background .13s;
}

.doc-toc-nav a:hover {
  color: var(--fs-ink);
  background: var(--fs-paper);
  text-decoration: none;
}

.doc-toc-nav a.is-active {
  color: var(--fs-purple-deep);
  background: color-mix(in srgb, var(--fs-purple-light) 14%, white);
  font-weight: var(--fs-w-semi);
  box-shadow: inset 2px 0 0 var(--fs-purple-deep);
}

/* ---- 15. FOOTER --------------------------------------------------------- */
.doc-footer {
  border-top: 1px solid var(--fs-line);
  padding: var(--fs-6) var(--fs-8);
  background: var(--fs-white);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--fs-4);
  flex-wrap: wrap;
}

.doc-footer-text {
  font-size: 12px;
  color: var(--fs-ink-60);
}

.doc-footer a {
  font-size: 12px;
  color: var(--fs-purple-deep);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.doc-footer svg {
  width: 15px; height: 15px;
  fill: currentColor;
}

/* ---- 15. RESPONSIVE ----------------------------------------------------- */
@media (max-width: 1300px) {
  .fs-shell { grid-template-columns: 264px 1fr; }
  .doc-toc { display: none; }
}

@media (max-width: 1024px) {
  .fs-shell { grid-template-columns: 240px 1fr; }
  .doc-page { padding: var(--fs-7) var(--fs-6) var(--fs-8); }
  .md-copy-btn { top: var(--fs-7); right: var(--fs-6); }
}

@media (max-width: 768px) {
  .fs-shell { grid-template-columns: 1fr; }
  .fs-sidebar {
    position: static;
    height: auto;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    border-right: none;
    border-bottom: 1px solid var(--fs-line);
    padding: var(--fs-3) var(--fs-4);
  }
  .fs-brand { padding-bottom: 0; border-bottom: none; }
  .fs-nav { flex-direction: row; flex-wrap: wrap; gap: 0; }
  .fs-nav-label { display: none; }
  .fs-sidebar-footer { display: none; }
  .doc-page { padding: var(--fs-5) var(--fs-4) var(--fs-7); }
  .md-copy-btn {
    position: static;
    display: inline-flex;
    margin-bottom: var(--fs-4);
  }
  .info-table { font-size: 12px; }
  .info-table th, .info-table td { padding: 8px 10px; }
  .doc-section { overflow-x: auto; }
}

/* ---- 16. COPY BUTTON (optional — wrap code-box with .code-wrap) --------- */
.code-wrap {
  position: relative;
}
.code-copy-btn {
  position: absolute;
  top: 10px;
  right: 10px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.16);
  color: rgba(255,255,255,0.55);
  border-radius: var(--fs-r-sm);
  padding: 3px 10px;
  font-size: 11px;
  font-family: var(--fs-font);
  font-weight: var(--fs-w-medium);
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background .13s, color .13s;
  line-height: 1.8;
}
.code-copy-btn:hover { background: rgba(255,255,255,0.18); color: #fff; }
.code-copy-btn.copied { color: var(--fs-blue); border-color: rgba(71,172,255,0.38); }

/* ---- 16b. "COPY AS MARKDOWN" PAGE BUTTON ------------------------------- */
.md-copy-btn {
  position: absolute;
  top: var(--fs-8);
  right: var(--fs-8);
  z-index: 5;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--fs-white);
  border: 1px solid var(--fs-line);
  color: var(--fs-purple-deep);
  border-radius: var(--fs-r-pill);
  padding: 7px 14px;
  font-family: var(--fs-font);
  font-size: 12.5px;
  font-weight: var(--fs-w-semi);
  letter-spacing: 0.01em;
  cursor: pointer;
  box-shadow: var(--fs-shadow-sm);
  transition: border-color .13s, color .13s, box-shadow .13s, background .13s;
}
.md-copy-btn:hover { border-color: var(--fs-purple); box-shadow: var(--fs-shadow-md); }
.md-copy-btn svg { width: 14px; height: 14px; fill: currentColor; }
.md-copy-btn.copied { color: var(--fs-success); border-color: color-mix(in srgb, var(--fs-success) 45%, transparent); }
.md-copy-btn.failed { color: var(--fs-danger); border-color: color-mix(in srgb, var(--fs-danger) 45%, transparent); }

/* ---- 17. PRINT ---------------------------------------------------------- */
@media print {
  .fs-sidebar, .doc-toc, .md-copy-btn { display: none; }
  .fs-shell { grid-template-columns: 1fr; }
  .doc-page { padding: 0; max-width: 100%; }
}

/* ---- 18. SIDEBAR "BACK TO PORTAL" LINK ---------------------------------- */
.fs-nav-home {
  color: var(--fs-ink-60) !important;
  font-weight: var(--fs-w-semi) !important;
  font-size: 12.5px !important;
}
.fs-nav-home:hover { color: var(--fs-purple-deep) !important; }

/* ---- 19. DOCUMENTATION PORTAL ------------------------------------------- */
.doc-portal {
  min-height: 100vh;
  background: var(--fs-bg-1);
  display: flex;
  flex-direction: column;
}

.doc-portal-inner {
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
  padding: var(--fs-9) var(--fs-6) var(--fs-8);
  flex: 1;
}

.doc-portal-header {
  margin-bottom: var(--fs-7);
}

.doc-portal-brand {
  display: flex;
  align-items: center;
  gap: 13px;
  margin-bottom: var(--fs-5);
}

.doc-portal-brand .fs-brand-mark {
  width: 44px; height: 44px;
  font-size: 19px;
}

.doc-portal-brand-name {
  font-weight: var(--fs-w-extra);
  font-size: 18px;
  letter-spacing: -0.02em;
  color: var(--fs-ink);
  line-height: 1.15;
}

.doc-portal-brand-sub {
  font-size: 10px;
  color: var(--fs-ink-60);
  font-weight: var(--fs-w-semi);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-top: 1px;
}

.doc-portal-title {
  font-size: var(--fs-h1);
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin-bottom: var(--fs-4);
}

.doc-portal-intro {
  font-size: 1rem;
  color: var(--fs-ink-80);
  line-height: 1.7;
  max-width: 68ch;
}

.doc-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--fs-5);
}

.doc-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--fs-white);
  border: 1px solid var(--fs-line);
  border-radius: var(--fs-r-lg);
  padding: var(--fs-5);
  box-shadow: var(--fs-shadow-sm);
  text-decoration: none;
  overflow: hidden;
  transition: box-shadow .16s, transform .16s, border-color .16s;
}

.doc-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--fs-gradient);
}

.doc-card:hover {
  box-shadow: var(--fs-shadow-md);
  transform: translateY(-2px);
  border-color: var(--fs-purple-light);
  text-decoration: none;
}

.doc-card-kicker {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: var(--fs-w-bold);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fs-purple-deep);
  margin-bottom: var(--fs-3);
}

.doc-card-title {
  font-size: 1.0625rem;
  font-weight: var(--fs-w-extra);
  letter-spacing: -0.015em;
  color: var(--fs-ink);
  line-height: 1.25;
  margin-bottom: var(--fs-2);
}

.doc-card-desc {
  font-size: 13.5px;
  color: var(--fs-ink-80);
  line-height: 1.55;
  margin-bottom: var(--fs-4);
}

.doc-card-meta {
  margin-top: auto;
  font-size: 11.5px;
  color: var(--fs-ink-40);
  font-weight: var(--fs-w-medium);
}

@media (max-width: 768px) {
  .doc-portal-inner { padding: var(--fs-7) var(--fs-4) var(--fs-6); }
  .doc-card-grid { grid-template-columns: 1fr; }
}

/* ---- 20. BRAND LOGO ----------------------------------------------------- */
/* Sidebar brand variant when using the wordmark logo instead of the "FS" tile */
.fs-brand--logo {
  flex-direction: column;
  align-items: flex-start;
  gap: var(--fs-2);
}
.fs-brand-logo {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
}
/* Portal header logo */
.doc-portal-brand--logo {
  flex-direction: column;
  align-items: flex-start;
  gap: var(--fs-3);
}
.doc-portal-logo {
  display: block;
  width: 100%;
  height: auto;
  max-width: 420px;
}
@media (max-width: 768px) {
  .doc-portal-logo { max-width: 260px; }
}
@media (max-width: 768px) {
  .fs-brand--logo { flex-direction: row; align-items: center; }
  .fs-brand-logo { width: auto; height: 22px; }
}

/* ---- 21. AI-GENERATED NOTICE -------------------------------------------- */
.ai-notice {
  display: flex;
  align-items: flex-start;
  gap: var(--fs-3);
  background: color-mix(in srgb, var(--fs-purple-light) 14%, white);
  border: 1px solid color-mix(in srgb, var(--fs-purple) 28%, transparent);
  border-radius: var(--fs-r-md);
  padding: var(--fs-3) var(--fs-4);
  margin-bottom: var(--fs-7);
  font-size: 13px;
  color: var(--fs-ink-80);
  line-height: 1.5;
}
.ai-notice-badge {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: var(--fs-w-extra);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #fff;
  background: var(--fs-gradient-purple);
  padding: 4px 9px;
  border-radius: var(--fs-r-pill);
  white-space: nowrap;
  margin-top: 1px;
}
.ai-notice strong { color: var(--fs-ink); }

/* Compact inline variant for the portal */
.ai-notice--portal { margin: var(--fs-5) 0 0; }
