.elementor-17924 .elementor-element.elementor-element-b2fdf85{--display:flex;}body.elementor-page-17924:not(.elementor-motion-effects-element-type-background), body.elementor-page-17924 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}/* Start custom CSS for html, class: .elementor-element-5722f32 *//* shared-styles.css — minimal, accessible defaults. Scoped to .red */
.red {
  --brand-primary:#0b3d91;
  --brand-accent:#009688;
  --text:#0f172a;
  --muted:#475569;
  --bg:#ffffff;
  --bg-alt:#f8fafc;
  --link:var(--brand-primary);
  --focus:#ffbf47;
  --border:#e2e8f0;
  --radius:16px;
  --maxw: 1000px;
  --space: clamp(0.75rem, 1.2vw, 1rem);
}

.red * {
  box-sizing: border-box;
}

.red html {
  scroll-behavior: smooth;
}

.red body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
  color: var(--text);
  background: var(--bg);
  line-height: 1.6;
}

.red a { color: var(--link); }
.red a:hover { text-decoration-thickness: .12rem; }

.red .skip-link {
  position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden;
}

.red .skip-link:focus {
  left: var(--space); top: var(--space); width: auto; height: auto;
  background: #fff; padding: .5rem .75rem;
  border: 2px solid var(--focus); border-radius: 8px; z-index: 1000;
}

.red header[role="banner"] {
  background: var(--bg-alt); border-bottom: 1px solid var(--border);
}

.red .header-inner {
  max-width: var(--maxw); margin-inline: auto;
  padding: .75rem var(--space);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}

.red .brand {
  display: flex; align-items: center; gap: .75rem;
  text-decoration: none; color: inherit;
}

.red .brand-logo {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand-primary), var(--brand-accent));
  display: inline-block;
}

.red .brand-name {
  font-weight: 700; letter-spacing: .2px;
}

.red .primary-nav ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; gap: 1rem; flex-wrap: wrap;
}

.red .primary-nav a {
  padding: .3rem .5rem; border-radius: 8px;
}

.red .primary-nav a:focus,
.red .primary-nav a:hover {
  outline: 2px solid var(--focus); outline-offset: 2px; text-decoration: none;
}

.red .page-title { margin-top: 1rem; margin-bottom: .25rem; }
.red .meta { color: var(--muted); margin-top: 0; }

.red .toc {
  background: var(--bg-alt); border: 1px solid var(--border);
  padding: 1rem; border-radius: var(--radius);
  margin-block: 1rem 2rem;
}

.red .toc h2 { font-size: 1rem; margin-top: 0; }
.red .toc ul { columns: 2; gap: 1.5rem; padding-left: 1rem; }

/* Scope sections to .red only */
.red section {
  margin-block: 2rem;
  padding: 1rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
}

.red h2, .red h3, .red h4 { scroll-margin-top: 4rem; }
.red h2 { font-size: 32px; }

.red code {
  background: #f1f5f9; padding: .15rem .35rem; border-radius: 6px;
}

.red .notice {
  background: #fffbe6; border: 1px solid #ffe58f;
  padding: .75rem; border-radius: 12px;
}

.red footer {
  border-top: 1px solid var(--border); background: var(--bg-alt);
}

.red .footer-inner {
  max-width: var(--maxw); margin-inline: auto;
  padding: 2rem var(--space); display: grid; gap: 1rem;
}

.red small, .red .small { font-size: .9rem; color: var(--muted); }
.red kbd {
  border: 1px solid var(--border); border-bottom-width: 2px;
  padding: .1rem .25rem; border-radius: 6px; background: #fff;
}

@media (max-width: 700px) {
  .red .toc ul { columns: 1; }
}/* End custom CSS */