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

:root {
  color-scheme: light;
  --eg-red:     #EB3237;
  --eg-red-d:   #cc2a2e;
  --eg-orange:  #F59632;
  --eg-dark:    #4C4B4C;
  --eg-gray:    #5F5F64;
  --eg-light:   #F6F1F1;
  --eg-sidebar: 268px;
  --eg-topbar:  58px;
}

html {
  margin: 0; padding: 0;
  scroll-padding-top: calc(var(--eg-topbar) + 12px);
}
body {
  font-family: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  padding-left: var(--eg-sidebar);
}

/* ── Topbar ───────────────────────────────────────────── */
.eg-topbar {
  background: #fff;
  border-bottom: 3px solid var(--eg-red);
  padding: 0 24px;
  height: var(--eg-topbar);
  display: flex;
  align-items: center;
  gap: 14px;
  box-shadow: 0 1px 6px rgba(0,0,0,.07);
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
}

.eg-topbar img.eg-logo { height: 24px; display: block; }

.eg-topbar-divider { width: 1px; height: 20px; background: #ddd; }

.eg-topbar-label {
  font-size: 12px; font-weight: 700;
  color: var(--eg-gray); letter-spacing: .7px; text-transform: uppercase;
}

.eg-topbar-badge {
  background: var(--eg-red); color: #fff;
  font-size: 10px; font-weight: 700;
  padding: 2px 7px; border-radius: 10px;
  letter-spacing: .6px; text-transform: uppercase;
}

.eg-topbar-links {
  margin-left: auto; display: flex; align-items: center; gap: 4px;
}

.eg-topbar-links a {
  color: var(--eg-gray); text-decoration: none;
  font-size: 13px; font-weight: 600;
  padding: 6px 12px; border-radius: 6px;
  transition: background .15s, color .15s;
}
.eg-topbar-links a:hover { background: var(--eg-light); color: var(--eg-dark); }

.eg-topbar-links a.eg-btn-spec {
  background: var(--eg-red); color: #fff; font-weight: 700;
}
.eg-topbar-links a.eg-btn-spec:hover { background: var(--eg-red-d); color: #fff; }

/* ── Sidebar ──────────────────────────────────────────── */
.eg-sidebar {
  position: fixed;
  top: var(--eg-topbar); left: 0;
  width: var(--eg-sidebar);
  height: calc(100vh - var(--eg-topbar));
  overflow-y: auto;
  background: #fafafa;
  border-right: 1px solid #e8e8e8;
  z-index: 100;
  display: flex;
  flex-direction: column;
}

.eg-sb-search {
  padding: 12px 12px 8px;
  border-bottom: 1px solid #ebebeb;
  position: sticky; top: 0;
  background: #fafafa;
  z-index: 10;
}

.eg-sb-search input {
  width: 100%;
  padding: 6px 10px;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-size: 12px;
  font-family: inherit;
  color: var(--eg-dark);
  background: #fff;
  outline: none;
  transition: border-color .15s;
}
.eg-sb-search input:focus { border-color: var(--eg-red); }
.eg-sb-search input::placeholder { color: #bbb; }

#eg-sb-content { padding: 8px 0 24px; flex: 1; }

.eg-sb-section { margin-bottom: 4px; }

.eg-sb-tag {
  display: flex; align-items: center;
  padding: 7px 14px;
  font-size: 11px; font-weight: 700;
  color: var(--eg-gray);
  letter-spacing: .6px; text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: color .15s;
  gap: 6px;
  user-select: none;
}
.eg-sb-tag:hover { color: var(--eg-red); }
.eg-sb-tag .eg-sb-chevron {
  flex-shrink: 0; margin-left: auto;
  transition: transform .2s ease;
}
.eg-sb-section.open .eg-sb-chevron { transform: rotate(90deg); }

.eg-sb-endpoints {
  display: flex; flex-direction: column;
  overflow: hidden;
  max-height: 0;
  transition: max-height .25s ease;
}
.eg-sb-section.open .eg-sb-endpoints { max-height: 2000px; }

.eg-sb-endpoint {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 14px 5px 20px;
  text-decoration: none;
  font-size: 12px;
  color: var(--eg-dark);
  border-left: 2px solid transparent;
  transition: background .12s, border-color .12s, color .12s;
  white-space: nowrap; overflow: hidden;
}
.eg-sb-endpoint:hover {
  background: #f0f0f0;
  border-left-color: var(--eg-red);
}
.eg-sb-endpoint.active {
  background: #fdf0f0;
  border-left-color: var(--eg-red);
  color: var(--eg-red);
}

.eg-sb-method {
  font-size: 9px; font-weight: 800;
  padding: 2px 5px; border-radius: 3px;
  color: #fff; flex-shrink: 0;
  letter-spacing: .4px; text-transform: uppercase;
  min-width: 36px; text-align: center;
}
.eg-sb-method.get    { background: #2d7dd2; }
.eg-sb-method.post   { background: #198754; }
.eg-sb-method.put    { background: var(--eg-orange); }
.eg-sb-method.delete { background: var(--eg-red); }

.eg-sb-path {
  overflow: hidden; text-overflow: ellipsis;
  font-size: 12px; line-height: 1.3;
}

/* ── Conteúdo principal ───────────────────────────────── */
.eg-main { padding-top: var(--eg-topbar); }

/* ── Ocultar topbar nativa do Swagger UI ──────────────── */
.swagger-ui .topbar { display: none !important; }

/* ── Info / description ───────────────────────────────── */
.swagger-ui .info { margin: 28px 0 4px; }
.swagger-ui .info .title { font-size: 24px; color: var(--eg-dark); font-weight: 700; }
.swagger-ui .info .description p { color: var(--eg-gray); font-size: 14px; }
.swagger-ui .info a { color: var(--eg-red); }

/* Divisores entre seções do description */
.swagger-ui .info .renderedMarkdown h2 {
  font-size: 15px;
  font-weight: 700;
  color: var(--eg-dark);
  margin: 28px 0 10px;
  padding-top: 20px;
  border-top: 1px solid #e8e8e8;
}
.swagger-ui .info .renderedMarkdown h2:first-child { border-top: none; margin-top: 12px; }

/* ── Scheme container ─────────────────────────────────── */
.swagger-ui .scheme-container {
  background: #fafafa; box-shadow: none;
  border-bottom: 1px solid #ebebeb; padding: 10px 0;
}

/* ── Tags (grupos) ────────────────────────────────────── */
.swagger-ui .opblock-tag { border-bottom: 1px solid #ebebeb; color: var(--eg-dark); }
.swagger-ui .opblock-tag:hover,
.swagger-ui .opblock-tag:focus { background: rgba(235,50,55,.04) !important; }
.swagger-ui .opblock-tag small { color: var(--eg-gray); }

/* ── Método badges ────────────────────────────────────── */
.swagger-ui .opblock.opblock-get    .opblock-summary-method { background: #2d7dd2; }
.swagger-ui .opblock.opblock-post   .opblock-summary-method { background: #198754; }
.swagger-ui .opblock.opblock-put    .opblock-summary-method { background: var(--eg-orange); }
.swagger-ui .opblock.opblock-delete .opblock-summary-method { background: var(--eg-red); }

.swagger-ui .opblock.opblock-get    { border-color: #2d7dd2; background: rgba(45,125,210,.03); }
.swagger-ui .opblock.opblock-post   { border-color: #198754; background: rgba(25,135,84,.03); }
.swagger-ui .opblock.opblock-put    { border-color: #F59632; background: rgba(245,150,50,.03); }
.swagger-ui .opblock.opblock-delete { border-color: #EB3237; background: rgba(235,50,55,.03); }

/* ── Botões ───────────────────────────────────────────── */
.swagger-ui .btn.authorize { border-color: var(--eg-red); color: var(--eg-red); }
.swagger-ui .btn.authorize svg { fill: var(--eg-red); }
.swagger-ui .btn.authorize:hover, .swagger-ui .btn.authorize:focus { background: var(--eg-red); color: #fff; }
.swagger-ui .btn.authorize:hover svg, .swagger-ui .btn.authorize:focus svg { fill: #fff; }
.swagger-ui .btn.execute { background: var(--eg-red); border-color: var(--eg-red); }
.swagger-ui .btn.execute:hover { background: var(--eg-red-d); border-color: var(--eg-red-d); }

/* ── Code inline ──────────────────────────────────────── */
.swagger-ui :not(pre) > code {
  color: var(--eg-dark) !important;
  background: #f0eded !important;
  border: 1px solid #ddd !important;
  border-radius: 4px !important;
  padding: 1px 6px !important;
  font-size: 12px !important;
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace !important;
}

/* ── Bloco de código (pre.microlight) ─────────────────── */
.swagger-ui pre.microlight { background: #1e1e1e !important; border-radius: 6px !important; }
.swagger-ui .microlight code,
.swagger-ui .microlight span:not([style]) {
  color: inherit !important; background: transparent !important;
  border: none !important; padding: 0 !important; font-size: inherit !important;
}
.swagger-ui .microlight ::selection { background: rgba(255,255,255,.25) !important; color: #fff !important; }

/* ── Opblock body ─────────────────────────────────────── */
.swagger-ui .opblock .opblock-body { background: #fff !important; }
.swagger-ui .opblock.opblock-get    .opblock-body { border-top: 1px solid rgba(45,125,210,.2); }
.swagger-ui .opblock.opblock-post   .opblock-body { border-top: 1px solid rgba(25,135,84,.2); }
.swagger-ui .opblock.opblock-put    .opblock-body { border-top: 1px solid rgba(245,150,50,.2); }
.swagger-ui .opblock.opblock-delete .opblock-body { border-top: 1px solid rgba(235,50,55,.2); }

/* ── Badges de versão ocultos ─────────────────────────── */
.swagger-ui .info .title span { display: none; }

/* ── Enum com scroll ──────────────────────────────────── */
.swagger-ui .renderedMarkdown p { word-break: break-word; }
.swagger-ui .parameter__enum {
  max-height: 130px; overflow-y: auto; font-size: 11px; color: var(--eg-gray);
  border: 1px solid #ebebeb; border-radius: 4px;
  padding: 6px 8px; margin-top: 4px; background: #fafafa;
}

/* ── Links ────────────────────────────────────────────── */
.swagger-ui a { color: var(--eg-red); }
.swagger-ui a:hover { color: var(--eg-red-d); }

/* ── INVALID badge oculto ─────────────────────────────── */
.swagger-ui .validation-errors { display: none !important; }

/* ── Scrollbar ────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: #f1f1f1; }
::-webkit-scrollbar-thumb { background: #ccc; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--eg-red); }
